Commit b2ea0dcd authored by Alex Deucher's avatar Alex Deucher

drm/radeon: load different smc firmware on some CI variants

The power tables on some variants require different firmware.
This may fix stability issues on some newer CI parts.

bug:
https://bugs.freedesktop.org/show_bug.cgi?id=91880Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 861c7fde
...@@ -53,6 +53,7 @@ MODULE_FIRMWARE("radeon/bonaire_mc.bin"); ...@@ -53,6 +53,7 @@ MODULE_FIRMWARE("radeon/bonaire_mc.bin");
MODULE_FIRMWARE("radeon/bonaire_rlc.bin"); MODULE_FIRMWARE("radeon/bonaire_rlc.bin");
MODULE_FIRMWARE("radeon/bonaire_sdma.bin"); MODULE_FIRMWARE("radeon/bonaire_sdma.bin");
MODULE_FIRMWARE("radeon/bonaire_smc.bin"); MODULE_FIRMWARE("radeon/bonaire_smc.bin");
MODULE_FIRMWARE("radeon/bonaire_k_smc.bin");
MODULE_FIRMWARE("radeon/HAWAII_pfp.bin"); MODULE_FIRMWARE("radeon/HAWAII_pfp.bin");
MODULE_FIRMWARE("radeon/HAWAII_me.bin"); MODULE_FIRMWARE("radeon/HAWAII_me.bin");
...@@ -72,6 +73,7 @@ MODULE_FIRMWARE("radeon/hawaii_mc.bin"); ...@@ -72,6 +73,7 @@ MODULE_FIRMWARE("radeon/hawaii_mc.bin");
MODULE_FIRMWARE("radeon/hawaii_rlc.bin"); MODULE_FIRMWARE("radeon/hawaii_rlc.bin");
MODULE_FIRMWARE("radeon/hawaii_sdma.bin"); MODULE_FIRMWARE("radeon/hawaii_sdma.bin");
MODULE_FIRMWARE("radeon/hawaii_smc.bin"); MODULE_FIRMWARE("radeon/hawaii_smc.bin");
MODULE_FIRMWARE("radeon/hawaii_k_smc.bin");
MODULE_FIRMWARE("radeon/KAVERI_pfp.bin"); MODULE_FIRMWARE("radeon/KAVERI_pfp.bin");
MODULE_FIRMWARE("radeon/KAVERI_me.bin"); MODULE_FIRMWARE("radeon/KAVERI_me.bin");
...@@ -1990,12 +1992,17 @@ static int cik_init_microcode(struct radeon_device *rdev) ...@@ -1990,12 +1992,17 @@ static int cik_init_microcode(struct radeon_device *rdev)
int new_fw = 0; int new_fw = 0;
int err; int err;
int num_fw; int num_fw;
bool new_smc = false;
DRM_DEBUG("\n"); DRM_DEBUG("\n");
switch (rdev->family) { switch (rdev->family) {
case CHIP_BONAIRE: case CHIP_BONAIRE:
chip_name = "BONAIRE"; chip_name = "BONAIRE";
if ((rdev->pdev->revision == 0x80) ||
(rdev->pdev->revision == 0x81) ||
(rdev->pdev->device == 0x665f))
new_smc = true;
new_chip_name = "bonaire"; new_chip_name = "bonaire";
pfp_req_size = CIK_PFP_UCODE_SIZE * 4; pfp_req_size = CIK_PFP_UCODE_SIZE * 4;
me_req_size = CIK_ME_UCODE_SIZE * 4; me_req_size = CIK_ME_UCODE_SIZE * 4;
...@@ -2010,6 +2017,8 @@ static int cik_init_microcode(struct radeon_device *rdev) ...@@ -2010,6 +2017,8 @@ static int cik_init_microcode(struct radeon_device *rdev)
break; break;
case CHIP_HAWAII: case CHIP_HAWAII:
chip_name = "HAWAII"; chip_name = "HAWAII";
if (rdev->pdev->revision == 0x80)
new_smc = true;
new_chip_name = "hawaii"; new_chip_name = "hawaii";
pfp_req_size = CIK_PFP_UCODE_SIZE * 4; pfp_req_size = CIK_PFP_UCODE_SIZE * 4;
me_req_size = CIK_ME_UCODE_SIZE * 4; me_req_size = CIK_ME_UCODE_SIZE * 4;
...@@ -2259,6 +2268,9 @@ static int cik_init_microcode(struct radeon_device *rdev) ...@@ -2259,6 +2268,9 @@ static int cik_init_microcode(struct radeon_device *rdev)
} }
} }
if (new_smc)
snprintf(fw_name, sizeof(fw_name), "radeon/%s_k_smc.bin", new_chip_name);
else
snprintf(fw_name, sizeof(fw_name), "radeon/%s_smc.bin", new_chip_name); snprintf(fw_name, sizeof(fw_name), "radeon/%s_smc.bin", new_chip_name);
err = request_firmware(&rdev->smc_fw, fw_name, rdev->dev); err = request_firmware(&rdev->smc_fw, fw_name, rdev->dev);
if (err) { if (err) {
......
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