xref: /openbmc/linux/drivers/gpu/drm/Kconfig (revision 0547dece8dcbb80983b3c37ad20ceca76a1f06a5)
1# SPDX-License-Identifier: GPL-2.0-only
2#
3# Drm device configuration
4#
5# This driver provides support for the
6# Direct Rendering Infrastructure (DRI) in XFree86 4.1.0 and higher.
7#
8menuconfig DRM
9	tristate "Direct Rendering Manager (XFree86 4.1.0 and higher DRI support)"
10	depends on (AGP || AGP=n) && !EMULATED_CMPXCHG && HAS_DMA
11	select DRM_PANEL_ORIENTATION_QUIRKS
12	select HDMI
13	select FB_CMDLINE
14	select I2C
15	select I2C_ALGOBIT
16	select DMA_SHARED_BUFFER
17	select SYNC_FILE
18	help
19	  Kernel-level support for the Direct Rendering Infrastructure (DRI)
20	  introduced in XFree86 4.0. If you say Y here, you need to select
21	  the module that's right for your graphics card from the list below.
22	  These modules provide support for synchronization, security, and
23	  DMA transfers. Please see <http://dri.sourceforge.net/> for more
24	  details.  You should also select and configure AGP
25	  (/dev/agpgart) support if it is available for your platform.
26
27config DRM_MIPI_DBI
28	tristate
29	depends on DRM
30
31config DRM_MIPI_DSI
32	bool
33	depends on DRM
34
35config DRM_DP_AUX_CHARDEV
36	bool "DRM DP AUX Interface"
37	depends on DRM
38	help
39	  Choose this option to enable a /dev/drm_dp_auxN node that allows to
40	  read and write values to arbitrary DPCD registers on the DP aux
41	  channel.
42
43config DRM_DEBUG_MM
44	bool "Insert extra checks and debug info into the DRM range managers"
45	default n
46	depends on DRM=y
47	depends on STACKTRACE_SUPPORT
48	select STACKDEPOT
49	help
50	  Enable allocation tracking of memory manager and leak detection on
51	  shutdown.
52
53	  Recommended for driver developers only.
54
55	  If in doubt, say "N".
56
57config DRM_DEBUG_SELFTEST
58	tristate "kselftests for DRM"
59	depends on DRM
60	depends on DEBUG_KERNEL
61	select PRIME_NUMBERS
62	select DRM_LIB_RANDOM
63	select DRM_KMS_HELPER
64	select DRM_EXPORT_FOR_TESTS if m
65	default n
66	help
67	  This option provides kernel modules that can be used to run
68	  various selftests on parts of the DRM api. This option is not
69	  useful for distributions or general kernels, but only for kernel
70	  developers working on DRM and associated drivers.
71
72	  If in doubt, say "N".
73
74config DRM_KMS_HELPER
75	tristate
76	depends on DRM
77	help
78	  CRTC helpers for KMS drivers.
79
80config DRM_KMS_FB_HELPER
81	bool
82	depends on DRM_KMS_HELPER
83	select FB
84	select FRAMEBUFFER_CONSOLE if !EXPERT
85	select FRAMEBUFFER_CONSOLE_DETECT_PRIMARY if FRAMEBUFFER_CONSOLE
86	select FB_SYS_FOPS
87	select FB_SYS_FILLRECT
88	select FB_SYS_COPYAREA
89	select FB_SYS_IMAGEBLIT
90	select FB_CFB_FILLRECT
91	select FB_CFB_COPYAREA
92	select FB_CFB_IMAGEBLIT
93	select FB_DEFERRED_IO
94	help
95	  FBDEV helpers for KMS drivers.
96
97config DRM_DEBUG_DP_MST_TOPOLOGY_REFS
98        bool "Enable refcount backtrace history in the DP MST helpers"
99	depends on STACKTRACE_SUPPORT
100        select STACKDEPOT
101        depends on DRM_KMS_HELPER
102        depends on DEBUG_KERNEL
103        depends on EXPERT
104        help
105          Enables debug tracing for topology refs in DRM's DP MST helpers. A
106          history of each topology reference/dereference will be printed to the
107          kernel log once a port or branch device's topology refcount reaches 0.
108
109          This has the potential to use a lot of memory and print some very
110          large kernel messages. If in doubt, say "N".
111
112config DRM_FBDEV_EMULATION
113	bool "Enable legacy fbdev support for your modesetting driver"
114	depends on DRM
115	select DRM_KMS_HELPER
116	select DRM_KMS_FB_HELPER
117	default y
118	help
119	  Choose this option if you have a need for the legacy fbdev
120	  support. Note that this support also provides the linux console
121	  support on top of your modesetting driver.
122
123	  If in doubt, say "Y".
124
125config DRM_FBDEV_OVERALLOC
126	int "Overallocation of the fbdev buffer"
127	depends on DRM_FBDEV_EMULATION
128	default 100
129	help
130	  Defines the fbdev buffer overallocation in percent. Default
131	  is 100. Typical values for double buffering will be 200,
132	  triple buffering 300.
133
134config DRM_FBDEV_LEAK_PHYS_SMEM
135	bool "Shamelessly allow leaking of fbdev physical address (DANGEROUS)"
136	depends on DRM_FBDEV_EMULATION && EXPERT
137	default n
138	help
139	  In order to keep user-space compatibility, we want in certain
140	  use-cases to keep leaking the fbdev physical address to the
141	  user-space program handling the fbdev buffer.
142	  This affects, not only, Amlogic, Allwinner or Rockchip devices
143	  with ARM Mali GPUs using an userspace Blob.
144	  This option is not supported by upstream developers and should be
145	  removed as soon as possible and be considered as a broken and
146	  legacy behaviour from a modern fbdev device driver.
147
148	  Please send any bug reports when using this to your proprietary
149	  software vendor that requires this.
150
151	  If in doubt, say "N" or spread the word to your closed source
152	  library vendor.
153
154config DRM_LOAD_EDID_FIRMWARE
155	bool "Allow to specify an EDID data set instead of probing for it"
156	depends on DRM
157	help
158	  Say Y here, if you want to use EDID data to be loaded from the
159	  /lib/firmware directory or one of the provided built-in
160	  data sets. This may be necessary, if the graphics adapter or
161	  monitor are unable to provide appropriate EDID data. Since this
162	  feature is provided as a workaround for broken hardware, the
163	  default case is N. Details and instructions how to build your own
164	  EDID data are given in Documentation/admin-guide/edid.rst.
165
166config DRM_DP_CEC
167	bool "Enable DisplayPort CEC-Tunneling-over-AUX HDMI support"
168	depends on DRM
169	select CEC_CORE
170	help
171	  Choose this option if you want to enable HDMI CEC support for
172	  DisplayPort/USB-C to HDMI adapters.
173
174	  Note: not all adapters support this feature, and even for those
175	  that do support this they often do not hook up the CEC pin.
176
177config DRM_TTM
178	tristate
179	depends on DRM && MMU
180	help
181	  GPU memory management subsystem for devices with multiple
182	  GPU memory types. Will be enabled automatically if a device driver
183	  uses it.
184
185config DRM_VRAM_HELPER
186	tristate
187	depends on DRM
188	help
189	  Helpers for VRAM memory management
190
191config DRM_TTM_HELPER
192	tristate
193	depends on DRM
194	select DRM_TTM
195	help
196	  Helpers for ttm-based gem objects
197
198config DRM_GEM_CMA_HELPER
199	bool
200	depends on DRM
201	help
202	  Choose this if you need the GEM CMA helper functions
203
204config DRM_KMS_CMA_HELPER
205	bool
206	depends on DRM
207	select DRM_GEM_CMA_HELPER
208	help
209	  Choose this if you need the KMS CMA helper functions
210
211config DRM_GEM_SHMEM_HELPER
212	bool
213	depends on DRM
214	help
215	  Choose this if you need the GEM shmem helper functions
216
217config DRM_VM
218	bool
219	depends on DRM && MMU
220
221config DRM_SCHED
222	tristate
223	depends on DRM
224
225source "drivers/gpu/drm/i2c/Kconfig"
226
227source "drivers/gpu/drm/arm/Kconfig"
228
229config DRM_RADEON
230	tristate "ATI Radeon"
231	depends on DRM && PCI && MMU
232	select FW_LOADER
233        select DRM_KMS_HELPER
234        select DRM_TTM
235	select DRM_TTM_HELPER
236	select POWER_SUPPLY
237	select HWMON
238	select BACKLIGHT_CLASS_DEVICE
239	select INTERVAL_TREE
240	help
241	  Choose this option if you have an ATI Radeon graphics card.  There
242	  are both PCI and AGP versions.  You don't need to choose this to
243	  run the Radeon in plain VGA mode.
244
245	  If M is selected, the module will be called radeon.
246
247source "drivers/gpu/drm/radeon/Kconfig"
248
249config DRM_AMDGPU
250	tristate "AMD GPU"
251	depends on DRM && PCI && MMU
252	select FW_LOADER
253	select DRM_KMS_HELPER
254	select DRM_SCHED
255	select DRM_TTM
256	select DRM_TTM_HELPER
257	select POWER_SUPPLY
258	select HWMON
259	select BACKLIGHT_CLASS_DEVICE
260	select INTERVAL_TREE
261	select CHASH
262	help
263	  Choose this option if you have a recent AMD Radeon graphics card.
264
265	  If M is selected, the module will be called amdgpu.
266
267source "drivers/gpu/drm/amd/amdgpu/Kconfig"
268
269source "drivers/gpu/drm/nouveau/Kconfig"
270
271source "drivers/gpu/drm/i915/Kconfig"
272
273source "drivers/gpu/drm/kmb/Kconfig"
274
275config DRM_VGEM
276	tristate "Virtual GEM provider"
277	depends on DRM
278	help
279	  Choose this option to get a virtual graphics memory manager,
280	  as used by Mesa's software renderer for enhanced performance.
281	  If M is selected the module will be called vgem.
282
283config DRM_VKMS
284	tristate "Virtual KMS (EXPERIMENTAL)"
285	depends on DRM
286	select DRM_KMS_HELPER
287	select DRM_GEM_SHMEM_HELPER
288	select CRC32
289	default n
290	help
291	  Virtual Kernel Mode-Setting (VKMS) is used for testing or for
292	  running GPU in a headless machines. Choose this option to get
293	  a VKMS.
294
295	  If M is selected the module will be called vkms.
296
297source "drivers/gpu/drm/exynos/Kconfig"
298
299source "drivers/gpu/drm/rockchip/Kconfig"
300
301source "drivers/gpu/drm/vmwgfx/Kconfig"
302
303source "drivers/gpu/drm/gma500/Kconfig"
304
305source "drivers/gpu/drm/udl/Kconfig"
306
307source "drivers/gpu/drm/ast/Kconfig"
308
309source "drivers/gpu/drm/mgag200/Kconfig"
310
311source "drivers/gpu/drm/armada/Kconfig"
312
313source "drivers/gpu/drm/atmel-hlcdc/Kconfig"
314
315source "drivers/gpu/drm/rcar-du/Kconfig"
316
317source "drivers/gpu/drm/shmobile/Kconfig"
318
319source "drivers/gpu/drm/sun4i/Kconfig"
320
321source "drivers/gpu/drm/omapdrm/Kconfig"
322
323source "drivers/gpu/drm/tilcdc/Kconfig"
324
325source "drivers/gpu/drm/qxl/Kconfig"
326
327source "drivers/gpu/drm/bochs/Kconfig"
328
329source "drivers/gpu/drm/virtio/Kconfig"
330
331source "drivers/gpu/drm/msm/Kconfig"
332
333source "drivers/gpu/drm/fsl-dcu/Kconfig"
334
335source "drivers/gpu/drm/tegra/Kconfig"
336
337source "drivers/gpu/drm/stm/Kconfig"
338
339source "drivers/gpu/drm/panel/Kconfig"
340
341source "drivers/gpu/drm/bridge/Kconfig"
342
343source "drivers/gpu/drm/sti/Kconfig"
344
345source "drivers/gpu/drm/imx/Kconfig"
346
347source "drivers/gpu/drm/ingenic/Kconfig"
348
349source "drivers/gpu/drm/v3d/Kconfig"
350
351source "drivers/gpu/drm/vc4/Kconfig"
352
353source "drivers/gpu/drm/etnaviv/Kconfig"
354
355source "drivers/gpu/drm/arc/Kconfig"
356
357source "drivers/gpu/drm/hisilicon/Kconfig"
358
359source "drivers/gpu/drm/mediatek/Kconfig"
360
361source "drivers/gpu/drm/zte/Kconfig"
362
363source "drivers/gpu/drm/mxsfb/Kconfig"
364
365source "drivers/gpu/drm/meson/Kconfig"
366
367source "drivers/gpu/drm/tiny/Kconfig"
368
369source "drivers/gpu/drm/pl111/Kconfig"
370
371source "drivers/gpu/drm/tve200/Kconfig"
372
373source "drivers/gpu/drm/xen/Kconfig"
374
375source "drivers/gpu/drm/vboxvideo/Kconfig"
376
377source "drivers/gpu/drm/lima/Kconfig"
378
379source "drivers/gpu/drm/panfrost/Kconfig"
380
381source "drivers/gpu/drm/aspeed/Kconfig"
382
383source "drivers/gpu/drm/mcde/Kconfig"
384
385source "drivers/gpu/drm/tidss/Kconfig"
386
387source "drivers/gpu/drm/xlnx/Kconfig"
388
389# Keep legacy drivers last
390
391menuconfig DRM_LEGACY
392	bool "Enable legacy drivers (DANGEROUS)"
393	depends on DRM && MMU
394	select DRM_VM
395	help
396	  Enable legacy DRI1 drivers. Those drivers expose unsafe and dangerous
397	  APIs to user-space, which can be used to circumvent access
398	  restrictions and other security measures. For backwards compatibility
399	  those drivers are still available, but their use is highly
400	  inadvisable and might harm your system.
401
402	  You are recommended to use the safe modeset-only drivers instead, and
403	  perform 3D emulation in user-space.
404
405	  Unless you have strong reasons to go rogue, say "N".
406
407if DRM_LEGACY
408
409config DRM_TDFX
410	tristate "3dfx Banshee/Voodoo3+"
411	depends on DRM && PCI
412	help
413	  Choose this option if you have a 3dfx Banshee or Voodoo3 (or later),
414	  graphics card.  If M is selected, the module will be called tdfx.
415
416config DRM_R128
417	tristate "ATI Rage 128"
418	depends on DRM && PCI
419	select FW_LOADER
420	help
421	  Choose this option if you have an ATI Rage 128 graphics card.  If M
422	  is selected, the module will be called r128.  AGP support for
423	  this card is strongly suggested (unless you have a PCI version).
424
425config DRM_I810
426	tristate "Intel I810"
427	# !PREEMPTION because of missing ioctl locking
428	depends on DRM && AGP && AGP_INTEL && (!PREEMPTION || BROKEN)
429	help
430	  Choose this option if you have an Intel I810 graphics card.  If M is
431	  selected, the module will be called i810.  AGP support is required
432	  for this driver to work.
433
434config DRM_MGA
435	tristate "Matrox g200/g400"
436	depends on DRM && PCI
437	select FW_LOADER
438	help
439	  Choose this option if you have a Matrox G200, G400 or G450 graphics
440	  card.  If M is selected, the module will be called mga.  AGP
441	  support is required for this driver to work.
442
443config DRM_SIS
444	tristate "SiS video cards"
445	depends on DRM && AGP
446	depends on FB_SIS || FB_SIS=n
447	help
448	  Choose this option if you have a SiS 630 or compatible video
449	  chipset. If M is selected the module will be called sis. AGP
450	  support is required for this driver to work.
451
452config DRM_VIA
453	tristate "Via unichrome video cards"
454	depends on DRM && PCI
455	help
456	  Choose this option if you have a Via unichrome or compatible video
457	  chipset. If M is selected the module will be called via.
458
459config DRM_SAVAGE
460	tristate "Savage video cards"
461	depends on DRM && PCI
462	help
463	  Choose this option if you have a Savage3D/4/SuperSavage/Pro/Twister
464	  chipset. If M is selected the module will be called savage.
465
466endif # DRM_LEGACY
467
468config DRM_EXPORT_FOR_TESTS
469	bool
470
471# Separate option because drm_panel_orientation_quirks.c is shared with fbdev
472config DRM_PANEL_ORIENTATION_QUIRKS
473	tristate
474
475config DRM_LIB_RANDOM
476	bool
477	default n
478