於 四,2013-12-19 於 10:49 +0000,Matt Fleming 提到: > On Thu, 19 Dec, at 06:20:16PM, Lee, Chun-Yi wrote: > > From: Jan Beulich <JBeulich@xxxxxxxx> > > > > Other than ix86, x86-64 on EFI so far didn't set the > > {g,s}et_wallclock accessors to the EFI routines, thus > > incorrectly using raw RTC accesses instead. > > > > Simply removing the #ifdef around the respective code isn't > > enough, however: While so far early get-time calls were done in > > physical mode, this doesn't work properly for x86-64, as virtual > > addresses would still need to be set up for all runtime regions > > (which wasn't the case on the system I have access to), so > > instead the patch moves the call to efi_enter_virtual_mode() > > ahead (which in turn allows to drop all code related to calling > > efi-get-time in physical mode). > > > > Additionally the earlier calling of efi_set_executable() > > requires the CPA code to cope, i.e. during early boot it must be > > avoided to call cpa_flush_array(), as the first thing this > > function does is a BUG_ON(irqs_disabled()). > > > > Also make the two EFI functions in question here static - > > they're not being referenced elsewhere. > > > > History: > > > > This commit was originally merged as bacef661acdb ("x86-64/efi: > > Use EFI to deal with platform wall clock") but it resulted in some > > ASUS machines no longer booting due to a firmware bug, and so was > > reverted in f026cfa82f62. > > > > Then a pre-emptive fix for the buggy ASUS firmware was merged in > > 03a1c254975e ("x86, efi: 1:1 pagetable mapping for virtual EFI > > calls") but it causes odd bootup problems on x86-64. So this patch > > revoked again by 11520e5e7c1. > > > > Now Borislav Petkov's "EFI runtime services virtual mapping" is > > merged to EFI 'next' branch. So this patch can be reapplied again. > > > > Signed-off-by: Jan Beulich <jbeulich@xxxxxxxx> > > Tested-by: Matt Fleming <matt.fleming@xxxxxxxxx> > > Acked-by: Matthew Garrett <mjg@xxxxxxxxxx> > > Cc: Ingo Molnar <mingo@xxxxxxxxxx> > > Cc: Peter Zijlstra <a.p.zijlstra@xxxxxxxxx> > > Cc: H. Peter Anvin <hpa@xxxxxxxxx> > > Signed-off-by: Matt Fleming <matt.fleming@xxxxxxxxx> [added commit history] > > Acked-by: Lee, Chun-Yi <jlee@xxxxxxxx> > > --- > > arch/x86/mm/pageattr.c | 10 ++++++---- > > arch/x86/platform/efi/efi.c | 35 +++++++++++------------------------ > > include/linux/efi.h | 2 -- > > init/main.c | 8 ++++---- > > 4 files changed, 21 insertions(+), 34 deletions(-) > > Lee, you can't just simply resend this patch with all the tags - I > haven't tested this version with any recent changes and I'm pretty sure > Matthew isn't going to Ack it. I am very sorry for I didn't remove those tags before send it. I will remove it when send second version. > > Do you know if anyone has tested this patch with Borislav's recent > changes? > I tested Borislav's patch set on a issue BIOS and make sure it works, but I have no chance to test this patch with it. I will find a time to test it. Thanks a lot! Joey Lee -- To unsubscribe from this list: send the line "unsubscribe linux-efi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html