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 I2C 14 select DMA_SHARED_BUFFER 15 select SYNC_FILE 16# gallium uses SYS_kcmp for os_same_file_description() to de-duplicate 17# device and dmabuf fd. Let's make sure that is available for our userspace. 18 select KCMP 19 select VIDEO 20 help 21 Kernel-level support for the Direct Rendering Infrastructure (DRI) 22 introduced in XFree86 4.0. If you say Y here, you need to select 23 the module that's right for your graphics card from the list below. 24 These modules provide support for synchronization, security, and 25 DMA transfers. Please see <http://dri.sourceforge.net/> for more 26 details. You should also select and configure AGP 27 (/dev/agpgart) support if it is available for your platform. 28 29if DRM 30 31config DRM_MIPI_DBI 32 tristate 33 depends on DRM 34 select DRM_KMS_HELPER 35 36config DRM_MIPI_DSI 37 bool 38 depends on DRM 39 40config DRM_DEBUG_MM 41 bool "Insert extra checks and debug info into the DRM range managers" 42 default n 43 depends on DRM 44 depends on STACKTRACE_SUPPORT 45 select STACKDEPOT 46 help 47 Enable allocation tracking of memory manager and leak detection on 48 shutdown. 49 50 Recommended for driver developers only. 51 52 If in doubt, say "N". 53 54config DRM_USE_DYNAMIC_DEBUG 55 bool "use dynamic debug to implement drm.debug" 56 default n 57 depends on BROKEN 58 depends on DRM 59 depends on DYNAMIC_DEBUG || DYNAMIC_DEBUG_CORE 60 depends on JUMP_LABEL 61 help 62 Use dynamic-debug to avoid drm_debug_enabled() runtime overheads. 63 Due to callsite counts in DRM drivers (~4k in amdgpu) and 56 64 bytes per callsite, the .data costs can be substantial, and 65 are therefore configurable. 66 67config DRM_KUNIT_TEST_HELPERS 68 tristate 69 depends on DRM && KUNIT 70 select DRM_KMS_HELPER 71 help 72 KUnit Helpers for KMS drivers. 73 74config DRM_KUNIT_TEST 75 tristate "KUnit tests for DRM" if !KUNIT_ALL_TESTS 76 depends on DRM && KUNIT && MMU 77 select DRM_BUDDY 78 select DRM_DISPLAY_DP_HELPER 79 select DRM_DISPLAY_HDMI_STATE_HELPER 80 select DRM_DISPLAY_HELPER 81 select DRM_EXEC 82 select DRM_EXPORT_FOR_TESTS if m 83 select DRM_GEM_SHMEM_HELPER 84 select DRM_KUNIT_TEST_HELPERS 85 select DRM_LIB_RANDOM 86 select PRIME_NUMBERS 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_DRAW 106 bool 107 depends on DRM 108 109config DRM_PANIC 110 bool "Display a user-friendly message when a kernel panic occurs" 111 depends on DRM 112 select FONT_SUPPORT 113 select DRM_DRAW 114 help 115 Enable a drm panic handler, which will display a user-friendly message 116 when a kernel panic occurs. It's useful when using a user-space 117 console instead of fbcon. 118 It will only work if your graphic driver supports this feature. 119 To support Hi-DPI Display, you can enable bigger fonts like 120 FONT_TER16x32 121 122config DRM_PANIC_FOREGROUND_COLOR 123 hex "Drm panic screen foreground color, in RGB" 124 depends on DRM_PANIC 125 default 0xffffff 126 127config DRM_PANIC_BACKGROUND_COLOR 128 hex "Drm panic screen background color, in RGB" 129 depends on DRM_PANIC 130 default 0x000000 131 132config DRM_PANIC_DEBUG 133 bool "Add a debug fs entry to trigger drm_panic" 134 depends on DRM_PANIC && DEBUG_FS 135 help 136 Add dri/[device]/drm_panic_plane_x in the kernel debugfs, to force the 137 panic handler to write the panic message to this plane scanout buffer. 138 This is unsafe and should not be enabled on a production build. 139 If in doubt, say "N". 140 141config DRM_PANIC_SCREEN 142 string "Panic screen formatter" 143 default "user" 144 depends on DRM_PANIC 145 help 146 This option enable to choose what will be displayed when a kernel 147 panic occurs. You can choose between "user", a short message telling 148 the user to reboot the system, or "kmsg" which will display the last 149 lines of kmsg. 150 This can also be overridden by drm.panic_screen=xxxx kernel parameter 151 or by writing to /sys/module/drm/parameters/panic_screen sysfs entry 152 Default is "user" 153 154config DRM_PANIC_SCREEN_QR_CODE 155 bool "Add a panic screen with a QR code" 156 depends on DRM_PANIC && RUST 157 select ZLIB_DEFLATE 158 help 159 This option adds a QR code generator, and a panic screen with a QR 160 code. The QR code will contain the last lines of kmsg and other debug 161 information. This should be easier for the user to report a kernel 162 panic, with all debug information available. 163 To use this panic screen, also set DRM_PANIC_SCREEN to "qr_code" 164 165config DRM_PANIC_SCREEN_QR_CODE_URL 166 string "Base URL of the QR code in the panic screen" 167 depends on DRM_PANIC_SCREEN_QR_CODE 168 help 169 This option sets the base URL to report the kernel panic. If it's set 170 the QR code will contain the URL and the kmsg compressed with zlib as 171 a URL parameter. If it's empty, the QR code will contain the kmsg as 172 uncompressed text only. 173 There is a demo code in javascript, to decode and uncompress the kmsg 174 data from the URL parameter at https://github.com/kdj0c/panic_report 175 176config DRM_PANIC_SCREEN_QR_VERSION 177 int "Maximum version (size) of the QR code." 178 depends on DRM_PANIC_SCREEN_QR_CODE 179 default 40 180 help 181 This option limits the version (or size) of the QR code. QR code 182 version ranges from Version 1 (21x21) to Version 40 (177x177). 183 Smaller QR code are easier to read, but will contain less debugging 184 data. Default is 40. 185 186config DRM_DEBUG_DP_MST_TOPOLOGY_REFS 187 bool "Enable refcount backtrace history in the DP MST helpers" 188 depends on STACKTRACE_SUPPORT 189 select STACKDEPOT 190 depends on DRM_KMS_HELPER 191 depends on DEBUG_KERNEL 192 depends on EXPERT 193 help 194 Enables debug tracing for topology refs in DRM's DP MST helpers. A 195 history of each topology reference/dereference will be printed to the 196 kernel log once a port or branch device's topology refcount reaches 0. 197 198 This has the potential to use a lot of memory and print some very 199 large kernel messages. If in doubt, say "N". 200 201config DRM_DEBUG_MODESET_LOCK 202 bool "Enable backtrace history for lock contention" 203 depends on STACKTRACE_SUPPORT 204 depends on DEBUG_KERNEL 205 depends on EXPERT 206 select STACKDEPOT 207 default y if DEBUG_WW_MUTEX_SLOWPATH 208 help 209 Enable debug tracing of failures to gracefully handle drm modeset lock 210 contention. A history of each drm modeset lock path hitting -EDEADLK 211 will be saved until gracefully handled, and the backtrace will be 212 printed when attempting to lock a contended lock. 213 214 If in doubt, say "N". 215 216config DRM_CLIENT 217 bool 218 depends on DRM 219 help 220 Enables support for DRM clients. DRM drivers that need 221 struct drm_client_dev and its interfaces should select this 222 option. Drivers that support the default clients should 223 select DRM_CLIENT_SELECTION instead. 224 225source "drivers/gpu/drm/clients/Kconfig" 226 227config DRM_LOAD_EDID_FIRMWARE 228 bool "Allow to specify an EDID data set instead of probing for it" 229 depends on DRM 230 help 231 Say Y here, if you want to use EDID data to be loaded from the 232 /lib/firmware directory or one of the provided built-in 233 data sets. This may be necessary, if the graphics adapter or 234 monitor are unable to provide appropriate EDID data. Since this 235 feature is provided as a workaround for broken hardware, the 236 default case is N. Details and instructions how to build your own 237 EDID data are given in Documentation/admin-guide/edid.rst. 238 239source "drivers/gpu/drm/display/Kconfig" 240 241config DRM_TTM 242 tristate 243 depends on DRM && MMU 244 help 245 GPU memory management subsystem for devices with multiple 246 GPU memory types. Will be enabled automatically if a device driver 247 uses it. 248 249config DRM_TTM_KUNIT_TEST 250 tristate "KUnit tests for TTM" if !KUNIT_ALL_TESTS 251 default n 252 depends on DRM && KUNIT && MMU && (UML || COMPILE_TEST) 253 select DRM_TTM 254 select DRM_BUDDY 255 select DRM_EXPORT_FOR_TESTS if m 256 select DRM_KUNIT_TEST_HELPERS 257 default KUNIT_ALL_TESTS 258 help 259 Enables unit tests for TTM, a GPU memory manager subsystem used 260 to manage memory buffers. This option is mostly useful for kernel 261 developers. It depends on (UML || COMPILE_TEST) since no other driver 262 which uses TTM can be loaded while running the tests. 263 264 If in doubt, say "N". 265 266config DRM_EXEC 267 tristate 268 depends on DRM 269 help 270 Execution context for command submissions 271 272config DRM_GPUVM 273 tristate 274 depends on DRM 275 select DRM_EXEC 276 help 277 GPU-VM representation providing helpers to manage a GPUs virtual 278 address space 279 280config DRM_BUDDY 281 tristate 282 depends on DRM 283 help 284 A page based buddy allocator 285 286config DRM_VRAM_HELPER 287 tristate 288 depends on DRM 289 help 290 Helpers for VRAM memory management 291 292config DRM_TTM_HELPER 293 tristate 294 depends on DRM 295 select DRM_TTM 296 select FB_SYSMEM_HELPERS_DEFERRED if DRM_FBDEV_EMULATION 297 help 298 Helpers for ttm-based gem objects 299 300config DRM_GEM_DMA_HELPER 301 tristate 302 depends on DRM 303 select FB_DMAMEM_HELPERS_DEFERRED if DRM_FBDEV_EMULATION 304 help 305 Choose this if you need the GEM DMA helper functions 306 307config DRM_GEM_SHMEM_HELPER 308 tristate 309 depends on DRM && MMU 310 select FB_SYSMEM_HELPERS_DEFERRED if DRM_FBDEV_EMULATION 311 help 312 Choose this if you need the GEM shmem helper functions 313 314config DRM_SUBALLOC_HELPER 315 tristate 316 depends on DRM 317 318config DRM_SCHED 319 tristate 320 depends on DRM 321 322source "drivers/gpu/drm/i2c/Kconfig" 323 324source "drivers/gpu/drm/arm/Kconfig" 325 326source "drivers/gpu/drm/radeon/Kconfig" 327 328source "drivers/gpu/drm/amd/amdgpu/Kconfig" 329 330source "drivers/gpu/drm/nouveau/Kconfig" 331 332source "drivers/gpu/drm/i915/Kconfig" 333 334source "drivers/gpu/drm/xe/Kconfig" 335 336source "drivers/gpu/drm/kmb/Kconfig" 337 338config DRM_VGEM 339 tristate "Virtual GEM provider" 340 depends on DRM && MMU 341 select DRM_GEM_SHMEM_HELPER 342 help 343 Choose this option to get a virtual graphics memory manager, 344 as used by Mesa's software renderer for enhanced performance. 345 If M is selected the module will be called vgem. 346 347source "drivers/gpu/drm/vkms/Kconfig" 348 349source "drivers/gpu/drm/exynos/Kconfig" 350 351source "drivers/gpu/drm/rockchip/Kconfig" 352 353source "drivers/gpu/drm/vmwgfx/Kconfig" 354 355source "drivers/gpu/drm/gma500/Kconfig" 356 357source "drivers/gpu/drm/udl/Kconfig" 358 359source "drivers/gpu/drm/ast/Kconfig" 360 361source "drivers/gpu/drm/mgag200/Kconfig" 362 363source "drivers/gpu/drm/armada/Kconfig" 364 365source "drivers/gpu/drm/atmel-hlcdc/Kconfig" 366 367source "drivers/gpu/drm/renesas/Kconfig" 368 369source "drivers/gpu/drm/sun4i/Kconfig" 370 371source "drivers/gpu/drm/omapdrm/Kconfig" 372 373source "drivers/gpu/drm/tilcdc/Kconfig" 374 375source "drivers/gpu/drm/qxl/Kconfig" 376 377source "drivers/gpu/drm/virtio/Kconfig" 378 379source "drivers/gpu/drm/msm/Kconfig" 380 381source "drivers/gpu/drm/fsl-dcu/Kconfig" 382 383source "drivers/gpu/drm/tegra/Kconfig" 384 385source "drivers/gpu/drm/stm/Kconfig" 386 387source "drivers/gpu/drm/panel/Kconfig" 388 389source "drivers/gpu/drm/bridge/Kconfig" 390 391source "drivers/gpu/drm/sti/Kconfig" 392 393source "drivers/gpu/drm/imx/Kconfig" 394 395source "drivers/gpu/drm/ingenic/Kconfig" 396 397source "drivers/gpu/drm/v3d/Kconfig" 398 399source "drivers/gpu/drm/vc4/Kconfig" 400 401source "drivers/gpu/drm/loongson/Kconfig" 402 403source "drivers/gpu/drm/etnaviv/Kconfig" 404 405source "drivers/gpu/drm/hisilicon/Kconfig" 406 407source "drivers/gpu/drm/logicvc/Kconfig" 408 409source "drivers/gpu/drm/mediatek/Kconfig" 410 411source "drivers/gpu/drm/mxsfb/Kconfig" 412 413source "drivers/gpu/drm/meson/Kconfig" 414 415source "drivers/gpu/drm/tiny/Kconfig" 416 417source "drivers/gpu/drm/pl111/Kconfig" 418 419source "drivers/gpu/drm/tve200/Kconfig" 420 421source "drivers/gpu/drm/xen/Kconfig" 422 423source "drivers/gpu/drm/vboxvideo/Kconfig" 424 425source "drivers/gpu/drm/lima/Kconfig" 426 427source "drivers/gpu/drm/panfrost/Kconfig" 428 429source "drivers/gpu/drm/panthor/Kconfig" 430 431source "drivers/gpu/drm/aspeed/Kconfig" 432 433source "drivers/gpu/drm/mcde/Kconfig" 434 435source "drivers/gpu/drm/tidss/Kconfig" 436 437source "drivers/gpu/drm/xlnx/Kconfig" 438 439source "drivers/gpu/drm/gud/Kconfig" 440 441source "drivers/gpu/drm/solomon/Kconfig" 442 443source "drivers/gpu/drm/sprd/Kconfig" 444 445source "drivers/gpu/drm/imagination/Kconfig" 446 447config DRM_HYPERV 448 tristate "DRM Support for Hyper-V synthetic video device" 449 depends on DRM && PCI && MMU && HYPERV 450 select DRM_CLIENT_SELECTION 451 select DRM_KMS_HELPER 452 select DRM_GEM_SHMEM_HELPER 453 help 454 This is a KMS driver for Hyper-V synthetic video device. Choose this 455 option if you would like to enable drm driver for Hyper-V virtual 456 machine. Unselect Hyper-V framebuffer driver (CONFIG_FB_HYPERV) so 457 that DRM driver is used by default. 458 459 If M is selected the module will be called hyperv_drm. 460 461config DRM_EXPORT_FOR_TESTS 462 bool 463 464# Separate option as not all DRM drivers use it 465config DRM_PANEL_BACKLIGHT_QUIRKS 466 tristate 467 468config DRM_LIB_RANDOM 469 bool 470 default n 471 472config DRM_PRIVACY_SCREEN 473 bool 474 default n 475 476config DRM_WERROR 477 bool "Compile the drm subsystem with warnings as errors" 478 depends on DRM && EXPERT 479 depends on !WERROR 480 default n 481 help 482 A kernel build should not cause any compiler warnings, and this 483 enables the '-Werror' flag to enforce that rule in the drm subsystem. 484 485 The drm subsystem enables more warnings than the kernel default, so 486 this config option is disabled by default. 487 488 If in doubt, say N. 489 490endif 491 492# Separate option because drm_panel_orientation_quirks.c is shared with fbdev 493config DRM_PANEL_ORIENTATION_QUIRKS 494 tristate 495