diff options
| author | Andrey Konovalov <andreyknvl@gmail.com> | 2017-06-14 14:13:36 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2017-06-14 14:13:36 +0200 |
| commit | fbec6b14d43b3885014393d928daa3ef2bbb1e8e (patch) | |
| tree | 4ac9abbbd2216e56e8eb058ef26b2c146f595ac9 /docs/linux_kernel_configs.md | |
| parent | 7b96fa44e1a1b0c6c6369f899b378eee7583a419 (diff) | |
| parent | 4731d5a4ac84accb8f4c3e224816d81055041e2b (diff) | |
Merge pull request #231 from xairy/up-docs
Move all documentation to docs/
Diffstat (limited to 'docs/linux_kernel_configs.md')
| -rw-r--r-- | docs/linux_kernel_configs.md | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/docs/linux_kernel_configs.md b/docs/linux_kernel_configs.md new file mode 100644 index 000000000..5627a446f --- /dev/null +++ b/docs/linux_kernel_configs.md @@ -0,0 +1,55 @@ +# Linux kernel configs + +List of recommended kernel configs for `syzkaller`: + +## Syzkaller features + +To enable coverage collection, which is extremely important for effective fuzzing: +``` +CONFIG_KCOV=y +CONFIG_KCOV_INSTRUMENT_ALL=y +CONFIG_DEBUG_FS=y +``` + +To show code coverage in web interface: +``` +CONFIG_DEBUG_INFO=y +``` + +For `namespace` sandbox: +``` +CONFIG_NAMESPACES=y +CONFIG_USER_NS=y +CONFIG_UTS_NS=y +CONFIG_IPC_NS=y +CONFIG_PID_NS=y +CONFIG_NET_NS=y +``` + +If your kernel doesn't have commits [arm64: setup: introduce kaslr_offset()](https://github.com/torvalds/linux/commit/7ede8665f27cde7da69e8b2fbeaa1ed0664879c5) + and [kcov: make kcov work properly with KASLR enabled](https://github.com/torvalds/linux/commit/4983f0ab7ffaad1e534b21975367429736475205), disable the following config: +``` +# CONFIG_RANDOMIZE_BASE is not set +``` + +## Bug detection configs + +`KASAN` for use-after-free and out-of-bounds detection: +``` +CONFIG_KASAN=y +CONFIG_KASAN_INLINE=y +``` + +Any other debugging configs, the more the better, here are some that proved to be especially useful: +``` +CONFIG_LOCKDEP=y +CONFIG_PROVE_LOCKING=y +CONFIG_DEBUG_ATOMIC_SLEEP=y +CONFIG_PROVE_RCU=y +CONFIG_DEBUG_VM=y +``` + +Increase RCU stall timeout to reduce false positive rate: +``` +CONFIG_RCU_CPU_STALL_TIMEOUT=60 +``` |
