blob: 2be73d53968828bb400ab04212f24b4f0a5a9331 [file] [log] [blame]
Masahiro Yamadacc85b7b2015-07-26 02:46:26 +09001#
2# Video configuration
3#
4
5menu "Graphics support"
6
Simon Glass52cb5042022-10-18 07:46:31 -06007config VIDEO
Simon Glass623d28f2016-01-18 19:52:15 -07008 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
Simon Glass52cb5042022-10-18 07:46:31 -060017if VIDEO
Simon Glass557786c2022-10-18 07:35:17 -060018
Dzmitry Sankouski7fa964a2023-03-07 13:21:14 +030019config VIDEO_FONT_4X6
20 bool "4 x 6 font size"
21 help
22 Font for video console driver, 4 x 6 pixels.
23 Provides character bitmap data in header file.
24 When selecting multiple fonts, you may want to enable CMD_SELECT_FONT too.
25
26config VIDEO_FONT_8X16
27 bool "8 x 16 font size"
28 default y
29 help
30 Font for video console driver, 8 x 16 pixels
31 Provides character bitmap data in header file.
32 When selecting multiple fonts, you may want to enable CMD_SELECT_FONT too.
33
Dzmitry Sankouski7932a992023-02-27 20:37:07 +030034config VIDEO_FONT_SUN12X22
35 bool "12 x 22 font size"
36 help
37 Font for video console driver, 12 x 22 pixels
38 Provides character bitmap data in header file.
39 When selecting multiple fonts, you may want to enable CMD_SELECT_FONT too.
40
Dzmitry Sankouskiefadfde2023-02-27 20:37:08 +030041config VIDEO_FONT_16X32
42 bool "16 x 32 font size"
43 help
44 Font for video console driver, 16 x 32 pixels
45 Provides character bitmap data in header file.
46 When selecting multiple fonts, you may want to enable CMD_SELECT_FONT too.
47
Simon Glass8e5a8b62021-11-19 13:24:01 -070048config VIDEO_LOGO
49 bool "Show the U-Boot logo on the display"
Simon Glass7a6528592021-11-19 13:24:04 -070050 default y if !SPLASH_SCREEN
Simon Glass87a3cd72021-11-19 13:24:03 -070051 select VIDEO_BMP_RLE8
Simon Glass8e5a8b62021-11-19 13:24:01 -070052 help
53 This enables showing the U-Boot logo on the display when a video
54 device is probed. It appears at the top right. The logo itself is at
55 tools/logos/u-boot_logo.bmp and looks best when the display has a
56 black background.
57
Anatolij Gustschin0dcb3fd2020-05-26 00:20:49 +020058config BACKLIGHT
59 bool "Enable panel backlight uclass support"
Anatolij Gustschin0dcb3fd2020-05-26 00:20:49 +020060 default y
61 help
62 This provides backlight uclass driver that enables basic panel
63 backlight support.
64
Simon Glassc3d2f352020-07-02 21:12:33 -060065config VIDEO_PCI_DEFAULT_FB_SIZE
66 hex "Default framebuffer size to use if no drivers request it"
Simon Glassc3d2f352020-07-02 21:12:33 -060067 default 0x1000000 if X86 && PCI
68 default 0 if !(X86 && PCI)
69 help
70 Generally, video drivers request the amount of memory they need for
71 the frame buffer when they are bound, by setting the size field in
Dario Binacchi2ec85772021-01-23 19:43:52 +010072 struct video_uc_plat. That memory is then reserved for use after
Simon Glassc3d2f352020-07-02 21:12:33 -060073 relocation. But PCI drivers cannot be bound before relocation unless
74 they are mentioned in the devicetree.
75
76 With this value set appropriately, it is possible for PCI video
77 devices to have a framebuffer allocated by U-Boot.
78
79 Note: the framebuffer needs to be large enough to store all pixels at
80 maximum resolution. For example, at 1920 x 1200 with 32 bits per
81 pixel, 2560 * 1600 * 32 / 8 = 0xfa0000 bytes are needed.
82
Simon Glass73c9c372020-07-02 21:12:20 -060083config VIDEO_COPY
84 bool "Enable copying the frame buffer to a hardware copy"
Simon Glass73c9c372020-07-02 21:12:20 -060085 help
86 On some machines (e.g. x86), reading from the frame buffer is very
87 slow because it is uncached. To improve performance, this feature
88 allows the frame buffer to be kept in cached memory (allocated by
89 U-Boot) and then copied to the hardware frame-buffer as needed.
90
91 To use this, your video driver must set @copy_base in
Dario Binacchi2ec85772021-01-23 19:43:52 +010092 struct video_uc_plat.
Simon Glass73c9c372020-07-02 21:12:20 -060093
Patrick Delaunay4300f072017-08-03 12:36:06 +020094config BACKLIGHT_PWM
95 bool "Generic PWM based Backlight Driver"
Anatolij Gustschin0dcb3fd2020-05-26 00:20:49 +020096 depends on BACKLIGHT && DM_PWM
Patrick Delaunay4300f072017-08-03 12:36:06 +020097 default y
98 help
99 If you have a LCD backlight adjustable by PWM, say Y to enable
100 this driver.
101 This driver can be use with "simple-panel" and
102 it understands the standard device tree
103 (leds/backlight/pwm-backlight.txt)
104
Patrick Delaunaya3c046f2017-08-03 12:36:07 +0200105config BACKLIGHT_GPIO
106 bool "Generic GPIO based Backlight Driver"
Anatolij Gustschin0dcb3fd2020-05-26 00:20:49 +0200107 depends on BACKLIGHT
Patrick Delaunaya3c046f2017-08-03 12:36:07 +0200108 help
109 If you have a LCD backlight adjustable by GPIO, say Y to enable
110 this driver.
111 This driver can be used with "simple-panel" and
112 it understands the standard device tree
113 (leds/backlight/gpio-backlight.txt)
114
Simon Glass623d28f2016-01-18 19:52:15 -0700115config VIDEO_BPP8
116 bool "Support 8-bit-per-pixel displays"
Anatolij Gustschindba36702020-02-04 22:43:06 +0100117 default y
Simon Glass623d28f2016-01-18 19:52:15 -0700118 help
119 Support drawing text and bitmaps onto a 8-bit-per-pixel display.
120 Enabling this will include code to support this display. Without
121 this option, such displays will not be supported and console output
122 will be empty.
123
124config VIDEO_BPP16
125 bool "Support 16-bit-per-pixel displays"
Anatolij Gustschindba36702020-02-04 22:43:06 +0100126 default y
Simon Glass623d28f2016-01-18 19:52:15 -0700127 help
128 Support drawing text and bitmaps onto a 16-bit-per-pixel display.
129 Enabling this will include code to support this display. Without
130 this option, such displays will not be supported and console output
131 will be empty.
132
133config VIDEO_BPP32
134 bool "Support 32-bit-per-pixel displays"
Anatolij Gustschindba36702020-02-04 22:43:06 +0100135 default y
Simon Glass623d28f2016-01-18 19:52:15 -0700136 help
137 Support drawing text and bitmaps onto a 32-bit-per-pixel display.
138 Enabling this will include code to support this display. Without
139 this option, such displays will not be supported and console output
140 will be empty.
141
Rob Clark06e7a0d2017-09-13 18:12:21 -0400142config VIDEO_ANSI
143 bool "Support ANSI escape sequences in video console"
Simon Glass80a8e802023-01-06 08:52:29 -0600144 default y if EFI_LOADER
Rob Clark06e7a0d2017-09-13 18:12:21 -0400145 help
146 Enable ANSI escape sequence decoding for a more fully functional
Simon Glass80a8e802023-01-06 08:52:29 -0600147 console. Functionality includes changing the text colour and moving
148 the cursor. These date from the 1970s and are still widely used today
149 to control a text terminal. U-Boot implements these by decoding the
150 sequences and performing the appropriate operation.
Rob Clark06e7a0d2017-09-13 18:12:21 -0400151
Yannick Fertréd08fb322019-10-07 15:29:04 +0200152config VIDEO_MIPI_DSI
153 bool "Support MIPI DSI interface"
Yannick Fertréd08fb322019-10-07 15:29:04 +0200154 help
155 Support MIPI DSI interface for driving a MIPI compatible device.
156 The MIPI Display Serial Interface (MIPI DSI) defines a high-speed
157 serial interface between a host processor and a display module.
158
Simon Glass6e0721d2016-01-22 21:53:37 +0100159config CONSOLE_NORMAL
160 bool "Support a simple text console"
Simon Glass557786c2022-10-18 07:35:17 -0600161 default y
Simon Glass6e0721d2016-01-22 21:53:37 +0100162 help
163 Support drawing text on the frame buffer console so that it can be
164 used as a console. Rotation is not supported by this driver (see
165 CONFIG_CONSOLE_ROTATION for that). A built-in 8x16 font is used
166 for the display.
167
168config CONSOLE_ROTATION
Simon Glass87aae882016-01-18 19:52:19 -0700169 bool "Support rotated displays"
Simon Glass87aae882016-01-18 19:52:19 -0700170 help
171 Sometimes, for example if the display is mounted in portrait
172 mode or even if it's mounted landscape but rotated by 180degree,
173 we need to rotate our content of the display relative to the
174 framebuffer, so that user can read the messages which are
175 printed out. Enable this option to include a text driver which can
176 support this. The rotation is set by the 'rot' parameter in
177 struct video_priv: 0=unrotated, 1=90 degrees clockwise, 2=180
178 degrees, 3=270 degrees.
179
Simon Glass2ef353e2016-01-14 18:10:42 -0700180config CONSOLE_TRUETYPE
181 bool "Support a console that uses TrueType fonts"
Dzmitry Sankouskibb165e42023-03-07 13:21:16 +0300182 select CMD_SELECT_FONT
Simon Glass2ef353e2016-01-14 18:10:42 -0700183 help
184 TrueTrype fonts can provide outline-drawing capability rather than
185 needing to provide a bitmap for each font and size that is needed.
186 With this option you can adjust the text size and use a variety of
187 fonts. Note that this is noticeably slower than with normal console.
188
189config CONSOLE_TRUETYPE_SIZE
190 int "TrueType font size"
191 depends on CONSOLE_TRUETYPE
192 default 18
193 help
194 This sets the font size for the console. The size is measured in
195 pixels and is the nominal height of a character. Note that fonts
196 are commonly measured in 'points', being 1/72 inch (about 3.52mm).
197 However that measurement depends on the size of your display and
198 there is no standard display density. At present there is not a
199 method to select the display's physical size, which would allow
200 U-Boot to calculate the correct font size.
201
Simon Glass79597762022-10-06 08:36:11 -0600202config CONSOLE_TRUETYPE_MAX_METRICS
203 int "TrueType maximum number of font / size combinations"
204 depends on CONSOLE_TRUETYPE
205 default 10 if EXPO
206 default 1
207 help
208 This sets the number of font / size combinations which can be used by
209 the console. For simple console use a single font is enough. When
210 boot menus are in use, this may need to be increased.
211
212 Note that a separate entry is needed for each font size, even if the
213 font itself is the same. This is because the entry caches various
214 font metrics which are expensive to regenerate each time the font
215 size changes.
216
Simon Glassd65a1422017-04-26 22:27:57 -0600217config SYS_WHITE_ON_BLACK
218 bool "Display console as white on a black background"
Trevor Woerner513f6402020-05-06 08:02:41 -0400219 default y if ARCH_AT91 || ARCH_EXYNOS || ARCH_ROCKCHIP || ARCH_TEGRA || X86 || ARCH_SUNXI
Simon Glassd65a1422017-04-26 22:27:57 -0600220 help
221 Normally the display is black on a white background, Enable this
222 option to invert this, i.e. white on a black background. This can be
223 better in low-light situations or to reduce eye strain in some
224 cases.
225
Rob Clarkf1411882017-08-03 12:47:01 -0400226config NO_FB_CLEAR
227 bool "Skip framebuffer clear"
228 help
229 If firmware (whatever loads u-boot) has already put a splash image
230 on screen, you might want to preserve it until whatever u-boot
231 loads takes over the screen. This, for example, can be used to
232 keep splash image on screen until grub graphical boot menu starts.
233
Anatolij Gustschin0dcb3fd2020-05-26 00:20:49 +0200234config PANEL
235 bool "Enable panel uclass support"
Anatolij Gustschin0dcb3fd2020-05-26 00:20:49 +0200236 default y
237 help
238 This provides panel uclass driver that enables basic panel support.
239
240config SIMPLE_PANEL
241 bool "Enable simple panel support"
Asherah Connor81b0f612021-03-03 14:46:47 +1100242 depends on PANEL && BACKLIGHT && DM_GPIO
Anatolij Gustschin0dcb3fd2020-05-26 00:20:49 +0200243 default y
244 help
245 This turns on a simple panel driver that enables a compatible
246 video panel.
247
Simon Glassf8360fe2022-10-06 08:36:07 -0600248config PANEL_HX8238D
249 bool "Enable Himax HX-8238D LCD driver"
250 depends on PANEL
251 help
252 Support for HX-8238D LCD Panel
253 The HX8238-D is a single chip controller and driver LSI that
254 integrates the power circuit.
255 It can drive a maximum 960x240 dot graphics on a-TFT panel
256 displays in 16M colors with dithering.
257
Simon Glass2ef353e2016-01-14 18:10:42 -0700258source "drivers/video/fonts/Kconfig"
259
Simon Glass86f07462016-02-06 14:31:37 -0700260config VIDCONSOLE_AS_LCD
Patrick Delaunay60b92242020-07-01 14:56:10 +0200261 bool "Use 'vidconsole' when CONFIG_VIDCONSOLE_AS_NAME string is seen in stdout"
Patrick Delaunay60b92242020-07-01 14:56:10 +0200262 help
263 This is a work-around for boards which have 'lcd' or 'vga' in their
264 stdout environment variable, but have moved to use driver model for
265 video. In this case the console will no-longer work. While it is
266 possible to update the environment, the breakage may be confusing for
267 users. This option will be removed around the end of 2020.
268
269config VIDCONSOLE_AS_NAME
270 string "Use 'vidconsole' when string defined here is seen in stdout"
271 depends on VIDCONSOLE_AS_LCD
Anatolij Gustschin47020642020-05-23 17:11:20 +0200272 default "lcd" if LCD || TEGRA_COMMON
273 default "vga" if !LCD
Simon Glass86f07462016-02-06 14:31:37 -0700274 help
Anatolij Gustschin47020642020-05-23 17:11:20 +0200275 This is a work-around for boards which have 'lcd' or 'vga' in their
276 stdout environment variable, but have moved to use driver model for
277 video. In this case the console will no-longer work. While it is
278 possible to update the environment, the breakage may be confusing for
279 users. This option will be removed around the end of 2020.
Simon Glass86f07462016-02-06 14:31:37 -0700280
Bin Menga0676be2016-10-09 04:14:16 -0700281config VIDEO_COREBOOT
282 bool "Enable coreboot framebuffer driver support"
Simon Glassd2398ab2021-03-15 18:00:27 +1300283 depends on X86
Bin Menga0676be2016-10-09 04:14:16 -0700284 help
285 Turn on this option to enable a framebuffer driver when U-Boot is
286 loaded by coreboot where the graphics device is configured by
287 coreboot already. This can in principle be used with any platform
288 that coreboot supports.
289
Bin Meng0f862b92018-06-12 08:36:22 -0700290config VIDEO_EFI
291 bool "Enable EFI framebuffer driver support"
Simon Glass04c26ff2021-11-03 21:09:10 -0600292 depends on EFI_STUB || EFI_APP
Bin Meng0f862b92018-06-12 08:36:22 -0700293 help
294 Turn on this option to enable a framebuffeer driver when U-Boot is
295 loaded as a payload (see README.u-boot_on_efi) by an EFI BIOS where
296 the graphics device is configured by the EFI BIOS already. This can
297 in principle be used with any platform that has an EFI BIOS.
298
Simon Glass42bf3ee2014-12-29 19:32:28 -0700299config VIDEO_VESA
300 bool "Enable VESA video driver support"
Simon Glass42bf3ee2014-12-29 19:32:28 -0700301 help
302 Turn on this option to enable a very simple driver which uses vesa
303 to discover the video mode and then provides a frame buffer for use
304 by U-Boot. This can in principle be used with any platform that
305 supports PCI and video cards that support VESA BIOS Extension (VBE).
306
Bin Meng072b79d2015-05-11 07:36:29 +0800307config FRAMEBUFFER_SET_VESA_MODE
308 bool "Set framebuffer graphics resolution"
Simon Glassdec49b72016-03-11 22:07:30 -0700309 depends on VIDEO_VESA || VIDEO_BROADWELL_IGD
Bin Meng072b79d2015-05-11 07:36:29 +0800310 help
311 Set VESA/native framebuffer mode (needed for bootsplash and graphical
312 framebuffer console)
313
314choice
315 prompt "framebuffer graphics resolution"
Bin Meng4da8a3f2018-04-11 22:02:16 -0700316 default FRAMEBUFFER_VESA_MODE_118
Bin Meng072b79d2015-05-11 07:36:29 +0800317 depends on FRAMEBUFFER_SET_VESA_MODE
318 help
319 This option sets the resolution used for the U-Boot framebuffer (and
320 bootsplash screen).
321
322config FRAMEBUFFER_VESA_MODE_100
323 bool "640x400 256-color"
324
325config FRAMEBUFFER_VESA_MODE_101
326 bool "640x480 256-color"
327
328config FRAMEBUFFER_VESA_MODE_102
329 bool "800x600 16-color"
330
331config FRAMEBUFFER_VESA_MODE_103
332 bool "800x600 256-color"
333
334config FRAMEBUFFER_VESA_MODE_104
335 bool "1024x768 16-color"
336
337config FRAMEBUFFER_VESA_MODE_105
Bin Meng932adc62015-08-09 23:26:59 -0700338 bool "1024x768 256-color"
Bin Meng072b79d2015-05-11 07:36:29 +0800339
340config FRAMEBUFFER_VESA_MODE_106
341 bool "1280x1024 16-color"
342
343config FRAMEBUFFER_VESA_MODE_107
344 bool "1280x1024 256-color"
345
346config FRAMEBUFFER_VESA_MODE_108
347 bool "80x60 text"
348
349config FRAMEBUFFER_VESA_MODE_109
350 bool "132x25 text"
351
352config FRAMEBUFFER_VESA_MODE_10A
353 bool "132x43 text"
354
355config FRAMEBUFFER_VESA_MODE_10B
356 bool "132x50 text"
357
358config FRAMEBUFFER_VESA_MODE_10C
359 bool "132x60 text"
360
361config FRAMEBUFFER_VESA_MODE_10D
362 bool "320x200 32k-color (1:5:5:5)"
363
364config FRAMEBUFFER_VESA_MODE_10E
365 bool "320x200 64k-color (5:6:5)"
366
367config FRAMEBUFFER_VESA_MODE_10F
368 bool "320x200 16.8M-color (8:8:8)"
369
370config FRAMEBUFFER_VESA_MODE_110
371 bool "640x480 32k-color (1:5:5:5)"
372
373config FRAMEBUFFER_VESA_MODE_111
374 bool "640x480 64k-color (5:6:5)"
375
376config FRAMEBUFFER_VESA_MODE_112
377 bool "640x480 16.8M-color (8:8:8)"
378
379config FRAMEBUFFER_VESA_MODE_113
380 bool "800x600 32k-color (1:5:5:5)"
381
382config FRAMEBUFFER_VESA_MODE_114
383 bool "800x600 64k-color (5:6:5)"
384
385config FRAMEBUFFER_VESA_MODE_115
386 bool "800x600 16.8M-color (8:8:8)"
387
388config FRAMEBUFFER_VESA_MODE_116
389 bool "1024x768 32k-color (1:5:5:5)"
390
391config FRAMEBUFFER_VESA_MODE_117
392 bool "1024x768 64k-color (5:6:5)"
393
394config FRAMEBUFFER_VESA_MODE_118
395 bool "1024x768 16.8M-color (8:8:8)"
396
397config FRAMEBUFFER_VESA_MODE_119
398 bool "1280x1024 32k-color (1:5:5:5)"
399
400config FRAMEBUFFER_VESA_MODE_11A
401 bool "1280x1024 64k-color (5:6:5)"
402
403config FRAMEBUFFER_VESA_MODE_11B
404 bool "1280x1024 16.8M-color (8:8:8)"
405
406config FRAMEBUFFER_VESA_MODE_USER
407 bool "Manually select VESA mode"
408
409endchoice
410
411# Map the config names to an integer (KB).
412config FRAMEBUFFER_VESA_MODE
413 prompt "VESA mode" if FRAMEBUFFER_VESA_MODE_USER
414 hex
415 default 0x100 if FRAMEBUFFER_VESA_MODE_100
416 default 0x101 if FRAMEBUFFER_VESA_MODE_101
417 default 0x102 if FRAMEBUFFER_VESA_MODE_102
418 default 0x103 if FRAMEBUFFER_VESA_MODE_103
419 default 0x104 if FRAMEBUFFER_VESA_MODE_104
420 default 0x105 if FRAMEBUFFER_VESA_MODE_105
421 default 0x106 if FRAMEBUFFER_VESA_MODE_106
422 default 0x107 if FRAMEBUFFER_VESA_MODE_107
423 default 0x108 if FRAMEBUFFER_VESA_MODE_108
424 default 0x109 if FRAMEBUFFER_VESA_MODE_109
425 default 0x10A if FRAMEBUFFER_VESA_MODE_10A
426 default 0x10B if FRAMEBUFFER_VESA_MODE_10B
427 default 0x10C if FRAMEBUFFER_VESA_MODE_10C
428 default 0x10D if FRAMEBUFFER_VESA_MODE_10D
429 default 0x10E if FRAMEBUFFER_VESA_MODE_10E
430 default 0x10F if FRAMEBUFFER_VESA_MODE_10F
431 default 0x110 if FRAMEBUFFER_VESA_MODE_110
432 default 0x111 if FRAMEBUFFER_VESA_MODE_111
433 default 0x112 if FRAMEBUFFER_VESA_MODE_112
434 default 0x113 if FRAMEBUFFER_VESA_MODE_113
435 default 0x114 if FRAMEBUFFER_VESA_MODE_114
436 default 0x115 if FRAMEBUFFER_VESA_MODE_115
437 default 0x116 if FRAMEBUFFER_VESA_MODE_116
438 default 0x117 if FRAMEBUFFER_VESA_MODE_117
439 default 0x118 if FRAMEBUFFER_VESA_MODE_118
440 default 0x119 if FRAMEBUFFER_VESA_MODE_119
441 default 0x11A if FRAMEBUFFER_VESA_MODE_11A
442 default 0x11B if FRAMEBUFFER_VESA_MODE_11B
443 default 0x117 if FRAMEBUFFER_VESA_MODE_USER
444
Hans de Goededfc1efe2015-08-08 16:03:29 +0200445config VIDEO_LCD_ANX9804
446 bool "ANX9804 bridge chip"
Hans de Goededfc1efe2015-08-08 16:03:29 +0200447 ---help---
448 Support for the ANX9804 bridge chip, which can take pixel data coming
449 from a parallel LCD interface and translate it on the fy into a DP
450 interface for driving eDP TFT displays. It uses I2C for configuration.
451
Tom Rini4c047422022-03-18 08:38:28 -0400452config ATMEL_LCD
453 bool "Atmel LCD panel support"
Simon Glass557786c2022-10-18 07:35:17 -0600454 depends on ARCH_AT91
Tom Rini4c047422022-03-18 08:38:28 -0400455
456config ATMEL_LCD_BGR555
457 bool "Display in BGR555 mode"
458 help
459 Use the BGR555 output mode. Otherwise RGB565 is used.
460
Simon Glass7b3fabb2022-01-23 07:04:14 -0700461config VIDEO_BCM2835
462 bool "Display support for BCM2835"
463 help
464 The graphics processor already sets up the display so this driver
465 simply checks the resolution and then sets up the frame buffer with
466 that same resolution (or as near as possible) and 32bpp depth, so
467 that U-Boot can access it with full colour depth.
468
Yannick Fertré5b855d42019-10-07 15:29:08 +0200469config VIDEO_LCD_ORISETECH_OTM8009A
470 bool "OTM8009A DSI LCD panel support"
Yannick Fertré5b855d42019-10-07 15:29:08 +0200471 select VIDEO_MIPI_DSI
Yannick Fertré5b855d42019-10-07 15:29:08 +0200472 help
473 Say Y here if you want to enable support for Orise Technology
474 otm8009a 480x800 dsi 2dl panel.
475
Yannick Fertréb038fed2019-10-07 15:29:09 +0200476config VIDEO_LCD_RAYDIUM_RM68200
477 bool "RM68200 DSI LCD panel support"
Yannick Fertréb038fed2019-10-07 15:29:09 +0200478 select VIDEO_MIPI_DSI
Yannick Fertréb038fed2019-10-07 15:29:09 +0200479 help
480 Say Y here if you want to enable support for Raydium RM68200
481 720x1280 DSI video mode panel.
482
Siarhei Siamashka4c19cf22015-01-19 05:23:32 +0200483config VIDEO_LCD_SSD2828
484 bool "SSD2828 bridge chip"
Siarhei Siamashka4c19cf22015-01-19 05:23:32 +0200485 ---help---
486 Support for the SSD2828 bridge chip, which can take pixel data coming
487 from a parallel LCD interface and translate it on the fly into MIPI DSI
488 interface for driving a MIPI compatible LCD panel. It uses SPI for
489 configuration.
490
491config VIDEO_LCD_SSD2828_TX_CLK
492 int "SSD2828 TX_CLK frequency (in MHz)"
493 depends on VIDEO_LCD_SSD2828
Siarhei Siamashka61fb91f2015-01-19 05:23:35 +0200494 default 0
Siarhei Siamashka4c19cf22015-01-19 05:23:32 +0200495 ---help---
496 The frequency of the crystal, which is clocking SSD2828. It may be
497 anything in the 8MHz-30MHz range and the exact value should be
498 retrieved from the board schematics. Or in the case of Allwinner
499 hardware, it can be usually found as 'lcd_xtal_freq' variable in
Siarhei Siamashka61fb91f2015-01-19 05:23:35 +0200500 FEX files. It can be also set to 0 for selecting PCLK from the
501 parallel LCD interface instead of TX_CLK as the PLL clock source.
Siarhei Siamashka4c19cf22015-01-19 05:23:32 +0200502
503config VIDEO_LCD_SSD2828_RESET
504 string "RESET pin of SSD2828"
505 depends on VIDEO_LCD_SSD2828
506 default ""
507 ---help---
508 The reset pin of SSD2828 chip. This takes a string in the format
Samuel Hollandc7ab95d2021-09-11 16:50:48 -0500509 understood by 'sunxi_name_to_gpio' function, e.g. PH1 for pin 1 of port H.
Siarhei Siamashka4c19cf22015-01-19 05:23:32 +0200510
Neil Armstrong4a4057a2020-09-29 11:53:53 +0200511config VIDEO_LCD_TDO_TL070WSH30
512 bool "TDO TL070WSH30 DSI LCD panel support"
Neil Armstrong4a4057a2020-09-29 11:53:53 +0200513 select VIDEO_MIPI_DSI
Neil Armstrong4a4057a2020-09-29 11:53:53 +0200514 help
515 Say Y here if you want to enable support for TDO TL070WSH30
516 1024x600 DSI video mode panel.
517
Hans de Goedec0482032015-01-20 09:22:26 +0100518config VIDEO_LCD_HITACHI_TX18D42VM
519 bool "Hitachi tx18d42vm LVDS LCD panel support"
Hans de Goedec0482032015-01-20 09:22:26 +0100520 ---help---
521 Support for Hitachi tx18d42vm LVDS LCD panels, these panels have a
522 lcd controller which needs to be initialized over SPI, once that is
523 done they work like a regular LVDS panel.
524
Siarhei Siamashka4c19cf22015-01-19 05:23:32 +0200525config VIDEO_LCD_SPI_CS
526 string "SPI CS pin for LCD related config job"
Hans de Goedec0482032015-01-20 09:22:26 +0100527 depends on VIDEO_LCD_SSD2828 || VIDEO_LCD_HITACHI_TX18D42VM
Siarhei Siamashka4c19cf22015-01-19 05:23:32 +0200528 default ""
529 ---help---
530 This is one of the SPI communication pins, involved in setting up a
531 working LCD configuration. The exact role of SPI may differ for
532 different hardware setups. The option takes a string in the format
Samuel Hollandc7ab95d2021-09-11 16:50:48 -0500533 understood by 'sunxi_name_to_gpio' function, e.g. PH1 for pin 1 of port H.
Siarhei Siamashka4c19cf22015-01-19 05:23:32 +0200534
535config VIDEO_LCD_SPI_SCLK
536 string "SPI SCLK pin for LCD related config job"
Hans de Goedec0482032015-01-20 09:22:26 +0100537 depends on VIDEO_LCD_SSD2828 || VIDEO_LCD_HITACHI_TX18D42VM
Siarhei Siamashka4c19cf22015-01-19 05:23:32 +0200538 default ""
539 ---help---
540 This is one of the SPI communication pins, involved in setting up a
541 working LCD configuration. The exact role of SPI may differ for
542 different hardware setups. The option takes a string in the format
Samuel Hollandc7ab95d2021-09-11 16:50:48 -0500543 understood by 'sunxi_name_to_gpio' function, e.g. PH1 for pin 1 of port H.
Siarhei Siamashka4c19cf22015-01-19 05:23:32 +0200544
545config VIDEO_LCD_SPI_MOSI
546 string "SPI MOSI pin for LCD related config job"
Hans de Goedec0482032015-01-20 09:22:26 +0100547 depends on VIDEO_LCD_SSD2828 || VIDEO_LCD_HITACHI_TX18D42VM
Siarhei Siamashka4c19cf22015-01-19 05:23:32 +0200548 default ""
549 ---help---
550 This is one of the SPI communication pins, involved in setting up a
551 working LCD configuration. The exact role of SPI may differ for
552 different hardware setups. The option takes a string in the format
Samuel Hollandc7ab95d2021-09-11 16:50:48 -0500553 understood by 'sunxi_name_to_gpio' function, e.g. PH1 for pin 1 of port H.
Siarhei Siamashka4c19cf22015-01-19 05:23:32 +0200554
555config VIDEO_LCD_SPI_MISO
556 string "SPI MISO pin for LCD related config job (optional)"
557 depends on VIDEO_LCD_SSD2828
558 default ""
559 ---help---
560 This is one of the SPI communication pins, involved in setting up a
561 working LCD configuration. The exact role of SPI may differ for
562 different hardware setups. If wired up, this pin may provide additional
563 useful functionality. Such as bi-directional communication with the
564 hardware and LCD panel id retrieval (if the panel can report it). The
Samuel Hollandc7ab95d2021-09-11 16:50:48 -0500565 option takes a string in the format understood by 'sunxi_name_to_gpio'
Siarhei Siamashka4c19cf22015-01-19 05:23:32 +0200566 function, e.g. PH1 for pin 1 of port H.
Simon Glass06679ad2015-04-14 21:03:38 -0600567
Neil Armstrongadd986c2018-07-24 17:45:28 +0200568source "drivers/video/meson/Kconfig"
569
Stefan Roeseab91fd52016-01-20 08:13:28 +0100570config VIDEO_MVEBU
571 bool "Armada XP LCD controller"
Stefan Roeseab91fd52016-01-20 08:13:28 +0100572 ---help---
573 Support for the LCD controller integrated in the Marvell
574 Armada XP SoC.
575
Adam Ford60a59d42018-08-02 08:50:20 -0500576config VIDEO_OMAP3
577 bool "Enable OMAP3+ DSS Support"
578 depends on ARCH_OMAP2PLUS
579 help
580 This enables the Display subsystem (DSS) on OMAP3+ boards.
581
Anatolij Gustschin4601eb42016-01-25 17:17:22 +0100582config I2C_EDID
583 bool "Enable EDID library"
Anatolij Gustschin4601eb42016-01-25 17:17:22 +0100584 help
585 This enables library for accessing EDID data from an LCD panel.
586
Simon Glass7d3d7762016-01-21 19:45:00 -0700587config DISPLAY
588 bool "Enable Display support"
589 depends on DM
Anatolij Gustschin4601eb42016-01-25 17:17:22 +0100590 select I2C_EDID
Simon Glass06679ad2015-04-14 21:03:38 -0600591 help
Simon Glass7d3d7762016-01-21 19:45:00 -0700592 This supports drivers that provide a display, such as eDP (Embedded
593 DisplayPort) and HDMI (High Definition Multimedia Interface).
594 The devices provide a simple interface to start up the display,
595 read display information and enable it.
Simon Glass3ef2a722015-04-14 21:03:42 -0600596
Liviu Dudau33967102018-09-28 13:49:31 +0100597config NXP_TDA19988
598 bool "Enable NXP TDA19988 support"
599 depends on DISPLAY
Liviu Dudau33967102018-09-28 13:49:31 +0100600 help
601 This enables support for the NXP TDA19988 HDMI encoder. This encoder
602 will convert RGB data streams into HDMI-encoded signals.
603
Songjun Wu72ac56a2017-04-11 16:33:30 +0800604config ATMEL_HLCD
605 bool "Enable ATMEL video support using HLCDC"
Songjun Wu72ac56a2017-04-11 16:33:30 +0800606 help
607 HLCDC supports video output to an attached LCD panel.
608
Svyatoslav Ryhel3e9488a2023-04-25 10:51:42 +0300609config BACKLIGHT_LM3533
610 bool "Backlight Driver for LM3533"
611 depends on BACKLIGHT
612 select DM_I2C
613 help
614 Say Y to enable the backlight driver for National Semiconductor / TI
615 LM3533 Lighting Power chip. Only Bank A is supported as for now.
616 Supported backlight level range is from 2 to 255 with step of 1.
617
Dario Binacchi260bdb32023-01-28 16:55:31 +0100618source "drivers/video/ti/Kconfig"
619
Tom Rini3eeabf52022-06-10 22:59:34 -0400620source "drivers/video/exynos/Kconfig"
621
Mario Sixc13ee192018-08-09 14:51:23 +0200622config LOGICORE_DP_TX
623 bool "Enable Logicore DP TX driver"
624 depends on DISPLAY
625 help
626 Enable the driver for the transmitter part of the Xilinx LogiCORE
627 DisplayPort, a IP core for Xilinx FPGAs that implements a DisplayPort
628 video interface as defined by VESA DisplayPort v1.2.
629
630 Note that this is a pure transmitter device, and has no display
631 capabilities by itself.
632
Simon Glassdec49b72016-03-11 22:07:30 -0700633config VIDEO_BROADWELL_IGD
634 bool "Enable Intel Broadwell integrated graphics device"
635 depends on X86
636 help
Simon Glassa3fdd002016-10-05 20:42:14 -0600637 This enables support for integrated graphics on Intel broadwell
Simon Glassdec49b72016-03-11 22:07:30 -0700638 devices. Initialisation is mostly performed by a VGA boot ROM, with
639 some setup handled by U-Boot itself. The graphics adaptor works as
640 a VESA device and supports LCD panels, eDP and LVDS outputs.
641 Configuration of most aspects of device operation is performed using
642 a special tool which configures the VGA ROM, but the graphics
643 resolution can be selected in U-Boot.
644
Simon Glass03f2a512016-10-05 20:42:15 -0600645config VIDEO_IVYBRIDGE_IGD
646 bool "Enable Intel Ivybridge integration graphics support"
647 depends on X86
648 help
649 This enables support for integrated graphics on Intel ivybridge
650 devices. Initialisation is mostly performed by a VGA boot ROM, with
651 some setup handled by U-Boot itself. The graphics adaptor works as
652 a VESA device and supports LCD panels, eDP and LVDS outputs.
653 Configuration of most aspects of device operation is performed using
654 a special tool which configures the VGA ROM, but the graphics
655 resolution can be selected in U-Boot.
656
eric.gao@rock-chips.com735ddea2017-04-17 22:24:23 +0800657source "drivers/video/rockchip/Kconfig"
Simon Glass0139ae62016-01-21 19:45:03 -0700658
Liviu Dudau8373ed32018-09-28 13:50:53 +0100659config VIDEO_ARM_MALIDP
660 bool "Enable Arm Mali Display Processor support"
Simon Glass557786c2022-10-18 07:35:17 -0600661 depends on OF_CONTROL
Liviu Dudau8373ed32018-09-28 13:50:53 +0100662 select VEXPRESS_CLK
663 help
664 This enables support for Arm Ltd Mali Display Processors from
665 the DP500, DP550 and DP650 family.
666
Simon Glass161eea72016-01-18 19:52:24 -0700667config VIDEO_SANDBOX_SDL
668 bool "Enable sandbox video console using SDL"
Tom Riniea79bb72022-11-19 18:45:43 -0500669 depends on SANDBOX_SDL
Simon Glass161eea72016-01-18 19:52:24 -0700670 help
671 When using sandbox you can enable an emulated LCD display which
672 appears as an SDL (Simple DirectMedia Layer) window. This is a
673 console device and can display stdout output. Within U-Boot is is
674 a normal bitmap display and can display images as well as text.
675
Philippe CORNUdcbad9a2017-08-03 12:36:08 +0200676source "drivers/video/stm32/Kconfig"
677
Nikhil M Jain94272742023-01-31 15:35:17 +0530678source "drivers/video/tidss/Kconfig"
679
Simon Glass3ef2a722015-04-14 21:03:42 -0600680config VIDEO_TEGRA124
681 bool "Enable video support on Tegra124"
682 help
683 Tegra124 supports many video output options including eDP and
684 HDMI. At present only eDP is supported by U-Boot. This option
685 enables this support which can be used on devices which
686 have an eDP display connected.
Simon Glass7cf17572015-07-02 18:16:08 -0600687
688source "drivers/video/bridge/Kconfig"
Masahiro Yamadacc85b7b2015-07-26 02:46:26 +0900689
Svyatoslav Ryheld15683f2023-03-27 11:11:41 +0300690source "drivers/video/tegra20/Kconfig"
691
Anatolij Gustschin411e73d2019-03-18 23:29:32 +0100692source "drivers/video/imx/Kconfig"
Anatolij Gustschin983e2f22019-03-18 23:29:31 +0100693
Anatolij Gustschine22e08e2021-10-04 17:33:12 +0200694config VIDEO_MXS
695 bool "Enable video support on i.MX28/i.MX6UL/i.MX7 SoCs"
Anatolij Gustschine22e08e2021-10-04 17:33:12 +0200696 help
697 Enable framebuffer driver for i.MX28/i.MX6UL/i.MX7 processors
698
Stefan Bosch5ed5ad42020-07-10 19:07:36 +0200699config VIDEO_NX
700 bool "Enable video support on Nexell SoC"
701 depends on ARCH_S5P6818 || ARCH_S5P4418
702 help
703 Nexell SoC supports many video output options including eDP and
704 HDMI. This option enables this support which can be used on devices
705 which have an eDP display connected.
706
Michal Simek32058b82020-12-03 09:31:35 +0100707config VIDEO_SEPS525
708 bool "Enable video support for Seps525"
Simon Glass557786c2022-10-18 07:35:17 -0600709 depends on DM_GPIO
Michal Simek32058b82020-12-03 09:31:35 +0100710 help
711 Enable support for the Syncoam PM-OLED display driver (RGB 160x128).
712 Currently driver is supporting only SPI interface.
713
Michal Simekab2829a2022-02-23 15:52:02 +0100714config VIDEO_ZYNQMP_DPSUB
715 bool "Enable video support for ZynqMP Display Port"
Simon Glass557786c2022-10-18 07:35:17 -0600716 depends on ZYNQMP_POWER_DOMAIN
Michal Simekab2829a2022-02-23 15:52:02 +0100717 help
718 Enable support for Xilinx ZynqMP Display Port. Currently this file
719 is used as placeholder for driver. The main reason is to record
720 compatible string and calling power domain driver.
721
Stefan Bosch5ed5ad42020-07-10 19:07:36 +0200722source "drivers/video/nexell/Kconfig"
723
Simon Glassd76f29a2016-10-17 20:12:57 -0600724config CONSOLE_SCROLL_LINES
725 int "Number of lines to scroll the console by"
Simon Glassd76f29a2016-10-17 20:12:57 -0600726 default 1
727 help
728 When the console need to be scrolled, this is the number of
729 lines to scroll by. It defaults to 1. Increasing this makes the
730 console jump but can help speed up operation when scrolling
731 is slow.
732
Philipp Tomsich3a53b3e2017-05-05 21:48:26 +0200733config VIDEO_DW_HDMI
734 bool
735 help
736 Enables the common driver code for the Designware HDMI TX
737 block found in SoCs from various vendors.
738 As this does not provide any functionality by itself (but
739 rather requires a SoC-specific glue driver to call it), it
740 can not be enabled from the configuration menu.
741
Yannick Fertré9712c822019-10-07 15:29:05 +0200742config VIDEO_DSI_HOST_SANDBOX
743 bool "Enable sandbox for dsi host"
744 depends on SANDBOX
745 select VIDEO_MIPI_DSI
746 help
747 Enable support for sandbox dsi host device used for testing
748 purposes.
749 Display Serial Interface (DSI) defines a serial bus and
750 a communication protocol between the host and the device
751 (panel, bridge).
752
Yannick Fertré764af462019-10-07 15:29:06 +0200753config VIDEO_DW_MIPI_DSI
754 bool
755 select VIDEO_MIPI_DSI
756 help
757 Enables the common driver code for the Synopsis Designware
758 MIPI DSI block found in SoCs from various vendors.
759 As this does not provide any functionality by itself (but
760 rather requires a SoC-specific glue driver to call it), it
761 can not be enabled from the configuration menu.
762
Rob Clarkcf7ab0c2017-08-03 12:47:00 -0400763config VIDEO_SIMPLE
764 bool "Simple display driver for preconfigured display"
765 help
766 Enables a simple generic display driver which utilizes the
767 simple-framebuffer devicetree bindings.
768
769 This driver assumes that the display hardware has been initialized
770 before u-boot starts, and u-boot will simply render to the pre-
771 allocated frame buffer surface.
772
Icenowy Zheng60e4b8f2017-10-26 11:14:46 +0800773config VIDEO_DT_SIMPLEFB
774 bool "Enable SimpleFB support for passing framebuffer to OS"
775 help
776 Enables the code to pass the framebuffer to the kernel as a
777 simple framebuffer in the device tree.
778 The video output is initialized by U-Boot, and kept by the
779 kernel.
780
Stephan Gerhold36f654a2021-07-02 19:21:56 +0200781config VIDEO_MCDE_SIMPLE
782 bool "Simple driver for ST-Ericsson MCDE with preconfigured display"
Stephan Gerhold36f654a2021-07-02 19:21:56 +0200783 help
784 Enables a simple display driver for ST-Ericsson MCDE
785 (Multichannel Display Engine), which reads the configuration from
786 the MCDE registers.
787
788 This driver assumes that the display hardware has been initialized
789 before u-boot starts, and u-boot will simply render to the pre-
790 allocated frame buffer surface.
791
Mario Six1b773202018-09-27 09:19:29 +0200792config OSD
793 bool "Enable OSD support"
794 depends on DM
Mario Six1b773202018-09-27 09:19:29 +0200795 help
796 This supports drivers that provide a OSD (on-screen display), which
797 is a (usually text-oriented) graphics buffer to show information on
798 a display.
Mario Six8ea19da2018-09-27 09:19:30 +0200799
Mario Six02ad6fb2018-09-27 09:19:31 +0200800config SANDBOX_OSD
801 bool "Enable sandbox OSD"
802 depends on OSD
803 help
804 Enable support for sandbox OSD device used for testing purposes.
805
Mario Six8ea19da2018-09-27 09:19:30 +0200806config IHS_VIDEO_OUT
807 bool "Enable IHS video out driver"
808 depends on OSD
809 help
810 Enable support for the gdsys Integrated Hardware Systems (IHS) video
811 out On-screen Display (OSD) used on gdsys FPGAs to control dynamic
812 textual overlays of the display outputs.
813
Simon Glass2d7a7942020-08-11 11:23:35 -0600814config SPLASH_SCREEN
815 bool "Show a splash-screen image"
816 help
817 If this option is set, the environment is checked for a variable
818 "splashimage". If found, the usual display of logo, copyright and
819 system information on the LCD is suppressed and the BMP image at the
820 address specified in "splashimage" is loaded instead. The console is
821 redirected to the "nulldev", too. This allows for a "silent" boot
822 where a splash screen is loaded very quickly after power-on.
823
824 The splash_screen_prepare() function is a weak function defined in
825 common/splash.c. It is called as part of the splash screen display
826 sequence. It gives the board an opportunity to prepare the splash
827 image data before it is processed and sent to the frame buffer by
828 U-Boot. Define your own version to use this feature.
829
Simon Glass8b883a32022-10-18 06:24:16 -0600830if SPLASH_SCREEN
831
Simon Glass2d7a7942020-08-11 11:23:35 -0600832config SPLASH_SCREEN_ALIGN
833 bool "Allow positioning the splash image anywhere on the display"
Simon Glass2d7a7942020-08-11 11:23:35 -0600834 help
835 If this option is set the splash image can be freely positioned
836 on the screen. Environment variable "splashpos" specifies the
837 position as "x,y". If a positive number is given it is used as
838 number of pixel from left/top. If a negative number is given it
839 is used as number of pixel from right/bottom. You can also
840 specify 'm' for centering the image.
841
842 Example:
843 setenv splashpos m,m
844 => image at center of screen
845
846 setenv splashpos 30,20
847 => image at x = 30 and y = 20
848
849 setenv splashpos -10,m
850 => vertically centered image
851 at x = dspWidth - bmpWidth - 9
852
Simon Glass45c0a7e2022-10-18 06:30:56 -0600853config HIDE_LOGO_VERSION
854 bool "Hide the version information on the splash screen"
855 help
856 Normally the U-Boot version string is shown on the display when the
857 splash screen is enabled. This information is not otherwise visible
858 since video starts up after U-Boot has displayed the initial banner.
859
860 Enable this option to hide this information.
861
Simon Glass2d7a7942020-08-11 11:23:35 -0600862config SPLASH_SOURCE
863 bool "Control the source of the splash image"
Simon Glass2d7a7942020-08-11 11:23:35 -0600864 help
865 Use the splash_source.c library. This library provides facilities to
866 declare board specific splash image locations, routines for loading
867 splash image from supported locations, and a way of controlling the
868 selected splash location using the "splashsource" environment
869 variable.
870
871 This CONFIG works as follows:
872
873 - If splashsource is set to a supported location name as defined by
874 board code, use that splash location.
875 - If splashsource is undefined, use the first splash location as
876 default.
877 - If splashsource is set to an unsupported value, do not load a splash
878 screen.
879
880 A splash source location can describe either storage with raw data, a
881 storage formatted with a file system or a FIT image. In case of a
882 filesystem, the splash screen data is loaded as a file. The name of
883 the splash screen file can be controlled with the environment variable
884 "splashfile".
885
886 To enable loading the splash image from a FIT image, CONFIG_FIT must
887 be enabled. The FIT image has to start at the 'offset' field address
888 in the selected splash location. The name of splash image within the
889 FIT shall be specified by the environment variable "splashfile".
890
891 In case the environment variable "splashfile" is not defined the
892 default name 'splash.bmp' will be used.
893
Simon Glass8b883a32022-10-18 06:24:16 -0600894endif # SPLASH_SCREEN
895
Patrick Delaunay5d0e2ab2020-09-28 11:30:14 +0200896config VIDEO_BMP_GZIP
897 bool "Gzip compressed BMP image support"
Nikhil M Jain9fa24c12023-04-20 17:40:59 +0530898 depends on BMP || SPLASH_SCREEN
Patrick Delaunay5d0e2ab2020-09-28 11:30:14 +0200899 help
900 If this option is set, additionally to standard BMP
901 images, gzipped BMP images can be displayed via the
902 splashscreen support or the bmp command.
903
Simon Glass858198c2022-10-18 06:46:08 -0600904config VIDEO_LOGO_MAX_SIZE
Simon Glasscda7d0c2022-10-18 06:49:18 -0600905 hex "Maximum size of the bitmap logo in bytes"
906 default 0x100000
907 help
908 Sets the maximum uncompressed size of the logo. This is needed when
909 decompressing a BMP file using the gzip algorithm, since it cannot
910 read the size from the bitmap header.
Simon Glass858198c2022-10-18 06:46:08 -0600911
Patrick Delaunayc47fe772020-09-28 11:30:15 +0200912config VIDEO_BMP_RLE8
913 bool "Run length encoded BMP image (RLE8) support"
Patrick Delaunayc47fe772020-09-28 11:30:15 +0200914 help
915 If this option is set, the 8-bit RLE compressed BMP images
916 is supported.
917
Patrick Delaunayb1f17632020-09-28 11:30:16 +0200918config BMP_16BPP
919 bool "16-bit-per-pixel BMP image support"
Patrick Delaunayb1f17632020-09-28 11:30:16 +0200920 help
921 Support display of bitmaps file with 16-bit-per-pixel
922
923config BMP_24BPP
924 bool "24-bit-per-pixel BMP image support"
Patrick Delaunayb1f17632020-09-28 11:30:16 +0200925 help
926 Support display of bitmaps file with 24-bit-per-pixel.
927
928config BMP_32BPP
929 bool "32-bit-per-pixel BMP image support"
Patrick Delaunayb1f17632020-09-28 11:30:16 +0200930 help
931 Support display of bitmaps file with 32-bit-per-pixel.
932
Simon Glass52cb5042022-10-18 07:46:31 -0600933endif # VIDEO
Simon Glass557786c2022-10-18 07:35:17 -0600934
Nikhil M Jain9fa24c12023-04-20 17:40:59 +0530935config SPL_VIDEO
936 bool "Enable driver model support for LCD/video"
937 depends on SPL_DM
938 help
939 The video subsystem adds a small amount of overhead to the image.
940 If this is acceptable and you have a need to use video drivers in
941 SPL, enable this option. It might provide a cleaner interface to
942 setting up video within SPL, and allows the same drivers to be
943 used as U-Boot proper.
944
945if SPL_VIDEO
946source "drivers/video/tidss/Kconfig"
947
948config SPL_VIDEO_LOGO
949 bool "Show the U-Boot logo on the display at SPL"
950 default y if !SPL_SPLASH_SCREEN
951 select SPL_VIDEO_BMP_RLE8
952 help
953 This enables showing the U-Boot logo on the display when a video
954 device is probed. It appears at the top right. The logo itself is at
955 tools/logos/u-boot_logo.bmp and looks best when the display has a
956 black background.
957
958config SPL_SPLASH_SCREEN
959 bool "Show a splash-screen image at SPL"
960 help
961 If this option is set, the environment is checked for a variable
962 "splashimage" at spl stage.
963
964config SPL_SYS_WHITE_ON_BLACK
965 bool "Display console as white on a black background at SPL"
966 help
967 Normally the display is black on a white background, Enable this
968 option to invert this, i.e. white on a black background at spl stage.
969 This can be better in low-light situations or to reduce eye strain in
970 some cases.
971
972config SPL_VIDEO_PCI_DEFAULT_FB_SIZE
973 hex "Default framebuffer size to use if no drivers request it at SPL"
974 default 0x1000000 if X86 && PCI
975 default 0 if !(X86 && PCI)
976 help
977 Generally, video drivers request the amount of memory they need for
978 the frame buffer when they are bound, by setting the size field in
979 struct video_uc_plat. That memory is then reserved for use after
980 relocation. But PCI drivers cannot be bound before relocation unless
981 they are mentioned in the devicetree.
982
983 With this value set appropriately, it is possible for PCI video
984 devices to have a framebuffer allocated by U-Boot.
985
986 Note: the framebuffer needs to be large enough to store all pixels at
987 maximum resolution. For example, at 1920 x 1200 with 32 bits per
988 pixel, 2560 * 1600 * 32 / 8 = 0xfa0000 bytes are needed.
989
990config SPL_CONSOLE_SCROLL_LINES
991 int "Number of lines to scroll the console by at SPL"
992 default 1
993 help
994 When the console need to be scrolled, this is the number of
995 lines to scroll by. It defaults to 1. Increasing this makes the
996 console jump but can help speed up operation when scrolling
997 is slow.
998
999config SPL_CONSOLE_NORMAL
1000 bool "Support a simple text console at SPL"
1001 default y
1002 help
1003 Support drawing text on the frame buffer console so that it can be
1004 used as a console. Rotation is not supported by this driver (see
1005 CONFIG_CONSOLE_ROTATION for that). A built-in 8x16 font is used
1006 for the display.
1007
1008config SPL_BACKLIGHT
1009 bool "Enable panel backlight uclass support at SPL"
1010 default y
1011 help
1012 This provides backlight uclass driver that enables basic panel
1013 backlight support.
1014
1015config SPL_PANEL
1016 bool "Enable panel uclass support at SPL"
1017 default y
1018 help
1019 This provides panel uclass driver that enables basic panel support.
1020
1021config SPL_SIMPLE_PANEL
1022 bool "Enable simple panel support at SPL"
1023 depends on SPL_PANEL && SPL_BACKLIGHT && SPL_DM_GPIO
1024 default y
1025 help
1026 This turns on a simple panel driver that enables a compatible
1027 video panel.
1028
1029config SPL_SYS_WHITE_ON_BLACK
1030 bool "Display console as white on a black background at SPL"
1031 help
1032 Normally the display is black on a white background, Enable this
1033 option to invert this, i.e. white on a black background at spl stage.
1034 This can be better in low-light situations or to reduce eye strain in
1035 some cases.
1036
1037if SPL_SPLASH_SCREEN
1038
1039config SPL_SPLASH_SCREEN_ALIGN
1040 bool "Allow positioning the splash image anywhere on the display at SPL"
1041 help
1042 If this option is set the splash image can be freely positioned
1043 on the screen only at SPL. Environment variable "splashpos" specifies
1044 the position as "x,y". If a positive number is given it is used as
1045 number of pixel from left/top. If a negative number is given it
1046 is used as number of pixel from right/bottom.
1047
1048config SPL_SPLASH_SOURCE
1049 bool "Control the source of the splash image at SPL"
1050 help
1051 Use the splash_source.c library. This library provides facilities to
1052 declare board specific splash image locations, routines for loading
1053 splash image from supported locations, and a way of controlling the
1054 selected splash location using the "splashsource" environment
1055 variable.
1056
1057 This CONFIG works as follows:
1058
1059 - If splashsource is set to a supported location name as defined by
1060 board code, use that splash location.
1061 - If splashsource is undefined, use the first splash location as
1062 default.
1063 - If splashsource is set to an unsupported value, do not load a splash
1064 screen.
1065
1066 A splash source location can describe either storage with raw data, a
1067 storage formatted with a file system or a FIT image. In case of a
1068 filesystem, the splash screen data is loaded as a file. The name of
1069 the splash screen file can be controlled with the environment variable
1070 "splashfile".
1071
1072 To enable loading the splash image from a FIT image, CONFIG_FIT must
1073 be enabled. The FIT image has to start at the 'offset' field address
1074 in the selected splash location. The name of splash image within the
1075 FIT shall be specified by the environment variable "splashfile".
1076
1077 In case the environment variable "splashfile" is not defined the
1078 default name 'splash.bmp' will be used.
1079
1080endif # SPL_SPLASH_SCREEN
1081
1082config SPL_VIDEO_BMP_GZIP
1083 bool "Gzip compressed BMP image support at SPL"
1084 depends on SPL_SPLASH_SCREEN || SPL_BMP
1085 help
1086 If this option is set, additionally to standard BMP
1087 images, gzipped BMP images can be displayed via the
1088 splashscreen supportat SPL stage.
1089
1090config SPL_VIDEO_LOGO_MAX_SIZE
1091 hex "Maximum size of the bitmap logo in bytes at SPL"
1092 default 0x100000
1093 help
1094 Sets the maximum uncompressed size of the logo. This is needed when
1095 decompressing a BMP file using the gzip algorithm, since it cannot
1096 read the size from the bitmap header.
1097
1098config SPL_VIDEO_BMP_RLE8
1099 bool "Run length encoded BMP image (RLE8) support at SPL"
1100 help
1101 If this option is set, the 8-bit RLE compressed BMP images
1102 is supported.
1103
1104config SPL_BMP_16BPP
1105 bool "16-bit-per-pixel BMP image support at SPL"
1106 help
1107 Support display of bitmaps file with 16-bit-per-pixel
1108
1109config SPL_BMP_24BPP
1110 bool "24-bit-per-pixel BMP image support at SPL"
1111 help
1112 Support display of bitmaps file with 24-bit-per-pixel.
1113
1114config SPL_BMP_32BPP
1115 bool "32-bit-per-pixel BMP image support at SPL"
1116 help
1117 Support display of bitmaps file with 32-bit-per-pixel.
1118
1119config SPL_VIDEO_BPP8
1120 bool "Support 8-bit-per-pixel displays at SPL"
1121 default y
1122 help
1123 Support drawing text and bitmaps onto a 8-bit-per-pixel display.
1124 Enabling this will include code to support this display. Without
1125 this option, such displays will not be supported and console output
1126 will be empty.
1127
1128config SPL_VIDEO_BPP16
1129 bool "Support 16-bit-per-pixel displays at SPL"
1130 default y
1131 help
1132 Support drawing text and bitmaps onto a 16-bit-per-pixel display.
1133 Enabling this will include code to support this display. Without
1134 this option, such displays will not be supported and console output
1135 will be empty.
1136
1137config SPL_VIDEO_BPP32
1138 bool "Support 32-bit-per-pixel displays at SPL"
1139 default y
1140 help
1141 Support drawing text and bitmaps onto a 32-bit-per-pixel display.
1142 Enabling this will include code to support this display. Without
1143 this option, such displays will not be supported and console output
1144 will be empty.
1145
1146config SPL_HIDE_LOGO_VERSION
1147 bool "Hide the version information on the splash screen at SPL"
1148 help
1149 Normally the U-Boot version string is shown on the display when the
1150 splash screen is enabled. This information is not otherwise visible
1151 since video starts up after U-Boot has displayed the initial banner.
1152
1153 Enable this option to hide this information.
1154endif
1155
Masahiro Yamadacc85b7b2015-07-26 02:46:26 +09001156endmenu