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