syz-check

command
v0.0.0-...-9220929 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 9, 2025 License: Apache-2.0 Imports: 18 Imported by: 0

Documentation

Overview

syz-check does best-effort static correctness checking of the syscall descriptions in sys/os/*.txt. Use:

$ go install ./tools/syz-check
$ syz-check -obj-amd64 /linux_amd64/vmlinux -obj-arm64 /linux_arm64/vmlinux \
	-obj-386 /linux_386/vmlinux -obj-arm /linux_arm/vmlinux

The vmlinux files should include debug info, enable all relevant configs (since we parse dwarf), and be compiled with -gdwarf-3 -fno-eliminate-unused-debug-types -fno-eliminate-unused-debug-symbols flags. -gdwarf-3 is required because version 4 changes the way bitfields are encoded and Go before 1.18 does not support then new encoding and at least earlier versions mis-handle it, see: https://go-review.googlesource.com/c/go/+/328709/comments/edf0619d_daec236f

Use the following configs for kernels (x86_64 config for i386 as well): upstream-apparmor-kasan.config, upstream-arm-full.config, upstream-arm64-full.config

You may check only one arch as well (but then don't commit changes to warn files):

$ syz-check -obj-amd64 /linux_amd64/vmlinux

You may also disable dwarf or netlink checks with the corresponding flags. E.g. -dwarf=0 greatly speeds up checking if you are only interested in netlink warnings (but then again don't commit changes).

The results are produced in sys/os/*.warn files. On implementation level syz-check parses vmlinux dwarf, extracts struct descriptions and compares them with what we have (size, fields, alignment, etc). Netlink checking extracts policy symbols from the object files and parses them.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL