Subversion Repositories shark

Rev

Rev 467 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
467 giacomo 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
#define DBE_VT_SIZE  (sizeof(dbeVTimings)/sizeof(dbeVTimings[0]))
680
#endif // INCLUDE_TIMING_TABLE_DATA
681
 
682
#endif // ! __SGIVWFB_H__