From: Stephan Gerhold <stephan@gerhold.net>
To: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
Cc: Andy Gross <agross@kernel.org>,
Bjorn Andersson <andersson@kernel.org>,
Konrad Dybcio <konrad.dybcio@somainline.org>,
Rob Herring <robh+dt@kernel.org>,
Krzysztof Kozlowski <krzysztof.kozlowski+dt@linaro.org>,
Amit Kucheria <amitk@kernel.org>,
Thara Gopinath <thara.gopinath@gmail.com>,
"Rafael J. Wysocki" <rafael@kernel.org>,
Daniel Lezcano <daniel.lezcano@linaro.org>,
Zhang Rui <rui.zhang@intel.com>,
linux-arm-msm@vger.kernel.org, linux-pm@vger.kernel.org,
devicetree@vger.kernel.org
Subject: Re: [RFC PATCH 00/10] thermal/drivers/tsens: specify nvmem cells in DT rather than parsing them manually
Date: Sun, 25 Sep 2022 14:28:36 +0200 [thread overview]
Message-ID: <YzBJdG0niOotj9K1@gerhold.net> (raw)
In-Reply-To: <722E6DEE-BD57-4573-A151-508917961D1B@linaro.org>
On Sun, Sep 25, 2022 at 02:21:11PM +0300, Dmitry Baryshkov wrote:
> On 25 September 2022 13:20:09 GMT+03:00, Stephan Gerhold <stephan@gerhold.net> wrote:
> >On Sat, Sep 24, 2022 at 09:58:56PM +0300, Dmitry Baryshkov wrote:
> >> On 22/09/2022 20:23, Stephan Gerhold wrote:
> >> > On Sat, Sep 10, 2022 at 03:46:51PM +0300, Dmitry Baryshkov wrote:
> >> > > Historically the tsens driver fetches the calibration data as a blob and
> >> > > then parses the blob on its own. This results in semi-duplicated code
> >> > > spreading over the platform-specific functions.
> >> > >
> >> > > This patch series changes tsens calibration code to use pre-parsed nvmem
> >> > > cells rather than parsing the blob in the driver. For backwards
> >> > > compatibility the old code is left in place for msm8916 and qcs404, two
> >> > > platforms which have in-tree DT files. For msm8974 the original function
> >> > > is left intact, since it differs significantly (and I can not test the
> >> > > code on msm8974). For all other affected platforms the old parsing code
> >> > > has been dropped as a part of this RFC.
> >> > >
> >> > > The code was tested on msm8916 and qcs404 only, thus it is being sent as
> >> > > an RFC.
> >> > >
> >> >
> >> > Thanks a lot for working on this!
> >> >
> >> > After thinking about this for a while I wonder if we can go even a step
> >> > further: Can we drop SoC-specific code entirely for 8939 and 9607 and
> >> > match the generic compatible (qcom,tsens-v0_1)? This would allow most
> >> > v0.1 plaforms to use generic code like for qcom,tsens-v2.
> >>
> >> While this idea looks appealing, I think it's a bit against our custom to
> >> put hardware details into the driver rather than putting them into the DT.
> >> So, I think, the 8939 will have to stay as is, while for the 9607 and maybe
> >> several other devices it should be possible to create a fallback entry.
> >>
> >
> >IMHO the existing tsens-v2 support is a good example that it's sometimes
> >better to have some minor hardware details in the DT so the driver does
> >not have to be changed for every single platform. Extending from
> >specifying the number of sensors in the DT to the exact set of sensors
> >is not a very big step.
>
> Fine, I will take a look.
>
Thanks!
> >
> >Also, aren't you also going against the custom here by moving the fuse
> >hardware details to the DT? :)
>
> Not quite. Fuses are completely software thing.
>
Good point, but this depends on the point of view: Since those fuses are
likely "burned in" at the factory I would consider them to be part of
"hardware" like everything else. Even if I wanted to I probably couldn't
change anything about the layout, at least as a user (and probably even
as a customer). :-)
> >
> >> [...]
> >> > And actually there are two revisions of 8939, the older one has one
> >> > sensor less (msm-3.10: msm8939-common.dtsi vs msm8939-v3.0.dtsi).
> >> > This could also be easily handled from the DT without any code changes:
> >> >
> >> > qcom,sensors = <0 1 2 3 5 6 7 8 9>;
> >>
> >> Usually we only care about the latest revision of the chip, earlier
> >> revisions typically correspond to engineering samples, never hitting the
> >> actual consumer devices.
> >>
> >
> >I'm afraid we might have to care about both revisions here - I recently
> >checked a couple of MSM8939 devices in postmarketOS and there are
> >definitely two different revisions used in production - they are easily
> >identifiable since they have different CPU revisions in the "lscpu"
> >output (Cortex-A53 r0p1 vs r0p4).
>
> Ugh.
>
Indeed.
Thanks,
Stephan
prev parent reply other threads:[~2022-09-25 12:28 UTC|newest]
Thread overview: 25+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-09-10 12:46 [RFC PATCH 00/10] thermal/drivers/tsens: specify nvmem cells in DT rather than parsing them manually Dmitry Baryshkov
2022-09-10 12:46 ` [RFC PATCH 01/10] dt-bindings: thermal: tsens: support per-sensor calibration cells Dmitry Baryshkov
2022-09-11 13:37 ` Krzysztof Kozlowski
2022-09-13 19:19 ` Amit Kucheria
2022-09-10 12:46 ` [RFC PATCH 02/10] thermal/drivers/tsens: Support using nvmem cells for calibration data Dmitry Baryshkov
2022-09-13 19:18 ` Amit Kucheria
2022-09-13 21:07 ` Dmitry Baryshkov
2022-09-10 12:46 ` [RFC PATCH 03/10] thermal/drivers/tsens: drop single-cell code for msm8939 Dmitry Baryshkov
2022-09-10 12:46 ` [RFC PATCH 04/10] thermal/drivers/tsens: drop single-cell code for mdm9607 Dmitry Baryshkov
2022-09-10 12:46 ` [RFC PATCH 05/10] thermal/drivers/tsens: drop msm8976-specific defines Dmitry Baryshkov
2022-09-12 8:52 ` AngeloGioacchino Del Regno
2022-09-10 12:46 ` [RFC PATCH 06/10] thermal/drivers/tsens: use generic calibration routine for msm8976 Dmitry Baryshkov
2022-09-12 8:57 ` AngeloGioacchino Del Regno
2022-09-12 9:47 ` Dmitry Baryshkov
2022-09-24 16:42 ` Dmitry Baryshkov
2022-09-10 12:46 ` [RFC PATCH 07/10] thermal/drivers/tsens: use tsens_calibrate_nvmem for msm8976 calibration Dmitry Baryshkov
2022-09-10 12:46 ` [RFC PATCH 08/10] thermal/drivers/tsens: drop single-cell code for msm8976 Dmitry Baryshkov
2022-09-10 12:47 ` [RFC PATCH 09/10] arm64: dts: qcom: msm8916: specify per-sensor calibration cells Dmitry Baryshkov
2022-09-11 13:38 ` Krzysztof Kozlowski
2022-09-10 12:47 ` [RFC PATCH 10/10] arm64: dts: qcom: qcs404: " Dmitry Baryshkov
2022-09-22 17:23 ` [RFC PATCH 00/10] thermal/drivers/tsens: specify nvmem cells in DT rather than parsing them manually Stephan Gerhold
2022-09-24 18:58 ` Dmitry Baryshkov
2022-09-25 10:20 ` Stephan Gerhold
2022-09-25 11:21 ` Dmitry Baryshkov
2022-09-25 12:28 ` Stephan Gerhold [this message]
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=YzBJdG0niOotj9K1@gerhold.net \
--to=stephan@gerhold.net \
--cc=agross@kernel.org \
--cc=amitk@kernel.org \
--cc=andersson@kernel.org \
--cc=daniel.lezcano@linaro.org \
--cc=devicetree@vger.kernel.org \
--cc=dmitry.baryshkov@linaro.org \
--cc=konrad.dybcio@somainline.org \
--cc=krzysztof.kozlowski+dt@linaro.org \
--cc=linux-arm-msm@vger.kernel.org \
--cc=linux-pm@vger.kernel.org \
--cc=rafael@kernel.org \
--cc=robh+dt@kernel.org \
--cc=rui.zhang@intel.com \
--cc=thara.gopinath@gmail.com \
/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