From: Konrad Dybcio <konrad.dybcio@linaro.org>
To: AngeloGioacchino Del Regno
<angelogioacchino.delregno@collabora.com>,
Andy Gross <agross@kernel.org>,
Bjorn Andersson <andersson@kernel.org>,
Rob Herring <robh+dt@kernel.org>,
Krzysztof Kozlowski <krzysztof.kozlowski+dt@linaro.org>,
Viresh Kumar <vireshk@kernel.org>, Nishanth Menon <nm@ti.com>,
Stephen Boyd <sboyd@kernel.org>, Niklas Cassel <nks@flawful.org>,
Liam Girdwood <lgirdwood@gmail.com>,
Mark Brown <broonie@kernel.org>,
Conor Dooley <conor+dt@kernel.org>,
"Rafael J. Wysocki" <rafael@kernel.org>,
Viresh Kumar <viresh.kumar@linaro.org>,
Ulf Hansson <ulf.hansson@linaro.org>
Cc: Robert Marko <robimarko@gmail.com>,
linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org,
devicetree@vger.kernel.org, linux-pm@vger.kernel.org,
Jeffrey Hugo <quic_jhugo@quicinc.com>,
Marijn Suijten <marijn.suijten@somainline.org>,
Konrad Dybcio <konrad.dybcio@linaro.org>
Subject: [PATCH v13 07/10] soc: qcom: cpr: Use u64 for frequency
Date: Wed, 02 Aug 2023 14:37:47 +0200 [thread overview]
Message-ID: <20230217-topic-cpr3h-v13-7-d01cff1c54cf@linaro.org> (raw)
In-Reply-To: <20230217-topic-cpr3h-v13-0-d01cff1c54cf@linaro.org>
32 bits is not enough for over-2.changeGHz frequencies. Move all variables
that operate on Hz to u64 to avoid overflows.
Reviewed-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
Tested-by: Jeffrey Hugo <quic_jhugo@quicinc.com>
Signed-off-by: Konrad Dybcio <konrad.dybcio@linaro.org>
---
drivers/genpd/qcom/cpr-common.c | 13 +++++++------
drivers/genpd/qcom/cpr-common.h | 9 ++++-----
drivers/genpd/qcom/cpr.c | 8 ++++----
3 files changed, 15 insertions(+), 15 deletions(-)
diff --git a/drivers/genpd/qcom/cpr-common.c b/drivers/genpd/qcom/cpr-common.c
index 44c681bbbf13..3e3a4a61cfde 100644
--- a/drivers/genpd/qcom/cpr-common.c
+++ b/drivers/genpd/qcom/cpr-common.c
@@ -218,7 +218,7 @@ unsigned int cpr_get_fuse_corner(struct dev_pm_opp *opp)
}
EXPORT_SYMBOL_GPL(cpr_get_fuse_corner);
-unsigned long cpr_get_opp_hz_for_req(struct dev_pm_opp *ref,
+u64 cpr_get_opp_hz_for_req(struct dev_pm_opp *ref,
struct device *cpu_dev)
{
u64 rate = 0;
@@ -250,7 +250,7 @@ unsigned long cpr_get_opp_hz_for_req(struct dev_pm_opp *ref,
out_ref:
of_node_put(desc_np);
- return (unsigned long) rate;
+ return rate;
}
EXPORT_SYMBOL_GPL(cpr_get_opp_hz_for_req);
@@ -260,7 +260,7 @@ int cpr_calculate_scaling(struct device *dev,
const struct corner *corner)
{
u32 quot_diff = 0;
- unsigned long freq_diff;
+ u64 freq_diff;
int scaling;
const struct fuse_corner *fuse, *prev_fuse;
int ret;
@@ -280,8 +280,9 @@ int cpr_calculate_scaling(struct device *dev,
}
freq_diff = fuse->max_freq - prev_fuse->max_freq;
- freq_diff /= 1000000; /* Convert to MHz */
- scaling = 1000 * quot_diff / freq_diff;
+ freq_diff = div_u64(freq_diff, 1000000); /* Convert to MHz */
+ scaling = 1000 * quot_diff;
+ do_div(scaling, freq_diff);
return min(scaling, fdata->max_quot_scale);
}
EXPORT_SYMBOL_GPL(cpr_calculate_scaling);
@@ -289,7 +290,7 @@ EXPORT_SYMBOL_GPL(cpr_calculate_scaling);
int cpr_interpolate(const struct corner *corner, int step_volt,
const struct fuse_corner_data *fdata)
{
- unsigned long f_high, f_low, f_diff;
+ u64 f_high, f_low, f_diff;
int uV_high, uV_low, uV;
u64 temp, temp_limit;
const struct fuse_corner *fuse, *prev_fuse;
diff --git a/drivers/genpd/qcom/cpr-common.h b/drivers/genpd/qcom/cpr-common.h
index 0aa227617d2f..1b2fa344eb09 100644
--- a/drivers/genpd/qcom/cpr-common.h
+++ b/drivers/genpd/qcom/cpr-common.h
@@ -42,7 +42,7 @@ struct fuse_corner {
int step_quot;
const struct reg_sequence *accs;
int num_accs;
- unsigned long max_freq;
+ u64 max_freq;
u8 ring_osc_idx;
};
@@ -54,13 +54,13 @@ struct corner {
int quot_adjust;
u32 save_ctl;
u32 save_irq;
- unsigned long freq;
+ u64 freq;
struct fuse_corner *fuse_corner;
};
struct corner_data {
unsigned int fuse_corner;
- unsigned long freq;
+ u64 freq;
};
struct acc_desc {
@@ -92,8 +92,7 @@ int cpr_populate_fuse_common(struct device *dev,
int cpr_find_initial_corner(struct device *dev, struct clk *cpu_clk,
struct corner *corners, int num_corners);
u32 cpr_get_fuse_corner(struct dev_pm_opp *opp);
-unsigned long cpr_get_opp_hz_for_req(struct dev_pm_opp *ref,
- struct device *cpu_dev);
+u64 cpr_get_opp_hz_for_req(struct dev_pm_opp *ref, struct device *cpu_dev);
int cpr_calculate_scaling(struct device *dev,
const char *quot_offset,
const struct fuse_corner_data *fdata,
diff --git a/drivers/genpd/qcom/cpr.c b/drivers/genpd/qcom/cpr.c
index 2cfeefebd24c..bd0ac95e86e7 100644
--- a/drivers/genpd/qcom/cpr.c
+++ b/drivers/genpd/qcom/cpr.c
@@ -826,8 +826,8 @@ static int cpr_corner_init(struct cpr_drv *drv)
struct corner_data *cdata;
const struct fuse_corner_data *fdata;
bool apply_scaling;
- unsigned long freq_diff, freq_diff_mhz;
- unsigned long freq;
+ unsigned long freq_diff_mhz;
+ u64 freq, freq_diff;
int step_volt = regulator_get_linear_step(drv->vdd_apc);
struct dev_pm_opp *opp;
@@ -866,7 +866,7 @@ static int cpr_corner_init(struct cpr_drv *drv)
cdata[level - 1].freq = freq;
fuse = &drv->fuse_corners[fnum];
- dev_dbg(drv->dev, "freq: %lu level: %u fuse level: %u\n",
+ dev_dbg(drv->dev, "freq: %llu level: %u fuse level: %u\n",
freq, dev_pm_opp_get_level(opp) - 1, fnum);
if (freq > fuse->max_freq)
fuse->max_freq = freq;
@@ -940,7 +940,7 @@ static int cpr_corner_init(struct cpr_drv *drv)
if (apply_scaling) {
freq_diff = fuse->max_freq - corner->freq;
- freq_diff_mhz = freq_diff / 1000000;
+ freq_diff_mhz = (u32)div_u64(freq_diff, 1000000);
corner->quot_adjust = scaling * freq_diff_mhz / 1000;
corner->uV = cpr_interpolate(corner, step_volt, fdata);
--
2.41.0
next prev parent reply other threads:[~2023-08-02 12:39 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-08-02 12:37 [PATCH v13 00/10] Add support for Core Power Reduction v3, v4 and Hardened Konrad Dybcio
2023-08-02 12:37 ` [PATCH v13 01/10] cpufreq: blocklist MSM8998 in cpufreq-dt-platdev Konrad Dybcio
2023-08-02 12:58 ` Caleb Connolly
2023-08-03 5:49 ` Viresh Kumar
2023-08-02 12:37 ` [PATCH v13 02/10] MAINTAINERS: Add entry for Qualcomm CPRv3/v4/Hardened driver Konrad Dybcio
2023-08-02 12:37 ` [PATCH v13 03/10] dt-bindings: opp: v2-qcom-level: Document CPR3 open/closed loop volt adjustment Konrad Dybcio
2023-08-08 16:17 ` Krzysztof Kozlowski
2023-08-02 12:37 ` [PATCH v13 04/10] dt-bindings: soc: qcom: cpr3: Add bindings for CPR3 driver Konrad Dybcio
2023-08-08 16:20 ` Krzysztof Kozlowski
2023-08-02 12:37 ` [PATCH v13 05/10] soc: qcom: cpr: Move common functions to new file Konrad Dybcio
2023-08-02 12:37 ` [PATCH v13 06/10] soc: qcom: cpr-common: Add support for flat fuse adjustment Konrad Dybcio
2023-08-02 12:37 ` Konrad Dybcio [this message]
2023-08-02 12:37 ` [PATCH v13 08/10] soc: qcom: cpr-common: Add threads support Konrad Dybcio
2023-08-02 12:37 ` [PATCH v13 09/10] soc: qcom: Add support for Core Power Reduction v3, v4 and Hardened Konrad Dybcio
2023-08-02 12:37 ` [PATCH v13 10/10] arm64: dts: qcom: msm8998: Configure CPRh Konrad Dybcio
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20230217-topic-cpr3h-v13-7-d01cff1c54cf@linaro.org \
--to=konrad.dybcio@linaro.org \
--cc=agross@kernel.org \
--cc=andersson@kernel.org \
--cc=angelogioacchino.delregno@collabora.com \
--cc=broonie@kernel.org \
--cc=conor+dt@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=krzysztof.kozlowski+dt@linaro.org \
--cc=lgirdwood@gmail.com \
--cc=linux-arm-msm@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pm@vger.kernel.org \
--cc=marijn.suijten@somainline.org \
--cc=nks@flawful.org \
--cc=nm@ti.com \
--cc=quic_jhugo@quicinc.com \
--cc=rafael@kernel.org \
--cc=robh+dt@kernel.org \
--cc=robimarko@gmail.com \
--cc=sboyd@kernel.org \
--cc=ulf.hansson@linaro.org \
--cc=viresh.kumar@linaro.org \
--cc=vireshk@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).