xref: /linux/drivers/virtio/Kconfig (revision c8bfe3fad4f86a029da7157bae9699c816f0c309)
1# SPDX-License-Identifier: GPL-2.0-only
2config VIRTIO_ANCHOR
3	bool
4
5config VIRTIO
6	tristate
7	select VIRTIO_ANCHOR
8	help
9	  This option is selected by any driver which implements the virtio
10	  bus, such as CONFIG_VIRTIO_PCI, CONFIG_VIRTIO_MMIO, CONFIG_RPMSG
11	  or CONFIG_S390_GUEST.
12
13config VIRTIO_PCI_LIB
14	tristate
15	help
16	  Modern PCI device implementation. This module implements the
17	  basic probe and control for devices which are based on modern
18	  PCI device with possible vendor specific extensions. Any
19	  module that selects this module must depend on PCI.
20
21config VIRTIO_PCI_LIB_LEGACY
22	tristate
23	help
24	  Legacy PCI device (Virtio PCI Card 0.9.x Draft and older device)
25	  implementation.
26	  This module implements the basic probe and control for devices
27	  which are based on legacy PCI device. Any module that selects this
28	  module must depend on PCI.
29
30menuconfig VIRTIO_MENU
31	bool "Virtio drivers"
32	default y
33
34if VIRTIO_MENU
35
36config VIRTIO_HARDEN_NOTIFICATION
37        bool "Harden virtio notification"
38        depends on BROKEN
39        help
40          Enable this to harden the device notifications and suppress
41          those that happen at a time where notifications are illegal.
42
43          Experimental: Note that several drivers still have issues that
44          may cause crashes or hangs when correct handling of
45          notifications is enforced; depending on the subset of
46          drivers and devices you use, this may or may not work.
47
48          If unsure, say N.
49
50config VIRTIO_PCI
51	tristate "PCI driver for virtio devices"
52	depends on PCI
53	select VIRTIO_PCI_LIB
54	select VIRTIO
55	help
56	  This driver provides support for virtio based paravirtual device
57	  drivers over PCI.  This requires that your VMM has appropriate PCI
58	  virtio backends.  Most QEMU based VMMs should support these devices
59	  (like KVM or Xen).
60
61	  If unsure, say M.
62
63config VIRTIO_PCI_ADMIN_LEGACY
64	bool
65	depends on VIRTIO_PCI && (X86 || COMPILE_TEST)
66	default y
67
68config VIRTIO_PCI_LEGACY
69	bool "Support for legacy virtio draft 0.9.X and older devices"
70	default y
71	depends on VIRTIO_PCI
72	select VIRTIO_PCI_LIB_LEGACY
73	help
74          Virtio PCI Card 0.9.X Draft (circa 2014) and older device support.
75
76	  This option enables building a transitional driver, supporting
77	  both devices conforming to Virtio 1 specification, and legacy devices.
78	  If disabled, you get a slightly smaller, non-transitional driver,
79	  with no legacy compatibility.
80
81          So look out into your driveway.  Do you have a flying car?  If
82          so, you can happily disable this option and virtio will not
83          break.  Otherwise, leave it set.  Unless you're testing what
84          life will be like in The Future.
85
86	  If unsure, say Y.
87
88config VIRTIO_VDPA
89	tristate "vDPA driver for virtio devices"
90	depends on VDPA
91	select VIRTIO
92	help
93	  This driver provides support for virtio based paravirtual
94	  device driver over vDPA bus. For this to be useful, you need
95	  an appropriate vDPA device implementation that operates on a
96	  physical device to allow the datapath of virtio to be
97	  offloaded to hardware.
98
99	  If unsure, say M.
100
101config VIRTIO_PMEM
102	tristate "Support for virtio pmem driver"
103	depends on VIRTIO
104	depends on LIBNVDIMM
105	help
106	  This driver provides access to virtio-pmem devices, storage devices
107	  that are mapped into the physical address space - similar to NVDIMMs
108	   - with a virtio-based flushing interface.
109
110	  If unsure, say Y.
111
112config VIRTIO_BALLOON
113	tristate "Virtio balloon driver"
114	depends on VIRTIO
115	select MEMORY_BALLOON
116	select PAGE_REPORTING
117	help
118	 This driver supports increasing and decreasing the amount
119	 of memory within a KVM guest.
120
121	 If unsure, say M.
122
123config VIRTIO_MEM
124	tristate "Virtio mem driver"
125	depends on X86_64 || ARM64
126	depends on VIRTIO
127	depends on MEMORY_HOTPLUG
128	depends on MEMORY_HOTREMOVE
129	depends on CONTIG_ALLOC
130	depends on EXCLUSIVE_SYSTEM_RAM
131	help
132	 This driver provides access to virtio-mem paravirtualized memory
133	 devices, allowing to hotplug and hotunplug memory.
134
135	 This driver currently only supports x86-64 and arm64. Although it
136	 should compile on other architectures that implement memory
137	 hot(un)plug, architecture-specific and/or common
138	 code changes may be required for virtio-mem, kdump and kexec to work as
139	 expected.
140
141	 If unsure, say M.
142
143config VIRTIO_INPUT
144	tristate "Virtio input driver"
145	depends on VIRTIO
146	depends on INPUT
147	help
148	 This driver supports virtio input devices such as
149	 keyboards, mice and tablets.
150
151	 If unsure, say M.
152
153config VIRTIO_MMIO
154	tristate "Platform bus driver for memory mapped virtio devices"
155	depends on HAS_IOMEM && HAS_DMA
156	select VIRTIO
157	help
158	 This drivers provides support for memory mapped virtio
159	 platform device driver.
160
161 	 If unsure, say N.
162
163config VIRTIO_MMIO_CMDLINE_DEVICES
164	bool "Memory mapped virtio devices parameter parsing"
165	depends on VIRTIO_MMIO
166	help
167	 Allow virtio-mmio devices instantiation via the kernel command line
168	 or module parameters. Be aware that using incorrect parameters (base
169	 address in particular) can crash your system - you have been warned.
170	 See Documentation/admin-guide/kernel-parameters.rst for details.
171
172	 If unsure, say 'N'.
173
174config VIRTIO_DMA_SHARED_BUFFER
175	tristate
176	depends on DMA_SHARED_BUFFER
177	help
178	 This option adds a flavor of dma buffers that are backed by
179	 virtio resources.
180
181endif # VIRTIO_MENU
182