[PATCH v3 2/5] dt-bindings: soc: add document for rockchip reboot notifier driver
Heiko Stübner
heiko at sntech.de
Tue Dec 1 07:47:36 PST 2015
Hi Andy,
Am Dienstag, 1. Dezember 2015, 23:10:15 schrieb Andy Yan:
> 2015-11-23 21:15 GMT+08:00 Andy Yan <andyshrk at gmail.com>:
> > 2015-11-20 9:58 GMT+08:00 Rob Herring <robh at kernel.org>:
> >> On Thu, Nov 19, 2015 at 7:16 PM, Andy Yan <andy.yan at rock-chips.com>
> >>
> >> wrote:
> >> > On 2015年11月19日 12:35, Heiko Stuebner wrote:
> >> >> Am Donnerstag, 19. November 2015, 09:17:37 schrieb Andy Yan:
> >> >>> On 2015年11月19日 06:59, Rob Herring wrote:
> >> >>>> On Wed, Nov 18, 2015 at 05:53:30PM +0800, Andy Yan wrote:
> >> >>>>> Add devicetree binding document for rockchip reboot nofifier driver
> >> >>>>
> >> >>>> Just reading the subject this is way too specific to the Linux
> >> >>>> driver
> >> >>>> needs rather than a h/w description. Please don't create fake DT
> >>
> >> nodes
> >>
> >> >>>> just to bind to drivers. Whatever &pmu is is probably what should
> >>
> >> have
> >>
> >> >>>> the DT node. Let the driver for it create child devices if you need
> >> >>>> that.
> >> >>>>
> >> >>> This is note a fake DT nodes, we really need it to tell the
> >>
> >> driver
> >>
> >> >>> which register to use to store the reboot mode. Because
> >>
> >> rockchip
> >>
> >> >>> use different register file to store the reboot mode on
> >>
> >> different
> >>
> >> >>> platform, on rk3066,rk3188, rk3288,it use one of the PMU
> >> >>>
> >> >>> register, on
> >> >>>
> >> >>> the incoming RK3036, it use one of the GRF register, and it
> >> >>> use
> >> >>>
> >> >>> one of
> >> >>>
> >> >>> the PMUGRF register for arm64 platform rk3368. On the other
> >>
> >> hand,
> >>
> >> >>> the
> >> >>>
> >> >>> PMU/GRF/PMUGRF register file are mapped as "syscon", then
> >> >>>
> >> >>> referenced
> >> >>>
> >> >>> by other DT nodes by phandle. So maybe let it as a separate DT
> >> >>>
> >> >>> node here
> >> >>>
> >> >>> is better.
> >> >>
> >> >> or alternatively we could do something similar to what the bl-switcher
> >> >> cupfreq-driver does. Take a look at
> >> >>
> >> >> drivers/cpufreq/arm_big_little.c
> >> >> drivers/clk/clk-mb86s7x.c
> >> >>
> >> >> We already have the core restart-handler code in the clock-tree, so
> >>
> >> could
> >>
> >> >> maybe simply do the
> >> >>
> >> >> platform_device_register_simple("rockchip-reboot", -1, NULL,
> >>
> >> 0);
> >>
> >> >> in that common code?
> >> >>
> >> >> Though I'm not yet sure how to get the platform-data. I guess one
> >>
> >> option
> >>
> >> >> would
> >> >> be to do things like the 3288 suspend code does
> >> >> (arch/arm/mach-rockchip/pm.c
> >> >> at the bottom), by having the per-soc-data in the driver and then
> >>
> >> matching
> >>
> >> >> against the pmu. Because the pmu is not part of the clock controller
> >> >> binding
> >> >> (and probably also shouldn't be).
> >> >>
> >> > Thanks for your suggestion.
> >> >
> >> > I have read the code you list above, if we implement the reboot
> >>
> >> notifier
> >>
> >> > driver like this, the driver need to add much more code to find the
> >> >
> >> > platform
> >> >
> >> > data(like arch/arm/mach-rockhcip/pm.c), what's more, if we have a
> >>
> >> new
> >>
> >> > soc
> >> >
> >> > in the future and the soc use a different register here, we need
> >>
> >> modify
> >>
> >> > the
> >> >
> >> > driver to add a new platform data again, this will bring additional
> >> >
> >> > work.
> >> >
> >> > Use the DT node pass the register will make the driver code simple
> >>
> >> and
> >>
> >> > clear.
> >> >
> >> > Is there any hurt to put this information in the DT?
> >>
> >> Add the data you need to the PMU node. Then the PMU driver can get it
> >> and pass to the child driver.
> >>
> >> Rob
> >> --
> >>
> > Do you mean I should implement the DT node like this?
> >
> > diff --git a/arch/arm/boot/dts/rk3xxx.dtsi
> >
> > b/arch/arm/boot/dts/rk3xxx.dtsi
> > index 7b14d7a..1735d09 100644
> > --- a/arch/arm/boot/dts/rk3xxx.dtsi
> > +++ b/arch/arm/boot/dts/rk3xxx.dtsi
> > @@ -103,12 +103,6 @@
> >
> > };
> >
> > };
> >
> > - reboot {
> > - compatible = "rockchip,reboot";
> > - rockchip,regmap = <&pmu>;
> > - offset = <0x40>;
> > - };
> > -
> >
> > xin24m: oscillator {
> >
> > compatible = "fixed-clock";
> > clock-frequency = <24000000>;
> >
> > @@ -249,7 +243,11 @@
> >
> > pmu: pmu at 20004000 {
> >
> > compatible = "rockchip,rk3066-pmu", "syscon";
> >
> > - reg = <0x20004000 0x100>;
> > + reg = <0x20004000 0x100>;
> > + reboot {
> > + compatible = "rockchip,reboot";
> > + offset = <0x40>;
> > + };
> >
> > };
> >
> > diff --git a/arch/arm64/boot/dts/rockchip/rk3368.dtsi
> > b/arch/arm64/boot/dts/rockchip/rk3368.dtsi
> > index cd02229..8a9837a 100644
> > --- a/arch/arm64/boot/dts/rockchip/rk3368.dtsi
> > +++ b/arch/arm64/boot/dts/rockchip/rk3368.dtsi
> > @@ -202,12 +202,6 @@
> >
> > method = "smc";
> >
> > };
> >
> > - reboot {
> > - compatible = "rockchip,reboot";
> > - rockchip,regmap = <&pmugrf>;
> > - offset = <0x200>;
> > - };
> > -
> >
> > timer {
> >
> > compatible = "arm,armv8-timer";
> > interrupts = <GIC_PPI 13
> >
> > @@ -493,6 +487,10 @@
> >
> > pmugrf: syscon at ff738000 {
> >
> > compatible = "rockchip,rk3368-pmugrf", "syscon";
compatible = "rockchip,rk3368-pmugrf", "syscon", "simple-mfd";
> > reg = <0x0 0xff738000 0x0 0x1000>;
> >
> > + reboot {
> > + compatible = "rockchip,reboot";
> > + offset = <0x200>;
> > + };
> >
> > };
>
> Is there any further suggestion for this? If not, I will send the V4 with
> the DT node as a subnode in PMU or PMUGRF.
I guess Rob is the authority on this, but I'm not sure on the "devicetree
describes hardware" level.
On the one hand it is not really a hardware-device, but on the other hand it
is a firmware-interface (like psci etc, that's already in the devicetree
elsewhere), so I'd guess it should be ok.
Heiko
More information about the Linux-rockchip
mailing list