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__ |