RE: [PATCH] drm/amdgpu/discovery: validate VCN and SDMA instances

2022-05-16 Thread Chen, Guchun
Reviewed-by: Guchun Chen 

Regards,
Guchun

-Original Message-
From: amd-gfx  On Behalf Of Alex Deucher
Sent: Tuesday, May 17, 2022 2:17 AM
To: amd-gfx@lists.freedesktop.org
Cc: Deucher, Alexander 
Subject: [PATCH] drm/amdgpu/discovery: validate VCN and SDMA instances

Validate the VCN and SDMA instances against the driver structure sizes to make 
sure we don't get into a situation where the firmware reports more instances 
than the driver supports.

Signed-off-by: Alex Deucher 
---
 drivers/gpu/drm/amd/amdgpu/amdgpu_discovery.c | 17 ++---
 1 file changed, 14 insertions(+), 3 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_discovery.c 
b/drivers/gpu/drm/amd/amdgpu/amdgpu_discovery.c
index 1f4e07a32445..2c4f1adb5343 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_discovery.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_discovery.c
@@ -1137,13 +1137,24 @@ static int amdgpu_discovery_reg_base_init(struct 
amdgpu_device *adev)
adev->vcn.vcn_config[adev->vcn.num_vcn_inst] =
ip->revision & 0xc0;
ip->revision &= ~0xc0;
-   adev->vcn.num_vcn_inst++;
+   if (adev->vcn.num_vcn_inst < 
AMDGPU_MAX_VCN_INSTANCES)
+   adev->vcn.num_vcn_inst++;
+   else
+   dev_err(adev->dev, "Too many VCN 
instances: %d vs %d\n",
+   adev->vcn.num_vcn_inst + 1,
+   AMDGPU_MAX_VCN_INSTANCES);
}
if (le16_to_cpu(ip->hw_id) == SDMA0_HWID ||
le16_to_cpu(ip->hw_id) == SDMA1_HWID ||
le16_to_cpu(ip->hw_id) == SDMA2_HWID ||
-   le16_to_cpu(ip->hw_id) == SDMA3_HWID)
-   adev->sdma.num_instances++;
+   le16_to_cpu(ip->hw_id) == SDMA3_HWID) {
+   if (adev->sdma.num_instances < 
AMDGPU_MAX_SDMA_INSTANCES)
+   adev->sdma.num_instances++;
+   else
+   dev_err(adev->dev, "Too many SDMA 
instances: %d vs %d\n",
+   adev->sdma.num_instances + 1,
+   AMDGPU_MAX_SDMA_INSTANCES);
+   }
 
if (le16_to_cpu(ip->hw_id) == UMC_HWID)
adev->gmc.num_umc++;
--
2.35.3



[PATCH] drm/amdgpu/discovery: validate VCN and SDMA instances

2022-05-16 Thread Alex Deucher
Validate the VCN and SDMA instances against the driver
structure sizes to make sure we don't get into a
situation where the firmware reports more instances than
the driver supports.

Signed-off-by: Alex Deucher 
---
 drivers/gpu/drm/amd/amdgpu/amdgpu_discovery.c | 17 ++---
 1 file changed, 14 insertions(+), 3 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_discovery.c 
b/drivers/gpu/drm/amd/amdgpu/amdgpu_discovery.c
index 1f4e07a32445..2c4f1adb5343 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_discovery.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_discovery.c
@@ -1137,13 +1137,24 @@ static int amdgpu_discovery_reg_base_init(struct 
amdgpu_device *adev)
adev->vcn.vcn_config[adev->vcn.num_vcn_inst] =
ip->revision & 0xc0;
ip->revision &= ~0xc0;
-   adev->vcn.num_vcn_inst++;
+   if (adev->vcn.num_vcn_inst < 
AMDGPU_MAX_VCN_INSTANCES)
+   adev->vcn.num_vcn_inst++;
+   else
+   dev_err(adev->dev, "Too many VCN 
instances: %d vs %d\n",
+   adev->vcn.num_vcn_inst + 1,
+   AMDGPU_MAX_VCN_INSTANCES);
}
if (le16_to_cpu(ip->hw_id) == SDMA0_HWID ||
le16_to_cpu(ip->hw_id) == SDMA1_HWID ||
le16_to_cpu(ip->hw_id) == SDMA2_HWID ||
-   le16_to_cpu(ip->hw_id) == SDMA3_HWID)
-   adev->sdma.num_instances++;
+   le16_to_cpu(ip->hw_id) == SDMA3_HWID) {
+   if (adev->sdma.num_instances < 
AMDGPU_MAX_SDMA_INSTANCES)
+   adev->sdma.num_instances++;
+   else
+   dev_err(adev->dev, "Too many SDMA 
instances: %d vs %d\n",
+   adev->sdma.num_instances + 1,
+   AMDGPU_MAX_SDMA_INSTANCES);
+   }
 
if (le16_to_cpu(ip->hw_id) == UMC_HWID)
adev->gmc.num_umc++;
-- 
2.35.3