xref: /openbmc/linux/arch/m68k/include/asm/fbio.h (revision 551e378ca1852dc51609b722014416d4da0770c6)
149148020SSam Ravnborg #ifndef __LINUX_FBIO_H
249148020SSam Ravnborg #define __LINUX_FBIO_H
349148020SSam Ravnborg 
449148020SSam Ravnborg #include <linux/compiler.h>
549148020SSam Ravnborg #include <linux/types.h>
649148020SSam Ravnborg 
749148020SSam Ravnborg /* Constants used for fbio SunOS compatibility */
849148020SSam Ravnborg /* (C) 1996 Miguel de Icaza */
949148020SSam Ravnborg 
1049148020SSam Ravnborg /* Frame buffer types */
1149148020SSam Ravnborg #define FBTYPE_NOTYPE           -1
1249148020SSam Ravnborg #define FBTYPE_SUN1BW           0   /* mono */
1349148020SSam Ravnborg #define FBTYPE_SUN1COLOR        1
1449148020SSam Ravnborg #define FBTYPE_SUN2BW           2
1549148020SSam Ravnborg #define FBTYPE_SUN2COLOR        3
1649148020SSam Ravnborg #define FBTYPE_SUN2GP           4
1749148020SSam Ravnborg #define FBTYPE_SUN5COLOR        5
1849148020SSam Ravnborg #define FBTYPE_SUN3COLOR        6
1949148020SSam Ravnborg #define FBTYPE_MEMCOLOR         7
2049148020SSam Ravnborg #define FBTYPE_SUN4COLOR        8
2149148020SSam Ravnborg 
2249148020SSam Ravnborg #define FBTYPE_NOTSUN1          9
2349148020SSam Ravnborg #define FBTYPE_NOTSUN2          10
2449148020SSam Ravnborg #define FBTYPE_NOTSUN3          11
2549148020SSam Ravnborg 
2649148020SSam Ravnborg #define FBTYPE_SUNFAST_COLOR    12  /* cg6 */
2749148020SSam Ravnborg #define FBTYPE_SUNROP_COLOR     13
2849148020SSam Ravnborg #define FBTYPE_SUNFB_VIDEO      14
2949148020SSam Ravnborg #define FBTYPE_SUNGIFB          15
3049148020SSam Ravnborg #define FBTYPE_SUNGPLAS         16
3149148020SSam Ravnborg #define FBTYPE_SUNGP3           17
3249148020SSam Ravnborg #define FBTYPE_SUNGT            18
3349148020SSam Ravnborg #define FBTYPE_SUNLEO           19      /* zx Leo card */
3449148020SSam Ravnborg #define FBTYPE_MDICOLOR         20      /* cg14 */
3549148020SSam Ravnborg #define FBTYPE_TCXCOLOR		21	/* SUNW,tcx card */
3649148020SSam Ravnborg 
3749148020SSam Ravnborg #define FBTYPE_LASTPLUSONE      21	/* This is not last + 1 in fact... */
3849148020SSam Ravnborg 
3949148020SSam Ravnborg /* Does not seem to be listed in the Sun file either */
4049148020SSam Ravnborg #define FBTYPE_CREATOR          22
4149148020SSam Ravnborg #define FBTYPE_PCI_IGA1682	23
4249148020SSam Ravnborg #define FBTYPE_P9100COLOR	24
4349148020SSam Ravnborg 
4449148020SSam Ravnborg #define FBTYPE_PCI_GENERIC	1000
4549148020SSam Ravnborg #define FBTYPE_PCI_MACH64	1001
4649148020SSam Ravnborg 
4749148020SSam Ravnborg /* fbio ioctls */
4849148020SSam Ravnborg /* Returned by FBIOGTYPE */
4949148020SSam Ravnborg struct  fbtype {
5049148020SSam Ravnborg         int     fb_type;        /* fb type, see above */
5149148020SSam Ravnborg         int     fb_height;      /* pixels */
5249148020SSam Ravnborg         int     fb_width;       /* pixels */
5349148020SSam Ravnborg         int     fb_depth;
5449148020SSam Ravnborg         int     fb_cmsize;      /* color map entries */
5549148020SSam Ravnborg         int     fb_size;        /* fb size in bytes */
5649148020SSam Ravnborg };
5749148020SSam Ravnborg #define FBIOGTYPE _IOR('F', 0, struct fbtype)
5849148020SSam Ravnborg 
5949148020SSam Ravnborg struct  fbcmap {
6049148020SSam Ravnborg         int             index;          /* first element (0 origin) */
6149148020SSam Ravnborg         int             count;
6249148020SSam Ravnborg         unsigned char   __user *red;
6349148020SSam Ravnborg         unsigned char   __user *green;
6449148020SSam Ravnborg         unsigned char   __user *blue;
6549148020SSam Ravnborg };
6649148020SSam Ravnborg 
6749148020SSam Ravnborg #ifdef __KERNEL__
6849148020SSam Ravnborg #define FBIOPUTCMAP_SPARC _IOW('F', 3, struct fbcmap)
6949148020SSam Ravnborg #define FBIOGETCMAP_SPARC _IOW('F', 4, struct fbcmap)
7049148020SSam Ravnborg #else
7149148020SSam Ravnborg #define FBIOPUTCMAP _IOW('F', 3, struct fbcmap)
7249148020SSam Ravnborg #define FBIOGETCMAP _IOW('F', 4, struct fbcmap)
7349148020SSam Ravnborg #endif
7449148020SSam Ravnborg 
7549148020SSam Ravnborg /* # of device specific values */
7649148020SSam Ravnborg #define FB_ATTR_NDEVSPECIFIC    8
7749148020SSam Ravnborg /* # of possible emulations */
7849148020SSam Ravnborg #define FB_ATTR_NEMUTYPES       4
7949148020SSam Ravnborg 
8049148020SSam Ravnborg struct fbsattr {
8149148020SSam Ravnborg         int     flags;
8249148020SSam Ravnborg         int     emu_type;	/* -1 if none */
8349148020SSam Ravnborg         int     dev_specific[FB_ATTR_NDEVSPECIFIC];
8449148020SSam Ravnborg };
8549148020SSam Ravnborg 
8649148020SSam Ravnborg struct fbgattr {
8749148020SSam Ravnborg         int     real_type;	/* real frame buffer type */
8849148020SSam Ravnborg         int     owner;		/* unknown */
8949148020SSam Ravnborg         struct fbtype fbtype;	/* real frame buffer fbtype */
9049148020SSam Ravnborg         struct fbsattr sattr;
9149148020SSam Ravnborg         int     emu_types[FB_ATTR_NEMUTYPES]; /* supported emulations */
9249148020SSam Ravnborg };
9349148020SSam Ravnborg #define FBIOSATTR  _IOW('F', 5, struct fbgattr) /* Unsupported: */
9449148020SSam Ravnborg #define FBIOGATTR  _IOR('F', 6, struct fbgattr)	/* supported */
9549148020SSam Ravnborg 
9649148020SSam Ravnborg #define FBIOSVIDEO _IOW('F', 7, int)
9749148020SSam Ravnborg #define FBIOGVIDEO _IOR('F', 8, int)
9849148020SSam Ravnborg 
9949148020SSam Ravnborg struct fbcursor {
10049148020SSam Ravnborg         short set;              /* what to set, choose from the list above */
10149148020SSam Ravnborg         short enable;           /* cursor on/off */
10249148020SSam Ravnborg         struct fbcurpos pos;    /* cursor position */
10349148020SSam Ravnborg         struct fbcurpos hot;    /* cursor hot spot */
10449148020SSam Ravnborg         struct fbcmap cmap;     /* color map info */
10549148020SSam Ravnborg         struct fbcurpos size;   /* cursor bit map size */
10649148020SSam Ravnborg         char __user *image;     /* cursor image bits */
10749148020SSam Ravnborg         char __user *mask;      /* cursor mask bits */
10849148020SSam Ravnborg };
10949148020SSam Ravnborg 
11049148020SSam Ravnborg /* set/get cursor attributes/shape */
11149148020SSam Ravnborg #define FBIOSCURSOR     _IOW('F', 24, struct fbcursor)
11249148020SSam Ravnborg #define FBIOGCURSOR     _IOWR('F', 25, struct fbcursor)
11349148020SSam Ravnborg 
11449148020SSam Ravnborg /* set/get cursor position */
11549148020SSam Ravnborg #define FBIOSCURPOS     _IOW('F', 26, struct fbcurpos)
11649148020SSam Ravnborg #define FBIOGCURPOS     _IOW('F', 27, struct fbcurpos)
11749148020SSam Ravnborg 
11849148020SSam Ravnborg /* get max cursor size */
11949148020SSam Ravnborg #define FBIOGCURMAX     _IOR('F', 28, struct fbcurpos)
12049148020SSam Ravnborg 
12149148020SSam Ravnborg /* wid manipulation */
12249148020SSam Ravnborg struct fb_wid_alloc {
12349148020SSam Ravnborg #define FB_WID_SHARED_8		0
12449148020SSam Ravnborg #define FB_WID_SHARED_24	1
12549148020SSam Ravnborg #define FB_WID_DBL_8		2
12649148020SSam Ravnborg #define FB_WID_DBL_24		3
12749148020SSam Ravnborg 	__u32	wa_type;
12849148020SSam Ravnborg 	__s32	wa_index;	/* Set on return */
12949148020SSam Ravnborg 	__u32	wa_count;
13049148020SSam Ravnborg };
13149148020SSam Ravnborg struct fb_wid_item {
13249148020SSam Ravnborg 	__u32	wi_type;
13349148020SSam Ravnborg 	__s32	wi_index;
13449148020SSam Ravnborg 	__u32	wi_attrs;
13549148020SSam Ravnborg 	__u32	wi_values[32];
13649148020SSam Ravnborg };
13749148020SSam Ravnborg struct fb_wid_list {
13849148020SSam Ravnborg 	__u32	wl_flags;
13949148020SSam Ravnborg 	__u32	wl_count;
14049148020SSam Ravnborg 	struct fb_wid_item	*wl_list;
14149148020SSam Ravnborg };
14249148020SSam Ravnborg 
14349148020SSam Ravnborg #define FBIO_WID_ALLOC	_IOWR('F', 30, struct fb_wid_alloc)
14449148020SSam Ravnborg #define FBIO_WID_FREE	_IOW('F', 31, struct fb_wid_alloc)
14549148020SSam Ravnborg #define FBIO_WID_PUT	_IOW('F', 32, struct fb_wid_list)
14649148020SSam Ravnborg #define FBIO_WID_GET	_IOWR('F', 33, struct fb_wid_list)
14749148020SSam Ravnborg 
14849148020SSam Ravnborg /* Creator ioctls */
14949148020SSam Ravnborg #define FFB_IOCTL	('F'<<8)
15049148020SSam Ravnborg #define FFB_SYS_INFO		(FFB_IOCTL|80)
15149148020SSam Ravnborg #define FFB_CLUTREAD		(FFB_IOCTL|81)
15249148020SSam Ravnborg #define FFB_CLUTPOST		(FFB_IOCTL|82)
15349148020SSam Ravnborg #define FFB_SETDIAGMODE		(FFB_IOCTL|83)
15449148020SSam Ravnborg #define FFB_GETMONITORID	(FFB_IOCTL|84)
15549148020SSam Ravnborg #define FFB_GETVIDEOMODE	(FFB_IOCTL|85)
15649148020SSam Ravnborg #define FFB_SETVIDEOMODE	(FFB_IOCTL|86)
15749148020SSam Ravnborg #define FFB_SETSERVER		(FFB_IOCTL|87)
15849148020SSam Ravnborg #define FFB_SETOVCTL		(FFB_IOCTL|88)
15949148020SSam Ravnborg #define FFB_GETOVCTL		(FFB_IOCTL|89)
16049148020SSam Ravnborg #define FFB_GETSAXNUM		(FFB_IOCTL|90)
16149148020SSam Ravnborg #define FFB_FBDEBUG		(FFB_IOCTL|91)
16249148020SSam Ravnborg 
16349148020SSam Ravnborg /* Cg14 ioctls */
16449148020SSam Ravnborg #define MDI_IOCTL          ('M'<<8)
16549148020SSam Ravnborg #define MDI_RESET          (MDI_IOCTL|1)
16649148020SSam Ravnborg #define MDI_GET_CFGINFO    (MDI_IOCTL|2)
16749148020SSam Ravnborg #define MDI_SET_PIXELMODE  (MDI_IOCTL|3)
16849148020SSam Ravnborg #    define MDI_32_PIX     32
16949148020SSam Ravnborg #    define MDI_16_PIX     16
17049148020SSam Ravnborg #    define MDI_8_PIX      8
17149148020SSam Ravnborg 
17249148020SSam Ravnborg struct mdi_cfginfo {
17349148020SSam Ravnborg 	int     mdi_ncluts;     /* Number of implemented CLUTs in this MDI */
17449148020SSam Ravnborg         int     mdi_type;       /* FBTYPE name */
17549148020SSam Ravnborg         int     mdi_height;     /* height */
176*551e378cSDaniel Mack         int     mdi_width;      /* width */
17749148020SSam Ravnborg         int     mdi_size;       /* available ram */
17849148020SSam Ravnborg         int     mdi_mode;       /* 8bpp, 16bpp or 32bpp */
17949148020SSam Ravnborg         int     mdi_pixfreq;    /* pixel clock (from PROM) */
18049148020SSam Ravnborg };
18149148020SSam Ravnborg 
18249148020SSam Ravnborg /* SparcLinux specific ioctl for the MDI, should be replaced for
18349148020SSam Ravnborg  * the SET_XLUT/SET_CLUTn ioctls instead
18449148020SSam Ravnborg  */
18549148020SSam Ravnborg #define MDI_CLEAR_XLUT       (MDI_IOCTL|9)
18649148020SSam Ravnborg 
18749148020SSam Ravnborg /* leo & ffb ioctls */
18849148020SSam Ravnborg struct fb_clut_alloc {
18949148020SSam Ravnborg 	__u32	clutid;	/* Set on return */
19049148020SSam Ravnborg  	__u32	flag;
19149148020SSam Ravnborg  	__u32	index;
19249148020SSam Ravnborg };
19349148020SSam Ravnborg 
19449148020SSam Ravnborg struct fb_clut {
19549148020SSam Ravnborg #define FB_CLUT_WAIT	0x00000001	/* Not yet implemented */
19649148020SSam Ravnborg  	__u32	flag;
19749148020SSam Ravnborg  	__u32	clutid;
19849148020SSam Ravnborg  	__u32	offset;
19949148020SSam Ravnborg  	__u32	count;
20049148020SSam Ravnborg  	char *	red;
20149148020SSam Ravnborg  	char *	green;
20249148020SSam Ravnborg  	char *	blue;
20349148020SSam Ravnborg };
20449148020SSam Ravnborg 
20549148020SSam Ravnborg struct fb_clut32 {
20649148020SSam Ravnborg  	__u32	flag;
20749148020SSam Ravnborg  	__u32	clutid;
20849148020SSam Ravnborg  	__u32	offset;
20949148020SSam Ravnborg  	__u32	count;
21049148020SSam Ravnborg  	__u32	red;
21149148020SSam Ravnborg  	__u32	green;
21249148020SSam Ravnborg  	__u32	blue;
21349148020SSam Ravnborg };
21449148020SSam Ravnborg 
21549148020SSam Ravnborg #define LEO_CLUTALLOC	_IOWR('L', 53, struct fb_clut_alloc)
21649148020SSam Ravnborg #define LEO_CLUTFREE	_IOW('L', 54, struct fb_clut_alloc)
21749148020SSam Ravnborg #define LEO_CLUTREAD	_IOW('L', 55, struct fb_clut)
21849148020SSam Ravnborg #define LEO_CLUTPOST	_IOW('L', 56, struct fb_clut)
21949148020SSam Ravnborg #define LEO_SETGAMMA	_IOW('L', 68, int) /* Not yet implemented */
22049148020SSam Ravnborg #define LEO_GETGAMMA	_IOR('L', 69, int) /* Not yet implemented */
22149148020SSam Ravnborg 
22249148020SSam Ravnborg #ifdef __KERNEL__
22349148020SSam Ravnborg /* Addresses on the fd of a cgsix that are mappable */
22449148020SSam Ravnborg #define CG6_FBC    0x70000000
22549148020SSam Ravnborg #define CG6_TEC    0x70001000
22649148020SSam Ravnborg #define CG6_BTREGS 0x70002000
22749148020SSam Ravnborg #define CG6_FHC    0x70004000
22849148020SSam Ravnborg #define CG6_THC    0x70005000
22949148020SSam Ravnborg #define CG6_ROM    0x70006000
23049148020SSam Ravnborg #define CG6_RAM    0x70016000
23149148020SSam Ravnborg #define CG6_DHC    0x80000000
23249148020SSam Ravnborg 
23349148020SSam Ravnborg #define CG3_MMAP_OFFSET 0x4000000
23449148020SSam Ravnborg 
23549148020SSam Ravnborg /* Addresses on the fd of a tcx that are mappable */
23649148020SSam Ravnborg #define TCX_RAM8BIT   		0x00000000
23749148020SSam Ravnborg #define TCX_RAM24BIT   		0x01000000
23849148020SSam Ravnborg #define TCX_UNK3   		0x10000000
23949148020SSam Ravnborg #define TCX_UNK4   		0x20000000
24049148020SSam Ravnborg #define TCX_CONTROLPLANE   	0x28000000
24149148020SSam Ravnborg #define TCX_UNK6   		0x30000000
24249148020SSam Ravnborg #define TCX_UNK7   		0x38000000
24349148020SSam Ravnborg #define TCX_TEC    		0x70000000
24449148020SSam Ravnborg #define TCX_BTREGS 		0x70002000
24549148020SSam Ravnborg #define TCX_THC    		0x70004000
24649148020SSam Ravnborg #define TCX_DHC    		0x70008000
24749148020SSam Ravnborg #define TCX_ALT	   		0x7000a000
24849148020SSam Ravnborg #define TCX_SYNC   		0x7000e000
24949148020SSam Ravnborg #define TCX_UNK2    		0x70010000
25049148020SSam Ravnborg 
25149148020SSam Ravnborg /* CG14 definitions */
25249148020SSam Ravnborg 
25349148020SSam Ravnborg /* Offsets into the OBIO space: */
25449148020SSam Ravnborg #define CG14_REGS        0       /* registers */
25549148020SSam Ravnborg #define CG14_CURSORREGS  0x1000  /* cursor registers */
25649148020SSam Ravnborg #define CG14_DACREGS     0x2000  /* DAC registers */
25749148020SSam Ravnborg #define CG14_XLUT        0x3000  /* X Look Up Table -- ??? */
25849148020SSam Ravnborg #define CG14_CLUT1       0x4000  /* Color Look Up Table */
25949148020SSam Ravnborg #define CG14_CLUT2       0x5000  /* Color Look Up Table */
26049148020SSam Ravnborg #define CG14_CLUT3       0x6000  /* Color Look Up Table */
26149148020SSam Ravnborg #define CG14_AUTO	 0xf000
26249148020SSam Ravnborg 
26349148020SSam Ravnborg #endif /* KERNEL */
26449148020SSam Ravnborg 
26549148020SSam Ravnborg /* These are exported to userland for applications to use */
26649148020SSam Ravnborg /* Mappable offsets for the cg14: control registers */
26749148020SSam Ravnborg #define MDI_DIRECT_MAP 0x10000000
26849148020SSam Ravnborg #define MDI_CTLREG_MAP 0x20000000
26949148020SSam Ravnborg #define MDI_CURSOR_MAP 0x30000000
27049148020SSam Ravnborg #define MDI_SHDW_VRT_MAP 0x40000000
27149148020SSam Ravnborg 
27249148020SSam Ravnborg /* Mappable offsets for the cg14: frame buffer resolutions */
27349148020SSam Ravnborg /* 32 bits */
27449148020SSam Ravnborg #define MDI_CHUNKY_XBGR_MAP 0x50000000
27549148020SSam Ravnborg #define MDI_CHUNKY_BGR_MAP 0x60000000
27649148020SSam Ravnborg 
27749148020SSam Ravnborg /* 16 bits */
27849148020SSam Ravnborg #define MDI_PLANAR_X16_MAP 0x70000000
27949148020SSam Ravnborg #define MDI_PLANAR_C16_MAP 0x80000000
28049148020SSam Ravnborg 
28149148020SSam Ravnborg /* 8 bit is done as CG3 MMAP offset */
28249148020SSam Ravnborg /* 32 bits, planar */
28349148020SSam Ravnborg #define MDI_PLANAR_X32_MAP 0x90000000
28449148020SSam Ravnborg #define MDI_PLANAR_B32_MAP 0xa0000000
28549148020SSam Ravnborg #define MDI_PLANAR_G32_MAP 0xb0000000
28649148020SSam Ravnborg #define MDI_PLANAR_R32_MAP 0xc0000000
28749148020SSam Ravnborg 
28849148020SSam Ravnborg /* Mappable offsets on leo */
28949148020SSam Ravnborg #define LEO_SS0_MAP            0x00000000
29049148020SSam Ravnborg #define LEO_LC_SS0_USR_MAP     0x00800000
29149148020SSam Ravnborg #define LEO_LD_SS0_MAP         0x00801000
29249148020SSam Ravnborg #define LEO_LX_CURSOR_MAP      0x00802000
29349148020SSam Ravnborg #define LEO_SS1_MAP            0x00803000
29449148020SSam Ravnborg #define LEO_LC_SS1_USR_MAP     0x01003000
29549148020SSam Ravnborg #define LEO_LD_SS1_MAP         0x01004000
29649148020SSam Ravnborg #define LEO_UNK_MAP            0x01005000
29749148020SSam Ravnborg #define LEO_LX_KRN_MAP         0x01006000
29849148020SSam Ravnborg #define LEO_LC_SS0_KRN_MAP     0x01007000
29949148020SSam Ravnborg #define LEO_LC_SS1_KRN_MAP     0x01008000
30049148020SSam Ravnborg #define LEO_LD_GBL_MAP         0x01009000
30149148020SSam Ravnborg #define LEO_UNK2_MAP           0x0100a000
30249148020SSam Ravnborg 
30349148020SSam Ravnborg #ifdef __KERNEL__
30449148020SSam Ravnborg struct  fbcmap32 {
30549148020SSam Ravnborg 	int             index;          /* first element (0 origin) */
30649148020SSam Ravnborg 	int             count;
30749148020SSam Ravnborg 	u32		red;
30849148020SSam Ravnborg 	u32		green;
30949148020SSam Ravnborg 	u32		blue;
31049148020SSam Ravnborg };
31149148020SSam Ravnborg 
31249148020SSam Ravnborg #define FBIOPUTCMAP32	_IOW('F', 3, struct fbcmap32)
31349148020SSam Ravnborg #define FBIOGETCMAP32	_IOW('F', 4, struct fbcmap32)
31449148020SSam Ravnborg 
31549148020SSam Ravnborg struct fbcursor32 {
31649148020SSam Ravnborg 	short set;		/* what to set, choose from the list above */
31749148020SSam Ravnborg 	short enable;		/* cursor on/off */
31849148020SSam Ravnborg 	struct fbcurpos pos;	/* cursor position */
31949148020SSam Ravnborg 	struct fbcurpos hot;	/* cursor hot spot */
32049148020SSam Ravnborg 	struct fbcmap32 cmap;	/* color map info */
32149148020SSam Ravnborg 	struct fbcurpos size;	/* cursor bit map size */
32249148020SSam Ravnborg 	u32	image;		/* cursor image bits */
32349148020SSam Ravnborg 	u32	mask;		/* cursor mask bits */
32449148020SSam Ravnborg };
32549148020SSam Ravnborg 
32649148020SSam Ravnborg #define FBIOSCURSOR32	_IOW('F', 24, struct fbcursor32)
32749148020SSam Ravnborg #define FBIOGCURSOR32	_IOW('F', 25, struct fbcursor32)
32849148020SSam Ravnborg #endif
32949148020SSam Ravnborg 
33049148020SSam Ravnborg #endif /* __LINUX_FBIO_H */
331