summaryrefslogtreecommitdiffstats
path: root/drivers/gpu/nvgpu/clk/clk.c
diff options
context:
space:
mode:
authorDebarshi Dutta <ddutta@nvidia.com>2018-06-26 06:11:12 -0400
committermobile promotions <svcmobile_promotions@nvidia.com>2018-09-04 10:25:41 -0400
commit16ad9f537979c5f3717fc5781b1c2fad22a76f96 (patch)
tree2a150c50983180051fa5ecc942764e081961d787 /drivers/gpu/nvgpu/clk/clk.c
parentf125d1b681c324d5d58abcc42fac1301e1faa921 (diff)
gpu: nvgpu: move gp106 specific clk_arbiter code into HAL
Currently, clock arbiter code is extensively using dgpu specific implementation. This patch restructures the clk_arbiter code and moves gp106 specific code into HAL. Following changes are made in this patch 1) clk_domain_get_f_points is now invoked via HAL for gp106 i.e. g->ops.clk.clk_domain_get_f_points. 2) moved nvgpu_clk_arb_change_vf_point and other related static functions to clk_arb_gp106.c. 3) Instead of only checking if get_arbiter_clk_domain is empty, a check for support_clk_freq_controller is also added. This is to enable the clk_arbiter based on support from both the OS and the chips. Bug 2061372 Change-Id: I65b0a4e02145a86fbbfb420ed591b1fa3c86f6dc Signed-off-by: Debarshi Dutta <ddutta@nvidia.com> Reviewed-on: https://git-master.nvidia.com/r/1774279 Reviewed-by: svc-misra-checker <svc-misra-checker@nvidia.com> GVS: Gerrit_Virtual_Submit Reviewed-by: Deepak Nibade <dnibade@nvidia.com> Reviewed-by: Vijayakumar Subbu <vsubbu@nvidia.com> Reviewed-by: mobile promotions <svcmobile_promotions@nvidia.com> Tested-by: mobile promotions <svcmobile_promotions@nvidia.com>
Diffstat (limited to 'drivers/gpu/nvgpu/clk/clk.c')
-rw-r--r--drivers/gpu/nvgpu/clk/clk.c31
1 files changed, 0 insertions, 31 deletions
diff --git a/drivers/gpu/nvgpu/clk/clk.c b/drivers/gpu/nvgpu/clk/clk.c
index 49087468..731124f7 100644
--- a/drivers/gpu/nvgpu/clk/clk.c
+++ b/drivers/gpu/nvgpu/clk/clk.c
@@ -869,34 +869,3 @@ u32 clk_domain_get_f_or_v(
869 } 869 }
870 return status; 870 return status;
871} 871}
872
873u32 clk_domain_get_f_points(
874 struct gk20a *g,
875 u32 clkapidomain,
876 u32 *pfpointscount,
877 u16 *pfreqpointsinmhz
878)
879{
880 u32 status = -EINVAL;
881 struct clk_domain *pdomain;
882 u8 i;
883 struct clk_pmupstate *pclk = &g->clk_pmu;
884
885 if (pfpointscount == NULL)
886 return -EINVAL;
887
888 if ((pfreqpointsinmhz == NULL) && (*pfpointscount != 0))
889 return -EINVAL;
890
891 BOARDOBJGRP_FOR_EACH(&(pclk->clk_domainobjs.super.super),
892 struct clk_domain *, pdomain, i) {
893 if (pdomain->api_domain == clkapidomain) {
894 status = pdomain->clkdomainclkgetfpoints(g, pclk,
895 pdomain, pfpointscount,
896 pfreqpointsinmhz,
897 CLK_PROG_VFE_ENTRY_LOGIC);
898 return status;
899 }
900 }
901 return status;
902}