xref: /OK3568_Linux_fs/kernel/arch/m68k/include/asm/fbio.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */
2*4882a593Smuzhiyun #ifndef __LINUX_FBIO_H
3*4882a593Smuzhiyun #define __LINUX_FBIO_H
4*4882a593Smuzhiyun 
5*4882a593Smuzhiyun #include <linux/compiler.h>
6*4882a593Smuzhiyun #include <linux/types.h>
7*4882a593Smuzhiyun 
8*4882a593Smuzhiyun /* Constants used for fbio SunOS compatibility */
9*4882a593Smuzhiyun /* (C) 1996 Miguel de Icaza */
10*4882a593Smuzhiyun 
11*4882a593Smuzhiyun /* Frame buffer types */
12*4882a593Smuzhiyun #define FBTYPE_NOTYPE           -1
13*4882a593Smuzhiyun #define FBTYPE_SUN1BW           0   /* mono */
14*4882a593Smuzhiyun #define FBTYPE_SUN1COLOR        1
15*4882a593Smuzhiyun #define FBTYPE_SUN2BW           2
16*4882a593Smuzhiyun #define FBTYPE_SUN2COLOR        3
17*4882a593Smuzhiyun #define FBTYPE_SUN2GP           4
18*4882a593Smuzhiyun #define FBTYPE_SUN5COLOR        5
19*4882a593Smuzhiyun #define FBTYPE_SUN3COLOR        6
20*4882a593Smuzhiyun #define FBTYPE_MEMCOLOR         7
21*4882a593Smuzhiyun #define FBTYPE_SUN4COLOR        8
22*4882a593Smuzhiyun 
23*4882a593Smuzhiyun #define FBTYPE_NOTSUN1          9
24*4882a593Smuzhiyun #define FBTYPE_NOTSUN2          10
25*4882a593Smuzhiyun #define FBTYPE_NOTSUN3          11
26*4882a593Smuzhiyun 
27*4882a593Smuzhiyun #define FBTYPE_SUNFAST_COLOR    12  /* cg6 */
28*4882a593Smuzhiyun #define FBTYPE_SUNROP_COLOR     13
29*4882a593Smuzhiyun #define FBTYPE_SUNFB_VIDEO      14
30*4882a593Smuzhiyun #define FBTYPE_SUNGIFB          15
31*4882a593Smuzhiyun #define FBTYPE_SUNGPLAS         16
32*4882a593Smuzhiyun #define FBTYPE_SUNGP3           17
33*4882a593Smuzhiyun #define FBTYPE_SUNGT            18
34*4882a593Smuzhiyun #define FBTYPE_SUNLEO           19      /* zx Leo card */
35*4882a593Smuzhiyun #define FBTYPE_MDICOLOR         20      /* cg14 */
36*4882a593Smuzhiyun #define FBTYPE_TCXCOLOR		21	/* SUNW,tcx card */
37*4882a593Smuzhiyun 
38*4882a593Smuzhiyun #define FBTYPE_LASTPLUSONE      21	/* This is not last + 1 in fact... */
39*4882a593Smuzhiyun 
40*4882a593Smuzhiyun /* Does not seem to be listed in the Sun file either */
41*4882a593Smuzhiyun #define FBTYPE_CREATOR          22
42*4882a593Smuzhiyun #define FBTYPE_PCI_IGA1682	23
43*4882a593Smuzhiyun #define FBTYPE_P9100COLOR	24
44*4882a593Smuzhiyun 
45*4882a593Smuzhiyun #define FBTYPE_PCI_GENERIC	1000
46*4882a593Smuzhiyun #define FBTYPE_PCI_MACH64	1001
47*4882a593Smuzhiyun 
48*4882a593Smuzhiyun /* fbio ioctls */
49*4882a593Smuzhiyun /* Returned by FBIOGTYPE */
50*4882a593Smuzhiyun struct  fbtype {
51*4882a593Smuzhiyun         int     fb_type;        /* fb type, see above */
52*4882a593Smuzhiyun         int     fb_height;      /* pixels */
53*4882a593Smuzhiyun         int     fb_width;       /* pixels */
54*4882a593Smuzhiyun         int     fb_depth;
55*4882a593Smuzhiyun         int     fb_cmsize;      /* color map entries */
56*4882a593Smuzhiyun         int     fb_size;        /* fb size in bytes */
57*4882a593Smuzhiyun };
58*4882a593Smuzhiyun #define FBIOGTYPE _IOR('F', 0, struct fbtype)
59*4882a593Smuzhiyun 
60*4882a593Smuzhiyun struct  fbcmap {
61*4882a593Smuzhiyun         int             index;          /* first element (0 origin) */
62*4882a593Smuzhiyun         int             count;
63*4882a593Smuzhiyun         unsigned char   __user *red;
64*4882a593Smuzhiyun         unsigned char   __user *green;
65*4882a593Smuzhiyun         unsigned char   __user *blue;
66*4882a593Smuzhiyun };
67*4882a593Smuzhiyun 
68*4882a593Smuzhiyun #ifdef __KERNEL__
69*4882a593Smuzhiyun #define FBIOPUTCMAP_SPARC _IOW('F', 3, struct fbcmap)
70*4882a593Smuzhiyun #define FBIOGETCMAP_SPARC _IOW('F', 4, struct fbcmap)
71*4882a593Smuzhiyun #else
72*4882a593Smuzhiyun #define FBIOPUTCMAP _IOW('F', 3, struct fbcmap)
73*4882a593Smuzhiyun #define FBIOGETCMAP _IOW('F', 4, struct fbcmap)
74*4882a593Smuzhiyun #endif
75*4882a593Smuzhiyun 
76*4882a593Smuzhiyun /* # of device specific values */
77*4882a593Smuzhiyun #define FB_ATTR_NDEVSPECIFIC    8
78*4882a593Smuzhiyun /* # of possible emulations */
79*4882a593Smuzhiyun #define FB_ATTR_NEMUTYPES       4
80*4882a593Smuzhiyun 
81*4882a593Smuzhiyun struct fbsattr {
82*4882a593Smuzhiyun         int     flags;
83*4882a593Smuzhiyun         int     emu_type;	/* -1 if none */
84*4882a593Smuzhiyun         int     dev_specific[FB_ATTR_NDEVSPECIFIC];
85*4882a593Smuzhiyun };
86*4882a593Smuzhiyun 
87*4882a593Smuzhiyun struct fbgattr {
88*4882a593Smuzhiyun         int     real_type;	/* real frame buffer type */
89*4882a593Smuzhiyun         int     owner;		/* unknown */
90*4882a593Smuzhiyun         struct fbtype fbtype;	/* real frame buffer fbtype */
91*4882a593Smuzhiyun         struct fbsattr sattr;
92*4882a593Smuzhiyun         int     emu_types[FB_ATTR_NEMUTYPES]; /* supported emulations */
93*4882a593Smuzhiyun };
94*4882a593Smuzhiyun #define FBIOSATTR  _IOW('F', 5, struct fbgattr) /* Unsupported: */
95*4882a593Smuzhiyun #define FBIOGATTR  _IOR('F', 6, struct fbgattr)	/* supported */
96*4882a593Smuzhiyun 
97*4882a593Smuzhiyun #define FBIOSVIDEO _IOW('F', 7, int)
98*4882a593Smuzhiyun #define FBIOGVIDEO _IOR('F', 8, int)
99*4882a593Smuzhiyun 
100*4882a593Smuzhiyun struct fbcursor {
101*4882a593Smuzhiyun         short set;              /* what to set, choose from the list above */
102*4882a593Smuzhiyun         short enable;           /* cursor on/off */
103*4882a593Smuzhiyun         struct fbcurpos pos;    /* cursor position */
104*4882a593Smuzhiyun         struct fbcurpos hot;    /* cursor hot spot */
105*4882a593Smuzhiyun         struct fbcmap cmap;     /* color map info */
106*4882a593Smuzhiyun         struct fbcurpos size;   /* cursor bit map size */
107*4882a593Smuzhiyun         char __user *image;     /* cursor image bits */
108*4882a593Smuzhiyun         char __user *mask;      /* cursor mask bits */
109*4882a593Smuzhiyun };
110*4882a593Smuzhiyun 
111*4882a593Smuzhiyun /* set/get cursor attributes/shape */
112*4882a593Smuzhiyun #define FBIOSCURSOR     _IOW('F', 24, struct fbcursor)
113*4882a593Smuzhiyun #define FBIOGCURSOR     _IOWR('F', 25, struct fbcursor)
114*4882a593Smuzhiyun 
115*4882a593Smuzhiyun /* set/get cursor position */
116*4882a593Smuzhiyun #define FBIOSCURPOS     _IOW('F', 26, struct fbcurpos)
117*4882a593Smuzhiyun #define FBIOGCURPOS     _IOW('F', 27, struct fbcurpos)
118*4882a593Smuzhiyun 
119*4882a593Smuzhiyun /* get max cursor size */
120*4882a593Smuzhiyun #define FBIOGCURMAX     _IOR('F', 28, struct fbcurpos)
121*4882a593Smuzhiyun 
122*4882a593Smuzhiyun /* wid manipulation */
123*4882a593Smuzhiyun struct fb_wid_alloc {
124*4882a593Smuzhiyun #define FB_WID_SHARED_8		0
125*4882a593Smuzhiyun #define FB_WID_SHARED_24	1
126*4882a593Smuzhiyun #define FB_WID_DBL_8		2
127*4882a593Smuzhiyun #define FB_WID_DBL_24		3
128*4882a593Smuzhiyun 	__u32	wa_type;
129*4882a593Smuzhiyun 	__s32	wa_index;	/* Set on return */
130*4882a593Smuzhiyun 	__u32	wa_count;
131*4882a593Smuzhiyun };
132*4882a593Smuzhiyun struct fb_wid_item {
133*4882a593Smuzhiyun 	__u32	wi_type;
134*4882a593Smuzhiyun 	__s32	wi_index;
135*4882a593Smuzhiyun 	__u32	wi_attrs;
136*4882a593Smuzhiyun 	__u32	wi_values[32];
137*4882a593Smuzhiyun };
138*4882a593Smuzhiyun struct fb_wid_list {
139*4882a593Smuzhiyun 	__u32	wl_flags;
140*4882a593Smuzhiyun 	__u32	wl_count;
141*4882a593Smuzhiyun 	struct fb_wid_item	*wl_list;
142*4882a593Smuzhiyun };
143*4882a593Smuzhiyun 
144*4882a593Smuzhiyun #define FBIO_WID_ALLOC	_IOWR('F', 30, struct fb_wid_alloc)
145*4882a593Smuzhiyun #define FBIO_WID_FREE	_IOW('F', 31, struct fb_wid_alloc)
146*4882a593Smuzhiyun #define FBIO_WID_PUT	_IOW('F', 32, struct fb_wid_list)
147*4882a593Smuzhiyun #define FBIO_WID_GET	_IOWR('F', 33, struct fb_wid_list)
148*4882a593Smuzhiyun 
149*4882a593Smuzhiyun /* Creator ioctls */
150*4882a593Smuzhiyun #define FFB_IOCTL	('F'<<8)
151*4882a593Smuzhiyun #define FFB_SYS_INFO		(FFB_IOCTL|80)
152*4882a593Smuzhiyun #define FFB_CLUTREAD		(FFB_IOCTL|81)
153*4882a593Smuzhiyun #define FFB_CLUTPOST		(FFB_IOCTL|82)
154*4882a593Smuzhiyun #define FFB_SETDIAGMODE		(FFB_IOCTL|83)
155*4882a593Smuzhiyun #define FFB_GETMONITORID	(FFB_IOCTL|84)
156*4882a593Smuzhiyun #define FFB_GETVIDEOMODE	(FFB_IOCTL|85)
157*4882a593Smuzhiyun #define FFB_SETVIDEOMODE	(FFB_IOCTL|86)
158*4882a593Smuzhiyun #define FFB_SETSERVER		(FFB_IOCTL|87)
159*4882a593Smuzhiyun #define FFB_SETOVCTL		(FFB_IOCTL|88)
160*4882a593Smuzhiyun #define FFB_GETOVCTL		(FFB_IOCTL|89)
161*4882a593Smuzhiyun #define FFB_GETSAXNUM		(FFB_IOCTL|90)
162*4882a593Smuzhiyun #define FFB_FBDEBUG		(FFB_IOCTL|91)
163*4882a593Smuzhiyun 
164*4882a593Smuzhiyun /* Cg14 ioctls */
165*4882a593Smuzhiyun #define MDI_IOCTL          ('M'<<8)
166*4882a593Smuzhiyun #define MDI_RESET          (MDI_IOCTL|1)
167*4882a593Smuzhiyun #define MDI_GET_CFGINFO    (MDI_IOCTL|2)
168*4882a593Smuzhiyun #define MDI_SET_PIXELMODE  (MDI_IOCTL|3)
169*4882a593Smuzhiyun #    define MDI_32_PIX     32
170*4882a593Smuzhiyun #    define MDI_16_PIX     16
171*4882a593Smuzhiyun #    define MDI_8_PIX      8
172*4882a593Smuzhiyun 
173*4882a593Smuzhiyun struct mdi_cfginfo {
174*4882a593Smuzhiyun 	int     mdi_ncluts;     /* Number of implemented CLUTs in this MDI */
175*4882a593Smuzhiyun         int     mdi_type;       /* FBTYPE name */
176*4882a593Smuzhiyun         int     mdi_height;     /* height */
177*4882a593Smuzhiyun         int     mdi_width;      /* width */
178*4882a593Smuzhiyun         int     mdi_size;       /* available ram */
179*4882a593Smuzhiyun         int     mdi_mode;       /* 8bpp, 16bpp or 32bpp */
180*4882a593Smuzhiyun         int     mdi_pixfreq;    /* pixel clock (from PROM) */
181*4882a593Smuzhiyun };
182*4882a593Smuzhiyun 
183*4882a593Smuzhiyun /* SparcLinux specific ioctl for the MDI, should be replaced for
184*4882a593Smuzhiyun  * the SET_XLUT/SET_CLUTn ioctls instead
185*4882a593Smuzhiyun  */
186*4882a593Smuzhiyun #define MDI_CLEAR_XLUT       (MDI_IOCTL|9)
187*4882a593Smuzhiyun 
188*4882a593Smuzhiyun /* leo & ffb ioctls */
189*4882a593Smuzhiyun struct fb_clut_alloc {
190*4882a593Smuzhiyun 	__u32	clutid;	/* Set on return */
191*4882a593Smuzhiyun  	__u32	flag;
192*4882a593Smuzhiyun  	__u32	index;
193*4882a593Smuzhiyun };
194*4882a593Smuzhiyun 
195*4882a593Smuzhiyun struct fb_clut {
196*4882a593Smuzhiyun #define FB_CLUT_WAIT	0x00000001	/* Not yet implemented */
197*4882a593Smuzhiyun  	__u32	flag;
198*4882a593Smuzhiyun  	__u32	clutid;
199*4882a593Smuzhiyun  	__u32	offset;
200*4882a593Smuzhiyun  	__u32	count;
201*4882a593Smuzhiyun  	char *	red;
202*4882a593Smuzhiyun  	char *	green;
203*4882a593Smuzhiyun  	char *	blue;
204*4882a593Smuzhiyun };
205*4882a593Smuzhiyun 
206*4882a593Smuzhiyun struct fb_clut32 {
207*4882a593Smuzhiyun  	__u32	flag;
208*4882a593Smuzhiyun  	__u32	clutid;
209*4882a593Smuzhiyun  	__u32	offset;
210*4882a593Smuzhiyun  	__u32	count;
211*4882a593Smuzhiyun  	__u32	red;
212*4882a593Smuzhiyun  	__u32	green;
213*4882a593Smuzhiyun  	__u32	blue;
214*4882a593Smuzhiyun };
215*4882a593Smuzhiyun 
216*4882a593Smuzhiyun #define LEO_CLUTALLOC	_IOWR('L', 53, struct fb_clut_alloc)
217*4882a593Smuzhiyun #define LEO_CLUTFREE	_IOW('L', 54, struct fb_clut_alloc)
218*4882a593Smuzhiyun #define LEO_CLUTREAD	_IOW('L', 55, struct fb_clut)
219*4882a593Smuzhiyun #define LEO_CLUTPOST	_IOW('L', 56, struct fb_clut)
220*4882a593Smuzhiyun #define LEO_SETGAMMA	_IOW('L', 68, int) /* Not yet implemented */
221*4882a593Smuzhiyun #define LEO_GETGAMMA	_IOR('L', 69, int) /* Not yet implemented */
222*4882a593Smuzhiyun 
223*4882a593Smuzhiyun #ifdef __KERNEL__
224*4882a593Smuzhiyun /* Addresses on the fd of a cgsix that are mappable */
225*4882a593Smuzhiyun #define CG6_FBC    0x70000000
226*4882a593Smuzhiyun #define CG6_TEC    0x70001000
227*4882a593Smuzhiyun #define CG6_BTREGS 0x70002000
228*4882a593Smuzhiyun #define CG6_FHC    0x70004000
229*4882a593Smuzhiyun #define CG6_THC    0x70005000
230*4882a593Smuzhiyun #define CG6_ROM    0x70006000
231*4882a593Smuzhiyun #define CG6_RAM    0x70016000
232*4882a593Smuzhiyun #define CG6_DHC    0x80000000
233*4882a593Smuzhiyun 
234*4882a593Smuzhiyun #define CG3_MMAP_OFFSET 0x4000000
235*4882a593Smuzhiyun 
236*4882a593Smuzhiyun /* Addresses on the fd of a tcx that are mappable */
237*4882a593Smuzhiyun #define TCX_RAM8BIT   		0x00000000
238*4882a593Smuzhiyun #define TCX_RAM24BIT   		0x01000000
239*4882a593Smuzhiyun #define TCX_UNK3   		0x10000000
240*4882a593Smuzhiyun #define TCX_UNK4   		0x20000000
241*4882a593Smuzhiyun #define TCX_CONTROLPLANE   	0x28000000
242*4882a593Smuzhiyun #define TCX_UNK6   		0x30000000
243*4882a593Smuzhiyun #define TCX_UNK7   		0x38000000
244*4882a593Smuzhiyun #define TCX_TEC    		0x70000000
245*4882a593Smuzhiyun #define TCX_BTREGS 		0x70002000
246*4882a593Smuzhiyun #define TCX_THC    		0x70004000
247*4882a593Smuzhiyun #define TCX_DHC    		0x70008000
248*4882a593Smuzhiyun #define TCX_ALT	   		0x7000a000
249*4882a593Smuzhiyun #define TCX_SYNC   		0x7000e000
250*4882a593Smuzhiyun #define TCX_UNK2    		0x70010000
251*4882a593Smuzhiyun 
252*4882a593Smuzhiyun /* CG14 definitions */
253*4882a593Smuzhiyun 
254*4882a593Smuzhiyun /* Offsets into the OBIO space: */
255*4882a593Smuzhiyun #define CG14_REGS        0       /* registers */
256*4882a593Smuzhiyun #define CG14_CURSORREGS  0x1000  /* cursor registers */
257*4882a593Smuzhiyun #define CG14_DACREGS     0x2000  /* DAC registers */
258*4882a593Smuzhiyun #define CG14_XLUT        0x3000  /* X Look Up Table -- ??? */
259*4882a593Smuzhiyun #define CG14_CLUT1       0x4000  /* Color Look Up Table */
260*4882a593Smuzhiyun #define CG14_CLUT2       0x5000  /* Color Look Up Table */
261*4882a593Smuzhiyun #define CG14_CLUT3       0x6000  /* Color Look Up Table */
262*4882a593Smuzhiyun #define CG14_AUTO	 0xf000
263*4882a593Smuzhiyun 
264*4882a593Smuzhiyun #endif /* KERNEL */
265*4882a593Smuzhiyun 
266*4882a593Smuzhiyun /* These are exported to userland for applications to use */
267*4882a593Smuzhiyun /* Mappable offsets for the cg14: control registers */
268*4882a593Smuzhiyun #define MDI_DIRECT_MAP 0x10000000
269*4882a593Smuzhiyun #define MDI_CTLREG_MAP 0x20000000
270*4882a593Smuzhiyun #define MDI_CURSOR_MAP 0x30000000
271*4882a593Smuzhiyun #define MDI_SHDW_VRT_MAP 0x40000000
272*4882a593Smuzhiyun 
273*4882a593Smuzhiyun /* Mappable offsets for the cg14: frame buffer resolutions */
274*4882a593Smuzhiyun /* 32 bits */
275*4882a593Smuzhiyun #define MDI_CHUNKY_XBGR_MAP 0x50000000
276*4882a593Smuzhiyun #define MDI_CHUNKY_BGR_MAP 0x60000000
277*4882a593Smuzhiyun 
278*4882a593Smuzhiyun /* 16 bits */
279*4882a593Smuzhiyun #define MDI_PLANAR_X16_MAP 0x70000000
280*4882a593Smuzhiyun #define MDI_PLANAR_C16_MAP 0x80000000
281*4882a593Smuzhiyun 
282*4882a593Smuzhiyun /* 8 bit is done as CG3 MMAP offset */
283*4882a593Smuzhiyun /* 32 bits, planar */
284*4882a593Smuzhiyun #define MDI_PLANAR_X32_MAP 0x90000000
285*4882a593Smuzhiyun #define MDI_PLANAR_B32_MAP 0xa0000000
286*4882a593Smuzhiyun #define MDI_PLANAR_G32_MAP 0xb0000000
287*4882a593Smuzhiyun #define MDI_PLANAR_R32_MAP 0xc0000000
288*4882a593Smuzhiyun 
289*4882a593Smuzhiyun /* Mappable offsets on leo */
290*4882a593Smuzhiyun #define LEO_SS0_MAP            0x00000000
291*4882a593Smuzhiyun #define LEO_LC_SS0_USR_MAP     0x00800000
292*4882a593Smuzhiyun #define LEO_LD_SS0_MAP         0x00801000
293*4882a593Smuzhiyun #define LEO_LX_CURSOR_MAP      0x00802000
294*4882a593Smuzhiyun #define LEO_SS1_MAP            0x00803000
295*4882a593Smuzhiyun #define LEO_LC_SS1_USR_MAP     0x01003000
296*4882a593Smuzhiyun #define LEO_LD_SS1_MAP         0x01004000
297*4882a593Smuzhiyun #define LEO_UNK_MAP            0x01005000
298*4882a593Smuzhiyun #define LEO_LX_KRN_MAP         0x01006000
299*4882a593Smuzhiyun #define LEO_LC_SS0_KRN_MAP     0x01007000
300*4882a593Smuzhiyun #define LEO_LC_SS1_KRN_MAP     0x01008000
301*4882a593Smuzhiyun #define LEO_LD_GBL_MAP         0x01009000
302*4882a593Smuzhiyun #define LEO_UNK2_MAP           0x0100a000
303*4882a593Smuzhiyun 
304*4882a593Smuzhiyun #ifdef __KERNEL__
305*4882a593Smuzhiyun struct  fbcmap32 {
306*4882a593Smuzhiyun 	int             index;          /* first element (0 origin) */
307*4882a593Smuzhiyun 	int             count;
308*4882a593Smuzhiyun 	u32		red;
309*4882a593Smuzhiyun 	u32		green;
310*4882a593Smuzhiyun 	u32		blue;
311*4882a593Smuzhiyun };
312*4882a593Smuzhiyun 
313*4882a593Smuzhiyun #define FBIOPUTCMAP32	_IOW('F', 3, struct fbcmap32)
314*4882a593Smuzhiyun #define FBIOGETCMAP32	_IOW('F', 4, struct fbcmap32)
315*4882a593Smuzhiyun 
316*4882a593Smuzhiyun struct fbcursor32 {
317*4882a593Smuzhiyun 	short set;		/* what to set, choose from the list above */
318*4882a593Smuzhiyun 	short enable;		/* cursor on/off */
319*4882a593Smuzhiyun 	struct fbcurpos pos;	/* cursor position */
320*4882a593Smuzhiyun 	struct fbcurpos hot;	/* cursor hot spot */
321*4882a593Smuzhiyun 	struct fbcmap32 cmap;	/* color map info */
322*4882a593Smuzhiyun 	struct fbcurpos size;	/* cursor bit map size */
323*4882a593Smuzhiyun 	u32	image;		/* cursor image bits */
324*4882a593Smuzhiyun 	u32	mask;		/* cursor mask bits */
325*4882a593Smuzhiyun };
326*4882a593Smuzhiyun 
327*4882a593Smuzhiyun #define FBIOSCURSOR32	_IOW('F', 24, struct fbcursor32)
328*4882a593Smuzhiyun #define FBIOGCURSOR32	_IOW('F', 25, struct fbcursor32)
329*4882a593Smuzhiyun #endif
330*4882a593Smuzhiyun 
331*4882a593Smuzhiyun #endif /* __LINUX_FBIO_H */
332