[PATCH v2] x86, efi: Make "noefi" really disable EFI runtime serivces

2013-02-21 Thread Matt Fleming
From: Matt Fleming 

commit 1de63d60cd5b ("efi: Clear EFI_RUNTIME_SERVICES rather than
EFI_BOOT by "noefi" boot parameter") attempted to make "noefi" true to
its documentation and disable EFI runtime services to prevent the
bricking bug described in commit e0094244e41c ("samsung-laptop:
Disable on EFI hardware"). However, it's not possible to clear
EFI_RUNTIME_SERVICES from an early param function because
EFI_RUNTIME_SERVICES is set in efi_init() *after* parse_early_param().

This resulted in "noefi" effectively becoming a no-op and no longer
providing users with a way to disable EFI, which is bad for those
users that have buggy machines.

Reported-by: Walt Nelson Jr 
Cc: Satoru Takeuchi 
Cc: H. Peter Anvin 
Cc: Yinghai Lu 
Cc: 
Signed-off-by: Matt Fleming 
---

v2: Annotate with __initdata as pointed out by Yinghai Lu.

 arch/x86/platform/efi/efi.c | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)

diff --git a/arch/x86/platform/efi/efi.c b/arch/x86/platform/efi/efi.c
index 928bf83..ec9f325 100644
--- a/arch/x86/platform/efi/efi.c
+++ b/arch/x86/platform/efi/efi.c
@@ -85,9 +85,10 @@ int efi_enabled(int facility)
 }
 EXPORT_SYMBOL(efi_enabled);
 
+static bool __initdata disable_runtime = false;
 static int __init setup_noefi(char *arg)
 {
-   clear_bit(EFI_RUNTIME_SERVICES, _efi_facility);
+   disable_runtime = true;
return 0;
 }
 early_param("noefi", setup_noefi);
@@ -734,7 +735,7 @@ void __init efi_init(void)
if (!efi_is_native())
pr_info("No EFI runtime due to 32/64-bit mismatch with 
kernel\n");
else {
-   if (efi_runtime_init())
+   if (disable_runtime || efi_runtime_init())
return;
set_bit(EFI_RUNTIME_SERVICES, _efi_facility);
}
-- 
1.7.11.7

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/


[PATCH v2] x86, efi: Make noefi really disable EFI runtime serivces

2013-02-21 Thread Matt Fleming
From: Matt Fleming matt.flem...@intel.com

commit 1de63d60cd5b (efi: Clear EFI_RUNTIME_SERVICES rather than
EFI_BOOT by noefi boot parameter) attempted to make noefi true to
its documentation and disable EFI runtime services to prevent the
bricking bug described in commit e0094244e41c (samsung-laptop:
Disable on EFI hardware). However, it's not possible to clear
EFI_RUNTIME_SERVICES from an early param function because
EFI_RUNTIME_SERVICES is set in efi_init() *after* parse_early_param().

This resulted in noefi effectively becoming a no-op and no longer
providing users with a way to disable EFI, which is bad for those
users that have buggy machines.

Reported-by: Walt Nelson Jr walt0...@gmail.com
Cc: Satoru Takeuchi takeuchi_sat...@jp.fujitsu.com
Cc: H. Peter Anvin h...@linux.intel.com
Cc: Yinghai Lu ying...@kernel.org
Cc: sta...@vger.kernel.org
Signed-off-by: Matt Fleming matt.flem...@intel.com
---

v2: Annotate with __initdata as pointed out by Yinghai Lu.

 arch/x86/platform/efi/efi.c | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)

diff --git a/arch/x86/platform/efi/efi.c b/arch/x86/platform/efi/efi.c
index 928bf83..ec9f325 100644
--- a/arch/x86/platform/efi/efi.c
+++ b/arch/x86/platform/efi/efi.c
@@ -85,9 +85,10 @@ int efi_enabled(int facility)
 }
 EXPORT_SYMBOL(efi_enabled);
 
+static bool __initdata disable_runtime = false;
 static int __init setup_noefi(char *arg)
 {
-   clear_bit(EFI_RUNTIME_SERVICES, x86_efi_facility);
+   disable_runtime = true;
return 0;
 }
 early_param(noefi, setup_noefi);
@@ -734,7 +735,7 @@ void __init efi_init(void)
if (!efi_is_native())
pr_info(No EFI runtime due to 32/64-bit mismatch with 
kernel\n);
else {
-   if (efi_runtime_init())
+   if (disable_runtime || efi_runtime_init())
return;
set_bit(EFI_RUNTIME_SERVICES, x86_efi_facility);
}
-- 
1.7.11.7

--
To unsubscribe from this list: send the line unsubscribe linux-kernel in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/