Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 0967160a authored by Ingo Molnar's avatar Ingo Molnar
Browse files

Merge branch 'x86/asm' into perf/x86, to avoid conflicts with upcoming patches



Signed-off-by: default avatarIngo Molnar <mingo@kernel.org>
parents 2fde4f94 b57c0b51
Loading
Loading
Loading
Loading
+12 −6
Original line number Original line Diff line number Diff line
@@ -78,9 +78,6 @@ The expensive (paranoid) way is to read back the MSR_GS_BASE value
	xorl %ebx,%ebx
	xorl %ebx,%ebx
1:	ret
1:	ret


and the whole paranoid non-paranoid macro complexity is about whether
to suffer that RDMSR cost.

If we are at an interrupt or user-trap/gate-alike boundary then we can
If we are at an interrupt or user-trap/gate-alike boundary then we can
use the faster check: the stack will be a reliable indicator of
use the faster check: the stack will be a reliable indicator of
whether SWAPGS was already done: if we see that we are a secondary
whether SWAPGS was already done: if we see that we are a secondary
@@ -93,6 +90,15 @@ which might have triggered right after a normal entry wrote CS to the
stack but before we executed SWAPGS, then the only safe way to check
stack but before we executed SWAPGS, then the only safe way to check
for GS is the slower method: the RDMSR.
for GS is the slower method: the RDMSR.


So we try only to mark those entry methods 'paranoid' that absolutely
Therefore, super-atomic entries (except NMI, which is handled separately)
need the more expensive check for the GS base - and we generate all
must use idtentry with paranoid=1 to handle gsbase correctly.  This
'normal' entry points with the regular (faster) entry macros.
triggers three main behavior changes:

 - Interrupt entry will use the slower gsbase check.
 - Interrupt entry from user mode will switch off the IST stack.
 - Interrupt exit to kernel mode will not attempt to reschedule.

We try to only use IST entries and the paranoid entry code for vectors
that absolutely need the more expensive check for the GS base - and we
generate all 'normal' entry points with the regular (faster) paranoid=0
variant.
+5 −3
Original line number Original line Diff line number Diff line
@@ -40,9 +40,11 @@ An IST is selected by a non-zero value in the IST field of an
interrupt-gate descriptor.  When an interrupt occurs and the hardware
interrupt-gate descriptor.  When an interrupt occurs and the hardware
loads such a descriptor, the hardware automatically sets the new stack
loads such a descriptor, the hardware automatically sets the new stack
pointer based on the IST value, then invokes the interrupt handler.  If
pointer based on the IST value, then invokes the interrupt handler.  If
software wants to allow nested IST interrupts then the handler must
the interrupt came from user mode, then the interrupt handler prologue
adjust the IST values on entry to and exit from the interrupt handler.
will switch back to the per-thread stack.  If software wants to allow
(This is occasionally done, e.g. for debug exceptions.)
nested IST interrupts then the handler must adjust the IST values on
entry to and exit from the interrupt handler.  (This is occasionally
done, e.g. for debug exceptions.)


Events with different IST codes (i.e. with different stacks) can be
Events with different IST codes (i.e. with different stacks) can be
nested.  For example, a debug interrupt can safely be interrupted by an
nested.  For example, a debug interrupt can safely be interrupted by an
+2 −2
Original line number Original line Diff line number Diff line
@@ -179,8 +179,8 @@ sysenter_dispatch:
sysexit_from_sys_call:
sysexit_from_sys_call:
	andl    $~TS_COMPAT,TI_status+THREAD_INFO(%rsp,RIP-ARGOFFSET)
	andl    $~TS_COMPAT,TI_status+THREAD_INFO(%rsp,RIP-ARGOFFSET)
	/* clear IF, that popfq doesn't enable interrupts early */
	/* clear IF, that popfq doesn't enable interrupts early */
	andl  $~0x200,EFLAGS-R11(%rsp) 
	andl	$~0x200,EFLAGS-ARGOFFSET(%rsp)
	movl	RIP-R11(%rsp),%edx		/* User %eip */
	movl	RIP-ARGOFFSET(%rsp),%edx		/* User %eip */
	CFI_REGISTER rip,rdx
	CFI_REGISTER rip,rdx
	RESTORE_ARGS 0,24,0,0,0,0
	RESTORE_ARGS 0,24,0,0,0,0
	xorq	%r8,%r8
	xorq	%r8,%r8
+0 −1
Original line number Original line Diff line number Diff line
@@ -83,7 +83,6 @@ For 32-bit we have the following conventions - kernel is built with
#define SS		160
#define SS		160


#define ARGOFFSET	R11
#define ARGOFFSET	R11
#define SWFRAME		ORIG_RAX


	.macro SAVE_ARGS addskip=0, save_rcx=1, save_r891011=1, rax_enosys=0
	.macro SAVE_ARGS addskip=0, save_rcx=1, save_r891011=1, rax_enosys=0
	subq  $9*8+\addskip, %rsp
	subq  $9*8+\addskip, %rsp
+0 −1
Original line number Original line Diff line number Diff line
@@ -190,7 +190,6 @@ enum mcp_flags {
void machine_check_poll(enum mcp_flags flags, mce_banks_t *b);
void machine_check_poll(enum mcp_flags flags, mce_banks_t *b);


int mce_notify_irq(void);
int mce_notify_irq(void);
void mce_notify_process(void);


DECLARE_PER_CPU(struct mce, injectm);
DECLARE_PER_CPU(struct mce, injectm);


Loading