Linus Torvalds
94a855111e
Merge tag 'x86_core_for_v6.2' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
...
Pull x86 core updates from Borislav Petkov:
- Add the call depth tracking mitigation for Retbleed which has been
long in the making. It is a lighterweight software-only fix for
Skylake-based cores where enabling IBRS is a big hammer and causes a
significant performance impact.
What it basically does is, it aligns all kernel functions to 16 bytes
boundary and adds a 16-byte padding before the function, objtool
collects all functions' locations and when the mitigation gets
applied, it patches a call accounting thunk which is used to track
the call depth of the stack at any time.
When that call depth reaches a magical, microarchitecture-specific
value for the Return Stack Buffer, the code stuffs that RSB and
avoids its underflow which could otherwise lead to the Intel variant
of Retbleed.
This software-only solution brings a lot of the lost performance
back, as benchmarks suggest:
https://lore.kernel.org/all/20220915111039.092790446@infradead.org/
That page above also contains a lot more detailed explanation of the
whole mechanism
- Implement a new control flow integrity scheme called FineIBT which is
based on the software kCFI implementation and uses hardware IBT
support where present to annotate and track indirect branches using a
hash to validate them
- Other misc fixes and cleanups
* tag 'x86_core_for_v6.2' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (80 commits)
x86/paravirt: Use common macro for creating simple asm paravirt functions
x86/paravirt: Remove clobber bitmask from .parainstructions
x86/debug: Include percpu.h in debugreg.h to get DECLARE_PER_CPU() et al
x86/cpufeatures: Move X86_FEATURE_CALL_DEPTH from bit 18 to bit 19 of word 11, to leave space for WIP X86_FEATURE_SGX_EDECCSSA bit
x86/Kconfig: Enable kernel IBT by default
x86,pm: Force out-of-line memcpy()
objtool: Fix weak hole vs prefix symbol
objtool: Optimize elf_dirty_reloc_sym()
x86/cfi: Add boot time hash randomization
x86/cfi: Boot time selection of CFI scheme
x86/ibt: Implement FineIBT
objtool: Add --cfi to generate the .cfi_sites section
x86: Add prefix symbols for function padding
objtool: Add option to generate prefix symbols
objtool: Avoid O(bloody terrible) behaviour -- an ode to libelf
objtool: Slice up elf_create_section_symbol()
kallsyms: Revert "Take callthunks into account"
x86: Unconfuse CONFIG_ and X86_FEATURE_ namespaces
x86/retpoline: Fix crash printing warning
x86/paravirt: Fix a !PARAVIRT build warning
...
2022-12-14 15:03:00 -08:00
..
2020-08-10 01:32:59 +09:00
2022-11-11 18:14:59 +08:00
2022-05-09 17:20:37 -07:00
2022-11-18 13:55:09 -08:00
2022-12-12 16:42:57 -08:00
2022-06-15 10:29:10 +02:00
2022-07-17 17:31:39 -07:00
2022-07-29 18:12:34 -07:00
2022-11-21 14:30:53 -07:00
2022-08-07 10:03:24 -07:00
2021-07-08 11:48:20 -07:00
2022-12-13 10:43:59 -08:00
2022-11-18 02:15:15 +01:00
2022-02-13 16:50:06 -08:00
2022-11-23 19:50:15 +01:00
2021-10-19 23:44:30 +08:00
2020-08-10 01:32:59 +09:00
2020-12-29 15:36:49 -08:00
2021-09-24 16:13:35 -07:00
2022-10-03 03:52:58 +09:00
2022-04-26 17:58:51 -04:00
2018-06-12 16:19:22 -07:00
2019-05-24 17:39:02 +02:00
2019-05-24 17:39:02 +02:00
2020-11-18 14:15:17 -06:00
2022-01-20 08:52:55 +02:00
2022-06-01 18:29:06 -07:00
2019-05-30 11:26:32 -07:00
2021-12-13 10:56:09 +01:00
2021-10-01 16:52:48 -04:00
2022-08-02 17:14:47 -06:00
2017-11-02 11:10:55 +01:00
2021-05-06 19:24:12 -07:00
2020-10-16 13:25:14 -06:00
2022-09-26 12:19:12 -07:00
2019-05-21 10:50:45 +02:00
2022-04-26 17:58:51 -04:00
2022-04-26 17:58:51 -04:00
2020-06-11 15:14:53 +02:00
2022-06-16 19:58:21 -07:00
2018-08-16 12:14:42 -07:00
2022-05-19 23:46:10 +02:00
2019-05-24 17:27:11 +02:00
2021-07-08 11:48:22 -07:00
2022-09-01 16:55:35 +02:00
2017-11-02 11:10:55 +01:00
2020-08-20 15:45:14 -04:00
2019-06-19 17:09:55 +02:00
2017-11-02 11:10:55 +01:00
2022-10-11 17:42:58 -06:00
2022-09-11 21:55:06 -07:00
2019-05-24 17:39:02 +02:00
2021-10-01 16:52:48 -04:00
2019-10-18 15:01:57 +02:00
2022-10-06 05:57:36 -07:00
2022-10-01 10:22:57 -07:00
2019-06-19 17:09:06 +02:00
2021-01-21 14:06:00 -07:00
2021-05-06 19:24:12 -07:00
2019-06-19 17:09:06 +02:00
2022-01-31 11:21:43 +11:00
2018-07-27 19:04:33 +08:00
2022-01-31 11:21:43 +11:00
2022-03-07 12:48:35 -07:00
2022-03-07 12:48:35 -07:00
2019-06-19 17:09:06 +02:00
2022-06-07 10:27:38 +02:00
2020-06-18 17:26:43 +10:00
2017-11-02 11:10:55 +01:00
2021-08-19 09:02:55 +09:00
2021-06-22 13:56:43 +02:00
2022-12-12 17:28:58 -08:00
2018-06-12 23:33:24 +02:00
2021-07-01 11:06:05 -07:00
2020-01-31 10:30:40 -08:00
2021-07-01 11:06:06 -07:00
2021-05-06 19:24:12 -07:00
2021-07-01 11:06:06 -07:00
2021-10-19 23:44:30 +08:00
2021-11-08 16:55:26 -08:00
2020-07-31 11:49:08 +02:00
2021-08-13 14:09:32 -10:00
2022-09-01 18:04:43 +02:00
2020-11-20 14:45:33 +11:00
2022-04-22 21:30:57 +02:00
2022-09-07 17:04:49 +02:00
2020-10-16 11:11:20 -07:00
2022-09-11 21:55:10 -07:00
2020-12-15 22:46:15 -08:00
2022-07-17 17:31:38 -07:00
2020-12-15 22:46:15 -08:00
2021-01-03 20:05:18 -05:00
2020-10-16 11:11:22 -07:00
2022-12-12 16:22:22 -08:00
2020-01-08 16:59:19 +00:00
2022-11-18 02:15:15 +01:00
2022-10-06 05:57:36 -07:00
2022-09-19 14:35:08 +02:00
2022-11-22 21:08:28 -08:00
2018-07-27 19:04:33 +08:00
2022-03-07 12:48:35 -07:00
2022-01-15 08:47:31 -08:00
2019-10-14 15:04:00 -07:00
2022-04-29 14:38:01 -07:00
2017-02-24 17:46:57 -08:00
2022-04-27 10:57:33 -07:00
2019-05-13 11:07:33 +02:00
2022-07-10 13:55:49 -07:00
2017-11-02 11:10:55 +01:00
2019-05-21 10:50:45 +02:00
2022-11-29 16:34:15 -04:00
2019-06-19 17:09:56 +02:00
2022-10-03 14:03:21 -07:00
2018-05-09 06:55:44 +02:00
2022-12-13 10:43:59 -08:00
2022-04-13 21:32:21 +02:00
2019-05-30 11:26:32 -07:00
2022-11-19 00:56:15 +01:00
2019-05-24 17:27:11 +02:00
2021-08-19 09:02:55 +09:00
2022-12-14 09:15:43 -08:00
2022-12-14 15:03:00 -08:00
2022-12-13 19:29:45 -08:00
2022-10-18 15:07:33 -07:00
2022-03-22 15:57:11 -07:00
2022-10-11 12:01:24 +02:00
2022-11-08 15:57:24 -08:00
2022-07-14 15:45:26 -07:00
2021-07-08 11:48:20 -07:00
2019-06-19 17:09:08 +02:00
2021-12-28 11:26:18 +01:00
2022-11-18 02:15:15 +01:00
2022-05-13 07:20:13 -07:00
2021-05-19 15:05:11 +02:00
2020-10-16 11:11:19 -07:00
2021-08-13 18:37:38 +02:00
2022-06-16 19:58:20 -07:00
2021-07-08 11:48:20 -07:00
2022-04-05 13:32:27 -06:00
2022-11-18 13:55:06 -08:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2021-12-04 10:56:24 +01:00
2022-07-03 14:40:28 -07:00
2022-03-11 10:42:56 +01:00
2021-02-17 17:31:06 -06:00
2022-11-22 19:38:39 -07:00
2019-05-24 17:39:02 +02:00
2022-12-14 12:20:00 -08:00
2022-11-30 15:58:41 -08:00
2018-10-16 13:45:44 +02:00
2022-12-14 12:20:00 -08:00
2019-05-21 10:50:45 +02:00
2020-09-26 10:33:57 -07:00
2017-11-02 11:10:55 +01:00
2019-05-24 17:39:02 +02:00
2022-11-09 19:28:02 -08:00
2019-05-21 10:50:45 +02:00
2022-11-08 15:06:56 -08:00
2022-04-22 21:30:57 +02:00
2022-11-30 16:13:16 -08:00
2017-11-02 11:10:55 +01:00
2021-12-24 14:54:29 -08:00
2019-05-21 10:50:45 +02:00
2022-11-18 13:55:06 -08:00
2022-10-03 17:34:32 -07:00
2022-11-02 12:39:27 -07:00
2022-12-12 15:06:30 -08:00
2021-04-16 16:10:37 -07:00
2021-07-01 11:06:05 -07:00
2021-09-19 17:13:35 -07:00
2022-11-30 15:58:40 -08:00
2019-05-21 10:50:45 +02:00
2022-11-30 13:16:40 -08:00
2019-05-21 11:28:45 +02:00
2019-05-21 10:50:45 +02:00
2022-05-22 11:32:30 -07:00
2022-11-30 16:13:17 -08:00
2022-10-11 17:42:58 -06:00
2022-08-24 13:46:57 +01:00
2019-09-25 17:51:39 -07:00
2020-08-12 10:58:00 -07:00
2022-02-06 11:05:28 +00:00
2021-07-08 11:48:20 -07:00
2022-12-09 10:42:56 +00:00
2022-12-13 10:43:59 -08:00
2022-11-09 11:29:21 -07:00
2021-07-08 11:48:20 -07:00
2022-09-23 16:46:19 +02:00
2019-08-08 07:45:01 -06:00
2022-09-26 19:46:29 -07:00
2022-11-01 10:04:52 -07:00
2022-06-03 10:34:34 -07:00
2022-12-12 16:42:57 -08:00
2022-07-17 17:31:41 -07:00
2022-03-17 20:17:18 -07:00
2022-10-03 14:03:18 -07:00
2022-09-30 13:21:22 -06:00
2019-05-30 11:26:32 -07:00
2022-09-05 14:51:46 +01:00
2022-10-28 16:07:57 -07:00
2022-04-19 21:58:47 +02:00
2022-04-19 21:58:47 +02:00
2022-11-01 10:04:52 -07:00
2021-06-18 11:43:09 +02:00
2022-10-01 10:22:58 -07:00
2021-07-08 11:48:20 -07:00
2020-08-12 10:58:00 -07:00
2019-07-01 19:34:46 -07:00
2022-11-11 18:18:05 -08:00
2019-05-21 10:50:45 +02:00
2022-09-07 17:04:49 +02:00
2022-05-19 19:28:37 +02:00
2022-11-18 02:15:22 +01:00
2021-01-18 11:03:26 +01:00
2022-07-17 17:14:36 -07:00
2022-01-20 08:52:54 +02:00
2022-11-18 02:18:02 +01:00
2022-10-12 18:51:50 -07:00
2022-10-12 18:51:50 -07:00
2018-10-15 16:31:29 -04:00
2022-03-29 15:13:36 -07:00
2022-11-18 02:15:22 +01:00
2022-11-16 13:32:32 +00:00
2022-11-18 02:15:15 +01:00
2022-02-25 09:36:06 +01:00
2022-11-08 15:57:22 -08:00
2018-10-16 13:45:44 +02:00
2022-10-12 18:51:49 -07:00
2022-10-11 17:42:58 -06:00
2019-05-21 10:50:45 +02:00
2022-10-11 17:42:58 -06:00
2017-02-26 11:03:38 -05:00
2022-12-12 16:22:22 -08:00
2021-12-06 16:04:44 -08:00
2022-12-13 15:47:48 -08:00
2021-09-06 11:04:03 -07:00
2021-09-08 11:50:26 -07:00
2019-06-05 17:36:37 +02:00
2019-06-05 17:36:37 +02:00
2022-04-29 14:38:00 -07:00
2022-05-03 10:15:07 +02:00
2022-01-20 08:52:55 +02:00
2019-10-16 14:56:21 +02:00
2017-07-21 09:38:30 +02:00
2022-11-18 02:18:02 +01:00
2022-03-28 19:25:11 -04:00
2022-11-18 02:15:15 +01:00
2019-10-03 12:12:23 -04:00
2021-02-17 14:08:01 +01:00
2022-06-15 17:41:12 +02:00
2022-07-17 17:31:39 -07:00
2020-11-18 14:15:17 -06:00
2020-04-07 10:43:43 -07:00
2022-12-02 13:04:44 -08:00
2021-02-05 11:03:47 -08:00
2019-05-24 17:39:02 +02:00
2018-06-07 17:34:39 -07:00
2022-10-03 14:03:18 -07:00
2022-10-11 17:42:58 -06:00
2022-12-12 16:22:22 -08:00
2017-11-02 11:10:55 +01:00
2022-06-09 16:24:25 -04:00
2020-08-12 10:58:00 -07:00