2022-05-21 01:46:38 +07:00
|
|
|
## Copyright (C) 2019 - 2022 ENCRYPTED SUPPORT LP <adrelanos@whonix.org>
|
2019-11-05 21:55:43 +07:00
|
|
|
## See the file COPYING for copying conditions.
|
|
|
|
|
2020-04-08 23:46:11 +07:00
|
|
|
kpkg="linux-image-$(dpkg --print-architecture)" || true
|
|
|
|
kver="$(dpkg-query --show --showformat='${Version}' "$kpkg")" 2>/dev/null || true
|
2019-12-23 17:00:35 +07:00
|
|
|
#echo "## kver: $kver"
|
2019-12-19 03:43:01 +07:00
|
|
|
|
|
|
|
## Disables the merging of slabs of similar sizes.
|
|
|
|
## Sometimes a slab can be used in a vulnerable way which an attacker can exploit.
|
2019-05-05 21:42:03 +07:00
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX slab_nomerge"
|
2019-05-06 03:17:33 +07:00
|
|
|
|
2021-09-09 23:16:18 +07:00
|
|
|
## Enables sanity checks (F) and redzoning (Z).
|
2022-07-13 01:32:03 +07:00
|
|
|
## Disabled due to kernel deciding to implicitly disable kernel pointer hashing
|
|
|
|
## https://github.com/torvalds/linux/commit/792702911f581f7793962fbeb99d5c3a1b28f4c3
|
|
|
|
#GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX slub_debug=FZ"
|
2019-12-24 02:44:52 +07:00
|
|
|
|
2021-09-09 23:16:18 +07:00
|
|
|
## Zero memory at allocation and free time.
|
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX init_on_alloc=1 init_on_free=1"
|
2019-05-06 03:17:33 +07:00
|
|
|
|
2019-11-05 21:55:43 +07:00
|
|
|
## Makes the kernel panic on uncorrectable errors in ECC memory that an attacker could exploit.
|
2019-05-06 03:17:33 +07:00
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX mce=0"
|
2019-06-24 00:54:34 +07:00
|
|
|
|
2019-11-05 21:55:43 +07:00
|
|
|
## Enables Kernel Page Table Isolation which mitigates Meltdown and improves KASLR.
|
2019-06-24 00:54:34 +07:00
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX pti=on"
|
|
|
|
|
2019-12-19 03:43:01 +07:00
|
|
|
## Vsyscalls are obsolete, are at fixed addresses and are a target for ROP.
|
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX vsyscall=none"
|
|
|
|
|
|
|
|
## Enables page allocator freelist randomization.
|
2021-09-09 23:16:18 +07:00
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX page_alloc.shuffle=1"
|
2019-12-19 03:43:01 +07:00
|
|
|
|
2022-07-13 01:34:35 +07:00
|
|
|
## Enables randomisation of the kernel stack offset on syscall entries (introduced in kernel 5.13).
|
|
|
|
## https://lkml.org/lkml/2019/3/18/246
|
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX randomize_kstack_offset=on"
|
|
|
|
|
2019-12-19 03:43:01 +07:00
|
|
|
## Enables kernel lockdown.
|
2019-12-23 15:41:54 +07:00
|
|
|
##
|
|
|
|
## Disabled for now as it enforces module signature verification which breaks
|
|
|
|
## too many things.
|
2019-12-23 15:46:02 +07:00
|
|
|
## https://forums.whonix.org/t/enforce-kernel-module-software-signature-verification-module-signing-disallow-kernel-module-loading-by-default/7880
|
2019-12-23 15:41:54 +07:00
|
|
|
##
|
|
|
|
#if dpkg --compare-versions "${kver}" ge "5.4"; then
|
|
|
|
# GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX lockdown=confidentiality"
|
|
|
|
#fi
|
2020-02-17 02:51:32 +07:00
|
|
|
|
|
|
|
## Gather more entropy during boot.
|
|
|
|
##
|
|
|
|
## Requires linux-hardened kernel patch.
|
|
|
|
## https://github.com/anthraxx/linux-hardened
|
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX extra_latent_entropy"
|
2020-04-23 23:26:31 +07:00
|
|
|
|
2020-09-29 02:21:20 +07:00
|
|
|
## Restrict access to debugfs since it can contain a lot of sensitive information.
|
|
|
|
## https://lkml.org/lkml/2020/7/16/122
|
|
|
|
## https://github.com/torvalds/linux/blob/fb1201aececc59990b75ef59fca93ae4aa1e1444/Documentation/admin-guide/kernel-parameters.txt#L835-L848
|
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX debugfs=off"
|
2022-07-20 01:06:35 +07:00
|
|
|
|
|
|
|
## Force the kernel to panic on "oopses" (which may be due to false positives)
|
|
|
|
GRUB_CMDLINE_LINUX="$GRUB_CMDLINE_LINUX oops=panic"
|