diff options
| author | Olof Johansson <olof@lixom.net> | 2012-09-05 15:35:48 -0700 | 
|---|---|---|
| committer | Olof Johansson <olof@lixom.net> | 2012-09-05 15:35:48 -0700 | 
| commit | 1875962377574b4edb7b164001e3e341c25290d5 (patch) | |
| tree | 374a5299403ec21e2d9a66a6548ce876a388b589 /arch/x86/platform/efi/efi.c | |
| parent | 5cbee140a28c2746449ae31e85738043ae4da927 (diff) | |
| parent | c88a79a7789b2909ad1cf69ea2c9142030bbd6f4 (diff) | |
| download | olio-linux-3.10-1875962377574b4edb7b164001e3e341c25290d5.tar.xz olio-linux-3.10-1875962377574b4edb7b164001e3e341c25290d5.zip  | |
Merge branch 'soc-core' of git://git.kernel.org/pub/scm/linux/kernel/git/horms/renesas into next/dt
* 'soc-core' of git://git.kernel.org/pub/scm/linux/kernel/git/horms/renesas:
  ARM: mach-shmobile: Add compilation support for dtbs using 'make dtbs'
  + sync to 3.6-rc3
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();  |