diff options
Diffstat (limited to 'meta-amdfalconx86/recipes-kernel/linux/files/1146-used-cached-gca-values-for-vi_read_register.patch')
-rw-r--r-- | meta-amdfalconx86/recipes-kernel/linux/files/1146-used-cached-gca-values-for-vi_read_register.patch | 166 |
1 files changed, 0 insertions, 166 deletions
diff --git a/meta-amdfalconx86/recipes-kernel/linux/files/1146-used-cached-gca-values-for-vi_read_register.patch b/meta-amdfalconx86/recipes-kernel/linux/files/1146-used-cached-gca-values-for-vi_read_register.patch deleted file mode 100644 index ed7262c9..00000000 --- a/meta-amdfalconx86/recipes-kernel/linux/files/1146-used-cached-gca-values-for-vi_read_register.patch +++ /dev/null @@ -1,166 +0,0 @@ -From 2ce0f44274368b2a6640c3062eb119a0de8c1056 Mon Sep 17 00:00:00 2001 -From: Sanjay R Mehta <sanju.mehta@amd.com> -Date: Wed, 7 Dec 2016 15:07:53 +0530 -Subject: [PATCH 08/10] used cached gca values for vi_read_register -MIME-Version: 1.0 -Content-Type: text/plain; charset=UTF-8 -Content-Transfer-Encoding: 8bit - -Using the cached values has less latency for bare metal -and SR-IOV, and prevents reading back bogus values if the -engine is powergated. - -Reviewed-by: Christian König <christian.koenig@amd.com> -Signed-off-by: Alex Deucher <alexander.deucher@amd.com> -Signed-off-by: Sanjay R Mehta <sanju.mehta@amd.com> ---- - drivers/gpu/drm/amd/amdgpu/vi.c | 115 +++++++++++++++++++++++++++++++++------- - 1 file changed, 96 insertions(+), 19 deletions(-) - -diff --git a/drivers/gpu/drm/amd/amdgpu/vi.c b/drivers/gpu/drm/amd/amdgpu/vi.c -index 02ba429..3a42e83 100644 ---- a/drivers/gpu/drm/amd/amdgpu/vi.c -+++ b/drivers/gpu/drm/amd/amdgpu/vi.c -@@ -513,21 +513,100 @@ static const struct amdgpu_allowed_register_entry vi_allowed_read_registers[] = - {mmPA_SC_RASTER_CONFIG_1, false, true}, - }; - --static uint32_t vi_read_indexed_register(struct amdgpu_device *adev, u32 se_num, -- u32 sh_num, u32 reg_offset) -+static uint32_t vi_get_register_value(struct amdgpu_device *adev, -+ bool indexed, u32 se_num, -+ 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; -+ -+ switch (reg_offset) { -+ case mmCC_RB_BACKEND_DISABLE: -+ 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; -+ case mmPA_SC_RASTER_CONFIG_1: -+ return adev->gfx.config.rb_config[se_idx][sh_idx].raster_config_1; -+ } - -- mutex_lock(&adev->grbm_idx_mutex); -- if (se_num != 0xffffffff || sh_num != 0xffffffff) -- gfx_v8_0_select_se_sh(adev, se_num, sh_num); -+ mutex_lock(&adev->grbm_idx_mutex); -+ if (se_num != 0xffffffff || sh_num != 0xffffffff) -+ gfx_v8_0_select_se_sh(adev, se_num, sh_num); - -- val = RREG32(reg_offset); -+ val = RREG32(reg_offset); - -- if (se_num != 0xffffffff || sh_num != 0xffffffff) -- gfx_v8_0_select_se_sh(adev, 0xffffffff, 0xffffffff); -- mutex_unlock(&adev->grbm_idx_mutex); -- return val; -+ if (se_num != 0xffffffff || sh_num != 0xffffffff) -+ gfx_v8_0_select_se_sh(adev, 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]; -+ case mmGB_MACROTILE_MODE0: -+ case mmGB_MACROTILE_MODE1: -+ case mmGB_MACROTILE_MODE2: -+ case mmGB_MACROTILE_MODE3: -+ case mmGB_MACROTILE_MODE4: -+ case mmGB_MACROTILE_MODE5: -+ case mmGB_MACROTILE_MODE6: -+ case mmGB_MACROTILE_MODE7: -+ case mmGB_MACROTILE_MODE8: -+ case mmGB_MACROTILE_MODE9: -+ case mmGB_MACROTILE_MODE10: -+ case mmGB_MACROTILE_MODE11: -+ case mmGB_MACROTILE_MODE12: -+ case mmGB_MACROTILE_MODE13: -+ case mmGB_MACROTILE_MODE14: -+ case mmGB_MACROTILE_MODE15: -+ idx = (reg_offset - mmGB_MACROTILE_MODE0); -+ return adev->gfx.config.macrotile_mode_array[idx]; -+ default: -+ return RREG32(reg_offset); -+ } -+ } - } - - static int vi_read_register(struct amdgpu_device *adev, u32 se_num, -@@ -562,10 +641,9 @@ static int vi_read_register(struct amdgpu_device *adev, u32 se_num, - if (reg_offset != asic_register_entry->reg_offset) - continue; - if (!asic_register_entry->untouched) -- *value = asic_register_entry->grbm_indexed ? -- vi_read_indexed_register(adev, se_num, -- sh_num, reg_offset) : -- RREG32(reg_offset); -+ *value = vi_get_register_value(adev, -+ asic_register_entry->grbm_indexed, -+ se_num, sh_num, reg_offset); - return 0; - } - } -@@ -575,10 +653,9 @@ static int vi_read_register(struct amdgpu_device *adev, u32 se_num, - continue; - - if (!vi_allowed_read_registers[i].untouched) -- *value = vi_allowed_read_registers[i].grbm_indexed ? -- vi_read_indexed_register(adev, se_num, -- sh_num, reg_offset) : -- RREG32(reg_offset); -+ *value = vi_get_register_value(adev, -+ vi_allowed_read_registers[i].grbm_indexed, -+ se_num, sh_num, reg_offset); - return 0; - } - return -EINVAL; --- -2.7.4 - |