[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