xref: /openbmc/linux/drivers/video/fbdev/Kconfig (revision bc33f5e5)
1# SPDX-License-Identifier: GPL-2.0-only
2#
3# fbdev configuration
4#
5
6config FB_CMDLINE
7	bool
8
9config FB_NOTIFY
10	bool
11
12menuconfig FB
13	tristate "Support for frame buffer devices"
14	select FB_CMDLINE
15	select FB_NOTIFY
16	help
17	  The frame buffer device provides an abstraction for the graphics
18	  hardware. It represents the frame buffer of some video hardware and
19	  allows application software to access the graphics hardware through
20	  a well-defined interface, so the software doesn't need to know
21	  anything about the low-level (hardware register) stuff.
22
23	  Frame buffer devices work identically across the different
24	  architectures supported by Linux and make the implementation of
25	  application programs easier and more portable; at this point, an X
26	  server exists which uses the frame buffer device exclusively.
27	  On several non-X86 architectures, the frame buffer device is the
28	  only way to use the graphics hardware.
29
30	  The device is accessed through special device nodes, usually located
31	  in the /dev directory, i.e. /dev/fb*.
32
33	  You need an utility program called fbset to make full use of frame
34	  buffer devices. Please read <file:Documentation/fb/framebuffer.rst>
35	  and the Framebuffer-HOWTO at
36	  <http://www.munted.org.uk/programming/Framebuffer-HOWTO-1.3.html> for more
37	  information.
38
39	  Say Y here and to the driver for your graphics board below if you
40	  are compiling a kernel for a non-x86 architecture.
41
42	  If you are compiling for the x86 architecture, you can say Y if you
43	  want to play with it, but it is not essential. Please note that
44	  running graphical applications that directly touch the hardware
45	  (e.g. an accelerated X server) and that are not frame buffer
46	  device-aware may cause unexpected results. If unsure, say N.
47
48config FIRMWARE_EDID
49	bool "Enable firmware EDID"
50	depends on FB
51	help
52	  This enables access to the EDID transferred from the firmware.
53	  On the i386, this is from the Video BIOS. Enable this if DDC/I2C
54	  transfers do not work for your driver and if you are using
55	  nvidiafb, i810fb or savagefb.
56
57	  In general, choosing Y for this option is safe.  If you
58	  experience extremely long delays while booting before you get
59	  something on your display, try setting this to N.  Matrox cards in
60	  combination with certain motherboards and monitors are known to
61	  suffer from this problem.
62
63config FB_DDC
64	tristate
65	depends on FB
66	select I2C_ALGOBIT
67	select I2C
68
69config FB_CFB_FILLRECT
70	tristate
71	depends on FB
72	help
73	  Include the cfb_fillrect function for generic software rectangle
74	  filling. This is used by drivers that don't provide their own
75	  (accelerated) version.
76
77config FB_CFB_COPYAREA
78	tristate
79	depends on FB
80	help
81	  Include the cfb_copyarea function for generic software area copying.
82	  This is used by drivers that don't provide their own (accelerated)
83	  version.
84
85config FB_CFB_IMAGEBLIT
86	tristate
87	depends on FB
88	help
89	  Include the cfb_imageblit function for generic software image
90	  blitting. This is used by drivers that don't provide their own
91	  (accelerated) version.
92
93config FB_CFB_REV_PIXELS_IN_BYTE
94	bool
95	depends on FB
96	help
97	  Allow generic frame-buffer functions to work on displays with 1, 2
98	  and 4 bits per pixel depths which has opposite order of pixels in
99	  byte order to bytes in long order.
100
101config FB_SYS_FILLRECT
102	tristate
103	depends on FB
104	help
105	  Include the sys_fillrect function for generic software rectangle
106	  filling. This is used by drivers that don't provide their own
107	  (accelerated) version and the framebuffer is in system RAM.
108
109config FB_SYS_COPYAREA
110	tristate
111	depends on FB
112	help
113	  Include the sys_copyarea function for generic software area copying.
114	  This is used by drivers that don't provide their own (accelerated)
115	  version and the framebuffer is in system RAM.
116
117config FB_SYS_IMAGEBLIT
118	tristate
119	depends on FB
120	help
121	  Include the sys_imageblit function for generic software image
122	  blitting. This is used by drivers that don't provide their own
123	  (accelerated) version and the framebuffer is in system RAM.
124
125config FB_PROVIDE_GET_FB_UNMAPPED_AREA
126	bool
127	depends on FB
128	help
129	  Allow generic frame-buffer to provide get_fb_unmapped_area
130	  function.
131
132menuconfig FB_FOREIGN_ENDIAN
133	bool "Framebuffer foreign endianness support"
134	depends on FB
135	help
136	  This menu will let you enable support for the framebuffers with
137	  non-native endianness (e.g. Little-Endian framebuffer on a
138	  Big-Endian machine). Most probably you don't have such hardware,
139	  so it's safe to say "n" here.
140
141choice
142	prompt "Choice endianness support"
143	depends on FB_FOREIGN_ENDIAN
144
145config FB_BOTH_ENDIAN
146	bool "Support for Big- and Little-Endian framebuffers"
147
148config FB_BIG_ENDIAN
149	bool "Support for Big-Endian framebuffers only"
150
151config FB_LITTLE_ENDIAN
152	bool "Support for Little-Endian framebuffers only"
153
154endchoice
155
156config FB_SYS_FOPS
157	tristate
158	depends on FB
159
160config FB_DEFERRED_IO
161	bool
162	depends on FB
163
164config FB_HECUBA
165	tristate
166	depends on FB
167	depends on FB_DEFERRED_IO
168
169config FB_SVGALIB
170	tristate
171	depends on FB
172	help
173	  Common utility functions useful to fbdev drivers of VGA-based
174	  cards.
175
176config FB_MACMODES
177	tristate
178	depends on FB
179
180config FB_BACKLIGHT
181	tristate
182	depends on FB
183	select BACKLIGHT_CLASS_DEVICE
184
185config FB_MODE_HELPERS
186	bool "Enable Video Mode Handling Helpers"
187	depends on FB
188	help
189	  This enables functions for handling video modes using the
190	  Generalized Timing Formula and the EDID parser. A few drivers rely
191	  on this feature such as the radeonfb, rivafb, and the i810fb. If
192	  your driver does not take advantage of this feature, choosing Y will
193	  just increase the kernel size by about 5K.
194
195config FB_TILEBLITTING
196	bool "Enable Tile Blitting Support"
197	depends on FB
198	help
199	  This enables tile blitting.  Tile blitting is a drawing technique
200	  where the screen is divided into rectangular sections (tiles), whereas
201	  the standard blitting divides the screen into pixels. Because the
202	  default drawing element is a tile, drawing functions will be passed
203	  parameters in terms of number of tiles instead of number of pixels.
204	  For example, to draw a single character, instead of using bitmaps,
205	  an index to an array of bitmaps will be used.  To clear or move a
206	  rectangular section of a screen, the rectangle will be described in
207	  terms of number of tiles in the x- and y-axis.
208
209	  This is particularly important to one driver, matroxfb.  If
210	  unsure, say N.
211
212comment "Frame buffer hardware drivers"
213	depends on FB
214
215config FB_GRVGA
216	tristate "Aeroflex Gaisler framebuffer support"
217	depends on FB && SPARC
218	select FB_CFB_FILLRECT
219	select FB_CFB_COPYAREA
220	select FB_CFB_IMAGEBLIT
221	help
222	  This enables support for the SVGACTRL framebuffer in the GRLIB IP library from Aeroflex Gaisler.
223
224config FB_CIRRUS
225	tristate "Cirrus Logic support"
226	depends on FB && (ZORRO || PCI)
227	select FB_CFB_FILLRECT
228	select FB_CFB_COPYAREA
229	select FB_CFB_IMAGEBLIT
230	select VIDEO_NOMODESET
231	help
232	  This enables support for Cirrus Logic GD542x/543x based boards on
233	  Amiga: SD64, Piccolo, Picasso II/II+, Picasso IV, or EGS Spectrum.
234
235	  If you have a PCI-based system, this enables support for these
236	  chips: GD-543x, GD-544x, GD-5480.
237
238	  Please read the file <file:Documentation/fb/cirrusfb.rst>.
239
240	  Say N unless you have such a graphics board or plan to get one
241	  before you next recompile the kernel.
242
243config FB_PM2
244	tristate "Permedia2 support"
245	depends on FB && ((AMIGA && BROKEN) || PCI)
246	select FB_CFB_FILLRECT
247	select FB_CFB_COPYAREA
248	select FB_CFB_IMAGEBLIT
249	select VIDEO_NOMODESET
250	help
251	  This is the frame buffer device driver for cards based on
252	  the 3D Labs Permedia, Permedia 2 and Permedia 2V chips.
253	  The driver was tested on the following cards:
254		Diamond FireGL 1000 PRO AGP
255		ELSA Gloria Synergy PCI
256		Appian Jeronimo PRO (both heads) PCI
257		3DLabs Oxygen ACX aka EONtronics Picasso P2 PCI
258		Techsource Raptor GFX-8P (aka Sun PGX-32) on SPARC
259		ASK Graphic Blaster Exxtreme AGP
260
261	  To compile this driver as a module, choose M here: the
262	  module will be called pm2fb.
263
264config FB_PM2_FIFO_DISCONNECT
265	bool "enable FIFO disconnect feature"
266	depends on FB_PM2 && PCI
267	help
268	  Support the Permedia2 FIFO disconnect feature.
269
270config FB_ARMCLCD
271	tristate "ARM PrimeCell PL110 support"
272	depends on ARM || ARM64 || COMPILE_TEST
273	depends on FB && ARM_AMBA && HAS_IOMEM
274	select FB_CFB_FILLRECT
275	select FB_CFB_COPYAREA
276	select FB_CFB_IMAGEBLIT
277	select FB_MODE_HELPERS if OF
278	select VIDEOMODE_HELPERS if OF
279	select BACKLIGHT_CLASS_DEVICE if OF
280	help
281	  This framebuffer device driver is for the ARM PrimeCell PL110
282	  Colour LCD controller.  ARM PrimeCells provide the building
283	  blocks for System on a Chip devices.
284
285	  If you want to compile this as a module (=code which can be
286	  inserted into and removed from the running kernel), say M
287	  here and read <file:Documentation/kbuild/modules.rst>.  The module
288	  will be called amba-clcd.
289
290config FB_ACORN
291	bool "Acorn VIDC support"
292	depends on (FB = y) && ARM && ARCH_ACORN
293	select FB_CFB_FILLRECT
294	select FB_CFB_COPYAREA
295	select FB_CFB_IMAGEBLIT
296	help
297	  This is the frame buffer device driver for the Acorn VIDC graphics
298	  hardware found in Acorn RISC PCs and other ARM-based machines.  If
299	  unsure, say N.
300
301config FB_CLPS711X
302	tristate "CLPS711X LCD support"
303	depends on FB && (ARCH_CLPS711X || COMPILE_TEST)
304	select FB_MODE_HELPERS
305	select FB_SYS_FILLRECT
306	select FB_SYS_COPYAREA
307	select FB_SYS_IMAGEBLIT
308	select LCD_CLASS_DEVICE
309	select VIDEOMODE_HELPERS
310	help
311	  Say Y to enable the Framebuffer driver for the Cirrus Logic
312	  CLPS711X CPUs.
313
314config FB_SA1100
315	bool "SA-1100 LCD support"
316	depends on (FB = y) && ARM && ARCH_SA1100
317	select FB_CFB_FILLRECT
318	select FB_CFB_COPYAREA
319	select FB_CFB_IMAGEBLIT
320	help
321	  This is a framebuffer device for the SA-1100 LCD Controller.
322	  See <http://www.linux-fbdev.org/> for information on framebuffer
323	  devices.
324
325	  If you plan to use the LCD display with your SA-1100 system, say
326	  Y here.
327
328config FB_IMX
329	tristate "Freescale i.MX1/21/25/27 LCD support"
330	depends on FB && HAVE_CLK && HAS_IOMEM
331	depends on ARCH_MXC || COMPILE_TEST
332	select LCD_CLASS_DEVICE
333	select FB_CFB_FILLRECT
334	select FB_CFB_COPYAREA
335	select FB_CFB_IMAGEBLIT
336	select FB_MODE_HELPERS
337	select VIDEOMODE_HELPERS
338
339config FB_CYBER2000
340	tristate "CyberPro 2000/2010/5000 support"
341	depends on FB && PCI && (BROKEN || !SPARC64)
342	select FB_CFB_FILLRECT
343	select FB_CFB_COPYAREA
344	select FB_CFB_IMAGEBLIT
345	select VIDEO_NOMODESET
346	help
347	  This enables support for the Integraphics CyberPro 20x0 and 5000
348	  VGA chips used in the Rebel.com Netwinder and other machines.
349	  Say Y if you have a NetWinder or a graphics card containing this
350	  device, otherwise say N.
351
352config FB_CYBER2000_DDC
353	bool "DDC for CyberPro support"
354	depends on FB_CYBER2000
355	select FB_DDC
356	default y
357	help
358	  Say Y here if you want DDC support for your CyberPro graphics
359	  card. This is only I2C bus support, driver does not use EDID.
360
361config FB_CYBER2000_I2C
362	bool "CyberPro 2000/2010/5000 I2C support"
363	depends on FB_CYBER2000 && I2C && ARCH_NETWINDER
364	depends on I2C=y || FB_CYBER2000=m
365	select I2C_ALGOBIT
366	help
367	  Enable support for the I2C video decoder interface on the
368	  Integraphics CyberPro 20x0 and 5000 VGA chips.  This is used
369	  on the Netwinder machines for the SAA7111 video capture.
370
371config FB_APOLLO
372	bool
373	depends on (FB = y) && APOLLO
374	default y
375	select FB_CFB_FILLRECT
376	select FB_CFB_IMAGEBLIT
377
378config FB_Q40
379	bool
380	depends on (FB = y) && Q40
381	default y
382	select FB_CFB_FILLRECT
383	select FB_CFB_COPYAREA
384	select FB_CFB_IMAGEBLIT
385
386config FB_AMIGA
387	tristate "Amiga native chipset support"
388	depends on FB && AMIGA
389	help
390	  This is the frame buffer device driver for the builtin graphics
391	  chipset found in Amigas.
392
393	  To compile this driver as a module, choose M here: the
394	  module will be called amifb.
395
396config FB_AMIGA_OCS
397	bool "Amiga OCS chipset support"
398	depends on FB_AMIGA
399	help
400	  This enables support for the original Agnus and Denise video chips,
401	  found in the Amiga 1000 and most A500's and A2000's. If you intend
402	  to run Linux on any of these systems, say Y; otherwise say N.
403
404config FB_AMIGA_ECS
405	bool "Amiga ECS chipset support"
406	depends on FB_AMIGA
407	help
408	  This enables support for the Enhanced Chip Set, found in later
409	  A500's, later A2000's, the A600, the A3000, the A3000T and CDTV. If
410	  you intend to run Linux on any of these systems, say Y; otherwise
411	  say N.
412
413config FB_AMIGA_AGA
414	bool "Amiga AGA chipset support"
415	depends on FB_AMIGA
416	help
417	  This enables support for the Advanced Graphics Architecture (also
418	  known as the AGA or AA) Chip Set, found in the A1200, A4000, A4000T
419	  and CD32. If you intend to run Linux on any of these systems, say Y;
420	  otherwise say N.
421
422config FB_FM2
423	bool "Amiga FrameMaster II/Rainbow II support"
424	depends on (FB = y) && ZORRO
425	select FB_CFB_FILLRECT
426	select FB_CFB_COPYAREA
427	select FB_CFB_IMAGEBLIT
428	help
429	  This is the frame buffer device driver for the Amiga FrameMaster
430	  card from BSC (exhibited 1992 but not shipped as a CBM product).
431
432config FB_ARC
433	tristate "Arc Monochrome LCD board support"
434	depends on FB && (X86 || COMPILE_TEST)
435	select FB_SYS_FILLRECT
436	select FB_SYS_COPYAREA
437	select FB_SYS_IMAGEBLIT
438	select FB_SYS_FOPS
439	help
440	  This enables support for the Arc Monochrome LCD board. The board
441	  is based on the KS-108 lcd controller and is typically a matrix
442	  of 2*n chips. This driver was tested with a 128x64 panel. This
443	  driver supports it for use with x86 SBCs through a 16 bit GPIO
444	  interface (8 bit data, 8 bit control). If you anticipate using
445	  this driver, say Y or M; otherwise say N. You must specify the
446	  GPIO IO address to be used for setting control and data.
447
448config FB_ATARI
449	bool "Atari native chipset support"
450	depends on (FB = y) && ATARI
451	select FB_CFB_FILLRECT
452	select FB_CFB_COPYAREA
453	select FB_CFB_IMAGEBLIT
454	help
455	  This is the frame buffer device driver for the builtin graphics
456	  chipset found in Ataris.
457
458config FB_OF
459	bool "Open Firmware frame buffer device support"
460	depends on (FB = y) && PPC && (!PPC_PSERIES || PCI)
461	depends on !DRM_OFDRM
462	select APERTURE_HELPERS
463	select FB_CFB_FILLRECT
464	select FB_CFB_COPYAREA
465	select FB_CFB_IMAGEBLIT
466	select FB_MACMODES
467	help
468	  Say Y if you want support with Open Firmware for your graphics
469	  board.
470
471config FB_CONTROL
472	bool "Apple \"control\" display support"
473	depends on (FB = y) && ((PPC_PMAC && PPC32) || COMPILE_TEST)
474	select FB_CFB_FILLRECT
475	select FB_CFB_COPYAREA
476	select FB_CFB_IMAGEBLIT
477	select FB_MACMODES
478	help
479	  This driver supports a frame buffer for the graphics adapter in the
480	  Power Macintosh 7300 and others.
481
482config FB_PLATINUM
483	bool "Apple \"platinum\" display support"
484	depends on (FB = y) && PPC_PMAC && PPC32
485	select FB_CFB_FILLRECT
486	select FB_CFB_COPYAREA
487	select FB_CFB_IMAGEBLIT
488	select FB_MACMODES
489	help
490	  This driver supports a frame buffer for the "platinum" graphics
491	  adapter in some Power Macintoshes.
492
493config FB_VALKYRIE
494	bool "Apple \"valkyrie\" display support"
495	depends on (FB = y) && (MAC || (PPC_PMAC && PPC32))
496	select FB_CFB_FILLRECT
497	select FB_CFB_COPYAREA
498	select FB_CFB_IMAGEBLIT
499	select FB_MACMODES
500	help
501	  This driver supports a frame buffer for the "valkyrie" graphics
502	  adapter in some Power Macintoshes.
503
504config FB_CT65550
505	bool "Chips 65550 display support"
506	depends on (FB = y) && PPC32 && PCI
507	select FB_CFB_FILLRECT
508	select FB_CFB_COPYAREA
509	select FB_CFB_IMAGEBLIT
510	select VIDEO_NOMODESET
511	help
512	  This is the frame buffer device driver for the Chips & Technologies
513	  65550 graphics chip in PowerBooks.
514
515config FB_ASILIANT
516	bool "Asiliant (Chips) 69000 display support"
517	depends on (FB = y) && PCI
518	select FB_CFB_FILLRECT
519	select FB_CFB_COPYAREA
520	select FB_CFB_IMAGEBLIT
521	select VIDEO_NOMODESET
522	help
523	  This is the frame buffer device driver for the Asiliant 69030 chipset
524
525config FB_IMSTT
526	bool "IMS Twin Turbo display support"
527	depends on (FB = y) && PCI
528	select FB_CFB_IMAGEBLIT
529	select FB_MACMODES if PPC_PMAC
530	select VIDEO_NOMODESET
531	help
532	  The IMS Twin Turbo is a PCI-based frame buffer card bundled with
533	  many Macintosh and compatible computers.
534
535config FB_VGA16
536	tristate "VGA 16-color graphics support"
537	depends on FB && (X86 || PPC)
538	select APERTURE_HELPERS
539	select FB_CFB_FILLRECT
540	select FB_CFB_COPYAREA
541	select FB_CFB_IMAGEBLIT
542	select VGASTATE
543	select FONT_8x16 if FRAMEBUFFER_CONSOLE
544	help
545	  This is the frame buffer device driver for VGA 16 color graphic
546	  cards. Say Y if you have such a card.
547
548	  To compile this driver as a module, choose M here: the
549	  module will be called vga16fb.
550
551config FB_STI
552	tristate "HP STI frame buffer device support"
553	depends on FB && PARISC
554	select FB_CFB_FILLRECT
555	select FB_CFB_COPYAREA
556	select FB_CFB_IMAGEBLIT
557	default y
558	help
559	  STI refers to the HP "Standard Text Interface" which is a set of
560	  BIOS routines contained in a ROM chip in HP PA-RISC based machines.
561	  Enabling this option will implement the linux framebuffer device
562	  using calls to the STI BIOS routines for initialisation.
563
564	  If you enable this option, you will get a planar framebuffer device
565	  /dev/fb which will work on the most common HP graphic cards of the
566	  NGLE family, including the artist chips (in the 7xx and Bxxx series),
567	  HCRX, HCRX24, CRX, CRX24 and VisEG series.
568
569	  It is safe to enable this option, so you should probably say "Y".
570
571config FB_MAC
572	bool "Generic Macintosh display support"
573	depends on (FB = y) && MAC
574	select FB_CFB_FILLRECT
575	select FB_CFB_COPYAREA
576	select FB_CFB_IMAGEBLIT
577	select FB_MACMODES
578
579config FB_HP300
580	bool
581	depends on (FB = y) && DIO
582	select FB_CFB_IMAGEBLIT
583	default y
584
585config FB_TGA
586	tristate "TGA/SFB+ framebuffer support"
587	depends on FB
588	depends on PCI || TC
589	depends on ALPHA || TC
590	select FB_CFB_FILLRECT
591	select FB_CFB_COPYAREA
592	select FB_CFB_IMAGEBLIT
593	select BITREVERSE
594	select VIDEO_NOMODESET
595	help
596	  This is the frame buffer device driver for generic TGA and SFB+
597	  graphic cards.  These include DEC ZLXp-E1, -E2 and -E3 PCI cards,
598	  also known as PBXGA-A, -B and -C, and DEC ZLX-E1, -E2 and -E3
599	  TURBOchannel cards, also known as PMAGD-A, -B and -C.
600
601	  Due to hardware limitations ZLX-E2 and E3 cards are not supported
602	  for DECstation 5000/200 systems.  Additionally due to firmware
603	  limitations these cards may cause troubles with booting DECstation
604	  5000/240 and /260 systems, but are fully supported under Linux if
605	  you manage to get it going. ;-)
606
607	  Say Y if you have one of those.
608
609config FB_UVESA
610	tristate "Userspace VESA VGA graphics support"
611	depends on FB && CONNECTOR
612	select FB_CFB_FILLRECT
613	select FB_CFB_COPYAREA
614	select FB_CFB_IMAGEBLIT
615	select FB_MODE_HELPERS
616	help
617	  This is the frame buffer driver for generic VBE 2.0 compliant
618	  graphic cards. It can also take advantage of VBE 3.0 features,
619	  such as refresh rate adjustment.
620
621	  This driver generally provides more features than vesafb but
622	  requires a userspace helper application called 'v86d'. See
623	  <file:Documentation/fb/uvesafb.rst> for more information.
624
625	  If unsure, say N.
626
627config FB_VESA
628	bool "VESA VGA graphics support"
629	depends on (FB = y) && X86
630	select APERTURE_HELPERS
631	select FB_CFB_FILLRECT
632	select FB_CFB_COPYAREA
633	select FB_CFB_IMAGEBLIT
634	select SYSFB
635	help
636	  This is the frame buffer device driver for generic VESA 2.0
637	  compliant graphic cards. The older VESA 1.2 cards are not supported.
638	  You will get a boot time penguin logo at no additional cost. Please
639	  read <file:Documentation/fb/vesafb.rst>. If unsure, say Y.
640
641config FB_EFI
642	bool "EFI-based Framebuffer Support"
643	depends on (FB = y) && !IA64 && EFI
644	select APERTURE_HELPERS
645	select DRM_PANEL_ORIENTATION_QUIRKS
646	select FB_CFB_FILLRECT
647	select FB_CFB_COPYAREA
648	select FB_CFB_IMAGEBLIT
649	select SYSFB
650	help
651	  This is the EFI frame buffer device driver. If the firmware on
652	  your platform is EFI 1.10 or UEFI 2.0, select Y to add support for
653	  using the EFI framebuffer as your console.
654
655config FB_N411
656	tristate "N411 Apollo/Hecuba devkit support"
657	depends on FB && X86 && MMU
658	select FB_SYS_FILLRECT
659	select FB_SYS_COPYAREA
660	select FB_SYS_IMAGEBLIT
661	select FB_SYS_FOPS
662	select FB_DEFERRED_IO
663	select FB_HECUBA
664	help
665	  This enables support for the Apollo display controller in its
666	  Hecuba form using the n411 devkit.
667
668config FB_HGA
669	tristate "Hercules mono graphics support"
670	depends on FB && X86
671	help
672	  Say Y here if you have a Hercules mono graphics card.
673
674	  To compile this driver as a module, choose M here: the
675	  module will be called hgafb.
676
677	  As this card technology is at least 25 years old,
678	  most people will answer N here.
679
680config FB_GBE
681	bool "SGI Graphics Backend frame buffer support"
682	depends on (FB = y) && HAS_IOMEM
683	depends on SGI_IP32 || COMPILE_TEST
684	select FB_CFB_FILLRECT
685	select FB_CFB_COPYAREA
686	select FB_CFB_IMAGEBLIT
687	help
688	  This is the frame buffer device driver for SGI Graphics Backend.
689	  This chip is used in SGI O2 and Visual Workstation 320/540.
690
691config FB_GBE_MEM
692	int "Video memory size in MB"
693	depends on FB_GBE
694	default 4
695	help
696	  This is the amount of memory reserved for the framebuffer,
697	  which can be any value between 1MB and 8MB.
698
699config FB_SBUS
700	bool "SBUS and UPA framebuffers"
701	depends on (FB = y) && SPARC
702	help
703	  Say Y if you want support for SBUS or UPA based frame buffer device.
704
705config FB_BW2
706	bool "BWtwo support"
707	depends on (FB = y) && (SPARC && FB_SBUS)
708	select FB_CFB_FILLRECT
709	select FB_CFB_COPYAREA
710	select FB_CFB_IMAGEBLIT
711	help
712	  This is the frame buffer device driver for the BWtwo frame buffer.
713
714config FB_CG3
715	bool "CGthree support"
716	depends on (FB = y) && (SPARC && FB_SBUS)
717	select FB_CFB_FILLRECT
718	select FB_CFB_COPYAREA
719	select FB_CFB_IMAGEBLIT
720	help
721	  This is the frame buffer device driver for the CGthree frame buffer.
722
723config FB_CG6
724	bool "CGsix (GX,TurboGX) support"
725	depends on (FB = y) && (SPARC && FB_SBUS)
726	select FB_CFB_COPYAREA
727	select FB_CFB_IMAGEBLIT
728	help
729	  This is the frame buffer device driver for the CGsix (GX, TurboGX)
730	  frame buffer.
731
732config FB_FFB
733	bool "Creator/Creator3D/Elite3D support"
734	depends on FB_SBUS && SPARC64
735	select FB_CFB_COPYAREA
736	select FB_CFB_IMAGEBLIT
737	help
738	  This is the frame buffer device driver for the Creator, Creator3D,
739	  and Elite3D graphics boards.
740
741config FB_TCX
742	bool "TCX (SS4/SS5 only) support"
743	depends on FB_SBUS
744	select FB_CFB_FILLRECT
745	select FB_CFB_COPYAREA
746	select FB_CFB_IMAGEBLIT
747	help
748	  This is the frame buffer device driver for the TCX 24/8bit frame
749	  buffer.
750
751config FB_CG14
752	bool "CGfourteen (SX) support"
753	depends on FB_SBUS
754	select FB_CFB_FILLRECT
755	select FB_CFB_COPYAREA
756	select FB_CFB_IMAGEBLIT
757	help
758	  This is the frame buffer device driver for the CGfourteen frame
759	  buffer on Desktop SPARCsystems with the SX graphics option.
760
761config FB_P9100
762	bool "P9100 (Sparcbook 3 only) support"
763	depends on FB_SBUS
764	select FB_CFB_FILLRECT
765	select FB_CFB_COPYAREA
766	select FB_CFB_IMAGEBLIT
767	help
768	  This is the frame buffer device driver for the P9100 card
769	  supported on Sparcbook 3 machines.
770
771config FB_LEO
772	bool "Leo (ZX) support"
773	depends on FB_SBUS
774	select FB_CFB_FILLRECT
775	select FB_CFB_COPYAREA
776	select FB_CFB_IMAGEBLIT
777	help
778	  This is the frame buffer device driver for the SBUS-based Sun ZX
779	  (leo) frame buffer cards.
780
781config FB_XVR500
782	bool "Sun XVR-500 3DLABS Wildcat support"
783	depends on (FB = y) && PCI && SPARC64
784	select FB_CFB_FILLRECT
785	select FB_CFB_COPYAREA
786	select FB_CFB_IMAGEBLIT
787	select VIDEO_NOMODESET
788	help
789	  This is the framebuffer device for the Sun XVR-500 and similar
790	  graphics cards based upon the 3DLABS Wildcat chipset.  The driver
791	  only works on sparc64 systems where the system firmware has
792	  mostly initialized the card already.  It is treated as a
793	  completely dumb framebuffer device.
794
795config FB_XVR2500
796	bool "Sun XVR-2500 3DLABS Wildcat support"
797	depends on (FB = y) && PCI && SPARC64
798	select FB_CFB_FILLRECT
799	select FB_CFB_COPYAREA
800	select FB_CFB_IMAGEBLIT
801	select VIDEO_NOMODESET
802	help
803	  This is the framebuffer device for the Sun XVR-2500 and similar
804	  graphics cards based upon the 3DLABS Wildcat chipset.  The driver
805	  only works on sparc64 systems where the system firmware has
806	  mostly initialized the card already.  It is treated as a
807	  completely dumb framebuffer device.
808
809config FB_XVR1000
810	bool "Sun XVR-1000 support"
811	depends on (FB = y) && SPARC64
812	select FB_CFB_FILLRECT
813	select FB_CFB_COPYAREA
814	select FB_CFB_IMAGEBLIT
815	help
816	  This is the framebuffer device for the Sun XVR-1000 and similar
817	  graphics cards.  The driver only works on sparc64 systems where
818	  the system firmware has mostly initialized the card already.  It
819	  is treated as a completely dumb framebuffer device.
820
821config FB_PVR2
822	tristate "NEC PowerVR 2 display support"
823	depends on FB && HAS_IOMEM
824	depends on SH_DREAMCAST || COMPILE_TEST
825	select FB_CFB_FILLRECT
826	select FB_CFB_COPYAREA
827	select FB_CFB_IMAGEBLIT
828	select VIDEO_NOMODESET
829	help
830	  Say Y here if you have a PowerVR 2 card in your box.  If you plan to
831	  run linux on your Dreamcast, you will have to say Y here.
832	  This driver may or may not work on other PowerVR 2 cards, but is
833	  totally untested.  Use at your own risk.  If unsure, say N.
834
835	  To compile this driver as a module, choose M here: the
836	  module will be called pvr2fb.
837
838	  You can pass several parameters to the driver at boot time or at
839	  module load time.  The parameters look like "video=pvr2:XXX", where
840	  the meaning of XXX can be found at the end of the main source file
841	  (<file:drivers/video/fbdev/pvr2fb.c>). Please see the file
842	  <file:Documentation/fb/pvr2fb.rst>.
843
844config FB_OPENCORES
845	tristate "OpenCores VGA/LCD core 2.0 framebuffer support"
846	depends on FB && HAS_DMA
847	select FB_CFB_FILLRECT
848	select FB_CFB_COPYAREA
849	select FB_CFB_IMAGEBLIT
850	help
851	  This enables support for the OpenCores VGA/LCD core.
852
853	  The OpenCores VGA/LCD core is typically used together with
854	  softcore CPUs (e.g. OpenRISC or Microblaze) or hard processor
855	  systems (e.g. Altera socfpga or Xilinx Zynq) on FPGAs.
856
857	  The source code and specification for the core is available at
858	  <https://opencores.org/project,vga_lcd>
859
860config FB_S1D13XXX
861	tristate "Epson S1D13XXX framebuffer support"
862	depends on FB
863	select FB_CFB_FILLRECT
864	select FB_CFB_COPYAREA
865	select FB_CFB_IMAGEBLIT
866	help
867	  Support for S1D13XXX framebuffer device family (currently only
868	  working with S1D13806). Product specs at
869	  <https://vdc.epson.com/>
870
871config FB_ATMEL
872	tristate "AT91 LCD Controller support"
873	depends on FB && OF && HAVE_CLK && HAS_IOMEM
874	depends on HAVE_FB_ATMEL || COMPILE_TEST
875	select FB_BACKLIGHT
876	select FB_CFB_FILLRECT
877	select FB_CFB_COPYAREA
878	select FB_CFB_IMAGEBLIT
879	select FB_MODE_HELPERS
880	select VIDEOMODE_HELPERS
881	help
882	  This enables support for the AT91 LCD Controller.
883
884config FB_NVIDIA
885	tristate "nVidia Framebuffer Support"
886	depends on FB && PCI
887	select FB_BACKLIGHT if FB_NVIDIA_BACKLIGHT
888	select FB_MODE_HELPERS
889	select FB_CFB_FILLRECT
890	select FB_CFB_COPYAREA
891	select FB_CFB_IMAGEBLIT
892	select BITREVERSE
893	select VGASTATE
894	select VIDEO_NOMODESET
895	help
896	  This driver supports graphics boards with the nVidia chips, TNT
897	  and newer. For very old chipsets, such as the RIVA128, then use
898	  the rivafb.
899	  Say Y if you have such a graphics board.
900
901	  To compile this driver as a module, choose M here: the
902	  module will be called nvidiafb.
903
904config FB_NVIDIA_I2C
905	bool "Enable DDC Support"
906	depends on FB_NVIDIA
907	select FB_DDC
908	help
909	  This enables I2C support for nVidia Chipsets.  This is used
910	  only for getting EDID information from the attached display
911	  allowing for robust video mode handling and switching.
912
913	  Because fbdev-2.6 requires that drivers must be able to
914	  independently validate video mode parameters, you should say Y
915	  here.
916
917config FB_NVIDIA_DEBUG
918	bool "Lots of debug output"
919	depends on FB_NVIDIA
920	help
921	  Say Y here if you want the nVidia driver to output all sorts
922	  of debugging information to provide to the maintainer when
923	  something goes wrong.
924
925config FB_NVIDIA_BACKLIGHT
926	bool "Support for backlight control"
927	depends on FB_NVIDIA
928	default y
929	help
930	  Say Y here if you want to control the backlight of your display.
931
932config FB_RIVA
933	tristate "nVidia Riva support"
934	depends on FB && PCI
935	select FB_BACKLIGHT if FB_RIVA_BACKLIGHT
936	select FB_MODE_HELPERS
937	select FB_CFB_FILLRECT
938	select FB_CFB_COPYAREA
939	select FB_CFB_IMAGEBLIT
940	select BITREVERSE
941	select VGASTATE
942	select VIDEO_NOMODESET
943	help
944	  This driver supports graphics boards with the nVidia Riva/Geforce
945	  chips.
946	  Say Y if you have such a graphics board.
947
948	  To compile this driver as a module, choose M here: the
949	  module will be called rivafb.
950
951config FB_RIVA_I2C
952	bool "Enable DDC Support"
953	depends on FB_RIVA
954	select FB_DDC
955	help
956	  This enables I2C support for nVidia Chipsets.  This is used
957	  only for getting EDID information from the attached display
958	  allowing for robust video mode handling and switching.
959
960	  Because fbdev-2.6 requires that drivers must be able to
961	  independently validate video mode parameters, you should say Y
962	  here.
963
964config FB_RIVA_DEBUG
965	bool "Lots of debug output"
966	depends on FB_RIVA
967	help
968	  Say Y here if you want the Riva driver to output all sorts
969	  of debugging information to provide to the maintainer when
970	  something goes wrong.
971
972config FB_RIVA_BACKLIGHT
973	bool "Support for backlight control"
974	depends on FB_RIVA
975	default y
976	help
977	  Say Y here if you want to control the backlight of your display.
978
979config FB_I740
980	tristate "Intel740 support"
981	depends on FB && PCI
982	select FB_MODE_HELPERS
983	select FB_CFB_FILLRECT
984	select FB_CFB_COPYAREA
985	select FB_CFB_IMAGEBLIT
986	select VGASTATE
987	select VIDEO_NOMODESET
988	select FB_DDC
989	help
990	  This driver supports graphics cards based on Intel740 chip.
991
992config FB_I810
993	tristate "Intel 810/815 support"
994	depends on FB && PCI && X86_32 && AGP_INTEL
995	select FB_MODE_HELPERS
996	select FB_CFB_FILLRECT
997	select FB_CFB_COPYAREA
998	select FB_CFB_IMAGEBLIT
999	select VGASTATE
1000	select VIDEO_NOMODESET
1001	help
1002	  This driver supports the on-board graphics built in to the Intel 810
1003	  and 815 chipsets.  Say Y if you have and plan to use such a board.
1004
1005	  To compile this driver as a module, choose M here: the
1006	  module will be called i810fb.
1007
1008	  For more information, please read
1009	  <file:Documentation/fb/intel810.rst>
1010
1011config FB_I810_GTF
1012	bool "use VESA Generalized Timing Formula"
1013	depends on FB_I810
1014	help
1015	  If you say Y, then the VESA standard, Generalized Timing Formula
1016	  or GTF, will be used to calculate the required video timing values
1017	  per video mode.  Since the GTF allows nondiscrete timings
1018	  (nondiscrete being a range of values as opposed to discrete being a
1019	  set of values), you'll be able to use any combination of horizontal
1020	  and vertical resolutions, and vertical refresh rates without having
1021	  to specify your own timing parameters.  This is especially useful
1022	  to maximize the performance of an aging display, or if you just
1023	  have a display with nonstandard dimensions. A VESA compliant
1024	  monitor is recommended, but can still work with non-compliant ones.
1025	  If you need or want this, then select this option. The timings may
1026	  not be compliant with Intel's recommended values. Use at your own
1027	  risk.
1028
1029	  If you say N, the driver will revert to discrete video timings
1030	  using a set recommended by Intel in their documentation.
1031
1032	  If unsure, say N.
1033
1034config FB_I810_I2C
1035	bool "Enable DDC Support"
1036	depends on FB_I810 && FB_I810_GTF
1037	select FB_DDC
1038	help
1039	  Add DDC/I2C support for i810fb.  This will allow the driver to get
1040	  display information, especially for monitors with fickle timings.
1041
1042	  If unsure, say Y.
1043
1044config FB_LE80578
1045	tristate "Intel LE80578 (Vermilion) support"
1046	depends on FB && PCI && X86
1047	select FB_MODE_HELPERS
1048	select FB_CFB_FILLRECT
1049	select FB_CFB_COPYAREA
1050	select FB_CFB_IMAGEBLIT
1051	select VIDEO_NOMODESET
1052	help
1053	  This driver supports the LE80578 (Vermilion Range) chipset
1054
1055config FB_CARILLO_RANCH
1056	tristate "Intel Carillo Ranch support"
1057	depends on FB_LE80578 && FB && PCI && X86
1058	help
1059	  This driver supports the LE80578 (Carillo Ranch) board
1060
1061config FB_INTEL
1062	tristate "Intel 830M/845G/852GM/855GM/865G/915G/945G/945GM/965G/965GM support"
1063	depends on FB && PCI && X86 && AGP_INTEL && EXPERT
1064	select FB_MODE_HELPERS
1065	select FB_CFB_FILLRECT
1066	select FB_CFB_COPYAREA
1067	select FB_CFB_IMAGEBLIT
1068	select BOOT_VESA_SUPPORT if FB_INTEL = y
1069	select VIDEO_NOMODESET
1070	depends on !DRM_I915
1071	help
1072	  This driver supports the on-board graphics built in to the Intel
1073	  830M/845G/852GM/855GM/865G/915G/915GM/945G/945GM/965G/965GM chipsets.
1074	  Say Y if you have and plan to use such a board.
1075
1076	  To make FB_INTEL=Y work you need to say AGP_INTEL=y too.
1077
1078	  To compile this driver as a module, choose M here: the
1079	  module will be called intelfb.
1080
1081	  For more information, please read <file:Documentation/fb/intelfb.rst>
1082
1083config FB_INTEL_DEBUG
1084	bool "Intel driver Debug Messages"
1085	depends on FB_INTEL
1086	help
1087	  Say Y here if you want the Intel driver to output all sorts
1088	  of debugging information to provide to the maintainer when
1089	  something goes wrong.
1090
1091config FB_INTEL_I2C
1092	bool "DDC/I2C for Intel framebuffer support"
1093	depends on FB_INTEL
1094	select FB_DDC
1095	default y
1096	help
1097	  Say Y here if you want DDC/I2C support for your on-board Intel graphics.
1098
1099config FB_MATROX
1100	tristate "Matrox acceleration"
1101	depends on FB && PCI
1102	select FB_CFB_FILLRECT
1103	select FB_CFB_COPYAREA
1104	select FB_CFB_IMAGEBLIT
1105	select FB_TILEBLITTING
1106	select FB_MACMODES if PPC_PMAC
1107	select VIDEO_NOMODESET
1108	help
1109	  Say Y here if you have a Matrox Millennium, Matrox Millennium II,
1110	  Matrox Mystique, Matrox Mystique 220, Matrox Productiva G100, Matrox
1111	  Mystique G200, Matrox Millennium G200, Matrox Marvel G200 video,
1112	  Matrox G400, G450 or G550 card in your box.
1113
1114	  To compile this driver as a module, choose M here: the
1115	  module will be called matroxfb.
1116
1117	  You can pass several parameters to the driver at boot time or at
1118	  module load time. The parameters look like "video=matroxfb:XXX", and
1119	  are described in <file:Documentation/fb/matroxfb.rst>.
1120
1121config FB_MATROX_MILLENIUM
1122	bool "Millennium I/II support"
1123	depends on FB_MATROX
1124	help
1125	  Say Y here if you have a Matrox Millennium or Matrox Millennium II
1126	  video card. If you select "Advanced lowlevel driver options" below,
1127	  you should check 4 bpp packed pixel, 8 bpp packed pixel, 16 bpp
1128	  packed pixel, 24 bpp packed pixel and 32 bpp packed pixel. You can
1129	  also use font widths different from 8.
1130
1131config FB_MATROX_MYSTIQUE
1132	bool "Mystique support"
1133	depends on FB_MATROX
1134	help
1135	  Say Y here if you have a Matrox Mystique or Matrox Mystique 220
1136	  video card. If you select "Advanced lowlevel driver options" below,
1137	  you should check 8 bpp packed pixel, 16 bpp packed pixel, 24 bpp
1138	  packed pixel and 32 bpp packed pixel. You can also use font widths
1139	  different from 8.
1140
1141config FB_MATROX_G
1142	bool "G100/G200/G400/G450/G550 support"
1143	depends on FB_MATROX
1144	help
1145	  Say Y here if you have a Matrox G100, G200, G400, G450 or G550 based
1146	  video card. If you select "Advanced lowlevel driver options", you
1147	  should check 8 bpp packed pixel, 16 bpp packed pixel, 24 bpp packed
1148	  pixel and 32 bpp packed pixel. You can also use font widths
1149	  different from 8.
1150
1151	  If you need support for G400 secondary head, you must say Y to
1152	  "Matrox I2C support" and "G400 second head support" right below.
1153	  G450/G550 secondary head and digital output are supported without
1154	  additional modules.
1155
1156	  The driver starts in monitor mode. You must use the matroxset tool
1157	  (available at <ftp://platan.vc.cvut.cz/pub/linux/matrox-latest/>) to
1158	  swap primary and secondary head outputs, or to change output mode.
1159	  Secondary head driver always start in 640x480 resolution and you
1160	  must use fbset to change it.
1161
1162	  Do not forget that second head supports only 16 and 32 bpp
1163	  packed pixels, so it is a good idea to compile them into the kernel
1164	  too. You can use only some font widths, as the driver uses generic
1165	  painting procedures (the secondary head does not use acceleration
1166	  engine).
1167
1168	  G450/G550 hardware can display TV picture only from secondary CRTC,
1169	  and it performs no scaling, so picture must have 525 or 625 lines.
1170
1171config FB_MATROX_I2C
1172	tristate "Matrox I2C support"
1173	depends on FB_MATROX
1174	select FB_DDC
1175	help
1176	  This drivers creates I2C buses which are needed for accessing the
1177	  DDC (I2C) bus present on all Matroxes, an I2C bus which
1178	  interconnects Matrox optional devices, like MGA-TVO on G200 and
1179	  G400, and the secondary head DDC bus, present on G400 only.
1180
1181	  You can say Y or M here if you want to experiment with monitor
1182	  detection code. You must say Y or M here if you want to use either
1183	  second head of G400 or MGA-TVO on G200 or G400.
1184
1185	  If you compile it as module, it will create a module named
1186	  i2c-matroxfb.
1187
1188config FB_MATROX_MAVEN
1189	tristate "G400 second head support"
1190	depends on FB_MATROX_G && FB_MATROX_I2C
1191	help
1192	  WARNING !!! This support does not work with G450 !!!
1193
1194	  Say Y or M here if you want to use a secondary head (meaning two
1195	  monitors in parallel) on G400 or MGA-TVO add-on on G200. Secondary
1196	  head is not compatible with accelerated XFree 3.3.x SVGA servers -
1197	  secondary head output is blanked while you are in X. With XFree
1198	  3.9.17 preview you can use both heads if you use SVGA over fbdev or
1199	  the fbdev driver on first head and the fbdev driver on second head.
1200
1201	  If you compile it as module, two modules are created,
1202	  matroxfb_crtc2 and matroxfb_maven. Matroxfb_maven is needed for
1203	  both G200 and G400, matroxfb_crtc2 is needed only by G400. You must
1204	  also load i2c-matroxfb to get it to run.
1205
1206	  The driver starts in monitor mode and you must use the matroxset
1207	  tool (available at
1208	  <ftp://platan.vc.cvut.cz/pub/linux/matrox-latest/>) to switch it to
1209	  PAL or NTSC or to swap primary and secondary head outputs.
1210	  Secondary head driver also always start in 640x480 resolution, you
1211	  must use fbset to change it.
1212
1213	  Also do not forget that second head supports only 16 and 32 bpp
1214	  packed pixels, so it is a good idea to compile them into the kernel
1215	  too.  You can use only some font widths, as the driver uses generic
1216	  painting procedures (the secondary head does not use acceleration
1217	  engine).
1218
1219config FB_RADEON
1220	tristate "ATI Radeon display support"
1221	depends on FB && PCI
1222	select FB_BACKLIGHT if FB_RADEON_BACKLIGHT
1223	select FB_MODE_HELPERS
1224	select FB_CFB_FILLRECT
1225	select FB_CFB_COPYAREA
1226	select FB_CFB_IMAGEBLIT
1227	select FB_MACMODES if PPC
1228	select VIDEO_NOMODESET
1229	help
1230	  Choose this option if you want to use an ATI Radeon graphics card as
1231	  a framebuffer device.  There are both PCI and AGP versions.  You
1232	  don't need to choose this to run the Radeon in plain VGA mode.
1233
1234	  There is a product page at
1235	  https://products.amd.com/en-us/GraphicCardResult.aspx
1236
1237config FB_RADEON_I2C
1238	bool "DDC/I2C for ATI Radeon support"
1239	depends on FB_RADEON
1240	select FB_DDC
1241	default y
1242	help
1243	  Say Y here if you want DDC/I2C support for your Radeon board.
1244
1245config FB_RADEON_BACKLIGHT
1246	bool "Support for backlight control"
1247	depends on FB_RADEON
1248	default y
1249	help
1250	  Say Y here if you want to control the backlight of your display.
1251
1252config FB_RADEON_DEBUG
1253	bool "Lots of debug output from Radeon driver"
1254	depends on FB_RADEON
1255	help
1256	  Say Y here if you want the Radeon driver to output all sorts
1257	  of debugging information to provide to the maintainer when
1258	  something goes wrong.
1259
1260config FB_ATY128
1261	tristate "ATI Rage128 display support"
1262	depends on FB && PCI
1263	select FB_CFB_FILLRECT
1264	select FB_CFB_COPYAREA
1265	select FB_CFB_IMAGEBLIT
1266	select FB_BACKLIGHT if FB_ATY128_BACKLIGHT
1267	select FB_MACMODES if PPC_PMAC
1268	select VIDEO_NOMODESET
1269	help
1270	  This driver supports graphics boards with the ATI Rage128 chips.
1271	  Say Y if you have such a graphics board and read
1272	  <file:Documentation/fb/aty128fb.rst>.
1273
1274	  To compile this driver as a module, choose M here: the
1275	  module will be called aty128fb.
1276
1277config FB_ATY128_BACKLIGHT
1278	bool "Support for backlight control"
1279	depends on FB_ATY128
1280	default y
1281	help
1282	  Say Y here if you want to control the backlight of your display.
1283
1284config FB_ATY
1285	tristate "ATI Mach64 display support" if PCI || ATARI
1286	depends on FB && !SPARC32
1287	select FB_CFB_FILLRECT
1288	select FB_CFB_COPYAREA
1289	select FB_CFB_IMAGEBLIT
1290	select FB_BACKLIGHT if FB_ATY_BACKLIGHT
1291	select FB_MACMODES if PPC
1292	select FB_ATY_CT if SPARC64 && PCI
1293	select VIDEO_NOMODESET
1294	help
1295	  This driver supports graphics boards with the ATI Mach64 chips.
1296	  Say Y if you have such a graphics board.
1297
1298	  To compile this driver as a module, choose M here: the
1299	  module will be called atyfb.
1300
1301config FB_ATY_CT
1302	bool "Mach64 CT/VT/GT/LT (incl. 3D RAGE) support"
1303	depends on PCI && FB_ATY
1304	help
1305	  Say Y here to support use of ATI's 64-bit Rage boards (or other
1306	  boards based on the Mach64 CT, VT, GT, and LT chipsets) as a
1307	  framebuffer device.  The ATI product support page for these boards
1308	  is at <http://support.ati.com/products/pc/mach64/mach64.html>.
1309
1310config FB_ATY_GENERIC_LCD
1311	bool "Mach64 generic LCD support"
1312	depends on FB_ATY_CT
1313	help
1314	  Say Y if you have a laptop with an ATI Rage LT PRO, Rage Mobility,
1315	  Rage XC, or Rage XL chipset.
1316
1317config FB_ATY_GX
1318	bool "Mach64 GX support" if PCI
1319	depends on FB_ATY
1320	default y if ATARI
1321	help
1322	  Say Y here to support use of the ATI Mach64 Graphics Expression
1323	  board (or other boards based on the Mach64 GX chipset) as a
1324	  framebuffer device.  The ATI product support page for these boards
1325	  is at
1326	  <http://support.ati.com/products/pc/mach64/graphics_xpression.html>.
1327
1328config FB_ATY_BACKLIGHT
1329	bool "Support for backlight control"
1330	depends on FB_ATY
1331	default y
1332	help
1333	  Say Y here if you want to control the backlight of your display.
1334
1335config FB_S3
1336	tristate "S3 Trio/Virge support"
1337	depends on FB && PCI
1338	select FB_CFB_FILLRECT
1339	select FB_CFB_COPYAREA
1340	select FB_CFB_IMAGEBLIT
1341	select FB_TILEBLITTING
1342	select FB_SVGALIB
1343	select VGASTATE
1344	select VIDEO_NOMODESET
1345	select FONT_8x16 if FRAMEBUFFER_CONSOLE
1346	help
1347	  Driver for graphics boards with S3 Trio / S3 Virge chip.
1348
1349config FB_S3_DDC
1350	bool "DDC for S3 support"
1351	depends on FB_S3
1352	select FB_DDC
1353	default y
1354	help
1355	  Say Y here if you want DDC support for your S3 graphics card.
1356
1357config FB_SAVAGE
1358	tristate "S3 Savage support"
1359	depends on FB && PCI
1360	select FB_MODE_HELPERS
1361	select FB_CFB_FILLRECT
1362	select FB_CFB_COPYAREA
1363	select FB_CFB_IMAGEBLIT
1364	select VGASTATE
1365	select VIDEO_NOMODESET
1366	help
1367	  This driver supports notebooks and computers with S3 Savage PCI/AGP
1368	  chips.
1369
1370	  Say Y if you have such a graphics card.
1371
1372	  To compile this driver as a module, choose M here; the module
1373	  will be called savagefb.
1374
1375config FB_SAVAGE_I2C
1376	bool "Enable DDC2 Support"
1377	depends on FB_SAVAGE
1378	select FB_DDC
1379	help
1380	  This enables I2C support for S3 Savage Chipsets.  This is used
1381	  only for getting EDID information from the attached display
1382	  allowing for robust video mode handling and switching.
1383
1384	  Because fbdev-2.6 requires that drivers must be able to
1385	  independently validate video mode parameters, you should say Y
1386	  here.
1387
1388config FB_SAVAGE_ACCEL
1389	bool "Enable Console Acceleration"
1390	depends on FB_SAVAGE
1391	help
1392	  This option will compile in console acceleration support. If
1393	  the resulting framebuffer console has bothersome glitches, then
1394	  choose N here.
1395
1396config FB_SIS
1397	tristate "SiS/XGI display support"
1398	depends on FB && PCI
1399	select FB_CFB_FILLRECT
1400	select FB_CFB_COPYAREA
1401	select FB_CFB_IMAGEBLIT
1402	select BOOT_VESA_SUPPORT if FB_SIS = y
1403	select FB_SIS_300 if !FB_SIS_315
1404	select VIDEO_NOMODESET
1405	help
1406	  This is the frame buffer device driver for the SiS 300, 315, 330
1407	  and 340 series as well as XGI V3XT, V5, V8, Z7 graphics chipsets.
1408	  Specs available at <https://www.sis.com> and <http://www.xgitech.com>.
1409
1410	  To compile this driver as a module, choose M here; the module
1411	  will be called sisfb.
1412
1413config FB_SIS_300
1414	bool "SiS 300 series support"
1415	depends on FB_SIS
1416	help
1417	  Say Y here to support use of the SiS 300/305, 540, 630 and 730.
1418
1419config FB_SIS_315
1420	bool "SiS 315/330/340 series and XGI support"
1421	depends on FB_SIS
1422	help
1423	  Say Y here to support use of the SiS 315, 330 and 340 series
1424	  (315/H/PRO, 55x, 650, 651, 740, 330, 661, 741, 760, 761) as well
1425	  as XGI V3XT, V5, V8 and Z7.
1426
1427config FB_VIA
1428	tristate "VIA UniChrome (Pro) and Chrome9 display support"
1429	depends on FB && PCI && GPIOLIB && I2C && (X86 || COMPILE_TEST)
1430	select FB_CFB_FILLRECT
1431	select FB_CFB_COPYAREA
1432	select FB_CFB_IMAGEBLIT
1433	select I2C_ALGOBIT
1434	select VIDEO_NOMODESET
1435	help
1436	  This is the frame buffer device driver for Graphics chips of VIA
1437	  UniChrome (Pro) Family (CLE266,PM800/CN400,P4M800CE/P4M800Pro/
1438	  CN700/VN800,CX700/VX700,P4M890) and Chrome9 Family (K8M890,CN896
1439	  /P4M900,VX800)
1440	  Say Y if you have a VIA UniChrome graphics board.
1441
1442	  To compile this driver as a module, choose M here: the
1443	  module will be called viafb.
1444
1445if FB_VIA
1446
1447config FB_VIA_DIRECT_PROCFS
1448	bool "direct hardware access via procfs (DEPRECATED)(DANGEROUS)"
1449	help
1450	  Allow direct hardware access to some output registers via procfs.
1451	  This is dangerous but may provide the only chance to get the
1452	  correct output device configuration.
1453	  Its use is strongly discouraged.
1454
1455config FB_VIA_X_COMPATIBILITY
1456	bool "X server compatibility"
1457	help
1458	  This option reduces the functionality (power saving, ...) of the
1459	  framebuffer to avoid negative impact on the OpenChrome X server.
1460	  If you use any X server other than fbdev you should enable this
1461	  otherwise it should be safe to disable it and allow using all
1462	  features.
1463
1464endif
1465
1466config FB_NEOMAGIC
1467	tristate "NeoMagic display support"
1468	depends on FB && PCI
1469	select FB_MODE_HELPERS
1470	select FB_CFB_FILLRECT
1471	select FB_CFB_COPYAREA
1472	select FB_CFB_IMAGEBLIT
1473	select VGASTATE
1474	select VIDEO_NOMODESET
1475	help
1476	  This driver supports notebooks with NeoMagic PCI chips.
1477	  Say Y if you have such a graphics card.
1478
1479	  To compile this driver as a module, choose M here: the
1480	  module will be called neofb.
1481
1482config FB_KYRO
1483	tristate "IMG Kyro support"
1484	depends on FB && PCI
1485	select FB_CFB_FILLRECT
1486	select FB_CFB_COPYAREA
1487	select FB_CFB_IMAGEBLIT
1488	select VIDEO_NOMODESET
1489	help
1490	  Say Y here if you have a STG4000 / Kyro / PowerVR 3 based
1491	  graphics board.
1492
1493	  To compile this driver as a module, choose M here: the
1494	  module will be called kyrofb.
1495
1496config FB_3DFX
1497	tristate "3Dfx Banshee/Voodoo3/Voodoo5 display support"
1498	depends on FB && PCI
1499	select FB_CFB_IMAGEBLIT
1500	select FB_CFB_FILLRECT
1501	select FB_CFB_COPYAREA
1502	select FB_MODE_HELPERS
1503	select VIDEO_NOMODESET
1504	help
1505	  This driver supports graphics boards with the 3Dfx Banshee,
1506	  Voodoo3 or VSA-100 (aka Voodoo4/5) chips. Say Y if you have
1507	  such a graphics board.
1508
1509	  To compile this driver as a module, choose M here: the
1510	  module will be called tdfxfb.
1511
1512config FB_3DFX_ACCEL
1513	bool "3Dfx Acceleration functions"
1514	depends on FB_3DFX
1515	help
1516	This will compile the 3Dfx Banshee/Voodoo3/VSA-100 frame buffer
1517	device driver with acceleration functions.
1518
1519config FB_3DFX_I2C
1520	bool "Enable DDC/I2C support"
1521	depends on FB_3DFX
1522	select FB_DDC
1523	default y
1524	help
1525	  Say Y here if you want DDC/I2C support for your 3dfx Voodoo3.
1526
1527config FB_VOODOO1
1528	tristate "3Dfx Voodoo Graphics (sst1) support"
1529	depends on FB && PCI
1530	select FB_CFB_FILLRECT
1531	select FB_CFB_COPYAREA
1532	select FB_CFB_IMAGEBLIT
1533	select VIDEO_NOMODESET
1534	help
1535	  Say Y here if you have a 3Dfx Voodoo Graphics (Voodoo1/sst1) or
1536	  Voodoo2 (cvg) based graphics card.
1537
1538	  To compile this driver as a module, choose M here: the
1539	  module will be called sstfb.
1540
1541	  WARNING: Do not use any application that uses the 3D engine
1542	  (namely glide) while using this driver.
1543	  Please read the <file:Documentation/fb/sstfb.rst> for supported
1544	  options and other important info  support.
1545
1546config FB_VT8623
1547	tristate "VIA VT8623 support"
1548	depends on FB && PCI
1549	select FB_CFB_FILLRECT
1550	select FB_CFB_COPYAREA
1551	select FB_CFB_IMAGEBLIT
1552	select FB_TILEBLITTING
1553	select FB_SVGALIB
1554	select VGASTATE
1555	select VIDEO_NOMODESET
1556	select FONT_8x16 if FRAMEBUFFER_CONSOLE
1557	help
1558	  Driver for CastleRock integrated graphics core in the
1559	  VIA VT8623 [Apollo CLE266] chipset.
1560
1561config FB_TRIDENT
1562	tristate "Trident/CyberXXX/CyberBlade support"
1563	depends on FB && PCI
1564	select FB_CFB_FILLRECT
1565	select FB_CFB_COPYAREA
1566	select FB_CFB_IMAGEBLIT
1567	select FB_DDC
1568	select FB_MODE_HELPERS
1569	select VIDEO_NOMODESET
1570	help
1571	  This is the frame buffer device driver for Trident PCI/AGP chipsets.
1572	  Supported chipset families are TGUI 9440/96XX, 3DImage, Blade3D
1573	  and Blade XP.
1574	  There are also integrated versions of these chips called CyberXXXX,
1575	  CyberImage or CyberBlade. These chips are mostly found in laptops
1576	  but also on some motherboards including early VIA EPIA motherboards.
1577	  For more information, read <file:Documentation/fb/tridentfb.rst>
1578
1579	  Say Y if you have such a graphics board.
1580
1581	  To compile this driver as a module, choose M here: the
1582	  module will be called tridentfb.
1583
1584config FB_ARK
1585	tristate "ARK 2000PV support"
1586	depends on FB && PCI
1587	select FB_CFB_FILLRECT
1588	select FB_CFB_COPYAREA
1589	select FB_CFB_IMAGEBLIT
1590	select FB_TILEBLITTING
1591	select FB_SVGALIB
1592	select VGASTATE
1593	select VIDEO_NOMODESET
1594	select FONT_8x16 if FRAMEBUFFER_CONSOLE
1595	help
1596	  Driver for PCI graphics boards with ARK 2000PV chip
1597	  and ICS 5342 RAMDAC.
1598
1599config FB_PM3
1600	tristate "Permedia3 support"
1601	depends on FB && PCI
1602	select FB_CFB_FILLRECT
1603	select FB_CFB_COPYAREA
1604	select FB_CFB_IMAGEBLIT
1605	select VIDEO_NOMODESET
1606	help
1607	  This is the frame buffer device driver for the 3DLabs Permedia3
1608	  chipset, used in Formac ProFormance III, 3DLabs Oxygen VX1 &
1609	  similar boards, 3DLabs Permedia3 Create!, Appian Jeronimo 2000
1610	  and maybe other boards.
1611
1612config FB_CARMINE
1613	tristate "Fujitsu carmine frame buffer support"
1614	depends on FB && PCI
1615	select FB_CFB_FILLRECT
1616	select FB_CFB_COPYAREA
1617	select FB_CFB_IMAGEBLIT
1618	select VIDEO_NOMODESET
1619	help
1620	  This is the frame buffer device driver for the Fujitsu Carmine chip.
1621	  The driver provides two independent frame buffer devices.
1622
1623choice
1624	depends on FB_CARMINE
1625	prompt "DRAM timing"
1626	default FB_CARMINE_DRAM_EVAL
1627
1628config FB_CARMINE_DRAM_EVAL
1629	bool "Eval board timings"
1630	help
1631	  Use timings which work on the eval card.
1632
1633config CARMINE_DRAM_CUSTOM
1634	bool "Custom board timings"
1635	help
1636	  Use custom board timings.
1637endchoice
1638
1639config FB_AU1100
1640	bool "Au1100 LCD Driver"
1641	depends on (FB = y) && MIPS_ALCHEMY
1642	select FB_CFB_FILLRECT
1643	select FB_CFB_COPYAREA
1644	select FB_CFB_IMAGEBLIT
1645	help
1646	  This is the framebuffer driver for the AMD Au1100 SOC.  It can drive
1647	  various panels and CRTs by passing in kernel cmd line option
1648	  au1100fb:panel=<name>.
1649
1650config FB_AU1200
1651	bool "Au1200/Au1300 LCD Driver"
1652	depends on (FB = y) && MIPS_ALCHEMY
1653	select FB_SYS_FILLRECT
1654	select FB_SYS_COPYAREA
1655	select FB_SYS_IMAGEBLIT
1656	select FB_SYS_FOPS
1657	help
1658	  This is the framebuffer driver for the Au1200/Au1300 SOCs.
1659	  It can drive various panels and CRTs by passing in kernel cmd line
1660	  option au1200fb:panel=<name>.
1661
1662config FB_VT8500
1663	bool "VIA VT8500 framebuffer support"
1664	depends on (FB = y) && ARM && ARCH_VT8500
1665	select FB_SYS_FILLRECT if (!FB_WMT_GE_ROPS)
1666	select FB_SYS_COPYAREA if (!FB_WMT_GE_ROPS)
1667	select FB_SYS_IMAGEBLIT
1668	select FB_MODE_HELPERS
1669	select VIDEOMODE_HELPERS
1670	help
1671	  This is the framebuffer driver for VIA VT8500 integrated LCD
1672	  controller.
1673
1674config FB_WM8505
1675	bool "Wondermedia WM8xxx-series frame buffer support"
1676	depends on (FB = y) && HAS_IOMEM && (ARCH_VT8500 || COMPILE_TEST)
1677	select FB_SYS_FILLRECT if (!FB_WMT_GE_ROPS)
1678	select FB_SYS_COPYAREA if (!FB_WMT_GE_ROPS)
1679	select FB_SYS_IMAGEBLIT
1680	select FB_MODE_HELPERS
1681	select VIDEOMODE_HELPERS
1682	help
1683	  This is the framebuffer driver for WonderMedia WM8xxx-series
1684	  integrated LCD controller. This driver covers the WM8505, WM8650
1685	  and WM8850 SoCs.
1686
1687config FB_WMT_GE_ROPS
1688	bool "VT8500/WM8xxx accelerated raster ops support"
1689	depends on (FB = y) && (FB_VT8500 || FB_WM8505)
1690	help
1691	  This adds support for accelerated raster operations on the
1692	  VIA VT8500 and Wondermedia 85xx series SoCs.
1693
1694source "drivers/video/fbdev/geode/Kconfig"
1695
1696config FB_HIT
1697	tristate "HD64461 Frame Buffer support"
1698	depends on FB && HD64461
1699	select FB_CFB_FILLRECT
1700	select FB_CFB_COPYAREA
1701	select FB_CFB_IMAGEBLIT
1702	help
1703	  This is the frame buffer device driver for the Hitachi HD64461 LCD
1704	  frame buffer card.
1705
1706config FB_PMAG_AA
1707	tristate "PMAG-AA TURBOchannel framebuffer support"
1708	depends on FB && TC
1709	select FB_CFB_FILLRECT
1710	select FB_CFB_COPYAREA
1711	select FB_CFB_IMAGEBLIT
1712	help
1713	  Support for the PMAG-AA TURBOchannel framebuffer card (1280x1024x1)
1714	  used mainly in the MIPS-based DECstation series.
1715
1716config FB_PMAG_BA
1717	tristate "PMAG-BA TURBOchannel framebuffer support"
1718	depends on FB && TC
1719	select FB_CFB_FILLRECT
1720	select FB_CFB_COPYAREA
1721	select FB_CFB_IMAGEBLIT
1722	help
1723	  Support for the PMAG-BA TURBOchannel framebuffer card (1024x864x8)
1724	  used mainly in the MIPS-based DECstation series.
1725
1726config FB_PMAGB_B
1727	tristate "PMAGB-B TURBOchannel framebuffer support"
1728	depends on FB && TC
1729	select FB_CFB_FILLRECT
1730	select FB_CFB_COPYAREA
1731	select FB_CFB_IMAGEBLIT
1732	help
1733	  Support for the PMAGB-B TURBOchannel framebuffer card used mainly
1734	  in the MIPS-based DECstation series. The card is currently only
1735	  supported in 1280x1024x8 mode.
1736
1737config FB_MAXINE
1738	bool "Maxine (Personal DECstation) onboard framebuffer support"
1739	depends on (FB = y) && MACH_DECSTATION
1740	select FB_CFB_FILLRECT
1741	select FB_CFB_COPYAREA
1742	select FB_CFB_IMAGEBLIT
1743	help
1744	  Support for the onboard framebuffer (1024x768x8) in the Personal
1745	  DECstation series (Personal DECstation 5000/20, /25, /33, /50,
1746	  Codename "Maxine").
1747
1748config FB_G364
1749	bool "G364 frame buffer support"
1750	depends on (FB = y) && (MIPS_MAGNUM_4000 || OLIVETTI_M700)
1751	select FB_CFB_FILLRECT
1752	select FB_CFB_COPYAREA
1753	select FB_CFB_IMAGEBLIT
1754	help
1755	  The G364 driver is the framebuffer used in MIPS Magnum 4000 and
1756	  Olivetti M700-10 systems.
1757
1758config FB_68328
1759	bool "Motorola 68328 native frame buffer support"
1760	depends on (FB = y) && (M68328 || M68EZ328 || M68VZ328)
1761	select FB_CFB_FILLRECT
1762	select FB_CFB_COPYAREA
1763	select FB_CFB_IMAGEBLIT
1764	help
1765	  Say Y here if you want to support the built-in frame buffer of
1766	  the Motorola 68328 CPU family.
1767
1768config FB_PXA168
1769	tristate "PXA168/910 LCD framebuffer support"
1770	depends on FB && HAVE_CLK && HAS_IOMEM
1771	depends on CPU_PXA168 || CPU_PXA910 || COMPILE_TEST
1772	select FB_CFB_FILLRECT
1773	select FB_CFB_COPYAREA
1774	select FB_CFB_IMAGEBLIT
1775	help
1776	  Frame buffer driver for the built-in LCD controller in the Marvell
1777	  MMP processor.
1778
1779config FB_PXA
1780	tristate "PXA LCD framebuffer support"
1781	depends on FB && ARCH_PXA
1782	select FB_CFB_FILLRECT
1783	select FB_CFB_COPYAREA
1784	select FB_CFB_IMAGEBLIT
1785	select VIDEOMODE_HELPERS if OF
1786	select FB_MODE_HELPERS if OF
1787	help
1788	  Frame buffer driver for the built-in LCD controller in the Intel
1789	  PXA2x0 processor.
1790
1791	  This driver is also available as a module ( = code which can be
1792	  inserted and removed from the running kernel whenever you want). The
1793	  module will be called pxafb. If you want to compile it as a module,
1794	  say M here and read <file:Documentation/kbuild/modules.rst>.
1795
1796	  If unsure, say N.
1797
1798config FB_PXA_OVERLAY
1799	bool "Support PXA27x/PXA3xx Overlay(s) as framebuffer"
1800	depends on FB_PXA && (PXA27x || PXA3xx)
1801
1802config FB_PXA_SMARTPANEL
1803	bool "PXA Smartpanel LCD support"
1804	depends on FB_PXA
1805
1806config FB_PXA_PARAMETERS
1807	bool "PXA LCD command line parameters"
1808	depends on FB_PXA
1809	help
1810	  Enable the use of kernel command line or module parameters
1811	  to configure the physical properties of the LCD panel when
1812	  using the PXA LCD driver.
1813
1814	  This option allows you to override the panel parameters
1815	  supplied by the platform in order to support multiple
1816	  different models of flatpanel. If you will only be using a
1817	  single model of flatpanel then you can safely leave this
1818	  option disabled.
1819
1820	  <file:Documentation/fb/pxafb.rst> describes the available parameters.
1821
1822config PXA3XX_GCU
1823	tristate "PXA3xx 2D graphics accelerator driver"
1824	depends on FB_PXA
1825	help
1826	  Kernelspace driver for the 2D graphics controller unit (GCU)
1827	  found on PXA3xx processors. There is a counterpart driver in the
1828	  DirectFB suite, see http://www.directfb.org/
1829
1830	  If you compile this as a module, it will be called pxa3xx_gcu.
1831
1832config FB_FSL_DIU
1833	tristate "Freescale DIU framebuffer support"
1834	depends on FB && FSL_SOC
1835	select FB_MODE_HELPERS
1836	select FB_CFB_FILLRECT
1837	select FB_CFB_COPYAREA
1838	select FB_CFB_IMAGEBLIT
1839	select PPC_LIB_RHEAP
1840	help
1841	  Framebuffer driver for the Freescale SoC DIU
1842
1843config FB_W100
1844	tristate "W100 frame buffer support"
1845	depends on FB && HAS_IOMEM && (ARCH_PXA || COMPILE_TEST)
1846	select FB_CFB_FILLRECT
1847	select FB_CFB_COPYAREA
1848	select FB_CFB_IMAGEBLIT
1849	help
1850	  Frame buffer driver for the w100 as found on the Sharp SL-Cxx series.
1851	  It can also drive the w3220 chip found on iPAQ hx4700.
1852
1853	  This driver is also available as a module ( = code which can be
1854	  inserted and removed from the running kernel whenever you want). The
1855	  module will be called w100fb. If you want to compile it as a module,
1856	  say M here and read <file:Documentation/kbuild/modules.rst>.
1857
1858	  If unsure, say N.
1859
1860config FB_SH_MOBILE_LCDC
1861	tristate "SuperH Mobile LCDC framebuffer support"
1862	depends on FB && HAVE_CLK && HAS_IOMEM
1863	depends on SUPERH || ARCH_RENESAS || COMPILE_TEST
1864	select FB_SYS_FILLRECT
1865	select FB_SYS_COPYAREA
1866	select FB_SYS_IMAGEBLIT
1867	select FB_SYS_FOPS
1868	select FB_DEFERRED_IO
1869	select FB_BACKLIGHT
1870	help
1871	  Frame buffer driver for the on-chip SH-Mobile LCD controller.
1872
1873config FB_TMIO
1874	tristate "Toshiba Mobile IO FrameBuffer support"
1875	depends on FB && (MFD_TMIO || COMPILE_TEST)
1876	select FB_CFB_FILLRECT
1877	select FB_CFB_COPYAREA
1878	select FB_CFB_IMAGEBLIT
1879	help
1880	  Frame buffer driver for the Toshiba Mobile IO integrated as found
1881	  on the Sharp SL-6000 series
1882
1883	  This driver is also available as a module ( = code which can be
1884	  inserted and removed from the running kernel whenever you want). The
1885	  module will be called tmiofb. If you want to compile it as a module,
1886	  say M here and read <file:Documentation/kbuild/modules.rst>.
1887
1888	  If unsure, say N.
1889
1890config FB_TMIO_ACCELL
1891	bool "tmiofb acceleration"
1892	depends on FB_TMIO
1893	default y
1894
1895config FB_S3C
1896	tristate "Samsung S3C framebuffer support"
1897	depends on FB && HAVE_CLK && HAS_IOMEM
1898	depends on (CPU_S3C2416 || ARCH_S3C64XX) || COMPILE_TEST
1899	select FB_CFB_FILLRECT
1900	select FB_CFB_COPYAREA
1901	select FB_CFB_IMAGEBLIT
1902	help
1903	  Frame buffer driver for the built-in FB controller in the Samsung
1904	  SoC line from the S3C2443 onwards, including the S3C2416, S3C2450,
1905	  and the S3C64XX series such as the S3C6400 and S3C6410.
1906
1907	  These chips all have the same basic framebuffer design with the
1908	  actual capabilities depending on the chip. For instance the S3C6400
1909	  and S3C6410 support 4 hardware windows whereas the S3C24XX series
1910	  currently only have two.
1911
1912	  Currently the support is only for the S3C6400 and S3C6410 SoCs.
1913
1914config FB_S3C_DEBUG_REGWRITE
1915	bool "Debug register writes"
1916	depends on FB_S3C
1917	help
1918	  Show all register writes via pr_debug()
1919
1920config FB_S3C2410
1921	tristate "S3C2410 LCD framebuffer support"
1922	depends on FB && ARCH_S3C24XX
1923	select FB_CFB_FILLRECT
1924	select FB_CFB_COPYAREA
1925	select FB_CFB_IMAGEBLIT
1926	help
1927	  Frame buffer driver for the built-in LCD controller in the Samsung
1928	  S3C2410 processor.
1929
1930	  This driver is also available as a module ( = code which can be
1931	  inserted and removed from the running kernel whenever you want). The
1932	  module will be called s3c2410fb. If you want to compile it as a module,
1933	  say M here and read <file:Documentation/kbuild/modules.rst>.
1934
1935	  If unsure, say N.
1936config FB_S3C2410_DEBUG
1937	bool "S3C2410 lcd debug messages"
1938	depends on FB_S3C2410
1939	help
1940	  Turn on debugging messages. Note that you can set/unset at run time
1941	  through sysfs
1942
1943config FB_SM501
1944	tristate "Silicon Motion SM501 framebuffer support"
1945	depends on FB && MFD_SM501
1946	select FB_CFB_FILLRECT
1947	select FB_CFB_COPYAREA
1948	select FB_CFB_IMAGEBLIT
1949	help
1950	  Frame buffer driver for the CRT and LCD controllers in the Silicon
1951	  Motion SM501.
1952
1953	  This driver is also available as a module ( = code which can be
1954	  inserted and removed from the running kernel whenever you want). The
1955	  module will be called sm501fb. If you want to compile it as a module,
1956	  say M here and read <file:Documentation/kbuild/modules.rst>.
1957
1958	  If unsure, say N.
1959
1960config FB_SMSCUFX
1961	tristate "SMSC UFX6000/7000 USB Framebuffer support"
1962	depends on FB && USB
1963	select FB_MODE_HELPERS
1964	select FB_SYS_FILLRECT
1965	select FB_SYS_COPYAREA
1966	select FB_SYS_IMAGEBLIT
1967	select FB_SYS_FOPS
1968	select FB_DEFERRED_IO
1969	help
1970	  This is a kernel framebuffer driver for SMSC UFX USB devices.
1971	  Supports fbdev clients like xf86-video-fbdev, kdrive, fbi, and
1972	  mplayer -vo fbdev. Supports both UFX6000 (USB 2.0) and UFX7000
1973	  (USB 3.0) devices.
1974	  To compile as a module, choose M here: the module name is smscufx.
1975
1976config FB_UDL
1977	tristate "Displaylink USB Framebuffer support"
1978	depends on FB && USB
1979	select FB_MODE_HELPERS
1980	select FB_SYS_FILLRECT
1981	select FB_SYS_COPYAREA
1982	select FB_SYS_IMAGEBLIT
1983	select FB_SYS_FOPS
1984	select FB_DEFERRED_IO
1985	help
1986	  This is a kernel framebuffer driver for DisplayLink USB devices.
1987	  Supports fbdev clients like xf86-video-fbdev, kdrive, fbi, and
1988	  mplayer -vo fbdev. Supports all USB 2.0 era DisplayLink devices.
1989	  To compile as a module, choose M here: the module name is udlfb.
1990
1991config FB_IBM_GXT4500
1992	tristate "Framebuffer support for IBM GXT4000P/4500P/6000P/6500P adaptors"
1993	depends on FB
1994	select FB_CFB_FILLRECT
1995	select FB_CFB_COPYAREA
1996	select FB_CFB_IMAGEBLIT
1997	select VIDEO_NOMODESET
1998	help
1999	  Say Y here to enable support for the IBM GXT4000P/6000P and
2000	  GXT4500P/6500P display adaptor based on Raster Engine RC1000,
2001	  found on some IBM System P (pSeries) machines. This driver
2002	  doesn't use Geometry Engine GT1000. This driver also supports
2003	  AGP Fire GL2/3/4 cards on x86.
2004
2005config FB_PS3
2006	tristate "PS3 GPU framebuffer driver"
2007	depends on FB && PS3_PS3AV
2008	select FB_SYS_FILLRECT
2009	select FB_SYS_COPYAREA
2010	select FB_SYS_IMAGEBLIT
2011	select FB_SYS_FOPS
2012	help
2013	  Include support for the virtual frame buffer in the PS3 platform.
2014
2015config FB_PS3_DEFAULT_SIZE_M
2016	int "PS3 default frame buffer size (in MiB)"
2017	depends on FB_PS3
2018	default 9
2019	help
2020	  This is the default size (in MiB) of the virtual frame buffer in
2021	  the PS3.
2022	  The default value can be overridden on the kernel command line
2023	  using the "ps3fb" option (e.g. "ps3fb=9M");
2024
2025config FB_XILINX
2026	tristate "Xilinx frame buffer support"
2027	depends on FB && (MICROBLAZE || ARCH_ZYNQ || ARCH_ZYNQMP)
2028	select FB_CFB_FILLRECT
2029	select FB_CFB_COPYAREA
2030	select FB_CFB_IMAGEBLIT
2031	help
2032	  Include support for the Xilinx ML300/ML403 reference design
2033	  framebuffer. ML300 carries a 640*480 LCD display on the board,
2034	  ML403 uses a standard DB15 VGA connector.
2035
2036config FB_GOLDFISH
2037	tristate "Goldfish Framebuffer"
2038	depends on FB
2039	depends on GOLDFISH || COMPILE_TEST
2040	select FB_CFB_FILLRECT
2041	select FB_CFB_COPYAREA
2042	select FB_CFB_IMAGEBLIT
2043	help
2044	  Framebuffer driver for Goldfish Virtual Platform
2045
2046config FB_COBALT
2047	tristate "Cobalt server LCD frame buffer support"
2048	depends on FB && MIPS_COBALT
2049
2050config FB_SH7760
2051	bool "SH7760/SH7763/SH7720/SH7721 LCDC support"
2052	depends on FB && (CPU_SUBTYPE_SH7760 || CPU_SUBTYPE_SH7763 \
2053		|| CPU_SUBTYPE_SH7720 || CPU_SUBTYPE_SH7721)
2054	select FB_CFB_FILLRECT
2055	select FB_CFB_COPYAREA
2056	select FB_CFB_IMAGEBLIT
2057	help
2058	  Support for the SH7760/SH7763/SH7720/SH7721 integrated
2059	  (D)STN/TFT LCD Controller.
2060	  Supports display resolutions up to 1024x1024 pixel, grayscale and
2061	  color operation, with depths ranging from 1 bpp to 8 bpp monochrome
2062	  and 8, 15 or 16 bpp color; 90 degrees clockwise display rotation for
2063	  panels <= 320 pixel horizontal resolution.
2064
2065config FB_DA8XX
2066	tristate "DA8xx/OMAP-L1xx/AM335x Framebuffer support"
2067	depends on FB && HAVE_CLK && HAS_IOMEM
2068	depends on ARCH_DAVINCI_DA8XX || SOC_AM33XX || COMPILE_TEST
2069	select FB_CFB_FILLRECT
2070	select FB_CFB_COPYAREA
2071	select FB_CFB_IMAGEBLIT
2072	select FB_CFB_REV_PIXELS_IN_BYTE
2073	select FB_MODE_HELPERS
2074	select VIDEOMODE_HELPERS
2075	help
2076	  This is the frame buffer device driver for the TI LCD controller
2077	  found on DA8xx/OMAP-L1xx/AM335x SoCs.
2078	  If unsure, say N.
2079
2080config FB_VIRTUAL
2081	tristate "Virtual Frame Buffer support (ONLY FOR TESTING!)"
2082	depends on FB
2083	select FB_SYS_FILLRECT
2084	select FB_SYS_COPYAREA
2085	select FB_SYS_IMAGEBLIT
2086	select FB_SYS_FOPS
2087	help
2088	  This is a `virtual' frame buffer device. It operates on a chunk of
2089	  unswappable kernel memory instead of on the memory of a graphics
2090	  board. This means you cannot see any output sent to this frame
2091	  buffer device, while it does consume precious memory. The main use
2092	  of this frame buffer device is testing and debugging the frame
2093	  buffer subsystem. Do NOT enable it for normal systems! To protect
2094	  the innocent, it has to be enabled explicitly at boot time using the
2095	  kernel option `video=vfb:'.
2096
2097	  To compile this driver as a module, choose M here: the
2098	  module will be called vfb. In order to load it, you must use
2099	  the vfb_enable=1 option.
2100
2101	  If unsure, say N.
2102
2103config XEN_FBDEV_FRONTEND
2104	tristate "Xen virtual frame buffer support"
2105	depends on FB && XEN
2106	select FB_SYS_FILLRECT
2107	select FB_SYS_COPYAREA
2108	select FB_SYS_IMAGEBLIT
2109	select FB_SYS_FOPS
2110	select FB_DEFERRED_IO
2111	select XEN_XENBUS_FRONTEND
2112	default y
2113	help
2114	  This driver implements the front-end of the Xen virtual
2115	  frame buffer driver.  It communicates with a back-end
2116	  in another domain.
2117
2118config FB_METRONOME
2119	tristate "E-Ink Metronome/8track controller support"
2120	depends on FB
2121	select FB_SYS_FILLRECT
2122	select FB_SYS_COPYAREA
2123	select FB_SYS_IMAGEBLIT
2124	select FB_SYS_FOPS
2125	select FB_DEFERRED_IO
2126	help
2127	  This driver implements support for the E-Ink Metronome
2128	  controller. The pre-release name for this device was 8track
2129	  and could also have been called by some vendors as PVI-nnnn.
2130
2131config FB_MB862XX
2132	tristate "Fujitsu MB862xx GDC support"
2133	depends on FB
2134	depends on PCI || (OF && PPC)
2135	select FB_CFB_FILLRECT
2136	select FB_CFB_COPYAREA
2137	select FB_CFB_IMAGEBLIT
2138	select VIDEO_NOMODESET
2139	help
2140	  Frame buffer driver for Fujitsu Carmine/Coral-P(A)/Lime controllers.
2141
2142choice
2143	prompt "GDC variant"
2144	depends on FB_MB862XX
2145
2146config FB_MB862XX_PCI_GDC
2147	bool "Carmine/Coral-P(A) GDC"
2148	depends on PCI
2149	help
2150	  This enables framebuffer support for Fujitsu Carmine/Coral-P(A)
2151	  PCI graphics controller devices.
2152
2153config FB_MB862XX_LIME
2154	bool "Lime GDC"
2155	depends on OF && PPC
2156	select FB_FOREIGN_ENDIAN
2157	select FB_LITTLE_ENDIAN
2158	help
2159	  Framebuffer support for Fujitsu Lime GDC on host CPU bus.
2160
2161endchoice
2162
2163config FB_MB862XX_I2C
2164	bool "Support I2C bus on MB862XX GDC"
2165	depends on FB_MB862XX && I2C
2166	depends on FB_MB862XX=m || I2C=y
2167	default y
2168	help
2169	  Selecting this option adds Coral-P(A)/Lime GDC I2C bus adapter
2170	  driver to support accessing I2C devices on controller's I2C bus.
2171	  These are usually some video decoder chips.
2172
2173config FB_EP93XX
2174	tristate "EP93XX frame buffer support"
2175	depends on FB && ARCH_EP93XX
2176	select FB_CFB_FILLRECT
2177	select FB_CFB_COPYAREA
2178	select FB_CFB_IMAGEBLIT
2179	help
2180	  Framebuffer driver for the Cirrus Logic EP93XX series of processors.
2181	  This driver is also available as a module. The module will be called
2182	  ep93xx-fb.
2183
2184config FB_PRE_INIT_FB
2185	bool "Don't reinitialize, use bootloader's GDC/Display configuration"
2186	depends on FB && FB_MB862XX_LIME
2187	help
2188	  Select this option if display contents should be inherited as set by
2189	  the bootloader.
2190
2191config FB_MX3
2192	tristate "MX3 Framebuffer support"
2193	depends on FB && MX3_IPU
2194	select BACKLIGHT_CLASS_DEVICE
2195	select FB_CFB_FILLRECT
2196	select FB_CFB_COPYAREA
2197	select FB_CFB_IMAGEBLIT
2198	default y
2199	help
2200	  This is a framebuffer device for the i.MX31 LCD Controller. So
2201	  far only synchronous displays are supported. If you plan to use
2202	  an LCD display with your i.MX31 system, say Y here.
2203
2204config FB_BROADSHEET
2205	tristate "E-Ink Broadsheet/Epson S1D13521 controller support"
2206	depends on FB && (ARCH_PXA || COMPILE_TEST)
2207	select FB_SYS_FILLRECT
2208	select FB_SYS_COPYAREA
2209	select FB_SYS_IMAGEBLIT
2210	select FB_SYS_FOPS
2211	select FB_DEFERRED_IO
2212	help
2213	  This driver implements support for the E-Ink Broadsheet
2214	  controller. The release name for this device was Epson S1D13521
2215	  and could also have been called by other names when coupled with
2216	  a bridge adapter.
2217
2218config FB_HYPERV
2219	tristate "Microsoft Hyper-V Synthetic Video support"
2220	depends on FB && HYPERV
2221	select FB_CFB_FILLRECT
2222	select FB_CFB_COPYAREA
2223	select FB_CFB_IMAGEBLIT
2224	select FB_DEFERRED_IO
2225	select DMA_CMA if HAVE_DMA_CONTIGUOUS && CMA
2226	select VIDEO_NOMODESET
2227	help
2228	  This framebuffer driver supports Microsoft Hyper-V Synthetic Video.
2229
2230config FB_SIMPLE
2231	tristate "Simple framebuffer support"
2232	depends on FB
2233	depends on !DRM_SIMPLEDRM
2234	select APERTURE_HELPERS
2235	select FB_CFB_FILLRECT
2236	select FB_CFB_COPYAREA
2237	select FB_CFB_IMAGEBLIT
2238	help
2239	  Say Y if you want support for a simple frame-buffer.
2240
2241	  This driver assumes that the display hardware has been initialized
2242	  before the kernel boots, and the kernel will simply render to the
2243	  pre-allocated frame buffer surface.
2244
2245	  Configuration re: surface address, size, and format must be provided
2246	  through device tree, or plain old platform data.
2247
2248config FB_SSD1307
2249	tristate "Solomon SSD1307 framebuffer support"
2250	depends on FB && I2C
2251	depends on GPIOLIB || COMPILE_TEST
2252	select FB_SYS_FOPS
2253	select FB_SYS_FILLRECT
2254	select FB_SYS_COPYAREA
2255	select FB_SYS_IMAGEBLIT
2256	select FB_DEFERRED_IO
2257	select PWM
2258	select FB_BACKLIGHT
2259	help
2260	  This driver implements support for the Solomon SSD1307
2261	  OLED controller over I2C.
2262
2263config FB_SM712
2264	tristate "Silicon Motion SM712 framebuffer support"
2265	depends on FB && PCI
2266	select FB_CFB_FILLRECT
2267	select FB_CFB_COPYAREA
2268	select FB_CFB_IMAGEBLIT
2269	select VIDEO_NOMODESET
2270	help
2271	  Frame buffer driver for the Silicon Motion SM710, SM712, SM721
2272	  and SM722 chips.
2273
2274	  This driver is also available as a module. The module will be
2275	  called sm712fb. If you want to compile it as a module, say M
2276	  here and read <file:Documentation/kbuild/modules.rst>.
2277
2278source "drivers/video/fbdev/omap/Kconfig"
2279source "drivers/video/fbdev/omap2/Kconfig"
2280source "drivers/video/fbdev/mmp/Kconfig"
2281