1 /*
2 Haiku ATI video driver adapted from the X.org ATI driver which has the
3 following copyright:
4
5 Copyright 1992,1993,1994,1995,1996,1997 by Kevin E. Martin, Chapel Hill, North Carolina.
6
7 Copyright 2009, 2011 Haiku, Inc. All rights reserved.
8 Distributed under the terms of the MIT license.
9
10 Authors:
11 Gerald Zajac
12 */
13
14 #ifndef __MACH64_H__
15 #define __MACH64_H__
16
17
18 #define CURSOR_BYTES 1024 // bytes used for cursor image in video memory
19
20 // Memory types for Mach64 chips.
21
22 enum Mach64_MemoryType
23 {
24 MEM_NONE,
25 MEM_DRAM,
26 MEM_EDO,
27 MEM_PSEUDO_EDO,
28 MEM_SDRAM,
29 MEM_SGRAM,
30 MEM_SGRAM32,
31 MEM_TYPE_7
32 };
33
34
35 // Macros to get/set a contiguous bit field. Arguments should not be
36 // self-modifying.
37
38 #define UnitOf(___Value) (((((___Value) ^ ((___Value) - 1)) + 1) >> 1) \
39 | ((((___Value) ^ ((___Value) - 1)) >> 1) + 1))
40
41 #define GetBits(__Value, _Mask) (((__Value) & (_Mask)) / UnitOf(_Mask))
42 #define SetBits(__Value, _Mask) (((__Value) * UnitOf(_Mask)) & (_Mask))
43
44
45 // Register MMIO addresses - expressed in BYTE offsets.
46 //-----------------------------------------------------
47
48 #define CRTC_H_TOTAL_DISP (0x0c00 + 0x0000) // Dword offset 00
49 #define CRTC_H_SYNC_STRT_WID (0x0c00 + 0x0004) // Dword offset 01
50 #define CRTC_V_TOTAL_DISP (0x0c00 + 0x0008) // Dword offset 02
51 #define CRTC_V_SYNC_STRT_WID (0x0c00 + 0x000C) // Dword offset 03
52 #define CRTC_VLINE_CRNT_VLINE (0x0c00 + 0x0010) // Dword offset 04
53 #define CRTC_OFF_PITCH (0x0c00 + 0x0014) // Dword offset 05
54 #define CRTC_INT_CNTL (0x0c00 + 0x0018) // Dword offset 06
55 #define CRTC_GEN_CNTL (0x0c00 + 0x001C) // Dword offset 07
56
57 #define DSP_CONFIG (0x0c00 + 0x0020) // Dword offset 08
58 #define DSP_ON_OFF (0x0c00 + 0x0024) // Dword offset 09
59
60 #define SHARED_CNTL (0x0c00 + 0x0038) // Dword offset 0E
61
62 #define OVR_CLR (0x0c00 + 0x0040) // Dword offset 10
63 #define OVR_WID_LEFT_RIGHT (0x0c00 + 0x0044) // Dword offset 11
64 #define OVR_WID_TOP_BOTTOM (0x0c00 + 0x0048) // Dword offset 12
65
66 #define CUR_CLR0 (0x0c00 + 0x0060) // Dword offset 18
67 #define CUR_CLR1 (0x0c00 + 0x0064) // Dword offset 19
68 #define CUR_OFFSET (0x0c00 + 0x0068) // Dword offset 1A
69 #define CUR_HORZ_VERT_POSN (0x0c00 + 0x006C) // Dword offset 1B
70 #define CUR_HORZ_VERT_OFF (0x0c00 + 0x0070) // Dword offset 1C
71
72 #define HW_DEBUG (0x0c00 + 0x007C) // Dword offset 1F
73
74 #define SCRATCH_REG0 (0x0c00 + 0x0080) // Dword offset 20
75 #define SCRATCH_REG1 (0x0c00 + 0x0084) // Dword offset 21
76
77 #define CLOCK_CNTL (0x0c00 + 0x0090) // Dword offset 24
78
79 #define BUS_CNTL (0x0c00 + 0x00A0) // Dword offset 28
80
81 #define LCD_INDEX (0x0c00 + 0x00A4) // Dword offset 29
82 #define LCD_DATA (0x0c00 + 0x00A8) // Dword offset 2A
83
84 #define MEM_CNTL (0x0c00 + 0x00B0) // Dword offset 2C
85
86 #define MEM_VGA_WP_SEL (0x0c00 + 0x00B4) // Dword offset 2D
87 #define MEM_VGA_RP_SEL (0x0c00 + 0x00B8) // Dword offset 2E
88
89 #define DAC_REGS (0x0c00 + 0x00C0) // Dword offset 30
90 #define DAC_W_INDEX (DAC_REGS + 0)
91 #define DAC_DATA (DAC_REGS + 1)
92 #define DAC_MASK (DAC_REGS + 2)
93 #define DAC_R_INDEX (DAC_REGS + 3)
94 #define DAC_CNTL (0x0c00 + 0x00C4) // Dword offset 31
95
96 #define GEN_TEST_CNTL (0x0c00 + 0x00D0) // Dword offset 34
97
98 #define CONFIG_CNTL (0x0c00 + 0x00DC // Dword offset 37 (CT, ET, VT)
99 #define CONFIG_CHIP_ID (0x0c00 + 0x00E0) // Dword offset 38
100 #define CONFIG_STAT0 (0x0c00 + 0x00E4) // Dword offset 39
101 #define CONFIG_STAT1 (0x0c00 + 0x00E8) // Dword offset 3A
102
103 #define DST_OFF_PITCH (0x0c00 + 0x0100) // Dword offset 40
104 #define DST_X (0x0c00 + 0x0104) // Dword offset 41
105 #define DST_Y (0x0c00 + 0x0108) // Dword offset 42
106 #define DST_Y_X (0x0c00 + 0x010C) // Dword offset 43
107 #define DST_WIDTH (0x0c00 + 0x0110) // Dword offset 44
108 #define DST_HEIGHT (0x0c00 + 0x0114) // Dword offset 45
109 #define DST_HEIGHT_WIDTH (0x0c00 + 0x0118) // Dword offset 46
110 #define DST_X_WIDTH (0x0c00 + 0x011C) // Dword offset 47
111 #define DST_BRES_LNTH (0x0c00 + 0x0120) // Dword offset 48
112 #define DST_BRES_ERR (0x0c00 + 0x0124) // Dword offset 49
113 #define DST_BRES_INC (0x0c00 + 0x0128) // Dword offset 4A
114 #define DST_BRES_DEC (0x0c00 + 0x012C) // Dword offset 4B
115 #define DST_CNTL (0x0c00 + 0x0130) // Dword offset 4C
116
117 #define SRC_OFF_PITCH (0x0c00 + 0x0180) // Dword offset 60
118 #define SRC_X (0x0c00 + 0x0184) // Dword offset 61
119 #define SRC_Y (0x0c00 + 0x0188) // Dword offset 62
120 #define SRC_Y_X (0x0c00 + 0x018C) // Dword offset 63
121 #define SRC_WIDTH1 (0x0c00 + 0x0190) // Dword offset 64
122 #define SRC_HEIGHT1 (0x0c00 + 0x0194) // Dword offset 65
123 #define SRC_HEIGHT1_WIDTH1 (0x0c00 + 0x0198) // Dword offset 66
124 #define SRC_X_START (0x0c00 + 0x019C) // Dword offset 67
125 #define SRC_Y_START (0x0c00 + 0x01A0) // Dword offset 68
126 #define SRC_Y_X_START (0x0c00 + 0x01A4) // Dword offset 69
127 #define SRC_WIDTH2 (0x0c00 + 0x01A8) // Dword offset 6A
128 #define SRC_HEIGHT2 (0x0c00 + 0x01AC) // Dword offset 6B
129 #define SRC_HEIGHT2_WIDTH2 (0x0c00 + 0x01B0) // Dword offset 6C
130 #define SRC_CNTL (0x0c00 + 0x01B4) // Dword offset 6D
131
132 #define HOST_DATA0 (0x0c00 + 0x0200) // Dword offset 80
133 #define HOST_DATA1 (0x0c00 + 0x0204) // Dword offset 81
134 #define HOST_DATA2 (0x0c00 + 0x0208) // Dword offset 82
135 #define HOST_DATA3 (0x0c00 + 0x020C) // Dword offset 83
136 #define HOST_DATA4 (0x0c00 + 0x0210) // Dword offset 84
137 #define HOST_DATA5 (0x0c00 + 0x0214) // Dword offset 85
138 #define HOST_DATA6 (0x0c00 + 0x0218) // Dword offset 86
139 #define HOST_DATA7 (0x0c00 + 0x021C) // Dword offset 87
140 #define HOST_DATA8 (0x0c00 + 0x0220) // Dword offset 88
141 #define HOST_DATA9 (0x0c00 + 0x0224) // Dword offset 89
142 #define HOST_DATAA (0x0c00 + 0x0228) // Dword offset 8A
143 #define HOST_DATAB (0x0c00 + 0x022C) // Dword offset 8B
144 #define HOST_DATAC (0x0c00 + 0x0230) // Dword offset 8C
145 #define HOST_DATAD (0x0c00 + 0x0234) // Dword offset 8D
146 #define HOST_DATAE (0x0c00 + 0x0238) // Dword offset 8E
147 #define HOST_DATAF (0x0c00 + 0x023C) // Dword offset 8F
148 #define HOST_CNTL (0x0c00 + 0x0240) // Dword offset 90
149
150 #define PAT_REG0 (0x0c00 + 0x0280) // Dword offset A0
151 #define PAT_REG1 (0x0c00 + 0x0284) // Dword offset A1
152 #define PAT_CNTL (0x0c00 + 0x0288) // Dword offset A2
153
154 #define SC_LEFT (0x0c00 + 0x02A0) // Dword offset A8
155 #define SC_RIGHT (0x0c00 + 0x02A4) // Dword offset A9
156 #define SC_LEFT_RIGHT (0x0c00 + 0x02A8) // Dword offset AA
157 #define SC_TOP (0x0c00 + 0x02AC) // Dword offset AB
158 #define SC_BOTTOM (0x0c00 + 0x02B0) // Dword offset AC
159 #define SC_TOP_BOTTOM (0x0c00 + 0x02B4) // Dword offset AD
160
161 #define DP_BKGD_CLR (0x0c00 + 0x02C0) // Dword offset B0
162 #define DP_FRGD_CLR (0x0c00 + 0x02C4) // Dword offset B1
163 #define DP_WRITE_MASK (0x0c00 + 0x02C8) // Dword offset B2
164 #define DP_CHAIN_MASK (0x0c00 + 0x02CC) // Dword offset B3
165 #define DP_PIX_WIDTH (0x0c00 + 0x02D0) // Dword offset B4
166 #define DP_MIX (0x0c00 + 0x02D4) // Dword offset B5
167 #define DP_SRC (0x0c00 + 0x02D8) // Dword offset B6
168
169 #define CLR_CMP_CLR (0x0c00 + 0x0300) // Dword offset C0
170 #define CLR_CMP_MASK (0x0c00 + 0x0304) // Dword offset C1
171 #define CLR_CMP_CNTL (0x0c00 + 0x0308) // Dword offset C2
172
173 #define FIFO_STAT (0x0c00 + 0x0310) // Dword offset C4
174
175 #define CONTEXT_MASK (0x0c00 + 0x0320) // Dword offset C8
176 #define CONTEXT_LOAD_CNTL (0x0c00 + 0x032C) // Dword offset CB
177
178 #define GUI_TRAJ_CNTL (0x0c00 + 0x0330) // Dword offset CC
179 #define GUI_STAT (0x0c00 + 0x0338) // Dword offset CE
180
181
182 // Definitions used for overlays.
183 //===============================
184
185 #define REG_BLOCK_1 0x0800 // offset of register block 1 in register area
186
187 #define OVERLAY_Y_X_START (REG_BLOCK_1 + 0x0000) // Dword offset 00
188 #define OVERLAY_LOCK_START 0x80000000ul
189 #define OVERLAY_Y_X_END (REG_BLOCK_1 + 0x0004) // Dword offset 01
190 #define OVERLAY_GRAPHICS_KEY_CLR (REG_BLOCK_1 + 0x0010) // Dword offset 04
191 #define OVERLAY_GRAPHICS_KEY_MSK (REG_BLOCK_1 + 0x0014) // Dword offset 05
192 #define OVERLAY_KEY_CNTL (REG_BLOCK_1 + 0x0018) // Dword offset 06
193 #define OVERLAY_MIX_FALSE 0x00
194 #define OVERLAY_MIX_EQUAL 0x50
195 #define OVERLAY_SCALE_INC (REG_BLOCK_1 + 0x0020) // Dword offset 08
196 #define OVERLAY_SCALE_CNTL (REG_BLOCK_1 + 0x0024) // Dword offset 09
197 #define SCALE_PIX_EXPAND 0x00000001
198 #define OVERLAY_EN 0x40000000
199 #define SCALE_EN 0x80000000
200 #define SCALER_HEIGHT_WIDTH (REG_BLOCK_1 + 0x0028) // Dword offset 0a
201 #define SCALER_BUF0_OFFSET (REG_BLOCK_1 + 0x0034) // Dword offset 0d
202 #define SCALER_BUF0_PITCH (REG_BLOCK_1 + 0x003c) // Dword offset 0f
203 #define VIDEO_FORMAT (REG_BLOCK_1 + 0x0048) // Dword offset 12
204 #define SCALE_IN_VYUY422 0x000b0000
205 #define BUF0_OFFSET (REG_BLOCK_1 + 0x0080) // Dword offset 20
206 #define BUF0_PITCH (REG_BLOCK_1 + 0x008c) // Dword offset 23
207 #define SCALER_COLOUR_CNTL (REG_BLOCK_1 + 0x0150) // Dword offset 54
208 #define SCALER_H_COEFF0 (REG_BLOCK_1 + 0x0154) // Dword offset 55
209 #define SCALER_H_COEFF1 (REG_BLOCK_1 + 0x0158) // Dword offset 56
210 #define SCALER_H_COEFF2 (REG_BLOCK_1 + 0x015c) // Dword offset 57
211 #define SCALER_H_COEFF3 (REG_BLOCK_1 + 0x0160) // Dword offset 58
212 #define SCALER_H_COEFF4 (REG_BLOCK_1 + 0x0164) // Dword offset 59
213
214
215 // CRTC control values.
216
217 #define CRTC_H_SYNC_NEG 0x00200000
218 #define CRTC_V_SYNC_NEG 0x00200000
219
220 #define CRTC_DBL_SCAN_EN 0x00000001
221 #define CRTC_INTERLACE_EN 0x00000002
222 #define CRTC_HSYNC_DIS 0x00000004
223 #define CRTC_VSYNC_DIS 0x00000008
224 #define CRTC_CSYNC_EN 0x00000010
225 #define CRTC_PIX_BY_2_EN 0x00000020
226 #define CRTC_DISPLAY_DIS 0x00000040
227 #define CRTC_VGA_XOVERSCAN 0x00000080
228
229 #define CRTC_PIX_WIDTH 0x00000700
230 #define CRTC_PIX_WIDTH_4BPP 0x00000100
231 #define CRTC_PIX_WIDTH_8BPP 0x00000200
232 #define CRTC_PIX_WIDTH_15BPP 0x00000300
233 #define CRTC_PIX_WIDTH_16BPP 0x00000400
234 #define CRTC_PIX_WIDTH_24BPP 0x00000500
235 #define CRTC_PIX_WIDTH_32BPP 0x00000600
236
237 #define CRTC_BYTE_PIX_ORDER 0x00000800
238 #define CRTC_PIX_ORDER_MSN_LSN 0x00000000
239 #define CRTC_PIX_ORDER_LSN_MSN 0x00000800
240
241 #define CRTC_FIFO_LWM 0x000f0000
242 #define CRTC2_PIX_WIDTH 0x000e0000
243 #define CRTC_VGA_128KAP_PAGING 0x00100000
244 #define CRTC_VFC_SYNC_TRISTATE 0x00200000
245 #define CRTC2_EN 0x00200000
246 #define CRTC_LOCK_REGS 0x00400000
247 #define CRTC_SYNC_TRISTATE 0x00800000
248 #define CRTC_EXT_DISP_EN 0x01000000
249 #define CRTC_EN 0x02000000
250 #define CRTC_DISP_REQ_EN 0x04000000
251 #define CRTC_VGA_LINEAR 0x08000000
252 #define CRTC_VGA_TEXT_132 0x20000000
253 #define CRTC_CNT_EN 0x40000000
254 #define CRTC_CUR_B_TEST 0x80000000
255
256 #define CRTC_CRNT_VLINE 0x07f00000
257 #define CRTC_VBLANK 0x00000001
258
259 #define CRTC_PITCH 0xffc00000
260
261 // DAC control values.
262 #define DAC_8BIT_EN 0x00000100
263
264
265 // Mix control values.
266 #define MIX_NOT_DST 0x0000
267 #define MIX_0 0x0001
268 #define MIX_1 0x0002
269 #define MIX_DST 0x0003
270 #define MIX_NOT_SRC 0x0004
271 #define MIX_XOR 0x0005
272 #define MIX_XNOR 0x0006
273 #define MIX_SRC 0x0007
274 #define MIX_NAND 0x0008
275 #define MIX_NOT_SRC_OR_DST 0x0009
276 #define MIX_SRC_OR_NOT_DST 0x000a
277 #define MIX_OR 0x000b
278 #define MIX_AND 0x000c
279 #define MIX_SRC_AND_NOT_DST 0x000d
280 #define MIX_NOT_SRC_AND_DST 0x000e
281 #define MIX_NOR 0x000f
282
283 // BUS_CNTL register constants.
284 #define BUS_FIFO_ERR_ACK 0x00200000
285 #define BUS_HOST_ERR_ACK 0x00800000
286 #define BUS_EXT_REG_EN 0x08000000
287
288 // GEN_TEST_CNTL register constants.
289 #define GEN_OVR_OUTPUT_EN 0x20
290 #define HWCURSOR_ENABLE 0x80
291 #define GUI_ENGINE_ENABLE 0x100
292
293 // DSP_CONFIG register constants.
294 #define DSP_XCLKS_PER_QW 0x00003fff
295 #define DSP_LOOP_LATENCY 0x000f0000
296 #define DSP_PRECISION 0x00700000
297
298 // DSP_ON_OFF register constants.
299 #define DSP_OFF 0x000007ff
300 #define DSP_ON 0x07ff0000
301
302 // CLOCK_CNTL register constants.
303 #define CLOCK_SEL 0x0f
304 #define CLOCK_DIV 0x30
305 #define CLOCK_DIV1 0x00
306 #define CLOCK_DIV2 0x10
307 #define CLOCK_DIV4 0x20
308 #define CLOCK_STROBE 0x40
309 #define PLL_WR_EN 0x02
310 #define PLL_ADDR 0xfc
311
312 // PLL registers.
313 #define PLL_MACRO_CNTL 0x01
314 #define PLL_REF_DIV 0x02
315 #define PLL_GEN_CNTL 0x03
316 #define PLL_MCLK_FB_DIV 0x04
317 #define PLL_VCLK_CNTL 0x05
318 #define PLL_VCLK_POST_DIV 0x06
319 #define PLL_VCLK0_FB_DIV 0x07
320 #define PLL_VCLK1_FB_DIV 0x08
321 #define PLL_VCLK2_FB_DIV 0x09
322 #define PLL_VCLK3_FB_DIV 0x0A
323 #define PLL_XCLK_CNTL 0x0B
324 #define PLL_TEST_CTRL 0x0E
325 #define PLL_TEST_COUNT 0x0F
326
327 // Fields in PLL registers.
328 #define PLL_PC_GAIN 0x07
329 #define PLL_VC_GAIN 0x18
330 #define PLL_DUTY_CYC 0xE0
331 #define PLL_MFB_TIMES_4_2B 0x08
332 #define PLL_VCLK0_XDIV 0x10
333 #define PLL_OVERRIDE 0x01
334 #define PLL_MCLK_RST 0x02
335 #define OSC_EN 0x04
336 #define EXT_CLK_EN 0x08
337 #define MCLK_SRC_SEL 0x70
338 #define EXT_CLK_CNTL 0x80
339 #define PLL_VCLK_SRC_SEL 0x03
340 #define PLL_VCLK_RESET 0x04
341 #define VCLK_INVERT 0x08
342 #define VCLK0_POST 0x03
343 #define VCLK1_POST 0x0C
344 #define VCLK2_POST 0x30
345 #define VCLK3_POST 0xC0
346
347 // MEM_CNTL register constants.
348 #define CTL_MEM_TRP 0x00000300
349 #define CTL_MEM_TRCD 0x00000C00
350 #define CTL_MEM_TCRD 0x00001000
351 #define CTL_MEM_TRAS 0x00070000
352
353 // DST_CNTL register constants.
354 #define DST_X_LEFT_TO_RIGHT 1
355 #define DST_Y_TOP_TO_BOTTOM 2
356 #define DST_LAST_PEL 0x20
357
358 // SRC_CNTL register constants.
359 #define SRC_LINE_X_LEFT_TO_RIGHT 0x10
360
361 // HOST_CNTL register constants.
362 #define HOST_BYTE_ALIGN 1
363
364 // DP_CHAIN_MASK register constants.
365 #define DP_CHAIN_4BPP 0x8888
366 #define DP_CHAIN_7BPP 0xD2D2
367 #define DP_CHAIN_8BPP 0x8080
368 #define DP_CHAIN_8BPP_RGB 0x9292
369 #define DP_CHAIN_15BPP 0x4210
370 #define DP_CHAIN_16BPP 0x8410
371 #define DP_CHAIN_24BPP 0x8080
372 #define DP_CHAIN_32BPP 0x8080
373
374 // DP_PIX_WIDTH register constants.
375 #define DST_1BPP 0
376 #define DST_4BPP 1
377 #define DST_8BPP 2
378 #define DST_15BPP 3
379 #define DST_16BPP 4
380 #define DST_32BPP 6
381 #define SRC_1BPP 0
382 #define SRC_4BPP 0x100
383 #define SRC_8BPP 0x200
384 #define SRC_15BPP 0x300
385 #define SRC_16BPP 0x400
386 #define SRC_32BPP 0x600
387 #define HOST_1BPP 0
388 #define HOST_4BPP 0x10000
389 #define HOST_8BPP 0x20000
390 #define HOST_15BPP 0x30000
391 #define HOST_16BPP 0x40000
392 #define HOST_32BPP 0x60000
393 #define BYTE_ORDER_MSB_TO_LSB 0
394 #define BYTE_ORDER_LSB_TO_MSB 0x1000000
395
396 // DP_SRC register constants.
397 #define BKGD_SRC_BKGD_CLR 0
398 #define FRGD_SRC_FRGD_CLR 0x100
399 #define FRGD_SRC_BLIT 0x300
400 #define MONO_SRC_ONE 0
401
402 // GUI_STAT register constants.
403 #define ENGINE_BUSY 1
404
405 // LCD Index register constants.
406 #define LCD_REG_INDEX 0x0000003F
407 #define LCD_DISPLAY_DIS 0x00000100
408 #define LCD_SRC_SEL 0x00000200
409 #define CRTC2_DISPLAY_DIS 0x00000400
410
411 // LCD register indices.
412 #define LCD_CONFIG_PANEL 0x00
413 #define LCD_GEN_CNTL 0x01
414 #define LCD_DSTN_CONTROL 0x02
415 #define LCD_HFB_PITCH_ADDR 0x03
416 #define LCD_HORZ_STRETCHING 0x04
417 #define LCD_VERT_STRETCHING 0x05
418 #define LCD_EXT_VERT_STRETCH 0x06
419 #define LCD_LT_GIO 0x07
420 #define LCD_POWER_MANAGEMENT 0x08
421
422 // LCD_CONFIG_PANEL register constants.
423 #define DONT_SHADOW_HEND 0x00004000
424
425 // LCD_GEN_CNTL register constants.
426 #define CRT_ON 0x00000001
427 #define LCD_ON 0x00000002
428 #define HORZ_DIVBY2_EN 0x00000004
429 #define LOCK_8DOT 0x00000010
430 #define DONT_SHADOW_VPAR 0x00000040
431 #define DIS_HOR_CRT_DIVBY2 0x00000400
432 #define MCLK_PM_EN 0x00010000
433 #define VCLK_DAC_PM_EN 0x00020000
434 #define CRTC_RW_SELECT 0x08000000
435 #define USE_SHADOWED_VEND 0x10000000
436 #define USE_SHADOWED_ROWCUR 0x20000000
437 #define SHADOW_EN 0x40000000
438 #define SHADOW_RW_EN 0x80000000
439
440 // LCD_HORZ_STRETCHING register constants.
441 #define HORZ_STRETCH_BLEND 0x00000fff
442 #define HORZ_STRETCH_RATIO 0x0000ffff
443 #define HORZ_STRETCH_LOOP 0x00070000
444 #define HORZ_PANEL_SIZE 0x0ff00000
445 #define AUTO_HORZ_RATIO 0x20000000
446 #define HORZ_STRETCH_MODE 0x40000000
447 #define HORZ_STRETCH_EN 0x80000000
448
449 // LCD_VERT_STRETCHING register constants.
450 #define VERT_STRETCH_RATIO0 0x000003ff
451 #define VERT_STRETCH_RATIO1 0x000ffc00
452 #define VERT_STRETCH_RATIO2 0x3ff00000
453 #define VERT_STRETCH_USE0 0x40000000
454 #define VERT_STRETCH_EN 0x80000000
455
456 // LCD_EXT_VERT_STRETCH register constants.
457 #define VERT_STRETCH_RATIO3 0x000003ff
458 #define FORCE_DAC_DATA 0x000000ff
459 #define FORCE_DAC_DATA_SEL 0x00000300
460 #define VERT_STRETCH_MODE 0x00000400
461 #define VERT_PANEL_SIZE 0x003ff800
462 #define AUTO_VERT_RATIO 0x00400000
463 #define USE_AUTO_FP_POS 0x00800000
464 #define USE_AUTO_LCD_VSYNC 0x01000000
465
466 // LCD_POWER_MANAGEMENT register constants.
467 #define AUTO_POWER_UP 0x00000008
468 #define POWER_BLON 0x02000000
469 #define STANDBY_NOW 0x10000000
470 #define SUSPEND_NOW 0x20000000
471
472
473
474 // Functions to get/set PLL registers.
475 //=======================================
476
477 static inline uint8
Mach64_GetPLLReg(uint8 index)478 Mach64_GetPLLReg(uint8 index)
479 {
480 OUTREG8(CLOCK_CNTL + 1, (index << 2) & PLL_ADDR);
481 return INREG8(CLOCK_CNTL + 2);
482 }
483
484
485 static inline void
Mach64_SetPLLReg(uint8 index,uint8 value)486 Mach64_SetPLLReg(uint8 index, uint8 value)
487 {
488 OUTREG8(CLOCK_CNTL + 1, ((index << 2) & PLL_ADDR) | PLL_WR_EN);
489 OUTREG8(CLOCK_CNTL + 2, value);
490 }
491
492
493 static inline uint32
Mach64_GetLCDReg(int index)494 Mach64_GetLCDReg(int index)
495 {
496 OUTREG8(LCD_INDEX, index & LCD_REG_INDEX);
497 return INREG(LCD_DATA);
498 }
499
500
501 static inline void
Mach64_PutLCDReg(int index,uint32 value)502 Mach64_PutLCDReg(int index, uint32 value)
503 {
504 OUTREG8(LCD_INDEX, index & LCD_REG_INDEX);
505 OUTREG(LCD_DATA, value);
506 }
507
508
509 #endif // __MACH64_H__
510