Commit 879af1c6 authored by Huang Rui's avatar Huang Rui Committed by Alex Deucher

drm/amd/powerplay: introduce the function to load the soft pptable for navi10 (v2)

Driver is able to load soft pptable from smc bin file with this function. We
stored the soft pptable in the bottom of smc.bin that the version is v2.

v2: remove is_fw_v2_0 flag.
Signed-off-by: default avatarHuang Rui <ray.huang@amd.com>
Reviewed-by: default avatarHawking Zhang <Hawking.Zhang@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 0186eb96
...@@ -389,6 +389,11 @@ struct smu_context ...@@ -389,6 +389,11 @@ struct smu_context
uint32_t power_limit; uint32_t power_limit;
uint32_t default_power_limit; uint32_t default_power_limit;
/* soft pptable */
uint32_t ppt_offset_bytes;
uint32_t ppt_size_bytes;
uint8_t *ppt_start_addr;
bool support_power_containment; bool support_power_containment;
bool disable_watermark; bool disable_watermark;
......
...@@ -43,6 +43,7 @@ ...@@ -43,6 +43,7 @@
#include "asic_reg/smuio/smuio_11_0_0_sh_mask.h" #include "asic_reg/smuio/smuio_11_0_0_sh_mask.h"
MODULE_FIRMWARE("amdgpu/vega20_smc.bin"); MODULE_FIRMWARE("amdgpu/vega20_smc.bin");
MODULE_FIRMWARE("amdgpu/navi10_smc.bin");
#define SMU11_TOOL_SIZE 0x19000 #define SMU11_TOOL_SIZE 0x19000
#define SMU11_THERMAL_MINIMUM_ALERT_TEMP 0 #define SMU11_THERMAL_MINIMUM_ALERT_TEMP 0
...@@ -152,6 +153,18 @@ smu_v11_0_send_msg_with_param(struct smu_context *smu, uint16_t msg, ...@@ -152,6 +153,18 @@ smu_v11_0_send_msg_with_param(struct smu_context *smu, uint16_t msg,
return ret; return ret;
} }
static void smu_v11_0_init_smu_ext_microcode(struct smu_context *smu)
{
struct amdgpu_device *adev = smu->adev;
const struct smc_firmware_header_v2_0 *v2;
v2 = (const struct smc_firmware_header_v2_0 *) adev->pm.fw->data;
smu->ppt_offset_bytes = le32_to_cpu(v2->ppt_offset_bytes);
smu->ppt_size_bytes = le32_to_cpu(v2->ppt_size_bytes);
smu->ppt_start_addr = (uint8_t *)v2 + smu->ppt_offset_bytes;
}
static int smu_v11_0_init_microcode(struct smu_context *smu) static int smu_v11_0_init_microcode(struct smu_context *smu)
{ {
struct amdgpu_device *adev = smu->adev; struct amdgpu_device *adev = smu->adev;
...@@ -161,6 +174,7 @@ static int smu_v11_0_init_microcode(struct smu_context *smu) ...@@ -161,6 +174,7 @@ static int smu_v11_0_init_microcode(struct smu_context *smu)
const struct smc_firmware_header_v1_0 *hdr; const struct smc_firmware_header_v1_0 *hdr;
const struct common_firmware_header *header; const struct common_firmware_header *header;
struct amdgpu_firmware_info *ucode = NULL; struct amdgpu_firmware_info *ucode = NULL;
uint32_t version_major, version_minor;
switch (adev->asic_type) { switch (adev->asic_type) {
case CHIP_VEGA20: case CHIP_VEGA20:
...@@ -186,6 +200,11 @@ static int smu_v11_0_init_microcode(struct smu_context *smu) ...@@ -186,6 +200,11 @@ static int smu_v11_0_init_microcode(struct smu_context *smu)
amdgpu_ucode_print_smc_hdr(&hdr->header); amdgpu_ucode_print_smc_hdr(&hdr->header);
adev->pm.fw_version = le32_to_cpu(hdr->header.ucode_version); adev->pm.fw_version = le32_to_cpu(hdr->header.ucode_version);
version_major = le16_to_cpu(hdr->header.header_version_major);
version_minor = le16_to_cpu(hdr->header.header_version_minor);
if (version_major == 2 && version_minor == 0)
smu_v11_0_init_smu_ext_microcode(smu); /* with soft pptable */
if (adev->firmware.load_type == AMDGPU_FW_LOAD_PSP) { if (adev->firmware.load_type == AMDGPU_FW_LOAD_PSP) {
ucode = &adev->firmware.ucode[AMDGPU_UCODE_ID_SMC]; ucode = &adev->firmware.ucode[AMDGPU_UCODE_ID_SMC];
ucode->ucode_id = AMDGPU_UCODE_ID_SMC; ucode->ucode_id = AMDGPU_UCODE_ID_SMC;
...@@ -291,6 +310,11 @@ static int smu_v11_0_read_pptable_from_vbios(struct smu_context *smu) ...@@ -291,6 +310,11 @@ static int smu_v11_0_read_pptable_from_vbios(struct smu_context *smu)
uint8_t frev, crev; uint8_t frev, crev;
void *table; void *table;
if (smu->smu_table.boot_values.pp_table_id > 0 && smu->ppt_start_addr) {
/* load soft pptable */
table = (void *)smu->ppt_start_addr;
size= smu->ppt_size_bytes;
} else {
index = get_index_into_master_table(atom_master_list_of_data_tables_v2_1, index = get_index_into_master_table(atom_master_list_of_data_tables_v2_1,
powerplayinfo); powerplayinfo);
...@@ -298,6 +322,7 @@ static int smu_v11_0_read_pptable_from_vbios(struct smu_context *smu) ...@@ -298,6 +322,7 @@ static int smu_v11_0_read_pptable_from_vbios(struct smu_context *smu)
(uint8_t **)&table); (uint8_t **)&table);
if (ret) if (ret)
return ret; return ret;
}
if (!smu->smu_table.power_play_table) if (!smu->smu_table.power_play_table)
smu->smu_table.power_play_table = table; smu->smu_table.power_play_table = table;
...@@ -2076,6 +2101,7 @@ static const struct smu_funcs smu_v11_0_funcs = { ...@@ -2076,6 +2101,7 @@ static const struct smu_funcs smu_v11_0_funcs = {
.send_smc_msg_with_param = smu_v11_0_send_msg_with_param, .send_smc_msg_with_param = smu_v11_0_send_msg_with_param,
.read_smc_arg = smu_v11_0_read_arg, .read_smc_arg = smu_v11_0_read_arg,
.read_pptable_from_vbios = smu_v11_0_read_pptable_from_vbios, .read_pptable_from_vbios = smu_v11_0_read_pptable_from_vbios,
.setup_pptable = smu_v11_0_setup_pptable,
.init_smc_tables = smu_v11_0_init_smc_tables, .init_smc_tables = smu_v11_0_init_smc_tables,
.fini_smc_tables = smu_v11_0_fini_smc_tables, .fini_smc_tables = smu_v11_0_fini_smc_tables,
.init_power = smu_v11_0_init_power, .init_power = smu_v11_0_init_power,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment