diff options
Diffstat (limited to 'meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/1068-Revert-drm-amdgpu-Program-ring-for-vce-instance-1-at.patch')
-rw-r--r-- | meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/1068-Revert-drm-amdgpu-Program-ring-for-vce-instance-1-at.patch | 161 |
1 files changed, 161 insertions, 0 deletions
diff --git a/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/1068-Revert-drm-amdgpu-Program-ring-for-vce-instance-1-at.patch b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/1068-Revert-drm-amdgpu-Program-ring-for-vce-instance-1-at.patch new file mode 100644 index 00000000..88dad387 --- /dev/null +++ b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/1068-Revert-drm-amdgpu-Program-ring-for-vce-instance-1-at.patch @@ -0,0 +1,161 @@ +From 7b280d761a14bc996b25ef8463c681a7a559d9d9 Mon Sep 17 00:00:00 2001 +From: Rex Zhu <Rex.Zhu@amd.com> +Date: Thu, 19 Oct 2017 14:42:47 +0800 +Subject: [PATCH 1068/4131] Revert "drm/amdgpu: Program ring for vce instance 1 + at its register space" + +This reverts commit 45cc6586b7a73e84a8806881122b6ec306cdc9e7. +--- + drivers/gpu/drm/amd/amdgpu/vce_v3_0.c | 95 ++++++++++------------------------- + 1 file changed, 27 insertions(+), 68 deletions(-) + +diff --git a/drivers/gpu/drm/amd/amdgpu/vce_v3_0.c b/drivers/gpu/drm/amd/amdgpu/vce_v3_0.c +index 242dfb1..9ef8145 100644 +--- a/drivers/gpu/drm/amd/amdgpu/vce_v3_0.c ++++ b/drivers/gpu/drm/amd/amdgpu/vce_v3_0.c +@@ -77,26 +77,13 @@ static int vce_v3_0_set_clockgating_state(void *handle, + static uint64_t vce_v3_0_ring_get_rptr(struct amdgpu_ring *ring) + { + struct amdgpu_device *adev = ring->adev; +- u32 v; +- +- mutex_lock(&adev->grbm_idx_mutex); +- if (adev->vce.harvest_config == 0 || +- adev->vce.harvest_config == AMDGPU_VCE_HARVEST_VCE1) +- WREG32(mmGRBM_GFX_INDEX, GET_VCE_INSTANCE(0)); +- else if (adev->vce.harvest_config == AMDGPU_VCE_HARVEST_VCE0) +- WREG32(mmGRBM_GFX_INDEX, GET_VCE_INSTANCE(1)); + + if (ring == &adev->vce.ring[0]) +- v = RREG32(mmVCE_RB_RPTR); ++ return RREG32(mmVCE_RB_RPTR); + else if (ring == &adev->vce.ring[1]) +- v = RREG32(mmVCE_RB_RPTR2); ++ return RREG32(mmVCE_RB_RPTR2); + else +- v = RREG32(mmVCE_RB_RPTR3); +- +- WREG32(mmGRBM_GFX_INDEX, mmGRBM_GFX_INDEX_DEFAULT); +- mutex_unlock(&adev->grbm_idx_mutex); +- +- return v; ++ return RREG32(mmVCE_RB_RPTR3); + } + + /** +@@ -109,26 +96,13 @@ static uint64_t vce_v3_0_ring_get_rptr(struct amdgpu_ring *ring) + static uint64_t vce_v3_0_ring_get_wptr(struct amdgpu_ring *ring) + { + struct amdgpu_device *adev = ring->adev; +- u32 v; +- +- mutex_lock(&adev->grbm_idx_mutex); +- if (adev->vce.harvest_config == 0 || +- adev->vce.harvest_config == AMDGPU_VCE_HARVEST_VCE1) +- WREG32(mmGRBM_GFX_INDEX, GET_VCE_INSTANCE(0)); +- else if (adev->vce.harvest_config == AMDGPU_VCE_HARVEST_VCE0) +- WREG32(mmGRBM_GFX_INDEX, GET_VCE_INSTANCE(1)); + + if (ring == &adev->vce.ring[0]) +- v = RREG32(mmVCE_RB_WPTR); ++ return RREG32(mmVCE_RB_WPTR); + else if (ring == &adev->vce.ring[1]) +- v = RREG32(mmVCE_RB_WPTR2); ++ return RREG32(mmVCE_RB_WPTR2); + else +- v = RREG32(mmVCE_RB_WPTR3); +- +- WREG32(mmGRBM_GFX_INDEX, mmGRBM_GFX_INDEX_DEFAULT); +- mutex_unlock(&adev->grbm_idx_mutex); +- +- return v; ++ return RREG32(mmVCE_RB_WPTR3); + } + + /** +@@ -142,22 +116,12 @@ static void vce_v3_0_ring_set_wptr(struct amdgpu_ring *ring) + { + struct amdgpu_device *adev = ring->adev; + +- mutex_lock(&adev->grbm_idx_mutex); +- if (adev->vce.harvest_config == 0 || +- adev->vce.harvest_config == AMDGPU_VCE_HARVEST_VCE1) +- WREG32(mmGRBM_GFX_INDEX, GET_VCE_INSTANCE(0)); +- else if (adev->vce.harvest_config == AMDGPU_VCE_HARVEST_VCE0) +- WREG32(mmGRBM_GFX_INDEX, GET_VCE_INSTANCE(1)); +- + if (ring == &adev->vce.ring[0]) + WREG32(mmVCE_RB_WPTR, lower_32_bits(ring->wptr)); + else if (ring == &adev->vce.ring[1]) + WREG32(mmVCE_RB_WPTR2, lower_32_bits(ring->wptr)); + else + WREG32(mmVCE_RB_WPTR3, lower_32_bits(ring->wptr)); +- +- WREG32(mmGRBM_GFX_INDEX, mmGRBM_GFX_INDEX_DEFAULT); +- mutex_unlock(&adev->grbm_idx_mutex); + } + + static void vce_v3_0_override_vce_clock_gating(struct amdgpu_device *adev, bool override) +@@ -267,38 +231,33 @@ static int vce_v3_0_start(struct amdgpu_device *adev) + struct amdgpu_ring *ring; + int idx, r; + ++ ring = &adev->vce.ring[0]; ++ WREG32(mmVCE_RB_RPTR, lower_32_bits(ring->wptr)); ++ WREG32(mmVCE_RB_WPTR, lower_32_bits(ring->wptr)); ++ WREG32(mmVCE_RB_BASE_LO, ring->gpu_addr); ++ WREG32(mmVCE_RB_BASE_HI, upper_32_bits(ring->gpu_addr)); ++ WREG32(mmVCE_RB_SIZE, ring->ring_size / 4); ++ ++ ring = &adev->vce.ring[1]; ++ WREG32(mmVCE_RB_RPTR2, lower_32_bits(ring->wptr)); ++ WREG32(mmVCE_RB_WPTR2, lower_32_bits(ring->wptr)); ++ WREG32(mmVCE_RB_BASE_LO2, ring->gpu_addr); ++ WREG32(mmVCE_RB_BASE_HI2, upper_32_bits(ring->gpu_addr)); ++ WREG32(mmVCE_RB_SIZE2, ring->ring_size / 4); ++ ++ ring = &adev->vce.ring[2]; ++ WREG32(mmVCE_RB_RPTR3, lower_32_bits(ring->wptr)); ++ WREG32(mmVCE_RB_WPTR3, lower_32_bits(ring->wptr)); ++ WREG32(mmVCE_RB_BASE_LO3, ring->gpu_addr); ++ WREG32(mmVCE_RB_BASE_HI3, upper_32_bits(ring->gpu_addr)); ++ WREG32(mmVCE_RB_SIZE3, ring->ring_size / 4); ++ + mutex_lock(&adev->grbm_idx_mutex); + for (idx = 0; idx < 2; ++idx) { + if (adev->vce.harvest_config & (1 << idx)) + continue; + + WREG32(mmGRBM_GFX_INDEX, GET_VCE_INSTANCE(idx)); +- +- /* Program instance 0 reg space for two instances or instance 0 case +- program instance 1 reg space for only instance 1 available case */ +- if (idx != 1 || adev->vce.harvest_config == AMDGPU_VCE_HARVEST_VCE0) { +- ring = &adev->vce.ring[0]; +- WREG32(mmVCE_RB_RPTR, lower_32_bits(ring->wptr)); +- WREG32(mmVCE_RB_WPTR, lower_32_bits(ring->wptr)); +- WREG32(mmVCE_RB_BASE_LO, ring->gpu_addr); +- WREG32(mmVCE_RB_BASE_HI, upper_32_bits(ring->gpu_addr)); +- WREG32(mmVCE_RB_SIZE, ring->ring_size / 4); +- +- ring = &adev->vce.ring[1]; +- WREG32(mmVCE_RB_RPTR2, lower_32_bits(ring->wptr)); +- WREG32(mmVCE_RB_WPTR2, lower_32_bits(ring->wptr)); +- WREG32(mmVCE_RB_BASE_LO2, ring->gpu_addr); +- WREG32(mmVCE_RB_BASE_HI2, upper_32_bits(ring->gpu_addr)); +- WREG32(mmVCE_RB_SIZE2, ring->ring_size / 4); +- +- ring = &adev->vce.ring[2]; +- WREG32(mmVCE_RB_RPTR3, lower_32_bits(ring->wptr)); +- WREG32(mmVCE_RB_WPTR3, lower_32_bits(ring->wptr)); +- WREG32(mmVCE_RB_BASE_LO3, ring->gpu_addr); +- WREG32(mmVCE_RB_BASE_HI3, upper_32_bits(ring->gpu_addr)); +- WREG32(mmVCE_RB_SIZE3, ring->ring_size / 4); +- } +- + vce_v3_0_mc_resume(adev, idx); + WREG32_FIELD(VCE_STATUS, JOB_BUSY, 1); + +-- +2.7.4 + |