On Thu, Jan 05, 2012 at 09:14:10PM -0500, Konrad Rzeszutek Wilk wrote:
On Fri, Jan 06, 2012 at 07:53:13AM +1000, Ben Skeggs wrote:
On Thu, 2012-01-05 at 13:31 -0500, j.glisse@gmail.com wrote:
From: Jerome Glisse jglisse@redhat.com
ttm might call the move notify with null new mem placement, properly handle this case inside nouveau move notify callback.
This has been fixed already in a -next tree I sent to Dave.
I just tried -next with your patch (and two other fixes that I had sent):
drm/ttm/dma: Only call set_pages_array_wb when the page is not in WB pool drm/ttm/dma: Fix accounting error when calling ttm_mem_global_free_page and don't try to free freed pages
and Jerome's AGP fix: ttm: fix agp since ttm tt rework
and got the crash (but only with NVidia cards) after swapping between Xorg and the VCs. Look in drm-next.jpg
http://darnok.org/vga/drm-next.jpg
With your patch removed ("drm/nouveau/ttm: fix crash as a result of a recent ttm change") and the patch below by Jerome I still get it to crash (see drm-next-with-Jerome-fix-revert-Ben.jpg)..
http://darnok.org/vga/drm-next-with-Jerome-fix-revert-Ben.jpg
Ben.
Signed-off-by: Jerome Glisse jglisse@redhat.com
drivers/gpu/drm/nouveau/nouveau_bo.c | 6 +++--- 1 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/drivers/gpu/drm/nouveau/nouveau_bo.c b/drivers/gpu/drm/nouveau/nouveau_bo.c index f12dd0f..65f5b0b 100644 --- a/drivers/gpu/drm/nouveau/nouveau_bo.c +++ b/drivers/gpu/drm/nouveau/nouveau_bo.c @@ -808,9 +808,8 @@ out: }
static void -nouveau_bo_move_ntfy(struct ttm_buffer_object *bo, struct ttm_mem_reg *new_mem) +nouveau_bo_move_notify(struct ttm_buffer_object *bo, struct ttm_mem_reg *new_mem) {
- struct nouveau_mem *node = new_mem->mm_node; struct nouveau_bo *nvbo = nouveau_bo(bo); struct nouveau_vma *vma;
@@ -820,6 +819,7 @@ nouveau_bo_move_ntfy(struct ttm_buffer_object *bo, struct ttm_mem_reg *new_mem) } else if (new_mem && new_mem->mem_type == TTM_PL_TT && nvbo->page_shift == vma->vm->spg_shift) {
struct nouveau_mem *node = new_mem->mm_node; nouveau_vm_map_sg(vma, 0, new_mem-> num_pages << PAGE_SHIFT, node, node->pages);
@@ -1131,7 +1131,7 @@ struct ttm_bo_driver nouveau_bo_driver = { .invalidate_caches = nouveau_bo_invalidate_caches, .init_mem_type = nouveau_bo_init_mem_type, .evict_flags = nouveau_bo_evict_flags,
- .move_notify = nouveau_bo_move_ntfy,
- .move_notify = nouveau_bo_move_notify, .move = nouveau_bo_move, .verify_access = nouveau_bo_verify_access, .sync_obj_signaled = __nouveau_fence_signalled,
dri-devel mailing list dri-devel@lists.freedesktop.org http://lists.freedesktop.org/mailman/listinfo/dri-devel