mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-10 07:00:48 +00:00
drm/ttm: Fix accesses through vmas with only partial coverage
VMAs covering a bo but that didn't start at the same address space offset as the bo they were mapping were incorrectly generating SEGFAULT errors in the fault handler. Reported-by: Joseph Dolinak <kanilo2@yahoo.com> Signed-off-by: Thomas Hellstrom <thellstrom@vmware.com> Reviewed-by: Jakob Bornecrantz <jakob@vmware.com> Cc: stable@vger.kernel.org
This commit is contained in:
parent
9255ce80f8
commit
d386735588
@ -169,9 +169,9 @@ static int ttm_bo_vm_fault(struct vm_area_struct *vma, struct vm_fault *vmf)
|
|||||||
}
|
}
|
||||||
|
|
||||||
page_offset = ((address - vma->vm_start) >> PAGE_SHIFT) +
|
page_offset = ((address - vma->vm_start) >> PAGE_SHIFT) +
|
||||||
drm_vma_node_start(&bo->vma_node) - vma->vm_pgoff;
|
vma->vm_pgoff - drm_vma_node_start(&bo->vma_node);
|
||||||
page_last = vma_pages(vma) +
|
page_last = vma_pages(vma) + vma->vm_pgoff -
|
||||||
drm_vma_node_start(&bo->vma_node) - vma->vm_pgoff;
|
drm_vma_node_start(&bo->vma_node);
|
||||||
|
|
||||||
if (unlikely(page_offset >= bo->num_pages)) {
|
if (unlikely(page_offset >= bo->num_pages)) {
|
||||||
retval = VM_FAULT_SIGBUS;
|
retval = VM_FAULT_SIGBUS;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user