xref: /openbmc/linux/drivers/base/Kconfig (revision e1cf33aa)
1b2441318SGreg Kroah-Hartman# SPDX-License-Identifier: GPL-2.0
21da177e4SLinus Torvaldsmenu "Generic Driver Options"
31da177e4SLinus Torvalds
486d56134SMichael Marineauconfig UEVENT_HELPER
586d56134SMichael Marineau	bool "Support for uevent helper"
66a8d8abbSKay Sievers	help
786d56134SMichael Marineau	  The uevent helper program is forked by the kernel for
86a8d8abbSKay Sievers	  every uevent.
97934779aSKay Sievers	  Before the switch to the netlink-based uevent source, this was
107934779aSKay Sievers	  used to hook hotplug scripts into kernel device events. It
117934779aSKay Sievers	  usually pointed to a shell script at /sbin/hotplug.
127934779aSKay Sievers	  This should not be used today, because usual systems create
137934779aSKay Sievers	  many events at bootup or device discovery in a very short time
147934779aSKay Sievers	  frame. One forked process per event can create so many processes
157934779aSKay Sievers	  that it creates a high system load, or on smaller systems
167934779aSKay Sievers	  it is known to create out-of-memory situations during bootup.
176a8d8abbSKay Sievers
1886d56134SMichael Marineauconfig UEVENT_HELPER_PATH
1986d56134SMichael Marineau	string "path to uevent helper"
2086d56134SMichael Marineau	depends on UEVENT_HELPER
2186d56134SMichael Marineau	default ""
2286d56134SMichael Marineau	help
2386d56134SMichael Marineau	  To disable user space helper program execution at by default
2486d56134SMichael Marineau	  specify an empty string here. This setting can still be altered
25573c9774SMárton Németh	  via /proc/sys/kernel/hotplug or via /sys/kernel/uevent_helper
26573c9774SMárton Németh	  later at runtime.
27573c9774SMárton Németh
282b2af54aSKay Sieversconfig DEVTMPFS
294237e5fdSKay Sievers	bool "Maintain a devtmpfs filesystem to mount at /dev"
302b2af54aSKay Sievers	help
31da5e4ef7SPeter Korsgaard	  This creates a tmpfs/ramfs filesystem instance early at bootup.
324237e5fdSKay Sievers	  In this filesystem, the kernel driver core maintains device
334237e5fdSKay Sievers	  nodes with their default names and permissions for all
344237e5fdSKay Sievers	  registered devices with an assigned major/minor number.
354237e5fdSKay Sievers	  Userspace can modify the filesystem content as needed, add
364237e5fdSKay Sievers	  symlinks, and apply needed permissions.
374237e5fdSKay Sievers	  It provides a fully functional /dev directory, where usually
384237e5fdSKay Sievers	  udev runs on top, managing permissions and adding meaningful
394237e5fdSKay Sievers	  symlinks.
404237e5fdSKay Sievers	  In very limited environments, it may provide a sufficient
414237e5fdSKay Sievers	  functional /dev without any further help. It also allows simple
424237e5fdSKay Sievers	  rescue systems, and reliably handles dynamic major/minor numbers.
432b2af54aSKay Sievers
44da5e4ef7SPeter Korsgaard	  Notice: if CONFIG_TMPFS isn't enabled, the simpler ramfs
45da5e4ef7SPeter Korsgaard	  file system will be used instead.
46da5e4ef7SPeter Korsgaard
472b2af54aSKay Sieversconfig DEVTMPFS_MOUNT
484237e5fdSKay Sievers	bool "Automount devtmpfs at /dev, after the kernel mounted the rootfs"
492b2af54aSKay Sievers	depends on DEVTMPFS
502b2af54aSKay Sievers	help
514237e5fdSKay Sievers	  This will instruct the kernel to automatically mount the
524237e5fdSKay Sievers	  devtmpfs filesystem at /dev, directly after the kernel has
534237e5fdSKay Sievers	  mounted the root filesystem. The behavior can be overridden
544237e5fdSKay Sievers	  with the commandline parameter: devtmpfs.mount=0|1.
554237e5fdSKay Sievers	  This option does not affect initramfs based booting, here
564237e5fdSKay Sievers	  the devtmpfs filesystem always needs to be mounted manually
570feb03afSEmilio López	  after the rootfs is mounted.
584237e5fdSKay Sievers	  With this option enabled, it allows to bring up a system in
594237e5fdSKay Sievers	  rescue mode with init=/bin/sh, even when the /dev directory
604237e5fdSKay Sievers	  on the rootfs is completely empty.
612b2af54aSKay Sievers
621da177e4SLinus Torvaldsconfig STANDALONE
63967857dfSKees Cook	bool "Select only drivers that don't need compile-time external firmware"
641da177e4SLinus Torvalds	default y
651da177e4SLinus Torvalds	help
661da177e4SLinus Torvalds	  Select this option if you don't have magic firmware for drivers that
671da177e4SLinus Torvalds	  need it.
681da177e4SLinus Torvalds
691da177e4SLinus Torvalds	  If unsure, say Y.
701da177e4SLinus Torvalds
711da177e4SLinus Torvaldsconfig PREVENT_FIRMWARE_BUILD
7202c39930SLuis R. Rodriguez	bool "Disable drivers features which enable custom firmware building"
731da177e4SLinus Torvalds	default y
741da177e4SLinus Torvalds	help
7502c39930SLuis R. Rodriguez	  Say yes to disable driver features which enable building a custom
7602c39930SLuis R. Rodriguez	  driver firmware at kernel build time. These drivers do not use the
7702c39930SLuis R. Rodriguez	  kernel firmware API to load firmware (CONFIG_FW_LOADER), instead they
7802c39930SLuis R. Rodriguez	  use their own custom loading mechanism. The required firmware is
7902c39930SLuis R. Rodriguez	  usually shipped with the driver, building the driver firmware
8002c39930SLuis R. Rodriguez	  should only be needed if you have an updated firmware source.
8102c39930SLuis R. Rodriguez
8202c39930SLuis R. Rodriguez	  Firmware should not be being built as part of kernel, these days
8302c39930SLuis R. Rodriguez	  you should always prevent this and say Y here. There are only two
8402c39930SLuis R. Rodriguez	  old drivers which enable building of its firmware at kernel build
8502c39930SLuis R. Rodriguez	  time:
8602c39930SLuis R. Rodriguez
8702c39930SLuis R. Rodriguez	    o CONFIG_WANXL through CONFIG_WANXL_BUILD_FIRMWARE
8802c39930SLuis R. Rodriguez	    o CONFIG_SCSI_AIC79XX through CONFIG_AIC79XX_BUILD_FIRMWARE
8902c39930SLuis R. Rodriguez
9006bfd3c8SLuis R. Rodriguezsource "drivers/base/firmware_loader/Kconfig"
9102c39930SLuis R. Rodriguez
92833c9545SJohannes Bergconfig WANT_DEV_COREDUMP
93833c9545SJohannes Berg	bool
94833c9545SJohannes Berg	help
95833c9545SJohannes Berg	  Drivers should "select" this option if they desire to use the
96833c9545SJohannes Berg	  device coredump mechanism.
97833c9545SJohannes Berg
98cd3d9ea1SJohannes Bergconfig ALLOW_DEV_COREDUMP
99cd3d9ea1SJohannes Berg	bool "Allow device coredump" if EXPERT
1009c602699SAristeu Rozanski	default y
101833c9545SJohannes Berg	help
1029c602699SAristeu Rozanski	  This option controls if the device coredump mechanism is available or
1039c602699SAristeu Rozanski	  not; if disabled, the mechanism will be omitted even if drivers that
1049c602699SAristeu Rozanski	  can use it are enabled.
1059c602699SAristeu Rozanski	  Say 'N' for more sensitive systems or systems that don't want
1069c602699SAristeu Rozanski	  to ever access the information to not have the code, nor keep any
1079c602699SAristeu Rozanski	  data.
108833c9545SJohannes Berg
1099c602699SAristeu Rozanski	  If unsure, say Y.
110833c9545SJohannes Berg
111833c9545SJohannes Bergconfig DEV_COREDUMP
112833c9545SJohannes Berg	bool
113833c9545SJohannes Berg	default y if WANT_DEV_COREDUMP
114cd3d9ea1SJohannes Berg	depends on ALLOW_DEV_COREDUMP
115833c9545SJohannes Berg
1161da177e4SLinus Torvaldsconfig DEBUG_DRIVER
1171da177e4SLinus Torvalds	bool "Driver Core verbose debug messages"
1181da177e4SLinus Torvalds	depends on DEBUG_KERNEL
1191da177e4SLinus Torvalds	help
1201da177e4SLinus Torvalds	  Say Y here if you want the Driver core to produce a bunch of
1211da177e4SLinus Torvalds	  debug messages to the system log. Select this if you are having a
1221da177e4SLinus Torvalds	  problem with the driver core and want to see more of what is
1231da177e4SLinus Torvalds	  going on.
1241da177e4SLinus Torvalds
1251da177e4SLinus Torvalds	  If you are unsure about this, say N here.
1261da177e4SLinus Torvalds
1279ac7849eSTejun Heoconfig DEBUG_DEVRES
1289ac7849eSTejun Heo	bool "Managed device resources verbose debug messages"
1299ac7849eSTejun Heo	depends on DEBUG_KERNEL
1309ac7849eSTejun Heo	help
1319ac7849eSTejun Heo	  This option enables kernel parameter devres.log. If set to
1329ac7849eSTejun Heo	  non-zero, devres debug messages are printed. Select this if
1339ac7849eSTejun Heo	  you are having a problem with devres or want to debug
1349ac7849eSTejun Heo	  resource management for a managed device. devres.log can be
1359ac7849eSTejun Heo	  switched on and off from sysfs node.
1369ac7849eSTejun Heo
1379ac7849eSTejun Heo	  If you are unsure about this, Say N here.
1389ac7849eSTejun Heo
139bea5b158SRob Herringconfig DEBUG_TEST_DRIVER_REMOVE
140248ff021SLaura Abbott	bool "Test driver remove calls during probe (UNSTABLE)"
141bea5b158SRob Herring	depends on DEBUG_KERNEL
142bea5b158SRob Herring	help
143bea5b158SRob Herring	  Say Y here if you want the Driver core to test driver remove functions
144bea5b158SRob Herring	  by calling probe, remove, probe. This tests the remove path without
145bea5b158SRob Herring	  having to unbind the driver or unload the driver module.
146bea5b158SRob Herring
147248ff021SLaura Abbott	  This option is expected to find errors and may render your system
148248ff021SLaura Abbott	  unusable. You should say N here unless you are explicitly looking to
149248ff021SLaura Abbott	  test this functionality.
150bea5b158SRob Herring
151*e1cf33aaSKeith Buschconfig HMEM_REPORTING
152*e1cf33aaSKeith Busch	bool
153*e1cf33aaSKeith Busch	default n
154*e1cf33aaSKeith Busch	depends on NUMA
155*e1cf33aaSKeith Busch	help
156*e1cf33aaSKeith Busch	  Enable reporting for heterogenous memory access attributes under
157*e1cf33aaSKeith Busch	  their non-uniform memory nodes.
158*e1cf33aaSKeith Busch
15979543cf2SDmitry Torokhovsource "drivers/base/test/Kconfig"
16079543cf2SDmitry Torokhov
1614039483fSMichael Holzheuconfig SYS_HYPERVISOR
1624039483fSMichael Holzheu	bool
1634039483fSMichael Holzheu	default n
164eba6cd67SRandy Dunlap
1659f13a1fdSBen Hutchingsconfig GENERIC_CPU_DEVICES
1669f13a1fdSBen Hutchings	bool
1679f13a1fdSBen Hutchings	default n
1689f13a1fdSBen Hutchings
16967bad2fdSArd Biesheuvelconfig GENERIC_CPU_AUTOPROBE
17067bad2fdSArd Biesheuvel	bool
17167bad2fdSArd Biesheuvel
17287590ce6SThomas Gleixnerconfig GENERIC_CPU_VULNERABILITIES
17387590ce6SThomas Gleixner	bool
17487590ce6SThomas Gleixner
17574d1d82cSLee Jonesconfig SOC_BUS
17674d1d82cSLee Jones	bool
177c97db7ccSArnd Bergmann	select GLOB
17874d1d82cSLee Jones
179b83a313bSMark Brownsource "drivers/base/regmap/Kconfig"
180b83a313bSMark Brown
181d15bd7eeSSumit Semwalconfig DMA_SHARED_BUFFER
1823b32a592SDave Airlie	bool
183d15bd7eeSSumit Semwal	default n
184d15bd7eeSSumit Semwal	select ANON_INODES
18503e4e0a9SChris Wilson	select IRQ_WORK
186d15bd7eeSSumit Semwal	help
187d15bd7eeSSumit Semwal	  This option enables the framework for buffer-sharing between
188d15bd7eeSSumit Semwal	  multiple drivers. A buffer is associated with a file using driver
189d15bd7eeSSumit Semwal	  APIs extension; the file's descriptor can then be passed on to other
190d15bd7eeSSumit Semwal	  driver.
191d15bd7eeSSumit Semwal
192f54d1867SChris Wilsonconfig DMA_FENCE_TRACE
193f54d1867SChris Wilson	bool "Enable verbose DMA_FENCE_TRACE messages"
194e941759cSMaarten Lankhorst	depends on DMA_SHARED_BUFFER
195e941759cSMaarten Lankhorst	help
196f54d1867SChris Wilson	  Enable the DMA_FENCE_TRACE printks. This will add extra
197e941759cSMaarten Lankhorst	  spam to the console log, but will make it easier to diagnose
198e941759cSMaarten Lankhorst	  lockup related problems for dma-buffers shared across multiple
199e941759cSMaarten Lankhorst	  devices.
200e941759cSMaarten Lankhorst
2012ef7a295SJuri Lelliconfig GENERIC_ARCH_TOPOLOGY
2022ef7a295SJuri Lelli	bool
2032ef7a295SJuri Lelli	help
2042ef7a295SJuri Lelli	  Enable support for architectures common topology code: e.g., parsing
2052ef7a295SJuri Lelli	  CPU capacity information from DT, usage of such information for
2062ef7a295SJuri Lelli	  appropriate scaling, sysfs interface for changing capacity values at
2072ef7a295SJuri Lelli	  runtime.
2082ef7a295SJuri Lelli
209eba6cd67SRandy Dunlapendmenu
210