On 11/06/2015 03:49 PM, Kees Cook wrote:
On Fri, Nov 6, 2015 at 3:41 PM, Laura Abbott <labbott@xxxxxxxxxx> wrote:
On 11/06/2015 12:46 PM, Russell King - ARM Linux wrote:
On Fri, Nov 06, 2015 at 10:44:32AM -0800, Laura Abbott wrote:
with my test patch. I think setting both current->active_mm and &init_mm
is sufficient. Maybe explicitly setting swapper_pg_dir would be cleaner?
Please, stop thinking like this. If you're trying to change the kernel
section mappings after threads have been spawned, you need to change
them for _all_ threads, which means you need to change them for every
page table that's in existence at that time - you can't do just one
table and hope everyone updates, it doesn't work like that.
That's a bad assumption assumption on my part based on what I was
observing. At the time of mark_rodata_ro, the only threads present
are kernel threads which aren't going to have task->mm. Only the
running thread is going to have active_mm. None of those are init_mm.
To be complete we need:
- Update every task->mm for every thread in every process
- Update current->active_mm
- Update &init_mm explicitly
All this would need to be done under stop_machine as well. Does that cover
everything or am I still off?
I still think we need to find an earlier place to do this. :(
-Kees
The problem is still the initmem. That needs to be writable and executable
during inittime and then have the page tables adjusted afterwards if it is
going to be freed back. I'll give this some more thought to see if I can
come up with something or if anyone else has another idea.
Thanks,
Laura
--
To unsubscribe, send a message with 'unsubscribe linux-mm' in
the body to majordomo@xxxxxxxxx. For more info on Linux MM,
see: http://www.linux-mm.org/ .
Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>