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