Linux Kernel  3.7.1
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
sgivw.h
Go to the documentation of this file.
1 /*
2  * linux/drivers/video/sgivw.h -- SGI DBE frame buffer device header
3  *
4  * Copyright (C) 1999 Silicon Graphics, Inc.
5  * Jeffrey Newquist, [email protected]
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 {
311 
315 
321 
326 
329 
333 
337 
341 
343 } dbe_timing_t;
344 
345 
346 
347 /*
348  * Crime Video Timing Data Structure
349  */
350 
352 {
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  {
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  {
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  {
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  {
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  {
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  {
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  {
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  {
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  {
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  {
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  {
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  {
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  {
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  {
547  /* flags, width, height, fields_sec, cfreq */
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  {
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  {
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  {
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  {
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  {
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  {
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  {
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  {
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  {
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  {
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__