blob: 22cc921ae291323389f4b5af3cf3cbd9881d9fff [file] [log] [blame]
Thomas Gleixnerec8f24b2019-05-19 13:07:45 +01001# SPDX-License-Identifier: GPL-2.0-only
Mathieu Desnoyers267c4022007-10-18 23:41:07 -07002menuconfig SAMPLES
3 bool "Sample kernel code"
4 help
5 You can build and test sample kernel code here.
6
7if SAMPLES
8
Masahiro Yamada87ffbba2020-04-29 12:45:25 +09009config SAMPLE_AUXDISPLAY
10 bool "auxdisplay sample"
11 depends on CC_CAN_LINK
12
Steven Rostedt9cfe06f2009-04-14 21:37:03 -040013config SAMPLE_TRACE_EVENTS
Li Zefan96d17982009-05-06 10:32:32 +080014 tristate "Build trace_events examples -- loadable modules only"
15 depends on EVENT_TRACING && m
Steven Rostedt9cfe06f2009-04-14 21:37:03 -040016 help
17 This build trace event example modules.
18
Steven Rostedt (Red Hat)aad108a2016-06-17 14:50:23 -040019config SAMPLE_TRACE_PRINTK
20 tristate "Build trace_printk module - tests various trace_printk formats"
21 depends on EVENT_TRACING && m
22 help
23 This builds a module that calls trace_printk() and can be used to
24 test various trace_printk() calls from a module.
25
Steven Rostedt (VMware)b06457c2019-11-08 13:12:33 -050026config SAMPLE_FTRACE_DIRECT
27 tristate "Build register_ftrace_direct() example"
28 depends on DYNAMIC_FTRACE_WITH_DIRECT_CALLS && m
Heiko Carstensc316eb42021-10-12 15:38:01 +020029 depends on HAVE_SAMPLE_FTRACE_DIRECT
Steven Rostedt (VMware)b06457c2019-11-08 13:12:33 -050030 help
31 This builds an ftrace direct function example
32 that hooks to wake_up_process and prints the parameters.
33
Heiko Carstens503e4512021-11-15 20:56:13 +010034config SAMPLE_FTRACE_DIRECT_MULTI
35 tristate "Build register_ftrace_direct_multi() example"
36 depends on DYNAMIC_FTRACE_WITH_DIRECT_CALLS && m
37 depends on HAVE_SAMPLE_FTRACE_DIRECT_MULTI
38 help
39 This builds an ftrace direct function example
40 that hooks to wake_up_process and schedule, and prints
41 the function addresses.
42
Divya Indi89ed4242019-11-20 11:08:39 -080043config SAMPLE_TRACE_ARRAY
44 tristate "Build sample module for kernel access to Ftrace instancess"
45 depends on EVENT_TRACING && m
46 help
47 This builds a module that demonstrates the use of various APIs to
48 access Ftrace instances from within the kernel.
49
Greg Kroah-Hartman40efcb02007-11-27 11:28:26 -080050config SAMPLE_KOBJECT
Masahiro Yamadae7e34912019-04-27 12:33:40 +090051 tristate "Build kobject examples"
Greg Kroah-Hartman40efcb02007-11-27 11:28:26 -080052 help
53 This config option will allow you to build a number of
54 different kobject sample modules showing how to use kobjects,
55 ksets, and ktypes properly.
56
57 If in doubt, say "N" here.
58
Ananth N Mavinakayanahalli804defe2008-03-04 14:28:38 -080059config SAMPLE_KPROBES
60 tristate "Build kprobes examples -- loadable modules only"
61 depends on KPROBES && m
62 help
63 This build several kprobes example modules.
64
65config SAMPLE_KRETPROBES
66 tristate "Build kretprobes example -- loadable modules only"
67 default m
68 depends on SAMPLE_KPROBES && KRETPROBES
69
K.Prasad43203992009-06-01 23:46:20 +053070config SAMPLE_HW_BREAKPOINT
71 tristate "Build kernel hardware breakpoint examples -- loadable module only"
72 depends on HAVE_HW_BREAKPOINT && m
73 help
74 This builds kernel hardware breakpoint example modules.
75
Stefani Seibold5bf2b192010-08-10 18:03:39 -070076config SAMPLE_KFIFO
77 tristate "Build kfifo examples -- loadable modules only"
78 depends on m
79 help
80 This config option will allow you to build a number of
81 different kfifo sample modules showing how to use the
82 generic kfifo API.
83
84 If in doubt, say "N" here.
85
Jason Wessel4aad8f52010-10-25 10:14:05 -050086config SAMPLE_KDB
Lucas De Marchi25985ed2011-03-30 22:57:33 -030087 tristate "Build kdb command example -- loadable modules only"
Jason Wessel4aad8f52010-10-25 10:14:05 -050088 depends on KGDB_KDB && m
89 help
90 Build an example of how to dynamically add the hello
91 command to the kdb shell.
92
Bjorn Andersson842891b2017-06-26 09:02:28 -070093config SAMPLE_QMI_CLIENT
94 tristate "Build qmi client sample -- loadable modules only"
95 depends on m
96 depends on ARCH_QCOM
Arnd Bergmanndea4bd12018-02-22 16:57:38 +010097 depends on NET
Bjorn Andersson842891b2017-06-26 09:02:28 -070098 select QCOM_QMI_HELPERS
99 help
100 Build an QMI client sample driver, which demonstrates how to
101 communicate with a remote QRTR service, using QMI encoded messages.
102
Ohad Ben-Cohen779b96d2011-10-20 21:41:24 +0200103config SAMPLE_RPMSG_CLIENT
104 tristate "Build rpmsg client sample -- loadable modules only"
105 depends on RPMSG && m
106 help
107 Build an rpmsg client sample driver, which demonstrates how
108 to communicate with an AMP-configured remote processor over
109 the rpmsg bus.
110
Josh Poimboeuf12cf89b2015-02-03 16:45:18 -0600111config SAMPLE_LIVEPATCH
Joe Lawrence439e7272017-08-31 16:37:41 -0400112 tristate "Build live patching samples -- loadable modules only"
Josh Poimboeuf12cf89b2015-02-03 16:45:18 -0600113 depends on LIVEPATCH && m
Seth Jennings13d1cf72014-12-16 11:58:20 -0600114 help
Joe Lawrence439e7272017-08-31 16:37:41 -0400115 Build sample live patch demonstrations.
Seth Jennings13d1cf72014-12-16 11:58:20 -0600116
Christoph Hellwig51798222015-10-03 15:32:59 +0200117config SAMPLE_CONFIGFS
118 tristate "Build configfs patching sample -- loadable modules only"
119 depends on CONFIGFS_FS && m
120 help
121 Builds a sample configfs interface.
122
Arnd Bergmann14fbff62016-04-25 18:03:08 +0200123config SAMPLE_CONNECTOR
124 tristate "Build connector sample -- loadable modules only"
Masahiro Yamadae949f4c2019-06-04 19:13:59 +0900125 depends on CONNECTOR && HEADERS_INSTALL && m
Arnd Bergmann14fbff62016-04-25 18:03:08 +0200126 help
127 When enabled, this builds both a sample kernel module for
128 the connector interface and a user space tool to communicate
129 with it.
Mauro Carvalho Chehabbaa293e2019-06-27 15:39:22 -0300130 See also Documentation/driver-api/connector.rst
Arnd Bergmann14fbff62016-04-25 18:03:08 +0200131
Gabriel Krisman Bertazi54510932021-10-25 16:27:45 -0300132config SAMPLE_FANOTIFY_ERROR
133 bool "Build fanotify error monitoring sample"
Gabriel Krisman Bertazi8fc70b32021-10-28 15:56:28 -0300134 depends on FANOTIFY && CC_CAN_LINK && HEADERS_INSTALL
Gabriel Krisman Bertazi54510932021-10-25 16:27:45 -0300135 help
136 When enabled, this builds an example code that uses the
137 FAN_FS_ERROR fanotify mechanism to monitor filesystem
138 errors.
139 See also Documentation/admin-guide/filesystem-monitoring.rst.
140
Masahiro Yamadae949f4c2019-06-04 19:13:59 +0900141config SAMPLE_HIDRAW
142 bool "hidraw sample"
Masahiro Yamada82d00a92020-04-29 12:45:20 +0900143 depends on CC_CAN_LINK && HEADERS_INSTALL
Masahiro Yamadae949f4c2019-06-04 19:13:59 +0900144
Mickaël Salaünba84b0b2021-04-22 17:41:21 +0200145config SAMPLE_LANDLOCK
146 bool "Landlock example"
147 depends on CC_CAN_LINK && HEADERS_INSTALL
148 help
149 Build a simple Landlock sandbox manager able to start a process
150 restricted by a user-defined filesystem access control policy.
151
Masahiro Yamadae949f4c2019-06-04 19:13:59 +0900152config SAMPLE_PIDFD
153 bool "pidfd sample"
Masahiro Yamada60fb0b12020-04-29 12:45:23 +0900154 depends on CC_CAN_LINK && HEADERS_INSTALL
Masahiro Yamadae949f4c2019-06-04 19:13:59 +0900155
Olof Johanssonf6041c12016-07-05 23:53:19 -0700156config SAMPLE_SECCOMP
Masahiro Yamada7206c122019-04-27 12:33:39 +0900157 bool "Build seccomp sample code"
Masahiro Yamadaf59e7662020-04-29 12:45:16 +0900158 depends on SECCOMP_FILTER && CC_CAN_LINK && HEADERS_INSTALL
Olof Johanssonf6041c12016-07-05 23:53:19 -0700159 help
160 Build samples of seccomp filters using various methods of
161 BPF filter construction.
162
Masahiro Yamadab98ccc72020-04-29 12:45:26 +0900163config SAMPLE_TIMER
164 bool "Timer sample"
165 depends on CC_CAN_LINK && HEADERS_INSTALL
166
Masahiro Yamada87ecdf42020-04-29 12:45:19 +0900167config SAMPLE_UHID
168 bool "UHID sample"
169 depends on CC_CAN_LINK && HEADERS_INSTALL
170 help
171 Build UHID sample program.
172
Alex Williamson08c1a4e2016-12-30 08:13:30 -0700173config SAMPLE_VFIO_MDEV_MTTY
174 tristate "Build VFIO mtty example mediated device sample code -- loadable modules only"
Jason Gunthorpeaf3ab3f2021-06-17 16:22:14 +0200175 depends on VFIO_MDEV && m
Alex Williamson08c1a4e2016-12-30 08:13:30 -0700176 help
177 Build a virtual tty sample driver for use as a VFIO
178 mediated device
179
Gerd Hoffmannd61fc96f2018-05-11 09:05:03 -0600180config SAMPLE_VFIO_MDEV_MDPY
181 tristate "Build VFIO mdpy example mediated device sample code -- loadable modules only"
Jason Gunthorpeaf3ab3f2021-06-17 16:22:14 +0200182 depends on VFIO_MDEV && m
Gerd Hoffmannd61fc96f2018-05-11 09:05:03 -0600183 help
184 Build a virtual display sample driver for use as a VFIO
185 mediated device. It is a simple framebuffer and supports
186 the region display interface (VFIO_GFX_PLANE_TYPE_REGION).
187
Gerd Hoffmanncacade12018-05-11 09:05:04 -0600188config SAMPLE_VFIO_MDEV_MDPY_FB
189 tristate "Build VFIO mdpy example guest fbdev driver -- loadable module only"
190 depends on FB && m
191 select FB_CFB_FILLRECT
192 select FB_CFB_COPYAREA
193 select FB_CFB_IMAGEBLIT
194 help
195 Guest fbdev driver for the virtual display sample driver.
196
Gerd Hoffmanna5e6e652018-05-11 09:05:04 -0600197config SAMPLE_VFIO_MDEV_MBOCHS
198 tristate "Build VFIO mdpy example mediated device sample code -- loadable modules only"
Jason Gunthorpeaf3ab3f2021-06-17 16:22:14 +0200199 depends on VFIO_MDEV && m
Arnd Bergmannc1abca92018-05-30 23:37:31 +0200200 select DMA_SHARED_BUFFER
Gerd Hoffmanna5e6e652018-05-11 09:05:04 -0600201 help
202 Build a virtual display sample driver for use as a VFIO
203 mediated device. It supports the region display interface
204 (VFIO_GFX_PLANE_TYPE_DMABUF).
205 Emulate enough of qemu stdvga to make bochs-drm.ko happy.
206 That is basically the vram memory bar and the bochs dispi
207 interface vbe registers in the mmio register bar.
208 Specifically it does *not* include any legacy vga stuff.
209 Device looks a lot like "qemu -device secondary-vga".
210
Christian Brauner9762dc12019-01-11 14:41:00 +0100211config SAMPLE_ANDROID_BINDERFS
212 bool "Build Android binderfs example"
Masahiro Yamadafca5e942020-06-07 12:20:53 +0900213 depends on CC_CAN_LINK && HEADERS_INSTALL
Christian Brauner9762dc12019-01-11 14:41:00 +0100214 help
215 Builds a sample program to illustrate the use of the Android binderfs
216 filesystem.
217
David Howellsf1b56182018-11-01 23:36:32 +0000218config SAMPLE_VFS
219 bool "Build example programs that use new VFS system calls"
Masahiro Yamada28949b82020-04-29 12:45:22 +0900220 depends on CC_CAN_LINK && HEADERS_INSTALL
David Howellsa528d352017-01-31 16:46:22 +0000221 help
David Howellsf1b56182018-11-01 23:36:32 +0000222 Build example userspace programs that use new VFS system calls such
223 as mount API and statx(). Note that this is restricted to the x86
224 arch whilst it accesses system calls that aren't yet in all arches.
David Howellsa528d352017-01-31 16:46:22 +0000225
Tomas Winkler6859eba2019-10-10 16:27:10 +0300226config SAMPLE_INTEL_MEI
227 bool "Build example program working with intel mei driver"
228 depends on INTEL_MEI
Masahiro Yamadac4c10992020-04-29 12:45:24 +0900229 depends on CC_CAN_LINK && HEADERS_INSTALL
Tomas Winkler6859eba2019-10-10 16:27:10 +0300230 help
231 Build a sample program to work with mei device.
232
Masahiro Yamada88a8e272020-04-29 12:45:27 +0900233config SAMPLE_WATCHDOG
234 bool "watchdog sample"
235 depends on CC_CAN_LINK
Tomas Winkler6859eba2019-10-10 16:27:10 +0300236
David Howellsf5b5a162020-01-14 17:07:11 +0000237config SAMPLE_WATCH_QUEUE
Gabriel Krisman Bertazi8fe62e02020-11-24 15:28:02 -0500238 bool "Build example watch_queue notification API consumer"
Masahiro Yamada214377e2020-06-17 11:08:38 +0900239 depends on CC_CAN_LINK && HEADERS_INSTALL
David Howellsf5b5a162020-01-14 17:07:11 +0000240 help
241 Build example userspace program to use the new mount_notify(),
242 sb_notify() syscalls and the KEYCTL_WATCH_KEY keyctl() function.
Mathieu Desnoyers267c4022007-10-18 23:41:07 -0700243
Mike Leachede5bab2021-11-24 20:00:36 +0000244config SAMPLE_CORESIGHT_SYSCFG
245 tristate "Build example loadable module for CoreSight config"
246 depends on CORESIGHT && m
247 help
248 Build an example loadable module that adds new CoreSight features
249 and configuration using the CoreSight system configuration API.
250 This demonstrates how a user may create their own CoreSight
251 configurations and easily load them into the system at runtime.
252
Mathieu Desnoyers267c4022007-10-18 23:41:07 -0700253endif # SAMPLES
Heiko Carstensc316eb42021-10-12 15:38:01 +0200254
255config HAVE_SAMPLE_FTRACE_DIRECT
256 bool
Linus Torvalds0b707e52021-11-06 14:48:06 -0700257
Heiko Carstens503e4512021-11-15 20:56:13 +0100258config HAVE_SAMPLE_FTRACE_DIRECT_MULTI
Linus Torvalds0b707e52021-11-06 14:48:06 -0700259 bool