forked from Minki/linux
drm/amd/display: Don't ask PSP to load DMCUB for backdoor load
[Why] If we're doing backdoor load then do it entirely ourselves without invoking any of the frontdoor path to avoid potential issues with outdated tOS. [How] Check the load type and don't pass it to base if we don't want it loaded. Signed-off-by: Nicholas Kazlauskas <nicholas.kazlauskas@amd.com> Reviewed-by: Hersen Wu <hersenxs.wu@amd.com> Acked-by: Rodrigo Siqueira <Rodrigo.Siqueira@amd.com> Acked-by: Harry Wentland <harry.wentland@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
20a5e52f37
commit
9a6ed54709
@ -1207,17 +1207,21 @@ static int dm_dmub_sw_init(struct amdgpu_device *adev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
hdr = (const struct dmcub_firmware_header_v1_0 *)adev->dm.dmub_fw->data;
|
hdr = (const struct dmcub_firmware_header_v1_0 *)adev->dm.dmub_fw->data;
|
||||||
adev->firmware.ucode[AMDGPU_UCODE_ID_DMCUB].ucode_id =
|
|
||||||
AMDGPU_UCODE_ID_DMCUB;
|
if (adev->firmware.load_type == AMDGPU_FW_LOAD_PSP) {
|
||||||
adev->firmware.ucode[AMDGPU_UCODE_ID_DMCUB].fw = adev->dm.dmub_fw;
|
adev->firmware.ucode[AMDGPU_UCODE_ID_DMCUB].ucode_id =
|
||||||
adev->firmware.fw_size +=
|
AMDGPU_UCODE_ID_DMCUB;
|
||||||
ALIGN(le32_to_cpu(hdr->inst_const_bytes), PAGE_SIZE);
|
adev->firmware.ucode[AMDGPU_UCODE_ID_DMCUB].fw =
|
||||||
|
adev->dm.dmub_fw;
|
||||||
|
adev->firmware.fw_size +=
|
||||||
|
ALIGN(le32_to_cpu(hdr->inst_const_bytes), PAGE_SIZE);
|
||||||
|
|
||||||
|
DRM_INFO("Loading DMUB firmware via PSP: version=0x%08X\n",
|
||||||
|
adev->dm.dmcub_fw_version);
|
||||||
|
}
|
||||||
|
|
||||||
adev->dm.dmcub_fw_version = le32_to_cpu(hdr->header.ucode_version);
|
adev->dm.dmcub_fw_version = le32_to_cpu(hdr->header.ucode_version);
|
||||||
|
|
||||||
DRM_INFO("Loading DMUB firmware via PSP: version=0x%08X\n",
|
|
||||||
adev->dm.dmcub_fw_version);
|
|
||||||
|
|
||||||
adev->dm.dmub_srv = kzalloc(sizeof(*adev->dm.dmub_srv), GFP_KERNEL);
|
adev->dm.dmub_srv = kzalloc(sizeof(*adev->dm.dmub_srv), GFP_KERNEL);
|
||||||
dmub_srv = adev->dm.dmub_srv;
|
dmub_srv = adev->dm.dmub_srv;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user