All of lore.kernel.org
 help / color / mirror / Atom feed
From: Stephen Boyd <swboyd@chromium.org>
To: Lina Iyer <ilina@codeaurora.org>,
	evgreen@chromium.org, linus.walleij@linaro.org, maz@kernel.org
Cc: linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org,
	bjorn.andersson@linaro.org, mkshah@codeaurora.org,
	linux-gpio@vger.kernel.org, Lina Iyer <ilina@codeaurora.org>,
	devicetree@vger.kernel.org
Subject: Re: [PATCH RFC v2 06/14] dt-bindings/interrupt-controller: pdc: add SPI config register
Date: Tue, 15 Oct 2019 23:27:20 -0700	[thread overview]
Message-ID: <5da6b849.1c69fb81.a9b04.1b9f@mx.google.com> (raw)
In-Reply-To: <5d92829e.1c69fb81.d860a.9096@mx.google.com>

Quoting Stephen Boyd (2019-09-30 15:33:01)
> Quoting Lina Iyer (2019-09-13 14:59:14)
> > In addition to configuring the PDC, additional registers that interface
> > the GIC have to be configured to match the GPIO type. The registers on
> > some QCOM SoCs are access restricted, while on other SoCs are not. They
> > SoCs with access restriction to these SPI registers need to be written
> > from the firmware using the SCM interface. Add a flag to indicate if the
> > register is to be written using SCM interface.
> > 
> > Cc: devicetree@vger.kernel.org
> > Signed-off-by: Lina Iyer <ilina@codeaurora.org>
> > ---
> >  .../devicetree/bindings/interrupt-controller/qcom,pdc.txt   | 13 ++++++++++++-
> >  1 file changed, 12 insertions(+), 1 deletion(-)
> > 
> > diff --git a/Documentation/devicetree/bindings/interrupt-controller/qcom,pdc.txt b/Documentation/devicetree/bindings/interrupt-controller/qcom,pdc.txt
> > index 8e0797c..e329f8d 100644
> > --- a/Documentation/devicetree/bindings/interrupt-controller/qcom,pdc.txt
> > +++ b/Documentation/devicetree/bindings/interrupt-controller/qcom,pdc.txt
> > @@ -24,6 +24,9 @@ Properties:
> >         Usage: required
> >         Value type: <prop-encoded-array>
> >         Definition: Specifies the base physical address for PDC hardware.
> > +                   Optionally, specify the PDC's GIC interface registers that
> > +                   need to be configured for wakeup capable GPIOs routed to
> > +                   the PDC.
> >  
> >  - interrupt-cells:
> >         Usage: required
> > @@ -50,15 +53,23 @@ Properties:
> >                     The second element is the GIC hwirq number for the PDC port.
> >                     The third element is the number of interrupts in sequence.
> >  
> > +- qcom,scm-spi-cfg:
> > +       Usage: optional
> > +       Value type: <bool>
> > +       Definition: Specifies if the SPI configuration registers have to be
> > +                   written from the firmware. Sometimes the PDC interface
> > +                   register to the GIC can only be written from the firmware.
> > +
> >  Example:
> >  
> >         pdc: interrupt-controller@b220000 {
> >                 compatible = "qcom,sdm845-pdc";
> > -               reg = <0xb220000 0x30000>;
> > +               reg = <0 0x0b220000 0 0x30000>, <0 0x179900f0 0 0x60>;
> >                 qcom,pdc-ranges = <0 512 94>, <94 641 15>, <115 662 7>;
> >                 #interrupt-cells = <2>;
> >                 interrupt-parent = <&intc>;
> >                 interrupt-controller;
> > +               qcom,scm-spi-cfg;
> >         };
> 
> This overlaps register region with the mailbox node. That node is
> actually a pile of random "CPU" registers used to ping remote processors
> and apparently control how the PDC interacts with the GIC. Maybe this
> can be changed to a phandle and then the driver can interogate the
> phandle to determine if it's the SCM firmware or if it's the shared
> mailbox register? If it's a shared mailbox then it can write to it at
> the offset it knows about (because it's sdm845 compatible specific) and
> if it's SCM then it can use the hardcoded address as well?
> 
> Basically I'm saying that it just needs a phandle.
> 
>         qcom,spi-cfg = <&scm>;
> 
> or
> 
>         qcom,spi-cfg = <&mailbox>;
> 
> and then driver knows how to use that to write into random registers.
> Maybe we can have an API in regmap that finds the regmap for a given
> device node? That way we don't have to funnel everything through syscon
> for this.
> 
>         of_get_regmap(struct device_node *np, const char *name);
> 
> Where NULL name means "first available" and then do the devres search
> otherwise for a device that has the matching node pointer.
> 

I had another idea the other day. Maybe a better approach would be to
make the mailbox or SCM code an interrupt controller with the
appropriate functions to poke the bits necessary to make the interrupts
work. Then we can make it a chip in the hierarchy between the GIC and
PDC and make the interrupts call through from PDC to GIC. The locking
could be handled in each respective driver if necessary, and otherwise
we don't have to use a regmap or remap the same registers (except we may
need to describe if the parent is the mailbox node or the scm fimware
node).


  reply	other threads:[~2019-10-16  6:27 UTC|newest]

Thread overview: 35+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2019-09-13 21:59 [PATCH RFC v2 00/14] Support wakeup capable GPIOs Lina Iyer
2019-09-13 21:59 ` [PATCH RFC v2 01/14] irqdomain: add bus token DOMAIN_BUS_WAKEUP Lina Iyer
2019-09-13 21:59 ` [PATCH RFC v2 02/14] drivers: irqchip: qcom-pdc: update max PDC interrupts Lina Iyer
2019-09-13 21:59 ` [PATCH RFC v2 03/14] drivers: irqchip: pdc: Do not toggle IRQ_ENABLE during mask/unmask Lina Iyer
2019-09-13 21:59 ` [PATCH RFC v2 04/14] drivers: irqchip: add PDC irqdomain for wakeup capable GPIOs Lina Iyer
2019-11-08 21:21   ` Doug Anderson
2019-11-08 21:54     ` Lina Iyer
2019-11-08 22:16       ` Lina Iyer
2019-11-08 22:57         ` Doug Anderson
2019-11-08 23:14           ` Lina Iyer
2019-09-13 21:59 ` [PATCH RFC v2 05/14] of: irq: document properties for wakeup interrupt parent Lina Iyer
2019-10-03 12:02   ` Linus Walleij
2019-10-03 12:02     ` Linus Walleij
2019-11-08 21:29   ` Doug Anderson
2019-09-13 21:59 ` [PATCH RFC v2 06/14] dt-bindings/interrupt-controller: pdc: add SPI config register Lina Iyer
2019-09-30 22:14   ` Rob Herring
2019-09-30 22:14     ` Rob Herring
2019-09-30 22:33   ` Stephen Boyd
2019-09-30 22:33     ` Stephen Boyd
2019-10-16  6:27     ` Stephen Boyd [this message]
2019-11-05 20:58       ` Lina Iyer
2019-11-06  0:53         ` Stephen Boyd
2019-11-11 18:37           ` Lina Iyer
2019-11-12 11:52             ` Marc Zyngier
2019-09-13 21:59 ` [PATCH RFC v2 07/14] drivers: irqchip: pdc: additionally set type in SPI config registers Lina Iyer
2019-09-13 21:59 ` [PATCH RFC v2 08/14] genirq: Introduce irq_chip_get/set_parent_state calls Lina Iyer
2019-09-13 21:59 ` [PATCH RFC v2 09/14] drivers: irqchip: pdc: Add irqchip set/get state calls Lina Iyer
2019-09-13 21:59 ` [PATCH RFC v2 10/14] drivers: pinctrl: msm: setup GPIO chip in hierarchy Lina Iyer
2019-10-03 12:17   ` Linus Walleij
2019-11-13 18:35     ` Lina Iyer
2019-09-13 21:59 ` [PATCH RFC v2 11/14] drivers: pinctrl: sdm845: add PDC wakeup interrupt map for GPIOs Lina Iyer
2019-10-03 12:18   ` Linus Walleij
2019-09-13 21:59 ` [PATCH RFC v2 12/14] arm64: dts: qcom: add PDC interrupt controller for SDM845 Lina Iyer
2019-09-13 21:59 ` [PATCH RFC v2 13/14] arm64: dts: qcom: setup PDC as the wakeup parent for TLMM on SDM845 Lina Iyer
2019-09-13 21:59 ` [PATCH RFC v2 14/14] arm64: defconfig: enable PDC interrupt controller for Qualcomm SDM845 Lina Iyer

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=5da6b849.1c69fb81.a9b04.1b9f@mx.google.com \
    --to=swboyd@chromium.org \
    --cc=bjorn.andersson@linaro.org \
    --cc=devicetree@vger.kernel.org \
    --cc=evgreen@chromium.org \
    --cc=ilina@codeaurora.org \
    --cc=linus.walleij@linaro.org \
    --cc=linux-arm-msm@vger.kernel.org \
    --cc=linux-gpio@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=maz@kernel.org \
    --cc=mkshah@codeaurora.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.