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 instancess"
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 TSM_MEASUREMENTS
190	select VIRT_DRIVERS
191	help
192	  Build a sample module that emulates MRs (Measurement Registers) and
193	  exposes them to user mode applications through the TSM sysfs
194	  interface (/sys/class/misc/tsm_mr_sample/emulated_mr/).
195
196	  The module name will be tsm-mr-sample when built as a module.
197
198config SAMPLE_UHID
199	bool "UHID sample"
200	depends on CC_CAN_LINK && HEADERS_INSTALL
201	help
202	  Build UHID sample program.
203
204config SAMPLE_VFIO_MDEV_MTTY
205	tristate "Build VFIO mtty example mediated device sample code"
206	depends on VFIO
207	select VFIO_MDEV
208	help
209	  Build a virtual tty sample driver for use as a VFIO
210	  mediated device
211
212config SAMPLE_VFIO_MDEV_MDPY
213	tristate "Build VFIO mdpy example mediated device sample code"
214	depends on VFIO
215	select VFIO_MDEV
216	help
217	  Build a virtual display sample driver for use as a VFIO
218	  mediated device.  It is a simple framebuffer and supports
219	  the region display interface (VFIO_GFX_PLANE_TYPE_REGION).
220
221config SAMPLE_VFIO_MDEV_MDPY_FB
222	tristate "Build VFIO mdpy example guest fbdev driver"
223	depends on FB
224	select FB_IOMEM_HELPERS
225	help
226	  Guest fbdev driver for the virtual display sample driver.
227
228config SAMPLE_VFIO_MDEV_MBOCHS
229	tristate "Build VFIO mbochs example mediated device sample code"
230	depends on VFIO
231	select VFIO_MDEV
232	select DMA_SHARED_BUFFER
233	help
234	  Build a virtual display sample driver for use as a VFIO
235	  mediated device.  It supports the region display interface
236	  (VFIO_GFX_PLANE_TYPE_DMABUF).
237	  Emulate enough of qemu stdvga to make bochs-drm.ko happy.
238	  That is basically the vram memory bar and the bochs dispi
239	  interface vbe registers in the mmio register bar.
240	  Specifically it does *not* include any legacy vga stuff.
241	  Device looks a lot like "qemu -device secondary-vga".
242
243config SAMPLE_ANDROID_BINDERFS
244	bool "Build Android binderfs example"
245	depends on CC_CAN_LINK && HEADERS_INSTALL
246	help
247	  Builds a sample program to illustrate the use of the Android binderfs
248	  filesystem.
249
250config SAMPLE_VFS
251	bool "Build example programs that use new VFS system calls"
252	depends on CC_CAN_LINK && HEADERS_INSTALL
253	help
254	  Build example userspace programs that use new VFS system calls such
255	  as mount API and statx().  Note that this is restricted to the x86
256	  arch whilst it accesses system calls that aren't yet in all arches.
257
258config SAMPLE_INTEL_MEI
259	bool "Build example program working with intel mei driver"
260	depends on INTEL_MEI
261	depends on CC_CAN_LINK && HEADERS_INSTALL
262	help
263	  Build a sample program to work with mei device.
264
265config SAMPLE_TPS6594_PFSM
266	bool "Build example program working with TPS6594 PFSM driver"
267	depends on HEADERS_INSTALL
268	depends on CC_CAN_LINK
269	help
270	  Build a sample program to work with PFSM devices.
271
272config SAMPLE_WATCHDOG
273	bool "watchdog sample"
274	depends on CC_CAN_LINK
275
276config SAMPLE_WATCH_QUEUE
277	bool "Build example watch_queue notification API consumer"
278	depends on CC_CAN_LINK && HEADERS_INSTALL
279	help
280	  Build example userspace program to use the new mount_notify(),
281	  sb_notify() syscalls and the KEYCTL_WATCH_KEY keyctl() function.
282
283config SAMPLE_CORESIGHT_SYSCFG
284	tristate "Build example loadable module for CoreSight config"
285	depends on CORESIGHT && m
286	help
287	  Build an example loadable module that adds new CoreSight features
288	  and configuration using the CoreSight system configuration API.
289	  This demonstrates how a user may create their own CoreSight
290	  configurations and easily load them into the system at runtime.
291
292config SAMPLE_KMEMLEAK
293        tristate "Simple test for the kernel memory leak detector"
294        depends on DEBUG_KMEMLEAK && m
295        help
296          Build a sample program which have explicitly leaks memory to test
297          kmemleak
298
299config SAMPLE_CGROUP
300	bool "Build cgroup sample code"
301	depends on CGROUPS && CC_CAN_LINK && HEADERS_INSTALL
302	help
303	  Build samples that demonstrate the usage of the cgroup API.
304
305config SAMPLE_CHECK_EXEC
306	bool "Exec secure bits examples"
307	depends on CC_CAN_LINK && HEADERS_INSTALL
308	help
309	  Build a tool to easily configure SECBIT_EXEC_RESTRICT_FILE and
310	  SECBIT_EXEC_DENY_INTERACTIVE, and a simple script interpreter to
311	  demonstrate how they should be used with execveat(2) +
312	  AT_EXECVE_CHECK.
313
314config SAMPLE_HUNG_TASK
315	tristate "Hung task detector test code"
316	depends on DETECT_HUNG_TASK && DEBUG_FS
317	help
318	  Build a module that provides debugfs files (e.g., mutex, semaphore,
319	  etc.) under <debugfs>/hung_task. If user reads one of these files,
320	  it will sleep long time (256 seconds) with holding a lock. Thus,
321	  if 2 or more processes read the same file concurrently, it will
322	  be detected by the hung_task watchdog.
323
324source "samples/rust/Kconfig"
325
326source "samples/damon/Kconfig"
327
328endif # SAMPLES
329
330config HAVE_SAMPLE_FTRACE_DIRECT
331	bool
332
333config HAVE_SAMPLE_FTRACE_DIRECT_MULTI
334	bool
335