Thread (47 messages) 47 messages, 10 authors, 2015-10-01

Re: [PATCH 1/2] x86/efi: Map EFI memmap entries in-order at runtime

From: Matt Fleming <hidden>
Date: 2015-09-29 13:53:13
Also in: lkml, stable

On Tue, 29 Sep, at 11:12:30AM, Ingo Molnar wrote:
* Ard Biesheuvel [off-list ref] wrote:
quoted
quoted
except that I don't think
the condition on 64-bit makes any sense:

+       if (!efi_enabled(EFI_OLD_MEMMAP) && efi_enabled(EFI_64BIT)) {

I can see us being nervous wrt. backported patches, but is there any strong reason
to not follow this up with a third (non-backported) patch that changes this to:

+       if (!efi_enabled(EFI_OLD_MEMMAP)) {

for v4.4?
The 32-bit side essentially implements the old memmap only, which is the the 
bottom-up version. So old memmap will be implied by 32-bit but not set in the 
EFI flags, resulting in the reverse enumeration being used with the bottom-up 
mapping logic. The net result of that is that we create the same problem for 
32-bit that we are trying to solve for 64-bit, i.e., the regions will end up in 
reverse order in the VA mapping.

To deobfuscate this particular conditional, we could set EFI_OLD_MEMMAP 
unconditionally on 32-bit x86. Or we could reshuffle variables and conditionals 
in various other way.
Setting EFI_OLD_MEMMAP would be fine, if doing that has no bad side effects.
 
Right, I think that's a very good suggestion, because like Ard
mentioned, since EFI_OLD_MEMMAP is implied for 32-bit (there's no
other way to map stuff currently), so it makes sense to force set the
bit.
quoted
[...] I am not convinced that the overall end result will be any better though.
That's not true, we change an obscure, implicit dependency on 32-bit detail to an 
explicit EFI_OLD_MEMMAP flag that shows exactly what's happening. That's a clear 
improvement.
Agreed.

-- 
Matt Fleming, Intel Open Source Technology Center
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help