diff options
author | Linus Torvalds <[email protected]> | 2024-04-03 16:36:44 -0700 |
---|---|---|
committer | Thomas Gleixner <[email protected]> | 2024-04-08 19:27:05 +0200 |
commit | 1e3ad78334a69b36e107232e337f9d693dcc9df2 (patch) | |
tree | 11162955093106a59ca3825365580797e0aff750 /drivers/usb/cdns3/cdns3-pci-wrap.c | |
parent | 0cd01ac5dcb1e18eb18df0f0d05b5de76522a437 (diff) |
x86/syscall: Don't force use of indirect calls for system calls
Make <asm/syscall.h> build a switch statement instead, and the compiler can
either decide to generate an indirect jump, or - more likely these days due
to mitigations - just a series of conditional branches.
Yes, the conditional branches also have branch prediction, but the branch
prediction is much more controlled, in that it just causes speculatively
running the wrong system call (harmless), rather than speculatively running
possibly wrong random less controlled code gadgets.
This doesn't mitigate other indirect calls, but the system call indirection
is the first and most easily triggered case.
Signed-off-by: Linus Torvalds <[email protected]>
Signed-off-by: Daniel Sneddon <[email protected]>
Signed-off-by: Thomas Gleixner <[email protected]>
Reviewed-by: Josh Poimboeuf <[email protected]>
Diffstat (limited to 'drivers/usb/cdns3/cdns3-pci-wrap.c')
0 files changed, 0 insertions, 0 deletions