linux/drivers/interconnect/qcom
Leo Yan 65fac3b349 interconnect: qcom: icc-rpm: Fix for cached clock rate
All nodes within an interconnect bus share interconnect bus clocks, but
every node has its own cached clock rate values, this can lead to
unexpected clock rate setting.

Let's see an example shown in below, in this case, a bus have two nodes
A and B, and its buswidth is 8:

  step1: vote bandwidth 1600M for node(A):

    aggregated(bw) = 1600M
    qcom_icc_node(A)->rate = 1600M / 8 = 200MHz

  step2: vote bandwidth 1600M for node(B):

    aggregated(bw) = 1600M + 1600M = 3200M
    qcom_icc_node(B)->rate = 3200M / 8 = 400MHz

  step3: unvote bandwidth 1600M for node(A)

    aggregated(bw) = 3200M - 1600M = 1600M
    target_clock = 1600M / 8 = 200MHz

The problem is in step 3, the calculated target clock rate is 200MHz,
which equals to the cached clock rate in node(A) (See step 1),
unfortunately, qcom_icc_set() skips to set the new clock rate 200MHz in
this case, so the bus clock rate will continue to stay at 400MHz.

To resolve the issue, one possible solution is to invoke clk_get_rate()
to retrieve the clock rates on the fly, thus we can totally remove the
cached clock rates.  But after review the code, many bus clock has set
the flag CLK_GET_RATE_NOCACHE, this results in the retrieving bus clock
rate is time cost for iterating parent clock nodes, and even challenges
bus clock drivers to provide recalc_rate() callbacks.

So this patch moves the cached rates into structure qcom_icc_provider,
we use it as a central place to maintain bus clock handlers and cached
clock rate, therefore, it can smoothly dismiss the mismatching problem.

Signed-off-by: Leo Yan <leo.yan@linaro.org>
Link: https://lore.kernel.org/r/20220416031029.693211-2-leo.yan@linaro.org
Signed-off-by: Georgi Djakov <djakov@kernel.org>
2022-05-04 10:46:18 +03:00
..
bcm-voter.c interconnect: qcom: Add missing MODULE_DEVICE_TABLE 2021-05-11 07:26:31 +03:00
bcm-voter.h interconnect: qcom: Consolidate interconnect RPMh support 2020-02-28 12:11:40 +02:00
icc-rpm.c interconnect: qcom: icc-rpm: Fix for cached clock rate 2022-05-04 10:46:18 +03:00
icc-rpm.h interconnect: qcom: icc-rpm: Fix for cached clock rate 2022-05-04 10:46:18 +03:00
icc-rpmh.c interconnect: qcom: icc-rpmh: Add BCMs to commit list in pre_aggregate 2021-11-30 14:14:19 +02:00
icc-rpmh.h interconnect: qcom: icc-rpmh: Consolidate probe functions 2021-07-22 10:05:24 +03:00
Kconfig Merge branch 'icc-qcm2290' into icc-next 2021-12-15 07:14:27 +02:00
Makefile Merge branch 'icc-qcm2290' into icc-next 2021-12-15 07:14:27 +02:00
msm8916.c interconnect: icc-rpm: Define ICC device type 2021-12-15 07:12:36 +02:00
msm8939.c interconnect: qcom: msm8939: Remove snoc_mm specific regmap 2022-02-10 12:40:59 +02:00
msm8974.c interconnect: qcom: msm8974: Don't boost the NoC rate during boot 2020-11-18 00:21:47 +02:00
msm8996.c interconnect: icc-rpm: Define ICC device type 2021-12-15 07:12:36 +02:00
msm8996.h interconnect: qcom: Add MSM8996 interconnect provider driver 2021-11-22 18:35:22 +02:00
osm-l3.c interconnect: qcom: Add EPSS L3 support on SC7280 2021-11-22 16:57:22 +02:00
qcm2290.c interconnect: qcom: Add QCM2290 driver support 2021-12-15 07:13:16 +02:00
qcs404.c interconnect: qcs404: expand DEFINE_QNODE macros 2021-10-04 14:13:58 +03:00
sc7180.c interconnect: qcom: icc-rpmh: Consolidate probe functions 2021-07-22 10:05:24 +03:00
sc7180.h interconnect: qcom: Add OSM L3 support on SC7180 2020-03-03 19:02:52 +02:00
sc7280.c interconnect: qcom: icc-rpmh: Consolidate probe functions 2021-07-22 10:05:24 +03:00
sc7280.h interconnect: qcom: Add EPSS L3 support on SC7280 2021-11-22 16:57:22 +02:00
sc8180x.c interconnect: qcom: Add SC8180x providers 2021-08-09 15:16:53 +03:00
sc8180x.h interconnect: qcom: osm-l3: Add sc8180x support 2021-08-09 15:17:25 +03:00
sdm660.c interconnect: icc-rpm: Define ICC device type 2021-12-15 07:12:36 +02:00
sdm845.c interconnect: qcom: icc-rpmh: Consolidate probe functions 2021-07-22 10:05:24 +03:00
sdm845.h interconnect: qcom: Add OSM L3 interconnect provider support 2020-03-03 19:02:52 +02:00
sdx55.c interconnect: qcom: icc-rpmh: Consolidate probe functions 2021-07-22 10:05:24 +03:00
sdx55.h interconnect: qcom: Add SDX55 interconnect provider driver 2021-01-27 13:11:33 +02:00
sm8150.c interconnect: qcom: icc-rpmh: Add BCMs to commit list in pre_aggregate 2021-11-30 14:14:19 +02:00
sm8150.h interconnect: qcom: Add OSM L3 support on SM8150 2020-09-08 16:29:01 +03:00
sm8250.c interconnect: qcom: icc-rpmh: Add BCMs to commit list in pre_aggregate 2021-11-30 14:14:19 +02:00
sm8250.h interconnect: qcom: Add EPSS L3 support on SM8250 2020-09-08 16:29:01 +03:00
sm8350.c interconnect: qcom: icc-rpmh: Add BCMs to commit list in pre_aggregate 2021-11-30 14:14:19 +02:00
sm8350.h interconnect: qcom: Add SM8350 interconnect provider driver 2021-03-27 14:34:12 +02:00
sm8450.c interconnect: qcom: Add SM8450 interconnect provider driver 2021-12-14 23:43:26 +02:00
sm8450.h interconnect: qcom: Add SM8450 interconnect provider driver 2021-12-14 23:43:26 +02:00
smd-rpm.c interconnect: qcom: Add interconnect RPM over SMD driver 2019-08-13 23:06:40 +03:00
smd-rpm.h interconnect: qcom: Add interconnect RPM over SMD driver 2019-08-13 23:06:40 +03:00