|
@@ -905,7 +905,7 @@ apicinterrupt IRQ_WORK_VECTOR irq_work_interrupt smp_irq_work_interrupt
|
|
|
*/
|
|
*/
|
|
|
#define CPU_TSS_IST(x) PER_CPU_VAR(cpu_tss_rw) + (TSS_ist + ((x) - 1) * 8)
|
|
#define CPU_TSS_IST(x) PER_CPU_VAR(cpu_tss_rw) + (TSS_ist + ((x) - 1) * 8)
|
|
|
|
|
|
|
|
-.macro idtentry sym do_sym has_error_code:req paranoid=0 shift_ist=-1
|
|
|
|
|
|
|
+.macro idtentry sym do_sym has_error_code:req paranoid=0 shift_ist=-1 create_gap=0
|
|
|
ENTRY(\sym)
|
|
ENTRY(\sym)
|
|
|
UNWIND_HINT_IRET_REGS offset=\has_error_code*8
|
|
UNWIND_HINT_IRET_REGS offset=\has_error_code*8
|
|
|
|
|
|
|
@@ -925,6 +925,20 @@ ENTRY(\sym)
|
|
|
jnz .Lfrom_usermode_switch_stack_\@
|
|
jnz .Lfrom_usermode_switch_stack_\@
|
|
|
.endif
|
|
.endif
|
|
|
|
|
|
|
|
|
|
+ .if \create_gap == 1
|
|
|
|
|
+ /*
|
|
|
|
|
+ * If coming from kernel space, create a 6-word gap to allow the
|
|
|
|
|
+ * int3 handler to emulate a call instruction.
|
|
|
|
|
+ */
|
|
|
|
|
+ testb $3, CS-ORIG_RAX(%rsp)
|
|
|
|
|
+ jnz .Lfrom_usermode_no_gap_\@
|
|
|
|
|
+ .rept 6
|
|
|
|
|
+ pushq 5*8(%rsp)
|
|
|
|
|
+ .endr
|
|
|
|
|
+ UNWIND_HINT_IRET_REGS offset=8
|
|
|
|
|
+.Lfrom_usermode_no_gap_\@:
|
|
|
|
|
+ .endif
|
|
|
|
|
+
|
|
|
.if \paranoid
|
|
.if \paranoid
|
|
|
call paranoid_entry
|
|
call paranoid_entry
|
|
|
.else
|
|
.else
|
|
@@ -1154,7 +1168,7 @@ apicinterrupt3 HYPERV_STIMER0_VECTOR \
|
|
|
#endif /* CONFIG_HYPERV */
|
|
#endif /* CONFIG_HYPERV */
|
|
|
|
|
|
|
|
idtentry debug do_debug has_error_code=0 paranoid=1 shift_ist=DEBUG_STACK
|
|
idtentry debug do_debug has_error_code=0 paranoid=1 shift_ist=DEBUG_STACK
|
|
|
-idtentry int3 do_int3 has_error_code=0
|
|
|
|
|
|
|
+idtentry int3 do_int3 has_error_code=0 create_gap=1
|
|
|
idtentry stack_segment do_stack_segment has_error_code=1
|
|
idtentry stack_segment do_stack_segment has_error_code=1
|
|
|
|
|
|
|
|
#ifdef CONFIG_XEN
|
|
#ifdef CONFIG_XEN
|