]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/blame - releases/2.6.32.27/drm-ttm-clear-the-ghost-cpu_writers-flag-on-ttm_buffer_object_transfer.patch
4.14-stable patches
[thirdparty/kernel/stable-queue.git] / releases / 2.6.32.27 / drm-ttm-clear-the-ghost-cpu_writers-flag-on-ttm_buffer_object_transfer.patch
CommitLineData
ea66788a
GKH
1From 0fbecd400dd0a82d465b3086f209681e8c54cb0f Mon Sep 17 00:00:00 2001
2From: Francisco Jerez <currojerez@riseup.net>
3Date: Tue, 21 Sep 2010 02:15:15 +0200
4Subject: drm/ttm: Clear the ghost cpu_writers flag on ttm_buffer_object_transfer.
5
6From: Francisco Jerez <currojerez@riseup.net>
7
8commit 0fbecd400dd0a82d465b3086f209681e8c54cb0f upstream.
9
10It makes sense for a BO to move after a process has requested
11exclusive RW access on it (e.g. because the BO used to be located in
12unmappable VRAM and we intercepted the CPU access from the fault
13handler).
14
15If we let the ghost object inherit cpu_writers from the original
16object, ttm_bo_release_list() will raise a kernel BUG when the ghost
17object is destroyed. This can be reproduced with the nouveau driver on
18nv5x.
19
20Reported-by: Marcin Slusarz <marcin.slusarz@gmail.com>
21Reviewed-by: Jerome Glisse <jglisse@redhat.com>
22Tested-by: Marcin Slusarz <marcin.slusarz@gmail.com>
23Signed-off-by: Francisco Jerez <currojerez@riseup.net>
24Signed-off-by: Dave Airlie <airlied@redhat.com>
25Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
26
27---
28 drivers/gpu/drm/ttm/ttm_bo_util.c | 1 +
29 1 file changed, 1 insertion(+)
30
31--- a/drivers/gpu/drm/ttm/ttm_bo_util.c
32+++ b/drivers/gpu/drm/ttm/ttm_bo_util.c
33@@ -330,6 +330,7 @@ static int ttm_buffer_object_transfer(st
34 INIT_LIST_HEAD(&fbo->lru);
35 INIT_LIST_HEAD(&fbo->swap);
36 fbo->vm_node = NULL;
37+ atomic_set(&fbo->cpu_writers, 0);
38
39 fbo->sync_obj = driver->sync_obj_ref(bo->sync_obj);
40 if (fbo->mem.mm_node)