[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1433819621-15093-3-git-send-email-ray.huang@amd.com>
Date: Tue, 9 Jun 2015 11:13:39 +0800
From: Huang Rui <ray.huang@....com>
To: Borislav Petkov <bp@...e.de>,
Andy Lutomirski <luto@...capital.net>,
Thomas Gleixner <tglx@...utronix.de>,
Peter Zijlstra <peterz@...radead.org>,
"Rafael J. Wysocki" <rjw@...ysocki.net>,
Len Brown <lenb@...nel.org>,
"John Stultz" <john.stultz@...aro.org>,
Frédéric Weisbecker <fweisbec@...il.com>
CC: <linux-kernel@...r.kernel.org>, <x86@...nel.org>,
Fengguang Wu <fengguang.wu@...el.com>,
Aaron Lu <aaron.lu@...el.com>,
Suravee Suthikulanit <suravee.suthikulpanit@....com>,
Tony Li <tony.li@....com>, Ken Xue <ken.xue@....com>,
Huang Rui <ray.huang@....com>
Subject: [PATCH v2 2/4] x86, mwaitt: make delay method configurable
This patch introduces a kernel parameter (delay), user is able to configure
it at boot loader to choose different types of delay method.
Default schema is to use TSC delay. This update can be more flexiable to
add new delay method.
Suggested-by: Suravee Suthikulanit <suravee.suthikulpanit@....com>
Signed-off-by: Huang Rui <ray.huang@....com>
---
arch/x86/include/asm/delay.h | 7 +++++++
arch/x86/kernel/setup.c | 19 +++++++++++++++++++
arch/x86/lib/delay.c | 12 +++++++++++-
3 files changed, 37 insertions(+), 1 deletion(-)
diff --git a/arch/x86/include/asm/delay.h b/arch/x86/include/asm/delay.h
index 9b3b4f2..99873ec 100644
--- a/arch/x86/include/asm/delay.h
+++ b/arch/x86/include/asm/delay.h
@@ -5,4 +5,11 @@
void use_tsc_delay(void);
+extern unsigned long boot_option_delay;
+
+enum delay_type {
+ DELAY_LOOP=0,
+ DELAY_TSC,
+};
+
#endif /* _ASM_X86_DELAY_H */
diff --git a/arch/x86/kernel/setup.c b/arch/x86/kernel/setup.c
index 0b10698..cc2886d 100644
--- a/arch/x86/kernel/setup.c
+++ b/arch/x86/kernel/setup.c
@@ -111,6 +111,7 @@
#include <asm/mce.h>
#include <asm/alternative.h>
#include <asm/prom.h>
+#include <asm/delay.h>
/*
* max_low_pfn_mapped: highest direct mapped pfn under 4GB
@@ -844,6 +845,24 @@ dump_kernel_offset(struct notifier_block *self, unsigned long v, void *p)
return 0;
}
+static int __init delay_setup(char *str)
+{
+ if (!str)
+ return -EINVAL;
+
+ if (!strcmp(str, "tsc")) {
+ pr_info("using tsc delay\n");
+ boot_option_delay = DELAY_TSC;
+ } else if (!strcmp(str, "loop")) {
+ pr_info("using loop delay\n");
+ boot_option_delay = DELAY_LOOP;
+ } else
+ return -1;
+
+ return 0;
+}
+early_param("delay", delay_setup);
+
/*
* Determine if we were loaded by an EFI loader. If so, then we have also been
* passed the efi memmap, systab, etc., so we should use these data structures
diff --git a/arch/x86/lib/delay.c b/arch/x86/lib/delay.c
index 39d6a3d..1a6952e 100644
--- a/arch/x86/lib/delay.c
+++ b/arch/x86/lib/delay.c
@@ -25,6 +25,8 @@
# include <asm/smp.h>
#endif
+unsigned long boot_option_delay = DELAY_TSC;
+
/* simple loop based delay: */
static void delay_loop(unsigned long loops)
{
@@ -94,7 +96,15 @@ static void (*delay_fn)(unsigned long) = delay_loop;
void use_tsc_delay(void)
{
- delay_fn = delay_tsc;
+ switch (boot_option_delay) {
+ case DELAY_LOOP:
+ delay_fn = delay_loop;
+ return;
+ case DELAY_TSC:
+ default:
+ delay_fn = delay_tsc;
+ return;
+ }
}
int read_current_timer(unsigned long *timer_val)
--
1.7.9.5
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists