| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | /* | 
|  | 2 | *  linux/drivers/video/sgivw.h -- SGI DBE frame buffer device header | 
|  | 3 | * | 
|  | 4 | *      Copyright (C) 1999 Silicon Graphics, Inc. | 
|  | 5 | *      Jeffrey Newquist, newquist@engr.sgi.som | 
|  | 6 | * | 
|  | 7 | *  This file is subject to the terms and conditions of the GNU General Public | 
|  | 8 | *  License. See the file COPYING in the main directory of this archive for | 
|  | 9 | *  more details. | 
|  | 10 | */ | 
|  | 11 |  | 
|  | 12 | #ifndef __SGIVWFB_H__ | 
|  | 13 | #define __SGIVWFB_H__ | 
|  | 14 |  | 
|  | 15 | #define DBE_GETREG(reg, dest)		((dest) = DBE_REG_BASE->reg) | 
|  | 16 | #define DBE_SETREG(reg, src)		DBE_REG_BASE->reg = (src) | 
|  | 17 | #define DBE_IGETREG(reg, idx, dest)	((dest) = DBE_REG_BASE->reg[idx]) | 
|  | 18 | #define DBE_ISETREG(reg, idx, src)	(DBE_REG_BASE->reg[idx] = (src)) | 
|  | 19 |  | 
|  | 20 | #define MASK(msb, lsb)          ( (((u32)1<<((msb)-(lsb)+1))-1) << (lsb) ) | 
|  | 21 | #define GET(v, msb, lsb)        ( ((u32)(v) & MASK(msb,lsb)) >> (lsb) ) | 
|  | 22 | #define SET(v, f, msb, lsb)     ( (v) = ((v)&~MASK(msb,lsb)) | (( (u32)(f)<<(lsb) ) & MASK(msb,lsb)) ) | 
|  | 23 |  | 
|  | 24 | #define GET_DBE_FIELD(reg, field, v)        GET((v), DBE_##reg##_##field##_MSB, DBE_##reg##_##field##_LSB) | 
|  | 25 | #define SET_DBE_FIELD(reg, field, v, f)     SET((v), (f), DBE_##reg##_##field##_MSB, DBE_##reg##_##field##_LSB) | 
|  | 26 |  | 
|  | 27 | /* NOTE: All loads/stores must be 32 bits and uncached */ | 
|  | 28 |  | 
|  | 29 | #define DBE_REG_PHYS	0xd0000000 | 
|  | 30 | #define DBE_REG_SIZE        0x01000000 | 
|  | 31 |  | 
|  | 32 | struct asregs { | 
|  | 33 | volatile u32 ctrlstat;     /* 0x000000 general control */ | 
|  | 34 | volatile u32 dotclock;     /* 0x000004 dot clock PLL control */ | 
|  | 35 | volatile u32 i2c;          /* 0x000008 crt I2C control */ | 
|  | 36 | volatile u32 sysclk;       /* 0x00000c system clock PLL control */ | 
|  | 37 | volatile u32 i2cfp;        /* 0x000010 flat panel I2C control */ | 
|  | 38 | volatile u32 id;           /* 0x000014 device id/chip revision */ | 
|  | 39 | volatile u32 config;       /* 0x000018 power on configuration */ | 
|  | 40 | volatile u32 bist;         /* 0x00001c internal bist status */ | 
|  | 41 |  | 
|  | 42 | char _pad0[ 0x010000 - 0x000020 ]; | 
|  | 43 |  | 
|  | 44 | volatile u32 vt_xy;        /* 0x010000 current dot coords */ | 
|  | 45 | volatile u32 vt_xymax;     /* 0x010004 maximum dot coords */ | 
|  | 46 | volatile u32 vt_vsync;     /* 0x010008 vsync on/off */ | 
|  | 47 | volatile u32 vt_hsync;     /* 0x01000c hsync on/off */ | 
|  | 48 | volatile u32 vt_vblank;    /* 0x010010 vblank on/off */ | 
|  | 49 | volatile u32 vt_hblank;    /* 0x010014 hblank on/off */ | 
|  | 50 | volatile u32 vt_flags;     /* 0x010018 polarity of vt signals */ | 
|  | 51 | volatile u32 vt_f2rf_lock; /* 0x01001c f2rf & framelck y coord */ | 
|  | 52 | volatile u32 vt_intr01;    /* 0x010020 intr 0,1 y coords */ | 
|  | 53 | volatile u32 vt_intr23;    /* 0x010024 intr 2,3 y coords */ | 
|  | 54 | volatile u32 fp_hdrv;      /* 0x010028 flat panel hdrv on/off */ | 
|  | 55 | volatile u32 fp_vdrv;      /* 0x01002c flat panel vdrv on/off */ | 
|  | 56 | volatile u32 fp_de;        /* 0x010030 flat panel de on/off */ | 
|  | 57 | volatile u32 vt_hpixen;    /* 0x010034 intrnl horiz pixel on/off*/ | 
|  | 58 | volatile u32 vt_vpixen;    /* 0x010038 intrnl vert pixel on/off */ | 
|  | 59 | volatile u32 vt_hcmap;     /* 0x01003c cmap write (horiz) */ | 
|  | 60 | volatile u32 vt_vcmap;     /* 0x010040 cmap write (vert) */ | 
|  | 61 | volatile u32 did_start_xy; /* 0x010044 eol/f did/xy reset val */ | 
|  | 62 | volatile u32 crs_start_xy; /* 0x010048 eol/f crs/xy reset val */ | 
|  | 63 | volatile u32 vc_start_xy;  /* 0x01004c eol/f vc/xy reset val */ | 
|  | 64 |  | 
|  | 65 | char _pad1[ 0x020000 - 0x010050 ]; | 
|  | 66 |  | 
|  | 67 | volatile u32 ovr_width_tile; /* 0x020000 overlay plane ctrl 0 */ | 
|  | 68 | volatile u32 ovr_inhwctrl;   /* 0x020004 overlay plane ctrl 1 */ | 
|  | 69 | volatile u32 ovr_control;    /* 0x020008 overlay plane ctrl 1 */ | 
|  | 70 |  | 
|  | 71 | char _pad2[ 0x030000 - 0x02000C ]; | 
|  | 72 |  | 
|  | 73 | volatile u32 frm_size_tile;  /* 0x030000 normal plane ctrl 0 */ | 
|  | 74 | volatile u32 frm_size_pixel; /* 0x030004 normal plane ctrl 1 */ | 
|  | 75 | volatile u32 frm_inhwctrl;   /* 0x030008 normal plane ctrl 2 */ | 
|  | 76 | volatile u32 frm_control;	   /* 0x03000C normal plane ctrl 3 */ | 
|  | 77 |  | 
|  | 78 | char _pad3[ 0x040000 - 0x030010 ]; | 
|  | 79 |  | 
|  | 80 | volatile u32 did_inhwctrl;   /* 0x040000 DID control */ | 
|  | 81 | volatile u32 did_control;    /* 0x040004 DID shadow */ | 
|  | 82 |  | 
|  | 83 | char _pad4[ 0x048000 - 0x040008 ]; | 
|  | 84 |  | 
|  | 85 | volatile u32 mode_regs[32];  /* 0x048000 - 0x04807c WID table */ | 
|  | 86 |  | 
|  | 87 | char _pad5[ 0x050000 - 0x048080 ]; | 
|  | 88 |  | 
|  | 89 | volatile u32 cmap[6144];     /* 0x050000 - 0x055ffc color map */ | 
|  | 90 |  | 
|  | 91 | char _pad6[ 0x058000 - 0x056000 ]; | 
|  | 92 |  | 
|  | 93 | volatile u32 cm_fifo;        /* 0x058000 color map fifo status */ | 
|  | 94 |  | 
|  | 95 | char _pad7[ 0x060000 - 0x058004 ]; | 
|  | 96 |  | 
|  | 97 | volatile u32 gmap[256];      /* 0x060000 - 0x0603fc gamma map */ | 
|  | 98 |  | 
|  | 99 | char _pad8[ 0x068000 - 0x060400 ]; | 
|  | 100 |  | 
|  | 101 | volatile u32 gmap10[1024];   /* 0x068000 - 0x068ffc gamma map */ | 
|  | 102 |  | 
|  | 103 | char _pad9[ 0x070000 - 0x069000 ]; | 
|  | 104 |  | 
|  | 105 | volatile u32 crs_pos;        /* 0x070000 cusror control 0 */ | 
|  | 106 | volatile u32 crs_ctl;        /* 0x070004 cusror control 1 */ | 
|  | 107 | volatile u32 crs_cmap[3];    /* 0x070008 - 0x070010 crs cmap */ | 
|  | 108 |  | 
|  | 109 | char _pad10[ 0x078000 - 0x070014 ]; | 
|  | 110 |  | 
|  | 111 | volatile u32 crs_glyph[64];  /* 0x078000 - 0x0780fc crs glyph */ | 
|  | 112 |  | 
|  | 113 | char _pad11[ 0x080000 - 0x078100 ]; | 
|  | 114 |  | 
|  | 115 | volatile u32 vc_0;           /* 0x080000 video capture crtl 0 */ | 
|  | 116 | volatile u32 vc_1;           /* 0x080004 video capture crtl 1 */ | 
|  | 117 | volatile u32 vc_2;           /* 0x080008 video capture crtl 2 */ | 
|  | 118 | volatile u32 vc_3;           /* 0x08000c video capture crtl 3 */ | 
|  | 119 | volatile u32 vc_4;           /* 0x080010 video capture crtl 3 */ | 
|  | 120 | volatile u32 vc_5;           /* 0x080014 video capture crtl 3 */ | 
|  | 121 | volatile u32 vc_6;           /* 0x080018 video capture crtl 3 */ | 
|  | 122 | volatile u32 vc_7;           /* 0x08001c video capture crtl 3 */ | 
|  | 123 | volatile u32 vc_8;           /* 0x08000c video capture crtl 3 */ | 
|  | 124 | }; | 
|  | 125 |  | 
|  | 126 | /* Bit mask information */ | 
|  | 127 |  | 
|  | 128 | #define DBE_CTRLSTAT_CHIPID_MSB     3 | 
|  | 129 | #define DBE_CTRLSTAT_CHIPID_LSB     0 | 
|  | 130 | #define DBE_CTRLSTAT_SENSE_N_MSB    4 | 
|  | 131 | #define DBE_CTRLSTAT_SENSE_N_LSB    4 | 
|  | 132 | #define DBE_CTRLSTAT_PCLKSEL_MSB    29 | 
|  | 133 | #define DBE_CTRLSTAT_PCLKSEL_LSB    28 | 
|  | 134 |  | 
|  | 135 | #define DBE_DOTCLK_M_MSB            7 | 
|  | 136 | #define DBE_DOTCLK_M_LSB            0 | 
|  | 137 | #define DBE_DOTCLK_N_MSB            13 | 
|  | 138 | #define DBE_DOTCLK_N_LSB            8 | 
|  | 139 | #define DBE_DOTCLK_P_MSB            15 | 
|  | 140 | #define DBE_DOTCLK_P_LSB            14 | 
|  | 141 | #define DBE_DOTCLK_RUN_MSB          20 | 
|  | 142 | #define DBE_DOTCLK_RUN_LSB          20 | 
|  | 143 |  | 
|  | 144 | #define DBE_VT_XY_VT_FREEZE_MSB     31 | 
|  | 145 | #define DBE_VT_XY_VT_FREEZE_LSB     31 | 
|  | 146 |  | 
|  | 147 | #define DBE_FP_VDRV_FP_VDRV_ON_MSB	23 | 
|  | 148 | #define DBE_FP_VDRV_FP_VDRV_ON_LSB	12 | 
|  | 149 | #define DBE_FP_VDRV_FP_VDRV_OFF_MSB	11 | 
|  | 150 | #define DBE_FP_VDRV_FP_VDRV_OFF_LSB	0 | 
|  | 151 |  | 
|  | 152 | #define DBE_FP_HDRV_FP_HDRV_ON_MSB	23 | 
|  | 153 | #define DBE_FP_HDRV_FP_HDRV_ON_LSB	12 | 
|  | 154 | #define DBE_FP_HDRV_FP_HDRV_OFF_MSB	11 | 
|  | 155 | #define DBE_FP_HDRV_FP_HDRV_OFF_LSB	0 | 
|  | 156 |  | 
|  | 157 | #define DBE_FP_DE_FP_DE_ON_MSB		23 | 
|  | 158 | #define DBE_FP_DE_FP_DE_ON_LSB		12 | 
|  | 159 | #define DBE_FP_DE_FP_DE_OFF_MSB		11 | 
|  | 160 | #define DBE_FP_DE_FP_DE_OFF_LSB		0 | 
|  | 161 |  | 
|  | 162 | #define DBE_VT_VSYNC_VT_VSYNC_ON_MSB        23 | 
|  | 163 | #define DBE_VT_VSYNC_VT_VSYNC_ON_LSB        12 | 
|  | 164 | #define DBE_VT_VSYNC_VT_VSYNC_OFF_MSB       11 | 
|  | 165 | #define DBE_VT_VSYNC_VT_VSYNC_OFF_LSB       0 | 
|  | 166 |  | 
|  | 167 | #define DBE_VT_HSYNC_VT_HSYNC_ON_MSB        23 | 
|  | 168 | #define DBE_VT_HSYNC_VT_HSYNC_ON_LSB        12 | 
|  | 169 | #define DBE_VT_HSYNC_VT_HSYNC_OFF_MSB       11 | 
|  | 170 | #define DBE_VT_HSYNC_VT_HSYNC_OFF_LSB       0 | 
|  | 171 |  | 
|  | 172 | #define DBE_VT_VBLANK_VT_VBLANK_ON_MSB        23 | 
|  | 173 | #define DBE_VT_VBLANK_VT_VBLANK_ON_LSB        12 | 
|  | 174 | #define DBE_VT_VBLANK_VT_VBLANK_OFF_MSB       11 | 
|  | 175 | #define DBE_VT_VBLANK_VT_VBLANK_OFF_LSB       0 | 
|  | 176 |  | 
|  | 177 | #define DBE_VT_HBLANK_VT_HBLANK_ON_MSB        23 | 
|  | 178 | #define DBE_VT_HBLANK_VT_HBLANK_ON_LSB        12 | 
|  | 179 | #define DBE_VT_HBLANK_VT_HBLANK_OFF_MSB       11 | 
|  | 180 | #define DBE_VT_HBLANK_VT_HBLANK_OFF_LSB       0 | 
|  | 181 |  | 
|  | 182 | #define DBE_VT_FLAGS_VDRV_INVERT_MSB		0 | 
|  | 183 | #define DBE_VT_FLAGS_VDRV_INVERT_LSB		0 | 
|  | 184 | #define DBE_VT_FLAGS_HDRV_INVERT_MSB		2 | 
|  | 185 | #define DBE_VT_FLAGS_HDRV_INVERT_LSB		2 | 
|  | 186 |  | 
|  | 187 | #define DBE_VT_VCMAP_VT_VCMAP_ON_MSB        23 | 
|  | 188 | #define DBE_VT_VCMAP_VT_VCMAP_ON_LSB        12 | 
|  | 189 | #define DBE_VT_VCMAP_VT_VCMAP_OFF_MSB       11 | 
|  | 190 | #define DBE_VT_VCMAP_VT_VCMAP_OFF_LSB       0 | 
|  | 191 |  | 
|  | 192 | #define DBE_VT_HCMAP_VT_HCMAP_ON_MSB        23 | 
|  | 193 | #define DBE_VT_HCMAP_VT_HCMAP_ON_LSB        12 | 
|  | 194 | #define DBE_VT_HCMAP_VT_HCMAP_OFF_MSB       11 | 
|  | 195 | #define DBE_VT_HCMAP_VT_HCMAP_OFF_LSB       0 | 
|  | 196 |  | 
|  | 197 | #define DBE_VT_XYMAX_VT_MAXX_MSB    11 | 
|  | 198 | #define DBE_VT_XYMAX_VT_MAXX_LSB    0 | 
|  | 199 | #define DBE_VT_XYMAX_VT_MAXY_MSB    23 | 
|  | 200 | #define DBE_VT_XYMAX_VT_MAXY_LSB    12 | 
|  | 201 |  | 
|  | 202 | #define DBE_VT_HPIXEN_VT_HPIXEN_ON_MSB      23 | 
|  | 203 | #define DBE_VT_HPIXEN_VT_HPIXEN_ON_LSB      12 | 
|  | 204 | #define DBE_VT_HPIXEN_VT_HPIXEN_OFF_MSB     11 | 
|  | 205 | #define DBE_VT_HPIXEN_VT_HPIXEN_OFF_LSB     0 | 
|  | 206 |  | 
|  | 207 | #define DBE_VT_VPIXEN_VT_VPIXEN_ON_MSB      23 | 
|  | 208 | #define DBE_VT_VPIXEN_VT_VPIXEN_ON_LSB      12 | 
|  | 209 | #define DBE_VT_VPIXEN_VT_VPIXEN_OFF_MSB     11 | 
|  | 210 | #define DBE_VT_VPIXEN_VT_VPIXEN_OFF_LSB     0 | 
|  | 211 |  | 
|  | 212 | #define DBE_OVR_CONTROL_OVR_DMA_ENABLE_MSB  0 | 
|  | 213 | #define DBE_OVR_CONTROL_OVR_DMA_ENABLE_LSB  0 | 
|  | 214 |  | 
|  | 215 | #define DBE_OVR_INHWCTRL_OVR_DMA_ENABLE_MSB 0 | 
|  | 216 | #define DBE_OVR_INHWCTRL_OVR_DMA_ENABLE_LSB 0 | 
|  | 217 |  | 
|  | 218 | #define DBE_OVR_WIDTH_TILE_OVR_FIFO_RESET_MSB       13 | 
|  | 219 | #define DBE_OVR_WIDTH_TILE_OVR_FIFO_RESET_LSB       13 | 
|  | 220 |  | 
|  | 221 | #define DBE_FRM_CONTROL_FRM_DMA_ENABLE_MSB  0 | 
|  | 222 | #define DBE_FRM_CONTROL_FRM_DMA_ENABLE_LSB  0 | 
|  | 223 | #define DBE_FRM_CONTROL_FRM_TILE_PTR_MSB    31 | 
|  | 224 | #define DBE_FRM_CONTROL_FRM_TILE_PTR_LSB    9 | 
|  | 225 | #define DBE_FRM_CONTROL_FRM_LINEAR_MSB      1 | 
|  | 226 | #define DBE_FRM_CONTROL_FRM_LINEAR_LSB      1 | 
|  | 227 |  | 
|  | 228 | #define DBE_FRM_INHWCTRL_FRM_DMA_ENABLE_MSB 0 | 
|  | 229 | #define DBE_FRM_INHWCTRL_FRM_DMA_ENABLE_LSB 0 | 
|  | 230 |  | 
|  | 231 | #define DBE_FRM_SIZE_TILE_FRM_WIDTH_TILE_MSB        12 | 
|  | 232 | #define DBE_FRM_SIZE_TILE_FRM_WIDTH_TILE_LSB        5 | 
|  | 233 | #define DBE_FRM_SIZE_TILE_FRM_RHS_MSB       4 | 
|  | 234 | #define DBE_FRM_SIZE_TILE_FRM_RHS_LSB       0 | 
|  | 235 | #define DBE_FRM_SIZE_TILE_FRM_DEPTH_MSB     14 | 
|  | 236 | #define DBE_FRM_SIZE_TILE_FRM_DEPTH_LSB     13 | 
|  | 237 | #define DBE_FRM_SIZE_TILE_FRM_FIFO_RESET_MSB        15 | 
|  | 238 | #define DBE_FRM_SIZE_TILE_FRM_FIFO_RESET_LSB        15 | 
|  | 239 |  | 
|  | 240 | #define DBE_FRM_SIZE_PIXEL_FB_HEIGHT_PIX_MSB        31 | 
|  | 241 | #define DBE_FRM_SIZE_PIXEL_FB_HEIGHT_PIX_LSB        16 | 
|  | 242 |  | 
|  | 243 | #define DBE_DID_CONTROL_DID_DMA_ENABLE_MSB  0 | 
|  | 244 | #define DBE_DID_CONTROL_DID_DMA_ENABLE_LSB  0 | 
|  | 245 | #define DBE_DID_INHWCTRL_DID_DMA_ENABLE_MSB 0 | 
|  | 246 | #define DBE_DID_INHWCTRL_DID_DMA_ENABLE_LSB 0 | 
|  | 247 |  | 
|  | 248 | #define DBE_DID_START_XY_DID_STARTY_MSB     23 | 
|  | 249 | #define DBE_DID_START_XY_DID_STARTY_LSB     12 | 
|  | 250 | #define DBE_DID_START_XY_DID_STARTX_MSB     11 | 
|  | 251 | #define DBE_DID_START_XY_DID_STARTX_LSB     0 | 
|  | 252 |  | 
|  | 253 | #define DBE_CRS_START_XY_CRS_STARTY_MSB     23 | 
|  | 254 | #define DBE_CRS_START_XY_CRS_STARTY_LSB     12 | 
|  | 255 | #define DBE_CRS_START_XY_CRS_STARTX_MSB     11 | 
|  | 256 | #define DBE_CRS_START_XY_CRS_STARTX_LSB     0 | 
|  | 257 |  | 
|  | 258 | #define DBE_WID_TYP_MSB     4 | 
|  | 259 | #define DBE_WID_TYP_LSB     2 | 
|  | 260 | #define DBE_WID_BUF_MSB     1 | 
|  | 261 | #define DBE_WID_BUF_LSB     0 | 
|  | 262 |  | 
|  | 263 | #define DBE_VC_START_XY_VC_STARTY_MSB       23 | 
|  | 264 | #define DBE_VC_START_XY_VC_STARTY_LSB       12 | 
|  | 265 | #define DBE_VC_START_XY_VC_STARTX_MSB       11 | 
|  | 266 | #define DBE_VC_START_XY_VC_STARTX_LSB       0 | 
|  | 267 |  | 
|  | 268 | /* Constants */ | 
|  | 269 |  | 
|  | 270 | #define DBE_FRM_DEPTH_8     0 | 
|  | 271 | #define DBE_FRM_DEPTH_16    1 | 
|  | 272 | #define DBE_FRM_DEPTH_32    2 | 
|  | 273 |  | 
|  | 274 | #define DBE_CMODE_I8        0 | 
|  | 275 | #define DBE_CMODE_I12       1 | 
|  | 276 | #define DBE_CMODE_RG3B2     2 | 
|  | 277 | #define DBE_CMODE_RGB4      3 | 
|  | 278 | #define DBE_CMODE_ARGB5     4 | 
|  | 279 | #define DBE_CMODE_RGB8      5 | 
|  | 280 | #define DBE_CMODE_RGBA5     6 | 
|  | 281 | #define DBE_CMODE_RGB10     7 | 
|  | 282 |  | 
|  | 283 | #define DBE_BMODE_BOTH      3 | 
|  | 284 |  | 
|  | 285 | #define DBE_CRS_MAGIC       54 | 
|  | 286 |  | 
|  | 287 | #define DBE_CLOCK_REF_KHZ	27000 | 
|  | 288 |  | 
|  | 289 | /* Config Register (DBE Only) Definitions */ | 
|  | 290 |  | 
|  | 291 | #define DBE_CONFIG_VDAC_ENABLE       0x00000001 | 
|  | 292 | #define DBE_CONFIG_VDAC_GSYNC        0x00000002 | 
|  | 293 | #define DBE_CONFIG_VDAC_PBLANK       0x00000004 | 
|  | 294 | #define DBE_CONFIG_FPENABLE          0x00000008 | 
|  | 295 | #define DBE_CONFIG_LENDIAN           0x00000020 | 
|  | 296 | #define DBE_CONFIG_TILEHIST          0x00000040 | 
|  | 297 | #define DBE_CONFIG_EXT_ADDR          0x00000080 | 
|  | 298 |  | 
|  | 299 | #define DBE_CONFIG_FBDEV        ( DBE_CONFIG_VDAC_ENABLE | \ | 
|  | 300 | DBE_CONFIG_VDAC_GSYNC  | \ | 
|  | 301 | DBE_CONFIG_VDAC_PBLANK | \ | 
|  | 302 | DBE_CONFIG_LENDIAN     | \ | 
|  | 303 | DBE_CONFIG_EXT_ADDR ) | 
|  | 304 |  | 
|  | 305 | /* | 
|  | 306 | * Available Video Timings and Corresponding Indices | 
|  | 307 | */ | 
|  | 308 |  | 
|  | 309 | typedef enum { | 
|  | 310 | DBE_VT_640_480_60, | 
|  | 311 |  | 
|  | 312 | DBE_VT_800_600_60, | 
|  | 313 | DBE_VT_800_600_75, | 
|  | 314 | DBE_VT_800_600_120, | 
|  | 315 |  | 
|  | 316 | DBE_VT_1024_768_50, | 
|  | 317 | DBE_VT_1024_768_60, | 
|  | 318 | DBE_VT_1024_768_75, | 
|  | 319 | DBE_VT_1024_768_85, | 
|  | 320 | DBE_VT_1024_768_120, | 
|  | 321 |  | 
|  | 322 | DBE_VT_1280_1024_50, | 
|  | 323 | DBE_VT_1280_1024_60, | 
|  | 324 | DBE_VT_1280_1024_75, | 
|  | 325 | DBE_VT_1280_1024_85, | 
|  | 326 |  | 
|  | 327 | DBE_VT_1600_1024_53, | 
|  | 328 | DBE_VT_1600_1024_60, | 
|  | 329 |  | 
|  | 330 | DBE_VT_1600_1200_50, | 
|  | 331 | DBE_VT_1600_1200_60, | 
|  | 332 | DBE_VT_1600_1200_75, | 
|  | 333 |  | 
|  | 334 | DBE_VT_1920_1080_50, | 
|  | 335 | DBE_VT_1920_1080_60, | 
|  | 336 | DBE_VT_1920_1080_72, | 
|  | 337 |  | 
|  | 338 | DBE_VT_1920_1200_50, | 
|  | 339 | DBE_VT_1920_1200_60, | 
|  | 340 | DBE_VT_1920_1200_66, | 
|  | 341 |  | 
|  | 342 | DBE_VT_UNKNOWN | 
|  | 343 | } dbe_timing_t; | 
|  | 344 |  | 
|  | 345 |  | 
|  | 346 |  | 
|  | 347 | /* | 
|  | 348 | * Crime Video Timing Data Structure | 
|  | 349 | */ | 
|  | 350 |  | 
|  | 351 | struct dbe_timing_info | 
|  | 352 | { | 
|  | 353 | dbe_timing_t type; | 
| Thiago Farina | 96c085d | 2009-11-01 16:47:35 -0500 | [diff] [blame] | 354 | int flags; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 355 | short width;		    /* Monitor resolution		*/ | 
|  | 356 | short height; | 
|  | 357 | int fields_sec;	    /* fields/sec  (Hz -3 dec. places */ | 
|  | 358 | int cfreq;		    /* pixel clock frequency (MHz -3 dec. places) */ | 
|  | 359 | short htotal;		    /* Horizontal total pixels	*/ | 
|  | 360 | short hblank_start;	    /* Horizontal blank start	*/ | 
|  | 361 | short hblank_end;	    /* Horizontal blank end		*/ | 
|  | 362 | short hsync_start;	    /* Horizontal sync start	*/ | 
|  | 363 | short hsync_end;	    /* Horizontal sync end		*/ | 
|  | 364 | short vtotal;		    /* Vertical total lines		*/ | 
|  | 365 | short vblank_start;	    /* Vertical blank start		*/ | 
|  | 366 | short vblank_end;	    /* Vertical blank end		*/ | 
|  | 367 | short vsync_start;	    /* Vertical sync start		*/ | 
|  | 368 | short vsync_end;	    /* Vertical sync end		*/ | 
|  | 369 | short pll_m;		    /* PLL M parameter		*/ | 
|  | 370 | short pll_n;		    /* PLL P parameter		*/ | 
|  | 371 | short pll_p;		    /* PLL N parameter		*/ | 
|  | 372 | }; | 
|  | 373 |  | 
|  | 374 | /* Defines for dbe_vof_info_t flags */ | 
|  | 375 |  | 
|  | 376 | #define DBE_VOF_UNKNOWNMON    1 | 
|  | 377 | #define DBE_VOF_STEREO        2 | 
|  | 378 | #define DBE_VOF_DO_GENSYNC    4          /* enable incoming sync */ | 
|  | 379 | #define DBE_VOF_SYNC_ON_GREEN 8          /* sync on green */ | 
|  | 380 | #define DBE_VOF_FLATPANEL     0x1000     /* FLATPANEL Timing */ | 
|  | 381 | #define DBE_VOF_MAGICKEY      0x2000     /* Backdoor key */ | 
|  | 382 |  | 
|  | 383 | /* | 
|  | 384 | * DBE Timing Tables | 
|  | 385 | */ | 
|  | 386 |  | 
|  | 387 | #ifdef INCLUDE_TIMING_TABLE_DATA | 
|  | 388 | struct dbe_timing_info dbeVTimings[] = { | 
|  | 389 | { | 
|  | 390 | DBE_VT_640_480_60, | 
|  | 391 | /*	flags,	width,			height,		fields_sec,		cfreq */ | 
| Thiago Farina | 96c085d | 2009-11-01 16:47:35 -0500 | [diff] [blame] | 392 | 0,	        640,			480,		59940,			25175, | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 393 | /*	htotal,	hblank_start,	hblank_end,	hsync_start,	hsync_end */ | 
| Thiago Farina | 96c085d | 2009-11-01 16:47:35 -0500 | [diff] [blame] | 394 | 800,	640,		        800,		656,		752, | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 395 | /*	vtotal,	vblank_start,	vblank_end,	vsync_start,	vsync_end */ | 
| Thiago Farina | 96c085d | 2009-11-01 16:47:35 -0500 | [diff] [blame] | 396 | 525,	480,		        525,		490,		    492, | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 397 | /*	pll_m,	pll_n,			pll_p */ | 
|  | 398 | 15,	    2,				3 | 
|  | 399 | }, | 
|  | 400 |  | 
|  | 401 | { | 
|  | 402 | DBE_VT_800_600_60, | 
|  | 403 | /*	flags,	width,			height,		fields_sec,		cfreq */ | 
|  | 404 | 0,	    800,			600,		60317,			40000, | 
|  | 405 | /*	htotal,	hblank_start,	hblank_end,	hsync_start,	hsync_end */ | 
|  | 406 | 1056,	800,		    1056,		840,		    968, | 
|  | 407 | /*	vtotal,	vblank_start,	vblank_end,	vsync_start,	vsync_end */ | 
|  | 408 | 628,	600,		    628,		601,		    605, | 
|  | 409 | /*	pll_m,	pll_n,			pll_p */ | 
|  | 410 | 3,	    1,				1 | 
|  | 411 | }, | 
|  | 412 |  | 
|  | 413 | { | 
|  | 414 | DBE_VT_800_600_75, | 
|  | 415 | /*	flags,	width,		    height,		fields_sec,	    cfreq */ | 
|  | 416 | 0,	    800,		    600,		75000,		    49500, | 
|  | 417 | /*	htotal,	hblank_start,	hblank_end,	hsync_start,	hsync_end */ | 
|  | 418 | 1056,	800,		    1056,		816,		    896, | 
|  | 419 | /*	vtotal,	vblank_start,	vblank_end,	vsync_start,	vsync_end */ | 
|  | 420 | 625,	600,		    625,		601,		    604, | 
|  | 421 | /*	pll_m,	pll_n,		    pll_p */ | 
|  | 422 | 11,	    3,		        1 | 
|  | 423 | }, | 
|  | 424 |  | 
|  | 425 | { | 
|  | 426 | DBE_VT_800_600_120, | 
|  | 427 | /*	flags,					width,		height,			fields_sec,	    cfreq */ | 
|  | 428 | DBE_VOF_STEREO,	    800,		600,			119800,		    82978, | 
|  | 429 | /*	htotal,	hblank_start,	hblank_end,	hsync_start,	hsync_end */ | 
|  | 430 | 1040,	800,		    1040,		856,		    976, | 
|  | 431 | /*	vtotal,	vblank_start,	vblank_end,	vsync_start,	vsync_end */ | 
|  | 432 | 666,	600,		    666,		637,		    643, | 
|  | 433 | /*	pll_m,	pll_n,		    pll_p */ | 
|  | 434 | 31,	    5,		        1 | 
|  | 435 | }, | 
|  | 436 |  | 
|  | 437 | { | 
|  | 438 | DBE_VT_1024_768_50, | 
|  | 439 | /*	flags,	width,		    height,		fields_sec,	    cfreq */ | 
|  | 440 | 0,	    1024,		    768,		50000,		    54163, | 
|  | 441 | /*	htotal,	hblank_start,	hblank_end,	hsync_start,	hsync_end */ | 
|  | 442 | 1344,	1024,		    1344,		1048,		    1184, | 
|  | 443 | /*	vtotal,	vblank_start,	vblank_end,	vsync_start,	vsync_end */ | 
|  | 444 | 806,	768,		    806,		771,		    777, | 
|  | 445 | /*	pll_m,	pll_n,		    pll_p */ | 
|  | 446 | 4,	    1,		        1 | 
|  | 447 | }, | 
|  | 448 |  | 
|  | 449 | { | 
|  | 450 | DBE_VT_1024_768_60, | 
|  | 451 | /*	flags,	width,			height,		fields_sec,		cfreq */ | 
|  | 452 | 0,	    1024,			768,		60004,			65000, | 
|  | 453 | /*	htotal,	hblank_start,	hblank_end,	hsync_start,	hsync_end */ | 
|  | 454 | 1344,	1024,		    1344,		1048,		    1184, | 
|  | 455 | /*	vtotal,	vblank_start,	vblank_end,	vsync_start,	vsync_end */ | 
|  | 456 | 806,	768,		    806,		771,		    777, | 
|  | 457 | /*	pll_m,	pll_n,			pll_p */ | 
|  | 458 | 12,	    5,				0 | 
|  | 459 | }, | 
|  | 460 |  | 
|  | 461 | { | 
|  | 462 | DBE_VT_1024_768_75, | 
|  | 463 | /*	flags,	width,			height,		fields_sec,		cfreq */ | 
|  | 464 | 0,	    1024,			768,		75029,			78750, | 
|  | 465 | /*	htotal,	hblank_start,	hblank_end,	hsync_start,	hsync_end */ | 
|  | 466 | 1312,	1024,		    1312,		1040,		    1136, | 
|  | 467 | /*	vtotal,	vblank_start,	vblank_end,	vsync_start,	vsync_end */ | 
|  | 468 | 800,	768,		    800,		769,		    772, | 
|  | 469 | /*	pll_m,	pll_n,			pll_p */ | 
|  | 470 | 29,	    5,				1 | 
|  | 471 | }, | 
|  | 472 |  | 
|  | 473 | { | 
|  | 474 | DBE_VT_1024_768_85, | 
|  | 475 | /*	flags,	width,			height,		fields_sec,		cfreq */ | 
|  | 476 | 0,	    1024,			768,		84997,			94500, | 
|  | 477 | /*	htotal,	hblank_start,	hblank_end,	hsync_start,	hsync_end */ | 
|  | 478 | 1376,	1024,		    1376,		1072,		    1168, | 
|  | 479 | /*	vtotal,	vblank_start,	vblank_end,	vsync_start,	vsync_end */ | 
|  | 480 | 808,	768,		    808,		769,		    772, | 
|  | 481 | /*	pll_m,	pll_n,			pll_p */ | 
|  | 482 | 7,	    2,				0 | 
|  | 483 | }, | 
|  | 484 |  | 
|  | 485 | { | 
|  | 486 | DBE_VT_1024_768_120, | 
|  | 487 | /*	flags,					width,		height,			fields_sec,		cfreq */ | 
|  | 488 | DBE_VOF_STEREO,	    1024,		768,			119800,			133195, | 
|  | 489 | /*	htotal,	hblank_start,	hblank_end,	hsync_start,	hsync_end */ | 
|  | 490 | 1376,	1024,		    1376,		1072,		    1168, | 
|  | 491 | /*	vtotal,	vblank_start,	vblank_end,	vsync_start,	vsync_end */ | 
|  | 492 | 808,	768,		    808,		769,		    772, | 
|  | 493 | /*	pll_m,	pll_n,			pll_p */ | 
|  | 494 | 5,	    1,				0 | 
|  | 495 | }, | 
|  | 496 |  | 
|  | 497 | { | 
|  | 498 | DBE_VT_1280_1024_50, | 
|  | 499 | /*	flags,	width,			height,		fields_sec,		cfreq */ | 
|  | 500 | 0,	    1280,			1024,		50000,			89460, | 
|  | 501 | /*	htotal,	hblank_start,	hblank_end,	hsync_start,	hsync_end */ | 
|  | 502 | 1680,	1280,		    1680,		1360,		    1480, | 
|  | 503 | /*	vtotal,	vblank_start,	vblank_end,	vsync_start,	vsync_end */ | 
|  | 504 | 1065,	1024,		    1065,		1027,		    1030, | 
|  | 505 | /*	pll_m,	pll_n,			pll_p */ | 
|  | 506 | 10,	    3,				0 | 
|  | 507 | }, | 
|  | 508 |  | 
|  | 509 | { | 
|  | 510 | DBE_VT_1280_1024_60, | 
|  | 511 | /*	flags,	width,			height,		fields_sec,		cfreq */ | 
|  | 512 | 0,	    1280,			1024,		60020,			108000, | 
|  | 513 | /*	htotal,	hblank_start,	hblank_end,	hsync_start,	hsync_end */ | 
|  | 514 | 1688,	1280,		    1688,		1328,		    1440, | 
|  | 515 | /*	vtotal,	vblank_start,	vblank_end,	vsync_start,	vsync_end */ | 
|  | 516 | 1066,	1024,		    1066,		1025,		    1028, | 
|  | 517 | /*	pll_m,	pll_n,			pll_p */ | 
|  | 518 | 4,	    1,			    0 | 
|  | 519 | }, | 
|  | 520 |  | 
|  | 521 | { | 
|  | 522 | DBE_VT_1280_1024_75, | 
|  | 523 | /*	flags,	width,			height,		fields_sec,		cfreq */ | 
|  | 524 | 0,	    1280,			1024,		75025,			135000, | 
|  | 525 | /*	htotal,	hblank_start,	hblank_end,	hsync_start,	hsync_end */ | 
|  | 526 | 1688,	1280,		    1688,		1296,		    1440, | 
|  | 527 | /*	vtotal,	vblank_start,	vblank_end,	vsync_start,	vsync_end */ | 
|  | 528 | 1066,	1024,		    1066,		1025,		    1028, | 
|  | 529 | /*	pll_m,	pll_n,			pll_p */ | 
|  | 530 | 5,	    1,				0 | 
|  | 531 | }, | 
|  | 532 |  | 
|  | 533 | { | 
|  | 534 | DBE_VT_1280_1024_85, | 
|  | 535 | /*	flags,	width,		    height,		fields_sec,	    cfreq */ | 
|  | 536 | 0,	    1280,		    1024,		85024,		    157500, | 
|  | 537 | /*	htotal,	hblank_start,	hblank_end,	hsync_start,	hsync_end */ | 
|  | 538 | 1728,	1280,		    1728,		1344,		    1504, | 
|  | 539 | /*	vtotal,	vblank_start,	vblank_end,	vsync_start,	vsync_end */ | 
|  | 540 | 1072,	1024,		    1072,		1025,		    1028, | 
|  | 541 | /*	pll_m,	pll_n,		    pll_p */ | 
|  | 542 | 29,	    5,		        0 | 
|  | 543 | }, | 
|  | 544 |  | 
|  | 545 | { | 
|  | 546 | DBE_VT_1600_1024_53, | 
|  | 547 | /* flags,	width,			height,		fields_sec,     cfreq */ | 
|  | 548 | DBE_VOF_FLATPANEL | DBE_VOF_MAGICKEY, | 
|  | 549 | 1600,			1024,		53000,			107447, | 
|  | 550 | /* htotal, hblank_start,   hblank_end,     hsync_start,    hsync_end */ | 
|  | 551 | 1900,   1600,           1900,           1630,           1730, | 
|  | 552 | /* vtotal, vblank_start,   vblank_end,     vsync_start,    vsync_end */ | 
|  | 553 | 1067,   1024,           1067,           1027,           1030, | 
|  | 554 | /* pll_m,  pll_n,          pll_p */ | 
|  | 555 | 4,      1,              0 | 
|  | 556 | }, | 
|  | 557 |  | 
|  | 558 | { | 
|  | 559 | DBE_VT_1600_1024_60, | 
|  | 560 | /* flags,					width,          height,			fields_sec,     cfreq */ | 
|  | 561 | DBE_VOF_FLATPANEL,   1600,           1024,			60000,          106913, | 
|  | 562 | /* htotal, hblank_start,   hblank_end,     hsync_start,    hsync_end */ | 
|  | 563 | 1670,   1600,           1670,           1630,           1650, | 
|  | 564 | /* vtotal, vblank_start,   vblank_end,     vsync_start,    vsync_end */ | 
|  | 565 | 1067,   1024,           1067,           1027,           1030, | 
|  | 566 | /* pll_m,  pll_n,          pll_p */ | 
|  | 567 | 4,      1,              0 | 
|  | 568 | }, | 
|  | 569 |  | 
|  | 570 | { | 
|  | 571 | DBE_VT_1600_1200_50, | 
|  | 572 | /* flags,  width,          height,         fields_sec,     cfreq */ | 
|  | 573 | 0,      1600,           1200,           50000,          130500, | 
|  | 574 | /* htotal, hblank_start,   hblank_end,     hsync_start,    hsync_end */ | 
|  | 575 | 2088,   1600,           2088,           1644,           1764, | 
|  | 576 | /* vtotal, vblank_start,   vblank_end,     vsync_start,    vsync_end */ | 
|  | 577 | 1250,   1200,           1250,           1205,           1211, | 
|  | 578 | /* pll_m,  pll_n,          pll_p */ | 
|  | 579 | 24,     5,              0 | 
|  | 580 | }, | 
|  | 581 |  | 
|  | 582 | { | 
|  | 583 | DBE_VT_1600_1200_60, | 
|  | 584 | /* flags,  width,          height,         fields_sec,     cfreq */ | 
|  | 585 | 0,      1600,           1200,           59940,          162000, | 
|  | 586 | /* htotal, hblank_start,   hblank_end,     hsync_start,    hsync_end */ | 
|  | 587 | 2160,   1600,           2160,           1644,           1856, | 
|  | 588 | /* vtotal, vblank_start,   vblank_end,     vsync_start,    vsync_end */ | 
|  | 589 | 1250,   1200,           1250,           1201,           1204, | 
|  | 590 | /* pll_m,  pll_n,          pll_p */ | 
|  | 591 | 6,		1,              0 | 
|  | 592 | }, | 
|  | 593 |  | 
|  | 594 | { | 
|  | 595 | DBE_VT_1600_1200_75, | 
|  | 596 | /* flags,  width,          height,         fields_sec,     cfreq */ | 
|  | 597 | 0,      1600,           1200,           75000,          202500, | 
|  | 598 | /* htotal, hblank_start,   hblank_end,     hsync_start,    hsync_end */ | 
|  | 599 | 2160,   1600,           2160,           1644,           1856, | 
|  | 600 | /* vtotal, vblank_start,   vblank_end,     vsync_start,    vsync_end */ | 
|  | 601 | 1250,   1200,           1250,           1201,           1204, | 
|  | 602 | /* pll_m,  pll_n,          pll_p */ | 
|  | 603 | 15,		2,              0 | 
|  | 604 | }, | 
|  | 605 |  | 
|  | 606 | { | 
|  | 607 | DBE_VT_1920_1080_50, | 
|  | 608 | /* flags,  width,          height,         fields_sec,     cfreq */ | 
|  | 609 | 0,      1920,           1080,           50000,          133200, | 
|  | 610 | /* htotal, hblank_start,   hblank_end,     hsync_start,    hsync_end */ | 
|  | 611 | 2368,   1920,           2368,           1952,           2096, | 
|  | 612 | /* vtotal, vblank_start,   vblank_end,     vsync_start,    vsync_end */ | 
|  | 613 | 1125,   1080,           1125,           1083,           1086, | 
|  | 614 | /* pll_m,  pll_n,          pll_p */ | 
|  | 615 | 5,      1,              0 | 
|  | 616 | }, | 
|  | 617 |  | 
|  | 618 | { | 
|  | 619 | DBE_VT_1920_1080_60, | 
|  | 620 | /* flags,  width,          height,         fields_sec,     cfreq */ | 
|  | 621 | 0,      1920,           1080,           59940,          159840, | 
|  | 622 | /* htotal, hblank_start,   hblank_end,     hsync_start,    hsync_end */ | 
|  | 623 | 2368,   1920,           2368,           1952,           2096, | 
|  | 624 | /* vtotal, vblank_start,   vblank_end,     vsync_start,    vsync_end */ | 
|  | 625 | 1125,   1080,           1125,           1083,           1086, | 
|  | 626 | /* pll_m,  pll_n,          pll_p */ | 
|  | 627 | 6,      1,              0 | 
|  | 628 | }, | 
|  | 629 |  | 
|  | 630 | { | 
|  | 631 | DBE_VT_1920_1080_72, | 
|  | 632 | /* flags,  width,          height,         fields_sec,     cfreq */ | 
|  | 633 | 0,      1920,           1080,           72000,          216023, | 
|  | 634 | /* htotal, hblank_start,   hblank_end,     hsync_start,    hsync_end */ | 
|  | 635 | 2560,   1920,           2560,           1968,           2184, | 
|  | 636 | /* vtotal, vblank_start,   vblank_end,     vsync_start,    vsync_end */ | 
|  | 637 | 1172,   1080,           1172,           1083,           1086, | 
|  | 638 | /* pll_m,  pll_n,          pll_p */ | 
|  | 639 | 8,      1,              0 | 
|  | 640 | }, | 
|  | 641 |  | 
|  | 642 | { | 
|  | 643 | DBE_VT_1920_1200_50, | 
|  | 644 | /* flags,  width,          height,         fields_sec,     cfreq */ | 
|  | 645 | 0,      1920,           1200,           50000,          161500, | 
|  | 646 | /* htotal, hblank_start,   hblank_end,     hsync_start,    hsync_end */ | 
|  | 647 | 2584,   1920,           2584,           1984,           2240, | 
|  | 648 | /* vtotal, vblank_start,   vblank_end,     vsync_start,    vsync_end */ | 
|  | 649 | 1250,   1200,           1250,           1203,           1206, | 
|  | 650 | /* pll_m,  pll_n,          pll_p */ | 
|  | 651 | 6,      1,              0 | 
|  | 652 | }, | 
| Thiago Farina | 96c085d | 2009-11-01 16:47:35 -0500 | [diff] [blame] | 653 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 654 | { | 
|  | 655 | DBE_VT_1920_1200_60, | 
|  | 656 | /* flags,  width,          height,         fields_sec,     cfreq */ | 
|  | 657 | 0,      1920,           1200,           59940,          193800, | 
|  | 658 | /* htotal, hblank_start,   hblank_end,     hsync_start,    hsync_end */ | 
|  | 659 | 2584,   1920,           2584,           1984,           2240, | 
|  | 660 | /* vtotal, vblank_start,   vblank_end,     vsync_start,    vsync_end */ | 
|  | 661 | 1250,   1200,           1250,           1203,           1206, | 
|  | 662 | /* pll_m,  pll_n,          pll_p */ | 
|  | 663 | 29,     4,              0 | 
|  | 664 | }, | 
|  | 665 |  | 
|  | 666 | { | 
|  | 667 | DBE_VT_1920_1200_66, | 
|  | 668 | /* flags,  width,          height,         fields_sec,     cfreq */ | 
|  | 669 | 0,      1920,           1200,           66000,          213180, | 
|  | 670 | /* htotal, hblank_start,   hblank_end,     hsync_start,    hsync_end */ | 
|  | 671 | 2584,   1920,           2584,           1984,           2240, | 
|  | 672 | /* vtotal, vblank_start,   vblank_end,     vsync_start,    vsync_end */ | 
|  | 673 | 1250,   1200,           1250,           1203,           1206, | 
|  | 674 | /* pll_m,  pll_n,          pll_p */ | 
|  | 675 | 8,      1,              0 | 
|  | 676 | } | 
|  | 677 | }; | 
|  | 678 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 679 | #endif // INCLUDE_TIMING_TABLE_DATA | 
|  | 680 |  | 
|  | 681 | #endif // ! __SGIVWFB_H__ |