]> git.ipfire.org Git - people/ms/u-boot.git/blame - drivers/video/Kconfig
Convert CONFIG_VIDEO to Kconfig
[people/ms/u-boot.git] / drivers / video / Kconfig
CommitLineData
0b11dbf7
MY
1#
2# Video configuration
3#
4
5menu "Graphics support"
6
1acafc73
SG
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
6e42e251
SG
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
b5146b28
SG
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
a29b0120
SG
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
a2931b30
SG
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
13b2bfce
BM
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
6b1ba984
SG
113config VIDEO_VESA
114 bool "Enable VESA video driver support"
6b1ba984
SG
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
6bde2dc5
BM
122config FRAMEBUFFER_SET_VESA_MODE
123 bool "Set framebuffer graphics resolution"
97cb0927 124 depends on VIDEO_VESA || VIDEO_BROADWELL_IGD
6bde2dc5
BM
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
57dccb55 153 bool "1024x768 256-color"
6bde2dc5
BM
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
66525bb7
HG
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
b8329acf
SS
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
dddccd69 280 default 0
b8329acf
SS
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
dddccd69
SS
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.
b8329acf
SS
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
a5464f2b
HG
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
b8329acf
SS
306config VIDEO_LCD_SPI_CS
307 string "SPI CS pin for LCD related config job"
a5464f2b 308 depends on VIDEO_LCD_SSD2828 || VIDEO_LCD_HITACHI_TX18D42VM
b8329acf
SS
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"
a5464f2b 318 depends on VIDEO_LCD_SSD2828 || VIDEO_LCD_HITACHI_TX18D42VM
b8329acf
SS
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"
a5464f2b 328 depends on VIDEO_LCD_SSD2828 || VIDEO_LCD_HITACHI_TX18D42VM
b8329acf
SS
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.
51f2c99e 348
913d1be2
SR
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
7588c312
AG
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
2dcf1433
SG
363config DISPLAY
364 bool "Enable Display support"
365 depends on DM
7588c312
AG
366 default n
367 select I2C_EDID
51f2c99e 368 help
2dcf1433
SG
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.
e7e8823c 373
97cb0927
SG
374config VIDEO_BROADWELL_IGD
375 bool "Enable Intel Broadwell integrated graphics device"
376 depends on X86
377 help
1df91276 378 This enables support for integrated graphics on Intel broadwell
97cb0927
SG
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
2c943804
SG
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
c2539483
SG
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
1e69ad01
SG
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
d2f90650
SG
417config VIDEO_TEGRA20
418 bool "Enable LCD support on Tegra20"
40d56a91 419 depends on OF_CONTROL
d2f90650
SG
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
e7e8823c
SG
426config VIDEO_TEGRA124
427 bool "Enable video support on Tegra124"
d7659212 428 depends on DM_VIDEO
e7e8823c
SG
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.
801ab9e9
SG
434
435source "drivers/video/bridge/Kconfig"
0b11dbf7 436
27604b15
SG
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
0b11dbf7 446endmenu