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