From: Heiko Stuebner <heiko@sntech.de>
To: Atish Patra <atishp@atishpatra.org>
Cc: Palmer Dabbelt <palmer@dabbelt.com>,
Paul Walmsley <paul.walmsley@sifive.com>,
linux-riscv <linux-riscv@lists.infradead.org>,
"linux-kernel@vger.kernel.org List"
<linux-kernel@vger.kernel.org>, Wei Fu <wefu@redhat.com>,
Guo Ren <guoren@kernel.org>,
Christoph Muellner <cmuellner@linux.com>,
Philipp Tomsich <philipp.tomsich@vrull.eu>,
Christoph Hellwig <hch@lst.de>,
Samuel Holland <samuel@sholland.org>,
Anup Patel <anup@brainfault.org>,
Nick Kossifidis <mick@ics.forth.gr>,
Rob Herring <robh+dt@kernel.org>,
krzk+dt@kernel.org, devicetree <devicetree@vger.kernel.org>,
Drew Fustini <drew@beagleboard.org>,
Randy Dunlap <rdunlap@infradead.org>
Subject: Re: [PATCH 1/4] of: also handle dma-noncoherent in of_dma_is_coherent()
Date: Mon, 20 Jun 2022 20:11:06 +0200 [thread overview]
Message-ID: <5907887.LM0AJKV5NW@phil> (raw)
In-Reply-To: <CAOnJCUJC3dk21cYXXDOsamvwFDHsukoBx7HEYwqHM+MN5fLRpA@mail.gmail.com>
Hi Atish,
Am Montag, 20. Juni 2022, 18:33:09 CEST schrieb Atish Patra:
> On Sun, Jun 19, 2022 at 1:32 PM Heiko Stuebner <heiko@sntech.de> wrote:
> >
> > of_dma_is_coherent() currently expects the architecture to be
> > non-coherent and some devices being coherent getting marked
> > as such with the dma-coherent devicetree property.
> >
> > For PowerPC CONFIG_OF_DMA_DEFAULT_COHERENT was added which currently
> > makes of_dma_is_coherent() always return true but doesn't handle
> > the case of the architecture being coherent but some devices not.
> >
> > So modify the function to also check for dma-noncoherent and
> > set a suitable default return value. If CONFIG_OF_DMA_DEFAULT_COHERENT
> > is set the value starts with true and finding dma-noncoherent will
> > set it to false and without CONFIG_OF_DMA_DEFAULT_COHERENT, the
> > behaviour is reversed.
> >
> > Signed-off-by: Heiko Stuebner <heiko@sntech.de>
> > ---
> > drivers/of/address.c | 16 +++++++++++-----
> > 1 file changed, 11 insertions(+), 5 deletions(-)
> >
> > diff --git a/drivers/of/address.c b/drivers/of/address.c
> > index 94f017d808c4..1c362d09983d 100644
> > --- a/drivers/of/address.c
> > +++ b/drivers/of/address.c
> > @@ -1045,26 +1045,32 @@ phys_addr_t __init of_dma_get_max_cpu_address(struct device_node *np)
> > *
> > * It returns true if "dma-coherent" property was found
> > * for this device in the DT, or if DMA is coherent by
> > - * default for OF devices on the current platform.
> > + * default for OF devices on the current platform and no
> > + * "dma-noncoherent" property was found for this device.
>
> "dma-noncoherent" is not a standard DT property. I couldn't find any
> references to
> it in the kernel as well. If we are introducing a new DT property for
> non-coherent devices,
> it should be added in DT bindings as well ?
The dma-coherent is part of the core devicetree-spec,
so I sent a patch adding dma-noncoherent [0]
to the devicetree-spec mailing list yesterday as well.
[0] https://www.spinics.net/lists/devicetree-spec/msg01053.html
>
> > */
> > bool of_dma_is_coherent(struct device_node *np)
> > {
> > struct device_node *node;
> > + bool ret = false;
> >
> > if (IS_ENABLED(CONFIG_OF_DMA_DEFAULT_COHERENT))
> > - return true;
> > + ret = true;
> >
> > node = of_node_get(np);
> >
> > while (node) {
> > if (of_property_read_bool(node, "dma-coherent")) {
> > - of_node_put(node);
> > - return true;
> > + ret = true;
> > + break;
> > + }
> > + if (of_property_read_bool(node, "dma-noncoherent")) {
> > + ret = false;
> > + break;
> > }
> > node = of_get_next_dma_parent(node);
> > }
> > of_node_put(node);
> > - return false;
> > + return ret;
> > }
> > EXPORT_SYMBOL_GPL(of_dma_is_coherent);
> >
> > --
> > 2.35.1
> >
>
>
>
_______________________________________________
linux-riscv mailing list
linux-riscv@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-riscv
WARNING: multiple messages have this Message-ID (diff)
From: Heiko Stuebner <heiko@sntech.de>
To: Atish Patra <atishp@atishpatra.org>
Cc: Palmer Dabbelt <palmer@dabbelt.com>,
Paul Walmsley <paul.walmsley@sifive.com>,
linux-riscv <linux-riscv@lists.infradead.org>,
"linux-kernel@vger.kernel.org List"
<linux-kernel@vger.kernel.org>, Wei Fu <wefu@redhat.com>,
Guo Ren <guoren@kernel.org>,
Christoph Muellner <cmuellner@linux.com>,
Philipp Tomsich <philipp.tomsich@vrull.eu>,
Christoph Hellwig <hch@lst.de>,
Samuel Holland <samuel@sholland.org>,
Anup Patel <anup@brainfault.org>,
Nick Kossifidis <mick@ics.forth.gr>,
Rob Herring <robh+dt@kernel.org>,
krzk+dt@kernel.org, devicetree <devicetree@vger.kernel.org>,
Drew Fustini <drew@beagleboard.org>,
Randy Dunlap <rdunlap@infradead.org>
Subject: Re: [PATCH 1/4] of: also handle dma-noncoherent in of_dma_is_coherent()
Date: Mon, 20 Jun 2022 20:11:06 +0200 [thread overview]
Message-ID: <5907887.LM0AJKV5NW@phil> (raw)
In-Reply-To: <CAOnJCUJC3dk21cYXXDOsamvwFDHsukoBx7HEYwqHM+MN5fLRpA@mail.gmail.com>
Hi Atish,
Am Montag, 20. Juni 2022, 18:33:09 CEST schrieb Atish Patra:
> On Sun, Jun 19, 2022 at 1:32 PM Heiko Stuebner <heiko@sntech.de> wrote:
> >
> > of_dma_is_coherent() currently expects the architecture to be
> > non-coherent and some devices being coherent getting marked
> > as such with the dma-coherent devicetree property.
> >
> > For PowerPC CONFIG_OF_DMA_DEFAULT_COHERENT was added which currently
> > makes of_dma_is_coherent() always return true but doesn't handle
> > the case of the architecture being coherent but some devices not.
> >
> > So modify the function to also check for dma-noncoherent and
> > set a suitable default return value. If CONFIG_OF_DMA_DEFAULT_COHERENT
> > is set the value starts with true and finding dma-noncoherent will
> > set it to false and without CONFIG_OF_DMA_DEFAULT_COHERENT, the
> > behaviour is reversed.
> >
> > Signed-off-by: Heiko Stuebner <heiko@sntech.de>
> > ---
> > drivers/of/address.c | 16 +++++++++++-----
> > 1 file changed, 11 insertions(+), 5 deletions(-)
> >
> > diff --git a/drivers/of/address.c b/drivers/of/address.c
> > index 94f017d808c4..1c362d09983d 100644
> > --- a/drivers/of/address.c
> > +++ b/drivers/of/address.c
> > @@ -1045,26 +1045,32 @@ phys_addr_t __init of_dma_get_max_cpu_address(struct device_node *np)
> > *
> > * It returns true if "dma-coherent" property was found
> > * for this device in the DT, or if DMA is coherent by
> > - * default for OF devices on the current platform.
> > + * default for OF devices on the current platform and no
> > + * "dma-noncoherent" property was found for this device.
>
> "dma-noncoherent" is not a standard DT property. I couldn't find any
> references to
> it in the kernel as well. If we are introducing a new DT property for
> non-coherent devices,
> it should be added in DT bindings as well ?
The dma-coherent is part of the core devicetree-spec,
so I sent a patch adding dma-noncoherent [0]
to the devicetree-spec mailing list yesterday as well.
[0] https://www.spinics.net/lists/devicetree-spec/msg01053.html
>
> > */
> > bool of_dma_is_coherent(struct device_node *np)
> > {
> > struct device_node *node;
> > + bool ret = false;
> >
> > if (IS_ENABLED(CONFIG_OF_DMA_DEFAULT_COHERENT))
> > - return true;
> > + ret = true;
> >
> > node = of_node_get(np);
> >
> > while (node) {
> > if (of_property_read_bool(node, "dma-coherent")) {
> > - of_node_put(node);
> > - return true;
> > + ret = true;
> > + break;
> > + }
> > + if (of_property_read_bool(node, "dma-noncoherent")) {
> > + ret = false;
> > + break;
> > }
> > node = of_get_next_dma_parent(node);
> > }
> > of_node_put(node);
> > - return false;
> > + return ret;
> > }
> > EXPORT_SYMBOL_GPL(of_dma_is_coherent);
> >
> > --
> > 2.35.1
> >
>
>
>
next prev parent reply other threads:[~2022-06-20 18:12 UTC|newest]
Thread overview: 25+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-06-19 20:32 [PATCH v4 0/4] riscv: implement Zicbom-based CMO instructions + the t-head variant Heiko Stuebner
2022-06-19 20:32 ` Heiko Stuebner
2022-06-19 20:32 ` [PATCH 1/4] of: also handle dma-noncoherent in of_dma_is_coherent() Heiko Stuebner
2022-06-19 20:32 ` Heiko Stuebner
2022-06-20 6:01 ` Christoph Hellwig
2022-06-20 6:01 ` Christoph Hellwig
2022-06-20 16:33 ` Atish Patra
2022-06-20 16:33 ` Atish Patra
2022-06-20 18:11 ` Heiko Stuebner [this message]
2022-06-20 18:11 ` Heiko Stuebner
2022-06-20 19:41 ` Atish Patra
2022-06-20 19:41 ` Atish Patra
2022-06-19 20:32 ` [PATCH 2/4] dt-bindings: riscv: document cbom-block-size Heiko Stuebner
2022-06-19 20:32 ` Heiko Stuebner
2022-06-19 20:32 ` [PATCH 3/4] riscv: Implement Zicbom-based cache management operations Heiko Stuebner
2022-06-19 20:32 ` Heiko Stuebner
2022-06-20 6:16 ` Christoph Hellwig
2022-06-20 6:16 ` Christoph Hellwig
2022-06-24 7:49 ` Heiko Stuebner
2022-06-24 7:49 ` Heiko Stuebner
2022-06-19 20:32 ` [PATCH 4/4] riscv: implement cache-management errata for T-Head SoCs Heiko Stuebner
2022-06-19 20:32 ` Heiko Stuebner
2022-06-20 0:53 ` kernel test robot
2022-06-29 1:29 ` Samuel Holland
2022-06-29 1:29 ` Samuel Holland
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=5907887.LM0AJKV5NW@phil \
--to=heiko@sntech.de \
--cc=anup@brainfault.org \
--cc=atishp@atishpatra.org \
--cc=cmuellner@linux.com \
--cc=devicetree@vger.kernel.org \
--cc=drew@beagleboard.org \
--cc=guoren@kernel.org \
--cc=hch@lst.de \
--cc=krzk+dt@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-riscv@lists.infradead.org \
--cc=mick@ics.forth.gr \
--cc=palmer@dabbelt.com \
--cc=paul.walmsley@sifive.com \
--cc=philipp.tomsich@vrull.eu \
--cc=rdunlap@infradead.org \
--cc=robh+dt@kernel.org \
--cc=samuel@sholland.org \
--cc=wefu@redhat.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 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.