mirror of
https://github.com/adulau/aha.git
synced 2024-12-30 20:56:23 +00:00
PCI: fix range check on mmapped sysfs resource files
pci_mmap_fits() returns the wrong answer if the sysfs resource file size is not a multiple of the page size. vm_end and vm_start are already page-aligned, so size - start < nr, causing mmap() to return EINVAL. Signed-off-by: Ed Swierk <eswierk@aristanetworks.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
This commit is contained in:
parent
f5dafca52d
commit
88e7df0b7e
1 changed files with 1 additions and 1 deletions
|
@ -575,7 +575,7 @@ static int pci_mmap_fits(struct pci_dev *pdev, int resno, struct vm_area_struct
|
||||||
|
|
||||||
nr = (vma->vm_end - vma->vm_start) >> PAGE_SHIFT;
|
nr = (vma->vm_end - vma->vm_start) >> PAGE_SHIFT;
|
||||||
start = vma->vm_pgoff;
|
start = vma->vm_pgoff;
|
||||||
size = pci_resource_len(pdev, resno) >> PAGE_SHIFT;
|
size = ((pci_resource_len(pdev, resno) - 1) >> PAGE_SHIFT) + 1;
|
||||||
if (start < size && size - start >= nr)
|
if (start < size && size - start >= nr)
|
||||||
return 1;
|
return 1;
|
||||||
WARN(1, "process \"%s\" tried to map 0x%08lx-0x%08lx on %s BAR %d (size 0x%08lx)\n",
|
WARN(1, "process \"%s\" tried to map 0x%08lx-0x%08lx on %s BAR %d (size 0x%08lx)\n",
|
||||||
|
|
Loading…
Reference in a new issue