xref: /linux/tools/testing/selftests/Makefile (revision b1c21075d30c40762750be0cded9822791df422b)
1b2441318SGreg Kroah-Hartman# SPDX-License-Identifier: GPL-2.0
2f0a1ffa6SAbdulrasaq LawaniTARGETS += acct
35aaf9effSMark BrownTARGETS += alsa
4e1083a03SMeng LiTARGETS += amd-pstate
55aaf9effSMark BrownTARGETS += arm64
647a18c42SPintu AgarwalTARGETS += bpf
75aa5bd14SDaniel BorkmannTARGETS += breakpoints
888537aacSNhat PhamTARGETS += cachestat
9f4ecb322SBamvor Jian ZhangTARGETS += capabilities
1084092dbcSRoman GushchinTARGETS += cgroup
11de528723SChristian BraunerTARGETS += clone3
1273a29531SAnjali KulkarniTARGETS += connector
132c5db60eSChristian BraunerTARGETS += core
14e66d5b67SViresh KumarTARGETS += cpufreq
1566a01b96SAndrew MortonTARGETS += cpu-hotplug
16678f0cdcSYuanchu XieTARGETS += damon
17b7274930SNícolas F. R. A. PradoTARGETS += devices/error_logs
180debb20cSNícolas F. R. A. PradoTARGETS += devices/probe
19888c72d5SMark BrownTARGETS += dmabuf-heaps
206edf2e37STom MurphyTARGETS += drivers/dma-buf
217f853a25SElizabeth FiguraTARGETS += drivers/ntsync
22cbac9242SSteffen EidenTARGETS += drivers/s390x/uvdevice
23b4db9f84SJakub KicinskiTARGETS += drivers/net
24c078290aSJonathan ToppinsTARGETS += drivers/net/bonding
25bbb774d9SBenjamin PoirierTARGETS += drivers/net/team
26ccfaed04SJiri PirkoTARGETS += drivers/net/virtio_net
278e51106dSPengfei XuTARGETS += drivers/platform/x86/intel/ifs
2814571ab1SNícolas F. R. A. PradoTARGETS += dt
2966a01b96SAndrew MortonTARGETS += efivarfs
3096e869d8SAndrew MortonTARGETS += exec
314859c257SAlexey GladkovTARGETS += fchmodat2
32ce290a19SChristian BraunerTARGETS += filesystems
3375abec73SChristian BraunerTARGETS += filesystems/binderfs
34f2728fe8SHeiherTARGETS += filesystems/epoll
35dd7c9be3SJavier Martinez CanillasTARGETS += filesystems/fat
36b5a78c71SAndrei VaginTARGETS += filesystems/overlayfs
375bd3cf8cSMiklos SzerediTARGETS += filesystems/statmount
38e1c24b52SMiklos SzerediTARGETS += filesystems/mount-notify
3996e869d8SAndrew MortonTARGETS += firmware
404185b3b9SPetteri AimonenTARGETS += fpu
4196e869d8SAndrew MortonTARGETS += ftrace
42ecac1a75SDarren HartTARGETS += futex
4322f6592bSBamvor Jian ZhangTARGETS += gpio
44dbb60c8aSBenjamin TissoiresTARGETS += hid
456320303fSStafford HorneTARGETS += intel_pstate
4657f09887SJason GunthorpeTARGETS += iommu
477e722473SBamvor Jian ZhangTARGETS += ipc
48e55c884eSSean YoungTARGETS += ir
4958c7be84SPavel EmelyanovTARGETS += kcmp
50c3c0e811SMimi ZoharTARGETS += kexec
51df82ffc5SThomas WeißschuhTARGETS += kselftest_harness
52783e9e51SPaolo BonziniTARGETS += kvm
53e1199815SMickaël SalaünTARGETS += landlock
54317dc34aSKees CookTARGETS += lib
55a2818ee4SJoe LawrenceTARGETS += livepatch
5646d1a0f0SKees CookTARGETS += lkdtm
57d3d929a8SCasey SchauflerTARGETS += lsm
58b6d97344SPranith KumarTARGETS += membarrier
594f5ce5e8SDavid HerrmannTARGETS += memfd
6058c7be84SPavel EmelyanovTARGETS += memory-hotplug
617a309195SRicardo CañueloTARGETS += mincore
62db181ce0SEric W. BiedermanTARGETS += mount
6301eadc8dSChristian BraunerTARGETS += mount_setattr
648374f431SPavel TikhomirovTARGETS += move_mount_set_group
6596e869d8SAndrew MortonTARGETS += mqueue
66b481341eSJeff XuTARGETS += mseal_system_mappings
67f595cf12SBongsu JeonTARGETS += nci
68a6f68034SDavid S. MillerTARGETS += net
69314001f0SRao ShoaibTARGETS += net/af_unix
7077442ffaSFelix MaurerTARGETS += net/can
7181573b18SVadym KochanTARGETS += net/forwarding
727d0455e9SSebastian Andrzej SiewiorTARGETS += net/hsr
73048d19d4SFlorian WestphalTARGETS += net/mptcp
749ef1ed26SYujie LiuTARGETS += net/netfilter
758a405552SWillem de BruijnTARGETS += net/openvswitch
76959bc330SAntonio QuartulliTARGETS += net/ovpn
778a405552SWillem de BruijnTARGETS += net/packetdrill
783ade6ce1SVegard NossumTARGETS += net/rds
798a405552SWillem de BruijnTARGETS += net/tcp_ao
80eb135311SThomas WeißschuhTARGETS += nolibc
816ad92bf6SAndrey VaginTARGETS += nsfs
82392188bbSManivannan SadhasivamTARGETS += pci_endpoint
83838f12c3SIlpo JärvinenTARGETS += pcie_bwctrl
84888c72d5SMark BrownTARGETS += perf_events
85575a0ae9SChristian BraunerTARGETS += pidfd
866952a4f6SChristian BraunerTARGETS += pid_namespace
874a679c5aSNícolas F. R. A. PradoTARGETS += power_supply
880e56dacdSMichael EllermanTARGETS += powerpc
8952905861SIvan OrlovTARGETS += prctl
909cd65655SAlexey DobriyanTARGETS += proc
91cc04a46fSHiraku ToyookaTARGETS += pstore
9296e869d8SAndrew MortonTARGETS += ptrace
93b28a10aeSAleksa SaraiTARGETS += openat2
94b733143cSShaopeng TanTARGETS += resctrl
95287dcc2bSEvan GreenTARGETS += riscv
96e4aebf06SAlexey GladkovTARGETS += rlimits
97ccba8b64SMathieu DesnoyersTARGETS += rseq
98a12ab9e1SAlexandre BelloniTARGETS += rtc
995d94da7fSLaura NaoTARGETS += rust
1007941b83bSBjörn TöpelTARGETS += sched_ext
101c99ee51aSKees CookTARGETS += seccomp
1022adcba79SJarkko SakkinenTARGETS += sgx
10311f0c8e0SDev JainTARGETS += signal
1043ce51050STim BirdTARGETS += size
1053c545084STom HromatkaTARGETS += sparc64
106b8826e50SAl ViroTARGETS += splice
1071087d019SBamvor Jian ZhangTARGETS += static_keys
10882208160SEmilio LópezTARGETS += sync
109179ef035SGabriel Krisman BertaziTARGETS += syscall_user_dispatch
11096e869d8SAndrew MortonTARGETS += sysctl
1112b9843fbSBriana OurslerTARGETS += tc-testing
11200e07cfbSKuppuswamy SathyanarayananTARGETS += tdx
113d4d27e5aSSrinivas PandruvadaTARGETS += thermal/intel/power_floor
11427801542SSrinivas PandruvadaTARGETS += thermal/intel/workload_hint
11561c57676SDmitry SafonovTARGETS += timens
1162278e5edSShuah Khanifneq (1, $(quicktest))
11796e869d8SAndrew MortonTARGETS += timers
1182278e5edSShuah Khanendif
119a3322868SAlexey DobriyanTARGETS += tmpfs
1206ea3dfe1SJarkko SakkinenTARGETS += tpm2
121e8cc3348SMichal SekletarTARGETS += tty
1226aecda00SMing LeiTARGETS += ublk
1236f874fa0SJuntong DengTARGETS += uevent
12468b4d2d5SMark BrownTARGETS += user_events
12540723419SVincenzo FrascinoTARGETS += vDSO
126baa489faSSeongJae ParkTARGETS += mm
1273f705dfdSAndy LutomirskiTARGETS += x86
1287a9b709eSPawan GuptaTARGETS += x86/bugs
129f21fb798SNaresh KambojuTARGETS += zram
13096e869d8SAndrew Morton#Please keep the TARGETS list alphabetically sorted
1312278e5edSShuah Khan# Run "make quicktest=1 run_tests" or
132c6a13fafSSeongJae Park# "make quicktest=1 kselftest" from top level Makefile
133274343adSFrederic Weisbecker
134ddddda9bSShuah KhanTARGETS_HOTPLUG = cpu-hotplug
135ddddda9bSShuah KhanTARGETS_HOTPLUG += memory-hotplug
136ddddda9bSShuah Khan
137b86761ffSJakub Kicinski# Networking tests want the net/lib target, include it automatically
138ff4b2bfaSJakub Kicinskiifneq ($(filter net drivers/net drivers/net/hw,$(TARGETS)),)
139b86761ffSJakub Kicinskiifeq ($(filter net/lib,$(TARGETS)),)
140b86761ffSJakub Kicinski	INSTALL_DEP_TARGETS := net/lib
141b86761ffSJakub Kicinskiendif
142b86761ffSJakub Kicinskiendif
143b86761ffSJakub Kicinski
1447a6eb7c3SMark Brown# User can optionally provide a TARGETS skiplist. By default we skip
1457941b83bSBjörn Töpel# targets using BPF since it has cutting edge build time dependencies
1467941b83bSBjörn Töpel# which require more effort to install.
1477941b83bSBjörn TöpelSKIP_TARGETS ?= bpf sched_ext
1483a24f7f6SCristian Marussiifneq ($(SKIP_TARGETS),)
1493a24f7f6SCristian Marussi	TMP := $(filter-out $(SKIP_TARGETS), $(TARGETS))
1503a24f7f6SCristian Marussi	override TARGETS := $(TMP)
1513a24f7f6SCristian Marussiendif
1523a24f7f6SCristian Marussi
1539d235a55SJiri Benc# User can set FORCE_TARGETS to 1 to require all targets to be successfully
1549d235a55SJiri Benc# built; make will fail if any of the targets cannot be built. If
1559d235a55SJiri Benc# FORCE_TARGETS is not set (the default), make will succeed if at least one
1569d235a55SJiri Benc# of the targets gets built.
1579d235a55SJiri BencFORCE_TARGETS ?=
1589d235a55SJiri Benc
159f69237e1SGreg Thelen# Clear LDFLAGS and MAKEFLAGS when implicit rules are missing.  This provides
160f69237e1SGreg Thelen# implicit rules to sub-test Makefiles which avoids build failures in test
161f69237e1SGreg Thelen# Makefile that don't have explicit build rules.
162f69237e1SGreg Thelenifeq (,$(LINK.c))
16360df4642SArnaldo Carvalho de Melooverride LDFLAGS =
16467d8712dSShuah Khanoverride MAKEFLAGS =
16567d8712dSShuah Khanendif
16667d8712dSShuah Khan
16729e911efSShuah Khan# Append kselftest to KBUILD_OUTPUT and O to avoid cluttering
16861c2018cSShuah Khan# KBUILD_OUTPUT with selftest objects and headers installed
16961c2018cSShuah Khan# by selftests Makefile or lib.mk.
170051f278eSMasahiro Yamadaifdef building_out_of_srctree
17152fd1d08SShuah Khanoverride LDFLAGS =
17252fd1d08SShuah Khanendif
17352fd1d08SShuah Khan
1745ad51ab6SMuhammad Usama Anjumtop_srcdir ?= ../../..
1755ad51ab6SMuhammad Usama Anjum
1765ad51ab6SMuhammad Usama Anjumifeq ("$(origin O)", "command line")
1775ad51ab6SMuhammad Usama Anjum  KBUILD_OUTPUT := $(O)
1788ce72dc3SShuah Khanendif
1795ad51ab6SMuhammad Usama Anjum
1805ad51ab6SMuhammad Usama Anjumifneq ($(KBUILD_OUTPUT),)
1815ad51ab6SMuhammad Usama Anjum  # Make's built-in functions such as $(abspath ...), $(realpath ...) cannot
1825ad51ab6SMuhammad Usama Anjum  # expand a shell special character '~'. We use a somewhat tedious way here.
1835ad51ab6SMuhammad Usama Anjum  abs_objtree := $(shell cd $(top_srcdir) && mkdir -p $(KBUILD_OUTPUT) && cd $(KBUILD_OUTPUT) && pwd)
1845ad51ab6SMuhammad Usama Anjum  $(if $(abs_objtree),, \
1855ad51ab6SMuhammad Usama Anjum    $(error failed to create output directory "$(KBUILD_OUTPUT)"))
1865ad51ab6SMuhammad Usama Anjum  # $(realpath ...) resolves symlinks
1875ad51ab6SMuhammad Usama Anjum  abs_objtree := $(realpath $(abs_objtree))
1885ad51ab6SMuhammad Usama Anjum  BUILD := $(abs_objtree)/kselftest
189cee27ae5SShuah Khan  KHDR_INCLUDES := -isystem ${abs_objtree}/usr/include
1905ad51ab6SMuhammad Usama Anjumelse
1915ad51ab6SMuhammad Usama Anjum  BUILD := $(CURDIR)
192250f8c11SMuhammad Usama Anjum  abs_srctree := $(shell cd $(top_srcdir) && pwd)
193cee27ae5SShuah Khan  KHDR_INCLUDES := -isystem ${abs_srctree}/usr/include
1945ad51ab6SMuhammad Usama Anjum  DEFAULT_INSTALL_HDR_PATH := 1
195a8ba798bSbamvor.zhangjian@huawei.comendif
196a8ba798bSbamvor.zhangjian@huawei.com
1978ce72dc3SShuah Khan# Prepare for headers install
1988ce72dc3SShuah Khaninclude $(top_srcdir)/scripts/subarch.include
1998ce72dc3SShuah KhanARCH           ?= $(SUBARCH)
200a8ba798bSbamvor.zhangjian@huawei.comexport BUILD
201250f8c11SMuhammad Usama Anjumexport KHDR_INCLUDES
2028ce72dc3SShuah Khan
2038ce72dc3SShuah Khan# set default goal to all, so make without a target runs all, even when
2048ce72dc3SShuah Khan# all isn't the first target in the file.
2058ce72dc3SShuah Khan.DEFAULT_GOAL := all
2068ce72dc3SShuah Khan
20743e8832fSJohn Hubbardall:
2085f70bde2SCristian Marussi	@ret=1;							\
209d3f2a958SBui Quang Minh	for TARGET in $(TARGETS) $(INSTALL_DEP_TARGETS); do	\
210a8ba798bSbamvor.zhangjian@huawei.com		BUILD_TARGET=$$BUILD/$$TARGET;			\
211a8ba798bSbamvor.zhangjian@huawei.com		mkdir $$BUILD_TARGET  -p;			\
2129d235a55SJiri Benc		$(MAKE) OUTPUT=$$BUILD_TARGET -C $$TARGET	\
213f6d344cdSMuhammad Usama Anjum				O=$(abs_objtree)		\
2149d235a55SJiri Benc				$(if $(FORCE_TARGETS),|| exit);	\
2155f70bde2SCristian Marussi		ret=$$((ret * $$?));				\
2165f70bde2SCristian Marussi	done; exit $$ret;
217274343adSFrederic Weisbecker
218cab6b056SAndrew Mortonrun_tests: all
2191ede0536SShuah Khan	@for TARGET in $(TARGETS); do \
220a8ba798bSbamvor.zhangjian@huawei.com		BUILD_TARGET=$$BUILD/$$TARGET;	\
221f6d344cdSMuhammad Usama Anjum		$(MAKE) OUTPUT=$$BUILD_TARGET -C $$TARGET run_tests \
2222a0683beSBenjamin Poirier				SRC_PATH=$(shell readlink -e $$(pwd)) \
2232a0683beSBenjamin Poirier				OBJ_PATH=$(BUILD)                   \
224f6d344cdSMuhammad Usama Anjum				O=$(abs_objtree);		    \
225f467f714SFrederic Weisbecker	done;
226f467f714SFrederic Weisbecker
227ddddda9bSShuah Khanhotplug:
2281ede0536SShuah Khan	@for TARGET in $(TARGETS_HOTPLUG); do \
229a8ba798bSbamvor.zhangjian@huawei.com		BUILD_TARGET=$$BUILD/$$TARGET;	\
2300ac33e4eSIlya Leoshkevich		$(MAKE) OUTPUT=$$BUILD_TARGET -C $$TARGET;\
231ddddda9bSShuah Khan	done;
232ddddda9bSShuah Khan
233ddddda9bSShuah Khanrun_hotplug: hotplug
2341ede0536SShuah Khan	@for TARGET in $(TARGETS_HOTPLUG); do \
235a8ba798bSbamvor.zhangjian@huawei.com		BUILD_TARGET=$$BUILD/$$TARGET;	\
2360ac33e4eSIlya Leoshkevich		$(MAKE) OUTPUT=$$BUILD_TARGET -C $$TARGET run_full_test;\
237ddddda9bSShuah Khan	done;
238ddddda9bSShuah Khan
239ddddda9bSShuah Khanclean_hotplug:
2401ede0536SShuah Khan	@for TARGET in $(TARGETS_HOTPLUG); do \
241a8ba798bSbamvor.zhangjian@huawei.com		BUILD_TARGET=$$BUILD/$$TARGET;	\
2420ac33e4eSIlya Leoshkevich		$(MAKE) OUTPUT=$$BUILD_TARGET -C $$TARGET clean;\
243ddddda9bSShuah Khan	done;
244ddddda9bSShuah Khan
245f615e2bbSHiraku Toyookarun_pstore_crash:
2460ac33e4eSIlya Leoshkevich	$(MAKE) -C pstore run_crash
247f615e2bbSHiraku Toyooka
248c3c59928SShuah Khan# Use $BUILD as the default install root. $BUILD points to the
249c3c59928SShuah Khan# right output location for the following cases:
250c3c59928SShuah Khan# 1. output_dir=kernel_src
251c3c59928SShuah Khan# 2. a separate output directory is specified using O= KBUILD_OUTPUT
252c3c59928SShuah Khan# 3. a separate output directory is specified using KBUILD_OUTPUT
25317eac6c2SShuah Khan# Avoid conflict with INSTALL_PATH set by the main Makefile
254c3c59928SShuah Khan#
25517eac6c2SShuah KhanKSFT_INSTALL_PATH ?= $(BUILD)/kselftest_install
25617eac6c2SShuah KhanKSFT_INSTALL_PATH := $(abspath $(KSFT_INSTALL_PATH))
25717eac6c2SShuah Khan# Avoid changing the rest of the logic here and lib.mk.
25817eac6c2SShuah KhanINSTALL_PATH := $(KSFT_INSTALL_PATH)
25932dcfba6SMichael EllermanALL_SCRIPT := $(INSTALL_PATH)/run_kselftest.sh
260f0f0a5dfSKees CookTEST_LIST := $(INSTALL_PATH)/kselftest-list.txt
26132dcfba6SMichael Ellerman
262c3c59928SShuah Khaninstall: all
26332dcfba6SMichael Ellermanifdef INSTALL_PATH
26432dcfba6SMichael Ellerman	@# Ask all targets to install their files
265d4e59a53SKees Cook	mkdir -p $(INSTALL_PATH)/kselftest
266c78fd76fSKees Cook	install -m 744 kselftest/module.sh $(INSTALL_PATH)/kselftest/
267d4e59a53SKees Cook	install -m 744 kselftest/runner.sh $(INSTALL_PATH)/kselftest/
2685c069b6dSKees Cook	install -m 744 kselftest/prefix.pl $(INSTALL_PATH)/kselftest/
2697c079e90SLaura Nao	install -m 744 kselftest/ktap_helpers.sh $(INSTALL_PATH)/kselftest/
2700e7b7bdeSNícolas F. R. A. Prado	install -m 744 kselftest/ksft.py $(INSTALL_PATH)/kselftest/
271f0f0a5dfSKees Cook	install -m 744 run_kselftest.sh $(INSTALL_PATH)/
272f0f0a5dfSKees Cook	rm -f $(TEST_LIST)
2735f70bde2SCristian Marussi	@ret=1;	\
274b86761ffSJakub Kicinski	for TARGET in $(TARGETS) $(INSTALL_DEP_TARGETS); do \
275a8ba798bSbamvor.zhangjian@huawei.com		BUILD_TARGET=$$BUILD/$$TARGET;	\
2762a0683beSBenjamin Poirier		$(MAKE) OUTPUT=$$BUILD_TARGET -C $$TARGET install \
2772a0683beSBenjamin Poirier				INSTALL_PATH=$(INSTALL_PATH)/$$TARGET \
2782a0683beSBenjamin Poirier				SRC_PATH=$(shell readlink -e $$(pwd)) \
2792a0683beSBenjamin Poirier				OBJ_PATH=$(INSTALL_PATH) \
280f6d344cdSMuhammad Usama Anjum				O=$(abs_objtree)		\
2819d235a55SJiri Benc				$(if $(FORCE_TARGETS),|| exit);	\
2825f70bde2SCristian Marussi		ret=$$((ret * $$?));		\
2835f70bde2SCristian Marussi	done; exit $$ret;
28432dcfba6SMichael Ellerman
28532dcfba6SMichael Ellerman
286f0f0a5dfSKees Cook	@# Ask all targets to emit their test scripts
287f0f0a5dfSKees Cook	@# While building kselftest-list.text skip also non-existent TARGET dirs:
288131b30c9SCristian Marussi	@# they could be the result of a build failure and should NOT be
289131b30c9SCristian Marussi	@# included in the generated runlist.
29032dcfba6SMichael Ellerman	for TARGET in $(TARGETS); do \
291a8ba798bSbamvor.zhangjian@huawei.com		BUILD_TARGET=$$BUILD/$$TARGET;	\
2929e34fad0SGuillaume Tucker		[ ! -d $(INSTALL_PATH)/$$TARGET ] && printf "Skipping non-existent dir: $$TARGET\n" && continue; \
2939e34fad0SGuillaume Tucker		printf "Emit Tests for $$TARGET\n"; \
294f0f0a5dfSKees Cook		$(MAKE) -s --no-print-directory OUTPUT=$$BUILD_TARGET COLLECTION=$$TARGET \
295f0f0a5dfSKees Cook			-C $$TARGET emit_tests >> $(TEST_LIST); \
29632dcfba6SMichael Ellerman	done;
297cd9f02adSTianyi Cui	@VERSION=$$(git describe HEAD 2>/dev/null); \
298cd9f02adSTianyi Cui	if [ -n "$$VERSION" ]; then \
299cd9f02adSTianyi Cui		echo "$$VERSION" > $(INSTALL_PATH)/VERSION; \
300cd9f02adSTianyi Cui		printf "Version saved to $(INSTALL_PATH)/VERSION\n"; \
301cd9f02adSTianyi Cui	else \
302cd9f02adSTianyi Cui		printf "Unable to get version from git describe\n"; \
303cd9f02adSTianyi Cui	fi
304*95d32c7eSShuah Khan	@echo "**Kselftest Installation is complete: $(INSTALL_PATH)**"
30532dcfba6SMichael Ellermanelse
30632dcfba6SMichael Ellerman	$(error Error: set INSTALL_PATH to use install)
30732dcfba6SMichael Ellermanendif
30832dcfba6SMichael Ellerman
309a5f30467SVeronika KabatovaFORMAT ?= .gz
310a5f30467SVeronika KabatovaTAR_PATH = $(abspath ${INSTALL_PATH}/kselftest-packages/kselftest.tar${FORMAT})
311a5f30467SVeronika Kabatovagen_tar: install
312a5f30467SVeronika Kabatova	@mkdir -p ${INSTALL_PATH}/kselftest-packages/
313a5f30467SVeronika Kabatova	@tar caf ${TAR_PATH} --exclude=kselftest-packages -C ${INSTALL_PATH} .
314a5f30467SVeronika Kabatova	@echo "Created ${TAR_PATH}"
315a5f30467SVeronika Kabatova
316274343adSFrederic Weisbeckerclean:
3171ede0536SShuah Khan	@for TARGET in $(TARGETS); do \
318a8ba798bSbamvor.zhangjian@huawei.com		BUILD_TARGET=$$BUILD/$$TARGET;	\
3190ac33e4eSIlya Leoshkevich		$(MAKE) OUTPUT=$$BUILD_TARGET -C $$TARGET clean;\
320274343adSFrederic Weisbecker	done;
32132dcfba6SMichael Ellerman
3223bb267a3SGuillaume Tucker.PHONY: all run_tests hotplug run_hotplug clean_hotplug run_pstore_crash install clean gen_tar
323