Re: [PATCH] drm/amdgpu: Enable doorbell selfring after resize FB BAR

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Am 25.04.23 um 12:16 schrieb Shane Xiao:
[Why]
The selfring doorbell aperture will change when resize FB
BAR successfully during gmc sw init, we should reorder
the sequence of enabling doorbell selfring aperture.

[How]
Move enable_doorbell_selfring_aperture from *_common_hw_init
to *_common_late_init.

This fixes the potential issue that GPU ring its own
doorbell when this device is in translated mode when
iommu is on.

v2:
   1. Remove *_enable_doorbell_aperture functions

Signed-off-by: Shane Xiao <shane.xiao@xxxxxxx>
Signed-off-by: Aaron Liu <aaron.liu@xxxxxxx>
Tested-by: Xiaomeng Hou <Xiaomeng.Hou@xxxxxxx>
---
  drivers/gpu/drm/amd/amdgpu/nv.c    | 17 +++++++----------
  drivers/gpu/drm/amd/amdgpu/soc15.c | 19 +++++++++----------
  drivers/gpu/drm/amd/amdgpu/soc21.c | 17 +++++++----------
  3 files changed, 23 insertions(+), 30 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/nv.c b/drivers/gpu/drm/amd/amdgpu/nv.c
index dabeeab2f2ad..cb39d556c23d 100644
--- a/drivers/gpu/drm/amd/amdgpu/nv.c
+++ b/drivers/gpu/drm/amd/amdgpu/nv.c
@@ -531,13 +531,6 @@ static void nv_program_aspm(struct amdgpu_device *adev)
} -static void nv_enable_doorbell_aperture(struct amdgpu_device *adev,
-					bool enable)
-{
-	adev->nbio.funcs->enable_doorbell_aperture(adev, enable);
-	adev->nbio.funcs->enable_doorbell_selfring_aperture(adev, enable);
-}
-
  const struct amdgpu_ip_block_version nv_common_ip_block =
  {
  	.type = AMD_IP_BLOCK_TYPE_COMMON,
@@ -999,6 +992,9 @@ static int nv_common_late_init(void *handle)
  		}
  	}
+ /* enable selfring doorbell aperture */

Documenting *what* you do is usually a bad idea since that should be obvious. You need to document *why* you do it.

In other words maybe change the comment to /* Enable this late because doorbell BAR location can change during hw_init */.

+	adev->nbio.funcs->enable_doorbell_selfring_aperture(adev, true);
+
  	return 0;
  }
@@ -1038,7 +1034,7 @@ static int nv_common_hw_init(void *handle)
  	if (adev->nbio.funcs->remap_hdp_registers && !amdgpu_sriov_vf(adev))
  		adev->nbio.funcs->remap_hdp_registers(adev);
  	/* enable the doorbell aperture */
-	nv_enable_doorbell_aperture(adev, true);
+	adev->nbio.funcs->enable_doorbell_aperture(adev, true);
return 0;
  }
@@ -1047,8 +1043,9 @@ static int nv_common_hw_fini(void *handle)
  {
  	struct amdgpu_device *adev = (struct amdgpu_device *)handle;
- /* disable the doorbell aperture */
-	nv_enable_doorbell_aperture(adev, false);
+	/* disable the doorbell aperture and selfring doorbell aperture*/

Same here and all other places as well.

Apart from that looks good to me,
Christian.

+	adev->nbio.funcs->enable_doorbell_aperture(adev, false);
+	adev->nbio.funcs->enable_doorbell_selfring_aperture(adev, false);
return 0;
  }
diff --git a/drivers/gpu/drm/amd/amdgpu/soc15.c b/drivers/gpu/drm/amd/amdgpu/soc15.c
index 4d1487a9836c..2db021f6e8ac 100644
--- a/drivers/gpu/drm/amd/amdgpu/soc15.c
+++ b/drivers/gpu/drm/amd/amdgpu/soc15.c
@@ -619,13 +619,6 @@ static void soc15_program_aspm(struct amdgpu_device *adev)
  		adev->nbio.funcs->program_aspm(adev);
  }
-static void soc15_enable_doorbell_aperture(struct amdgpu_device *adev,
-					   bool enable)
-{
-	adev->nbio.funcs->enable_doorbell_aperture(adev, enable);
-	adev->nbio.funcs->enable_doorbell_selfring_aperture(adev, enable);
-}
-
  const struct amdgpu_ip_block_version vega10_common_ip_block =
  {
  	.type = AMD_IP_BLOCK_TYPE_COMMON,
@@ -1125,6 +1118,9 @@ static int soc15_common_late_init(void *handle)
  	if (amdgpu_sriov_vf(adev))
  		xgpu_ai_mailbox_get_irq(adev);
+ /* enable selfring doorbell aperture */
+	adev->nbio.funcs->enable_doorbell_selfring_aperture(adev, true);
+
  	return 0;
  }
@@ -1182,7 +1178,8 @@ static int soc15_common_hw_init(void *handle)
  		adev->nbio.funcs->remap_hdp_registers(adev);
/* enable the doorbell aperture */
-	soc15_enable_doorbell_aperture(adev, true);
+	adev->nbio.funcs->enable_doorbell_aperture(adev, true);
+
  	/* HW doorbell routing policy: doorbell writing not
  	 * in SDMA/IH/MM/ACV range will be routed to CP. So
  	 * we need to init SDMA doorbell range prior
@@ -1198,8 +1195,10 @@ static int soc15_common_hw_fini(void *handle)
  {
  	struct amdgpu_device *adev = (struct amdgpu_device *)handle;
- /* disable the doorbell aperture */
-	soc15_enable_doorbell_aperture(adev, false);
+	/* disable the doorbell aperture and selfring doorbell aperture */
+	adev->nbio.funcs->enable_doorbell_aperture(adev, false);
+	adev->nbio.funcs->enable_doorbell_selfring_aperture(adev, false);
+
  	if (amdgpu_sriov_vf(adev))
  		xgpu_ai_mailbox_put_irq(adev);
diff --git a/drivers/gpu/drm/amd/amdgpu/soc21.c b/drivers/gpu/drm/amd/amdgpu/soc21.c
index 7d59303ca2f9..21d11b7c510e 100644
--- a/drivers/gpu/drm/amd/amdgpu/soc21.c
+++ b/drivers/gpu/drm/amd/amdgpu/soc21.c
@@ -450,13 +450,6 @@ static void soc21_program_aspm(struct amdgpu_device *adev)
  		adev->nbio.funcs->program_aspm(adev);
  }
-static void soc21_enable_doorbell_aperture(struct amdgpu_device *adev,
-					bool enable)
-{
-	adev->nbio.funcs->enable_doorbell_aperture(adev, enable);
-	adev->nbio.funcs->enable_doorbell_selfring_aperture(adev, enable);
-}
-
  const struct amdgpu_ip_block_version soc21_common_ip_block =
  {
  	.type = AMD_IP_BLOCK_TYPE_COMMON,
@@ -764,6 +757,9 @@ static int soc21_common_late_init(void *handle)
  			amdgpu_irq_get(adev, &adev->nbio.ras_err_event_athub_irq, 0);
  	}
+ /* enable selfring doorbell aperture */
+	adev->nbio.funcs->enable_doorbell_selfring_aperture(adev, true);
+
  	return 0;
  }
@@ -797,7 +793,7 @@ static int soc21_common_hw_init(void *handle)
  	if (adev->nbio.funcs->remap_hdp_registers)
  		adev->nbio.funcs->remap_hdp_registers(adev);
  	/* enable the doorbell aperture */
-	soc21_enable_doorbell_aperture(adev, true);
+	adev->nbio.funcs->enable_doorbell_aperture(adev, true);
return 0;
  }
@@ -806,8 +802,9 @@ static int soc21_common_hw_fini(void *handle)
  {
  	struct amdgpu_device *adev = (struct amdgpu_device *)handle;
- /* disable the doorbell aperture */
-	soc21_enable_doorbell_aperture(adev, false);
+	/* disable the doorbell aperture and selfring doorbell aperture */
+	adev->nbio.funcs->enable_doorbell_aperture(adev, false);
+	adev->nbio.funcs->enable_doorbell_selfring_aperture(adev, false);
if (amdgpu_sriov_vf(adev)) {
  		xgpu_nv_mailbox_put_irq(adev);




[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux