diff options
Diffstat (limited to 'arch/x86/platform/efi/efi.c')
| -rw-r--r-- | arch/x86/platform/efi/efi.c | 30 | 
1 files changed, 26 insertions, 4 deletions
diff --git a/arch/x86/platform/efi/efi.c b/arch/x86/platform/efi/efi.c index 2dc29f51e75..92660edaa1e 100644 --- a/arch/x86/platform/efi/efi.c +++ b/arch/x86/platform/efi/efi.c @@ -234,7 +234,22 @@ static efi_status_t __init phys_efi_set_virtual_address_map(  	return status;  } -static int efi_set_rtc_mmss(unsigned long nowtime) +static efi_status_t __init phys_efi_get_time(efi_time_t *tm, +					     efi_time_cap_t *tc) +{ +	unsigned long flags; +	efi_status_t status; + +	spin_lock_irqsave(&rtc_lock, flags); +	efi_call_phys_prelog(); +	status = efi_call_phys2(efi_phys.get_time, virt_to_phys(tm), +				virt_to_phys(tc)); +	efi_call_phys_epilog(); +	spin_unlock_irqrestore(&rtc_lock, flags); +	return status; +} + +int efi_set_rtc_mmss(unsigned long nowtime)  {  	int real_seconds, real_minutes;  	efi_status_t 	status; @@ -263,7 +278,7 @@ static int efi_set_rtc_mmss(unsigned long nowtime)  	return 0;  } -static unsigned long efi_get_time(void) +unsigned long efi_get_time(void)  {  	efi_status_t status;  	efi_time_t eft; @@ -606,13 +621,18 @@ static int __init efi_runtime_init(void)  	}  	/*  	 * We will only need *early* access to the following -	 * EFI runtime service before set_virtual_address_map +	 * two EFI runtime services before set_virtual_address_map  	 * is invoked.  	 */ +	efi_phys.get_time = (efi_get_time_t *)runtime->get_time;  	efi_phys.set_virtual_address_map =  		(efi_set_virtual_address_map_t *)  		runtime->set_virtual_address_map; - +	/* +	 * Make efi_get_time can be called before entering +	 * virtual mode. +	 */ +	efi.get_time = phys_efi_get_time;  	early_iounmap(runtime, sizeof(efi_runtime_services_t));  	return 0; @@ -700,10 +720,12 @@ void __init efi_init(void)  		efi_enabled = 0;  		return;  	} +#ifdef CONFIG_X86_32  	if (efi_native) {  		x86_platform.get_wallclock = efi_get_time;  		x86_platform.set_wallclock = efi_set_rtc_mmss;  	} +#endif  #if EFI_DEBUG  	print_efi_memmap();  |