| b.liu | e958203 | 2025-04-17 19:18:16 +0800 | [diff] [blame] | 1 | From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 |
| 2 | From: "Jason A. Donenfeld" <Jason@zx2c4.com> |
| 3 | Date: Sun, 15 Dec 2019 22:08:00 +0100 |
| 4 | Subject: [PATCH] wireguard: selftests: import harness makefile for test suite |
| 5 | |
| 6 | commit 65d88d04114bca7d85faebd5fed61069cb2b632c upstream. |
| 7 | |
| 8 | WireGuard has been using this on build.wireguard.com for the last |
| 9 | several years with considerable success. It allows for very quick and |
| 10 | iterative development cycles, and supports several platforms. |
| 11 | |
| 12 | To run the test suite on your current platform in QEMU: |
| 13 | |
| 14 | $ make -C tools/testing/selftests/wireguard/qemu -j$(nproc) |
| 15 | |
| 16 | To run it with KASAN and such turned on: |
| 17 | |
| 18 | $ DEBUG_KERNEL=yes make -C tools/testing/selftests/wireguard/qemu -j$(nproc) |
| 19 | |
| 20 | To run it emulated for another platform in QEMU: |
| 21 | |
| 22 | $ ARCH=arm make -C tools/testing/selftests/wireguard/qemu -j$(nproc) |
| 23 | |
| 24 | At the moment, we support aarch64_be, aarch64, arm, armeb, i686, m68k, |
| 25 | mips64, mips64el, mips, mipsel, powerpc64le, powerpc, and x86_64. |
| 26 | |
| 27 | The system supports incremental rebuilding, so it should be very fast to |
| 28 | change a single file and then test it out and have immediate feedback. |
| 29 | |
| 30 | This requires for the right toolchain and qemu to be installed prior. |
| 31 | I've had success with those from musl.cc. |
| 32 | |
| 33 | This is tailored for WireGuard at the moment, though later projects |
| 34 | might generalize it for other network testing. |
| 35 | |
| 36 | Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com> |
| 37 | Signed-off-by: David S. Miller <davem@davemloft.net> |
| 38 | Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com> |
| 39 | --- |
| 40 | .../selftests/wireguard/qemu/.gitignore | 2 + |
| 41 | .../testing/selftests/wireguard/qemu/Makefile | 385 ++++++++++++++++++ |
| 42 | .../wireguard/qemu/arch/aarch64.config | 5 + |
| 43 | .../wireguard/qemu/arch/aarch64_be.config | 6 + |
| 44 | .../selftests/wireguard/qemu/arch/arm.config | 9 + |
| 45 | .../wireguard/qemu/arch/armeb.config | 10 + |
| 46 | .../selftests/wireguard/qemu/arch/i686.config | 5 + |
| 47 | .../selftests/wireguard/qemu/arch/m68k.config | 9 + |
| 48 | .../selftests/wireguard/qemu/arch/mips.config | 11 + |
| 49 | .../wireguard/qemu/arch/mips64.config | 14 + |
| 50 | .../wireguard/qemu/arch/mips64el.config | 15 + |
| 51 | .../wireguard/qemu/arch/mipsel.config | 12 + |
| 52 | .../wireguard/qemu/arch/powerpc.config | 10 + |
| 53 | .../wireguard/qemu/arch/powerpc64le.config | 12 + |
| 54 | .../wireguard/qemu/arch/x86_64.config | 5 + |
| 55 | .../selftests/wireguard/qemu/debug.config | 67 +++ |
| 56 | tools/testing/selftests/wireguard/qemu/init.c | 284 +++++++++++++ |
| 57 | .../selftests/wireguard/qemu/kernel.config | 86 ++++ |
| 58 | 18 files changed, 947 insertions(+) |
| 59 | create mode 100644 tools/testing/selftests/wireguard/qemu/.gitignore |
| 60 | create mode 100644 tools/testing/selftests/wireguard/qemu/Makefile |
| 61 | create mode 100644 tools/testing/selftests/wireguard/qemu/arch/aarch64.config |
| 62 | create mode 100644 tools/testing/selftests/wireguard/qemu/arch/aarch64_be.config |
| 63 | create mode 100644 tools/testing/selftests/wireguard/qemu/arch/arm.config |
| 64 | create mode 100644 tools/testing/selftests/wireguard/qemu/arch/armeb.config |
| 65 | create mode 100644 tools/testing/selftests/wireguard/qemu/arch/i686.config |
| 66 | create mode 100644 tools/testing/selftests/wireguard/qemu/arch/m68k.config |
| 67 | create mode 100644 tools/testing/selftests/wireguard/qemu/arch/mips.config |
| 68 | create mode 100644 tools/testing/selftests/wireguard/qemu/arch/mips64.config |
| 69 | create mode 100644 tools/testing/selftests/wireguard/qemu/arch/mips64el.config |
| 70 | create mode 100644 tools/testing/selftests/wireguard/qemu/arch/mipsel.config |
| 71 | create mode 100644 tools/testing/selftests/wireguard/qemu/arch/powerpc.config |
| 72 | create mode 100644 tools/testing/selftests/wireguard/qemu/arch/powerpc64le.config |
| 73 | create mode 100644 tools/testing/selftests/wireguard/qemu/arch/x86_64.config |
| 74 | create mode 100644 tools/testing/selftests/wireguard/qemu/debug.config |
| 75 | create mode 100644 tools/testing/selftests/wireguard/qemu/init.c |
| 76 | create mode 100644 tools/testing/selftests/wireguard/qemu/kernel.config |
| 77 | |
| 78 | --- /dev/null |
| 79 | +++ b/tools/testing/selftests/wireguard/qemu/.gitignore |
| 80 | @@ -0,0 +1,2 @@ |
| 81 | +build/ |
| 82 | +distfiles/ |
| 83 | --- /dev/null |
| 84 | +++ b/tools/testing/selftests/wireguard/qemu/Makefile |
| 85 | @@ -0,0 +1,385 @@ |
| 86 | +# SPDX-License-Identifier: GPL-2.0 |
| 87 | +# |
| 88 | +# Copyright (C) 2015-2019 Jason A. Donenfeld <Jason@zx2c4.com>. All Rights Reserved. |
| 89 | + |
| 90 | +PWD := $(shell pwd) |
| 91 | + |
| 92 | +CHOST := $(shell gcc -dumpmachine) |
| 93 | +ifneq (,$(ARCH)) |
| 94 | +CBUILD := $(subst -gcc,,$(lastword $(subst /, ,$(firstword $(wildcard $(foreach bindir,$(subst :, ,$(PATH)),$(bindir)/$(ARCH)-*-gcc)))))) |
| 95 | +ifeq (,$(CBUILD)) |
| 96 | +$(error The toolchain for $(ARCH) is not installed) |
| 97 | +endif |
| 98 | +else |
| 99 | +CBUILD := $(CHOST) |
| 100 | +ARCH := $(firstword $(subst -, ,$(CBUILD))) |
| 101 | +endif |
| 102 | + |
| 103 | +# Set these from the environment to override |
| 104 | +KERNEL_PATH ?= $(PWD)/../../../../.. |
| 105 | +BUILD_PATH ?= $(PWD)/build/$(ARCH) |
| 106 | +DISTFILES_PATH ?= $(PWD)/distfiles |
| 107 | +NR_CPUS ?= 4 |
| 108 | + |
| 109 | +MIRROR := https://download.wireguard.com/qemu-test/distfiles/ |
| 110 | + |
| 111 | +default: qemu |
| 112 | + |
| 113 | +# variable name, tarball project name, version, tarball extension, default URI base |
| 114 | +define tar_download = |
| 115 | +$(1)_VERSION := $(3) |
| 116 | +$(1)_NAME := $(2)-$$($(1)_VERSION) |
| 117 | +$(1)_TAR := $(DISTFILES_PATH)/$$($(1)_NAME)$(4) |
| 118 | +$(1)_PATH := $(BUILD_PATH)/$$($(1)_NAME) |
| 119 | +$(call file_download,$$($(1)_NAME)$(4),$(5),$(6)) |
| 120 | +endef |
| 121 | + |
| 122 | +define file_download = |
| 123 | +$(DISTFILES_PATH)/$(1): |
| 124 | + mkdir -p $(DISTFILES_PATH) |
| 125 | + flock -x $$@.lock -c '[ -f $$@ ] && exit 0; wget -O $$@.tmp $(MIRROR)$(1) || wget -t inf --retry-on-http-error=404 -O $$@.tmp $(2)$(1) || rm -f $$@.tmp' |
| 126 | + if echo "$(3) $$@.tmp" | sha256sum -c -; then mv $$@.tmp $$@; else rm -f $$@.tmp; exit 71; fi |
| 127 | +endef |
| 128 | + |
| 129 | +$(eval $(call tar_download,MUSL,musl,1.1.20,.tar.gz,https://www.musl-libc.org/releases/,44be8771d0e6c6b5f82dd15662eb2957c9a3173a19a8b49966ac0542bbd40d61)) |
| 130 | +$(eval $(call tar_download,LIBMNL,libmnl,1.0.4,.tar.bz2,https://www.netfilter.org/projects/libmnl/files/,171f89699f286a5854b72b91d06e8f8e3683064c5901fb09d954a9ab6f551f81)) |
| 131 | +$(eval $(call tar_download,IPERF,iperf,3.1.7,.tar.gz,http://downloads.es.net/pub/iperf/,a4ef73406fe92250602b8da2ae89ec53211f805df97a1d1d629db5a14043734f)) |
| 132 | +$(eval $(call tar_download,BASH,bash,5.0,.tar.gz,https://ftp.gnu.org/gnu/bash/,b4a80f2ac66170b2913efbfb9f2594f1f76c7b1afd11f799e22035d63077fb4d)) |
| 133 | +$(eval $(call tar_download,IPROUTE2,iproute2,5.1.0,.tar.gz,https://www.kernel.org/pub/linux/utils/net/iproute2/,9b43707d6075ecdca14803ca8ce0c8553848c49fa1586d12fd508d66577243f2)) |
| 134 | +$(eval $(call tar_download,IPTABLES,iptables,1.6.1,.tar.bz2,https://www.netfilter.org/projects/iptables/files/,0fc2d7bd5d7be11311726466789d4c65fb4c8e096c9182b56ce97440864f0cf5)) |
| 135 | +$(eval $(call tar_download,NMAP,nmap,7.60,.tar.bz2,https://nmap.org/dist/,a8796ecc4fa6c38aad6139d9515dc8113023a82e9d787e5a5fb5fa1b05516f21)) |
| 136 | +$(eval $(call tar_download,IPUTILS,iputils,s20161105,.tar.gz,https://github.com/iputils/iputils/archive/s20161105.tar.gz/#,f813092f03d17294fd23544b129b95cdb87fe19f7970a51908a6b88509acad8a)) |
| 137 | +$(eval $(call tar_download,WIREGUARD_TOOLS,WireGuard,0.0.20191212,.tar.xz,https://git.zx2c4.com/WireGuard/snapshot/,b0d718380f7a8822b2f12d75e462fa4eafa3a77871002981f367cd4fe2a1b071)) |
| 138 | + |
| 139 | +KERNEL_BUILD_PATH := $(BUILD_PATH)/kernel$(if $(findstring yes,$(DEBUG_KERNEL)),-debug) |
| 140 | +rwildcard=$(foreach d,$(wildcard $1*),$(call rwildcard,$d/,$2) $(filter $(subst *,%,$2),$d)) |
| 141 | +WIREGUARD_SOURCES := $(call rwildcard,$(KERNEL_PATH)/drivers/net/wireguard/,*) |
| 142 | + |
| 143 | +export CFLAGS ?= -O3 -pipe |
| 144 | +export LDFLAGS ?= |
| 145 | +export CPPFLAGS := -I$(BUILD_PATH)/include |
| 146 | + |
| 147 | +ifeq ($(CHOST),$(CBUILD)) |
| 148 | +CROSS_COMPILE_FLAG := --host=$(CHOST) |
| 149 | +NOPIE_GCC := gcc -fno-PIE |
| 150 | +CFLAGS += -march=native |
| 151 | +STRIP := strip |
| 152 | +else |
| 153 | +$(info Cross compilation: building for $(CBUILD) using $(CHOST)) |
| 154 | +CROSS_COMPILE_FLAG := --build=$(CBUILD) --host=$(CHOST) |
| 155 | +export CROSS_COMPILE=$(CBUILD)- |
| 156 | +NOPIE_GCC := $(CBUILD)-gcc -fno-PIE |
| 157 | +STRIP := $(CBUILD)-strip |
| 158 | +endif |
| 159 | +ifeq ($(ARCH),aarch64) |
| 160 | +QEMU_ARCH := aarch64 |
| 161 | +KERNEL_ARCH := arm64 |
| 162 | +KERNEL_BZIMAGE := $(KERNEL_BUILD_PATH)/arch/arm64/boot/Image |
| 163 | +ifeq ($(CHOST),$(CBUILD)) |
| 164 | +QEMU_MACHINE := -cpu host -machine virt,gic_version=host,accel=kvm |
| 165 | +else |
| 166 | +QEMU_MACHINE := -cpu cortex-a53 -machine virt |
| 167 | +CFLAGS += -march=armv8-a -mtune=cortex-a53 |
| 168 | +endif |
| 169 | +else ifeq ($(ARCH),aarch64_be) |
| 170 | +QEMU_ARCH := aarch64 |
| 171 | +KERNEL_ARCH := arm64 |
| 172 | +KERNEL_BZIMAGE := $(KERNEL_BUILD_PATH)/arch/arm64/boot/Image |
| 173 | +ifeq ($(CHOST),$(CBUILD)) |
| 174 | +QEMU_MACHINE := -cpu host -machine virt,gic_version=host,accel=kvm |
| 175 | +else |
| 176 | +QEMU_MACHINE := -cpu cortex-a53 -machine virt |
| 177 | +CFLAGS += -march=armv8-a -mtune=cortex-a53 |
| 178 | +endif |
| 179 | +else ifeq ($(ARCH),arm) |
| 180 | +QEMU_ARCH := arm |
| 181 | +KERNEL_ARCH := arm |
| 182 | +KERNEL_BZIMAGE := $(KERNEL_BUILD_PATH)/arch/arm/boot/zImage |
| 183 | +ifeq ($(CHOST),$(CBUILD)) |
| 184 | +QEMU_MACHINE := -cpu host -machine virt,gic_version=host,accel=kvm |
| 185 | +else |
| 186 | +QEMU_MACHINE := -cpu cortex-a15 -machine virt |
| 187 | +CFLAGS += -march=armv7-a -mtune=cortex-a15 -mabi=aapcs-linux |
| 188 | +endif |
| 189 | +else ifeq ($(ARCH),armeb) |
| 190 | +QEMU_ARCH := arm |
| 191 | +KERNEL_ARCH := arm |
| 192 | +KERNEL_BZIMAGE := $(KERNEL_BUILD_PATH)/arch/arm/boot/zImage |
| 193 | +ifeq ($(CHOST),$(CBUILD)) |
| 194 | +QEMU_MACHINE := -cpu host -machine virt,gic_version=host,accel=kvm |
| 195 | +else |
| 196 | +QEMU_MACHINE := -cpu cortex-a15 -machine virt |
| 197 | +CFLAGS += -march=armv7-a -mabi=aapcs-linux # We don't pass -mtune=cortex-a15 due to a compiler bug on big endian. |
| 198 | +LDFLAGS += -Wl,--be8 |
| 199 | +endif |
| 200 | +else ifeq ($(ARCH),x86_64) |
| 201 | +QEMU_ARCH := x86_64 |
| 202 | +KERNEL_ARCH := x86_64 |
| 203 | +KERNEL_BZIMAGE := $(KERNEL_BUILD_PATH)/arch/x86/boot/bzImage |
| 204 | +ifeq ($(CHOST),$(CBUILD)) |
| 205 | +QEMU_MACHINE := -cpu host -machine q35,accel=kvm |
| 206 | +else |
| 207 | +QEMU_MACHINE := -cpu Skylake-Server -machine q35 |
| 208 | +CFLAGS += -march=skylake-avx512 |
| 209 | +endif |
| 210 | +else ifeq ($(ARCH),i686) |
| 211 | +QEMU_ARCH := i386 |
| 212 | +KERNEL_ARCH := x86 |
| 213 | +KERNEL_BZIMAGE := $(KERNEL_BUILD_PATH)/arch/x86/boot/bzImage |
| 214 | +ifeq ($(subst i686,x86_64,$(CBUILD)),$(CHOST)) |
| 215 | +QEMU_MACHINE := -cpu host -machine q35,accel=kvm |
| 216 | +else |
| 217 | +QEMU_MACHINE := -cpu coreduo -machine q35 |
| 218 | +CFLAGS += -march=prescott |
| 219 | +endif |
| 220 | +else ifeq ($(ARCH),mips64) |
| 221 | +QEMU_ARCH := mips64 |
| 222 | +KERNEL_ARCH := mips |
| 223 | +KERNEL_BZIMAGE := $(KERNEL_BUILD_PATH)/vmlinux |
| 224 | +ifeq ($(CHOST),$(CBUILD)) |
| 225 | +QEMU_MACHINE := -cpu host -machine malta,accel=kvm |
| 226 | +CFLAGS += -EB |
| 227 | +else |
| 228 | +QEMU_MACHINE := -cpu MIPS64R2-generic -machine malta -smp 1 |
| 229 | +CFLAGS += -march=mips64r2 -EB |
| 230 | +endif |
| 231 | +else ifeq ($(ARCH),mips64el) |
| 232 | +QEMU_ARCH := mips64el |
| 233 | +KERNEL_ARCH := mips |
| 234 | +KERNEL_BZIMAGE := $(KERNEL_BUILD_PATH)/vmlinux |
| 235 | +ifeq ($(CHOST),$(CBUILD)) |
| 236 | +QEMU_MACHINE := -cpu host -machine malta,accel=kvm |
| 237 | +CFLAGS += -EL |
| 238 | +else |
| 239 | +QEMU_MACHINE := -cpu MIPS64R2-generic -machine malta -smp 1 |
| 240 | +CFLAGS += -march=mips64r2 -EL |
| 241 | +endif |
| 242 | +else ifeq ($(ARCH),mips) |
| 243 | +QEMU_ARCH := mips |
| 244 | +KERNEL_ARCH := mips |
| 245 | +KERNEL_BZIMAGE := $(KERNEL_BUILD_PATH)/vmlinux |
| 246 | +ifeq ($(CHOST),$(CBUILD)) |
| 247 | +QEMU_MACHINE := -cpu host -machine malta,accel=kvm |
| 248 | +CFLAGS += -EB |
| 249 | +else |
| 250 | +QEMU_MACHINE := -cpu 24Kf -machine malta -smp 1 |
| 251 | +CFLAGS += -march=mips32r2 -EB |
| 252 | +endif |
| 253 | +else ifeq ($(ARCH),mipsel) |
| 254 | +QEMU_ARCH := mipsel |
| 255 | +KERNEL_ARCH := mips |
| 256 | +KERNEL_BZIMAGE := $(KERNEL_BUILD_PATH)/vmlinux |
| 257 | +ifeq ($(CHOST),$(CBUILD)) |
| 258 | +QEMU_MACHINE := -cpu host -machine malta,accel=kvm |
| 259 | +CFLAGS += -EL |
| 260 | +else |
| 261 | +QEMU_MACHINE := -cpu 24Kf -machine malta -smp 1 |
| 262 | +CFLAGS += -march=mips32r2 -EL |
| 263 | +endif |
| 264 | +else ifeq ($(ARCH),powerpc64le) |
| 265 | +QEMU_ARCH := ppc64 |
| 266 | +KERNEL_ARCH := powerpc |
| 267 | +KERNEL_BZIMAGE := $(KERNEL_BUILD_PATH)/vmlinux |
| 268 | +ifeq ($(CHOST),$(CBUILD)) |
| 269 | +QEMU_MACHINE := -cpu host,accel=kvm -machine pseries |
| 270 | +else |
| 271 | +QEMU_MACHINE := -machine pseries |
| 272 | +endif |
| 273 | +CFLAGS += -mcpu=powerpc64le -mlong-double-64 |
| 274 | +else ifeq ($(ARCH),powerpc) |
| 275 | +QEMU_ARCH := ppc |
| 276 | +KERNEL_ARCH := powerpc |
| 277 | +KERNEL_BZIMAGE := $(KERNEL_BUILD_PATH)/arch/powerpc/boot/uImage |
| 278 | +ifeq ($(CHOST),$(CBUILD)) |
| 279 | +QEMU_MACHINE := -cpu host,accel=kvm -machine ppce500 |
| 280 | +else |
| 281 | +QEMU_MACHINE := -machine ppce500 |
| 282 | +endif |
| 283 | +CFLAGS += -mcpu=powerpc -mlong-double-64 -msecure-plt |
| 284 | +else ifeq ($(ARCH),m68k) |
| 285 | +QEMU_ARCH := m68k |
| 286 | +KERNEL_ARCH := m68k |
| 287 | +KERNEL_BZIMAGE := $(KERNEL_BUILD_PATH)/vmlinux |
| 288 | +ifeq ($(CHOST),$(CBUILD)) |
| 289 | +QEMU_MACHINE := -cpu host,accel=kvm -machine q800 |
| 290 | +else |
| 291 | +QEMU_MACHINE := -machine q800 |
| 292 | +endif |
| 293 | +else |
| 294 | +$(error I only build: x86_64, i686, arm, armeb, aarch64, aarch64_be, mips, mipsel, mips64, mips64el, powerpc64le, powerpc, m68k) |
| 295 | +endif |
| 296 | + |
| 297 | +REAL_CC := $(CBUILD)-gcc |
| 298 | +MUSL_CC := $(BUILD_PATH)/musl-gcc |
| 299 | +export CC := $(MUSL_CC) |
| 300 | +USERSPACE_DEPS := $(MUSL_CC) $(BUILD_PATH)/include/.installed $(BUILD_PATH)/include/linux/.installed |
| 301 | + |
| 302 | +build: $(KERNEL_BZIMAGE) |
| 303 | +qemu: $(KERNEL_BZIMAGE) |
| 304 | + rm -f $(BUILD_PATH)/result |
| 305 | + timeout --foreground 20m qemu-system-$(QEMU_ARCH) \ |
| 306 | + -nodefaults \ |
| 307 | + -nographic \ |
| 308 | + -smp $(NR_CPUS) \ |
| 309 | + $(QEMU_MACHINE) \ |
| 310 | + -m $$(grep -q CONFIG_DEBUG_KMEMLEAK=y $(KERNEL_BUILD_PATH)/.config && echo 1G || echo 256M) \ |
| 311 | + -serial stdio \ |
| 312 | + -serial file:$(BUILD_PATH)/result \ |
| 313 | + -no-reboot \ |
| 314 | + -monitor none \ |
| 315 | + -kernel $< |
| 316 | + grep -Fq success $(BUILD_PATH)/result |
| 317 | + |
| 318 | +$(BUILD_PATH)/init-cpio-spec.txt: |
| 319 | + mkdir -p $(BUILD_PATH) |
| 320 | + echo "file /init $(BUILD_PATH)/init 755 0 0" > $@ |
| 321 | + echo "file /init.sh $(PWD)/../netns.sh 755 0 0" >> $@ |
| 322 | + echo "dir /dev 755 0 0" >> $@ |
| 323 | + echo "nod /dev/console 644 0 0 c 5 1" >> $@ |
| 324 | + echo "dir /bin 755 0 0" >> $@ |
| 325 | + echo "file /bin/iperf3 $(IPERF_PATH)/src/iperf3 755 0 0" >> $@ |
| 326 | + echo "file /bin/wg $(WIREGUARD_TOOLS_PATH)/src/tools/wg 755 0 0" >> $@ |
| 327 | + echo "file /bin/bash $(BASH_PATH)/bash 755 0 0" >> $@ |
| 328 | + echo "file /bin/ip $(IPROUTE2_PATH)/ip/ip 755 0 0" >> $@ |
| 329 | + echo "file /bin/ss $(IPROUTE2_PATH)/misc/ss 755 0 0" >> $@ |
| 330 | + echo "file /bin/ping $(IPUTILS_PATH)/ping 755 0 0" >> $@ |
| 331 | + echo "file /bin/ncat $(NMAP_PATH)/ncat/ncat 755 0 0" >> $@ |
| 332 | + echo "file /bin/xtables-multi $(IPTABLES_PATH)/iptables/xtables-multi 755 0 0" >> $@ |
| 333 | + echo "slink /bin/iptables xtables-multi 777 0 0" >> $@ |
| 334 | + echo "slink /bin/ping6 ping 777 0 0" >> $@ |
| 335 | + echo "dir /lib 755 0 0" >> $@ |
| 336 | + echo "file /lib/libc.so $(MUSL_PATH)/lib/libc.so 755 0 0" >> $@ |
| 337 | + echo "slink /lib/ld-linux.so.1 libc.so 777 0 0" >> $@ |
| 338 | + |
| 339 | +$(KERNEL_BUILD_PATH)/.config: kernel.config arch/$(ARCH).config |
| 340 | + mkdir -p $(KERNEL_BUILD_PATH) |
| 341 | + cp kernel.config $(KERNEL_BUILD_PATH)/minimal.config |
| 342 | + printf 'CONFIG_NR_CPUS=$(NR_CPUS)\nCONFIG_INITRAMFS_SOURCE="$(BUILD_PATH)/init-cpio-spec.txt"\n' >> $(KERNEL_BUILD_PATH)/minimal.config |
| 343 | + cat arch/$(ARCH).config >> $(KERNEL_BUILD_PATH)/minimal.config |
| 344 | + $(MAKE) -C $(KERNEL_PATH) O=$(KERNEL_BUILD_PATH) ARCH=$(KERNEL_ARCH) allnoconfig |
| 345 | + cd $(KERNEL_BUILD_PATH) && ARCH=$(KERNEL_ARCH) $(KERNEL_PATH)/scripts/kconfig/merge_config.sh -n $(KERNEL_BUILD_PATH)/.config $(KERNEL_BUILD_PATH)/minimal.config |
| 346 | + $(if $(findstring yes,$(DEBUG_KERNEL)),cp debug.config $(KERNEL_BUILD_PATH) && cd $(KERNEL_BUILD_PATH) && ARCH=$(KERNEL_ARCH) $(KERNEL_PATH)/scripts/kconfig/merge_config.sh -n $(KERNEL_BUILD_PATH)/.config debug.config,) |
| 347 | + |
| 348 | +$(KERNEL_BZIMAGE): $(KERNEL_BUILD_PATH)/.config $(BUILD_PATH)/init-cpio-spec.txt $(MUSL_PATH)/lib/libc.so $(IPERF_PATH)/src/iperf3 $(IPUTILS_PATH)/ping $(BASH_PATH)/bash $(IPROUTE2_PATH)/misc/ss $(IPROUTE2_PATH)/ip/ip $(IPTABLES_PATH)/iptables/xtables-multi $(NMAP_PATH)/ncat/ncat $(WIREGUARD_TOOLS_PATH)/src/tools/wg $(BUILD_PATH)/init ../netns.sh $(WIREGUARD_SOURCES) |
| 349 | + $(MAKE) -C $(KERNEL_PATH) O=$(KERNEL_BUILD_PATH) ARCH=$(KERNEL_ARCH) CROSS_COMPILE=$(CROSS_COMPILE) CC="$(NOPIE_GCC)" |
| 350 | + |
| 351 | +$(BUILD_PATH)/include/linux/.installed: | $(KERNEL_BUILD_PATH)/.config |
| 352 | + $(MAKE) -C $(KERNEL_PATH) O=$(KERNEL_BUILD_PATH) INSTALL_HDR_PATH=$(BUILD_PATH) ARCH=$(KERNEL_ARCH) CROSS_COMPILE=$(CROSS_COMPILE) headers_install |
| 353 | + touch $@ |
| 354 | + |
| 355 | +$(MUSL_PATH)/lib/libc.so: $(MUSL_TAR) |
| 356 | + mkdir -p $(BUILD_PATH) |
| 357 | + flock -s $<.lock tar -C $(BUILD_PATH) -xf $< |
| 358 | + cd $(MUSL_PATH) && CC=$(REAL_CC) ./configure --prefix=/ --disable-static --build=$(CBUILD) |
| 359 | + $(MAKE) -C $(MUSL_PATH) |
| 360 | + $(STRIP) -s $@ |
| 361 | + |
| 362 | +$(BUILD_PATH)/include/.installed: $(MUSL_PATH)/lib/libc.so |
| 363 | + $(MAKE) -C $(MUSL_PATH) DESTDIR=$(BUILD_PATH) install-headers |
| 364 | + touch $@ |
| 365 | + |
| 366 | +$(MUSL_CC): $(MUSL_PATH)/lib/libc.so |
| 367 | + sh $(MUSL_PATH)/tools/musl-gcc.specs.sh $(BUILD_PATH)/include $(MUSL_PATH)/lib /lib/ld-linux.so.1 > $(BUILD_PATH)/musl-gcc.specs |
| 368 | + printf '#!/bin/sh\nexec "$(REAL_CC)" --specs="$(BUILD_PATH)/musl-gcc.specs" -fno-stack-protector -no-pie "$$@"\n' > $(BUILD_PATH)/musl-gcc |
| 369 | + chmod +x $(BUILD_PATH)/musl-gcc |
| 370 | + |
| 371 | +$(IPERF_PATH)/.installed: $(IPERF_TAR) |
| 372 | + mkdir -p $(BUILD_PATH) |
| 373 | + flock -s $<.lock tar -C $(BUILD_PATH) -xf $< |
| 374 | + sed -i '1s/^/#include <stdint.h>/' $(IPERF_PATH)/src/cjson.h $(IPERF_PATH)/src/timer.h |
| 375 | + sed -i -r 's/-p?g//g' $(IPERF_PATH)/src/Makefile* |
| 376 | + touch $@ |
| 377 | + |
| 378 | +$(IPERF_PATH)/src/iperf3: | $(IPERF_PATH)/.installed $(USERSPACE_DEPS) |
| 379 | + cd $(IPERF_PATH) && CFLAGS="$(CFLAGS) -D_GNU_SOURCE" ./configure --prefix=/ $(CROSS_COMPILE_FLAG) --enable-static --disable-shared |
| 380 | + $(MAKE) -C $(IPERF_PATH) |
| 381 | + $(STRIP) -s $@ |
| 382 | + |
| 383 | +$(LIBMNL_PATH)/.installed: $(LIBMNL_TAR) |
| 384 | + flock -s $<.lock tar -C $(BUILD_PATH) -xf $< |
| 385 | + touch $@ |
| 386 | + |
| 387 | +$(LIBMNL_PATH)/src/.libs/libmnl.a: | $(LIBMNL_PATH)/.installed $(USERSPACE_DEPS) |
| 388 | + cd $(LIBMNL_PATH) && ./configure --prefix=/ $(CROSS_COMPILE_FLAG) --enable-static --disable-shared |
| 389 | + $(MAKE) -C $(LIBMNL_PATH) |
| 390 | + sed -i 's:prefix=.*:prefix=$(LIBMNL_PATH):' $(LIBMNL_PATH)/libmnl.pc |
| 391 | + |
| 392 | +$(WIREGUARD_TOOLS_PATH)/.installed: $(WIREGUARD_TOOLS_TAR) |
| 393 | + flock -s $<.lock tar -C $(BUILD_PATH) -xf $< |
| 394 | + touch $@ |
| 395 | + |
| 396 | +$(WIREGUARD_TOOLS_PATH)/src/tools/wg: | $(WIREGUARD_TOOLS_PATH)/.installed $(LIBMNL_PATH)/src/.libs/libmnl.a $(USERSPACE_DEPS) |
| 397 | + LDFLAGS="$(LDFLAGS) -L$(LIBMNL_PATH)/src/.libs" $(MAKE) -C $(WIREGUARD_TOOLS_PATH)/src/tools LIBMNL_CFLAGS="-I$(LIBMNL_PATH)/include" LIBMNL_LDLIBS="-lmnl" wg |
| 398 | + $(STRIP) -s $@ |
| 399 | + |
| 400 | +$(BUILD_PATH)/init: init.c | $(USERSPACE_DEPS) |
| 401 | + mkdir -p $(BUILD_PATH) |
| 402 | + $(MUSL_CC) -o $@ $(CFLAGS) $(LDFLAGS) -std=gnu11 $< |
| 403 | + $(STRIP) -s $@ |
| 404 | + |
| 405 | +$(IPUTILS_PATH)/.installed: $(IPUTILS_TAR) |
| 406 | + mkdir -p $(BUILD_PATH) |
| 407 | + flock -s $<.lock tar -C $(BUILD_PATH) -xf $< |
| 408 | + touch $@ |
| 409 | + |
| 410 | +$(IPUTILS_PATH)/ping: | $(IPUTILS_PATH)/.installed $(USERSPACE_DEPS) |
| 411 | + $(MAKE) -C $(IPUTILS_PATH) USE_CAP=no USE_IDN=no USE_NETTLE=no USE_CRYPTO=no ping |
| 412 | + $(STRIP) -s $@ |
| 413 | + |
| 414 | +$(BASH_PATH)/.installed: $(BASH_TAR) |
| 415 | + mkdir -p $(BUILD_PATH) |
| 416 | + flock -s $<.lock tar -C $(BUILD_PATH) -xf $< |
| 417 | + touch $@ |
| 418 | + |
| 419 | +$(BASH_PATH)/bash: | $(BASH_PATH)/.installed $(USERSPACE_DEPS) |
| 420 | + cd $(BASH_PATH) && ./configure --prefix=/ $(CROSS_COMPILE_FLAG) --without-bash-malloc --disable-debugger --disable-help-builtin --disable-history --disable-multibyte --disable-progcomp --disable-readline --disable-mem-scramble |
| 421 | + $(MAKE) -C $(BASH_PATH) |
| 422 | + $(STRIP) -s $@ |
| 423 | + |
| 424 | +$(IPROUTE2_PATH)/.installed: $(IPROUTE2_TAR) |
| 425 | + mkdir -p $(BUILD_PATH) |
| 426 | + flock -s $<.lock tar -C $(BUILD_PATH) -xf $< |
| 427 | + printf 'CC:=$(CC)\nPKG_CONFIG:=pkg-config\nTC_CONFIG_XT:=n\nTC_CONFIG_ATM:=n\nTC_CONFIG_IPSET:=n\nIP_CONFIG_SETNS:=y\nHAVE_ELF:=n\nHAVE_MNL:=y\nHAVE_BERKELEY_DB:=n\nHAVE_LATEX:=n\nHAVE_PDFLATEX:=n\nCFLAGS+=-DHAVE_SETNS -DHAVE_LIBMNL -I$(LIBMNL_PATH)/include\nLDLIBS+=-lmnl' > $(IPROUTE2_PATH)/config.mk |
| 428 | + printf 'lib: snapshot\n\t$$(MAKE) -C lib\nip/ip: lib\n\t$$(MAKE) -C ip ip\nmisc/ss: lib\n\t$$(MAKE) -C misc ss\n' >> $(IPROUTE2_PATH)/Makefile |
| 429 | + touch $@ |
| 430 | + |
| 431 | +$(IPROUTE2_PATH)/ip/ip: | $(IPROUTE2_PATH)/.installed $(LIBMNL_PATH)/src/.libs/libmnl.a $(USERSPACE_DEPS) |
| 432 | + LDFLAGS="$(LDFLAGS) -L$(LIBMNL_PATH)/src/.libs" PKG_CONFIG_LIBDIR="$(LIBMNL_PATH)" $(MAKE) -C $(IPROUTE2_PATH) PREFIX=/ ip/ip |
| 433 | + $(STRIP) -s $(IPROUTE2_PATH)/ip/ip |
| 434 | + |
| 435 | +$(IPROUTE2_PATH)/misc/ss: | $(IPROUTE2_PATH)/.installed $(LIBMNL_PATH)/src/.libs/libmnl.a $(USERSPACE_DEPS) |
| 436 | + LDFLAGS="$(LDFLAGS) -L$(LIBMNL_PATH)/src/.libs" PKG_CONFIG_LIBDIR="$(LIBMNL_PATH)" $(MAKE) -C $(IPROUTE2_PATH) PREFIX=/ misc/ss |
| 437 | + $(STRIP) -s $(IPROUTE2_PATH)/misc/ss |
| 438 | + |
| 439 | +$(IPTABLES_PATH)/.installed: $(IPTABLES_TAR) |
| 440 | + mkdir -p $(BUILD_PATH) |
| 441 | + flock -s $<.lock tar -C $(BUILD_PATH) -xf $< |
| 442 | + sed -i -e "/nfnetlink=[01]/s:=[01]:=0:" -e "/nfconntrack=[01]/s:=[01]:=0:" $(IPTABLES_PATH)/configure |
| 443 | + touch $@ |
| 444 | + |
| 445 | +$(IPTABLES_PATH)/iptables/xtables-multi: | $(IPTABLES_PATH)/.installed $(LIBMNL_PATH)/src/.libs/libmnl.a $(USERSPACE_DEPS) |
| 446 | + cd $(IPTABLES_PATH) && PKG_CONFIG_LIBDIR="$(LIBMNL_PATH)" ./configure --prefix=/ $(CROSS_COMPILE_FLAG) --enable-static --disable-shared --disable-nftables --disable-bpf-compiler --disable-nfsynproxy --disable-libipq --with-kernel=$(BUILD_PATH)/include |
| 447 | + $(MAKE) -C $(IPTABLES_PATH) |
| 448 | + $(STRIP) -s $@ |
| 449 | + |
| 450 | +$(NMAP_PATH)/.installed: $(NMAP_TAR) |
| 451 | + mkdir -p $(BUILD_PATH) |
| 452 | + flock -s $<.lock tar -C $(BUILD_PATH) -xf $< |
| 453 | + touch $@ |
| 454 | + |
| 455 | +$(NMAP_PATH)/ncat/ncat: | $(NMAP_PATH)/.installed $(USERSPACE_DEPS) |
| 456 | + cd $(NMAP_PATH) && ./configure --prefix=/ $(CROSS_COMPILE_FLAG) --enable-static --disable-shared --without-ndiff --without-zenmap --without-nping --with-libpcap=included --with-libpcre=included --with-libdnet=included --without-liblua --with-liblinear=included --without-nmap-update --without-openssl --with-pcap=linux |
| 457 | + $(MAKE) -C $(NMAP_PATH) build-ncat |
| 458 | + $(STRIP) -s $@ |
| 459 | + |
| 460 | +clean: |
| 461 | + rm -rf $(BUILD_PATH) |
| 462 | + |
| 463 | +distclean: clean |
| 464 | + rm -rf $(DISTFILES_PATH) |
| 465 | + |
| 466 | +menuconfig: $(KERNEL_BUILD_PATH)/.config |
| 467 | + $(MAKE) -C $(KERNEL_PATH) O=$(KERNEL_BUILD_PATH) ARCH=$(KERNEL_ARCH) CROSS_COMPILE=$(CROSS_COMPILE) CC="$(NOPIE_GCC)" menuconfig |
| 468 | + |
| 469 | +.PHONY: qemu build clean distclean menuconfig |
| 470 | +.DELETE_ON_ERROR: |
| 471 | --- /dev/null |
| 472 | +++ b/tools/testing/selftests/wireguard/qemu/arch/aarch64.config |
| 473 | @@ -0,0 +1,5 @@ |
| 474 | +CONFIG_SERIAL_AMBA_PL011=y |
| 475 | +CONFIG_SERIAL_AMBA_PL011_CONSOLE=y |
| 476 | +CONFIG_CMDLINE_BOOL=y |
| 477 | +CONFIG_CMDLINE="console=ttyAMA0 wg.success=ttyAMA1" |
| 478 | +CONFIG_FRAME_WARN=1280 |
| 479 | --- /dev/null |
| 480 | +++ b/tools/testing/selftests/wireguard/qemu/arch/aarch64_be.config |
| 481 | @@ -0,0 +1,6 @@ |
| 482 | +CONFIG_CPU_BIG_ENDIAN=y |
| 483 | +CONFIG_SERIAL_AMBA_PL011=y |
| 484 | +CONFIG_SERIAL_AMBA_PL011_CONSOLE=y |
| 485 | +CONFIG_CMDLINE_BOOL=y |
| 486 | +CONFIG_CMDLINE="console=ttyAMA0 wg.success=ttyAMA1" |
| 487 | +CONFIG_FRAME_WARN=1280 |
| 488 | --- /dev/null |
| 489 | +++ b/tools/testing/selftests/wireguard/qemu/arch/arm.config |
| 490 | @@ -0,0 +1,9 @@ |
| 491 | +CONFIG_MMU=y |
| 492 | +CONFIG_ARCH_MULTI_V7=y |
| 493 | +CONFIG_ARCH_VIRT=y |
| 494 | +CONFIG_THUMB2_KERNEL=n |
| 495 | +CONFIG_SERIAL_AMBA_PL011=y |
| 496 | +CONFIG_SERIAL_AMBA_PL011_CONSOLE=y |
| 497 | +CONFIG_CMDLINE_BOOL=y |
| 498 | +CONFIG_CMDLINE="console=ttyAMA0 wg.success=ttyAMA1" |
| 499 | +CONFIG_FRAME_WARN=1024 |
| 500 | --- /dev/null |
| 501 | +++ b/tools/testing/selftests/wireguard/qemu/arch/armeb.config |
| 502 | @@ -0,0 +1,10 @@ |
| 503 | +CONFIG_MMU=y |
| 504 | +CONFIG_ARCH_MULTI_V7=y |
| 505 | +CONFIG_ARCH_VIRT=y |
| 506 | +CONFIG_THUMB2_KERNEL=n |
| 507 | +CONFIG_SERIAL_AMBA_PL011=y |
| 508 | +CONFIG_SERIAL_AMBA_PL011_CONSOLE=y |
| 509 | +CONFIG_CMDLINE_BOOL=y |
| 510 | +CONFIG_CMDLINE="console=ttyAMA0 wg.success=ttyAMA1" |
| 511 | +CONFIG_CPU_BIG_ENDIAN=y |
| 512 | +CONFIG_FRAME_WARN=1024 |
| 513 | --- /dev/null |
| 514 | +++ b/tools/testing/selftests/wireguard/qemu/arch/i686.config |
| 515 | @@ -0,0 +1,5 @@ |
| 516 | +CONFIG_SERIAL_8250=y |
| 517 | +CONFIG_SERIAL_8250_CONSOLE=y |
| 518 | +CONFIG_CMDLINE_BOOL=y |
| 519 | +CONFIG_CMDLINE="console=ttyS0 wg.success=ttyS1" |
| 520 | +CONFIG_FRAME_WARN=1024 |
| 521 | --- /dev/null |
| 522 | +++ b/tools/testing/selftests/wireguard/qemu/arch/m68k.config |
| 523 | @@ -0,0 +1,9 @@ |
| 524 | +CONFIG_MMU=y |
| 525 | +CONFIG_M68040=y |
| 526 | +CONFIG_MAC=y |
| 527 | +CONFIG_SERIAL_PMACZILOG=y |
| 528 | +CONFIG_SERIAL_PMACZILOG_TTYS=y |
| 529 | +CONFIG_SERIAL_PMACZILOG_CONSOLE=y |
| 530 | +CONFIG_CMDLINE_BOOL=y |
| 531 | +CONFIG_CMDLINE="console=ttyS0 wg.success=ttyS1" |
| 532 | +CONFIG_FRAME_WARN=1024 |
| 533 | --- /dev/null |
| 534 | +++ b/tools/testing/selftests/wireguard/qemu/arch/mips.config |
| 535 | @@ -0,0 +1,11 @@ |
| 536 | +CONFIG_CPU_MIPS32_R2=y |
| 537 | +CONFIG_MIPS_MALTA=y |
| 538 | +CONFIG_MIPS_CPS=y |
| 539 | +CONFIG_MIPS_FP_SUPPORT=y |
| 540 | +CONFIG_POWER_RESET=y |
| 541 | +CONFIG_POWER_RESET_SYSCON=y |
| 542 | +CONFIG_SERIAL_8250=y |
| 543 | +CONFIG_SERIAL_8250_CONSOLE=y |
| 544 | +CONFIG_CMDLINE_BOOL=y |
| 545 | +CONFIG_CMDLINE="console=ttyS0 wg.success=ttyS1" |
| 546 | +CONFIG_FRAME_WARN=1024 |
| 547 | --- /dev/null |
| 548 | +++ b/tools/testing/selftests/wireguard/qemu/arch/mips64.config |
| 549 | @@ -0,0 +1,14 @@ |
| 550 | +CONFIG_64BIT=y |
| 551 | +CONFIG_CPU_MIPS64_R2=y |
| 552 | +CONFIG_MIPS32_N32=y |
| 553 | +CONFIG_CPU_HAS_MSA=y |
| 554 | +CONFIG_MIPS_MALTA=y |
| 555 | +CONFIG_MIPS_CPS=y |
| 556 | +CONFIG_MIPS_FP_SUPPORT=y |
| 557 | +CONFIG_POWER_RESET=y |
| 558 | +CONFIG_POWER_RESET_SYSCON=y |
| 559 | +CONFIG_SERIAL_8250=y |
| 560 | +CONFIG_SERIAL_8250_CONSOLE=y |
| 561 | +CONFIG_CMDLINE_BOOL=y |
| 562 | +CONFIG_CMDLINE="console=ttyS0 wg.success=ttyS1" |
| 563 | +CONFIG_FRAME_WARN=1280 |
| 564 | --- /dev/null |
| 565 | +++ b/tools/testing/selftests/wireguard/qemu/arch/mips64el.config |
| 566 | @@ -0,0 +1,15 @@ |
| 567 | +CONFIG_64BIT=y |
| 568 | +CONFIG_CPU_MIPS64_R2=y |
| 569 | +CONFIG_MIPS32_N32=y |
| 570 | +CONFIG_CPU_HAS_MSA=y |
| 571 | +CONFIG_MIPS_MALTA=y |
| 572 | +CONFIG_CPU_LITTLE_ENDIAN=y |
| 573 | +CONFIG_MIPS_CPS=y |
| 574 | +CONFIG_MIPS_FP_SUPPORT=y |
| 575 | +CONFIG_POWER_RESET=y |
| 576 | +CONFIG_POWER_RESET_SYSCON=y |
| 577 | +CONFIG_SERIAL_8250=y |
| 578 | +CONFIG_SERIAL_8250_CONSOLE=y |
| 579 | +CONFIG_CMDLINE_BOOL=y |
| 580 | +CONFIG_CMDLINE="console=ttyS0 wg.success=ttyS1" |
| 581 | +CONFIG_FRAME_WARN=1280 |
| 582 | --- /dev/null |
| 583 | +++ b/tools/testing/selftests/wireguard/qemu/arch/mipsel.config |
| 584 | @@ -0,0 +1,12 @@ |
| 585 | +CONFIG_CPU_MIPS32_R2=y |
| 586 | +CONFIG_MIPS_MALTA=y |
| 587 | +CONFIG_CPU_LITTLE_ENDIAN=y |
| 588 | +CONFIG_MIPS_CPS=y |
| 589 | +CONFIG_MIPS_FP_SUPPORT=y |
| 590 | +CONFIG_POWER_RESET=y |
| 591 | +CONFIG_POWER_RESET_SYSCON=y |
| 592 | +CONFIG_SERIAL_8250=y |
| 593 | +CONFIG_SERIAL_8250_CONSOLE=y |
| 594 | +CONFIG_CMDLINE_BOOL=y |
| 595 | +CONFIG_CMDLINE="console=ttyS0 wg.success=ttyS1" |
| 596 | +CONFIG_FRAME_WARN=1024 |
| 597 | --- /dev/null |
| 598 | +++ b/tools/testing/selftests/wireguard/qemu/arch/powerpc.config |
| 599 | @@ -0,0 +1,10 @@ |
| 600 | +CONFIG_PPC_QEMU_E500=y |
| 601 | +CONFIG_FSL_SOC_BOOKE=y |
| 602 | +CONFIG_PPC_85xx=y |
| 603 | +CONFIG_PHYS_64BIT=y |
| 604 | +CONFIG_SERIAL_8250=y |
| 605 | +CONFIG_SERIAL_8250_CONSOLE=y |
| 606 | +CONFIG_MATH_EMULATION=y |
| 607 | +CONFIG_CMDLINE_BOOL=y |
| 608 | +CONFIG_CMDLINE="console=ttyS0 wg.success=ttyS1" |
| 609 | +CONFIG_FRAME_WARN=1024 |
| 610 | --- /dev/null |
| 611 | +++ b/tools/testing/selftests/wireguard/qemu/arch/powerpc64le.config |
| 612 | @@ -0,0 +1,12 @@ |
| 613 | +CONFIG_PPC64=y |
| 614 | +CONFIG_PPC_PSERIES=y |
| 615 | +CONFIG_ALTIVEC=y |
| 616 | +CONFIG_VSX=y |
| 617 | +CONFIG_PPC_OF_BOOT_TRAMPOLINE=y |
| 618 | +CONFIG_PPC_RADIX_MMU=y |
| 619 | +CONFIG_HVC_CONSOLE=y |
| 620 | +CONFIG_CPU_LITTLE_ENDIAN=y |
| 621 | +CONFIG_CMDLINE_BOOL=y |
| 622 | +CONFIG_CMDLINE="console=hvc0 wg.success=hvc1" |
| 623 | +CONFIG_SECTION_MISMATCH_WARN_ONLY=y |
| 624 | +CONFIG_FRAME_WARN=1280 |
| 625 | --- /dev/null |
| 626 | +++ b/tools/testing/selftests/wireguard/qemu/arch/x86_64.config |
| 627 | @@ -0,0 +1,5 @@ |
| 628 | +CONFIG_SERIAL_8250=y |
| 629 | +CONFIG_SERIAL_8250_CONSOLE=y |
| 630 | +CONFIG_CMDLINE_BOOL=y |
| 631 | +CONFIG_CMDLINE="console=ttyS0 wg.success=ttyS1" |
| 632 | +CONFIG_FRAME_WARN=1280 |
| 633 | --- /dev/null |
| 634 | +++ b/tools/testing/selftests/wireguard/qemu/debug.config |
| 635 | @@ -0,0 +1,67 @@ |
| 636 | +CONFIG_LOCALVERSION="-debug" |
| 637 | +CONFIG_ENABLE_WARN_DEPRECATED=y |
| 638 | +CONFIG_ENABLE_MUST_CHECK=y |
| 639 | +CONFIG_FRAME_POINTER=y |
| 640 | +CONFIG_STACK_VALIDATION=y |
| 641 | +CONFIG_DEBUG_KERNEL=y |
| 642 | +CONFIG_DEBUG_INFO=y |
| 643 | +CONFIG_DEBUG_INFO_DWARF4=y |
| 644 | +CONFIG_PAGE_EXTENSION=y |
| 645 | +CONFIG_PAGE_POISONING=y |
| 646 | +CONFIG_DEBUG_OBJECTS=y |
| 647 | +CONFIG_DEBUG_OBJECTS_FREE=y |
| 648 | +CONFIG_DEBUG_OBJECTS_TIMERS=y |
| 649 | +CONFIG_DEBUG_OBJECTS_WORK=y |
| 650 | +CONFIG_DEBUG_OBJECTS_RCU_HEAD=y |
| 651 | +CONFIG_DEBUG_OBJECTS_PERCPU_COUNTER=y |
| 652 | +CONFIG_DEBUG_OBJECTS_ENABLE_DEFAULT=1 |
| 653 | +CONFIG_SLUB_DEBUG_ON=y |
| 654 | +CONFIG_DEBUG_VM=y |
| 655 | +CONFIG_DEBUG_MEMORY_INIT=y |
| 656 | +CONFIG_HAVE_DEBUG_STACKOVERFLOW=y |
| 657 | +CONFIG_DEBUG_STACKOVERFLOW=y |
| 658 | +CONFIG_HAVE_ARCH_KMEMCHECK=y |
| 659 | +CONFIG_HAVE_ARCH_KASAN=y |
| 660 | +CONFIG_KASAN=y |
| 661 | +CONFIG_KASAN_INLINE=y |
| 662 | +CONFIG_UBSAN=y |
| 663 | +CONFIG_UBSAN_SANITIZE_ALL=y |
| 664 | +CONFIG_UBSAN_NO_ALIGNMENT=y |
| 665 | +CONFIG_UBSAN_NULL=y |
| 666 | +CONFIG_DEBUG_KMEMLEAK=y |
| 667 | +CONFIG_DEBUG_KMEMLEAK_EARLY_LOG_SIZE=8192 |
| 668 | +CONFIG_DEBUG_STACK_USAGE=y |
| 669 | +CONFIG_DEBUG_SHIRQ=y |
| 670 | +CONFIG_WQ_WATCHDOG=y |
| 671 | +CONFIG_SCHED_DEBUG=y |
| 672 | +CONFIG_SCHED_INFO=y |
| 673 | +CONFIG_SCHEDSTATS=y |
| 674 | +CONFIG_SCHED_STACK_END_CHECK=y |
| 675 | +CONFIG_DEBUG_TIMEKEEPING=y |
| 676 | +CONFIG_TIMER_STATS=y |
| 677 | +CONFIG_DEBUG_PREEMPT=y |
| 678 | +CONFIG_DEBUG_RT_MUTEXES=y |
| 679 | +CONFIG_DEBUG_SPINLOCK=y |
| 680 | +CONFIG_DEBUG_MUTEXES=y |
| 681 | +CONFIG_DEBUG_LOCK_ALLOC=y |
| 682 | +CONFIG_PROVE_LOCKING=y |
| 683 | +CONFIG_LOCKDEP=y |
| 684 | +CONFIG_DEBUG_ATOMIC_SLEEP=y |
| 685 | +CONFIG_TRACE_IRQFLAGS=y |
| 686 | +CONFIG_DEBUG_BUGVERBOSE=y |
| 687 | +CONFIG_DEBUG_LIST=y |
| 688 | +CONFIG_DEBUG_PI_LIST=y |
| 689 | +CONFIG_PROVE_RCU=y |
| 690 | +CONFIG_SPARSE_RCU_POINTER=y |
| 691 | +CONFIG_RCU_CPU_STALL_TIMEOUT=21 |
| 692 | +CONFIG_RCU_TRACE=y |
| 693 | +CONFIG_RCU_EQS_DEBUG=y |
| 694 | +CONFIG_USER_STACKTRACE_SUPPORT=y |
| 695 | +CONFIG_DEBUG_SG=y |
| 696 | +CONFIG_DEBUG_NOTIFIERS=y |
| 697 | +CONFIG_DOUBLEFAULT=y |
| 698 | +CONFIG_X86_DEBUG_FPU=y |
| 699 | +CONFIG_DEBUG_SECTION_MISMATCH=y |
| 700 | +CONFIG_DEBUG_PAGEALLOC=y |
| 701 | +CONFIG_DEBUG_PAGEALLOC_ENABLE_DEFAULT=y |
| 702 | +CONFIG_DEBUG_WW_MUTEX_SLOWPATH=y |
| 703 | --- /dev/null |
| 704 | +++ b/tools/testing/selftests/wireguard/qemu/init.c |
| 705 | @@ -0,0 +1,284 @@ |
| 706 | +// SPDX-License-Identifier: GPL-2.0 |
| 707 | +/* |
| 708 | + * Copyright (C) 2015-2019 Jason A. Donenfeld <Jason@zx2c4.com>. All Rights Reserved. |
| 709 | + */ |
| 710 | + |
| 711 | +#define _GNU_SOURCE |
| 712 | +#include <unistd.h> |
| 713 | +#include <errno.h> |
| 714 | +#include <string.h> |
| 715 | +#include <stdio.h> |
| 716 | +#include <stdlib.h> |
| 717 | +#include <stdbool.h> |
| 718 | +#include <fcntl.h> |
| 719 | +#include <sys/wait.h> |
| 720 | +#include <sys/mount.h> |
| 721 | +#include <sys/types.h> |
| 722 | +#include <sys/stat.h> |
| 723 | +#include <sys/types.h> |
| 724 | +#include <sys/io.h> |
| 725 | +#include <sys/ioctl.h> |
| 726 | +#include <sys/reboot.h> |
| 727 | +#include <sys/utsname.h> |
| 728 | +#include <sys/sendfile.h> |
| 729 | +#include <linux/random.h> |
| 730 | +#include <linux/version.h> |
| 731 | + |
| 732 | +__attribute__((noreturn)) static void poweroff(void) |
| 733 | +{ |
| 734 | + fflush(stdout); |
| 735 | + fflush(stderr); |
| 736 | + reboot(RB_AUTOBOOT); |
| 737 | + sleep(30); |
| 738 | + fprintf(stderr, "\x1b[37m\x1b[41m\x1b[1mFailed to power off!!!\x1b[0m\n"); |
| 739 | + exit(1); |
| 740 | +} |
| 741 | + |
| 742 | +static void panic(const char *what) |
| 743 | +{ |
| 744 | + fprintf(stderr, "\n\n\x1b[37m\x1b[41m\x1b[1mSOMETHING WENT HORRIBLY WRONG\x1b[0m\n\n \x1b[31m\x1b[1m%s: %s\x1b[0m\n\n\x1b[37m\x1b[44m\x1b[1mPower off...\x1b[0m\n\n", what, strerror(errno)); |
| 745 | + poweroff(); |
| 746 | +} |
| 747 | + |
| 748 | +#define pretty_message(msg) puts("\x1b[32m\x1b[1m" msg "\x1b[0m") |
| 749 | + |
| 750 | +static void print_banner(void) |
| 751 | +{ |
| 752 | + struct utsname utsname; |
| 753 | + int len; |
| 754 | + |
| 755 | + if (uname(&utsname) < 0) |
| 756 | + panic("uname"); |
| 757 | + |
| 758 | + len = strlen(" WireGuard Test Suite on ") + strlen(utsname.sysname) + strlen(utsname.release) + strlen(utsname.machine); |
| 759 | + printf("\x1b[45m\x1b[33m\x1b[1m%*.s\x1b[0m\n\x1b[45m\x1b[33m\x1b[1m WireGuard Test Suite on %s %s %s \x1b[0m\n\x1b[45m\x1b[33m\x1b[1m%*.s\x1b[0m\n\n", len, "", utsname.sysname, utsname.release, utsname.machine, len, ""); |
| 760 | +} |
| 761 | + |
| 762 | +static void seed_rng(void) |
| 763 | +{ |
| 764 | + int fd; |
| 765 | + struct { |
| 766 | + int entropy_count; |
| 767 | + int buffer_size; |
| 768 | + unsigned char buffer[256]; |
| 769 | + } entropy = { |
| 770 | + .entropy_count = sizeof(entropy.buffer) * 8, |
| 771 | + .buffer_size = sizeof(entropy.buffer), |
| 772 | + .buffer = "Adding real entropy is not actually important for these tests. Don't try this at home, kids!" |
| 773 | + }; |
| 774 | + |
| 775 | + if (mknod("/dev/urandom", S_IFCHR | 0644, makedev(1, 9))) |
| 776 | + panic("mknod(/dev/urandom)"); |
| 777 | + fd = open("/dev/urandom", O_WRONLY); |
| 778 | + if (fd < 0) |
| 779 | + panic("open(urandom)"); |
| 780 | + for (int i = 0; i < 256; ++i) { |
| 781 | + if (ioctl(fd, RNDADDENTROPY, &entropy) < 0) |
| 782 | + panic("ioctl(urandom)"); |
| 783 | + } |
| 784 | + close(fd); |
| 785 | +} |
| 786 | + |
| 787 | +static void mount_filesystems(void) |
| 788 | +{ |
| 789 | + pretty_message("[+] Mounting filesystems..."); |
| 790 | + mkdir("/dev", 0755); |
| 791 | + mkdir("/proc", 0755); |
| 792 | + mkdir("/sys", 0755); |
| 793 | + mkdir("/tmp", 0755); |
| 794 | + mkdir("/run", 0755); |
| 795 | + mkdir("/var", 0755); |
| 796 | + if (mount("none", "/dev", "devtmpfs", 0, NULL)) |
| 797 | + panic("devtmpfs mount"); |
| 798 | + if (mount("none", "/proc", "proc", 0, NULL)) |
| 799 | + panic("procfs mount"); |
| 800 | + if (mount("none", "/sys", "sysfs", 0, NULL)) |
| 801 | + panic("sysfs mount"); |
| 802 | + if (mount("none", "/tmp", "tmpfs", 0, NULL)) |
| 803 | + panic("tmpfs mount"); |
| 804 | + if (mount("none", "/run", "tmpfs", 0, NULL)) |
| 805 | + panic("tmpfs mount"); |
| 806 | + if (mount("none", "/sys/kernel/debug", "debugfs", 0, NULL)) |
| 807 | + ; /* Not a problem if it fails.*/ |
| 808 | + if (symlink("/run", "/var/run")) |
| 809 | + panic("run symlink"); |
| 810 | + if (symlink("/proc/self/fd", "/dev/fd")) |
| 811 | + panic("fd symlink"); |
| 812 | +} |
| 813 | + |
| 814 | +static void enable_logging(void) |
| 815 | +{ |
| 816 | + int fd; |
| 817 | + pretty_message("[+] Enabling logging..."); |
| 818 | + fd = open("/proc/sys/kernel/printk", O_WRONLY); |
| 819 | + if (fd >= 0) { |
| 820 | + if (write(fd, "9\n", 2) != 2) |
| 821 | + panic("write(printk)"); |
| 822 | + close(fd); |
| 823 | + } |
| 824 | + fd = open("/proc/sys/debug/exception-trace", O_WRONLY); |
| 825 | + if (fd >= 0) { |
| 826 | + if (write(fd, "1\n", 2) != 2) |
| 827 | + panic("write(exception-trace)"); |
| 828 | + close(fd); |
| 829 | + } |
| 830 | + fd = open("/proc/sys/kernel/panic_on_warn", O_WRONLY); |
| 831 | + if (fd >= 0) { |
| 832 | + if (write(fd, "1\n", 2) != 2) |
| 833 | + panic("write(panic_on_warn)"); |
| 834 | + close(fd); |
| 835 | + } |
| 836 | +} |
| 837 | + |
| 838 | +static void kmod_selftests(void) |
| 839 | +{ |
| 840 | + FILE *file; |
| 841 | + char line[2048], *start, *pass; |
| 842 | + bool success = true; |
| 843 | + pretty_message("[+] Module self-tests:"); |
| 844 | + file = fopen("/proc/kmsg", "r"); |
| 845 | + if (!file) |
| 846 | + panic("fopen(kmsg)"); |
| 847 | + if (fcntl(fileno(file), F_SETFL, O_NONBLOCK) < 0) |
| 848 | + panic("fcntl(kmsg, nonblock)"); |
| 849 | + while (fgets(line, sizeof(line), file)) { |
| 850 | + start = strstr(line, "wireguard: "); |
| 851 | + if (!start) |
| 852 | + continue; |
| 853 | + start += 11; |
| 854 | + *strchrnul(start, '\n') = '\0'; |
| 855 | + if (strstr(start, "www.wireguard.com")) |
| 856 | + break; |
| 857 | + pass = strstr(start, ": pass"); |
| 858 | + if (!pass || pass[6] != '\0') { |
| 859 | + success = false; |
| 860 | + printf(" \x1b[31m* %s\x1b[0m\n", start); |
| 861 | + } else |
| 862 | + printf(" \x1b[32m* %s\x1b[0m\n", start); |
| 863 | + } |
| 864 | + fclose(file); |
| 865 | + if (!success) { |
| 866 | + puts("\x1b[31m\x1b[1m[-] Tests failed! \u2639\x1b[0m"); |
| 867 | + poweroff(); |
| 868 | + } |
| 869 | +} |
| 870 | + |
| 871 | +static void launch_tests(void) |
| 872 | +{ |
| 873 | + char cmdline[4096], *success_dev; |
| 874 | + int status, fd; |
| 875 | + pid_t pid; |
| 876 | + |
| 877 | + pretty_message("[+] Launching tests..."); |
| 878 | + pid = fork(); |
| 879 | + if (pid == -1) |
| 880 | + panic("fork"); |
| 881 | + else if (pid == 0) { |
| 882 | + execl("/init.sh", "init", NULL); |
| 883 | + panic("exec"); |
| 884 | + } |
| 885 | + if (waitpid(pid, &status, 0) < 0) |
| 886 | + panic("waitpid"); |
| 887 | + if (WIFEXITED(status) && WEXITSTATUS(status) == 0) { |
| 888 | + pretty_message("[+] Tests successful! :-)"); |
| 889 | + fd = open("/proc/cmdline", O_RDONLY); |
| 890 | + if (fd < 0) |
| 891 | + panic("open(/proc/cmdline)"); |
| 892 | + if (read(fd, cmdline, sizeof(cmdline) - 1) <= 0) |
| 893 | + panic("read(/proc/cmdline)"); |
| 894 | + cmdline[sizeof(cmdline) - 1] = '\0'; |
| 895 | + for (success_dev = strtok(cmdline, " \n"); success_dev; success_dev = strtok(NULL, " \n")) { |
| 896 | + if (strncmp(success_dev, "wg.success=", 11)) |
| 897 | + continue; |
| 898 | + memcpy(success_dev + 11 - 5, "/dev/", 5); |
| 899 | + success_dev += 11 - 5; |
| 900 | + break; |
| 901 | + } |
| 902 | + if (!success_dev || !strlen(success_dev)) |
| 903 | + panic("Unable to find success device"); |
| 904 | + |
| 905 | + fd = open(success_dev, O_WRONLY); |
| 906 | + if (fd < 0) |
| 907 | + panic("open(success_dev)"); |
| 908 | + if (write(fd, "success\n", 8) != 8) |
| 909 | + panic("write(success_dev)"); |
| 910 | + close(fd); |
| 911 | + } else { |
| 912 | + const char *why = "unknown cause"; |
| 913 | + int what = -1; |
| 914 | + |
| 915 | + if (WIFEXITED(status)) { |
| 916 | + why = "exit code"; |
| 917 | + what = WEXITSTATUS(status); |
| 918 | + } else if (WIFSIGNALED(status)) { |
| 919 | + why = "signal"; |
| 920 | + what = WTERMSIG(status); |
| 921 | + } |
| 922 | + printf("\x1b[31m\x1b[1m[-] Tests failed with %s %d! \u2639\x1b[0m\n", why, what); |
| 923 | + } |
| 924 | +} |
| 925 | + |
| 926 | +static void ensure_console(void) |
| 927 | +{ |
| 928 | + for (unsigned int i = 0; i < 1000; ++i) { |
| 929 | + int fd = open("/dev/console", O_RDWR); |
| 930 | + if (fd < 0) { |
| 931 | + usleep(50000); |
| 932 | + continue; |
| 933 | + } |
| 934 | + dup2(fd, 0); |
| 935 | + dup2(fd, 1); |
| 936 | + dup2(fd, 2); |
| 937 | + close(fd); |
| 938 | + if (write(1, "\0\0\0\0\n", 5) == 5) |
| 939 | + return; |
| 940 | + } |
| 941 | + panic("Unable to open console device"); |
| 942 | +} |
| 943 | + |
| 944 | +static void clear_leaks(void) |
| 945 | +{ |
| 946 | + int fd; |
| 947 | + |
| 948 | + fd = open("/sys/kernel/debug/kmemleak", O_WRONLY); |
| 949 | + if (fd < 0) |
| 950 | + return; |
| 951 | + pretty_message("[+] Starting memory leak detection..."); |
| 952 | + write(fd, "clear\n", 5); |
| 953 | + close(fd); |
| 954 | +} |
| 955 | + |
| 956 | +static void check_leaks(void) |
| 957 | +{ |
| 958 | + int fd; |
| 959 | + |
| 960 | + fd = open("/sys/kernel/debug/kmemleak", O_WRONLY); |
| 961 | + if (fd < 0) |
| 962 | + return; |
| 963 | + pretty_message("[+] Scanning for memory leaks..."); |
| 964 | + sleep(2); /* Wait for any grace periods. */ |
| 965 | + write(fd, "scan\n", 5); |
| 966 | + close(fd); |
| 967 | + |
| 968 | + fd = open("/sys/kernel/debug/kmemleak", O_RDONLY); |
| 969 | + if (fd < 0) |
| 970 | + return; |
| 971 | + if (sendfile(1, fd, NULL, 0x7ffff000) > 0) |
| 972 | + panic("Memory leaks encountered"); |
| 973 | + close(fd); |
| 974 | +} |
| 975 | + |
| 976 | +int main(int argc, char *argv[]) |
| 977 | +{ |
| 978 | + seed_rng(); |
| 979 | + ensure_console(); |
| 980 | + print_banner(); |
| 981 | + mount_filesystems(); |
| 982 | + kmod_selftests(); |
| 983 | + enable_logging(); |
| 984 | + clear_leaks(); |
| 985 | + launch_tests(); |
| 986 | + check_leaks(); |
| 987 | + poweroff(); |
| 988 | + return 1; |
| 989 | +} |
| 990 | --- /dev/null |
| 991 | +++ b/tools/testing/selftests/wireguard/qemu/kernel.config |
| 992 | @@ -0,0 +1,86 @@ |
| 993 | +CONFIG_LOCALVERSION="" |
| 994 | +CONFIG_NET=y |
| 995 | +CONFIG_NETDEVICES=y |
| 996 | +CONFIG_NET_CORE=y |
| 997 | +CONFIG_NET_IPIP=y |
| 998 | +CONFIG_DUMMY=y |
| 999 | +CONFIG_VETH=y |
| 1000 | +CONFIG_MULTIUSER=y |
| 1001 | +CONFIG_NAMESPACES=y |
| 1002 | +CONFIG_NET_NS=y |
| 1003 | +CONFIG_UNIX=y |
| 1004 | +CONFIG_INET=y |
| 1005 | +CONFIG_IPV6=y |
| 1006 | +CONFIG_NETFILTER=y |
| 1007 | +CONFIG_NETFILTER_ADVANCED=y |
| 1008 | +CONFIG_NF_CONNTRACK=y |
| 1009 | +CONFIG_NF_NAT=y |
| 1010 | +CONFIG_NETFILTER_XTABLES=y |
| 1011 | +CONFIG_NETFILTER_XT_NAT=y |
| 1012 | +CONFIG_NETFILTER_XT_MATCH_LENGTH=y |
| 1013 | +CONFIG_NF_CONNTRACK_IPV4=y |
| 1014 | +CONFIG_NF_NAT_IPV4=y |
| 1015 | +CONFIG_IP_NF_IPTABLES=y |
| 1016 | +CONFIG_IP_NF_FILTER=y |
| 1017 | +CONFIG_IP_NF_NAT=y |
| 1018 | +CONFIG_IP_ADVANCED_ROUTER=y |
| 1019 | +CONFIG_IP_MULTIPLE_TABLES=y |
| 1020 | +CONFIG_IPV6_MULTIPLE_TABLES=y |
| 1021 | +CONFIG_TTY=y |
| 1022 | +CONFIG_BINFMT_ELF=y |
| 1023 | +CONFIG_BINFMT_SCRIPT=y |
| 1024 | +CONFIG_VDSO=y |
| 1025 | +CONFIG_VIRTUALIZATION=y |
| 1026 | +CONFIG_HYPERVISOR_GUEST=y |
| 1027 | +CONFIG_PARAVIRT=y |
| 1028 | +CONFIG_KVM_GUEST=y |
| 1029 | +CONFIG_PARAVIRT_SPINLOCKS=y |
| 1030 | +CONFIG_PRINTK=y |
| 1031 | +CONFIG_KALLSYMS=y |
| 1032 | +CONFIG_BUG=y |
| 1033 | +CONFIG_CC_OPTIMIZE_FOR_PERFORMANCE=y |
| 1034 | +CONFIG_EMBEDDED=n |
| 1035 | +CONFIG_BASE_FULL=y |
| 1036 | +CONFIG_FUTEX=y |
| 1037 | +CONFIG_SHMEM=y |
| 1038 | +CONFIG_SLUB=y |
| 1039 | +CONFIG_SPARSEMEM_VMEMMAP=y |
| 1040 | +CONFIG_SMP=y |
| 1041 | +CONFIG_SCHED_SMT=y |
| 1042 | +CONFIG_SCHED_MC=y |
| 1043 | +CONFIG_NUMA=y |
| 1044 | +CONFIG_PREEMPT=y |
| 1045 | +CONFIG_NO_HZ=y |
| 1046 | +CONFIG_NO_HZ_IDLE=y |
| 1047 | +CONFIG_NO_HZ_FULL=n |
| 1048 | +CONFIG_HZ_PERIODIC=n |
| 1049 | +CONFIG_HIGH_RES_TIMERS=y |
| 1050 | +CONFIG_ARCH_RANDOM=y |
| 1051 | +CONFIG_FILE_LOCKING=y |
| 1052 | +CONFIG_POSIX_TIMERS=y |
| 1053 | +CONFIG_DEVTMPFS=y |
| 1054 | +CONFIG_PROC_FS=y |
| 1055 | +CONFIG_PROC_SYSCTL=y |
| 1056 | +CONFIG_SYSFS=y |
| 1057 | +CONFIG_TMPFS=y |
| 1058 | +CONFIG_CONSOLE_LOGLEVEL_DEFAULT=15 |
| 1059 | +CONFIG_PRINTK_TIME=y |
| 1060 | +CONFIG_BLK_DEV_INITRD=y |
| 1061 | +CONFIG_LEGACY_VSYSCALL_NONE=y |
| 1062 | +CONFIG_KERNEL_GZIP=y |
| 1063 | +CONFIG_PANIC_ON_OOPS=y |
| 1064 | +CONFIG_BUG_ON_DATA_CORRUPTION=y |
| 1065 | +CONFIG_LOCKUP_DETECTOR=y |
| 1066 | +CONFIG_SOFTLOCKUP_DETECTOR=y |
| 1067 | +CONFIG_HARDLOCKUP_DETECTOR=y |
| 1068 | +CONFIG_WQ_WATCHDOG=y |
| 1069 | +CONFIG_DETECT_HUNG_TASK=y |
| 1070 | +CONFIG_BOOTPARAM_HARDLOCKUP_PANIC=y |
| 1071 | +CONFIG_BOOTPARAM_SOFTLOCKUP_PANIC=y |
| 1072 | +CONFIG_BOOTPARAM_HUNG_TASK_PANIC=y |
| 1073 | +CONFIG_PANIC_TIMEOUT=-1 |
| 1074 | +CONFIG_STACKTRACE=y |
| 1075 | +CONFIG_EARLY_PRINTK=y |
| 1076 | +CONFIG_GDB_SCRIPTS=y |
| 1077 | +CONFIG_WIREGUARD=y |
| 1078 | +CONFIG_WIREGUARD_DEBUG=y |