1# 2# Video configuration 3# 4 5menu "Graphics support" 6 7config DM_VIDEO 8 bool "Enable driver model support for LCD/video" 9 depends on DM 10 help 11 This enables driver model for LCD and video devices. These support 12 a bitmap display of various sizes and depths which can be drawn on 13 to display a command-line console or splash screen. Enabling this 14 option compiles in the video uclass and routes all LCD/video access 15 through this. 16 17config VIDEO_BPP8 18 bool "Support 8-bit-per-pixel displays" 19 depends on DM_VIDEO 20 default y if DM_VIDEO 21 help 22 Support drawing text and bitmaps onto a 8-bit-per-pixel display. 23 Enabling this will include code to support this display. Without 24 this option, such displays will not be supported and console output 25 will be empty. 26 27config VIDEO_BPP16 28 bool "Support 16-bit-per-pixel displays" 29 depends on DM_VIDEO 30 default y if DM_VIDEO 31 help 32 Support drawing text and bitmaps onto a 16-bit-per-pixel display. 33 Enabling this will include code to support this display. Without 34 this option, such displays will not be supported and console output 35 will be empty. 36 37config VIDEO_BPP32 38 bool "Support 32-bit-per-pixel displays" 39 depends on DM_VIDEO 40 default y if DM_VIDEO 41 help 42 Support drawing text and bitmaps onto a 32-bit-per-pixel display. 43 Enabling this will include code to support this display. Without 44 this option, such displays will not be supported and console output 45 will be empty. 46 47config CONSOLE_NORMAL 48 bool "Support a simple text console" 49 depends on DM_VIDEO 50 default y if DM_VIDEO 51 help 52 Support drawing text on the frame buffer console so that it can be 53 used as a console. Rotation is not supported by this driver (see 54 CONFIG_CONSOLE_ROTATION for that). A built-in 8x16 font is used 55 for the display. 56 57config CONSOLE_ROTATION 58 bool "Support rotated displays" 59 depends on DM_VIDEO 60 help 61 Sometimes, for example if the display is mounted in portrait 62 mode or even if it's mounted landscape but rotated by 180degree, 63 we need to rotate our content of the display relative to the 64 framebuffer, so that user can read the messages which are 65 printed out. Enable this option to include a text driver which can 66 support this. The rotation is set by the 'rot' parameter in 67 struct video_priv: 0=unrotated, 1=90 degrees clockwise, 2=180 68 degrees, 3=270 degrees. 69 70config CONSOLE_TRUETYPE 71 bool "Support a console that uses TrueType fonts" 72 depends on DM_VIDEO 73 help 74 TrueTrype fonts can provide outline-drawing capability rather than 75 needing to provide a bitmap for each font and size that is needed. 76 With this option you can adjust the text size and use a variety of 77 fonts. Note that this is noticeably slower than with normal console. 78 79config CONSOLE_TRUETYPE_SIZE 80 int "TrueType font size" 81 depends on CONSOLE_TRUETYPE 82 default 18 83 help 84 This sets the font size for the console. The size is measured in 85 pixels and is the nominal height of a character. Note that fonts 86 are commonly measured in 'points', being 1/72 inch (about 3.52mm). 87 However that measurement depends on the size of your display and 88 there is no standard display density. At present there is not a 89 method to select the display's physical size, which would allow 90 U-Boot to calculate the correct font size. 91 92source "drivers/video/fonts/Kconfig" 93 94config VIDCONSOLE_AS_LCD 95 bool "Use 'vidconsole' when 'lcd' is seen in stdout" 96 depends on DM_VIDEO 97 help 98 This is a work-around for boards which have 'lcd' in their stdout 99 environment variable, but have moved to use driver model for video. 100 In this case the console will no-longer work. While it is possible 101 to update the environment, the breakage may be confusing for users. 102 This option will be removed around the end of 2016. 103 104config VIDEO_COREBOOT 105 bool "Enable coreboot framebuffer driver support" 106 depends on X86 && SYS_COREBOOT 107 help 108 Turn on this option to enable a framebuffer driver when U-Boot is 109 loaded by coreboot where the graphics device is configured by 110 coreboot already. This can in principle be used with any platform 111 that coreboot supports. 112 113config VIDEO_VESA 114 bool "Enable VESA video driver support" 115 default n 116 help 117 Turn on this option to enable a very simple driver which uses vesa 118 to discover the video mode and then provides a frame buffer for use 119 by U-Boot. This can in principle be used with any platform that 120 supports PCI and video cards that support VESA BIOS Extension (VBE). 121 122config FRAMEBUFFER_SET_VESA_MODE 123 bool "Set framebuffer graphics resolution" 124 depends on VIDEO_VESA || VIDEO_BROADWELL_IGD 125 help 126 Set VESA/native framebuffer mode (needed for bootsplash and graphical 127 framebuffer console) 128 129choice 130 prompt "framebuffer graphics resolution" 131 default FRAMEBUFFER_VESA_MODE_117 132 depends on FRAMEBUFFER_SET_VESA_MODE 133 help 134 This option sets the resolution used for the U-Boot framebuffer (and 135 bootsplash screen). 136 137config FRAMEBUFFER_VESA_MODE_100 138 bool "640x400 256-color" 139 140config FRAMEBUFFER_VESA_MODE_101 141 bool "640x480 256-color" 142 143config FRAMEBUFFER_VESA_MODE_102 144 bool "800x600 16-color" 145 146config FRAMEBUFFER_VESA_MODE_103 147 bool "800x600 256-color" 148 149config FRAMEBUFFER_VESA_MODE_104 150 bool "1024x768 16-color" 151 152config FRAMEBUFFER_VESA_MODE_105 153 bool "1024x768 256-color" 154 155config FRAMEBUFFER_VESA_MODE_106 156 bool "1280x1024 16-color" 157 158config FRAMEBUFFER_VESA_MODE_107 159 bool "1280x1024 256-color" 160 161config FRAMEBUFFER_VESA_MODE_108 162 bool "80x60 text" 163 164config FRAMEBUFFER_VESA_MODE_109 165 bool "132x25 text" 166 167config FRAMEBUFFER_VESA_MODE_10A 168 bool "132x43 text" 169 170config FRAMEBUFFER_VESA_MODE_10B 171 bool "132x50 text" 172 173config FRAMEBUFFER_VESA_MODE_10C 174 bool "132x60 text" 175 176config FRAMEBUFFER_VESA_MODE_10D 177 bool "320x200 32k-color (1:5:5:5)" 178 179config FRAMEBUFFER_VESA_MODE_10E 180 bool "320x200 64k-color (5:6:5)" 181 182config FRAMEBUFFER_VESA_MODE_10F 183 bool "320x200 16.8M-color (8:8:8)" 184 185config FRAMEBUFFER_VESA_MODE_110 186 bool "640x480 32k-color (1:5:5:5)" 187 188config FRAMEBUFFER_VESA_MODE_111 189 bool "640x480 64k-color (5:6:5)" 190 191config FRAMEBUFFER_VESA_MODE_112 192 bool "640x480 16.8M-color (8:8:8)" 193 194config FRAMEBUFFER_VESA_MODE_113 195 bool "800x600 32k-color (1:5:5:5)" 196 197config FRAMEBUFFER_VESA_MODE_114 198 bool "800x600 64k-color (5:6:5)" 199 200config FRAMEBUFFER_VESA_MODE_115 201 bool "800x600 16.8M-color (8:8:8)" 202 203config FRAMEBUFFER_VESA_MODE_116 204 bool "1024x768 32k-color (1:5:5:5)" 205 206config FRAMEBUFFER_VESA_MODE_117 207 bool "1024x768 64k-color (5:6:5)" 208 209config FRAMEBUFFER_VESA_MODE_118 210 bool "1024x768 16.8M-color (8:8:8)" 211 212config FRAMEBUFFER_VESA_MODE_119 213 bool "1280x1024 32k-color (1:5:5:5)" 214 215config FRAMEBUFFER_VESA_MODE_11A 216 bool "1280x1024 64k-color (5:6:5)" 217 218config FRAMEBUFFER_VESA_MODE_11B 219 bool "1280x1024 16.8M-color (8:8:8)" 220 221config FRAMEBUFFER_VESA_MODE_USER 222 bool "Manually select VESA mode" 223 224endchoice 225 226# Map the config names to an integer (KB). 227config FRAMEBUFFER_VESA_MODE 228 prompt "VESA mode" if FRAMEBUFFER_VESA_MODE_USER 229 hex 230 default 0x100 if FRAMEBUFFER_VESA_MODE_100 231 default 0x101 if FRAMEBUFFER_VESA_MODE_101 232 default 0x102 if FRAMEBUFFER_VESA_MODE_102 233 default 0x103 if FRAMEBUFFER_VESA_MODE_103 234 default 0x104 if FRAMEBUFFER_VESA_MODE_104 235 default 0x105 if FRAMEBUFFER_VESA_MODE_105 236 default 0x106 if FRAMEBUFFER_VESA_MODE_106 237 default 0x107 if FRAMEBUFFER_VESA_MODE_107 238 default 0x108 if FRAMEBUFFER_VESA_MODE_108 239 default 0x109 if FRAMEBUFFER_VESA_MODE_109 240 default 0x10A if FRAMEBUFFER_VESA_MODE_10A 241 default 0x10B if FRAMEBUFFER_VESA_MODE_10B 242 default 0x10C if FRAMEBUFFER_VESA_MODE_10C 243 default 0x10D if FRAMEBUFFER_VESA_MODE_10D 244 default 0x10E if FRAMEBUFFER_VESA_MODE_10E 245 default 0x10F if FRAMEBUFFER_VESA_MODE_10F 246 default 0x110 if FRAMEBUFFER_VESA_MODE_110 247 default 0x111 if FRAMEBUFFER_VESA_MODE_111 248 default 0x112 if FRAMEBUFFER_VESA_MODE_112 249 default 0x113 if FRAMEBUFFER_VESA_MODE_113 250 default 0x114 if FRAMEBUFFER_VESA_MODE_114 251 default 0x115 if FRAMEBUFFER_VESA_MODE_115 252 default 0x116 if FRAMEBUFFER_VESA_MODE_116 253 default 0x117 if FRAMEBUFFER_VESA_MODE_117 254 default 0x118 if FRAMEBUFFER_VESA_MODE_118 255 default 0x119 if FRAMEBUFFER_VESA_MODE_119 256 default 0x11A if FRAMEBUFFER_VESA_MODE_11A 257 default 0x11B if FRAMEBUFFER_VESA_MODE_11B 258 default 0x117 if FRAMEBUFFER_VESA_MODE_USER 259 260config VIDEO_LCD_ANX9804 261 bool "ANX9804 bridge chip" 262 default n 263 ---help--- 264 Support for the ANX9804 bridge chip, which can take pixel data coming 265 from a parallel LCD interface and translate it on the fy into a DP 266 interface for driving eDP TFT displays. It uses I2C for configuration. 267 268config VIDEO_LCD_SSD2828 269 bool "SSD2828 bridge chip" 270 default n 271 ---help--- 272 Support for the SSD2828 bridge chip, which can take pixel data coming 273 from a parallel LCD interface and translate it on the fly into MIPI DSI 274 interface for driving a MIPI compatible LCD panel. It uses SPI for 275 configuration. 276 277config VIDEO_LCD_SSD2828_TX_CLK 278 int "SSD2828 TX_CLK frequency (in MHz)" 279 depends on VIDEO_LCD_SSD2828 280 default 0 281 ---help--- 282 The frequency of the crystal, which is clocking SSD2828. It may be 283 anything in the 8MHz-30MHz range and the exact value should be 284 retrieved from the board schematics. Or in the case of Allwinner 285 hardware, it can be usually found as 'lcd_xtal_freq' variable in 286 FEX files. It can be also set to 0 for selecting PCLK from the 287 parallel LCD interface instead of TX_CLK as the PLL clock source. 288 289config VIDEO_LCD_SSD2828_RESET 290 string "RESET pin of SSD2828" 291 depends on VIDEO_LCD_SSD2828 292 default "" 293 ---help--- 294 The reset pin of SSD2828 chip. This takes a string in the format 295 understood by 'name_to_gpio' function, e.g. PH1 for pin 1 of port H. 296 297config VIDEO_LCD_HITACHI_TX18D42VM 298 bool "Hitachi tx18d42vm LVDS LCD panel support" 299 depends on VIDEO 300 default n 301 ---help--- 302 Support for Hitachi tx18d42vm LVDS LCD panels, these panels have a 303 lcd controller which needs to be initialized over SPI, once that is 304 done they work like a regular LVDS panel. 305 306config VIDEO_LCD_SPI_CS 307 string "SPI CS pin for LCD related config job" 308 depends on VIDEO_LCD_SSD2828 || VIDEO_LCD_HITACHI_TX18D42VM 309 default "" 310 ---help--- 311 This is one of the SPI communication pins, involved in setting up a 312 working LCD configuration. The exact role of SPI may differ for 313 different hardware setups. The option takes a string in the format 314 understood by 'name_to_gpio' function, e.g. PH1 for pin 1 of port H. 315 316config VIDEO_LCD_SPI_SCLK 317 string "SPI SCLK pin for LCD related config job" 318 depends on VIDEO_LCD_SSD2828 || VIDEO_LCD_HITACHI_TX18D42VM 319 default "" 320 ---help--- 321 This is one of the SPI communication pins, involved in setting up a 322 working LCD configuration. The exact role of SPI may differ for 323 different hardware setups. The option takes a string in the format 324 understood by 'name_to_gpio' function, e.g. PH1 for pin 1 of port H. 325 326config VIDEO_LCD_SPI_MOSI 327 string "SPI MOSI pin for LCD related config job" 328 depends on VIDEO_LCD_SSD2828 || VIDEO_LCD_HITACHI_TX18D42VM 329 default "" 330 ---help--- 331 This is one of the SPI communication pins, involved in setting up a 332 working LCD configuration. The exact role of SPI may differ for 333 different hardware setups. The option takes a string in the format 334 understood by 'name_to_gpio' function, e.g. PH1 for pin 1 of port H. 335 336config VIDEO_LCD_SPI_MISO 337 string "SPI MISO pin for LCD related config job (optional)" 338 depends on VIDEO_LCD_SSD2828 339 default "" 340 ---help--- 341 This is one of the SPI communication pins, involved in setting up a 342 working LCD configuration. The exact role of SPI may differ for 343 different hardware setups. If wired up, this pin may provide additional 344 useful functionality. Such as bi-directional communication with the 345 hardware and LCD panel id retrieval (if the panel can report it). The 346 option takes a string in the format understood by 'name_to_gpio' 347 function, e.g. PH1 for pin 1 of port H. 348 349config VIDEO_MVEBU 350 bool "Armada XP LCD controller" 351 default n 352 ---help--- 353 Support for the LCD controller integrated in the Marvell 354 Armada XP SoC. 355 356config I2C_EDID 357 bool "Enable EDID library" 358 depends on DM_I2C 359 default n 360 help 361 This enables library for accessing EDID data from an LCD panel. 362 363config DISPLAY 364 bool "Enable Display support" 365 depends on DM 366 default n 367 select I2C_EDID 368 help 369 This supports drivers that provide a display, such as eDP (Embedded 370 DisplayPort) and HDMI (High Definition Multimedia Interface). 371 The devices provide a simple interface to start up the display, 372 read display information and enable it. 373 374config VIDEO_BROADWELL_IGD 375 bool "Enable Intel Broadwell integrated graphics device" 376 depends on X86 377 help 378 This enables support for integrated graphics on Intel broadwell 379 devices. Initialisation is mostly performed by a VGA boot ROM, with 380 some setup handled by U-Boot itself. The graphics adaptor works as 381 a VESA device and supports LCD panels, eDP and LVDS outputs. 382 Configuration of most aspects of device operation is performed using 383 a special tool which configures the VGA ROM, but the graphics 384 resolution can be selected in U-Boot. 385 386config VIDEO_IVYBRIDGE_IGD 387 bool "Enable Intel Ivybridge integration graphics support" 388 depends on X86 389 help 390 This enables support for integrated graphics on Intel ivybridge 391 devices. Initialisation is mostly performed by a VGA boot ROM, with 392 some setup handled by U-Boot itself. The graphics adaptor works as 393 a VESA device and supports LCD panels, eDP and LVDS outputs. 394 Configuration of most aspects of device operation is performed using 395 a special tool which configures the VGA ROM, but the graphics 396 resolution can be selected in U-Boot. 397 398config VIDEO_ROCKCHIP 399 bool "Enable Rockchip video support" 400 depends on DM_VIDEO 401 help 402 Rockchip SoCs provide video output capabilities for High-Definition 403 Multimedia Interface (HDMI), Low-voltage Differential Signalling 404 (LVDS), embedded DisplayPort (eDP) and Display Serial Interface 405 (DSI). This driver supports the on-chip video output device, and 406 targets the Rockchip RK3288. 407 408config VIDEO_SANDBOX_SDL 409 bool "Enable sandbox video console using SDL" 410 depends on SANDBOX 411 help 412 When using sandbox you can enable an emulated LCD display which 413 appears as an SDL (Simple DirectMedia Layer) window. This is a 414 console device and can display stdout output. Within U-Boot is is 415 a normal bitmap display and can display images as well as text. 416 417config VIDEO_TEGRA20 418 bool "Enable LCD support on Tegra20" 419 depends on OF_CONTROL 420 help 421 Tegra20 supports video output to an attached LCD panel as well as 422 other options such as HDMI. Only the LCD is supported in U-Boot. 423 This option enables this support which can be used on devices which 424 have an LCD display connected. 425 426config VIDEO_TEGRA124 427 bool "Enable video support on Tegra124" 428 depends on DM_VIDEO 429 help 430 Tegra124 supports many video output options including eDP and 431 HDMI. At present only eDP is supported by U-Boot. This option 432 enables this support which can be used on devices which 433 have an eDP display connected. 434 435source "drivers/video/bridge/Kconfig" 436 437config VIDEO 438 bool "Enable legacy video support" 439 depends on !DM_VIDEO 440 help 441 Define this for video support, without using driver model. Some 442 drivers use this because they are not yet converted to driver 443 model. Video drivers typically provide a colour text console and 444 cursor. 445 446config VIDEO_IPUV3 447 bool "i.MX IPUv3 Core video support" 448 depends on VIDEO && MX6 449 help 450 This enables framebuffer driver for i.MX processors working 451 on the IPUv3(Image Processing Unit) internal graphic processor. 452 453config CFB_CONSOLE 454 bool "Enable colour frame buffer console" 455 depends on VIDEO 456 default y if VIDEO 457 help 458 Enables the colour frame buffer driver. This supports colour 459 output on a bitmap display from an in-memory frame buffer. 460 Several colour devices are supported along with various options to 461 adjust the supported features. The driver is implemented in 462 cfb_console.c 463 464 The following defines are needed (cf. smiLynxEM, i8042) 465 VIDEO_FB_LITTLE_ENDIAN graphic memory organisation 466 (default big endian) 467 VIDEO_HW_RECTFILL graphic chip supports 468 rectangle fill (cf. smiLynxEM) 469 VIDEO_HW_BITBLT graphic chip supports 470 bit-blit (cf. smiLynxEM) 471 VIDEO_VISIBLE_COLS visible pixel columns (cols=pitch) 472 VIDEO_VISIBLE_ROWS visible pixel rows 473 VIDEO_PIXEL_SIZE bytes per pixel 474 VIDEO_DATA_FORMAT graphic data format 475 (0-5, cf. cfb_console.c) 476 VIDEO_FB_ADRS framebuffer address 477 VIDEO_KBD_INIT_FCT keyboard int fct (i.e. rx51_kp_init()) 478 VIDEO_TSTC_FCT test char fct (i.e. rx51_kp_tstc) 479 VIDEO_GETC_FCT get char fct (i.e. rx51_kp_getc) 480 CONFIG_VIDEO_LOGO display Linux logo in upper left corner 481 CONFIG_VIDEO_BMP_LOGO use bmp_logo.h instead of linux_logo.h 482 for logo. Requires CONFIG_VIDEO_LOGO 483 CONFIG_CONSOLE_EXTRA_INFO 484 additional board info beside 485 the logo 486 CONFIG_HIDE_LOGO_VERSION 487 do not display bootloader 488 version string 489 490 When CONFIG_CFB_CONSOLE is defined, the video console is the 491 default console. The serial console can be forced by setting the 492 environment 'console=serial'. 493 494config CFB_CONSOLE_ANSI 495 bool "Support ANSI escape sequences" 496 depends on CFB_CONSOLE 497 help 498 This allows the colour buffer frame buffer driver to support 499 a limited number of ANSI escape sequences (cursor control, 500 erase functions and limited graphics rendition control). Normal 501 output from U-Boot will pass through this filter. 502 503config VGA_AS_SINGLE_DEVICE 504 bool "Set the video as an output-only device" 505 depends on CFB_CONSOLE 506 default y 507 help 508 If enable the framebuffer device will be initialized as an 509 output-only device. The Keyboard driver will not be set up. This 510 may be used if you have no keyboard device, or more than one 511 (USB Keyboard, AT Keyboard). 512 513config VIDEO_SW_CURSOR 514 bool "Enable a software cursor" 515 depends on CFB_CONSOLE 516 default y if CFB_CONSOLE 517 help 518 This draws a cursor after the last character. No blinking is 519 provided. This makes it possible to see the current cursor 520 position when entering text on the console. It is recommended to 521 enable this. 522 523config CONSOLE_EXTRA_INFO 524 bool "Display additional board information" 525 depends on CFB_CONSOLE 526 help 527 Display additional board information strings that normally go to 528 the serial port. When this option is enabled, a board-specific 529 function video_get_info_str() is called to get the string for 530 each line of the display. The function should return the string, 531 which can be empty if there is nothing to display for that line. 532 533config CONSOLE_SCROLL_LINES 534 int "Number of lines to scroll the console by" 535 depends on CFB_CONSOLE || DM_VIDEO || LCD 536 default 1 537 help 538 When the console need to be scrolled, this is the number of 539 lines to scroll by. It defaults to 1. Increasing this makes the 540 console jump but can help speed up operation when scrolling 541 is slow. 542 543config VIDEO_CT69000 544 bool "Enable Chips & Technologies 69000 video driver" 545 depends on VIDEO 546 help 547 This enables a frame buffer driver for the Chips & Technologies 548 ct69000, a fairly old graphics device (circa 2000) which is used 549 on some hardware. It operates over the ISA bus, and supports 550 some acceleration features. 551 552 For the CT69000 and SMI_LYNXEM drivers, videomode is 553 selected via environment 'videomode'. Two different ways 554 are possible: 555 - "videomode=num" 'num' is a standard LiLo mode numbers. 556 Following standard modes are supported (* is default): 557 558 Colors 640x480 800x600 1024x768 1152x864 1280x1024 559 -------------+--------------------------------------------- 560 8 bits | 0x301* 0x303 0x305 0x161 0x307 561 15 bits | 0x310 0x313 0x316 0x162 0x319 562 16 bits | 0x311 0x314 0x317 0x163 0x31A 563 24 bits | 0x312 0x315 0x318 ? 0x31B 564 -------------+--------------------------------------------- 565 (i.e. setenv videomode 317; saveenv; reset;) 566 567 - "videomode=bootargs" all the video parameters are parsed 568 from the bootargs. (See drivers/video/videomodes.c) 569 570config SYS_CONSOLE_BG_COL 571 hex "Background colour" 572 depends on CFB_CONSOLE || VIDEO_CT69000 573 default 0x00 574 help 575 Defines the background colour for the console. The value is from 576 0x00 to 0xff and the meaning depends on the graphics card. 577 Typically, 0x00 means black and 0xff means white. Do not set 578 the background and foreground to the same colour or you will see 579 nothing. 580 581config SYS_CONSOLE_FG_COL 582 hex "Foreground colour" 583 depends on CFB_CONSOLE || VIDEO_CT69000 584 default 0xa0 585 help 586 Defines the foreground colour for the console. The value is from 587 0x00 to 0xff and the meaning depends on the graphics card. 588 Typically, 0x00 means black and 0xff means white. Do not set 589 the background and foreground to the same colour or you will see 590 nothing. 591 592config LCD 593 bool "Enable legacy LCD support" 594 help 595 Define this to enable LCD support (for output to LCD display). 596 You will also need to select an LCD driver using an additional 597 CONFIG option. See the README for details. Drives which have been 598 converted to driver model will instead used CONFIG_DM_VIDEO. 599 600endmenu 601