Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
K
kernel-hardening-checker
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
fact-depend
kernel-hardening-checker
Commits
2e33626c
Commit
2e33626c
authored
Jan 15, 2019
by
Alexander Popov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Change 'decision' to 'kspp' for non-default options recommended by KSPP
parent
84951bf6
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
23 additions
and
24 deletions
+23
-24
kconfig-hardened-check.py
kconfig-hardened-check.py
+23
-24
No files found.
kconfig-hardened-check.py
View file @
2e33626c
...
@@ -120,34 +120,28 @@ def construct_checklist():
...
@@ -120,34 +120,28 @@ def construct_checklist():
checklist
.
append
(
OptCheck
(
'X86_INTEL_UMIP'
,
'y'
,
'defconfig'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'X86_INTEL_UMIP'
,
'y'
,
'defconfig'
,
'self_protection'
))
checklist
.
append
(
OR
(
OptCheck
(
'STRICT_KERNEL_RWX'
,
'y'
,
'defconfig'
,
'self_protection'
),
\
checklist
.
append
(
OR
(
OptCheck
(
'STRICT_KERNEL_RWX'
,
'y'
,
'defconfig'
,
'self_protection'
),
\
OptCheck
(
'DEBUG_RODATA'
,
'y'
,
'defconfig'
,
'self_protection'
)))
# before v4.11
OptCheck
(
'DEBUG_RODATA'
,
'y'
,
'defconfig'
,
'self_protection'
)))
# before v4.11
checklist
.
append
(
OptCheck
(
'DEBUG_WX'
,
'y'
,
'ubuntu18'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'RANDOMIZE_BASE'
,
'y'
,
'defconfig'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'RANDOMIZE_BASE'
,
'y'
,
'defconfig'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'RANDOMIZE_MEMORY'
,
'y'
,
'defconfig'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'RANDOMIZE_MEMORY'
,
'y'
,
'defconfig'
,
'self_protection'
))
checklist
.
append
(
OR
(
OptCheck
(
'STACKPROTECTOR_STRONG'
,
'y'
,
'defconfig'
,
'self_protection'
),
\
checklist
.
append
(
OR
(
OptCheck
(
'STACKPROTECTOR_STRONG'
,
'y'
,
'defconfig'
,
'self_protection'
),
\
OptCheck
(
'CC_STACKPROTECTOR_STRONG'
,
'y'
,
'defconfig'
,
'self_protection'
)))
OptCheck
(
'CC_STACKPROTECTOR_STRONG'
,
'y'
,
'defconfig'
,
'self_protection'
)))
checklist
.
append
(
OptCheck
(
'VMAP_STACK'
,
'y'
,
'defconfig'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'VMAP_STACK'
,
'y'
,
'defconfig'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'THREAD_INFO_IN_TASK'
,
'y'
,
'defconfig'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'THREAD_INFO_IN_TASK'
,
'y'
,
'defconfig'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'SCHED_STACK_END_CHECK'
,
'y'
,
'ubuntu18'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'SLUB_DEBUG'
,
'y'
,
'defconfig'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'SLUB_DEBUG'
,
'y'
,
'defconfig'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'SLAB_FREELIST_HARDENED'
,
'y'
,
'ubuntu18'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'SLAB_FREELIST_RANDOM'
,
'y'
,
'ubuntu18'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'HARDENED_USERCOPY'
,
'y'
,
'ubuntu18'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'FORTIFY_SOURCE'
,
'y'
,
'ubuntu18'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'LOCK_DOWN_KERNEL'
,
'y'
,
'ubuntu18'
,
'self_protection'
))
# remember about LOCK_DOWN_MANDATORY
checklist
.
append
(
OptCheck
(
'LOCK_DOWN_KERNEL'
,
'y'
,
'ubuntu18'
,
'self_protection'
))
# remember about LOCK_DOWN_MANDATORY
checklist
.
append
(
OR
(
OptCheck
(
'STRICT_MODULE_RWX'
,
'y'
,
'defconfig'
,
'self_protection'
),
\
checklist
.
append
(
OR
(
OptCheck
(
'STRICT_MODULE_RWX'
,
'y'
,
'defconfig'
,
'self_protection'
),
\
OptCheck
(
'DEBUG_SET_MODULE_RONX'
,
'y'
,
'defconfig'
,
'self_protection'
),
\
OptCheck
(
'DEBUG_SET_MODULE_RONX'
,
'y'
,
'defconfig'
,
'self_protection'
),
\
modules_not_set
))
# DEBUG_SET_MODULE_RONX was before v4.11
modules_not_set
))
# DEBUG_SET_MODULE_RONX was before v4.11
checklist
.
append
(
OR
(
OptCheck
(
'MODULE_SIG'
,
'y'
,
'ubuntu18'
,
'self_protection'
),
\
modules_not_set
))
checklist
.
append
(
OR
(
OptCheck
(
'MODULE_SIG_ALL'
,
'y'
,
'ubuntu18'
,
'self_protection'
),
\
modules_not_set
))
checklist
.
append
(
OR
(
OptCheck
(
'MODULE_SIG_SHA512'
,
'y'
,
'ubuntu18'
,
'self_protection'
),
\
modules_not_set
))
checklist
.
append
(
OptCheck
(
'SYN_COOKIES'
,
'y'
,
'defconfig'
,
'self_protection'
))
# another reason?
checklist
.
append
(
OptCheck
(
'SYN_COOKIES'
,
'y'
,
'defconfig'
,
'self_protection'
))
# another reason?
checklist
.
append
(
OptCheck
(
'DEFAULT_MMAP_MIN_ADDR'
,
'65536'
,
'ubuntu18'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'BUG_ON_DATA_CORRUPTION'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'BUG_ON_DATA_CORRUPTION'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'DEBUG_WX'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'SCHED_STACK_END_CHECK'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'PAGE_POISONING'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'PAGE_POISONING'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'SLAB_FREELIST_HARDENED'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'SLAB_FREELIST_RANDOM'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'HARDENED_USERCOPY'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'HARDENED_USERCOPY_FALLBACK'
,
'is not set'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'FORTIFY_SOURCE'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'GCC_PLUGINS'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'GCC_PLUGINS'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'GCC_PLUGIN_RANDSTRUCT'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'GCC_PLUGIN_RANDSTRUCT'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'GCC_PLUGIN_STRUCTLEAK'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'GCC_PLUGIN_STRUCTLEAK'
,
'y'
,
'kspp'
,
'self_protection'
))
...
@@ -158,8 +152,14 @@ def construct_checklist():
...
@@ -158,8 +152,14 @@ def construct_checklist():
checklist
.
append
(
OptCheck
(
'DEBUG_SG'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'DEBUG_SG'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'DEBUG_CREDENTIALS'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'DEBUG_CREDENTIALS'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'DEBUG_NOTIFIERS'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'DEBUG_NOTIFIERS'
,
'y'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OR
(
OptCheck
(
'MODULE_SIG'
,
'y'
,
'kspp'
,
'self_protection'
),
\
modules_not_set
))
checklist
.
append
(
OR
(
OptCheck
(
'MODULE_SIG_ALL'
,
'y'
,
'kspp'
,
'self_protection'
),
\
modules_not_set
))
checklist
.
append
(
OR
(
OptCheck
(
'MODULE_SIG_SHA512'
,
'y'
,
'kspp'
,
'self_protection'
),
\
modules_not_set
))
checklist
.
append
(
OptCheck
(
'MODULE_SIG_FORCE'
,
'y'
,
'kspp'
,
'self_protection'
))
# refers to LOCK_DOWN_KERNEL
checklist
.
append
(
OptCheck
(
'MODULE_SIG_FORCE'
,
'y'
,
'kspp'
,
'self_protection'
))
# refers to LOCK_DOWN_KERNEL
checklist
.
append
(
OptCheck
(
'
HARDENED_USERCOPY_FALLBACK'
,
'is not set
'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'
DEFAULT_MMAP_MIN_ADDR'
,
'65536
'
,
'kspp'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'GCC_PLUGIN_STACKLEAK'
,
'y'
,
'my'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'GCC_PLUGIN_STACKLEAK'
,
'y'
,
'my'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'SLUB_DEBUG_ON'
,
'y'
,
'my'
,
'self_protection'
))
checklist
.
append
(
OptCheck
(
'SLUB_DEBUG_ON'
,
'y'
,
'my'
,
'self_protection'
))
...
@@ -171,28 +171,27 @@ def construct_checklist():
...
@@ -171,28 +171,27 @@ def construct_checklist():
checklist
.
append
(
OptCheck
(
'SLAB_MERGE_DEFAULT'
,
'is not set'
,
'my'
,
'self_protection'
))
# slab_nomerge
checklist
.
append
(
OptCheck
(
'SLAB_MERGE_DEFAULT'
,
'is not set'
,
'my'
,
'self_protection'
))
# slab_nomerge
checklist
.
append
(
OptCheck
(
'SECURITY'
,
'y'
,
'defconfig'
,
'security_policy'
))
checklist
.
append
(
OptCheck
(
'SECURITY'
,
'y'
,
'defconfig'
,
'security_policy'
))
checklist
.
append
(
OptCheck
(
'SECURITY_YAMA'
,
'y'
,
'
ubuntu18
'
,
'security_policy'
))
checklist
.
append
(
OptCheck
(
'SECURITY_YAMA'
,
'y'
,
'
kspp
'
,
'security_policy'
))
checklist
.
append
(
OptCheck
(
'SECURITY_SELINUX_DISABLE'
,
'is not set'
,
'
ubuntu18
'
,
'security_policy'
))
checklist
.
append
(
OptCheck
(
'SECURITY_SELINUX_DISABLE'
,
'is not set'
,
'
kspp
'
,
'security_policy'
))
checklist
.
append
(
OptCheck
(
'SECCOMP'
,
'y'
,
'defconfig'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'SECCOMP'
,
'y'
,
'defconfig'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'SECCOMP_FILTER'
,
'y'
,
'defconfig'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'SECCOMP_FILTER'
,
'y'
,
'defconfig'
,
'cut_attack_surface'
))
checklist
.
append
(
OR
(
OptCheck
(
'STRICT_DEVMEM'
,
'y'
,
'defconfig'
,
'cut_attack_surface'
),
\
checklist
.
append
(
OR
(
OptCheck
(
'STRICT_DEVMEM'
,
'y'
,
'defconfig'
,
'cut_attack_surface'
),
\
devmem_not_set
))
# refers to LOCK_DOWN_KERNEL
devmem_not_set
))
# refers to LOCK_DOWN_KERNEL
checklist
.
append
(
OptCheck
(
'ACPI_CUSTOM_METHOD'
,
'is not set'
,
'ubuntu18'
,
'cut_attack_surface'
))
# refers to LOCK_DOWN_KERNEL
checklist
.
append
(
OR
(
OptCheck
(
'IO_STRICT_DEVMEM'
,
'y'
,
'kspp'
,
'cut_attack_surface'
),
\
checklist
.
append
(
OptCheck
(
'COMPAT_BRK'
,
'is not set'
,
'ubuntu18'
,
'cut_attack_surface'
))
devmem_not_set
))
# refers to LOCK_DOWN_KERNEL
checklist
.
append
(
OptCheck
(
'DEVKMEM'
,
'is not set'
,
'ubuntu18'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'LEGACY_VSYSCALL_NONE'
,
'y'
,
'kspp'
,
'cut_attack_surface'
))
# 'vsyscall=none'
checklist
.
append
(
OptCheck
(
'COMPAT_VDSO'
,
'is not set'
,
'ubuntu18'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'ACPI_CUSTOM_METHOD'
,
'is not set'
,
'kspp'
,
'cut_attack_surface'
))
# refers to LOCK_DOWN_KERNEL
checklist
.
append
(
OptCheck
(
'COMPAT_BRK'
,
'is not set'
,
'kspp'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'DEVKMEM'
,
'is not set'
,
'kspp'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'COMPAT_VDSO'
,
'is not set'
,
'kspp'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'X86_PTDUMP'
,
'is not set'
,
'ubuntu18'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'X86_PTDUMP'
,
'is not set'
,
'ubuntu18'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'ZSMALLOC_STAT'
,
'is not set'
,
'ubuntu18'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'ZSMALLOC_STAT'
,
'is not set'
,
'ubuntu18'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'PAGE_OWNER'
,
'is not set'
,
'ubuntu18'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'PAGE_OWNER'
,
'is not set'
,
'ubuntu18'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'DEBUG_KMEMLEAK'
,
'is not set'
,
'ubuntu18'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'DEBUG_KMEMLEAK'
,
'is not set'
,
'ubuntu18'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'BINFMT_AOUT'
,
'is not set'
,
'ubuntu18'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'BINFMT_AOUT'
,
'is not set'
,
'ubuntu18'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'MMIOTRACE_TEST'
,
'is not set'
,
'ubuntu18'
,
'cut_attack_surface'
))
# refers to LOCK_DOWN_KERNEL
checklist
.
append
(
OptCheck
(
'MMIOTRACE_TEST'
,
'is not set'
,
'ubuntu18'
,
'cut_attack_surface'
))
# refers to LOCK_DOWN_KERNEL
checklist
.
append
(
OR
(
OptCheck
(
'IO_STRICT_DEVMEM'
,
'y'
,
'kspp'
,
'cut_attack_surface'
),
\
devmem_not_set
))
# refers to LOCK_DOWN_KERNEL
checklist
.
append
(
OptCheck
(
'LEGACY_VSYSCALL_NONE'
,
'y'
,
'kspp'
,
'cut_attack_surface'
))
# 'vsyscall=none'
checklist
.
append
(
OptCheck
(
'BINFMT_MISC'
,
'is not set'
,
'kspp'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'BINFMT_MISC'
,
'is not set'
,
'kspp'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'INET_DIAG'
,
'is not set'
,
'kspp'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'INET_DIAG'
,
'is not set'
,
'kspp'
,
'cut_attack_surface'
))
checklist
.
append
(
OptCheck
(
'KEXEC'
,
'is not set'
,
'kspp'
,
'cut_attack_surface'
))
# refers to LOCK_DOWN_KERNEL
checklist
.
append
(
OptCheck
(
'KEXEC'
,
'is not set'
,
'kspp'
,
'cut_attack_surface'
))
# refers to LOCK_DOWN_KERNEL
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment