diff options
| -rw-r--r-- | drivers/gpu/drm/amd/powerplay/hwmgr/vega20_hwmgr.c | 47 |
1 files changed, 27 insertions, 20 deletions
diff --git a/drivers/gpu/drm/amd/powerplay/hwmgr/vega20_hwmgr.c b/drivers/gpu/drm/amd/powerplay/hwmgr/vega20_hwmgr.c index da022ca79b56..0769b1ec562b 100644 --- a/drivers/gpu/drm/amd/powerplay/hwmgr/vega20_hwmgr.c +++ b/drivers/gpu/drm/amd/powerplay/hwmgr/vega20_hwmgr.c | |||
| @@ -771,40 +771,47 @@ static int vega20_init_smc_table(struct pp_hwmgr *hwmgr) | |||
| 771 | return 0; | 771 | return 0; |
| 772 | } | 772 | } |
| 773 | 773 | ||
| 774 | /* | ||
| 775 | * Override PCIe link speed and link width for DPM Level 1. PPTable entries | ||
| 776 | * reflect the ASIC capabilities and not the system capabilities. For e.g. | ||
| 777 | * Vega20 board in a PCI Gen3 system. In this case, when SMU's tries to switch | ||
| 778 | * to DPM1, it fails as system doesn't support Gen4. | ||
| 779 | */ | ||
| 774 | static int vega20_override_pcie_parameters(struct pp_hwmgr *hwmgr) | 780 | static int vega20_override_pcie_parameters(struct pp_hwmgr *hwmgr) |
| 775 | { | 781 | { |
| 776 | struct amdgpu_device *adev = (struct amdgpu_device *)(hwmgr->adev); | 782 | struct amdgpu_device *adev = (struct amdgpu_device *)(hwmgr->adev); |
| 777 | uint32_t pcie_speed = 0, pcie_width = 0, pcie_arg; | 783 | uint32_t pcie_gen = 0, pcie_width = 0, smu_pcie_arg; |
| 778 | int ret; | 784 | int ret; |
| 779 | 785 | ||
| 780 | if (adev->pm.pcie_gen_mask & CAIL_PCIE_LINK_SPEED_SUPPORT_GEN4) | 786 | if (adev->pm.pcie_gen_mask & CAIL_PCIE_LINK_SPEED_SUPPORT_GEN4) |
| 781 | pcie_speed = 16; | 787 | pcie_gen = 3; |
| 782 | else if (adev->pm.pcie_gen_mask & CAIL_PCIE_LINK_SPEED_SUPPORT_GEN3) | 788 | else if (adev->pm.pcie_gen_mask & CAIL_PCIE_LINK_SPEED_SUPPORT_GEN3) |
| 783 | pcie_speed = 8; | 789 | pcie_gen = 2; |
| 784 | else if (adev->pm.pcie_gen_mask & CAIL_PCIE_LINK_SPEED_SUPPORT_GEN2) | 790 | else if (adev->pm.pcie_gen_mask & CAIL_PCIE_LINK_SPEED_SUPPORT_GEN2) |
| 785 | pcie_speed = 5; | 791 | pcie_gen = 1; |
| 786 | else if (adev->pm.pcie_gen_mask & CAIL_PCIE_LINK_SPEED_SUPPORT_GEN1) | 792 | else if (adev->pm.pcie_gen_mask & CAIL_PCIE_LINK_SPEED_SUPPORT_GEN1) |
| 787 | pcie_speed = 2; | 793 | pcie_gen = 0; |
| 788 | 794 | ||
| 789 | if (adev->pm.pcie_mlw_mask & CAIL_PCIE_LINK_WIDTH_SUPPORT_X32) | 795 | if (adev->pm.pcie_mlw_mask & CAIL_PCIE_LINK_WIDTH_SUPPORT_X16) |
| 790 | pcie_width = 32; | 796 | pcie_width = 6; |
| 791 | else if (adev->pm.pcie_mlw_mask & CAIL_PCIE_LINK_WIDTH_SUPPORT_X16) | ||
| 792 | pcie_width = 16; | ||
| 793 | else if (adev->pm.pcie_mlw_mask & CAIL_PCIE_LINK_WIDTH_SUPPORT_X12) | 797 | else if (adev->pm.pcie_mlw_mask & CAIL_PCIE_LINK_WIDTH_SUPPORT_X12) |
| 794 | pcie_width = 12; | 798 | pcie_width = 5; |
| 795 | else if (adev->pm.pcie_mlw_mask & CAIL_PCIE_LINK_WIDTH_SUPPORT_X8) | 799 | else if (adev->pm.pcie_mlw_mask & CAIL_PCIE_LINK_WIDTH_SUPPORT_X8) |
| 796 | pcie_width = 8; | ||
| 797 | else if (adev->pm.pcie_mlw_mask & CAIL_PCIE_LINK_WIDTH_SUPPORT_X4) | ||
| 798 | pcie_width = 4; | 800 | pcie_width = 4; |
| 801 | else if (adev->pm.pcie_mlw_mask & CAIL_PCIE_LINK_WIDTH_SUPPORT_X4) | ||
| 802 | pcie_width = 3; | ||
| 799 | else if (adev->pm.pcie_mlw_mask & CAIL_PCIE_LINK_WIDTH_SUPPORT_X2) | 803 | else if (adev->pm.pcie_mlw_mask & CAIL_PCIE_LINK_WIDTH_SUPPORT_X2) |
| 800 | pcie_width = 2; | 804 | pcie_width = 2; |
| 801 | else if (adev->pm.pcie_mlw_mask & CAIL_PCIE_LINK_WIDTH_SUPPORT_X1) | 805 | else if (adev->pm.pcie_mlw_mask & CAIL_PCIE_LINK_WIDTH_SUPPORT_X1) |
| 802 | pcie_width = 1; | 806 | pcie_width = 1; |
| 803 | 807 | ||
| 804 | pcie_arg = pcie_width | (pcie_speed << 8); | 808 | /* Bit 31:16: LCLK DPM level. 0 is DPM0, and 1 is DPM1 |
| 805 | 809 | * Bit 15:8: PCIE GEN, 0 to 3 corresponds to GEN1 to GEN4 | |
| 810 | * Bit 7:0: PCIE lane width, 1 to 7 corresponds is x1 to x32 | ||
| 811 | */ | ||
| 812 | smu_pcie_arg = (1 << 16) | (pcie_gen << 8) | pcie_width; | ||
| 806 | ret = smum_send_msg_to_smc_with_parameter(hwmgr, | 813 | ret = smum_send_msg_to_smc_with_parameter(hwmgr, |
| 807 | PPSMC_MSG_OverridePcieParameters, pcie_arg); | 814 | PPSMC_MSG_OverridePcieParameters, smu_pcie_arg); |
| 808 | PP_ASSERT_WITH_CODE(!ret, | 815 | PP_ASSERT_WITH_CODE(!ret, |
| 809 | "[OverridePcieParameters] Attempt to override pcie params failed!", | 816 | "[OverridePcieParameters] Attempt to override pcie params failed!", |
| 810 | return ret); | 817 | return ret); |
| @@ -1611,11 +1618,6 @@ static int vega20_enable_dpm_tasks(struct pp_hwmgr *hwmgr) | |||
| 1611 | "[EnableDPMTasks] Failed to initialize SMC table!", | 1618 | "[EnableDPMTasks] Failed to initialize SMC table!", |
| 1612 | return result); | 1619 | return result); |
| 1613 | 1620 | ||
| 1614 | result = vega20_override_pcie_parameters(hwmgr); | ||
| 1615 | PP_ASSERT_WITH_CODE(!result, | ||
| 1616 | "[EnableDPMTasks] Failed to override pcie parameters!", | ||
| 1617 | return result); | ||
| 1618 | |||
| 1619 | result = vega20_run_btc(hwmgr); | 1621 | result = vega20_run_btc(hwmgr); |
| 1620 | PP_ASSERT_WITH_CODE(!result, | 1622 | PP_ASSERT_WITH_CODE(!result, |
| 1621 | "[EnableDPMTasks] Failed to run btc!", | 1623 | "[EnableDPMTasks] Failed to run btc!", |
| @@ -1631,6 +1633,11 @@ static int vega20_enable_dpm_tasks(struct pp_hwmgr *hwmgr) | |||
| 1631 | "[EnableDPMTasks] Failed to enable all smu features!", | 1633 | "[EnableDPMTasks] Failed to enable all smu features!", |
| 1632 | return result); | 1634 | return result); |
| 1633 | 1635 | ||
| 1636 | result = vega20_override_pcie_parameters(hwmgr); | ||
| 1637 | PP_ASSERT_WITH_CODE(!result, | ||
| 1638 | "[EnableDPMTasks] Failed to override pcie parameters!", | ||
| 1639 | return result); | ||
| 1640 | |||
| 1634 | result = vega20_notify_smc_display_change(hwmgr); | 1641 | result = vega20_notify_smc_display_change(hwmgr); |
| 1635 | PP_ASSERT_WITH_CODE(!result, | 1642 | PP_ASSERT_WITH_CODE(!result, |
| 1636 | "[EnableDPMTasks] Failed to notify smc display change!", | 1643 | "[EnableDPMTasks] Failed to notify smc display change!", |
