diff options
author | Juergen Gross <jgross@suse.com> | 2021-01-20 14:55:46 +0100 |
---|---|---|
committer | Borislav Petkov <bp@suse.de> | 2021-02-10 12:36:45 +0100 |
commit | ab234a260b1f625b26cbefa93ca365b0ae66df33 (patch) | |
tree | 3308ecacbf6f66119fb14707eb506de1ab43e027 /arch/x86/include/asm/paravirt.h | |
parent | afd30525a659ac0ae0904f0cb4a2ca75522c3123 (diff) | |
download | linux-ab234a260b1f625b26cbefa93ca365b0ae66df33.tar.gz linux-ab234a260b1f625b26cbefa93ca365b0ae66df33.tar.bz2 linux-ab234a260b1f625b26cbefa93ca365b0ae66df33.zip |
x86/pv: Rework arch_local_irq_restore() to not use popf
POPF is a rather expensive operation, so don't use it for restoring
irq flags. Instead, test whether interrupts are enabled in the flags
parameter and enable interrupts via STI in that case.
This results in the restore_fl paravirt op to be no longer needed.
Suggested-by: Andy Lutomirski <luto@kernel.org>
Signed-off-by: Juergen Gross <jgross@suse.com>
Signed-off-by: Borislav Petkov <bp@suse.de>
Link: https://lkml.kernel.org/r/20210120135555.32594-7-jgross@suse.com
Diffstat (limited to 'arch/x86/include/asm/paravirt.h')
-rw-r--r-- | arch/x86/include/asm/paravirt.h | 5 |
1 files changed, 0 insertions, 5 deletions
diff --git a/arch/x86/include/asm/paravirt.h b/arch/x86/include/asm/paravirt.h index dd43b1100a87..4abf110e2243 100644 --- a/arch/x86/include/asm/paravirt.h +++ b/arch/x86/include/asm/paravirt.h @@ -648,11 +648,6 @@ static inline notrace unsigned long arch_local_save_flags(void) return PVOP_CALLEE0(unsigned long, irq.save_fl); } -static inline notrace void arch_local_irq_restore(unsigned long f) -{ - PVOP_VCALLEE1(irq.restore_fl, f); -} - static inline notrace void arch_local_irq_disable(void) { PVOP_VCALLEE0(irq.irq_disable); |