xref: /linux/samples/Kconfig (revision 370c3883195566ee3e7d79e0146c3d735a406573)
1# SPDX-License-Identifier: GPL-2.0-only
2menuconfig SAMPLES
3	bool "Sample kernel code"
4	help
5	  You can build and test sample kernel code here.
6
7if SAMPLES
8
9config SAMPLE_AUXDISPLAY
10	bool "auxdisplay sample"
11	depends on CC_CAN_LINK
12
13config SAMPLE_TRACE_EVENTS
14	tristate "Build trace_events examples -- loadable modules only"
15	depends on EVENT_TRACING && m
16	help
17	  This builds the trace event example module.
18
19config SAMPLE_TRACE_CUSTOM_EVENTS
20	tristate "Build custom trace event example -- loadable modules only"
21	depends on EVENT_TRACING && m
22	help
23	  This builds the custom trace event example module.
24
25config SAMPLE_TRACE_PRINTK
26	tristate "Build trace_printk module - tests various trace_printk formats"
27	depends on EVENT_TRACING && m
28	help
29	  This builds a module that calls trace_printk() and can be used to
30	  test various trace_printk() calls from a module.
31
32config SAMPLE_FTRACE_DIRECT
33	tristate "Build register_ftrace_direct() example"
34	depends on DYNAMIC_FTRACE_WITH_DIRECT_CALLS && m
35	depends on HAVE_SAMPLE_FTRACE_DIRECT
36	help
37	  This builds an ftrace direct function example
38	  that hooks to wake_up_process and prints the parameters.
39
40config SAMPLE_FTRACE_DIRECT_MULTI
41	tristate "Build register_ftrace_direct() on multiple ips example"
42	depends on DYNAMIC_FTRACE_WITH_DIRECT_CALLS && m
43	depends on HAVE_SAMPLE_FTRACE_DIRECT_MULTI
44	help
45	  This builds an ftrace direct function example
46	  that hooks to wake_up_process and schedule, and prints
47	  the function addresses.
48
49config SAMPLE_FTRACE_OPS
50	tristate "Build custom ftrace ops example"
51	depends on FUNCTION_TRACER
52	help
53	  This builds an ftrace ops example that hooks two functions and
54	  measures the time taken to invoke one function a number of times.
55
56config SAMPLE_TRACE_ARRAY
57	tristate "Build sample module for kernel access to Ftrace instances"
58	depends on EVENT_TRACING && m
59	help
60	  This builds a module that demonstrates the use of various APIs to
61	  access Ftrace instances from within the kernel.
62
63config SAMPLE_KOBJECT
64	tristate "Build kobject examples"
65	help
66	  This config option will allow you to build a number of
67	  different kobject sample modules showing how to use kobjects,
68	  ksets, and ktypes properly.
69
70	  If in doubt, say "N" here.
71
72config SAMPLE_KPROBES
73	tristate "Build kprobes examples -- loadable modules only"
74	depends on KPROBES && m
75	help
76	  This build several kprobes example modules.
77
78config SAMPLE_KRETPROBES
79	tristate "Build kretprobes example -- loadable modules only"
80	default m
81	depends on SAMPLE_KPROBES && KRETPROBES
82
83config SAMPLE_HW_BREAKPOINT
84	tristate "Build kernel hardware breakpoint examples -- loadable module only"
85	depends on HAVE_HW_BREAKPOINT && m
86	help
87	  This builds kernel hardware breakpoint example modules.
88
89config SAMPLE_FPROBE
90	tristate "Build fprobe examples -- loadable modules only"
91	depends on FPROBE && m
92	help
93	  This builds a fprobe example module. This module has an option 'symbol'.
94	  You can specify a probed symbol or symbols separated with ','.
95
96config SAMPLE_KFIFO
97	tristate "Build kfifo examples -- loadable modules only"
98	depends on m
99	help
100	  This config option will allow you to build a number of
101	  different kfifo sample modules showing how to use the
102	  generic kfifo API.
103
104	  If in doubt, say "N" here.
105
106config SAMPLE_KDB
107	tristate "Build kdb command example -- loadable modules only"
108	depends on KGDB_KDB && m
109	help
110	  Build an example of how to dynamically add the hello
111	  command to the kdb shell.
112
113config SAMPLE_QMI_CLIENT
114	tristate "Build qmi client sample -- loadable modules only"
115	depends on m
116	depends on ARCH_QCOM
117	depends on NET
118	select QCOM_QMI_HELPERS
119	help
120	  Build an QMI client sample driver, which demonstrates how to
121	  communicate with a remote QRTR service, using QMI encoded messages.
122
123config SAMPLE_RPMSG_CLIENT
124	tristate "Build rpmsg client sample -- loadable modules only"
125	depends on RPMSG && m
126	help
127	  Build an rpmsg client sample driver, which demonstrates how
128	  to communicate with an AMP-configured remote processor over
129	  the rpmsg bus.
130
131config SAMPLE_LIVEPATCH
132	tristate "Build live patching samples -- loadable modules only"
133	depends on LIVEPATCH && m
134	help
135	  Build sample live patch demonstrations.
136
137config SAMPLE_CONFIGFS
138	tristate "Build configfs patching sample -- loadable modules only"
139	depends on CONFIGFS_FS && m
140	help
141	  Builds a sample configfs interface.
142
143config SAMPLE_CONNECTOR
144	tristate "Build connector sample -- loadable modules only"
145	depends on CONNECTOR && HEADERS_INSTALL && m
146	help
147	  When enabled, this builds both a sample kernel module for
148	  the connector interface and a user space tool to communicate
149	  with it.
150	  See also Documentation/driver-api/connector.rst
151
152config SAMPLE_FANOTIFY_ERROR
153	bool "Build fanotify error monitoring sample"
154	depends on FANOTIFY && CC_CAN_LINK && HEADERS_INSTALL
155	help
156	  When enabled, this builds an example code that uses the
157	  FAN_FS_ERROR fanotify mechanism to monitor filesystem
158	  errors.
159	  See also Documentation/admin-guide/filesystem-monitoring.rst.
160
161config SAMPLE_HIDRAW
162	bool "hidraw sample"
163	depends on CC_CAN_LINK && HEADERS_INSTALL
164
165config SAMPLE_LANDLOCK
166	bool "Landlock example"
167	depends on CC_CAN_LINK && HEADERS_INSTALL
168	help
169	  Build a simple Landlock sandbox manager able to start a process
170	  restricted by a user-defined filesystem access control policy.
171
172config SAMPLE_PIDFD
173	bool "pidfd sample"
174	depends on CC_CAN_LINK && HEADERS_INSTALL
175
176config SAMPLE_SECCOMP
177	bool "Build seccomp sample code"
178	depends on SECCOMP_FILTER && CC_CAN_LINK && HEADERS_INSTALL
179	help
180	  Build samples of seccomp filters using various methods of
181	  BPF filter construction.
182
183config SAMPLE_TIMER
184	bool "Timer sample"
185	depends on CC_CAN_LINK && HEADERS_INSTALL
186
187config SAMPLE_TSM_MR
188	tristate "TSM measurement sample"
189	select CRYPTO_LIB_SHA256
190	select CRYPTO_LIB_SHA512
191	select TSM_MEASUREMENTS
192	select VIRT_DRIVERS
193	help
194	  Build a sample module that emulates MRs (Measurement Registers) and
195	  exposes them to user mode applications through the TSM sysfs
196	  interface (/sys/class/misc/tsm_mr_sample/emulated_mr/).
197
198	  The module name will be tsm-mr-sample when built as a module.
199
200config SAMPLE_UHID
201	bool "UHID sample"
202	depends on CC_CAN_LINK && HEADERS_INSTALL
203	help
204	  Build UHID sample program.
205
206config SAMPLE_VFIO_MDEV_MTTY
207	tristate "Build VFIO mtty example mediated device sample code"
208	depends on VFIO
209	select VFIO_MDEV
210	help
211	  Build a virtual tty sample driver for use as a VFIO
212	  mediated device
213
214config SAMPLE_VFIO_MDEV_MDPY
215	tristate "Build VFIO mdpy example mediated device sample code"
216	depends on VFIO
217	select VFIO_MDEV
218	help
219	  Build a virtual display sample driver for use as a VFIO
220	  mediated device.  It is a simple framebuffer and supports
221	  the region display interface (VFIO_GFX_PLANE_TYPE_REGION).
222
223config SAMPLE_VFIO_MDEV_MDPY_FB
224	tristate "Build VFIO mdpy example guest fbdev driver"
225	depends on FB
226	select FB_IOMEM_HELPERS
227	help
228	  Guest fbdev driver for the virtual display sample driver.
229
230config SAMPLE_VFIO_MDEV_MBOCHS
231	tristate "Build VFIO mbochs example mediated device sample code"
232	depends on VFIO
233	select VFIO_MDEV
234	select DMA_SHARED_BUFFER
235	help
236	  Build a virtual display sample driver for use as a VFIO
237	  mediated device.  It supports the region display interface
238	  (VFIO_GFX_PLANE_TYPE_DMABUF).
239	  Emulate enough of qemu stdvga to make bochs-drm.ko happy.
240	  That is basically the vram memory bar and the bochs dispi
241	  interface vbe registers in the mmio register bar.
242	  Specifically it does *not* include any legacy vga stuff.
243	  Device looks a lot like "qemu -device secondary-vga".
244
245config SAMPLE_ANDROID_BINDERFS
246	bool "Build Android binderfs example"
247	depends on CC_CAN_LINK && HEADERS_INSTALL
248	help
249	  Builds a sample program to illustrate the use of the Android binderfs
250	  filesystem.
251
252config SAMPLE_VFS
253	bool "Build example programs that use new VFS system calls"
254	depends on CC_CAN_LINK && HEADERS_INSTALL
255	help
256	  Build example userspace programs that use new VFS system calls such
257	  as mount API and statx().  Note that this is restricted to the x86
258	  arch whilst it accesses system calls that aren't yet in all arches.
259
260config SAMPLE_INTEL_MEI
261	bool "Build example program working with intel mei driver"
262	depends on INTEL_MEI
263	depends on CC_CAN_LINK && HEADERS_INSTALL
264	help
265	  Build a sample program to work with mei device.
266
267config SAMPLE_TPS6594_PFSM
268	bool "Build example program working with TPS6594 PFSM driver"
269	depends on HEADERS_INSTALL
270	depends on CC_CAN_LINK
271	help
272	  Build a sample program to work with PFSM devices.
273
274config SAMPLE_WATCHDOG
275	bool "watchdog sample"
276	depends on CC_CAN_LINK
277
278config SAMPLE_WATCH_QUEUE
279	bool "Build example watch_queue notification API consumer"
280	depends on CC_CAN_LINK && HEADERS_INSTALL
281	help
282	  Build example userspace program to use the new mount_notify(),
283	  sb_notify() syscalls and the KEYCTL_WATCH_KEY keyctl() function.
284
285config SAMPLE_CORESIGHT_SYSCFG
286	tristate "Build example loadable module for CoreSight config"
287	depends on CORESIGHT && m
288	help
289	  Build an example loadable module that adds new CoreSight features
290	  and configuration using the CoreSight system configuration API.
291	  This demonstrates how a user may create their own CoreSight
292	  configurations and easily load them into the system at runtime.
293
294config SAMPLE_KMEMLEAK
295	tristate "Simple test for the kernel memory leak detector"
296	depends on DEBUG_KMEMLEAK && m
297	help
298	  Build a sample program which have explicitly leaks memory to test
299	  kmemleak.
300
301config SAMPLE_CGROUP
302	bool "Build cgroup sample code"
303	depends on CGROUPS && CC_CAN_LINK && HEADERS_INSTALL
304	help
305	  Build samples that demonstrate the usage of the cgroup API.
306
307config SAMPLE_CHECK_EXEC
308	bool "Exec secure bits examples"
309	depends on CC_CAN_LINK && HEADERS_INSTALL
310	help
311	  Build a tool to easily configure SECBIT_EXEC_RESTRICT_FILE and
312	  SECBIT_EXEC_DENY_INTERACTIVE, and a simple script interpreter to
313	  demonstrate how they should be used with execveat(2) +
314	  AT_EXECVE_CHECK.
315
316config SAMPLE_HUNG_TASK
317	tristate "Hung task detector test code"
318	depends on DETECT_HUNG_TASK && DEBUG_FS
319	help
320	  Build a module that provides debugfs files (e.g., mutex, semaphore,
321	  rw_semaphore_read, rw_semaphore_write) under <debugfs>/hung_task.
322	  Reading these files with multiple processes triggers hung task
323	  detection by holding locks for a long time (256 seconds).
324
325source "samples/rust/Kconfig"
326
327source "samples/damon/Kconfig"
328
329endif # SAMPLES
330
331config HAVE_SAMPLE_FTRACE_DIRECT
332	bool
333
334config HAVE_SAMPLE_FTRACE_DIRECT_MULTI
335	bool
336