GC 9.4.4 uses SPI busy status for idle detection instead of GRBM GUI_ACTIVE.
Add version check to use SPI_BUSY for 9.4.4 while keeping GRBM_STATUS
GUI_ACTIVE check for other GC versions.
v2: move this check into amdgpu_ptl_perf_monitor_ctrl(Lijo)
Signed-off-by: Perry Yuan <perry.yuan@amd.com>
Reviewed-by: Yifan Zhang <yifan1.zhang@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
*/
if (cmd->resp.status) {
dev_err(psp->adev->dev,
- "PTL command 0x%x failed, PSP response status: 0x%X\n",
- req_code, cmd->resp.status);
+ "PTL command 0x%x failed, PSP response status: 0x%X fw resp=0x%X\n",
+ req_code, cmd->resp.status,
+ cmd->resp.uresp.perf_hw_info.resp);
ret = -EIO;
goto out;
}
uint32_t ptl_fmt1, ptl_fmt2;
struct psp_context *psp;
struct amdgpu_ptl *ptl;
+ int ret;
if (!adev || !ptl_state || !fmt1 || !fmt2)
return -EINVAL;
}
}
+ /* Wait for GFX engine idle before PTL state transition */
+ if (req_code == PSP_PTL_PERF_MON_SET) {
+ ret = amdgpu_device_ip_wait_for_idle(adev,
+ AMD_IP_BLOCK_TYPE_GFX);
+ if (ret) {
+ dev_err(adev->dev, "GFX not idle before PTL operation (%d)\n", ret);
+ return ret;
+ }
+ }
+
return psp_ptl_invoke(psp, req_code, ptl_state, &ptl_fmt1, &ptl_fmt2);
}
{
struct amdgpu_device *adev = ip_block->adev;
int i, num_xcc;
+ u32 gc_ip_version;
num_xcc = NUM_XCC(adev->gfx.xcc_mask);
+ gc_ip_version = amdgpu_ip_version(adev, GC_HWIP, 0);
+
for (i = 0; i < num_xcc; i++) {
- if (REG_GET_FIELD(RREG32_SOC15(GC, GET_INST(GC, i), regGRBM_STATUS),
- GRBM_STATUS, GUI_ACTIVE))
- return false;
+ if (gc_ip_version == IP_VERSION(9, 4, 4)) {
+ if (REG_GET_FIELD(RREG32_SOC15(GC, GET_INST(GC, i), regGRBM_STATUS),
+ GRBM_STATUS, SPI_BUSY))
+ return false;
+ } else {
+ if (REG_GET_FIELD(RREG32_SOC15(GC, GET_INST(GC, i), regGRBM_STATUS),
+ GRBM_STATUS, GUI_ACTIVE))
+ return false;
+ }
}
return true;
}
if (adev->kfd.init_complete)
amdgpu_amdkfd_stop_sched(adev, pdd->dev->node_id);
- /* Wait for GFX to be idle before PTL operation */
- ret = amdgpu_device_ip_wait_for_idle(adev, AMD_IP_BLOCK_TYPE_GFX);
- if (ret)
- return -ETIMEDOUT;
-
ret = pdd->dev->kfd2kgd->ptl_ctrl(adev, PSP_PTL_PERF_MON_SET,
&ptl_state,
&pref_format1,