Re: [PATCH] x86: create array based interface to change page attribute
From: Thomas Hellström
Date: Tue Apr 01 2008 - 17:30:34 EST
Arjan van de Ven wrote:
Thomas Hellström wrote:
Given this problem, the previously mentioned use-case, and the fact
that we mostly really use user-space mappings,
Is there a possibility we could add the following functions to Dave's
patch (provided they would work as intended, of course, namely
invalidate / bring back the kernel mapping).
sadly there are multiple mappings, both in theory and practice.
Especially the _np / _p functions specifically work on only the
mapping you specify.
For this to work we would need to somehow make a "mark all mappings
NP, but please only do the kernel ones" kind of thing.
The semantics of that are... lets say messy at best.
Hmm, I'm not sure I follow you here. Are you saying that it's illegal to
have an NP mapping of a page (which, If I understand it correctly, means
no mapping at all) at the same time as you have a, say user-space WC
mapping pointing to the same physical page?
Or are you saying that it's very hard to keep track of all mappings to a
page, and change only the ones you really want to change?
If you mean the latter, for the DRM case, the DRM memory manager has
already made sure all user-space mappings of a page are killed before
calling CPA on it, (using unmap_mapping_range()) and they are faulted
back once CPA is done.
I was under the impression that calling CPA on the kernel mapping of
that page would do the rest?
/Thomas
--
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/