All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH 1/2] drm/amdgpu/gmc9: print client id string for mmhub
@ 2020-09-02 18:16 Alex Deucher
  2020-09-02 18:16 ` [PATCH 2/2] drm/amdgpu/mmhub2.0: " Alex Deucher
  2020-09-03  6:36 ` [PATCH 1/2] drm/amdgpu/gmc9: " Huang Rui
  0 siblings, 2 replies; 4+ messages in thread
From: Alex Deucher @ 2020-09-02 18:16 UTC (permalink / raw)
  To: amd-gfx; +Cc: Alex Deucher

Print the name of the client rather than the number.  This
makes it easier to debug what block is causing the fault.

Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
---
 drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c | 239 +++++++++++++++++++++++++-
 1 file changed, 230 insertions(+), 9 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
index 7e86aee60c64..f9e810126124 100644
--- a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
+++ b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
@@ -87,6 +87,203 @@ static const char *gfxhub_client_ids[] = {
 	"PA",
 };
 
+static const char *mmhub_client_ids_raven[][2] = {
+	[0][0] = "MP1",
+	[1][0] = "MP0",
+	[2][0] = "VCN",
+	[3][0] = "VCNU",
+	[4][0] = "HDP",
+	[5][0] = "DCE",
+	[13][0] = "UTCL2",
+	[19][0] = "TLS",
+	[26][0] = "OSS",
+	[27][0] = "SDMA0",
+	[0][1] = "MP1",
+	[1][1] = "MP0",
+	[2][1] = "VCN",
+	[3][1] = "VCNU",
+	[4][1] = "HDP",
+	[5][1] = "XDP",
+	[6][1] = "DBGU0",
+	[7][1] = "DCE",
+	[8][1] = "DCEDWB0",
+	[9][1] = "DCEDWB1",
+	[26][1] = "OSS",
+	[27][1] = "SDMA0",
+};
+
+static const char *mmhub_client_ids_renoir[][2] = {
+	[0][0] = "MP1",
+	[1][0] = "MP0",
+	[2][0] = "HDP",
+	[4][0] = "DCEDMC",
+	[5][0] = "DCEVGA",
+	[13][0] = "UTCL2",
+	[19][0] = "TLS",
+	[26][0] = "OSS",
+	[27][0] = "SDMA0",
+	[28][0] = "VCN",
+	[29][0] = "VCNU",
+	[30][0] = "JPEG",
+	[0][1] = "MP1",
+	[1][1] = "MP0",
+	[2][1] = "HDP",
+	[3][1] = "XDP",
+	[6][1] = "DBGU0",
+	[7][1] = "DCEDMC",
+	[8][1] = "DCEVGA",
+	[9][1] = "DCEDWB",
+	[26][1] = "OSS",
+	[27][1] = "SDMA0",
+	[28][1] = "VCN",
+	[29][1] = "VCNU",
+	[30][1] = "JPEG",
+};
+
+static const char *mmhub_client_ids_vega10[][2] = {
+	[0][0] = "MP0",
+	[1][0] = "UVD",
+	[2][0] = "UVDU",
+	[3][0] = "HDP",
+	[13][0] = "UTCL2",
+	[14][0] = "OSS",
+	[15][0] = "SDMA1",
+	[32+0][0] = "VCE0",
+	[32+1][0] = "VCE0U",
+	[32+2][0] = "XDMA",
+	[32+3][0] = "DCE",
+	[32+4][0] = "MP1",
+	[32+14][0] = "SDMA0",
+	[0][1] = "MP0",
+	[1][1] = "UVD",
+	[2][1] = "UVDU",
+	[3][1] = "DBGU0",
+	[4][1] = "HDP",
+	[5][1] = "XDP",
+	[14][1] = "OSS",
+	[15][1] = "SDMA0",
+	[32+0][1] = "VCE0",
+	[32+1][1] = "VCE0U",
+	[32+2][1] = "XDMA",
+	[32+3][1] = "DCE",
+	[32+4][1] = "DCEDWB",
+	[32+5][1] = "MP1",
+	[32+6][1] = "DBGU1",
+	[32+14][1] = "SDMA1",
+};
+
+static const char *mmhub_client_ids_vega12[][2] = {
+	[0][0] = "MP0",
+	[1][0] = "VCE0",
+	[2][0] = "VCE0U",
+	[3][0] = "HDP",
+	[13][0] = "UTCL2",
+	[14][0] = "OSS",
+	[15][0] = "SDMA1",
+	[32+0][0] = "DCE",
+	[32+1][0] = "XDMA",
+	[32+2][0] = "UVD",
+	[32+3][0] = "UVDU",
+	[32+4][0] = "MP1",
+	[32+15][0] = "SDMA0",
+	[0][1] = "MP0",
+	[1][1] = "VCE0",
+	[2][1] = "VCE0U",
+	[3][1] = "DBGU0",
+	[4][1] = "HDP",
+	[5][1] = "XDP",
+	[14][1] = "OSS",
+	[15][1] = "SDMA0",
+	[32+0][1] = "DCE",
+	[32+1][1] = "DCEDWB",
+	[32+2][1] = "XDMA",
+	[32+3][1] = "UVD",
+	[32+4][1] = "UVDU",
+	[32+5][1] = "MP1",
+	[32+6][1] = "DBGU1",
+	[32+15][1] = "SDMA1",
+};
+
+static const char *mmhub_client_ids_vega20[][2] = {
+	[0][0] = "XDMA",
+	[1][0] = "DCE",
+	[2][0] = "VCE0",
+	[3][0] = "VCE0U",
+	[4][0] = "UVD",
+	[5][0] = "UVD1U",
+	[13][0] = "OSS",
+	[14][0] = "HDP",
+	[15][0] = "SDMA0",
+	[32+0][0] = "UVD",
+	[32+1][0] = "UVDU",
+	[32+2][0] = "MP1",
+	[32+3][0] = "MP0",
+	[32+12][0] = "UTCL2",
+	[32+14][0] = "SDMA1",
+	[0][1] = "XDMA",
+	[1][1] = "DCE",
+	[2][1] = "DCEDWB",
+	[3][1] = "VCE0",
+	[4][1] = "VCE0U",
+	[5][1] = "UVD1",
+	[6][1] = "UVD1U",
+	[7][1] = "DBGU0",
+	[8][1] = "XDP",
+	[13][1] = "OSS",
+	[14][1] = "HDP",
+	[15][1] = "SDMA0",
+	[32+0][1] = "UVD",
+	[32+1][1] = "UVDU",
+	[32+2][1] = "DBGU1",
+	[32+3][1] = "MP1",
+	[32+4][1] = "MP0",
+	[32+14][1] = "SDMA1",
+};
+
+static const char *mmhub_client_ids_arcturus[][2] = {
+	[2][0] = "MP1",
+	[3][0] = "MP0",
+	[10][0] = "UTCL2",
+	[13][0] = "OSS",
+	[14][0] = "HDP",
+	[15][0] = "SDMA0",
+	[32+15][0] = "SDMA1",
+	[64+15][0] = "SDMA2",
+	[96+15][0] = "SDMA3",
+	[128+15][0] = "SDMA4",
+	[160+11][0] = "JPEG",
+	[160+12][0] = "VCN",
+	[160+13][0] = "VCNU",
+	[160+15][0] = "SDMA5",
+	[192+10][0] = "UTCL2",
+	[192+11][0] = "JPEG1",
+	[192+12][0] = "VCN1",
+	[192+13][0] = "VCN1U",
+	[192+15][0] = "SDMA6",
+	[224+15][0] = "SDMA7",
+	[0][1] = "DBGU1",
+	[1][1] = "XDP",
+	[2][1] = "MP1",
+	[3][1] = "MP0",
+	[13][1] = "OSS",
+	[14][1] = "HDP",
+	[15][1] = "SDMA0",
+	[32+15][1] = "SDMA1",
+	[32+15][1] = "SDMA1",
+	[64+15][1] = "SDMA2",
+	[96+15][1] = "SDMA3",
+	[128+15][1] = "SDMA4",
+	[160+11][1] = "JPEG",
+	[160+12][1] = "VCN",
+	[160+13][1] = "VCNU",
+	[160+15][1] = "SDMA5",
+	[192+11][1] = "JPEG1",
+	[192+12][1] = "VCN1",
+	[192+13][1] = "VCN1U",
+	[192+15][1] = "SDMA6",
+	[224+15][1] = "SDMA7",
+};
+
 static const u32 golden_settings_vega10_hdp[] =
 {
 	0xf64, 0x0fffffff, 0x00000000,
@@ -319,9 +516,10 @@ static int gmc_v9_0_process_interrupt(struct amdgpu_device *adev,
 {
 	struct amdgpu_vmhub *hub;
 	bool retry_fault = !!(entry->src_data[1] & 0x80);
-	uint32_t status = 0, cid = 0;
+	uint32_t status = 0, cid = 0, rw = 0;
 	u64 addr;
 	char hub_name[10];
+	const char *mmhub_cid;
 
 	addr = (u64)entry->src_data[0] << 12;
 	addr |= ((u64)entry->src_data[1] & 0xf) << 44;
@@ -358,6 +556,8 @@ static int gmc_v9_0_process_interrupt(struct amdgpu_device *adev,
 		status = RREG32(hub->vm_l2_pro_fault_status);
 		cid = REG_GET_FIELD(status,
 				    VM_L2_PROTECTION_FAULT_STATUS, CID);
+		rw = REG_GET_FIELD(status,
+				   VM_L2_PROTECTION_FAULT_STATUS, RW);
 		WREG32_P(hub->vm_l2_pro_fault_cntl, 1, ~1);
 	}
 
@@ -380,13 +580,37 @@ static int gmc_v9_0_process_interrupt(struct amdgpu_device *adev,
 			dev_err(adev->dev,
 				"VM_L2_PROTECTION_FAULT_STATUS:0x%08X\n",
 				status);
-			if (hub == &adev->vmhub[AMDGPU_GFXHUB_0])
+			if (hub == &adev->vmhub[AMDGPU_GFXHUB_0]) {
 				dev_err(adev->dev, "\t Faulty UTCL2 client ID: %s (0x%x)\n",
 					cid >= ARRAY_SIZE(gfxhub_client_ids) ? "unknown" : gfxhub_client_ids[cid],
 					cid);
-			else
-				dev_err(adev->dev, "\t Faulty UTCL2 client ID: 0x%x\n",
-					cid);
+			} else {
+				switch (adev->asic_type) {
+				case CHIP_VEGA10:
+					mmhub_cid = mmhub_client_ids_vega10[cid][rw];
+					break;
+				case CHIP_VEGA12:
+					mmhub_cid = mmhub_client_ids_vega12[cid][rw];
+					break;
+				case CHIP_VEGA20:
+					mmhub_cid = mmhub_client_ids_vega20[cid][rw];
+					break;
+				case CHIP_ARCTURUS:
+					mmhub_cid = mmhub_client_ids_arcturus[cid][rw];
+					break;
+				case CHIP_RAVEN:
+					mmhub_cid = mmhub_client_ids_raven[cid][rw];
+					break;
+				case CHIP_RENOIR:
+					mmhub_cid = mmhub_client_ids_renoir[cid][rw];
+					break;
+				default:
+					mmhub_cid = NULL;
+					break;
+				}
+				dev_err(adev->dev, "\t Faulty UTCL2 client ID: %s (0x%x)\n",
+					mmhub_cid ? mmhub_cid : "unknown", cid);
+			}
 			dev_err(adev->dev, "\t MORE_FAULTS: 0x%lx\n",
 				REG_GET_FIELD(status,
 				VM_L2_PROTECTION_FAULT_STATUS, MORE_FAULTS));
@@ -399,10 +623,7 @@ static int gmc_v9_0_process_interrupt(struct amdgpu_device *adev,
 			dev_err(adev->dev, "\t MAPPING_ERROR: 0x%lx\n",
 				REG_GET_FIELD(status,
 				VM_L2_PROTECTION_FAULT_STATUS, MAPPING_ERROR));
-			dev_err(adev->dev, "\t RW: 0x%lx\n",
-				REG_GET_FIELD(status,
-				VM_L2_PROTECTION_FAULT_STATUS, RW));
-
+			dev_err(adev->dev, "\t RW: 0x%x\n", rw);
 		}
 	}
 
-- 
2.25.4

_______________________________________________
amd-gfx mailing list
amd-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/amd-gfx

^ permalink raw reply related	[flat|nested] 4+ messages in thread

* [PATCH 2/2] drm/amdgpu/mmhub2.0: print client id string for mmhub
  2020-09-02 18:16 [PATCH 1/2] drm/amdgpu/gmc9: print client id string for mmhub Alex Deucher
@ 2020-09-02 18:16 ` Alex Deucher
  2020-09-03  6:36 ` [PATCH 1/2] drm/amdgpu/gmc9: " Huang Rui
  1 sibling, 0 replies; 4+ messages in thread
From: Alex Deucher @ 2020-09-02 18:16 UTC (permalink / raw)
  To: amd-gfx; +Cc: Alex Deucher

Print the name of the client rather than the number.  This
makes it easier to debug what block is causing the fault.

Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
---
 drivers/gpu/drm/amd/amdgpu/mmhub_v2_0.c | 88 +++++++++++++++++++++++--
 1 file changed, 82 insertions(+), 6 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/mmhub_v2_0.c b/drivers/gpu/drm/amd/amdgpu/mmhub_v2_0.c
index 5baf899417d8..2d88278c50bf 100644
--- a/drivers/gpu/drm/amd/amdgpu/mmhub_v2_0.c
+++ b/drivers/gpu/drm/amd/amdgpu/mmhub_v2_0.c
@@ -36,6 +36,63 @@
 #define mmDAGB0_CNTL_MISC2_Sienna_Cichlid                       0x0070
 #define mmDAGB0_CNTL_MISC2_Sienna_Cichlid_BASE_IDX              0
 
+static const char *mmhub_client_ids_navi1x[][2] = {
+	[3][0] = "DCEDMC",
+	[4][0] = "DCEVGA",
+	[5][0] = "MP0",
+	[6][0] = "MP1",
+	[13][0] = "VMC",
+	[14][0] = "HDP",
+	[15][0] = "OSS",
+	[16][0] = "VCNU",
+	[17][0] = "JPEG",
+	[18][0] = "VCN",
+	[3][1] = "DCEDMC",
+	[4][1] = "DCEXFC",
+	[5][1] = "DCEVGA",
+	[6][1] = "DCEDWB",
+	[7][1] = "MP0",
+	[8][1] = "MP1",
+	[9][1] = "DBGU1",
+	[10][1] = "DBGU0",
+	[11][1] = "XDP",
+	[14][1] = "HDP",
+	[15][1] = "OSS",
+	[16][1] = "VCNU",
+	[17][1] = "JPEG",
+	[18][1] = "VCN",
+};
+
+static const char *mmhub_client_ids_sienna_cichlid[][2] = {
+	[3][0] = "DCEDMC",
+	[4][0] = "DCEVGA",
+	[5][0] = "MP0",
+	[6][0] = "MP1",
+	[8][0] = "VMC",
+	[9][0] = "VCNU0",
+	[10][0] = "JPEG",
+	[12][0] = "VCNU1",
+	[13][0] = "VCN1",
+	[14][0] = "HDP",
+	[15][0] = "OSS",
+	[32+11][0] = "VCN0",
+	[0][1] = "DBGU0",
+	[1][1] = "DBGU1",
+	[2][1] = "DCEDWB",
+	[3][1] = "DCEDMC",
+	[4][1] = "DCEVGA",
+	[5][1] = "MP0",
+	[6][1] = "MP1",
+	[7][1] = "XDP",
+	[9][1] = "VCNU0",
+	[10][1] = "JPEG",
+	[11][1] = "VCN0",
+	[12][1] = "VCNU1",
+	[13][1] = "VCN1",
+	[14][1] = "HDP",
+	[15][1] = "OSS",
+};
+
 static uint32_t mmhub_v2_0_get_invalidate_req(unsigned int vmid,
 					      uint32_t flush_type)
 {
@@ -60,12 +117,33 @@ static void
 mmhub_v2_0_print_l2_protection_fault_status(struct amdgpu_device *adev,
 					     uint32_t status)
 {
+	uint32_t cid, rw;
+	const char *mmhub_cid = NULL;
+
+	cid = REG_GET_FIELD(status,
+			    MMVM_L2_PROTECTION_FAULT_STATUS, CID);
+	rw = REG_GET_FIELD(status,
+			   MMVM_L2_PROTECTION_FAULT_STATUS, RW);
+
 	dev_err(adev->dev,
 		"MMVM_L2_PROTECTION_FAULT_STATUS:0x%08X\n",
 		status);
-	dev_err(adev->dev, "\t Faulty UTCL2 client ID: 0x%lx\n",
-		REG_GET_FIELD(status,
-		MMVM_L2_PROTECTION_FAULT_STATUS, CID));
+	switch (adev->asic_type) {
+	case CHIP_NAVI10:
+	case CHIP_NAVI12:
+	case CHIP_NAVI14:
+		mmhub_cid = mmhub_client_ids_navi1x[cid][rw];
+		break;
+	case CHIP_SIENNA_CICHLID:
+	case CHIP_NAVY_FLOUNDER:
+		mmhub_cid = mmhub_client_ids_sienna_cichlid[cid][rw];
+		break;
+	default:
+		mmhub_cid = NULL;
+		break;
+	}
+	dev_err(adev->dev, "\t Faulty UTCL2 client ID: %s (0x%x)\n",
+		mmhub_cid ? mmhub_cid : "unknown", cid);
 	dev_err(adev->dev, "\t MORE_FAULTS: 0x%lx\n",
 		REG_GET_FIELD(status,
 		MMVM_L2_PROTECTION_FAULT_STATUS, MORE_FAULTS));
@@ -78,9 +156,7 @@ mmhub_v2_0_print_l2_protection_fault_status(struct amdgpu_device *adev,
 	dev_err(adev->dev, "\t MAPPING_ERROR: 0x%lx\n",
 		REG_GET_FIELD(status,
 		MMVM_L2_PROTECTION_FAULT_STATUS, MAPPING_ERROR));
-	dev_err(adev->dev, "\t RW: 0x%lx\n",
-		REG_GET_FIELD(status,
-		MMVM_L2_PROTECTION_FAULT_STATUS, RW));
+	dev_err(adev->dev, "\t RW: 0x%x\n", rw);
 }
 
 static void mmhub_v2_0_setup_vm_pt_regs(struct amdgpu_device *adev, uint32_t vmid,
-- 
2.25.4

_______________________________________________
amd-gfx mailing list
amd-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/amd-gfx

^ permalink raw reply related	[flat|nested] 4+ messages in thread

* Re: [PATCH 1/2] drm/amdgpu/gmc9: print client id string for mmhub
  2020-09-02 18:16 [PATCH 1/2] drm/amdgpu/gmc9: print client id string for mmhub Alex Deucher
  2020-09-02 18:16 ` [PATCH 2/2] drm/amdgpu/mmhub2.0: " Alex Deucher
@ 2020-09-03  6:36 ` Huang Rui
  2020-09-03  8:11   ` Christian König
  1 sibling, 1 reply; 4+ messages in thread
From: Huang Rui @ 2020-09-03  6:36 UTC (permalink / raw)
  To: Alex Deucher; +Cc: Alex Deucher, amd-gfx

On Wed, Sep 02, 2020 at 02:16:39PM -0400, Alex Deucher wrote:
> Print the name of the client rather than the number.  This
> makes it easier to debug what block is causing the fault.
> 
> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>

Series are Reviewed-by: Huang Rui <ray.huang@amd.com>

> ---
>  drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c | 239 +++++++++++++++++++++++++-
>  1 file changed, 230 insertions(+), 9 deletions(-)
> 
> diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
> index 7e86aee60c64..f9e810126124 100644
> --- a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
> +++ b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
> @@ -87,6 +87,203 @@ static const char *gfxhub_client_ids[] = {
>  	"PA",
>  };
>  
> +static const char *mmhub_client_ids_raven[][2] = {
> +	[0][0] = "MP1",
> +	[1][0] = "MP0",
> +	[2][0] = "VCN",
> +	[3][0] = "VCNU",
> +	[4][0] = "HDP",
> +	[5][0] = "DCE",
> +	[13][0] = "UTCL2",
> +	[19][0] = "TLS",
> +	[26][0] = "OSS",
> +	[27][0] = "SDMA0",
> +	[0][1] = "MP1",
> +	[1][1] = "MP0",
> +	[2][1] = "VCN",
> +	[3][1] = "VCNU",
> +	[4][1] = "HDP",
> +	[5][1] = "XDP",
> +	[6][1] = "DBGU0",
> +	[7][1] = "DCE",
> +	[8][1] = "DCEDWB0",
> +	[9][1] = "DCEDWB1",
> +	[26][1] = "OSS",
> +	[27][1] = "SDMA0",
> +};
> +
> +static const char *mmhub_client_ids_renoir[][2] = {
> +	[0][0] = "MP1",
> +	[1][0] = "MP0",
> +	[2][0] = "HDP",
> +	[4][0] = "DCEDMC",
> +	[5][0] = "DCEVGA",
> +	[13][0] = "UTCL2",
> +	[19][0] = "TLS",
> +	[26][0] = "OSS",
> +	[27][0] = "SDMA0",
> +	[28][0] = "VCN",
> +	[29][0] = "VCNU",
> +	[30][0] = "JPEG",
> +	[0][1] = "MP1",
> +	[1][1] = "MP0",
> +	[2][1] = "HDP",
> +	[3][1] = "XDP",
> +	[6][1] = "DBGU0",
> +	[7][1] = "DCEDMC",
> +	[8][1] = "DCEVGA",
> +	[9][1] = "DCEDWB",
> +	[26][1] = "OSS",
> +	[27][1] = "SDMA0",
> +	[28][1] = "VCN",
> +	[29][1] = "VCNU",
> +	[30][1] = "JPEG",
> +};
> +
> +static const char *mmhub_client_ids_vega10[][2] = {
> +	[0][0] = "MP0",
> +	[1][0] = "UVD",
> +	[2][0] = "UVDU",
> +	[3][0] = "HDP",
> +	[13][0] = "UTCL2",
> +	[14][0] = "OSS",
> +	[15][0] = "SDMA1",
> +	[32+0][0] = "VCE0",
> +	[32+1][0] = "VCE0U",
> +	[32+2][0] = "XDMA",
> +	[32+3][0] = "DCE",
> +	[32+4][0] = "MP1",
> +	[32+14][0] = "SDMA0",
> +	[0][1] = "MP0",
> +	[1][1] = "UVD",
> +	[2][1] = "UVDU",
> +	[3][1] = "DBGU0",
> +	[4][1] = "HDP",
> +	[5][1] = "XDP",
> +	[14][1] = "OSS",
> +	[15][1] = "SDMA0",
> +	[32+0][1] = "VCE0",
> +	[32+1][1] = "VCE0U",
> +	[32+2][1] = "XDMA",
> +	[32+3][1] = "DCE",
> +	[32+4][1] = "DCEDWB",
> +	[32+5][1] = "MP1",
> +	[32+6][1] = "DBGU1",
> +	[32+14][1] = "SDMA1",
> +};
> +
> +static const char *mmhub_client_ids_vega12[][2] = {
> +	[0][0] = "MP0",
> +	[1][0] = "VCE0",
> +	[2][0] = "VCE0U",
> +	[3][0] = "HDP",
> +	[13][0] = "UTCL2",
> +	[14][0] = "OSS",
> +	[15][0] = "SDMA1",
> +	[32+0][0] = "DCE",
> +	[32+1][0] = "XDMA",
> +	[32+2][0] = "UVD",
> +	[32+3][0] = "UVDU",
> +	[32+4][0] = "MP1",
> +	[32+15][0] = "SDMA0",
> +	[0][1] = "MP0",
> +	[1][1] = "VCE0",
> +	[2][1] = "VCE0U",
> +	[3][1] = "DBGU0",
> +	[4][1] = "HDP",
> +	[5][1] = "XDP",
> +	[14][1] = "OSS",
> +	[15][1] = "SDMA0",
> +	[32+0][1] = "DCE",
> +	[32+1][1] = "DCEDWB",
> +	[32+2][1] = "XDMA",
> +	[32+3][1] = "UVD",
> +	[32+4][1] = "UVDU",
> +	[32+5][1] = "MP1",
> +	[32+6][1] = "DBGU1",
> +	[32+15][1] = "SDMA1",
> +};
> +
> +static const char *mmhub_client_ids_vega20[][2] = {
> +	[0][0] = "XDMA",
> +	[1][0] = "DCE",
> +	[2][0] = "VCE0",
> +	[3][0] = "VCE0U",
> +	[4][0] = "UVD",
> +	[5][0] = "UVD1U",
> +	[13][0] = "OSS",
> +	[14][0] = "HDP",
> +	[15][0] = "SDMA0",
> +	[32+0][0] = "UVD",
> +	[32+1][0] = "UVDU",
> +	[32+2][0] = "MP1",
> +	[32+3][0] = "MP0",
> +	[32+12][0] = "UTCL2",
> +	[32+14][0] = "SDMA1",
> +	[0][1] = "XDMA",
> +	[1][1] = "DCE",
> +	[2][1] = "DCEDWB",
> +	[3][1] = "VCE0",
> +	[4][1] = "VCE0U",
> +	[5][1] = "UVD1",
> +	[6][1] = "UVD1U",
> +	[7][1] = "DBGU0",
> +	[8][1] = "XDP",
> +	[13][1] = "OSS",
> +	[14][1] = "HDP",
> +	[15][1] = "SDMA0",
> +	[32+0][1] = "UVD",
> +	[32+1][1] = "UVDU",
> +	[32+2][1] = "DBGU1",
> +	[32+3][1] = "MP1",
> +	[32+4][1] = "MP0",
> +	[32+14][1] = "SDMA1",
> +};
> +
> +static const char *mmhub_client_ids_arcturus[][2] = {
> +	[2][0] = "MP1",
> +	[3][0] = "MP0",
> +	[10][0] = "UTCL2",
> +	[13][0] = "OSS",
> +	[14][0] = "HDP",
> +	[15][0] = "SDMA0",
> +	[32+15][0] = "SDMA1",
> +	[64+15][0] = "SDMA2",
> +	[96+15][0] = "SDMA3",
> +	[128+15][0] = "SDMA4",
> +	[160+11][0] = "JPEG",
> +	[160+12][0] = "VCN",
> +	[160+13][0] = "VCNU",
> +	[160+15][0] = "SDMA5",
> +	[192+10][0] = "UTCL2",
> +	[192+11][0] = "JPEG1",
> +	[192+12][0] = "VCN1",
> +	[192+13][0] = "VCN1U",
> +	[192+15][0] = "SDMA6",
> +	[224+15][0] = "SDMA7",
> +	[0][1] = "DBGU1",
> +	[1][1] = "XDP",
> +	[2][1] = "MP1",
> +	[3][1] = "MP0",
> +	[13][1] = "OSS",
> +	[14][1] = "HDP",
> +	[15][1] = "SDMA0",
> +	[32+15][1] = "SDMA1",
> +	[32+15][1] = "SDMA1",
> +	[64+15][1] = "SDMA2",
> +	[96+15][1] = "SDMA3",
> +	[128+15][1] = "SDMA4",
> +	[160+11][1] = "JPEG",
> +	[160+12][1] = "VCN",
> +	[160+13][1] = "VCNU",
> +	[160+15][1] = "SDMA5",
> +	[192+11][1] = "JPEG1",
> +	[192+12][1] = "VCN1",
> +	[192+13][1] = "VCN1U",
> +	[192+15][1] = "SDMA6",
> +	[224+15][1] = "SDMA7",
> +};
> +
>  static const u32 golden_settings_vega10_hdp[] =
>  {
>  	0xf64, 0x0fffffff, 0x00000000,
> @@ -319,9 +516,10 @@ static int gmc_v9_0_process_interrupt(struct amdgpu_device *adev,
>  {
>  	struct amdgpu_vmhub *hub;
>  	bool retry_fault = !!(entry->src_data[1] & 0x80);
> -	uint32_t status = 0, cid = 0;
> +	uint32_t status = 0, cid = 0, rw = 0;
>  	u64 addr;
>  	char hub_name[10];
> +	const char *mmhub_cid;
>  
>  	addr = (u64)entry->src_data[0] << 12;
>  	addr |= ((u64)entry->src_data[1] & 0xf) << 44;
> @@ -358,6 +556,8 @@ static int gmc_v9_0_process_interrupt(struct amdgpu_device *adev,
>  		status = RREG32(hub->vm_l2_pro_fault_status);
>  		cid = REG_GET_FIELD(status,
>  				    VM_L2_PROTECTION_FAULT_STATUS, CID);
> +		rw = REG_GET_FIELD(status,
> +				   VM_L2_PROTECTION_FAULT_STATUS, RW);
>  		WREG32_P(hub->vm_l2_pro_fault_cntl, 1, ~1);
>  	}
>  
> @@ -380,13 +580,37 @@ static int gmc_v9_0_process_interrupt(struct amdgpu_device *adev,
>  			dev_err(adev->dev,
>  				"VM_L2_PROTECTION_FAULT_STATUS:0x%08X\n",
>  				status);
> -			if (hub == &adev->vmhub[AMDGPU_GFXHUB_0])
> +			if (hub == &adev->vmhub[AMDGPU_GFXHUB_0]) {
>  				dev_err(adev->dev, "\t Faulty UTCL2 client ID: %s (0x%x)\n",
>  					cid >= ARRAY_SIZE(gfxhub_client_ids) ? "unknown" : gfxhub_client_ids[cid],
>  					cid);
> -			else
> -				dev_err(adev->dev, "\t Faulty UTCL2 client ID: 0x%x\n",
> -					cid);
> +			} else {
> +				switch (adev->asic_type) {
> +				case CHIP_VEGA10:
> +					mmhub_cid = mmhub_client_ids_vega10[cid][rw];
> +					break;
> +				case CHIP_VEGA12:
> +					mmhub_cid = mmhub_client_ids_vega12[cid][rw];
> +					break;
> +				case CHIP_VEGA20:
> +					mmhub_cid = mmhub_client_ids_vega20[cid][rw];
> +					break;
> +				case CHIP_ARCTURUS:
> +					mmhub_cid = mmhub_client_ids_arcturus[cid][rw];
> +					break;
> +				case CHIP_RAVEN:
> +					mmhub_cid = mmhub_client_ids_raven[cid][rw];
> +					break;
> +				case CHIP_RENOIR:
> +					mmhub_cid = mmhub_client_ids_renoir[cid][rw];
> +					break;
> +				default:
> +					mmhub_cid = NULL;
> +					break;
> +				}
> +				dev_err(adev->dev, "\t Faulty UTCL2 client ID: %s (0x%x)\n",
> +					mmhub_cid ? mmhub_cid : "unknown", cid);
> +			}
>  			dev_err(adev->dev, "\t MORE_FAULTS: 0x%lx\n",
>  				REG_GET_FIELD(status,
>  				VM_L2_PROTECTION_FAULT_STATUS, MORE_FAULTS));
> @@ -399,10 +623,7 @@ static int gmc_v9_0_process_interrupt(struct amdgpu_device *adev,
>  			dev_err(adev->dev, "\t MAPPING_ERROR: 0x%lx\n",
>  				REG_GET_FIELD(status,
>  				VM_L2_PROTECTION_FAULT_STATUS, MAPPING_ERROR));
> -			dev_err(adev->dev, "\t RW: 0x%lx\n",
> -				REG_GET_FIELD(status,
> -				VM_L2_PROTECTION_FAULT_STATUS, RW));
> -
> +			dev_err(adev->dev, "\t RW: 0x%x\n", rw);
>  		}
>  	}
>  
> -- 
> 2.25.4
> 
> _______________________________________________
> amd-gfx mailing list
> amd-gfx@lists.freedesktop.org
> https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Flists.freedesktop.org%2Fmailman%2Flistinfo%2Famd-gfx&amp;data=02%7C01%7Cray.huang%40amd.com%7Cacb1cf0cc5064b3dfbd008d84f6c5fd0%7C3dd8961fe4884e608e11a82d994e183d%7C0%7C0%7C637346674195023748&amp;sdata=zZRNUXfycewKxFwuVk1gBGc9CiPGIOhhm1Uv9KAeoec%3D&amp;reserved=0
_______________________________________________
amd-gfx mailing list
amd-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/amd-gfx

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH 1/2] drm/amdgpu/gmc9: print client id string for mmhub
  2020-09-03  6:36 ` [PATCH 1/2] drm/amdgpu/gmc9: " Huang Rui
@ 2020-09-03  8:11   ` Christian König
  0 siblings, 0 replies; 4+ messages in thread
From: Christian König @ 2020-09-03  8:11 UTC (permalink / raw)
  To: Huang Rui, Alex Deucher; +Cc: Alex Deucher, amd-gfx

Am 03.09.20 um 08:36 schrieb Huang Rui:
> On Wed, Sep 02, 2020 at 02:16:39PM -0400, Alex Deucher wrote:
>> Print the name of the client rather than the number.  This
>> makes it easier to debug what block is causing the fault.
>>
>> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
> Series are Reviewed-by: Huang Rui <ray.huang@amd.com>

I would delegate that to the mmhub_v1_0 on gfx9 as well, but that's just 
an idea for a cleanup.

Series Reviewed-by: Christian König <christian.koenig@amd.com>

>
>> ---
>>   drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c | 239 +++++++++++++++++++++++++-
>>   1 file changed, 230 insertions(+), 9 deletions(-)
>>
>> diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
>> index 7e86aee60c64..f9e810126124 100644
>> --- a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
>> +++ b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
>> @@ -87,6 +87,203 @@ static const char *gfxhub_client_ids[] = {
>>   	"PA",
>>   };
>>   
>> +static const char *mmhub_client_ids_raven[][2] = {
>> +	[0][0] = "MP1",
>> +	[1][0] = "MP0",
>> +	[2][0] = "VCN",
>> +	[3][0] = "VCNU",
>> +	[4][0] = "HDP",
>> +	[5][0] = "DCE",
>> +	[13][0] = "UTCL2",
>> +	[19][0] = "TLS",
>> +	[26][0] = "OSS",
>> +	[27][0] = "SDMA0",
>> +	[0][1] = "MP1",
>> +	[1][1] = "MP0",
>> +	[2][1] = "VCN",
>> +	[3][1] = "VCNU",
>> +	[4][1] = "HDP",
>> +	[5][1] = "XDP",
>> +	[6][1] = "DBGU0",
>> +	[7][1] = "DCE",
>> +	[8][1] = "DCEDWB0",
>> +	[9][1] = "DCEDWB1",
>> +	[26][1] = "OSS",
>> +	[27][1] = "SDMA0",
>> +};
>> +
>> +static const char *mmhub_client_ids_renoir[][2] = {
>> +	[0][0] = "MP1",
>> +	[1][0] = "MP0",
>> +	[2][0] = "HDP",
>> +	[4][0] = "DCEDMC",
>> +	[5][0] = "DCEVGA",
>> +	[13][0] = "UTCL2",
>> +	[19][0] = "TLS",
>> +	[26][0] = "OSS",
>> +	[27][0] = "SDMA0",
>> +	[28][0] = "VCN",
>> +	[29][0] = "VCNU",
>> +	[30][0] = "JPEG",
>> +	[0][1] = "MP1",
>> +	[1][1] = "MP0",
>> +	[2][1] = "HDP",
>> +	[3][1] = "XDP",
>> +	[6][1] = "DBGU0",
>> +	[7][1] = "DCEDMC",
>> +	[8][1] = "DCEVGA",
>> +	[9][1] = "DCEDWB",
>> +	[26][1] = "OSS",
>> +	[27][1] = "SDMA0",
>> +	[28][1] = "VCN",
>> +	[29][1] = "VCNU",
>> +	[30][1] = "JPEG",
>> +};
>> +
>> +static const char *mmhub_client_ids_vega10[][2] = {
>> +	[0][0] = "MP0",
>> +	[1][0] = "UVD",
>> +	[2][0] = "UVDU",
>> +	[3][0] = "HDP",
>> +	[13][0] = "UTCL2",
>> +	[14][0] = "OSS",
>> +	[15][0] = "SDMA1",
>> +	[32+0][0] = "VCE0",
>> +	[32+1][0] = "VCE0U",
>> +	[32+2][0] = "XDMA",
>> +	[32+3][0] = "DCE",
>> +	[32+4][0] = "MP1",
>> +	[32+14][0] = "SDMA0",
>> +	[0][1] = "MP0",
>> +	[1][1] = "UVD",
>> +	[2][1] = "UVDU",
>> +	[3][1] = "DBGU0",
>> +	[4][1] = "HDP",
>> +	[5][1] = "XDP",
>> +	[14][1] = "OSS",
>> +	[15][1] = "SDMA0",
>> +	[32+0][1] = "VCE0",
>> +	[32+1][1] = "VCE0U",
>> +	[32+2][1] = "XDMA",
>> +	[32+3][1] = "DCE",
>> +	[32+4][1] = "DCEDWB",
>> +	[32+5][1] = "MP1",
>> +	[32+6][1] = "DBGU1",
>> +	[32+14][1] = "SDMA1",
>> +};
>> +
>> +static const char *mmhub_client_ids_vega12[][2] = {
>> +	[0][0] = "MP0",
>> +	[1][0] = "VCE0",
>> +	[2][0] = "VCE0U",
>> +	[3][0] = "HDP",
>> +	[13][0] = "UTCL2",
>> +	[14][0] = "OSS",
>> +	[15][0] = "SDMA1",
>> +	[32+0][0] = "DCE",
>> +	[32+1][0] = "XDMA",
>> +	[32+2][0] = "UVD",
>> +	[32+3][0] = "UVDU",
>> +	[32+4][0] = "MP1",
>> +	[32+15][0] = "SDMA0",
>> +	[0][1] = "MP0",
>> +	[1][1] = "VCE0",
>> +	[2][1] = "VCE0U",
>> +	[3][1] = "DBGU0",
>> +	[4][1] = "HDP",
>> +	[5][1] = "XDP",
>> +	[14][1] = "OSS",
>> +	[15][1] = "SDMA0",
>> +	[32+0][1] = "DCE",
>> +	[32+1][1] = "DCEDWB",
>> +	[32+2][1] = "XDMA",
>> +	[32+3][1] = "UVD",
>> +	[32+4][1] = "UVDU",
>> +	[32+5][1] = "MP1",
>> +	[32+6][1] = "DBGU1",
>> +	[32+15][1] = "SDMA1",
>> +};
>> +
>> +static const char *mmhub_client_ids_vega20[][2] = {
>> +	[0][0] = "XDMA",
>> +	[1][0] = "DCE",
>> +	[2][0] = "VCE0",
>> +	[3][0] = "VCE0U",
>> +	[4][0] = "UVD",
>> +	[5][0] = "UVD1U",
>> +	[13][0] = "OSS",
>> +	[14][0] = "HDP",
>> +	[15][0] = "SDMA0",
>> +	[32+0][0] = "UVD",
>> +	[32+1][0] = "UVDU",
>> +	[32+2][0] = "MP1",
>> +	[32+3][0] = "MP0",
>> +	[32+12][0] = "UTCL2",
>> +	[32+14][0] = "SDMA1",
>> +	[0][1] = "XDMA",
>> +	[1][1] = "DCE",
>> +	[2][1] = "DCEDWB",
>> +	[3][1] = "VCE0",
>> +	[4][1] = "VCE0U",
>> +	[5][1] = "UVD1",
>> +	[6][1] = "UVD1U",
>> +	[7][1] = "DBGU0",
>> +	[8][1] = "XDP",
>> +	[13][1] = "OSS",
>> +	[14][1] = "HDP",
>> +	[15][1] = "SDMA0",
>> +	[32+0][1] = "UVD",
>> +	[32+1][1] = "UVDU",
>> +	[32+2][1] = "DBGU1",
>> +	[32+3][1] = "MP1",
>> +	[32+4][1] = "MP0",
>> +	[32+14][1] = "SDMA1",
>> +};
>> +
>> +static const char *mmhub_client_ids_arcturus[][2] = {
>> +	[2][0] = "MP1",
>> +	[3][0] = "MP0",
>> +	[10][0] = "UTCL2",
>> +	[13][0] = "OSS",
>> +	[14][0] = "HDP",
>> +	[15][0] = "SDMA0",
>> +	[32+15][0] = "SDMA1",
>> +	[64+15][0] = "SDMA2",
>> +	[96+15][0] = "SDMA3",
>> +	[128+15][0] = "SDMA4",
>> +	[160+11][0] = "JPEG",
>> +	[160+12][0] = "VCN",
>> +	[160+13][0] = "VCNU",
>> +	[160+15][0] = "SDMA5",
>> +	[192+10][0] = "UTCL2",
>> +	[192+11][0] = "JPEG1",
>> +	[192+12][0] = "VCN1",
>> +	[192+13][0] = "VCN1U",
>> +	[192+15][0] = "SDMA6",
>> +	[224+15][0] = "SDMA7",
>> +	[0][1] = "DBGU1",
>> +	[1][1] = "XDP",
>> +	[2][1] = "MP1",
>> +	[3][1] = "MP0",
>> +	[13][1] = "OSS",
>> +	[14][1] = "HDP",
>> +	[15][1] = "SDMA0",
>> +	[32+15][1] = "SDMA1",
>> +	[32+15][1] = "SDMA1",
>> +	[64+15][1] = "SDMA2",
>> +	[96+15][1] = "SDMA3",
>> +	[128+15][1] = "SDMA4",
>> +	[160+11][1] = "JPEG",
>> +	[160+12][1] = "VCN",
>> +	[160+13][1] = "VCNU",
>> +	[160+15][1] = "SDMA5",
>> +	[192+11][1] = "JPEG1",
>> +	[192+12][1] = "VCN1",
>> +	[192+13][1] = "VCN1U",
>> +	[192+15][1] = "SDMA6",
>> +	[224+15][1] = "SDMA7",
>> +};
>> +
>>   static const u32 golden_settings_vega10_hdp[] =
>>   {
>>   	0xf64, 0x0fffffff, 0x00000000,
>> @@ -319,9 +516,10 @@ static int gmc_v9_0_process_interrupt(struct amdgpu_device *adev,
>>   {
>>   	struct amdgpu_vmhub *hub;
>>   	bool retry_fault = !!(entry->src_data[1] & 0x80);
>> -	uint32_t status = 0, cid = 0;
>> +	uint32_t status = 0, cid = 0, rw = 0;
>>   	u64 addr;
>>   	char hub_name[10];
>> +	const char *mmhub_cid;
>>   
>>   	addr = (u64)entry->src_data[0] << 12;
>>   	addr |= ((u64)entry->src_data[1] & 0xf) << 44;
>> @@ -358,6 +556,8 @@ static int gmc_v9_0_process_interrupt(struct amdgpu_device *adev,
>>   		status = RREG32(hub->vm_l2_pro_fault_status);
>>   		cid = REG_GET_FIELD(status,
>>   				    VM_L2_PROTECTION_FAULT_STATUS, CID);
>> +		rw = REG_GET_FIELD(status,
>> +				   VM_L2_PROTECTION_FAULT_STATUS, RW);
>>   		WREG32_P(hub->vm_l2_pro_fault_cntl, 1, ~1);
>>   	}
>>   
>> @@ -380,13 +580,37 @@ static int gmc_v9_0_process_interrupt(struct amdgpu_device *adev,
>>   			dev_err(adev->dev,
>>   				"VM_L2_PROTECTION_FAULT_STATUS:0x%08X\n",
>>   				status);
>> -			if (hub == &adev->vmhub[AMDGPU_GFXHUB_0])
>> +			if (hub == &adev->vmhub[AMDGPU_GFXHUB_0]) {
>>   				dev_err(adev->dev, "\t Faulty UTCL2 client ID: %s (0x%x)\n",
>>   					cid >= ARRAY_SIZE(gfxhub_client_ids) ? "unknown" : gfxhub_client_ids[cid],
>>   					cid);
>> -			else
>> -				dev_err(adev->dev, "\t Faulty UTCL2 client ID: 0x%x\n",
>> -					cid);
>> +			} else {
>> +				switch (adev->asic_type) {
>> +				case CHIP_VEGA10:
>> +					mmhub_cid = mmhub_client_ids_vega10[cid][rw];
>> +					break;
>> +				case CHIP_VEGA12:
>> +					mmhub_cid = mmhub_client_ids_vega12[cid][rw];
>> +					break;
>> +				case CHIP_VEGA20:
>> +					mmhub_cid = mmhub_client_ids_vega20[cid][rw];
>> +					break;
>> +				case CHIP_ARCTURUS:
>> +					mmhub_cid = mmhub_client_ids_arcturus[cid][rw];
>> +					break;
>> +				case CHIP_RAVEN:
>> +					mmhub_cid = mmhub_client_ids_raven[cid][rw];
>> +					break;
>> +				case CHIP_RENOIR:
>> +					mmhub_cid = mmhub_client_ids_renoir[cid][rw];
>> +					break;
>> +				default:
>> +					mmhub_cid = NULL;
>> +					break;
>> +				}
>> +				dev_err(adev->dev, "\t Faulty UTCL2 client ID: %s (0x%x)\n",
>> +					mmhub_cid ? mmhub_cid : "unknown", cid);
>> +			}
>>   			dev_err(adev->dev, "\t MORE_FAULTS: 0x%lx\n",
>>   				REG_GET_FIELD(status,
>>   				VM_L2_PROTECTION_FAULT_STATUS, MORE_FAULTS));
>> @@ -399,10 +623,7 @@ static int gmc_v9_0_process_interrupt(struct amdgpu_device *adev,
>>   			dev_err(adev->dev, "\t MAPPING_ERROR: 0x%lx\n",
>>   				REG_GET_FIELD(status,
>>   				VM_L2_PROTECTION_FAULT_STATUS, MAPPING_ERROR));
>> -			dev_err(adev->dev, "\t RW: 0x%lx\n",
>> -				REG_GET_FIELD(status,
>> -				VM_L2_PROTECTION_FAULT_STATUS, RW));
>> -
>> +			dev_err(adev->dev, "\t RW: 0x%x\n", rw);
>>   		}
>>   	}
>>   
>> -- 
>> 2.25.4
>>
>> _______________________________________________
>> amd-gfx mailing list
>> amd-gfx@lists.freedesktop.org
>> https://nam11.safelinks.protection.outlook.com/?url=https%3A%2F%2Flists.freedesktop.org%2Fmailman%2Flistinfo%2Famd-gfx&amp;data=02%7C01%7Cray.huang%40amd.com%7Cacb1cf0cc5064b3dfbd008d84f6c5fd0%7C3dd8961fe4884e608e11a82d994e183d%7C0%7C0%7C637346674195023748&amp;sdata=zZRNUXfycewKxFwuVk1gBGc9CiPGIOhhm1Uv9KAeoec%3D&amp;reserved=0
> _______________________________________________
> amd-gfx mailing list
> amd-gfx@lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/amd-gfx

_______________________________________________
amd-gfx mailing list
amd-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/amd-gfx

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2020-09-03  8:11 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2020-09-02 18:16 [PATCH 1/2] drm/amdgpu/gmc9: print client id string for mmhub Alex Deucher
2020-09-02 18:16 ` [PATCH 2/2] drm/amdgpu/mmhub2.0: " Alex Deucher
2020-09-03  6:36 ` [PATCH 1/2] drm/amdgpu/gmc9: " Huang Rui
2020-09-03  8:11   ` Christian König

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.