From: Huang Rui <ray.huang@amd.com>
To: "Borislav Petkov" <bp@suse.de>,
"Andy Lutomirski" <luto@amacapital.net>,
"Thomas Gleixner" <tglx@linutronix.de>,
"Peter Zijlstra" <peterz@infradead.org>,
"Rafael J. Wysocki" <rjw@rjwysocki.net>,
"Len Brown" <lenb@kernel.org>,
"John Stultz" <john.stultz@linaro.org>,
"Frédéric Weisbecker" <fweisbec@gmail.com>
Cc: <linux-kernel@vger.kernel.org>, <x86@kernel.org>,
Fengguang Wu <fengguang.wu@intel.com>,
Aaron Lu <aaron.lu@intel.com>,
Suravee Suthikulanit <suravee.suthikulpanit@amd.com>,
Tony Li <tony.li@amd.com>, Ken Xue <ken.xue@amd.com>,
Huang Rui <ray.huang@amd.com>
Subject: [PATCH v3 2/2] x86, mwaitt: introduce mwaix delay with a configurable timer
Date: Thu, 11 Jun 2015 22:14:11 +0800 [thread overview]
Message-ID: <1434032051-1953-3-git-send-email-ray.huang@amd.com> (raw)
In-Reply-To: <1434032051-1953-1-git-send-email-ray.huang@amd.com>
MWAITX can enable a timer and a corresponding timer value specified in SW
P0 clocks. The SW P0 frequency is the same with TSC. The timer provides an
upper bound on how long the instruction waits before exiting.
The implementation of delay function in kernel can lerverage the timer of
MWAITX. This patch provides a new method (delay_mwaitx) to measure delay
time.
Suggested-by: Andy Lutomirski <luto@amacapital.net>
Suggested-by: Borislav Petkov <bp@suse.de>
Suggested-by: Peter Zijlstra <peterz@infradead.org>
Signed-off-by: Huang Rui <ray.huang@amd.com>
---
arch/x86/include/asm/mwait.h | 11 +++++++++++
arch/x86/lib/delay.c | 41 ++++++++++++++++++++++++++++++++++++++++-
2 files changed, 51 insertions(+), 1 deletion(-)
diff --git a/arch/x86/include/asm/mwait.h b/arch/x86/include/asm/mwait.h
index ece8048..9b41580 100644
--- a/arch/x86/include/asm/mwait.h
+++ b/arch/x86/include/asm/mwait.h
@@ -14,6 +14,8 @@
#define CPUID5_ECX_INTERRUPT_BREAK 0x2
#define MWAIT_ECX_INTERRUPT_BREAK 0x1
+#define MWAITX_ECX_TIMER_ENABLE BIT(1)
+#define MWAITX_MAX_LOOPS ((u32)-1)
static inline void __monitor(const void *eax, unsigned long ecx,
unsigned long edx)
@@ -80,4 +82,13 @@ static inline void mwait_idle_with_hints(unsigned long eax, unsigned long ecx)
current_clr_polling();
}
+static inline void mwaitx(unsigned long eax, unsigned long loops,
+ bool enable)
+{
+ if (enable)
+ __mwaitx(eax, loops, MWAITX_ECX_TIMER_ENABLE);
+ else
+ __mwaitx(eax, 0, 0);
+}
+
#endif /* _ASM_X86_MWAIT_H */
diff --git a/arch/x86/lib/delay.c b/arch/x86/lib/delay.c
index 39d6a3d..9daf94a 100644
--- a/arch/x86/lib/delay.c
+++ b/arch/x86/lib/delay.c
@@ -20,6 +20,7 @@
#include <asm/processor.h>
#include <asm/delay.h>
#include <asm/timer.h>
+#include <asm/mwait.h>
#ifdef CONFIG_SMP
# include <asm/smp.h>
@@ -87,6 +88,41 @@ static void delay_tsc(unsigned long __loops)
}
/*
+ * On AMD platforms mwaitx has a configurable 32-bit timer, that counts
+ * with TSC frequency. And the input value is the loop of the counter, it
+ * will exit with the timer expired.
+ */
+static void delay_mwaitx(unsigned long __loops)
+{
+ u32 end, start, delay, addr, loops = __loops;
+
+ rdtsc_barrier();
+ rdtscl(start);
+
+ for (;;) {
+ delay = min(MWAITX_MAX_LOOPS, loops);
+
+ __monitorx(&addr, 0, 0);
+ /*
+ * AMD, like Intel, supports the EAX hint and EAX=0xf
+ * means, do not enter any deep C-state and we use it
+ * here in delay() to minimize wakeup latency.
+ */
+ mwaitx(0xf, delay, true);
+
+ rdtsc_barrier();
+ rdtscl(end);
+
+ if (loops <= end - start)
+ break;
+
+ loops -= end - start;
+
+ start = end;
+ }
+}
+
+/*
* Since we calibrate only once at boot, this
* function should be set once at boot and not changed
*/
@@ -108,7 +144,10 @@ int read_current_timer(unsigned long *timer_val)
void __delay(unsigned long loops)
{
- delay_fn(loops);
+ if (!static_cpu_has_safe(X86_FEATURE_MWAITT))
+ delay_fn(loops);
+ else
+ delay_mwaitx(loops);
}
EXPORT_SYMBOL(__delay);
--
1.9.1
next prev parent reply other threads:[~2015-06-11 14:15 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-06-11 14:14 [PATCH v3 0/2] x86, mwaitt: introduce AMD mwaitt support Huang Rui
2015-06-11 14:14 ` [PATCH v3 1/2] x86, mwaitt: add monitorx and mwaitx instruction Huang Rui
2015-06-11 14:19 ` Borislav Petkov
2015-06-11 14:14 ` Huang Rui
2015-06-11 14:14 ` Huang Rui [this message]
2015-06-11 17:34 ` [PATCH v3 2/2] x86, mwaitt: introduce mwaix delay with a configurable timer Andy Lutomirski
2015-06-12 4:03 ` Huang Rui
2015-06-12 7:38 ` Peter Zijlstra
2015-06-12 7:50 ` Huang Rui
2015-06-12 8:30 ` Borislav Petkov
2015-06-12 8:23 ` Huang Rui
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1434032051-1953-3-git-send-email-ray.huang@amd.com \
--to=ray.huang@amd.com \
--cc=aaron.lu@intel.com \
--cc=bp@suse.de \
--cc=fengguang.wu@intel.com \
--cc=fweisbec@gmail.com \
--cc=john.stultz@linaro.org \
--cc=ken.xue@amd.com \
--cc=lenb@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=luto@amacapital.net \
--cc=peterz@infradead.org \
--cc=rjw@rjwysocki.net \
--cc=suravee.suthikulpanit@amd.com \
--cc=tglx@linutronix.de \
--cc=tony.li@amd.com \
--cc=x86@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.