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