提交 6b294793 编写于 作者: K Kevin Wang 提交者: Alex Deucher

drm/amd/powerplay: add smu message name support

add smu_get_message_name support in smu.
Signed-off-by: NKevin Wang <kevin1.wang@amd.com>
Reviewed-by: NKenneth Feng <kenneth.feng@amd.com>
Signed-off-by: NAlex Deucher <alexander.deucher@amd.com>
上级 0ba5eda8
......@@ -30,6 +30,19 @@
#include "atom.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 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_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);
const char *smu_get_message_name(struct smu_context *smu, enum smu_message_type type);
#endif
......@@ -23,108 +23,112 @@
#ifndef __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 {
SMU_MSG_TestMessage = 0,
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_MESSAGE_TYPES
SMU_MSG_MAX_COUNT,
};
......@@ -207,4 +211,3 @@ enum smu_feature_mask {
};
#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);
if (ret)
pr_err("Failed to send message 0x%x, response 0x%x\n", index,
ret);
pr_err("failed send message: %10s (%d) response %#x\n",
smu_get_message_name(smu, msg), index, 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);
if (ret)
pr_err("Failed to send message 0x%x, response 0x%x, param 0x%x\n",
index, ret, param);
pr_err("failed send message: %10s (%d) \tparam: 0x%08x response %#x\n",
smu_get_message_name(smu, msg), index, param, ret);
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);
if (ret)
pr_err("Failed to send message 0x%x, response 0x%x param 0x%x\n",
index, ret, param);
pr_err("failed send message: %10s (%d) \tparam: 0x%08x response %#x\n",
smu_get_message_name(smu, msg), index, param, ret);
return ret;
}
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册