blob: a0ef0c4081c534887f18df7bf7d0ee9751342249 [file] [log] [blame]
Ben Cheng655a7c02013-10-16 16:09:24 -07001/****************************************************************************
2 ****************************************************************************
3 ***
4 *** This header was automatically generated from a Linux kernel header
5 *** of the same name, to make information necessary for userspace to
6 *** call into the kernel available to libc. It contains only constants,
7 *** structures, and macros generated from the original header, and thus,
8 *** contains no copyrightable information.
9 ***
10 *** To edit the content of this header, modify the corresponding
11 *** source file (e.g. under external/kernel-headers/original/) then
12 *** run bionic/libc/kernel/tools/update_all.py
13 ***
14 *** Any manual change here will be lost the next time this script will
15 *** be run. You've been warned!
16 ***
17 ****************************************************************************
18 ****************************************************************************/
19#ifndef _UAPI_LINUX_FB_H
20#define _UAPI_LINUX_FB_H
21#include <linux/types.h>
22#include <linux/i2c.h>
Ben Cheng655a7c02013-10-16 16:09:24 -070023#define FB_MAX 32
24#define FBIOGET_VSCREENINFO 0x4600
25#define FBIOPUT_VSCREENINFO 0x4601
26#define FBIOGET_FSCREENINFO 0x4602
Ben Cheng655a7c02013-10-16 16:09:24 -070027#define FBIOGETCMAP 0x4604
28#define FBIOPUTCMAP 0x4605
29#define FBIOPAN_DISPLAY 0x4606
30#define FBIO_CURSOR _IOWR('F', 0x08, struct fb_cursor)
Ben Cheng655a7c02013-10-16 16:09:24 -070031#define FBIOGET_CON2FBMAP 0x460F
32#define FBIOPUT_CON2FBMAP 0x4610
33#define FBIOBLANK 0x4611
34#define FBIOGET_VBLANK _IOR('F', 0x12, struct fb_vblank)
Ben Cheng655a7c02013-10-16 16:09:24 -070035#define FBIO_ALLOC 0x4613
36#define FBIO_FREE 0x4614
37#define FBIOGET_GLYPH 0x4615
38#define FBIOGET_HWCINFO 0x4616
Ben Cheng655a7c02013-10-16 16:09:24 -070039#define FBIOPUT_MODEINFO 0x4617
40#define FBIOGET_DISPINFO 0x4618
41#define FBIO_WAITFORVSYNC _IOW('F', 0x20, __u32)
42#define FB_TYPE_PACKED_PIXELS 0
Ben Cheng655a7c02013-10-16 16:09:24 -070043#define FB_TYPE_PLANES 1
44#define FB_TYPE_INTERLEAVED_PLANES 2
45#define FB_TYPE_TEXT 3
46#define FB_TYPE_VGA_PLANES 4
Ben Cheng655a7c02013-10-16 16:09:24 -070047#define FB_TYPE_FOURCC 5
48#define FB_AUX_TEXT_MDA 0
49#define FB_AUX_TEXT_CGA 1
50#define FB_AUX_TEXT_S3_MMIO 2
Ben Cheng655a7c02013-10-16 16:09:24 -070051#define FB_AUX_TEXT_MGA_STEP16 3
52#define FB_AUX_TEXT_MGA_STEP8 4
53#define FB_AUX_TEXT_SVGA_GROUP 8
54#define FB_AUX_TEXT_SVGA_MASK 7
Ben Cheng655a7c02013-10-16 16:09:24 -070055#define FB_AUX_TEXT_SVGA_STEP2 8
56#define FB_AUX_TEXT_SVGA_STEP4 9
57#define FB_AUX_TEXT_SVGA_STEP8 10
58#define FB_AUX_TEXT_SVGA_STEP16 11
Ben Cheng655a7c02013-10-16 16:09:24 -070059#define FB_AUX_TEXT_SVGA_LAST 15
60#define FB_AUX_VGA_PLANES_VGA4 0
61#define FB_AUX_VGA_PLANES_CFB4 1
62#define FB_AUX_VGA_PLANES_CFB8 2
Ben Cheng655a7c02013-10-16 16:09:24 -070063#define FB_VISUAL_MONO01 0
64#define FB_VISUAL_MONO10 1
65#define FB_VISUAL_TRUECOLOR 2
66#define FB_VISUAL_PSEUDOCOLOR 3
Ben Cheng655a7c02013-10-16 16:09:24 -070067#define FB_VISUAL_DIRECTCOLOR 4
68#define FB_VISUAL_STATIC_PSEUDOCOLOR 5
69#define FB_VISUAL_FOURCC 6
70#define FB_ACCEL_NONE 0
Ben Cheng655a7c02013-10-16 16:09:24 -070071#define FB_ACCEL_ATARIBLITT 1
72#define FB_ACCEL_AMIGABLITT 2
73#define FB_ACCEL_S3_TRIO64 3
74#define FB_ACCEL_NCR_77C32BLT 4
Ben Cheng655a7c02013-10-16 16:09:24 -070075#define FB_ACCEL_S3_VIRGE 5
76#define FB_ACCEL_ATI_MACH64GX 6
77#define FB_ACCEL_DEC_TGA 7
78#define FB_ACCEL_ATI_MACH64CT 8
Ben Cheng655a7c02013-10-16 16:09:24 -070079#define FB_ACCEL_ATI_MACH64VT 9
80#define FB_ACCEL_ATI_MACH64GT 10
81#define FB_ACCEL_SUN_CREATOR 11
82#define FB_ACCEL_SUN_CGSIX 12
Ben Cheng655a7c02013-10-16 16:09:24 -070083#define FB_ACCEL_SUN_LEO 13
84#define FB_ACCEL_IMS_TWINTURBO 14
85#define FB_ACCEL_3DLABS_PERMEDIA2 15
86#define FB_ACCEL_MATROX_MGA2064W 16
Ben Cheng655a7c02013-10-16 16:09:24 -070087#define FB_ACCEL_MATROX_MGA1064SG 17
88#define FB_ACCEL_MATROX_MGA2164W 18
89#define FB_ACCEL_MATROX_MGA2164W_AGP 19
90#define FB_ACCEL_MATROX_MGAG100 20
Ben Cheng655a7c02013-10-16 16:09:24 -070091#define FB_ACCEL_MATROX_MGAG200 21
92#define FB_ACCEL_SUN_CG14 22
93#define FB_ACCEL_SUN_BWTWO 23
94#define FB_ACCEL_SUN_CGTHREE 24
Ben Cheng655a7c02013-10-16 16:09:24 -070095#define FB_ACCEL_SUN_TCX 25
96#define FB_ACCEL_MATROX_MGAG400 26
97#define FB_ACCEL_NV3 27
98#define FB_ACCEL_NV4 28
Ben Cheng655a7c02013-10-16 16:09:24 -070099#define FB_ACCEL_NV5 29
100#define FB_ACCEL_CT_6555x 30
101#define FB_ACCEL_3DFX_BANSHEE 31
102#define FB_ACCEL_ATI_RAGE128 32
Ben Cheng655a7c02013-10-16 16:09:24 -0700103#define FB_ACCEL_IGS_CYBER2000 33
104#define FB_ACCEL_IGS_CYBER2010 34
105#define FB_ACCEL_IGS_CYBER5000 35
106#define FB_ACCEL_SIS_GLAMOUR 36
Ben Cheng655a7c02013-10-16 16:09:24 -0700107#define FB_ACCEL_3DLABS_PERMEDIA3 37
108#define FB_ACCEL_ATI_RADEON 38
109#define FB_ACCEL_I810 39
110#define FB_ACCEL_SIS_GLAMOUR_2 40
Ben Cheng655a7c02013-10-16 16:09:24 -0700111#define FB_ACCEL_SIS_XABRE 41
112#define FB_ACCEL_I830 42
113#define FB_ACCEL_NV_10 43
114#define FB_ACCEL_NV_20 44
Ben Cheng655a7c02013-10-16 16:09:24 -0700115#define FB_ACCEL_NV_30 45
116#define FB_ACCEL_NV_40 46
117#define FB_ACCEL_XGI_VOLARI_V 47
118#define FB_ACCEL_XGI_VOLARI_Z 48
Ben Cheng655a7c02013-10-16 16:09:24 -0700119#define FB_ACCEL_OMAP1610 49
120#define FB_ACCEL_TRIDENT_TGUI 50
121#define FB_ACCEL_TRIDENT_3DIMAGE 51
122#define FB_ACCEL_TRIDENT_BLADE3D 52
Ben Cheng655a7c02013-10-16 16:09:24 -0700123#define FB_ACCEL_TRIDENT_BLADEXP 53
124#define FB_ACCEL_CIRRUS_ALPINE 53
125#define FB_ACCEL_NEOMAGIC_NM2070 90
126#define FB_ACCEL_NEOMAGIC_NM2090 91
Ben Cheng655a7c02013-10-16 16:09:24 -0700127#define FB_ACCEL_NEOMAGIC_NM2093 92
128#define FB_ACCEL_NEOMAGIC_NM2097 93
129#define FB_ACCEL_NEOMAGIC_NM2160 94
130#define FB_ACCEL_NEOMAGIC_NM2200 95
Ben Cheng655a7c02013-10-16 16:09:24 -0700131#define FB_ACCEL_NEOMAGIC_NM2230 96
132#define FB_ACCEL_NEOMAGIC_NM2360 97
133#define FB_ACCEL_NEOMAGIC_NM2380 98
134#define FB_ACCEL_PXA3XX 99
Ben Cheng655a7c02013-10-16 16:09:24 -0700135#define FB_ACCEL_SAVAGE4 0x80
136#define FB_ACCEL_SAVAGE3D 0x81
137#define FB_ACCEL_SAVAGE3D_MV 0x82
138#define FB_ACCEL_SAVAGE2000 0x83
Ben Cheng655a7c02013-10-16 16:09:24 -0700139#define FB_ACCEL_SAVAGE_MX_MV 0x84
140#define FB_ACCEL_SAVAGE_MX 0x85
141#define FB_ACCEL_SAVAGE_IX_MV 0x86
142#define FB_ACCEL_SAVAGE_IX 0x87
Ben Cheng655a7c02013-10-16 16:09:24 -0700143#define FB_ACCEL_PROSAVAGE_PM 0x88
144#define FB_ACCEL_PROSAVAGE_KM 0x89
145#define FB_ACCEL_S3TWISTER_P 0x8a
146#define FB_ACCEL_S3TWISTER_K 0x8b
Ben Cheng655a7c02013-10-16 16:09:24 -0700147#define FB_ACCEL_SUPERSAVAGE 0x8c
148#define FB_ACCEL_PROSAVAGE_DDR 0x8d
149#define FB_ACCEL_PROSAVAGE_DDRK 0x8e
150#define FB_ACCEL_PUV3_UNIGFX 0xa0
Ben Cheng655a7c02013-10-16 16:09:24 -0700151#define FB_CAP_FOURCC 1
152struct fb_fix_screeninfo {
Tao Baod7db5942015-01-28 10:07:51 -0800153 char id[16];
154 unsigned long smem_start;
Tao Baod7db5942015-01-28 10:07:51 -0800155 __u32 smem_len;
156 __u32 type;
157 __u32 type_aux;
158 __u32 visual;
Tao Baod7db5942015-01-28 10:07:51 -0800159 __u16 xpanstep;
160 __u16 ypanstep;
161 __u16 ywrapstep;
162 __u32 line_length;
Tao Baod7db5942015-01-28 10:07:51 -0800163 unsigned long mmio_start;
164 __u32 mmio_len;
165 __u32 accel;
166 __u16 capabilities;
Tao Baod7db5942015-01-28 10:07:51 -0800167 __u16 reserved[2];
Ben Cheng655a7c02013-10-16 16:09:24 -0700168};
169struct fb_bitfield {
Tao Baod7db5942015-01-28 10:07:51 -0800170 __u32 offset;
Tao Baod7db5942015-01-28 10:07:51 -0800171 __u32 length;
172 __u32 msb_right;
Ben Cheng655a7c02013-10-16 16:09:24 -0700173};
174#define FB_NONSTD_HAM 1
Ben Cheng655a7c02013-10-16 16:09:24 -0700175#define FB_NONSTD_REV_PIX_IN_B 2
176#define FB_ACTIVATE_NOW 0
177#define FB_ACTIVATE_NXTOPEN 1
178#define FB_ACTIVATE_TEST 2
Ben Cheng655a7c02013-10-16 16:09:24 -0700179#define FB_ACTIVATE_MASK 15
180#define FB_ACTIVATE_VBL 16
181#define FB_CHANGE_CMAP_VBL 32
182#define FB_ACTIVATE_ALL 64
Ben Cheng655a7c02013-10-16 16:09:24 -0700183#define FB_ACTIVATE_FORCE 128
184#define FB_ACTIVATE_INV_MODE 256
Christopher Ferris8177cdf2020-08-03 11:53:55 -0700185#define FB_ACTIVATE_KD_TEXT 512
Ben Cheng655a7c02013-10-16 16:09:24 -0700186#define FB_ACCELF_TEXT 1
187#define FB_SYNC_HOR_HIGH_ACT 1
Ben Cheng655a7c02013-10-16 16:09:24 -0700188#define FB_SYNC_VERT_HIGH_ACT 2
189#define FB_SYNC_EXT 4
190#define FB_SYNC_COMP_HIGH_ACT 8
191#define FB_SYNC_BROADCAST 16
Ben Cheng655a7c02013-10-16 16:09:24 -0700192#define FB_SYNC_ON_GREEN 32
193#define FB_VMODE_NONINTERLACED 0
194#define FB_VMODE_INTERLACED 1
195#define FB_VMODE_DOUBLE 2
Ben Cheng655a7c02013-10-16 16:09:24 -0700196#define FB_VMODE_ODD_FLD_FIRST 4
197#define FB_VMODE_MASK 255
198#define FB_VMODE_YWRAP 256
199#define FB_VMODE_SMOOTH_XPAN 512
Ben Cheng655a7c02013-10-16 16:09:24 -0700200#define FB_VMODE_CONUPDATE 512
201#define FB_ROTATE_UR 0
202#define FB_ROTATE_CW 1
203#define FB_ROTATE_UD 2
Ben Cheng655a7c02013-10-16 16:09:24 -0700204#define FB_ROTATE_CCW 3
Tao Baod7db5942015-01-28 10:07:51 -0800205#define PICOS2KHZ(a) (1000000000UL / (a))
206#define KHZ2PICOS(a) (1000000000UL / (a))
Ben Cheng655a7c02013-10-16 16:09:24 -0700207struct fb_var_screeninfo {
Tao Baod7db5942015-01-28 10:07:51 -0800208 __u32 xres;
209 __u32 yres;
210 __u32 xres_virtual;
211 __u32 yres_virtual;
Tao Baod7db5942015-01-28 10:07:51 -0800212 __u32 xoffset;
213 __u32 yoffset;
214 __u32 bits_per_pixel;
215 __u32 grayscale;
Tao Baod7db5942015-01-28 10:07:51 -0800216 struct fb_bitfield red;
217 struct fb_bitfield green;
218 struct fb_bitfield blue;
219 struct fb_bitfield transp;
Tao Baod7db5942015-01-28 10:07:51 -0800220 __u32 nonstd;
221 __u32 activate;
222 __u32 height;
223 __u32 width;
Tao Baod7db5942015-01-28 10:07:51 -0800224 __u32 accel_flags;
225 __u32 pixclock;
226 __u32 left_margin;
227 __u32 right_margin;
Tao Baod7db5942015-01-28 10:07:51 -0800228 __u32 upper_margin;
229 __u32 lower_margin;
230 __u32 hsync_len;
231 __u32 vsync_len;
Tao Baod7db5942015-01-28 10:07:51 -0800232 __u32 sync;
233 __u32 vmode;
234 __u32 rotate;
235 __u32 colorspace;
Tao Baod7db5942015-01-28 10:07:51 -0800236 __u32 reserved[4];
Ben Cheng655a7c02013-10-16 16:09:24 -0700237};
238struct fb_cmap {
Tao Baod7db5942015-01-28 10:07:51 -0800239 __u32 start;
Tao Baod7db5942015-01-28 10:07:51 -0800240 __u32 len;
241 __u16 * red;
242 __u16 * green;
243 __u16 * blue;
Tao Baod7db5942015-01-28 10:07:51 -0800244 __u16 * transp;
Ben Cheng655a7c02013-10-16 16:09:24 -0700245};
246struct fb_con2fbmap {
Tao Baod7db5942015-01-28 10:07:51 -0800247 __u32 console;
Tao Baod7db5942015-01-28 10:07:51 -0800248 __u32 framebuffer;
Ben Cheng655a7c02013-10-16 16:09:24 -0700249};
250#define VESA_NO_BLANKING 0
251#define VESA_VSYNC_SUSPEND 1
Ben Cheng655a7c02013-10-16 16:09:24 -0700252#define VESA_HSYNC_SUSPEND 2
253#define VESA_POWERDOWN 3
254enum {
Tao Baod7db5942015-01-28 10:07:51 -0800255 FB_BLANK_UNBLANK = VESA_NO_BLANKING,
Tao Baod7db5942015-01-28 10:07:51 -0800256 FB_BLANK_NORMAL = VESA_NO_BLANKING + 1,
257 FB_BLANK_VSYNC_SUSPEND = VESA_VSYNC_SUSPEND + 1,
258 FB_BLANK_HSYNC_SUSPEND = VESA_HSYNC_SUSPEND + 1,
259 FB_BLANK_POWERDOWN = VESA_POWERDOWN + 1
Ben Cheng655a7c02013-10-16 16:09:24 -0700260};
261#define FB_VBLANK_VBLANKING 0x001
262#define FB_VBLANK_HBLANKING 0x002
263#define FB_VBLANK_HAVE_VBLANK 0x004
Ben Cheng655a7c02013-10-16 16:09:24 -0700264#define FB_VBLANK_HAVE_HBLANK 0x008
265#define FB_VBLANK_HAVE_COUNT 0x010
266#define FB_VBLANK_HAVE_VCOUNT 0x020
267#define FB_VBLANK_HAVE_HCOUNT 0x040
Ben Cheng655a7c02013-10-16 16:09:24 -0700268#define FB_VBLANK_VSYNCING 0x080
269#define FB_VBLANK_HAVE_VSYNC 0x100
270struct fb_vblank {
Tao Baod7db5942015-01-28 10:07:51 -0800271 __u32 flags;
Tao Baod7db5942015-01-28 10:07:51 -0800272 __u32 count;
273 __u32 vcount;
274 __u32 hcount;
275 __u32 reserved[4];
Ben Cheng655a7c02013-10-16 16:09:24 -0700276};
277#define ROP_COPY 0
278#define ROP_XOR 1
279struct fb_copyarea {
Tao Baod7db5942015-01-28 10:07:51 -0800280 __u32 dx;
281 __u32 dy;
282 __u32 width;
283 __u32 height;
Tao Baod7db5942015-01-28 10:07:51 -0800284 __u32 sx;
285 __u32 sy;
Ben Cheng655a7c02013-10-16 16:09:24 -0700286};
287struct fb_fillrect {
Tao Baod7db5942015-01-28 10:07:51 -0800288 __u32 dx;
289 __u32 dy;
290 __u32 width;
291 __u32 height;
Tao Baod7db5942015-01-28 10:07:51 -0800292 __u32 color;
293 __u32 rop;
Ben Cheng655a7c02013-10-16 16:09:24 -0700294};
295struct fb_image {
Tao Baod7db5942015-01-28 10:07:51 -0800296 __u32 dx;
297 __u32 dy;
298 __u32 width;
299 __u32 height;
Tao Baod7db5942015-01-28 10:07:51 -0800300 __u32 fg_color;
301 __u32 bg_color;
302 __u8 depth;
303 const char * data;
Tao Baod7db5942015-01-28 10:07:51 -0800304 struct fb_cmap cmap;
Ben Cheng655a7c02013-10-16 16:09:24 -0700305};
306#define FB_CUR_SETIMAGE 0x01
307#define FB_CUR_SETPOS 0x02
Ben Cheng655a7c02013-10-16 16:09:24 -0700308#define FB_CUR_SETHOT 0x04
309#define FB_CUR_SETCMAP 0x08
310#define FB_CUR_SETSHAPE 0x10
311#define FB_CUR_SETSIZE 0x20
Ben Cheng655a7c02013-10-16 16:09:24 -0700312#define FB_CUR_SETALL 0xFF
313struct fbcurpos {
Tao Baod7db5942015-01-28 10:07:51 -0800314 __u16 x, y;
Ben Cheng655a7c02013-10-16 16:09:24 -0700315};
Ben Cheng655a7c02013-10-16 16:09:24 -0700316struct fb_cursor {
Tao Baod7db5942015-01-28 10:07:51 -0800317 __u16 set;
318 __u16 enable;
319 __u16 rop;
Tao Baod7db5942015-01-28 10:07:51 -0800320 const char * mask;
321 struct fbcurpos hot;
322 struct fb_image image;
Ben Cheng655a7c02013-10-16 16:09:24 -0700323};
Christopher Ferrisd842e432019-03-07 10:21:59 -0800324#define FB_BACKLIGHT_LEVELS 128
325#define FB_BACKLIGHT_MAX 0xFF
Ben Cheng655a7c02013-10-16 16:09:24 -0700326#endif