08da4fcd6d
This patch is to improve the fine grain tuning function for Renoir. The fine grain tuning function uses the sysfs node -- pp_od_clk_voltage to config gfxclk. Meanwhile, another sysfs node -- power_dpm_force_perfomance_level also affects the gfx clk. It will cause confusion when these two sysfs nodes works together. And the flag "od_enabled" is used to control the overdrive function for dGPU, like navi10, navi14 and navi21. APU like Renior or Vangogh uses this "od_enabled" to configure the frequency range of gfx clock, but the max value of frequency range will not be higher than the safe limit, it is not "overdrive". So this patch adds two new flags -- "fine_grain_enabled" and "fine_grain_started" to avoid this confusion, the flag will make these two sysfs nodes work separately. The flag "fine_grain_enabled" is set as "enabled" by default, so the fine grain tuning function will be enabled by default. But the flag "fine_grain_started" is set as "false" by default, so the fine grain function will not take effect until it is set as "true". Only when power_dpm_force_perfomance_level is changed to "manual" mode, the flag "fine_grain_started" will be set as "true", and the fine grain tuning function will be started. In other profile modes, including "auto", "high", "low", "profile_peak", "profile_standard", "profile_min_sclk", "profile_min_mclk", the flag "fine_grain_started" will be set as "false", and the od range of fine grain tuning function will be restored default value. Signed-off-by: Xiaojian Du <Xiaojian.Du@amd.com> Reviewed-by: Huang Rui <ray.huang@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com> |
||
---|---|---|
.. | ||
vega12 | ||
amd_powerplay.h | ||
amdgpu_dpm.h | ||
amdgpu_pm.h | ||
amdgpu_smu.h | ||
arcturus_ppsmc.h | ||
cz_ppsmc.h | ||
fiji_ppsmc.h | ||
hardwaremanager.h | ||
hwmgr.h | ||
polaris10_pwrvirus.h | ||
power_state.h | ||
pp_debug.h | ||
pp_endian.h | ||
pp_thermal.h | ||
ppinterrupt.h | ||
rv_ppsmc.h | ||
smu7_common.h | ||
smu7_discrete.h | ||
smu7_fusion.h | ||
smu7_ppsmc.h | ||
smu7.h | ||
smu8_fusion.h | ||
smu8.h | ||
smu9_driver_if.h | ||
smu9.h | ||
smu10_driver_if.h | ||
smu10.h | ||
smu11_driver_if_arcturus.h | ||
smu11_driver_if_navi10.h | ||
smu11_driver_if_sienna_cichlid.h | ||
smu11_driver_if_vangogh.h | ||
smu11_driver_if.h | ||
smu12_driver_if.h | ||
smu71_discrete.h | ||
smu71.h | ||
smu72_discrete.h | ||
smu72.h | ||
smu73_discrete.h | ||
smu73.h | ||
smu74_discrete.h | ||
smu74.h | ||
smu75_discrete.h | ||
smu75.h | ||
smu_11_0_cdr_table.h | ||
smu_types.h | ||
smu_ucode_xfer_cz.h | ||
smu_ucode_xfer_vi.h | ||
smu_v11_0_7_ppsmc.h | ||
smu_v11_0_7_pptable.h | ||
smu_v11_0_ppsmc.h | ||
smu_v11_0_pptable.h | ||
smu_v11_0.h | ||
smu_v11_5_pmfw.h | ||
smu_v11_5_ppsmc.h | ||
smu_v12_0_ppsmc.h | ||
smu_v12_0.h | ||
smumgr.h | ||
tonga_ppsmc.h | ||
vega10_ppsmc.h | ||
vega12_ppsmc.h | ||
vega20_ppsmc.h |