mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-12 13:34:10 +08:00
drm/amdgpu: refine si_read_register
Signed-off-by: Flora Cui <Flora.Cui@amd.com> Reviewed-by: Hawking Zhang <Hawking.Zhang@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
c5dc14fb98
commit
dd5dfa61b4
@ -1010,24 +1010,81 @@ static struct amdgpu_allowed_register_entry si_allowed_read_registers[] = {
|
|||||||
{PA_SC_RASTER_CONFIG, false, true},
|
{PA_SC_RASTER_CONFIG, false, true},
|
||||||
};
|
};
|
||||||
|
|
||||||
static uint32_t si_read_indexed_register(struct amdgpu_device *adev,
|
static uint32_t si_get_register_value(struct amdgpu_device *adev,
|
||||||
u32 se_num, u32 sh_num,
|
bool indexed, u32 se_num,
|
||||||
u32 reg_offset)
|
u32 sh_num, u32 reg_offset)
|
||||||
{
|
{
|
||||||
uint32_t val;
|
if (indexed) {
|
||||||
|
uint32_t val;
|
||||||
|
unsigned se_idx = (se_num == 0xffffffff) ? 0 : se_num;
|
||||||
|
unsigned sh_idx = (sh_num == 0xffffffff) ? 0 : sh_num;
|
||||||
|
|
||||||
mutex_lock(&adev->grbm_idx_mutex);
|
switch (reg_offset) {
|
||||||
if (se_num != 0xffffffff || sh_num != 0xffffffff)
|
case mmCC_RB_BACKEND_DISABLE:
|
||||||
amdgpu_gfx_select_se_sh(adev, se_num, sh_num, 0xffffffff);
|
return adev->gfx.config.rb_config[se_idx][sh_idx].rb_backend_disable;
|
||||||
|
case mmGC_USER_RB_BACKEND_DISABLE:
|
||||||
|
return adev->gfx.config.rb_config[se_idx][sh_idx].user_rb_backend_disable;
|
||||||
|
case mmPA_SC_RASTER_CONFIG:
|
||||||
|
return adev->gfx.config.rb_config[se_idx][sh_idx].raster_config;
|
||||||
|
}
|
||||||
|
|
||||||
val = RREG32(reg_offset);
|
mutex_lock(&adev->grbm_idx_mutex);
|
||||||
|
if (se_num != 0xffffffff || sh_num != 0xffffffff)
|
||||||
|
amdgpu_gfx_select_se_sh(adev, se_num, sh_num, 0xffffffff);
|
||||||
|
|
||||||
if (se_num != 0xffffffff || sh_num != 0xffffffff)
|
val = RREG32(reg_offset);
|
||||||
amdgpu_gfx_select_se_sh(adev, 0xffffffff, 0xffffffff, 0xffffffff);
|
|
||||||
mutex_unlock(&adev->grbm_idx_mutex);
|
if (se_num != 0xffffffff || sh_num != 0xffffffff)
|
||||||
return val;
|
amdgpu_gfx_select_se_sh(adev, 0xffffffff, 0xffffffff, 0xffffffff);
|
||||||
|
mutex_unlock(&adev->grbm_idx_mutex);
|
||||||
|
return val;
|
||||||
|
} else {
|
||||||
|
unsigned idx;
|
||||||
|
|
||||||
|
switch (reg_offset) {
|
||||||
|
case mmGB_ADDR_CONFIG:
|
||||||
|
return adev->gfx.config.gb_addr_config;
|
||||||
|
case mmMC_ARB_RAMCFG:
|
||||||
|
return adev->gfx.config.mc_arb_ramcfg;
|
||||||
|
case mmGB_TILE_MODE0:
|
||||||
|
case mmGB_TILE_MODE1:
|
||||||
|
case mmGB_TILE_MODE2:
|
||||||
|
case mmGB_TILE_MODE3:
|
||||||
|
case mmGB_TILE_MODE4:
|
||||||
|
case mmGB_TILE_MODE5:
|
||||||
|
case mmGB_TILE_MODE6:
|
||||||
|
case mmGB_TILE_MODE7:
|
||||||
|
case mmGB_TILE_MODE8:
|
||||||
|
case mmGB_TILE_MODE9:
|
||||||
|
case mmGB_TILE_MODE10:
|
||||||
|
case mmGB_TILE_MODE11:
|
||||||
|
case mmGB_TILE_MODE12:
|
||||||
|
case mmGB_TILE_MODE13:
|
||||||
|
case mmGB_TILE_MODE14:
|
||||||
|
case mmGB_TILE_MODE15:
|
||||||
|
case mmGB_TILE_MODE16:
|
||||||
|
case mmGB_TILE_MODE17:
|
||||||
|
case mmGB_TILE_MODE18:
|
||||||
|
case mmGB_TILE_MODE19:
|
||||||
|
case mmGB_TILE_MODE20:
|
||||||
|
case mmGB_TILE_MODE21:
|
||||||
|
case mmGB_TILE_MODE22:
|
||||||
|
case mmGB_TILE_MODE23:
|
||||||
|
case mmGB_TILE_MODE24:
|
||||||
|
case mmGB_TILE_MODE25:
|
||||||
|
case mmGB_TILE_MODE26:
|
||||||
|
case mmGB_TILE_MODE27:
|
||||||
|
case mmGB_TILE_MODE28:
|
||||||
|
case mmGB_TILE_MODE29:
|
||||||
|
case mmGB_TILE_MODE30:
|
||||||
|
case mmGB_TILE_MODE31:
|
||||||
|
idx = (reg_offset - mmGB_TILE_MODE0);
|
||||||
|
return adev->gfx.config.tile_mode_array[idx];
|
||||||
|
default:
|
||||||
|
return RREG32(reg_offset);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int si_read_register(struct amdgpu_device *adev, u32 se_num,
|
static int si_read_register(struct amdgpu_device *adev, u32 se_num,
|
||||||
u32 sh_num, u32 reg_offset, u32 *value)
|
u32 sh_num, u32 reg_offset, u32 *value)
|
||||||
{
|
{
|
||||||
@ -1039,10 +1096,9 @@ static int si_read_register(struct amdgpu_device *adev, u32 se_num,
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (!si_allowed_read_registers[i].untouched)
|
if (!si_allowed_read_registers[i].untouched)
|
||||||
*value = si_allowed_read_registers[i].grbm_indexed ?
|
*value = si_get_register_value(adev,
|
||||||
si_read_indexed_register(adev, se_num,
|
si_allowed_read_registers[i].grbm_indexed,
|
||||||
sh_num, reg_offset) :
|
se_num, sh_num, reg_offset);
|
||||||
RREG32(reg_offset);
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
Loading…
Reference in New Issue
Block a user