+ efi-calling-efi_get_time-during-suspend.patch added to -mm tree

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



The patch titled
     EFI: calling efi_get_time during suspend
has been added to the -mm tree.  Its filename is
     efi-calling-efi_get_time-during-suspend.patch

See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find
out what to do about this

------------------------------------------------------
Subject: EFI: calling efi_get_time during suspend
From: Artiom Myaskouvskey <artiom.myaskouvskey@xxxxxxxxx>

Function efi_get_time called not only during init kernel phase but also
during suspend (from get_cmos_time).

When it is called from get_cmos_time the corresponding runtime service
should be called in virtual and not in physical mode.

Signed-off-by: Artiom Myaskouvskey <artiom.myaskouvskey@xxxxxxxxx>
Cc: "Narayanan, Chandramouli" <chandramouli.narayanan@xxxxxxxxx>
Cc: "Jiossy, Rami" <rami.jiossy@xxxxxxxxx>
Cc: "Satt, Shai" <shai.satt@xxxxxxxxx>
Cc: Andi Kleen <ak@xxxxxxx>
Cc: Matt Domsch <Matt_Domsch@xxxxxxxx>
Signed-off-by: Andrew Morton <akpm@xxxxxxxx>
---

 arch/i386/kernel/efi.c |   17 ++++++++++++-----
 include/linux/efi.h    |    2 +-
 2 files changed, 13 insertions(+), 6 deletions(-)

diff -puN arch/i386/kernel/efi.c~efi-calling-efi_get_time-during-suspend arch/i386/kernel/efi.c
--- a/arch/i386/kernel/efi.c~efi-calling-efi_get_time-during-suspend
+++ a/arch/i386/kernel/efi.c
@@ -194,17 +194,24 @@ inline int efi_set_rtc_mmss(unsigned lon
 	return 0;
 }
 /*
- * This should only be used during kernel init and before runtime
- * services have been remapped, therefore, we'll need to call in physical
- * mode.  Note, this call isn't used later, so mark it __init.
+ * This is used during kernel init before runtime
+ * services have been remapped and also during suspend, therefore,
+ * we'll need to call both in physical and virtual modes.
  */
-inline unsigned long __init efi_get_time(void)
+inline unsigned long efi_get_time(void)
 {
 	efi_status_t status;
 	efi_time_t eft;
 	efi_time_cap_t cap;
 
-	status = phys_efi_get_time(&eft, &cap);
+	if (efi.get_time) {
+		/* if we are in virtual mode use remapped function */
+ 		status = efi.get_time(&eft, &cap);
+	} else {
+		/* we are in physical mode */
+		status = phys_efi_get_time(&eft, &cap);
+	}
+
 	if (status != EFI_SUCCESS)
 		printk("Oops: efitime: can't read time status: 0x%lx\n",status);
 
diff -puN include/linux/efi.h~efi-calling-efi_get_time-during-suspend include/linux/efi.h
--- a/include/linux/efi.h~efi-calling-efi_get_time-during-suspend
+++ a/include/linux/efi.h
@@ -300,7 +300,7 @@ extern int efi_mem_attribute_range (unsi
 extern int __init efi_uart_console_only (void);
 extern void efi_initialize_iomem_resources(struct resource *code_resource,
 					struct resource *data_resource);
-extern unsigned long __init efi_get_time(void);
+extern unsigned long efi_get_time(void);
 extern int __init efi_set_rtc_mmss(unsigned long nowtime);
 extern struct efi_memory_map memmap;
 
_

Patches currently in -mm which might be from artiom.myaskouvskey@xxxxxxxxx are

efi-calling-efi_get_time-during-suspend.patch

-
To unsubscribe from this list: send the line "unsubscribe mm-commits" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Kernel Newbies FAQ]     [Kernel Archive]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [Bugtraq]     [Photo]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]

  Powered by Linux