1 #include "qemu/osdep.h"
10 static struct ati_regdesc ati_reg_names[] = {
13 {"CLOCK_CNTL_INDEX", 0x0008},
14 {"CLOCK_CNTL_DATA", 0x000c},
15 {"BIOS_0_SCRATCH", 0x0010},
17 {"BUS_CNTL1", 0x0034},
18 {"GEN_INT_CNTL", 0x0040},
19 {"CRTC_GEN_CNTL", 0x0050},
20 {"CRTC_EXT_CNTL", 0x0054},
22 {"GPIO_VGA_DDC", 0x0060},
23 {"GPIO_DVI_DDC", 0x0064},
24 {"GPIO_MONID", 0x0068},
25 {"I2C_CNTL_1", 0x0094},
26 {"AMCGPIO_MASK_MIR", 0x009c},
27 {"AMCGPIO_A_MIR", 0x00a0},
28 {"AMCGPIO_Y_MIR", 0x00a4},
29 {"AMCGPIO_EN_MIR", 0x00a8},
30 {"PALETTE_INDEX", 0x00b0},
31 {"PALETTE_DATA", 0x00b4},
32 {"CNFG_CNTL", 0x00e0},
33 {"GEN_RESET_CNTL", 0x00f0},
34 {"CNFG_MEMSIZE", 0x00f8},
35 {"CONFIG_APER_0_BASE", 0x0100},
36 {"CONFIG_APER_1_BASE", 0x0104},
37 {"CONFIG_APER_SIZE", 0x0108},
38 {"CONFIG_REG_1_BASE", 0x010c},
39 {"CONFIG_REG_APER_SIZE", 0x0110},
41 {"MC_FB_LOCATION", 0x0148},
42 {"MC_AGP_LOCATION", 0x014C},
43 {"MC_STATUS", 0x0150},
44 {"MEM_POWER_MISC", 0x015c},
47 {"AGP_APER_OFFSET", 0x0178},
48 {"PCI_GART_PAGE", 0x017c},
49 {"PC_NGUI_MODE", 0x0180},
50 {"PC_NGUI_CTLSTAT", 0x0184},
51 {"MPP_TB_CONFIG", 0x01C0},
52 {"MPP_GP_CONFIG", 0x01C8},
53 {"VIPH_CONTROL", 0x01D0},
54 {"CRTC_H_TOTAL_DISP", 0x0200},
55 {"CRTC_H_SYNC_STRT_WID", 0x0204},
56 {"CRTC_V_TOTAL_DISP", 0x0208},
57 {"CRTC_V_SYNC_STRT_WID", 0x020c},
58 {"CRTC_VLINE_CRNT_VLINE", 0x0210},
59 {"CRTC_CRNT_FRAME", 0x0214},
60 {"CRTC_GUI_TRIG_VLINE", 0x0218},
61 {"CRTC_OFFSET", 0x0224},
62 {"CRTC_OFFSET_CNTL", 0x0228},
63 {"CRTC_PITCH", 0x022c},
65 {"OVR_WID_LEFT_RIGHT", 0x0234},
66 {"OVR_WID_TOP_BOTTOM", 0x0238},
67 {"CUR_OFFSET", 0x0260},
68 {"CUR_HORZ_VERT_POSN", 0x0264},
69 {"CUR_HORZ_VERT_OFF", 0x0268},
72 {"LVDS_GEN_CNTL", 0x02d0},
73 {"DDA_CONFIG", 0x02e0},
74 {"DDA_ON_OFF", 0x02e4},
75 {"VGA_DDA_CONFIG", 0x02e8},
76 {"VGA_DDA_ON_OFF", 0x02ec},
77 {"CRTC2_H_TOTAL_DISP", 0x0300},
78 {"CRTC2_H_SYNC_STRT_WID", 0x0304},
79 {"CRTC2_V_TOTAL_DISP", 0x0308},
80 {"CRTC2_V_SYNC_STRT_WID", 0x030c},
81 {"CRTC2_VLINE_CRNT_VLINE", 0x0310},
82 {"CRTC2_CRNT_FRAME", 0x0314},
83 {"CRTC2_GUI_TRIG_VLINE", 0x0318},
84 {"CRTC2_OFFSET", 0x0324},
85 {"CRTC2_OFFSET_CNTL", 0x0328},
86 {"CRTC2_PITCH", 0x032c},
87 {"DDA2_CONFIG", 0x03e0},
88 {"DDA2_ON_OFF", 0x03e4},
89 {"CRTC2_GEN_CNTL", 0x03f8},
90 {"CRTC2_STATUS", 0x03fc},
91 {"OV0_SCALE_CNTL", 0x0420},
92 {"SUBPIC_CNTL", 0x0540},
93 {"PM4_BUFFER_OFFSET", 0x0700},
94 {"PM4_BUFFER_CNTL", 0x0704},
95 {"PM4_BUFFER_WM_CNTL", 0x0708},
96 {"PM4_BUFFER_DL_RPTR_ADDR", 0x070c},
97 {"PM4_BUFFER_DL_RPTR", 0x0710},
98 {"PM4_BUFFER_DL_WPTR", 0x0714},
99 {"PM4_VC_FPU_SETUP", 0x071c},
100 {"PM4_FPU_CNTL", 0x0720},
101 {"PM4_VC_FORMAT", 0x0724},
102 {"PM4_VC_CNTL", 0x0728},
103 {"PM4_VC_I01", 0x072c},
104 {"PM4_VC_VLOFF", 0x0730},
105 {"PM4_VC_VLSIZE", 0x0734},
106 {"PM4_IW_INDOFF", 0x0738},
107 {"PM4_IW_INDSIZE", 0x073c},
108 {"PM4_FPU_FPX0", 0x0740},
109 {"PM4_FPU_FPY0", 0x0744},
110 {"PM4_FPU_FPX1", 0x0748},
111 {"PM4_FPU_FPY1", 0x074c},
112 {"PM4_FPU_FPX2", 0x0750},
113 {"PM4_FPU_FPY2", 0x0754},
114 {"PM4_FPU_FPY3", 0x0758},
115 {"PM4_FPU_FPY4", 0x075c},
116 {"PM4_FPU_FPY5", 0x0760},
117 {"PM4_FPU_FPY6", 0x0764},
118 {"PM4_FPU_FPR", 0x0768},
119 {"PM4_FPU_FPG", 0x076c},
120 {"PM4_FPU_FPB", 0x0770},
121 {"PM4_FPU_FPA", 0x0774},
122 {"PM4_FPU_INTXY0", 0x0780},
123 {"PM4_FPU_INTXY1", 0x0784},
124 {"PM4_FPU_INTXY2", 0x0788},
125 {"PM4_FPU_INTARGB", 0x078c},
126 {"PM4_FPU_FPTWICEAREA", 0x0790},
127 {"PM4_FPU_DMAJOR01", 0x0794},
128 {"PM4_FPU_DMAJOR12", 0x0798},
129 {"PM4_FPU_DMAJOR02", 0x079c},
130 {"PM4_FPU_STAT", 0x07a0},
131 {"PM4_STAT", 0x07b8},
132 {"PM4_TEST_CNTL", 0x07d0},
133 {"PM4_MICROCODE_ADDR", 0x07d4},
134 {"PM4_MICROCODE_RADDR", 0x07d8},
135 {"PM4_MICROCODE_DATAH", 0x07dc},
136 {"PM4_MICROCODE_DATAL", 0x07e0},
137 {"PM4_CMDFIFO_ADDR", 0x07e4},
138 {"PM4_CMDFIFO_DATAH", 0x07e8},
139 {"PM4_CMDFIFO_DATAL", 0x07ec},
140 {"PM4_BUFFER_ADDR", 0x07f0},
141 {"PM4_BUFFER_DATAH", 0x07f4},
142 {"PM4_BUFFER_DATAL", 0x07f8},
143 {"PM4_MICRO_CNTL", 0x07fc},
144 {"CAP0_TRIG_CNTL", 0x0950},
145 {"CAP1_TRIG_CNTL", 0x09c0},
146 {"RBBM_STATUS", 0x0e40},
147 {"PM4_FIFO_DATA_EVEN", 0x1000},
148 {"PM4_FIFO_DATA_ODD", 0x1004},
149 {"DST_OFFSET", 0x1404},
150 {"DST_PITCH", 0x1408},
151 {"DST_WIDTH", 0x140c},
152 {"DST_HEIGHT", 0x1410},
157 {"SRC_PITCH_OFFSET", 0x1428},
158 {"DST_PITCH_OFFSET", 0x142c},
161 {"DST_HEIGHT_WIDTH", 0x143c},
162 {"DP_GUI_MASTER_CNTL", 0x146c},
163 {"BRUSH_SCALE", 0x1470},
164 {"BRUSH_Y_X", 0x1474},
165 {"DP_BRUSH_BKGD_CLR", 0x1478},
166 {"DP_BRUSH_FRGD_CLR", 0x147c},
167 {"DST_WIDTH_X", 0x1588},
168 {"DST_HEIGHT_WIDTH_8", 0x158c},
171 {"DST_WIDTH_HEIGHT", 0x1598},
172 {"DST_WIDTH_X_INCY", 0x159c},
173 {"DST_HEIGHT_Y", 0x15a0},
174 {"DST_X_SUB", 0x15a4},
175 {"DST_Y_SUB", 0x15a8},
176 {"SRC_OFFSET", 0x15ac},
177 {"SRC_PITCH", 0x15b0},
178 {"DST_HEIGHT_WIDTH_BW", 0x15b4},
179 {"CLR_CMP_CNTL", 0x15c0},
180 {"CLR_CMP_CLR_SRC", 0x15c4},
181 {"CLR_CMP_CLR_DST", 0x15c8},
182 {"CLR_CMP_MASK", 0x15cc},
183 {"DP_SRC_FRGD_CLR", 0x15d8},
184 {"DP_SRC_BKGD_CLR", 0x15dc},
185 {"DST_BRES_ERR", 0x1628},
186 {"DST_BRES_INC", 0x162c},
187 {"DST_BRES_DEC", 0x1630},
188 {"DST_BRES_LNTH", 0x1634},
189 {"DST_BRES_LNTH_SUB", 0x1638},
191 {"SC_RIGHT", 0x1644},
193 {"SC_BOTTOM", 0x164c},
194 {"SRC_SC_RIGHT", 0x1654},
195 {"SRC_SC_BOTTOM", 0x165c},
196 {"GUI_DEBUG0", 0x16a0},
197 {"GUI_DEBUG1", 0x16a4},
198 {"GUI_TIMEOUT", 0x16b0},
199 {"GUI_TIMEOUT0", 0x16b4},
200 {"GUI_TIMEOUT1", 0x16b8},
201 {"GUI_PROBE", 0x16bc},
203 {"DP_DATATYPE", 0x16c4},
205 {"DP_WRITE_MASK", 0x16cc},
206 {"DP_CNTL_XDIR_YDIR_YMAJOR", 0x16d0},
207 {"DEFAULT_OFFSET", 0x16e0},
208 {"DEFAULT_PITCH", 0x16e4},
209 {"DEFAULT_SC_BOTTOM_RIGHT", 0x16e8},
210 {"SC_TOP_LEFT", 0x16ec},
211 {"SC_BOTTOM_RIGHT", 0x16f0},
212 {"SRC_SC_BOTTOM_RIGHT", 0x16f4},
213 {"DST_TILE", 0x1700},
214 {"WAIT_UNTIL", 0x1720},
215 {"CACHE_CNTL", 0x1724},
216 {"GUI_STAT", 0x1740},
217 {"PC_GUI_MODE", 0x1744},
218 {"PC_GUI_CTLSTAT", 0x1748},
219 {"PC_DEBUG_MODE", 0x1760},
220 {"BRES_DST_ERR_DEC", 0x1780},
221 {"TRAIL_BRES_T12_ERR_DEC", 0x1784},
222 {"TRAIL_BRES_T12_INC", 0x1788},
223 {"DP_T12_CNTL", 0x178c},
224 {"DST_BRES_T1_LNTH", 0x1790},
225 {"DST_BRES_T2_LNTH", 0x1794},
226 {"SCALE_SRC_HEIGHT_WIDTH", 0x1994},
227 {"SCALE_OFFSET_0", 0x1998},
228 {"SCALE_PITCH", 0x199c},
229 {"SCALE_X_INC", 0x19a0},
230 {"SCALE_Y_INC", 0x19a4},
231 {"SCALE_HACC", 0x19a8},
232 {"SCALE_VACC", 0x19ac},
233 {"SCALE_DST_X_Y", 0x19b0},
234 {"SCALE_DST_HEIGHT_WIDTH", 0x19b4},
235 {"SCALE_3D_CNTL", 0x1a00},
236 {"SCALE_3D_DATATYPE", 0x1a20},
237 {"SETUP_CNTL", 0x1bc4},
238 {"SOLID_COLOR", 0x1bc8},
239 {"WINDOW_XY_OFFSET", 0x1bcc},
240 {"DRAW_LINE_POINT", 0x1bd0},
241 {"SETUP_CNTL_PM4", 0x1bd4},
242 {"DST_PITCH_OFFSET_C", 0x1c80},
243 {"DP_GUI_MASTER_CNTL_C", 0x1c84},
244 {"SC_TOP_LEFT_C", 0x1c88},
245 {"SC_BOTTOM_RIGHT_C", 0x1c8c},
246 {"CLR_CMP_MASK_3D", 0x1A28},
247 {"MISC_3D_STATE_CNTL_REG", 0x1CA0},
248 {"MC_SRC1_CNTL", 0x19D8},
249 {"TEX_CNTL", 0x1800},
250 {"RAGE128_MPP_TB_CONFIG", 0x01c0},
254 const char *ati_reg_name(int num)
259 for (i = 0; ati_reg_names[i].name; i++) {
260 if (ati_reg_names[i].num == num) {
261 return ati_reg_names[i].name;
267 const char *ati_reg_name(int num)