static void _a6xx_get_gmu_registers(struct msm_gpu *gpu,
                struct a6xx_gpu_state *a6xx_state,
                const struct a6xx_registers *regs,
-               struct a6xx_gpu_state_obj *obj)
+               struct a6xx_gpu_state_obj *obj,
+               bool rscc)
 {
        struct adreno_gpu *adreno_gpu = to_adreno_gpu(gpu);
        struct a6xx_gpu *a6xx_gpu = to_a6xx_gpu(adreno_gpu);
                u32 count = RANGE(regs->registers, i);
                int j;
 
-               for (j = 0; j < count; j++)
-                       obj->data[index++] = gmu_read(gmu,
-                               regs->registers[i] + j);
+               for (j = 0; j < count; j++) {
+                       u32 offset = regs->registers[i] + j;
+                       u32 val;
+
+                       if (rscc)
+                               val = gmu_read_rscc(gmu, offset);
+                       else
+                               val = gmu_read(gmu, offset);
+
+                       obj->data[index++] = val;
+               }
        }
 }
 
 
        /* Get the CX GMU registers from AHB */
        _a6xx_get_gmu_registers(gpu, a6xx_state, &a6xx_gmu_reglist[0],
-               &a6xx_state->gmu_registers[0]);
+               &a6xx_state->gmu_registers[0], false);
+       _a6xx_get_gmu_registers(gpu, a6xx_state, &a6xx_gmu_reglist[1],
+               &a6xx_state->gmu_registers[1], true);
 
        if (!a6xx_gmu_gx_is_on(&a6xx_gpu->gmu))
                return;
        /* Set the fence to ALLOW mode so we can access the registers */
        gpu_write(gpu, REG_A6XX_GMU_AO_AHB_FENCE_CTRL, 0);
 
-       _a6xx_get_gmu_registers(gpu, a6xx_state, &a6xx_gmu_reglist[1],
-               &a6xx_state->gmu_registers[1]);
+       _a6xx_get_gmu_registers(gpu, a6xx_state, &a6xx_gmu_reglist[2],
+               &a6xx_state->gmu_registers[2], false);
 }
 
 #define A6XX_GBIF_REGLIST_SIZE   1
 
        0x5157, 0x5158, 0x515d, 0x515d, 0x5162, 0x5162, 0x5164, 0x5165,
        0x5180, 0x5186, 0x5190, 0x519e, 0x51c0, 0x51c0, 0x51c5, 0x51cc,
        0x51e0, 0x51e2, 0x51f0, 0x51f0, 0x5200, 0x5201,
-       /* GPU RSCC */
-       0x8c8c, 0x8c8c, 0x8d01, 0x8d02, 0x8f40, 0x8f42, 0x8f44, 0x8f47,
-       0x8f4c, 0x8f87, 0x8fec, 0x8fef, 0x8ff4, 0x902f, 0x9094, 0x9097,
-       0x909c, 0x90d7, 0x913c, 0x913f, 0x9144, 0x917f,
        /* GMU AO */
        0x9300, 0x9316, 0x9400, 0x9400,
        /* GPU CC */
        0xbc00, 0xbc16, 0xbc20, 0xbc27,
 };
 
+static const u32 a6xx_gmu_cx_rscc_registers[] = {
+       /* GPU RSCC */
+       0x008c, 0x008c, 0x0101, 0x0102, 0x0340, 0x0342, 0x0344, 0x0347,
+       0x034c, 0x0387, 0x03ec, 0x03ef, 0x03f4, 0x042f, 0x0494, 0x0497,
+       0x049c, 0x04d7, 0x053c, 0x053f, 0x0544, 0x057f,
+};
+
 static const struct a6xx_registers a6xx_gmu_reglist[] = {
        REGS(a6xx_gmu_cx_registers, 0, 0),
+       REGS(a6xx_gmu_cx_rscc_registers, 0, 0),
        REGS(a6xx_gmu_gx_registers, 0, 0),
 };