Re: mmu_notifier and i915_gem_userptr.c
From: Chris Wilson
Date: Thu Jun 19 2014 - 12:03:15 EST
On Thu, Jun 19, 2014 at 05:36:55PM +0200, Joerg Roedel wrote:
> Hey Chris,
>
> recently I had a look at i915_gem_userptr.c in order to extend the
> mmu_notifier call-backs implemented there. My goal is to implement the
> change_pte call-back where it is necessary to get rid of it being
> wrapped mn_invalidate_range_start/end() calls (for the reason see
> commit 6bdb913f).
>
> For most users of mmu_notifiers this is easy, except the i915 driver :)
> The invalidate_range_start notifier implemented there can sleep, so it
> can't be reused for a change_pte implementation (because change_pte is
> called under ptl spin_lock and is not allowed to sleep). On the other
> hand you also didn't implement the invalidate_page notifier, so I am not
> sure whether the code actually cares about the somewhat similar
> change_pte events?
Maybe it should hook the invalidate_page notifier. I picked
invalidate_range() as it seemed to be called first and seemed to cover
all operations that affected an mm's addr range. The invalidate_page
seemed to be only called during writeback, which aiui will not affect gup.
Should we be hooking more notifiers?
> Here is where change_pte is called from:
>
> * In KSM code when pages are merged (shouldn't be relevant
> because KSM doesn't merged pages returned by get_user_pages())
> * In uprobes code when a user-page is replaced by a kernel page
> (should only handle .text sections, so probaly not relevant
> here)
> * When someone writes to a COW page in mm/memory.c (this looks
> relevant looking at forked processes, on the other hand,
> this is currently handled by unbinding the vma from the
> object list in the i915 driver)
>
> I am not familiar with the i915 hardware and the driver implementation
> details, so I wanted to ask whether the driver
>
> 1) Cares about the change_pte event?
I don't think so... If I understand correctly, change_pte only gets
called when the PTE is updated, not the physical page itself. If that is
true, then the dma mapping of the page is unaffected, and so the GPU
view of the page is not affected either. So, as long as the GPU
maintains a remapped address of a page that is associated by a process
address, we don't need to change anything.
> 2) If it cares, what is the best way to implement it? What the
> invalidate_range_start() notifier does seems a bit overkill,
> since for the change_pte event nothing is unmapped (but maybe
> remapped)
If need be, start with overkill. I'd rather drop everything and rebuild
it through the layers of mappings we have, as this is a new area for us
and we want some solid foundations before trying to be smart.
> So any insight you could provide here would be useful :)
Likewise. :-p
-Chris
--
Chris Wilson, Intel Open Source Technology Centre
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/