Commit | Line | Data |
---|---|---|
b2441318 | 1 | # SPDX-License-Identifier: GPL-2.0 |
1da177e4 LT |
2 | menu "Generic Driver Options" |
3 | ||
86d56134 MM |
4 | config UEVENT_HELPER |
5 | bool "Support for uevent helper" | |
6a8d8abb | 6 | help |
86d56134 | 7 | The uevent helper program is forked by the kernel for |
6a8d8abb | 8 | every uevent. |
7934779a KS |
9 | Before the switch to the netlink-based uevent source, this was |
10 | used to hook hotplug scripts into kernel device events. It | |
11 | usually pointed to a shell script at /sbin/hotplug. | |
12 | This should not be used today, because usual systems create | |
13 | many events at bootup or device discovery in a very short time | |
14 | frame. One forked process per event can create so many processes | |
15 | that it creates a high system load, or on smaller systems | |
16 | it is known to create out-of-memory situations during bootup. | |
6a8d8abb | 17 | |
86d56134 MM |
18 | config UEVENT_HELPER_PATH |
19 | string "path to uevent helper" | |
20 | depends on UEVENT_HELPER | |
21 | default "" | |
22 | help | |
23 | To disable user space helper program execution at by default | |
24 | specify an empty string here. This setting can still be altered | |
573c9774 MN |
25 | via /proc/sys/kernel/hotplug or via /sys/kernel/uevent_helper |
26 | later at runtime. | |
27 | ||
2b2af54a | 28 | config DEVTMPFS |
4237e5fd | 29 | bool "Maintain a devtmpfs filesystem to mount at /dev" |
2b2af54a | 30 | help |
da5e4ef7 | 31 | This creates a tmpfs/ramfs filesystem instance early at bootup. |
4237e5fd KS |
32 | In this filesystem, the kernel driver core maintains device |
33 | nodes with their default names and permissions for all | |
34 | registered devices with an assigned major/minor number. | |
35 | Userspace can modify the filesystem content as needed, add | |
36 | symlinks, and apply needed permissions. | |
37 | It provides a fully functional /dev directory, where usually | |
38 | udev runs on top, managing permissions and adding meaningful | |
39 | symlinks. | |
40 | In very limited environments, it may provide a sufficient | |
41 | functional /dev without any further help. It also allows simple | |
42 | rescue systems, and reliably handles dynamic major/minor numbers. | |
2b2af54a | 43 | |
da5e4ef7 PK |
44 | Notice: if CONFIG_TMPFS isn't enabled, the simpler ramfs |
45 | file system will be used instead. | |
46 | ||
2b2af54a | 47 | config DEVTMPFS_MOUNT |
4237e5fd | 48 | bool "Automount devtmpfs at /dev, after the kernel mounted the rootfs" |
2b2af54a KS |
49 | depends on DEVTMPFS |
50 | help | |
4237e5fd KS |
51 | This will instruct the kernel to automatically mount the |
52 | devtmpfs filesystem at /dev, directly after the kernel has | |
53 | mounted the root filesystem. The behavior can be overridden | |
54 | with the commandline parameter: devtmpfs.mount=0|1. | |
55 | This option does not affect initramfs based booting, here | |
56 | the devtmpfs filesystem always needs to be mounted manually | |
0feb03af | 57 | after the rootfs is mounted. |
4237e5fd KS |
58 | With this option enabled, it allows to bring up a system in |
59 | rescue mode with init=/bin/sh, even when the /dev directory | |
60 | on the rootfs is completely empty. | |
2b2af54a | 61 | |
1da177e4 | 62 | config STANDALONE |
967857df | 63 | bool "Select only drivers that don't need compile-time external firmware" |
1da177e4 LT |
64 | default y |
65 | help | |
66 | Select this option if you don't have magic firmware for drivers that | |
67 | need it. | |
68 | ||
69 | If unsure, say Y. | |
70 | ||
71 | config PREVENT_FIRMWARE_BUILD | |
02c39930 | 72 | bool "Disable drivers features which enable custom firmware building" |
1da177e4 LT |
73 | default y |
74 | help | |
02c39930 LR |
75 | Say yes to disable driver features which enable building a custom |
76 | driver firmware at kernel build time. These drivers do not use the | |
77 | kernel firmware API to load firmware (CONFIG_FW_LOADER), instead they | |
78 | use their own custom loading mechanism. The required firmware is | |
79 | usually shipped with the driver, building the driver firmware | |
80 | should only be needed if you have an updated firmware source. | |
81 | ||
82 | Firmware should not be being built as part of kernel, these days | |
83 | you should always prevent this and say Y here. There are only two | |
84 | old drivers which enable building of its firmware at kernel build | |
85 | time: | |
86 | ||
87 | o CONFIG_WANXL through CONFIG_WANXL_BUILD_FIRMWARE | |
88 | o CONFIG_SCSI_AIC79XX through CONFIG_AIC79XX_BUILD_FIRMWARE | |
89 | ||
06bfd3c8 | 90 | source "drivers/base/firmware_loader/Kconfig" |
02c39930 | 91 | |
833c9545 JB |
92 | config WANT_DEV_COREDUMP |
93 | bool | |
94 | help | |
95 | Drivers should "select" this option if they desire to use the | |
96 | device coredump mechanism. | |
97 | ||
cd3d9ea1 JB |
98 | config ALLOW_DEV_COREDUMP |
99 | bool "Allow device coredump" if EXPERT | |
9c602699 | 100 | default y |
833c9545 | 101 | help |
9c602699 AR |
102 | This option controls if the device coredump mechanism is available or |
103 | not; if disabled, the mechanism will be omitted even if drivers that | |
104 | can use it are enabled. | |
105 | Say 'N' for more sensitive systems or systems that don't want | |
106 | to ever access the information to not have the code, nor keep any | |
107 | data. | |
833c9545 | 108 | |
9c602699 | 109 | If unsure, say Y. |
833c9545 JB |
110 | |
111 | config DEV_COREDUMP | |
112 | bool | |
113 | default y if WANT_DEV_COREDUMP | |
cd3d9ea1 | 114 | depends on ALLOW_DEV_COREDUMP |
833c9545 | 115 | |
1da177e4 LT |
116 | config DEBUG_DRIVER |
117 | bool "Driver Core verbose debug messages" | |
118 | depends on DEBUG_KERNEL | |
119 | help | |
120 | Say Y here if you want the Driver core to produce a bunch of | |
121 | debug messages to the system log. Select this if you are having a | |
122 | problem with the driver core and want to see more of what is | |
123 | going on. | |
124 | ||
125 | If you are unsure about this, say N here. | |
126 | ||
9ac7849e TH |
127 | config DEBUG_DEVRES |
128 | bool "Managed device resources verbose debug messages" | |
129 | depends on DEBUG_KERNEL | |
130 | help | |
131 | This option enables kernel parameter devres.log. If set to | |
132 | non-zero, devres debug messages are printed. Select this if | |
133 | you are having a problem with devres or want to debug | |
134 | resource management for a managed device. devres.log can be | |
135 | switched on and off from sysfs node. | |
136 | ||
137 | If you are unsure about this, Say N here. | |
138 | ||
bea5b158 | 139 | config DEBUG_TEST_DRIVER_REMOVE |
248ff021 | 140 | bool "Test driver remove calls during probe (UNSTABLE)" |
bea5b158 RH |
141 | depends on DEBUG_KERNEL |
142 | help | |
143 | Say Y here if you want the Driver core to test driver remove functions | |
144 | by calling probe, remove, probe. This tests the remove path without | |
145 | having to unbind the driver or unload the driver module. | |
146 | ||
248ff021 LA |
147 | This option is expected to find errors and may render your system |
148 | unusable. You should say N here unless you are explicitly looking to | |
149 | test this functionality. | |
bea5b158 | 150 | |
14e08757 LC |
151 | config PM_QOS_KUNIT_TEST |
152 | bool "KUnit Test for PM QoS features" | |
35c57fc3 | 153 | depends on KUNIT=y |
14e08757 | 154 | |
e1cf33aa KB |
155 | config HMEM_REPORTING |
156 | bool | |
157 | default n | |
158 | depends on NUMA | |
159 | help | |
160 | Enable reporting for heterogenous memory access attributes under | |
161 | their non-uniform memory nodes. | |
162 | ||
79543cf2 DT |
163 | source "drivers/base/test/Kconfig" |
164 | ||
4039483f MH |
165 | config SYS_HYPERVISOR |
166 | bool | |
167 | default n | |
eba6cd67 | 168 | |
9f13a1fd BH |
169 | config GENERIC_CPU_DEVICES |
170 | bool | |
171 | default n | |
172 | ||
67bad2fd AB |
173 | config GENERIC_CPU_AUTOPROBE |
174 | bool | |
67bad2fd | 175 | |
87590ce6 TG |
176 | config GENERIC_CPU_VULNERABILITIES |
177 | bool | |
178 | ||
74d1d82c LJ |
179 | config SOC_BUS |
180 | bool | |
c97db7cc | 181 | select GLOB |
74d1d82c | 182 | |
b83a313b MB |
183 | source "drivers/base/regmap/Kconfig" |
184 | ||
d15bd7ee | 185 | config DMA_SHARED_BUFFER |
3b32a592 | 186 | bool |
d15bd7ee | 187 | default n |
03e4e0a9 | 188 | select IRQ_WORK |
d15bd7ee SS |
189 | help |
190 | This option enables the framework for buffer-sharing between | |
191 | multiple drivers. A buffer is associated with a file using driver | |
192 | APIs extension; the file's descriptor can then be passed on to other | |
193 | driver. | |
194 | ||
f54d1867 CW |
195 | config DMA_FENCE_TRACE |
196 | bool "Enable verbose DMA_FENCE_TRACE messages" | |
e941759c ML |
197 | depends on DMA_SHARED_BUFFER |
198 | help | |
f54d1867 | 199 | Enable the DMA_FENCE_TRACE printks. This will add extra |
e941759c ML |
200 | spam to the console log, but will make it easier to diagnose |
201 | lockup related problems for dma-buffers shared across multiple | |
202 | devices. | |
203 | ||
2ef7a295 JL |
204 | config GENERIC_ARCH_TOPOLOGY |
205 | bool | |
206 | help | |
207 | Enable support for architectures common topology code: e.g., parsing | |
208 | CPU capacity information from DT, usage of such information for | |
c181831f | 209 | appropriate scaling, sysfs interface for reading capacity values at |
2ef7a295 JL |
210 | runtime. |
211 | ||
eba6cd67 | 212 | endmenu |