xref: /linux/drivers/gpu/drm/Kconfig (revision d642ef71)
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 DRM_KMS_HELPER if DRM_FBDEV_EMULATION
13	select FB_CORE if DRM_FBDEV_EMULATION
14	select FB_SYSMEM_HELPERS_DEFERRED if DRM_FBDEV_EMULATION
15	select HDMI
16	select I2C
17	select DMA_SHARED_BUFFER
18	select SYNC_FILE
19# gallium uses SYS_kcmp for os_same_file_description() to de-duplicate
20# device and dmabuf fd. Let's make sure that is available for our userspace.
21	select KCMP
22	select VIDEO_CMDLINE
23	select VIDEO_NOMODESET
24	help
25	  Kernel-level support for the Direct Rendering Infrastructure (DRI)
26	  introduced in XFree86 4.0. If you say Y here, you need to select
27	  the module that's right for your graphics card from the list below.
28	  These modules provide support for synchronization, security, and
29	  DMA transfers. Please see <http://dri.sourceforge.net/> for more
30	  details.  You should also select and configure AGP
31	  (/dev/agpgart) support if it is available for your platform.
32
33config DRM_MIPI_DBI
34	tristate
35	depends on DRM
36	select DRM_KMS_HELPER
37
38config DRM_MIPI_DSI
39	bool
40	depends on DRM
41
42config DRM_DEBUG_MM
43	bool "Insert extra checks and debug info into the DRM range managers"
44	default n
45	depends on DRM=y
46	depends on STACKTRACE_SUPPORT
47	select STACKDEPOT
48	help
49	  Enable allocation tracking of memory manager and leak detection on
50	  shutdown.
51
52	  Recommended for driver developers only.
53
54	  If in doubt, say "N".
55
56config DRM_USE_DYNAMIC_DEBUG
57	bool "use dynamic debug to implement drm.debug"
58	default n
59	depends on BROKEN
60	depends on DRM
61	depends on DYNAMIC_DEBUG || DYNAMIC_DEBUG_CORE
62	depends on JUMP_LABEL
63	help
64	  Use dynamic-debug to avoid drm_debug_enabled() runtime overheads.
65	  Due to callsite counts in DRM drivers (~4k in amdgpu) and 56
66	  bytes per callsite, the .data costs can be substantial, and
67	  are therefore configurable.
68
69config DRM_KUNIT_TEST_HELPERS
70	tristate
71	depends on DRM && KUNIT
72	help
73	  KUnit Helpers for KMS drivers.
74
75config DRM_KUNIT_TEST
76	tristate "KUnit tests for DRM" if !KUNIT_ALL_TESTS
77	depends on DRM && KUNIT
78	select PRIME_NUMBERS
79	select DRM_DISPLAY_DP_HELPER
80	select DRM_DISPLAY_HELPER
81	select DRM_LIB_RANDOM
82	select DRM_KMS_HELPER
83	select DRM_BUDDY
84	select DRM_EXPORT_FOR_TESTS if m
85	select DRM_KUNIT_TEST_HELPERS
86	select DRM_EXEC
87	default KUNIT_ALL_TESTS
88	help
89	  This builds unit tests for DRM. This option is not useful for
90	  distributions or general kernels, but only for kernel
91	  developers working on DRM and associated drivers.
92
93	  For more information on KUnit and unit tests in general,
94	  please refer to the KUnit documentation in
95	  Documentation/dev-tools/kunit/.
96
97	  If in doubt, say "N".
98
99config DRM_KMS_HELPER
100	tristate
101	depends on DRM
102	help
103	  CRTC helpers for KMS drivers.
104
105config DRM_DEBUG_DP_MST_TOPOLOGY_REFS
106        bool "Enable refcount backtrace history in the DP MST helpers"
107	depends on STACKTRACE_SUPPORT
108        select STACKDEPOT
109        depends on DRM_KMS_HELPER
110        depends on DEBUG_KERNEL
111        depends on EXPERT
112        help
113          Enables debug tracing for topology refs in DRM's DP MST helpers. A
114          history of each topology reference/dereference will be printed to the
115          kernel log once a port or branch device's topology refcount reaches 0.
116
117          This has the potential to use a lot of memory and print some very
118          large kernel messages. If in doubt, say "N".
119
120config DRM_DEBUG_MODESET_LOCK
121	bool "Enable backtrace history for lock contention"
122	depends on STACKTRACE_SUPPORT
123	depends on DEBUG_KERNEL
124	depends on EXPERT
125	select STACKDEPOT
126	default y if DEBUG_WW_MUTEX_SLOWPATH
127	help
128	  Enable debug tracing of failures to gracefully handle drm modeset lock
129	  contention. A history of each drm modeset lock path hitting -EDEADLK
130	  will be saved until gracefully handled, and the backtrace will be
131	  printed when attempting to lock a contended lock.
132
133	  If in doubt, say "N".
134
135config DRM_FBDEV_EMULATION
136	bool "Enable legacy fbdev support for your modesetting driver"
137	depends on DRM
138	select FRAMEBUFFER_CONSOLE_DETECT_PRIMARY if FRAMEBUFFER_CONSOLE
139	default FB
140	help
141	  Choose this option if you have a need for the legacy fbdev
142	  support. Note that this support also provides the linux console
143	  support on top of your modesetting driver.
144
145	  If in doubt, say "Y".
146
147config DRM_FBDEV_OVERALLOC
148	int "Overallocation of the fbdev buffer"
149	depends on DRM_FBDEV_EMULATION
150	default 100
151	help
152	  Defines the fbdev buffer overallocation in percent. Default
153	  is 100. Typical values for double buffering will be 200,
154	  triple buffering 300.
155
156config DRM_FBDEV_LEAK_PHYS_SMEM
157	bool "Shamelessly allow leaking of fbdev physical address (DANGEROUS)"
158	depends on DRM_FBDEV_EMULATION && EXPERT
159	default n
160	help
161	  In order to keep user-space compatibility, we want in certain
162	  use-cases to keep leaking the fbdev physical address to the
163	  user-space program handling the fbdev buffer.
164	  This affects, not only, Amlogic, Allwinner or Rockchip devices
165	  with ARM Mali GPUs using an userspace Blob.
166	  This option is not supported by upstream developers and should be
167	  removed as soon as possible and be considered as a broken and
168	  legacy behaviour from a modern fbdev device driver.
169
170	  Please send any bug reports when using this to your proprietary
171	  software vendor that requires this.
172
173	  If in doubt, say "N" or spread the word to your closed source
174	  library vendor.
175
176config DRM_LOAD_EDID_FIRMWARE
177	bool "Allow to specify an EDID data set instead of probing for it"
178	depends on DRM
179	help
180	  Say Y here, if you want to use EDID data to be loaded from the
181	  /lib/firmware directory or one of the provided built-in
182	  data sets. This may be necessary, if the graphics adapter or
183	  monitor are unable to provide appropriate EDID data. Since this
184	  feature is provided as a workaround for broken hardware, the
185	  default case is N. Details and instructions how to build your own
186	  EDID data are given in Documentation/admin-guide/edid.rst.
187
188source "drivers/gpu/drm/display/Kconfig"
189
190config DRM_TTM
191	tristate
192	depends on DRM && MMU
193	help
194	  GPU memory management subsystem for devices with multiple
195	  GPU memory types. Will be enabled automatically if a device driver
196	  uses it.
197
198config DRM_TTM_KUNIT_TEST
199        tristate "KUnit tests for TTM" if !KUNIT_ALL_TESTS
200        default n
201        depends on DRM && KUNIT && MMU
202        select DRM_TTM
203        select DRM_EXPORT_FOR_TESTS if m
204        select DRM_KUNIT_TEST_HELPERS
205        default KUNIT_ALL_TESTS
206        help
207          Enables unit tests for TTM, a GPU memory manager subsystem used
208          to manage memory buffers. This option is mostly useful for kernel
209          developers.
210
211          If in doubt, say "N".
212
213config DRM_EXEC
214	tristate
215	depends on DRM
216	help
217	  Execution context for command submissions
218
219config DRM_GPUVM
220	tristate
221	depends on DRM
222	help
223	  GPU-VM representation providing helpers to manage a GPUs virtual
224	  address space
225
226config DRM_BUDDY
227	tristate
228	depends on DRM
229	help
230	  A page based buddy allocator
231
232config DRM_VRAM_HELPER
233	tristate
234	depends on DRM
235	help
236	  Helpers for VRAM memory management
237
238config DRM_TTM_HELPER
239	tristate
240	depends on DRM
241	select DRM_TTM
242	help
243	  Helpers for ttm-based gem objects
244
245config DRM_GEM_DMA_HELPER
246	tristate
247	depends on DRM
248	select FB_DMAMEM_HELPERS if DRM_FBDEV_EMULATION
249	help
250	  Choose this if you need the GEM DMA helper functions
251
252config DRM_GEM_SHMEM_HELPER
253	tristate
254	depends on DRM && MMU
255	help
256	  Choose this if you need the GEM shmem helper functions
257
258config DRM_SUBALLOC_HELPER
259	tristate
260	depends on DRM
261
262config DRM_SCHED
263	tristate
264	depends on DRM
265
266source "drivers/gpu/drm/i2c/Kconfig"
267
268source "drivers/gpu/drm/arm/Kconfig"
269
270source "drivers/gpu/drm/radeon/Kconfig"
271
272source "drivers/gpu/drm/amd/amdgpu/Kconfig"
273
274source "drivers/gpu/drm/nouveau/Kconfig"
275
276source "drivers/gpu/drm/i915/Kconfig"
277
278source "drivers/gpu/drm/kmb/Kconfig"
279
280config DRM_VGEM
281	tristate "Virtual GEM provider"
282	depends on DRM && MMU
283	select DRM_GEM_SHMEM_HELPER
284	help
285	  Choose this option to get a virtual graphics memory manager,
286	  as used by Mesa's software renderer for enhanced performance.
287	  If M is selected the module will be called vgem.
288
289config DRM_VKMS
290	tristate "Virtual KMS (EXPERIMENTAL)"
291	depends on DRM && MMU
292	select DRM_KMS_HELPER
293	select DRM_GEM_SHMEM_HELPER
294	select CRC32
295	default n
296	help
297	  Virtual Kernel Mode-Setting (VKMS) is used for testing or for
298	  running GPU in a headless machines. Choose this option to get
299	  a VKMS.
300
301	  If M is selected the module will be called vkms.
302
303source "drivers/gpu/drm/exynos/Kconfig"
304
305source "drivers/gpu/drm/rockchip/Kconfig"
306
307source "drivers/gpu/drm/vmwgfx/Kconfig"
308
309source "drivers/gpu/drm/gma500/Kconfig"
310
311source "drivers/gpu/drm/udl/Kconfig"
312
313source "drivers/gpu/drm/ast/Kconfig"
314
315source "drivers/gpu/drm/mgag200/Kconfig"
316
317source "drivers/gpu/drm/armada/Kconfig"
318
319source "drivers/gpu/drm/atmel-hlcdc/Kconfig"
320
321source "drivers/gpu/drm/renesas/Kconfig"
322
323source "drivers/gpu/drm/sun4i/Kconfig"
324
325source "drivers/gpu/drm/omapdrm/Kconfig"
326
327source "drivers/gpu/drm/tilcdc/Kconfig"
328
329source "drivers/gpu/drm/qxl/Kconfig"
330
331source "drivers/gpu/drm/virtio/Kconfig"
332
333source "drivers/gpu/drm/msm/Kconfig"
334
335source "drivers/gpu/drm/fsl-dcu/Kconfig"
336
337source "drivers/gpu/drm/tegra/Kconfig"
338
339source "drivers/gpu/drm/stm/Kconfig"
340
341source "drivers/gpu/drm/panel/Kconfig"
342
343source "drivers/gpu/drm/bridge/Kconfig"
344
345source "drivers/gpu/drm/sti/Kconfig"
346
347source "drivers/gpu/drm/imx/Kconfig"
348
349source "drivers/gpu/drm/ingenic/Kconfig"
350
351source "drivers/gpu/drm/v3d/Kconfig"
352
353source "drivers/gpu/drm/vc4/Kconfig"
354
355source "drivers/gpu/drm/loongson/Kconfig"
356
357source "drivers/gpu/drm/etnaviv/Kconfig"
358
359source "drivers/gpu/drm/hisilicon/Kconfig"
360
361source "drivers/gpu/drm/logicvc/Kconfig"
362
363source "drivers/gpu/drm/mediatek/Kconfig"
364
365source "drivers/gpu/drm/mxsfb/Kconfig"
366
367source "drivers/gpu/drm/meson/Kconfig"
368
369source "drivers/gpu/drm/tiny/Kconfig"
370
371source "drivers/gpu/drm/pl111/Kconfig"
372
373source "drivers/gpu/drm/tve200/Kconfig"
374
375source "drivers/gpu/drm/xen/Kconfig"
376
377source "drivers/gpu/drm/vboxvideo/Kconfig"
378
379source "drivers/gpu/drm/lima/Kconfig"
380
381source "drivers/gpu/drm/panfrost/Kconfig"
382
383source "drivers/gpu/drm/aspeed/Kconfig"
384
385source "drivers/gpu/drm/mcde/Kconfig"
386
387source "drivers/gpu/drm/tidss/Kconfig"
388
389source "drivers/gpu/drm/xlnx/Kconfig"
390
391source "drivers/gpu/drm/gud/Kconfig"
392
393source "drivers/gpu/drm/solomon/Kconfig"
394
395source "drivers/gpu/drm/sprd/Kconfig"
396
397config DRM_HYPERV
398	tristate "DRM Support for Hyper-V synthetic video device"
399	depends on DRM && PCI && MMU && HYPERV
400	select DRM_KMS_HELPER
401	select DRM_GEM_SHMEM_HELPER
402	help
403	 This is a KMS driver for Hyper-V synthetic video device. Choose this
404	 option if you would like to enable drm driver for Hyper-V virtual
405	 machine. Unselect Hyper-V framebuffer driver (CONFIG_FB_HYPERV) so
406	 that DRM driver is used by default.
407
408	 If M is selected the module will be called hyperv_drm.
409
410# Keep legacy drivers last
411
412menuconfig DRM_LEGACY
413	bool "Enable legacy drivers (DANGEROUS)"
414	depends on DRM && MMU
415	help
416	  Enable legacy DRI1 drivers. Those drivers expose unsafe and dangerous
417	  APIs to user-space, which can be used to circumvent access
418	  restrictions and other security measures. For backwards compatibility
419	  those drivers are still available, but their use is highly
420	  inadvisable and might harm your system.
421
422	  You are recommended to use the safe modeset-only drivers instead, and
423	  perform 3D emulation in user-space.
424
425	  Unless you have strong reasons to go rogue, say "N".
426
427if DRM_LEGACY
428# leave here to list legacy drivers
429endif # DRM_LEGACY
430
431config DRM_EXPORT_FOR_TESTS
432	bool
433
434# Separate option because drm_panel_orientation_quirks.c is shared with fbdev
435config DRM_PANEL_ORIENTATION_QUIRKS
436	tristate
437
438config DRM_LIB_RANDOM
439	bool
440	default n
441
442config DRM_PRIVACY_SCREEN
443	bool
444	default n
445