xref: /openbmc/linux/drivers/gpu/drm/Kconfig (revision 7a836736b6537b0e2633381d743d9c1559ce243c)
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 && (UML || COMPILE_TEST)
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. It depends on (UML || COMPILE_TEST) since no other driver
210          which uses TTM can be loaded while running the tests.
211
212          If in doubt, say "N".
213
214config DRM_EXEC
215	tristate
216	depends on DRM
217	help
218	  Execution context for command submissions
219
220config DRM_BUDDY
221	tristate
222	depends on DRM
223	help
224	  A page based buddy allocator
225
226config DRM_VRAM_HELPER
227	tristate
228	depends on DRM
229	help
230	  Helpers for VRAM memory management
231
232config DRM_TTM_HELPER
233	tristate
234	depends on DRM
235	select DRM_TTM
236	help
237	  Helpers for ttm-based gem objects
238
239config DRM_GEM_DMA_HELPER
240	tristate
241	depends on DRM
242	select FB_DMAMEM_HELPERS if DRM_FBDEV_EMULATION
243	help
244	  Choose this if you need the GEM DMA helper functions
245
246config DRM_GEM_SHMEM_HELPER
247	tristate
248	depends on DRM && MMU
249	help
250	  Choose this if you need the GEM shmem helper functions
251
252config DRM_SUBALLOC_HELPER
253	tristate
254	depends on DRM
255
256config DRM_SCHED
257	tristate
258	depends on DRM
259
260source "drivers/gpu/drm/i2c/Kconfig"
261
262source "drivers/gpu/drm/arm/Kconfig"
263
264source "drivers/gpu/drm/radeon/Kconfig"
265
266source "drivers/gpu/drm/amd/amdgpu/Kconfig"
267
268source "drivers/gpu/drm/nouveau/Kconfig"
269
270source "drivers/gpu/drm/i915/Kconfig"
271
272source "drivers/gpu/drm/kmb/Kconfig"
273
274config DRM_VGEM
275	tristate "Virtual GEM provider"
276	depends on DRM && MMU
277	select DRM_GEM_SHMEM_HELPER
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 && MMU
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/renesas/Kconfig"
316
317source "drivers/gpu/drm/sun4i/Kconfig"
318
319source "drivers/gpu/drm/omapdrm/Kconfig"
320
321source "drivers/gpu/drm/tilcdc/Kconfig"
322
323source "drivers/gpu/drm/qxl/Kconfig"
324
325source "drivers/gpu/drm/virtio/Kconfig"
326
327source "drivers/gpu/drm/msm/Kconfig"
328
329source "drivers/gpu/drm/fsl-dcu/Kconfig"
330
331source "drivers/gpu/drm/tegra/Kconfig"
332
333source "drivers/gpu/drm/stm/Kconfig"
334
335source "drivers/gpu/drm/panel/Kconfig"
336
337source "drivers/gpu/drm/bridge/Kconfig"
338
339source "drivers/gpu/drm/sti/Kconfig"
340
341source "drivers/gpu/drm/imx/Kconfig"
342
343source "drivers/gpu/drm/ingenic/Kconfig"
344
345source "drivers/gpu/drm/v3d/Kconfig"
346
347source "drivers/gpu/drm/vc4/Kconfig"
348
349source "drivers/gpu/drm/loongson/Kconfig"
350
351source "drivers/gpu/drm/etnaviv/Kconfig"
352
353source "drivers/gpu/drm/hisilicon/Kconfig"
354
355source "drivers/gpu/drm/logicvc/Kconfig"
356
357source "drivers/gpu/drm/mediatek/Kconfig"
358
359source "drivers/gpu/drm/mxsfb/Kconfig"
360
361source "drivers/gpu/drm/meson/Kconfig"
362
363source "drivers/gpu/drm/tiny/Kconfig"
364
365source "drivers/gpu/drm/pl111/Kconfig"
366
367source "drivers/gpu/drm/tve200/Kconfig"
368
369source "drivers/gpu/drm/xen/Kconfig"
370
371source "drivers/gpu/drm/vboxvideo/Kconfig"
372
373source "drivers/gpu/drm/lima/Kconfig"
374
375source "drivers/gpu/drm/panfrost/Kconfig"
376
377source "drivers/gpu/drm/aspeed/Kconfig"
378
379source "drivers/gpu/drm/mcde/Kconfig"
380
381source "drivers/gpu/drm/tidss/Kconfig"
382
383source "drivers/gpu/drm/xlnx/Kconfig"
384
385source "drivers/gpu/drm/gud/Kconfig"
386
387source "drivers/gpu/drm/solomon/Kconfig"
388
389source "drivers/gpu/drm/sprd/Kconfig"
390
391config DRM_HYPERV
392	tristate "DRM Support for Hyper-V synthetic video device"
393	depends on DRM && PCI && MMU && HYPERV
394	select DRM_KMS_HELPER
395	select DRM_GEM_SHMEM_HELPER
396	help
397	 This is a KMS driver for Hyper-V synthetic video device. Choose this
398	 option if you would like to enable drm driver for Hyper-V virtual
399	 machine. Unselect Hyper-V framebuffer driver (CONFIG_FB_HYPERV) so
400	 that DRM driver is used by default.
401
402	 If M is selected the module will be called hyperv_drm.
403
404# Keep legacy drivers last
405
406menuconfig DRM_LEGACY
407	bool "Enable legacy drivers (DANGEROUS)"
408	depends on DRM && MMU
409	help
410	  Enable legacy DRI1 drivers. Those drivers expose unsafe and dangerous
411	  APIs to user-space, which can be used to circumvent access
412	  restrictions and other security measures. For backwards compatibility
413	  those drivers are still available, but their use is highly
414	  inadvisable and might harm your system.
415
416	  You are recommended to use the safe modeset-only drivers instead, and
417	  perform 3D emulation in user-space.
418
419	  Unless you have strong reasons to go rogue, say "N".
420
421if DRM_LEGACY
422# leave here to list legacy drivers
423endif # DRM_LEGACY
424
425config DRM_EXPORT_FOR_TESTS
426	bool
427
428# Separate option because drm_panel_orientation_quirks.c is shared with fbdev
429config DRM_PANEL_ORIENTATION_QUIRKS
430	tristate
431
432config DRM_LIB_RANDOM
433	bool
434	default n
435
436config DRM_PRIVACY_SCREEN
437	bool
438	default n
439