On Tue, Jul 3, 2018 at 5:46 AM, Rex Zhu <rex.zhu at amd.com> wrote: > powerplay/dpm export all interfaces in struct amd_pm_funcs. > so call common exported interfaces instand of powerplay inner interfaces typo: instand ->instead With that fixed: Acked-by: Alex Deucher <alexander.deucher at amd.com> > > Also not include header file hwmgr.h > > Signed-off-by: Rex Zhu <Rex.Zhu at amd.com> > --- > .../drm/amd/display/amdgpu_dm/amdgpu_dm_pp_smu.c | 80 +++++++++++----------- > 1 file changed, 40 insertions(+), 40 deletions(-) > > diff --git a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_pp_smu.c b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_pp_smu.c > index 8184511..9c105c0 100644 > --- a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_pp_smu.c > +++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_pp_smu.c > @@ -33,7 +33,6 @@ > #include "amdgpu_dm_irq.h" > #include "amdgpu_pm.h" > #include "dm_pp_smu.h" > -#include "../../powerplay/inc/hwmgr.h" > > > bool dm_pp_apply_display_requirements( > @@ -452,76 +451,77 @@ bool dm_pp_get_static_clocks( > void pp_rv_set_display_requirement(struct pp_smu *pp, > struct pp_smu_display_requirement_rv *req) > { > - struct amdgpu_device *adev = pp->ctx->driver_context; > - struct pp_hwmgr *hwmgr = adev->powerplay.pp_handle; > - int ret = 0; > - if (hwmgr->hwmgr_func->set_deep_sleep_dcefclk) > - ret = hwmgr->hwmgr_func->set_deep_sleep_dcefclk(hwmgr, req->hard_min_dcefclk_khz/10); > - if (hwmgr->hwmgr_func->set_active_display_count) > - ret = hwmgr->hwmgr_func->set_active_display_count(hwmgr, req->display_count); > + struct dc_context *ctx = pp->ctx; > + struct amdgpu_device *adev = ctx->driver_context; > + const struct amd_pm_funcs *pp_funcs = adev->powerplay.pp_funcs; > + > + if (!pp_funcs || !pp_funcs->display_configuration_changed) > + return; > > - //store_cc6 is not yet implemented in SMU level > + amdgpu_dpm_display_configuration_changed(adev); > } > > void pp_rv_set_wm_ranges(struct pp_smu *pp, > struct pp_smu_wm_range_sets *ranges) > { > - struct amdgpu_device *adev = pp->ctx->driver_context; > - struct pp_hwmgr *hwmgr = adev->powerplay.pp_handle; > - struct pp_wm_sets_with_clock_ranges_soc15 ranges_soc15 = {0}; > - int i = 0; > - > - if (!hwmgr->hwmgr_func->set_watermarks_for_clocks_ranges || > - !pp || !ranges) > - return; > + struct dc_context *ctx = pp->ctx; > + struct amdgpu_device *adev = ctx->driver_context; > + void *pp_handle = adev->powerplay.pp_handle; > + const struct amd_pm_funcs *pp_funcs = adev->powerplay.pp_funcs; > + struct dm_pp_wm_sets_with_clock_ranges_soc15 wm_with_clock_ranges; > + struct dm_pp_clock_range_for_dmif_wm_set_soc15 *wm_dce_clocks = wm_with_clock_ranges.wm_dmif_clocks_ranges; > + struct dm_pp_clock_range_for_mcif_wm_set_soc15 *wm_soc_clocks = wm_with_clock_ranges.wm_mcif_clocks_ranges; > + int32_t i; > > - //not entirely sure if thats a correct assignment > - ranges_soc15.num_wm_sets_dmif = ranges->num_reader_wm_sets; > - ranges_soc15.num_wm_sets_mcif = ranges->num_writer_wm_sets; > + wm_with_clock_ranges.num_wm_dmif_sets = ranges->num_reader_wm_sets; > + wm_with_clock_ranges.num_wm_mcif_sets = ranges->num_writer_wm_sets; > > - for (i = 0; i < ranges_soc15.num_wm_sets_dmif; i++) { > + for (i = 0; i < wm_with_clock_ranges.num_wm_dmif_sets; i++) { > if (ranges->reader_wm_sets[i].wm_inst > 3) > - ranges_soc15.wm_sets_dmif[i].wm_set_id = DC_WM_SET_A; > + wm_dce_clocks[i].wm_set_id = WM_SET_A; > else > - ranges_soc15.wm_sets_dmif[i].wm_set_id = > + wm_dce_clocks[i].wm_set_id = > ranges->reader_wm_sets[i].wm_inst; > - ranges_soc15.wm_sets_dmif[i].wm_max_dcefclk_in_khz = > + wm_dce_clocks[i].wm_max_dcfclk_clk_in_khz = > ranges->reader_wm_sets[i].max_drain_clk_khz; > - ranges_soc15.wm_sets_dmif[i].wm_min_dcefclk_in_khz = > + wm_dce_clocks[i].wm_min_dcfclk_clk_in_khz = > ranges->reader_wm_sets[i].min_drain_clk_khz; > - ranges_soc15.wm_sets_dmif[i].wm_max_memclk_in_khz = > + wm_dce_clocks[i].wm_max_mem_clk_in_khz = > ranges->reader_wm_sets[i].max_fill_clk_khz; > - ranges_soc15.wm_sets_dmif[i].wm_min_memclk_in_khz = > + wm_dce_clocks[i].wm_min_mem_clk_in_khz = > ranges->reader_wm_sets[i].min_fill_clk_khz; > } > > - for (i = 0; i < ranges_soc15.num_wm_sets_mcif; i++) { > + for (i = 0; i < wm_with_clock_ranges.num_wm_mcif_sets; i++) { > if (ranges->writer_wm_sets[i].wm_inst > 3) > - ranges_soc15.wm_sets_dmif[i].wm_set_id = DC_WM_SET_A; > + wm_soc_clocks[i].wm_set_id = WM_SET_A; > else > - ranges_soc15.wm_sets_mcif[i].wm_set_id = > + wm_soc_clocks[i].wm_set_id = > ranges->writer_wm_sets[i].wm_inst; > - ranges_soc15.wm_sets_mcif[i].wm_max_socclk_in_khz = > + wm_soc_clocks[i].wm_max_socclk_clk_in_khz = > ranges->writer_wm_sets[i].max_fill_clk_khz; > - ranges_soc15.wm_sets_mcif[i].wm_min_socclk_in_khz = > + wm_soc_clocks[i].wm_min_socclk_clk_in_khz = > ranges->writer_wm_sets[i].min_fill_clk_khz; > - ranges_soc15.wm_sets_mcif[i].wm_max_memclk_in_khz = > + wm_soc_clocks[i].wm_max_mem_clk_in_khz = > ranges->writer_wm_sets[i].max_fill_clk_khz; > - ranges_soc15.wm_sets_mcif[i].wm_min_memclk_in_khz = > + wm_soc_clocks[i].wm_min_mem_clk_in_khz = > ranges->writer_wm_sets[i].min_fill_clk_khz; > } > > - hwmgr->hwmgr_func->set_watermarks_for_clocks_ranges(hwmgr, &ranges_soc15); > - > + pp_funcs->set_watermarks_for_clocks_ranges(pp_handle, &wm_with_clock_ranges); > } > > void pp_rv_set_pme_wa_enable(struct pp_smu *pp) > { > - struct amdgpu_device *adev = pp->ctx->driver_context; > - struct pp_hwmgr *hwmgr = adev->powerplay.pp_handle; > + struct dc_context *ctx = pp->ctx; > + struct amdgpu_device *adev = ctx->driver_context; > + void *pp_handle = adev->powerplay.pp_handle; > + const struct amd_pm_funcs *pp_funcs = adev->powerplay.pp_funcs; > + > + if (!pp_funcs || !pp_funcs->notify_smu_enable_pwe) > + return; > > - if (hwmgr->hwmgr_func->smus_notify_pwe) > - hwmgr->hwmgr_func->smus_notify_pwe(hwmgr); > + pp_funcs->notify_smu_enable_pwe(pp_handle); > } > > void dm_pp_get_funcs_rv( > -- > 1.9.1 > > _______________________________________________ > amd-gfx mailing list > amd-gfx at lists.freedesktop.org > https://lists.freedesktop.org/mailman/listinfo/amd-gfx