2023-03-30 17:08:47 +11:00
|
|
|
## Copyright (C) 2019 - 2023 ENCRYPTED SUPPORT LP <adrelanos@whonix.org>
|
2020-02-12 18:42:13 +00:00
|
|
|
## See the file COPYING for copying conditions.
|
|
|
|
|
2024-05-05 12:52:51 +00:00
|
|
|
## Enables known mitigations for CPU vulnerabilities.
|
2020-02-12 18:42:13 +00:00
|
|
|
##
|
2022-07-19 02:29:46 +10:00
|
|
|
## https://www.kernel.org/doc/html/latest/admin-guide/hw-vuln/index.html
|
2024-01-29 12:57:48 +00:00
|
|
|
## https://www.kernel.org/doc/html/latest/admin-guide/kernel-parameters.html
|
2020-02-12 18:42:13 +00:00
|
|
|
## https://forums.whonix.org/t/should-all-kernel-patches-for-cpu-bugs-be-unconditionally-enabled-vs-performance-vs-applicability/7647
|
|
|
|
|
2024-05-05 12:50:39 +00:00
|
|
|
## Check for potential updates directly from AMD and Intel.
|
|
|
|
##
|
|
|
|
## https://www.amd.com/en/resources/product-security.html
|
|
|
|
## https://www.intel.com/content/www/us/en/developer/topic-technology/software-security-guidance/advisory-guidance.html
|
|
|
|
## https://www.intel.com/content/www/us/en/developer/topic-technology/software-security-guidance/disclosure-documentation.html
|
|
|
|
|
2024-05-01 13:49:34 +10:00
|
|
|
## Enable a subset of known mitigations for CPU vulnerabilities and disable SMT.
|
2024-01-29 12:58:14 +00:00
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX mitigations=auto,nosmt"
|
|
|
|
|
2024-05-01 13:47:40 +10:00
|
|
|
## Enable mitigations for both Spectre Variant 2 (indirect branch speculation)
|
|
|
|
## and Intel branch history injection (BHI) vulnerabilities.
|
2020-02-12 18:42:13 +00:00
|
|
|
##
|
|
|
|
## https://www.kernel.org/doc/html/latest/admin-guide/hw-vuln/spectre.html
|
2024-05-01 13:47:40 +10:00
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX spectre_v2=on spectre_bhi=on"
|
2020-02-12 18:42:13 +00:00
|
|
|
|
2024-05-01 13:48:13 +10:00
|
|
|
## Disable Speculative Store Bypass (Spectre Variant 4).
|
|
|
|
##
|
|
|
|
## https://www.suse.com/support/kb/doc/?id=000019189
|
2020-02-12 18:42:13 +00:00
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX spec_store_bypass_disable=on"
|
|
|
|
|
2022-07-19 02:29:46 +10:00
|
|
|
## Enable mitigations for the L1TF vulnerability through disabling SMT
|
|
|
|
## and L1D flush runtime control.
|
2020-02-12 18:42:13 +00:00
|
|
|
##
|
2022-07-19 02:29:46 +10:00
|
|
|
## https://www.kernel.org/doc/html/latest/admin-guide/hw-vuln/l1tf.html
|
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX l1tf=full,force"
|
2020-02-12 18:42:13 +00:00
|
|
|
|
2022-07-19 02:29:46 +10:00
|
|
|
## Enable mitigations for the MDS vulnerability through clearing buffer cache
|
|
|
|
## and disabling SMT.
|
2020-02-12 18:42:13 +00:00
|
|
|
##
|
|
|
|
## https://www.kernel.org/doc/html/latest/admin-guide/hw-vuln/mds.html
|
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX mds=full,nosmt"
|
|
|
|
|
2022-07-19 02:29:46 +10:00
|
|
|
## Patches the TAA vulnerability by disabling TSX and enables mitigations using
|
|
|
|
## TSX Async Abort along with disabling SMT.
|
2020-02-12 18:42:13 +00:00
|
|
|
##
|
2022-07-19 02:29:46 +10:00
|
|
|
## https://www.kernel.org/doc/html/latest/admin-guide/hw-vuln/tsx_async_abort.html
|
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX tsx=off tsx_async_abort=full,nosmt"
|
2020-02-12 18:42:13 +00:00
|
|
|
|
|
|
|
## Mark all huge pages in the EPT as non-executable to mitigate iTLB multihit.
|
|
|
|
##
|
2022-07-19 02:29:46 +10:00
|
|
|
## https://www.kernel.org/doc/html/latest/admin-guide/hw-vuln/multihit.html
|
2020-02-12 18:42:13 +00:00
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX kvm.nx_huge_pages=force"
|
2022-07-19 02:30:49 +10:00
|
|
|
|
|
|
|
## Enables mitigations for SRBDS to prevent MDS attacks on RDRAND and RDSEED instructions.
|
2022-07-19 03:16:08 +10:00
|
|
|
## Only mitigated through microcode updates from Intel.
|
2022-07-19 02:30:49 +10:00
|
|
|
##
|
|
|
|
## https://www.kernel.org/doc/html/latest/admin-guide/hw-vuln/special-register-buffer-data-sampling.html
|
2022-07-19 03:16:08 +10:00
|
|
|
## https://access.redhat.com/solutions/5142691
|
2022-07-19 02:32:41 +10:00
|
|
|
|
2022-07-19 03:38:41 +10:00
|
|
|
## Force disable SMT as it has caused numerous CPU vulnerabilities.
|
|
|
|
## The only full mitigation of cross-HT attacks is to disable SMT.
|
|
|
|
##
|
|
|
|
## https://www.kernel.org/doc/html/latest/admin-guide/hw-vuln/core-scheduling.html
|
|
|
|
## https://forums.whonix.org/t/should-all-kernel-patches-for-cpu-bugs-be-unconditionally-enabled-vs-performance-vs-applicability/7647/17
|
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX nosmt=force"
|
|
|
|
|
2022-07-19 02:32:41 +10:00
|
|
|
## Enables the prctl interface to prevent leaks from L1D on context switches.
|
|
|
|
##
|
|
|
|
## https://www.kernel.org/doc/html/latest/admin-guide/hw-vuln/l1d_flush.html
|
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX l1d_flush=on"
|
2022-07-19 02:33:16 +10:00
|
|
|
|
|
|
|
## Mitigates numerous MMIO Stale Data vulnerabilities and disables SMT.
|
|
|
|
##
|
|
|
|
## https://www.kernel.org/doc/html/latest/admin-guide/hw-vuln/processor_mmio_stale_data.html
|
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX mmio_stale_data=full,nosmt"
|
2024-01-29 12:58:51 +00:00
|
|
|
|
|
|
|
## Enable mitigations for RETBleed (Arbitrary Speculative Code Execution with
|
|
|
|
## Return Instructions) vulnerability and disable SMT.
|
|
|
|
##
|
2024-05-01 13:49:00 +10:00
|
|
|
## https://www.suse.com/support/kb/doc/?id=000020693
|
2024-01-29 12:58:51 +00:00
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX retbleed=auto,nosmt"
|
2024-01-29 12:59:13 +00:00
|
|
|
|
|
|
|
## Control RAS overflow mitigation on AMD Zen CPUs.
|
2024-01-29 13:39:40 +00:00
|
|
|
## The current default kernel parameter is 'spec_rstack_overflow=safe-ret'
|
|
|
|
## This default will used until provided sufficient evidence to modify.
|
2024-01-29 12:59:13 +00:00
|
|
|
##
|
|
|
|
## https://www.kernel.org/doc/html/latest/admin-guide/hw-vuln/srso.html
|
2024-05-01 13:50:42 +10:00
|
|
|
|
|
|
|
## Mitigates Gather Data Sampling (GDS) vulnerability.
|
|
|
|
## Note for systems that have not received a suitable microcode update this will
|
|
|
|
## entirely disable use of the AVX instructions set.
|
|
|
|
##
|
|
|
|
## https://www.kernel.org/doc/html/latest/admin-guide/hw-vuln/gather_data_sampling.html
|
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX gather_data_sampling=force"
|
2024-05-01 13:55:09 +10:00
|
|
|
|
|
|
|
## Register File Data Sampling (RFDS) mitigation on Intel Atom CPUs which
|
|
|
|
## encompasses E-cores on hybrid architectures.
|
|
|
|
##
|
|
|
|
## https://www.kernel.org/doc/html/latest/admin-guide/hw-vuln/reg-file-data-sampling.html
|
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX reg_file_data_sampling=on"
|