diff options
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/soc15_common.h')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/soc15_common.h | 30 | 
1 files changed, 30 insertions, 0 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/soc15_common.h b/drivers/gpu/drm/amd/amdgpu/soc15_common.h index 52ffbea63a4f..8cdf5d1685cb 100644 --- a/drivers/gpu/drm/amd/amdgpu/soc15_common.h +++ b/drivers/gpu/drm/amd/amdgpu/soc15_common.h @@ -100,6 +100,30 @@  		}	\  	} while (0) +#define WREG32_RLC_EX(prefix, reg, value) \ +	do {							\ +		if (amdgpu_sriov_fullaccess(adev)) {    \ +			uint32_t i = 0;	\ +			uint32_t retries = 50000;	\ +			uint32_t r0 = adev->reg_offset[GC_HWIP][0][prefix##SCRATCH_REG0_BASE_IDX] + prefix##SCRATCH_REG0;	\ +			uint32_t r1 = adev->reg_offset[GC_HWIP][0][prefix##SCRATCH_REG1_BASE_IDX] + prefix##SCRATCH_REG1;	\ +			uint32_t spare_int = adev->reg_offset[GC_HWIP][0][prefix##RLC_SPARE_INT_BASE_IDX] + prefix##RLC_SPARE_INT;	\ +			WREG32(r0, value);	\ +			WREG32(r1, (reg | 0x80000000));	\ +			WREG32(spare_int, 0x1);	\ +			for (i = 0; i < retries; i++) {	\ +				u32 tmp = RREG32(r1);	\ +				if (!(tmp & 0x80000000))	\ +					break;	\ +				udelay(10);	\ +			}	\ +			if (i >= retries)	\ +				pr_err("timeout: rlcg program reg:0x%05x failed !\n", reg);	\ +		} else {	\ +			WREG32(reg, value); \ +		}	\ +	} while (0) +  #define WREG32_SOC15_RLC_SHADOW(ip, inst, reg, value) \  	do {							\  		uint32_t target_reg = adev->reg_offset[ip##_HWIP][inst][reg##_BASE_IDX] + reg;\ @@ -142,6 +166,12 @@  			WREG32_RLC(target_reg, value); \  	} while (0) +#define WREG32_SOC15_RLC_EX(prefix, ip, inst, reg, value) \ +	do {							\ +			uint32_t target_reg = adev->reg_offset[GC_HWIP][0][reg##_BASE_IDX] + reg;\ +			WREG32_RLC_EX(prefix, target_reg, value); \ +	} while (0) +  #define WREG32_FIELD15_RLC(ip, idx, reg, field, val)   \      WREG32_RLC((adev->reg_offset[ip##_HWIP][idx][mm##reg##_BASE_IDX] + mm##reg), \      (RREG32(adev->reg_offset[ip##_HWIP][idx][mm##reg##_BASE_IDX] + mm##reg) \  | 
