Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
awilliam
GitHub Repository: awilliam/linux-vfio
Path: blob/master/include/video/sgivw.h
10818 views
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 {
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
683