mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-09-04 20:19:47 +08:00
drm/amd/powerplay: add smu message name support
add smu_get_message_name support in smu. Signed-off-by: Kevin Wang <kevin1.wang@amd.com> Reviewed-by: Kenneth Feng <kenneth.feng@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
0ba5eda81a
commit
6b294793e3
@ -30,6 +30,19 @@
|
|||||||
#include "atom.h"
|
#include "atom.h"
|
||||||
#include "amd_pcie.h"
|
#include "amd_pcie.h"
|
||||||
|
|
||||||
|
#undef __SMU_DUMMY_MAP
|
||||||
|
#define __SMU_DUMMY_MAP(type) #type
|
||||||
|
static const char* __smu_message_names[] = {
|
||||||
|
SMU_MESSAGE_TYPES
|
||||||
|
};
|
||||||
|
|
||||||
|
const char *smu_get_message_name(struct smu_context *smu, enum smu_message_type type)
|
||||||
|
{
|
||||||
|
if (type < 0 || type > SMU_MSG_MAX_COUNT)
|
||||||
|
return "unknow smu message";
|
||||||
|
return __smu_message_names[type];
|
||||||
|
}
|
||||||
|
|
||||||
int smu_get_smc_version(struct smu_context *smu, uint32_t *if_version, uint32_t *smu_version)
|
int smu_get_smc_version(struct smu_context *smu, uint32_t *if_version, uint32_t *smu_version)
|
||||||
{
|
{
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
@ -804,5 +804,6 @@ enum amd_dpm_forced_level smu_get_performance_level(struct smu_context *smu);
|
|||||||
int smu_force_performance_level(struct smu_context *smu, enum amd_dpm_forced_level level);
|
int smu_force_performance_level(struct smu_context *smu, enum amd_dpm_forced_level level);
|
||||||
int smu_set_display_count(struct smu_context *smu, uint32_t count);
|
int smu_set_display_count(struct smu_context *smu, uint32_t count);
|
||||||
bool smu_clk_dpm_is_enabled(struct smu_context *smu, enum smu_clk_type clk_type);
|
bool smu_clk_dpm_is_enabled(struct smu_context *smu, enum smu_clk_type clk_type);
|
||||||
|
const char *smu_get_message_name(struct smu_context *smu, enum smu_message_type type);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -23,108 +23,112 @@
|
|||||||
#ifndef __SMU_TYPES_H__
|
#ifndef __SMU_TYPES_H__
|
||||||
#define __SMU_TYPES_H__
|
#define __SMU_TYPES_H__
|
||||||
|
|
||||||
|
#define SMU_MESSAGE_TYPES \
|
||||||
|
__SMU_DUMMY_MAP(TestMessage), \
|
||||||
|
__SMU_DUMMY_MAP(GetSmuVersion), \
|
||||||
|
__SMU_DUMMY_MAP(GetDriverIfVersion), \
|
||||||
|
__SMU_DUMMY_MAP(SetAllowedFeaturesMaskLow), \
|
||||||
|
__SMU_DUMMY_MAP(SetAllowedFeaturesMaskHigh), \
|
||||||
|
__SMU_DUMMY_MAP(EnableAllSmuFeatures), \
|
||||||
|
__SMU_DUMMY_MAP(DisableAllSmuFeatures), \
|
||||||
|
__SMU_DUMMY_MAP(EnableSmuFeaturesLow), \
|
||||||
|
__SMU_DUMMY_MAP(EnableSmuFeaturesHigh), \
|
||||||
|
__SMU_DUMMY_MAP(DisableSmuFeaturesLow), \
|
||||||
|
__SMU_DUMMY_MAP(DisableSmuFeaturesHigh), \
|
||||||
|
__SMU_DUMMY_MAP(GetEnabledSmuFeaturesLow), \
|
||||||
|
__SMU_DUMMY_MAP(GetEnabledSmuFeaturesHigh), \
|
||||||
|
__SMU_DUMMY_MAP(SetWorkloadMask), \
|
||||||
|
__SMU_DUMMY_MAP(SetPptLimit), \
|
||||||
|
__SMU_DUMMY_MAP(SetDriverDramAddrHigh), \
|
||||||
|
__SMU_DUMMY_MAP(SetDriverDramAddrLow), \
|
||||||
|
__SMU_DUMMY_MAP(SetToolsDramAddrHigh), \
|
||||||
|
__SMU_DUMMY_MAP(SetToolsDramAddrLow), \
|
||||||
|
__SMU_DUMMY_MAP(TransferTableSmu2Dram), \
|
||||||
|
__SMU_DUMMY_MAP(TransferTableDram2Smu), \
|
||||||
|
__SMU_DUMMY_MAP(UseDefaultPPTable), \
|
||||||
|
__SMU_DUMMY_MAP(UseBackupPPTable), \
|
||||||
|
__SMU_DUMMY_MAP(RunBtc), \
|
||||||
|
__SMU_DUMMY_MAP(RequestI2CBus), \
|
||||||
|
__SMU_DUMMY_MAP(ReleaseI2CBus), \
|
||||||
|
__SMU_DUMMY_MAP(SetFloorSocVoltage), \
|
||||||
|
__SMU_DUMMY_MAP(SoftReset), \
|
||||||
|
__SMU_DUMMY_MAP(StartBacoMonitor), \
|
||||||
|
__SMU_DUMMY_MAP(CancelBacoMonitor), \
|
||||||
|
__SMU_DUMMY_MAP(EnterBaco), \
|
||||||
|
__SMU_DUMMY_MAP(SetSoftMinByFreq), \
|
||||||
|
__SMU_DUMMY_MAP(SetSoftMaxByFreq), \
|
||||||
|
__SMU_DUMMY_MAP(SetHardMinByFreq), \
|
||||||
|
__SMU_DUMMY_MAP(SetHardMaxByFreq), \
|
||||||
|
__SMU_DUMMY_MAP(GetMinDpmFreq), \
|
||||||
|
__SMU_DUMMY_MAP(GetMaxDpmFreq), \
|
||||||
|
__SMU_DUMMY_MAP(GetDpmFreqByIndex), \
|
||||||
|
__SMU_DUMMY_MAP(GetDpmClockFreq), \
|
||||||
|
__SMU_DUMMY_MAP(GetSsVoltageByDpm), \
|
||||||
|
__SMU_DUMMY_MAP(SetMemoryChannelConfig), \
|
||||||
|
__SMU_DUMMY_MAP(SetGeminiMode), \
|
||||||
|
__SMU_DUMMY_MAP(SetGeminiApertureHigh), \
|
||||||
|
__SMU_DUMMY_MAP(SetGeminiApertureLow), \
|
||||||
|
__SMU_DUMMY_MAP(SetMinLinkDpmByIndex), \
|
||||||
|
__SMU_DUMMY_MAP(OverridePcieParameters), \
|
||||||
|
__SMU_DUMMY_MAP(OverDriveSetPercentage), \
|
||||||
|
__SMU_DUMMY_MAP(SetMinDeepSleepDcefclk), \
|
||||||
|
__SMU_DUMMY_MAP(ReenableAcDcInterrupt), \
|
||||||
|
__SMU_DUMMY_MAP(NotifyPowerSource), \
|
||||||
|
__SMU_DUMMY_MAP(SetUclkFastSwitch), \
|
||||||
|
__SMU_DUMMY_MAP(SetUclkDownHyst), \
|
||||||
|
__SMU_DUMMY_MAP(GfxDeviceDriverReset), \
|
||||||
|
__SMU_DUMMY_MAP(GetCurrentRpm), \
|
||||||
|
__SMU_DUMMY_MAP(SetVideoFps), \
|
||||||
|
__SMU_DUMMY_MAP(SetTjMax), \
|
||||||
|
__SMU_DUMMY_MAP(SetFanTemperatureTarget), \
|
||||||
|
__SMU_DUMMY_MAP(PrepareMp1ForUnload), \
|
||||||
|
__SMU_DUMMY_MAP(DramLogSetDramAddrHigh), \
|
||||||
|
__SMU_DUMMY_MAP(DramLogSetDramAddrLow), \
|
||||||
|
__SMU_DUMMY_MAP(DramLogSetDramSize), \
|
||||||
|
__SMU_DUMMY_MAP(SetFanMaxRpm), \
|
||||||
|
__SMU_DUMMY_MAP(SetFanMinPwm), \
|
||||||
|
__SMU_DUMMY_MAP(ConfigureGfxDidt), \
|
||||||
|
__SMU_DUMMY_MAP(NumOfDisplays), \
|
||||||
|
__SMU_DUMMY_MAP(RemoveMargins), \
|
||||||
|
__SMU_DUMMY_MAP(ReadSerialNumTop32), \
|
||||||
|
__SMU_DUMMY_MAP(ReadSerialNumBottom32), \
|
||||||
|
__SMU_DUMMY_MAP(SetSystemVirtualDramAddrHigh), \
|
||||||
|
__SMU_DUMMY_MAP(SetSystemVirtualDramAddrLow), \
|
||||||
|
__SMU_DUMMY_MAP(WaflTest), \
|
||||||
|
__SMU_DUMMY_MAP(SetFclkGfxClkRatio), \
|
||||||
|
__SMU_DUMMY_MAP(AllowGfxOff), \
|
||||||
|
__SMU_DUMMY_MAP(DisallowGfxOff), \
|
||||||
|
__SMU_DUMMY_MAP(GetPptLimit), \
|
||||||
|
__SMU_DUMMY_MAP(GetDcModeMaxDpmFreq), \
|
||||||
|
__SMU_DUMMY_MAP(GetDebugData), \
|
||||||
|
__SMU_DUMMY_MAP(SetXgmiMode), \
|
||||||
|
__SMU_DUMMY_MAP(RunAfllBtc), \
|
||||||
|
__SMU_DUMMY_MAP(ExitBaco), \
|
||||||
|
__SMU_DUMMY_MAP(PrepareMp1ForReset), \
|
||||||
|
__SMU_DUMMY_MAP(PrepareMp1ForShutdown), \
|
||||||
|
__SMU_DUMMY_MAP(SetMGpuFanBoostLimitRpm), \
|
||||||
|
__SMU_DUMMY_MAP(GetAVFSVoltageByDpm), \
|
||||||
|
__SMU_DUMMY_MAP(PowerUpVcn), \
|
||||||
|
__SMU_DUMMY_MAP(PowerDownVcn), \
|
||||||
|
__SMU_DUMMY_MAP(PowerUpJpeg), \
|
||||||
|
__SMU_DUMMY_MAP(PowerDownJpeg), \
|
||||||
|
__SMU_DUMMY_MAP(BacoAudioD3PME), \
|
||||||
|
__SMU_DUMMY_MAP(ArmD3), \
|
||||||
|
__SMU_DUMMY_MAP(RunGfxDcBtc), \
|
||||||
|
__SMU_DUMMY_MAP(RunSocDcBtc), \
|
||||||
|
__SMU_DUMMY_MAP(SetMemoryChannelEnable), \
|
||||||
|
__SMU_DUMMY_MAP(SetDfSwitchType), \
|
||||||
|
__SMU_DUMMY_MAP(GetVoltageByDpm), \
|
||||||
|
__SMU_DUMMY_MAP(GetVoltageByDpmOverdrive), \
|
||||||
|
__SMU_DUMMY_MAP(PowerUpVcn0), \
|
||||||
|
__SMU_DUMMY_MAP(PowerDownVcn01), \
|
||||||
|
__SMU_DUMMY_MAP(PowerUpVcn1), \
|
||||||
|
__SMU_DUMMY_MAP(PowerDownVcn1), \
|
||||||
|
|
||||||
|
#undef __SMU_DUMMY_MAP
|
||||||
|
#define __SMU_DUMMY_MAP(type) SMU_MSG_##type
|
||||||
enum smu_message_type {
|
enum smu_message_type {
|
||||||
SMU_MSG_TestMessage = 0,
|
SMU_MESSAGE_TYPES
|
||||||
SMU_MSG_GetSmuVersion,
|
|
||||||
SMU_MSG_GetDriverIfVersion,
|
|
||||||
SMU_MSG_SetAllowedFeaturesMaskLow,
|
|
||||||
SMU_MSG_SetAllowedFeaturesMaskHigh,
|
|
||||||
SMU_MSG_EnableAllSmuFeatures,
|
|
||||||
SMU_MSG_DisableAllSmuFeatures,
|
|
||||||
SMU_MSG_EnableSmuFeaturesLow,
|
|
||||||
SMU_MSG_EnableSmuFeaturesHigh,
|
|
||||||
SMU_MSG_DisableSmuFeaturesLow,
|
|
||||||
SMU_MSG_DisableSmuFeaturesHigh,
|
|
||||||
SMU_MSG_GetEnabledSmuFeaturesLow,
|
|
||||||
SMU_MSG_GetEnabledSmuFeaturesHigh,
|
|
||||||
SMU_MSG_SetWorkloadMask,
|
|
||||||
SMU_MSG_SetPptLimit,
|
|
||||||
SMU_MSG_SetDriverDramAddrHigh,
|
|
||||||
SMU_MSG_SetDriverDramAddrLow,
|
|
||||||
SMU_MSG_SetToolsDramAddrHigh,
|
|
||||||
SMU_MSG_SetToolsDramAddrLow,
|
|
||||||
SMU_MSG_TransferTableSmu2Dram,
|
|
||||||
SMU_MSG_TransferTableDram2Smu,
|
|
||||||
SMU_MSG_UseDefaultPPTable,
|
|
||||||
SMU_MSG_UseBackupPPTable,
|
|
||||||
SMU_MSG_RunBtc,
|
|
||||||
SMU_MSG_RequestI2CBus,
|
|
||||||
SMU_MSG_ReleaseI2CBus,
|
|
||||||
SMU_MSG_SetFloorSocVoltage,
|
|
||||||
SMU_MSG_SoftReset,
|
|
||||||
SMU_MSG_StartBacoMonitor,
|
|
||||||
SMU_MSG_CancelBacoMonitor,
|
|
||||||
SMU_MSG_EnterBaco,
|
|
||||||
SMU_MSG_SetSoftMinByFreq,
|
|
||||||
SMU_MSG_SetSoftMaxByFreq,
|
|
||||||
SMU_MSG_SetHardMinByFreq,
|
|
||||||
SMU_MSG_SetHardMaxByFreq,
|
|
||||||
SMU_MSG_GetMinDpmFreq,
|
|
||||||
SMU_MSG_GetMaxDpmFreq,
|
|
||||||
SMU_MSG_GetDpmFreqByIndex,
|
|
||||||
SMU_MSG_GetDpmClockFreq,
|
|
||||||
SMU_MSG_GetSsVoltageByDpm,
|
|
||||||
SMU_MSG_SetMemoryChannelConfig,
|
|
||||||
SMU_MSG_SetGeminiMode,
|
|
||||||
SMU_MSG_SetGeminiApertureHigh,
|
|
||||||
SMU_MSG_SetGeminiApertureLow,
|
|
||||||
SMU_MSG_SetMinLinkDpmByIndex,
|
|
||||||
SMU_MSG_OverridePcieParameters,
|
|
||||||
SMU_MSG_OverDriveSetPercentage,
|
|
||||||
SMU_MSG_SetMinDeepSleepDcefclk,
|
|
||||||
SMU_MSG_ReenableAcDcInterrupt,
|
|
||||||
SMU_MSG_NotifyPowerSource,
|
|
||||||
SMU_MSG_SetUclkFastSwitch,
|
|
||||||
SMU_MSG_SetUclkDownHyst,
|
|
||||||
SMU_MSG_GfxDeviceDriverReset,
|
|
||||||
SMU_MSG_GetCurrentRpm,
|
|
||||||
SMU_MSG_SetVideoFps,
|
|
||||||
SMU_MSG_SetTjMax,
|
|
||||||
SMU_MSG_SetFanTemperatureTarget,
|
|
||||||
SMU_MSG_PrepareMp1ForUnload,
|
|
||||||
SMU_MSG_DramLogSetDramAddrHigh,
|
|
||||||
SMU_MSG_DramLogSetDramAddrLow,
|
|
||||||
SMU_MSG_DramLogSetDramSize,
|
|
||||||
SMU_MSG_SetFanMaxRpm,
|
|
||||||
SMU_MSG_SetFanMinPwm,
|
|
||||||
SMU_MSG_ConfigureGfxDidt,
|
|
||||||
SMU_MSG_NumOfDisplays,
|
|
||||||
SMU_MSG_RemoveMargins,
|
|
||||||
SMU_MSG_ReadSerialNumTop32,
|
|
||||||
SMU_MSG_ReadSerialNumBottom32,
|
|
||||||
SMU_MSG_SetSystemVirtualDramAddrHigh,
|
|
||||||
SMU_MSG_SetSystemVirtualDramAddrLow,
|
|
||||||
SMU_MSG_WaflTest,
|
|
||||||
SMU_MSG_SetFclkGfxClkRatio,
|
|
||||||
SMU_MSG_AllowGfxOff,
|
|
||||||
SMU_MSG_DisallowGfxOff,
|
|
||||||
SMU_MSG_GetPptLimit,
|
|
||||||
SMU_MSG_GetDcModeMaxDpmFreq,
|
|
||||||
SMU_MSG_GetDebugData,
|
|
||||||
SMU_MSG_SetXgmiMode,
|
|
||||||
SMU_MSG_RunAfllBtc,
|
|
||||||
SMU_MSG_ExitBaco,
|
|
||||||
SMU_MSG_PrepareMp1ForReset,
|
|
||||||
SMU_MSG_PrepareMp1ForShutdown,
|
|
||||||
SMU_MSG_SetMGpuFanBoostLimitRpm,
|
|
||||||
SMU_MSG_GetAVFSVoltageByDpm,
|
|
||||||
SMU_MSG_PowerUpVcn,
|
|
||||||
SMU_MSG_PowerDownVcn,
|
|
||||||
SMU_MSG_PowerUpJpeg,
|
|
||||||
SMU_MSG_PowerDownJpeg,
|
|
||||||
SMU_MSG_BacoAudioD3PME,
|
|
||||||
SMU_MSG_ArmD3,
|
|
||||||
SMU_MSG_RunGfxDcBtc,
|
|
||||||
SMU_MSG_RunSocDcBtc,
|
|
||||||
SMU_MSG_SetMemoryChannelEnable,
|
|
||||||
SMU_MSG_SetDfSwitchType,
|
|
||||||
SMU_MSG_GetVoltageByDpm,
|
|
||||||
SMU_MSG_GetVoltageByDpmOverdrive,
|
|
||||||
SMU_MSG_PowerUpVcn0,
|
|
||||||
SMU_MSG_PowerDownVcn01,
|
|
||||||
SMU_MSG_PowerUpVcn1,
|
|
||||||
SMU_MSG_PowerDownVcn1,
|
|
||||||
SMU_MSG_MAX_COUNT,
|
SMU_MSG_MAX_COUNT,
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -207,4 +211,3 @@ enum smu_feature_mask {
|
|||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -105,8 +105,8 @@ static int smu_v11_0_send_msg(struct smu_context *smu, uint16_t msg)
|
|||||||
ret = smu_v11_0_wait_for_response(smu);
|
ret = smu_v11_0_wait_for_response(smu);
|
||||||
|
|
||||||
if (ret)
|
if (ret)
|
||||||
pr_err("Failed to send message 0x%x, response 0x%x\n", index,
|
pr_err("failed send message: %10s (%d) response %#x\n",
|
||||||
ret);
|
smu_get_message_name(smu, msg), index, ret);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
@ -126,8 +126,8 @@ smu_v11_0_send_msg_with_param(struct smu_context *smu, uint16_t msg,
|
|||||||
|
|
||||||
ret = smu_v11_0_wait_for_response(smu);
|
ret = smu_v11_0_wait_for_response(smu);
|
||||||
if (ret)
|
if (ret)
|
||||||
pr_err("Failed to send message 0x%x, response 0x%x, param 0x%x\n",
|
pr_err("failed send message: %10s (%d) \tparam: 0x%08x response %#x\n",
|
||||||
index, ret, param);
|
smu_get_message_name(smu, msg), index, param, ret);
|
||||||
|
|
||||||
WREG32_SOC15(MP1, 0, mmMP1_SMN_C2PMSG_90, 0);
|
WREG32_SOC15(MP1, 0, mmMP1_SMN_C2PMSG_90, 0);
|
||||||
|
|
||||||
@ -137,8 +137,8 @@ smu_v11_0_send_msg_with_param(struct smu_context *smu, uint16_t msg,
|
|||||||
|
|
||||||
ret = smu_v11_0_wait_for_response(smu);
|
ret = smu_v11_0_wait_for_response(smu);
|
||||||
if (ret)
|
if (ret)
|
||||||
pr_err("Failed to send message 0x%x, response 0x%x param 0x%x\n",
|
pr_err("failed send message: %10s (%d) \tparam: 0x%08x response %#x\n",
|
||||||
index, ret, param);
|
smu_get_message_name(smu, msg), index, param, ret);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user