• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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_BALLOON_HYP_OPS
124	def_bool y
125	depends on VIRTIO_BALLOON
126	depends on ARCH_HAS_VIRTIO_BALLOON_HYP_OPS
127
128config VIRTIO_MEM
129	tristate "Virtio mem driver"
130	depends on X86_64 || ARM64 || RISCV
131	depends on VIRTIO
132	depends on MEMORY_HOTPLUG
133	depends on MEMORY_HOTREMOVE
134	depends on CONTIG_ALLOC
135	depends on EXCLUSIVE_SYSTEM_RAM
136	help
137	 This driver provides access to virtio-mem paravirtualized memory
138	 devices, allowing to hotplug and hotunplug memory.
139
140	 This driver currently only supports x86-64 and arm64. Although it
141	 should compile on other architectures that implement memory
142	 hot(un)plug, architecture-specific and/or common
143	 code changes may be required for virtio-mem, kdump and kexec to work as
144	 expected.
145
146	 If unsure, say M.
147
148config VIRTIO_INPUT
149	tristate "Virtio input driver"
150	depends on VIRTIO
151	depends on INPUT
152	help
153	 This driver supports virtio input devices such as
154	 keyboards, mice and tablets.
155
156	 If unsure, say M.
157
158config VIRTIO_MMIO
159	tristate "Platform bus driver for memory mapped virtio devices"
160	depends on HAS_IOMEM && HAS_DMA
161	select VIRTIO
162	help
163	 This drivers provides support for memory mapped virtio
164	 platform device driver.
165
166 	 If unsure, say N.
167
168config VIRTIO_MMIO_CMDLINE_DEVICES
169	bool "Memory mapped virtio devices parameter parsing"
170	depends on VIRTIO_MMIO
171	help
172	 Allow virtio-mmio devices instantiation via the kernel command line
173	 or module parameters. Be aware that using incorrect parameters (base
174	 address in particular) can crash your system - you have been warned.
175	 See Documentation/admin-guide/kernel-parameters.rst for details.
176
177	 If unsure, say 'N'.
178
179config VIRTIO_DMA_SHARED_BUFFER
180	tristate "Virtio DMA shared buffer support"
181	depends on DMA_SHARED_BUFFER
182	help
183	 This option adds a flavor of dma buffers that are backed by
184	 virtio resources.
185
186config VIRTIO_DEBUG
187	bool "Debug facilities"
188	depends on VIRTIO
189	help
190	  Enable this to expose debug facilities over debugfs.
191	  This allows to debug features, to see what features the device
192	  advertises and to set filter for features used by driver.
193
194	  If unsure, say N.
195
196endif # VIRTIO_MENU
197