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;
354   int flags;
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 */
392     0,	        640,			480,		59940,			25175,
393     /*	htotal,	hblank_start,	hblank_end,	hsync_start,	hsync_end */
394     800,	640,		        800,		656,		752,
395     /*	vtotal,	vblank_start,	vblank_end,	vsync_start,	vsync_end */
396     525,	480,		        525,		490,		    492,
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   },
653 
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 
679 #endif // INCLUDE_TIMING_TABLE_DATA
680 
681 #endif // ! __SGIVWFB_H__
682