mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 11:18:45 +07:00
drm/amdgpu/psp: support init psp sos microcode with build-in toc
psp_firmware_header_v1_1 is used for psp sos with build-in toc Signed-off-by: Hawking Zhang <Hawking.Zhang@amd.com> Reviewed-by: Le Ma <Le.Ma@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
7d0906e83a
commit
93d8f2221b
@ -157,7 +157,7 @@ struct psp_context
|
|||||||
uint32_t toc_bin_size;
|
uint32_t toc_bin_size;
|
||||||
uint8_t *sys_start_addr;
|
uint8_t *sys_start_addr;
|
||||||
uint8_t *sos_start_addr;
|
uint8_t *sos_start_addr;
|
||||||
uint8_t *toc_start_addr
|
uint8_t *toc_start_addr;
|
||||||
|
|
||||||
/* tmr buffer */
|
/* tmr buffer */
|
||||||
struct amdgpu_bo *tmr_bo;
|
struct amdgpu_bo *tmr_bo;
|
||||||
|
@ -56,6 +56,7 @@ static int psp_v11_0_init_microcode(struct psp_context *psp)
|
|||||||
char fw_name[30];
|
char fw_name[30];
|
||||||
int err = 0;
|
int err = 0;
|
||||||
const struct psp_firmware_header_v1_0 *sos_hdr;
|
const struct psp_firmware_header_v1_0 *sos_hdr;
|
||||||
|
const struct psp_firmware_header_v1_1 *sos_hdr_v1_1;
|
||||||
const struct psp_firmware_header_v1_0 *asd_hdr;
|
const struct psp_firmware_header_v1_0 *asd_hdr;
|
||||||
const struct ta_firmware_header_v1_0 *ta_hdr;
|
const struct ta_firmware_header_v1_0 *ta_hdr;
|
||||||
|
|
||||||
@ -82,6 +83,9 @@ static int psp_v11_0_init_microcode(struct psp_context *psp)
|
|||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
sos_hdr = (const struct psp_firmware_header_v1_0 *)adev->psp.sos_fw->data;
|
sos_hdr = (const struct psp_firmware_header_v1_0 *)adev->psp.sos_fw->data;
|
||||||
|
|
||||||
|
switch (sos_hdr->header.header_version_major) {
|
||||||
|
case 1:
|
||||||
adev->psp.sos_fw_version = le32_to_cpu(sos_hdr->header.ucode_version);
|
adev->psp.sos_fw_version = le32_to_cpu(sos_hdr->header.ucode_version);
|
||||||
adev->psp.sos_feature_version = le32_to_cpu(sos_hdr->ucode_feature_version);
|
adev->psp.sos_feature_version = le32_to_cpu(sos_hdr->ucode_feature_version);
|
||||||
adev->psp.sos_bin_size = le32_to_cpu(sos_hdr->sos_size_bytes);
|
adev->psp.sos_bin_size = le32_to_cpu(sos_hdr->sos_size_bytes);
|
||||||
@ -91,6 +95,19 @@ static int psp_v11_0_init_microcode(struct psp_context *psp)
|
|||||||
le32_to_cpu(sos_hdr->header.ucode_array_offset_bytes);
|
le32_to_cpu(sos_hdr->header.ucode_array_offset_bytes);
|
||||||
adev->psp.sos_start_addr = (uint8_t *)adev->psp.sys_start_addr +
|
adev->psp.sos_start_addr = (uint8_t *)adev->psp.sys_start_addr +
|
||||||
le32_to_cpu(sos_hdr->sos_offset_bytes);
|
le32_to_cpu(sos_hdr->sos_offset_bytes);
|
||||||
|
if (sos_hdr->header.header_version_minor == 1) {
|
||||||
|
sos_hdr_v1_1 = (const struct psp_firmware_header_v1_1 *)adev->psp.sos_fw->data;
|
||||||
|
adev->psp.toc_bin_size = le32_to_cpu(sos_hdr_v1_1->toc_size_bytes);
|
||||||
|
adev->psp.toc_start_addr = (uint8_t *)adev->psp.sys_start_addr +
|
||||||
|
le32_to_cpu(sos_hdr_v1_1->toc_offset_bytes);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
dev_err(adev->dev,
|
||||||
|
"Unsupported psp sos firmware\n");
|
||||||
|
err = -EINVAL;
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
snprintf(fw_name, sizeof(fw_name), "amdgpu/%s_asd.bin", chip_name);
|
snprintf(fw_name, sizeof(fw_name), "amdgpu/%s_asd.bin", chip_name);
|
||||||
err = request_firmware(&adev->psp.asd_fw, fw_name, adev->dev);
|
err = request_firmware(&adev->psp.asd_fw, fw_name, adev->dev);
|
||||||
|
Loading…
Reference in New Issue
Block a user