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