From: Thomas Gleixner
Sent: November 5, 2018 at 8:28:29 PM GMT
> To: Andy Lutomirski <[email protected]>
> Cc: Nadav Amit <[email protected]>, Linus Torvalds 
> <[email protected]>, H. Peter Anvin <[email protected]>, Peter 
> Zijlstra <[email protected]>, Ingo Molnar <[email protected]>, LKML 
> <[email protected]>, X86 ML <[email protected]>, Borislav Petkov 
> <[email protected]>, Dave Hansen <[email protected]>, Andrew 
> Lutomirski <[email protected]>, Kees Cook <[email protected]>, Dave Hansen 
> <[email protected]>, Masami Hiramatsu <[email protected]>
> Subject: Re: [PATCH v3 2/7] x86/jump_label: Use text_poke_early() during 
> early_init
> 
> 
> On Mon, 5 Nov 2018, Andy Lutomirski wrote:
>> On Mon, Nov 5, 2018 at 11:25 AM Nadav Amit <[email protected]> wrote:
>> Linus, hpa, or Dave, a question for you: suppose I map some page
>> writably, write to it, then upgrade permissions to allow execute.
>> Must I force all CPUs that might execute from it without first
>> serializing to serialize?  I suspect this doesn't really affect user
>> code, but it may affect the module loader.
>> 
>> To be safe, shouldn't the module loader broadcast an IPI to
>> sync_core() everywhere after loading a module and before making it
>> runnable, regardless of alternative patching?
>> 
>> IOW, the right sequence of events probably ought to me:
>> 
>> 1. Allocate the memory and map it.
>> 2. Copy in the text.
>> 3. Patch alternatives, etc.  This is logically just like (2) from an
>> architectural perspective -- we're just writing to memory that won't
>> be executed.
>> 4. Serialize everything.
>> 5. Run it!
> 
> I'd make that:
> 
> 1. Allocate the memory and map it RW
> 2. Copy in the text.
> 3. Patch alternatives, etc.  This is logically just like (2) from an
>   architectural perspective -- we're just writing to memory that won't
>   be executed.
> 4. Map it RX
> 5. Serialize everything.
> 6. Run it!

Thanks. I will do something along these lines. This can improve module
loading time (saving IRQ save/restore time), but it will not make things
much prettier, since two code-paths for “early init kernel” and “early init
module” would be needed.

Reply via email to