drm/amdgpu: Restore partition mode after reset
On a full device reset, PSP FW gets unloaded. Hence restore the partition mode by placing a new request. Signed-off-by: Lijo Lazar <lijo.lazar@amd.com> Reviewed-by: Asad Kamal <asad.kamal@amd.com> Acked-by: Alex Deucher <alexander.deucher@amd.com> Tested-by: Asad Kamal <asad.kamal@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
f4f8a4dac0
commit
c45e38f217
@ -5137,6 +5137,11 @@ int amdgpu_do_asic_reset(struct list_head *device_list_handle,
|
||||
if (r)
|
||||
return r;
|
||||
|
||||
r = amdgpu_xcp_restore_partition_mode(
|
||||
tmp_adev->xcp_mgr);
|
||||
if (r)
|
||||
goto out;
|
||||
|
||||
r = amdgpu_device_ip_resume_phase2(tmp_adev);
|
||||
if (r)
|
||||
goto out;
|
||||
|
@ -163,16 +163,11 @@ int amdgpu_xcp_init(struct amdgpu_xcp_mgr *xcp_mgr, int num_xcps, int mode)
|
||||
return 0;
|
||||
}
|
||||
|
||||
int amdgpu_xcp_switch_partition_mode(struct amdgpu_xcp_mgr *xcp_mgr, int mode)
|
||||
static int __amdgpu_xcp_switch_partition_mode(struct amdgpu_xcp_mgr *xcp_mgr,
|
||||
int mode)
|
||||
{
|
||||
int ret, curr_mode, num_xcps = 0;
|
||||
|
||||
if (!xcp_mgr || mode == AMDGPU_XCP_MODE_NONE)
|
||||
return -EINVAL;
|
||||
|
||||
if (xcp_mgr->mode == mode)
|
||||
return 0;
|
||||
|
||||
if (!xcp_mgr->funcs || !xcp_mgr->funcs->switch_partition_mode)
|
||||
return 0;
|
||||
|
||||
@ -201,6 +196,25 @@ out:
|
||||
return ret;
|
||||
}
|
||||
|
||||
int amdgpu_xcp_switch_partition_mode(struct amdgpu_xcp_mgr *xcp_mgr, int mode)
|
||||
{
|
||||
if (!xcp_mgr || mode == AMDGPU_XCP_MODE_NONE)
|
||||
return -EINVAL;
|
||||
|
||||
if (xcp_mgr->mode == mode)
|
||||
return 0;
|
||||
|
||||
return __amdgpu_xcp_switch_partition_mode(xcp_mgr, mode);
|
||||
}
|
||||
|
||||
int amdgpu_xcp_restore_partition_mode(struct amdgpu_xcp_mgr *xcp_mgr)
|
||||
{
|
||||
if (!xcp_mgr || xcp_mgr->mode == AMDGPU_XCP_MODE_NONE)
|
||||
return 0;
|
||||
|
||||
return __amdgpu_xcp_switch_partition_mode(xcp_mgr, xcp_mgr->mode);
|
||||
}
|
||||
|
||||
int amdgpu_xcp_query_partition_mode(struct amdgpu_xcp_mgr *xcp_mgr, u32 flags)
|
||||
{
|
||||
int mode;
|
||||
|
@ -129,6 +129,7 @@ int amdgpu_xcp_mgr_init(struct amdgpu_device *adev, int init_mode,
|
||||
int amdgpu_xcp_init(struct amdgpu_xcp_mgr *xcp_mgr, int num_xcps, int mode);
|
||||
int amdgpu_xcp_query_partition_mode(struct amdgpu_xcp_mgr *xcp_mgr, u32 flags);
|
||||
int amdgpu_xcp_switch_partition_mode(struct amdgpu_xcp_mgr *xcp_mgr, int mode);
|
||||
int amdgpu_xcp_restore_partition_mode(struct amdgpu_xcp_mgr *xcp_mgr);
|
||||
int amdgpu_xcp_get_partition(struct amdgpu_xcp_mgr *xcp_mgr,
|
||||
enum AMDGPU_XCP_IP_BLOCK ip, int instance);
|
||||
|
||||
|
@ -500,7 +500,7 @@ static int aqua_vanjaram_switch_partition_mode(struct amdgpu_xcp_mgr *xcp_mgr,
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
if (adev->kfd.init_complete)
|
||||
if (adev->kfd.init_complete && !amdgpu_in_reset(adev))
|
||||
flags |= AMDGPU_XCP_OPS_KFD;
|
||||
|
||||
if (flags & AMDGPU_XCP_OPS_KFD) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user