Commit 1f96b1ef authored by Dave Hansen's avatar Dave Hansen Committed by Ingo Molnar

x86/fpu: Add placeholder for 'Processor Trace' XSAVE state

There is an XSAVE state component for Intel Processor Trace (PT).
But, we do not currently use it.

We add a placeholder in the code for it so it is not a mystery and
also so we do not need an explicit enum initialization for Protection
Keys in a moment.

Why don't we use it?

We might end up using this at _some_ point in the future.  But,
this is a "system" state which requires using the currently
unsupported XSAVES feature.  Unlike all the other XSAVE states,
PT state is also not directly tied to a thread.  You might
context-switch between threads, but not want to change any of the
PT state.  Or, you might switch between threads, and *do* want to
change PT state, all depending on what is being traced.

We currently just manually set some MSRs to do this PT context
switching, and it is unclear whether replacing our direct MSR use
with XSAVE will be a net win or loss, both in code complexity and
performance.
Signed-off-by: default avatarDave Hansen <dave.hansen@linux.intel.com>
Reviewed-by: default avatarThomas Gleixner <tglx@linutronix.de>
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Andy Lutomirski <luto@amacapital.net>
Cc: Borislav Petkov <bp@alien8.de>
Cc: Brian Gerst <brgerst@gmail.com>
Cc: Dave Hansen <dave@sr71.net>
Cc: Denys Vlasenko <dvlasenk@redhat.com>
Cc: H. Peter Anvin <hpa@zytor.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Rik van Riel <riel@redhat.com>
Cc: fenghua.yu@intel.com
Cc: linux-mm@kvack.org
Cc: yu-cheng.yu@intel.com
Link: http://lkml.kernel.org/r/20160212210158.5E4BCAE2@viggo.jf.intel.comSigned-off-by: default avatarIngo Molnar <mingo@kernel.org>
parent d4edcf0d
...@@ -108,6 +108,7 @@ enum xfeature { ...@@ -108,6 +108,7 @@ enum xfeature {
XFEATURE_OPMASK, XFEATURE_OPMASK,
XFEATURE_ZMM_Hi256, XFEATURE_ZMM_Hi256,
XFEATURE_Hi16_ZMM, XFEATURE_Hi16_ZMM,
XFEATURE_PT_UNIMPLEMENTED_SO_FAR,
XFEATURE_MAX, XFEATURE_MAX,
}; };
......
...@@ -13,6 +13,11 @@ ...@@ -13,6 +13,11 @@
#include <asm/tlbflush.h> #include <asm/tlbflush.h>
/*
* Although we spell it out in here, the Processor Trace
* xfeature is completely unused. We use other mechanisms
* to save/restore PT state in Linux.
*/
static const char *xfeature_names[] = static const char *xfeature_names[] =
{ {
"x87 floating point registers" , "x87 floating point registers" ,
...@@ -23,7 +28,7 @@ static const char *xfeature_names[] = ...@@ -23,7 +28,7 @@ static const char *xfeature_names[] =
"AVX-512 opmask" , "AVX-512 opmask" ,
"AVX-512 Hi256" , "AVX-512 Hi256" ,
"AVX-512 ZMM_Hi256" , "AVX-512 ZMM_Hi256" ,
"unknown xstate feature" , "Processor Trace (unused)" ,
}; };
/* /*
...@@ -470,7 +475,8 @@ static void check_xstate_against_struct(int nr) ...@@ -470,7 +475,8 @@ static void check_xstate_against_struct(int nr)
* numbers. * numbers.
*/ */
if ((nr < XFEATURE_YMM) || if ((nr < XFEATURE_YMM) ||
(nr >= XFEATURE_MAX)) { (nr >= XFEATURE_MAX) ||
(nr == XFEATURE_PT_UNIMPLEMENTED_SO_FAR)) {
WARN_ONCE(1, "no structure for xstate: %d\n", nr); WARN_ONCE(1, "no structure for xstate: %d\n", nr);
XSTATE_WARN_ON(1); XSTATE_WARN_ON(1);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment