[PATCH] drm/nouveau: fix ttm move notify callback

Konrad Rzeszutek Wilk konrad.wilk at oracle.com
Fri Jan 6 06:57:43 PST 2012


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 at gmail.com wrote:
> > > From: Jerome Glisse <jglisse at 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 at 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 at lists.freedesktop.org
> > http://lists.freedesktop.org/mailman/listinfo/dri-devel





More information about the dri-devel mailing list