All of lore.kernel.org
 help / color / mirror / Atom feed
From: Paul Cercueil <paul@crapouillou.net>
To: Vinod <vkoul@kernel.org>
Cc: Rob Herring <robh+dt@kernel.org>,
	Mark Rutland <mark.rutland@arm.com>,
	Ralf Baechle <ralf@linux-mips.org>,
	Paul Burton <paul.burton@mips.com>,
	James Hogan <jhogan@kernel.org>,
	Zubair Lutfullah Kakakhel <Zubair.Kakakhel@imgtec.com>,
	Mathieu Malaterre <malat@debian.org>,
	Daniel Silsby <dansilsby@gmail.com>,
	dmaengine@vger.kernel.org, devicetree@vger.kernel.org,
	linux-kernel@vger.kernel.org, linux-mips@linux-mips.org
Subject: [02/14] dmaengine: dma-jz4780: Separate chan/ctrl registers
Date: Tue, 10 Jul 2018 17:36:58 +0200	[thread overview]
Message-ID: <1531237019.17118.1@crapouillou.net> (raw)

Le lun. 9 juil. 2018 à 19:03, Vinod <vkoul@kernel.org> a écrit :
> On 03-07-18, 14:32, Paul Cercueil wrote:
>>  The register area of the JZ4780 DMA core can be split into different
>>  sections for different purposes:
>> 
>>  * one set of registers is used to perform actions at the DMA core 
>> level,
>>  that will generally affect all channels;
>> 
>>  * one set of registers per DMA channel, to perform actions at the 
>> DMA
>>  channel level, that will only affect the channel in question.
>> 
>>  The problem rises when trying to support new versions of the JZ47xx
>>  Ingenic SoC. For instance, the JZ4770 has two DMA cores, each one
>>  with six DMA channels, and the register sets are interleaved:
>>  <DMA0 chan regs> <DMA1 chan regs> <DMA0 ctrl regs> <DMA1 ctrl regs>
>> 
>>  By using one memory resource for the channel-specific registers and
>>  one memory resource for the core-specific registers, we can support
>>  the JZ4770, by initializing the driver once per DMA core with 
>> different
>>  addresses.
>> 
>>  Signed-off-by: Paul Cercueil <paul@crapouillou.net>
>>  ---
>>   .../devicetree/bindings/dma/jz4780-dma.txt    |   6 +-
> 
> Pls move to separate patch.

OK.

>>   drivers/dma/dma-jz4780.c                      | 106 
>> +++++++++++-------
>>   2 files changed, 69 insertions(+), 43 deletions(-)
>> 
>>  diff --git a/Documentation/devicetree/bindings/dma/jz4780-dma.txt 
>> b/Documentation/devicetree/bindings/dma/jz4780-dma.txt
>>  index f25feee62b15..f9b1864f5b77 100644
>>  --- a/Documentation/devicetree/bindings/dma/jz4780-dma.txt
>>  +++ b/Documentation/devicetree/bindings/dma/jz4780-dma.txt
>>  @@ -3,7 +3,8 @@
>>   Required properties:
>> 
>>   - compatible: Should be "ingenic,jz4780-dma"
>>  -- reg: Should contain the DMA controller registers location and 
>> length.
>>  +- reg: Should contain the DMA channel registers location and 
>> length, followed
>>  +  by the DMA controller registers location and length.
>>   - interrupts: Should contain the interrupt specifier of the DMA 
>> controller.
>>   - interrupt-parent: Should be the phandle of the interrupt 
>> controller that
>>   - clocks: Should contain a clock specifier for the JZ4780 PDMA 
>> clock.
>>  @@ -22,7 +23,8 @@ Example:
>> 
>>   dma: dma@13420000 {
>>   	compatible = "ingenic,jz4780-dma";
>>  -	reg = <0x13420000 0x10000>;
>>  +	reg = <0x13420000 0x400
>>  +	       0x13421000 0x40>;
> 
> Second should be optional or we break platform which may not have
> updated DT..

See comment below.

>>  -	jzdma->base = devm_ioremap_resource(dev, res);
>>  -	if (IS_ERR(jzdma->base))
>>  -		return PTR_ERR(jzdma->base);
>>  +	jzdma->chn_base = devm_ioremap_resource(dev, res);
>>  +	if (IS_ERR(jzdma->chn_base))
>>  +		return PTR_ERR(jzdma->chn_base);
>>  +
>>  +	res = platform_get_resource(pdev, IORESOURCE_MEM, 1);
>>  +	if (!res) {
>>  +		dev_err(dev, "failed to get I/O memory\n");
>>  +		return -EINVAL;
>>  +	}
> 
> okay and this breaks if you happen to get probed on older DT. I think 
> DT
> is treated as ABI so you need to continue support older method while
> finding if DT has split resources

See my response to PrasannaKumar. All the Ingenic-based boards do 
compile
the devicetree within the kernel, so I think it's still fine to add 
breaking
changes. I'll wait on @Rob to give his point of view on this, though.

(It's not something hard to change, but I'd like to know what's the 
policy
in that case. I have other DT-breaking patches to submit)

> --
> ~Vinod
---
To unsubscribe from this list: send the line "unsubscribe dmaengine" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

WARNING: multiple messages have this Message-ID (diff)
From: Paul Cercueil <paul@crapouillou.net>
To: Vinod <vkoul@kernel.org>
Cc: Rob Herring <robh+dt@kernel.org>,
	Mark Rutland <mark.rutland@arm.com>,
	Ralf Baechle <ralf@linux-mips.org>,
	Paul Burton <paul.burton@mips.com>,
	James Hogan <jhogan@kernel.org>,
	Zubair Lutfullah Kakakhel <Zubair.Kakakhel@imgtec.com>,
	Mathieu Malaterre <malat@debian.org>,
	Daniel Silsby <dansilsby@gmail.com>,
	dmaengine@vger.kernel.org, devicetree@vger.kernel.org,
	linux-kernel@vger.kernel.org, linux-mips@linux-mips.org
Subject: Re: [PATCH 02/14] dmaengine: dma-jz4780: Separate chan/ctrl registers
Date: Tue, 10 Jul 2018 17:36:58 +0200	[thread overview]
Message-ID: <1531237019.17118.1@crapouillou.net> (raw)
In-Reply-To: <20180709170359.GI22377@vkoul-mobl>



Le lun. 9 juil. 2018 à 19:03, Vinod <vkoul@kernel.org> a écrit :
> On 03-07-18, 14:32, Paul Cercueil wrote:
>>  The register area of the JZ4780 DMA core can be split into different
>>  sections for different purposes:
>> 
>>  * one set of registers is used to perform actions at the DMA core 
>> level,
>>  that will generally affect all channels;
>> 
>>  * one set of registers per DMA channel, to perform actions at the 
>> DMA
>>  channel level, that will only affect the channel in question.
>> 
>>  The problem rises when trying to support new versions of the JZ47xx
>>  Ingenic SoC. For instance, the JZ4770 has two DMA cores, each one
>>  with six DMA channels, and the register sets are interleaved:
>>  <DMA0 chan regs> <DMA1 chan regs> <DMA0 ctrl regs> <DMA1 ctrl regs>
>> 
>>  By using one memory resource for the channel-specific registers and
>>  one memory resource for the core-specific registers, we can support
>>  the JZ4770, by initializing the driver once per DMA core with 
>> different
>>  addresses.
>> 
>>  Signed-off-by: Paul Cercueil <paul@crapouillou.net>
>>  ---
>>   .../devicetree/bindings/dma/jz4780-dma.txt    |   6 +-
> 
> Pls move to separate patch.

OK.

>>   drivers/dma/dma-jz4780.c                      | 106 
>> +++++++++++-------
>>   2 files changed, 69 insertions(+), 43 deletions(-)
>> 
>>  diff --git a/Documentation/devicetree/bindings/dma/jz4780-dma.txt 
>> b/Documentation/devicetree/bindings/dma/jz4780-dma.txt
>>  index f25feee62b15..f9b1864f5b77 100644
>>  --- a/Documentation/devicetree/bindings/dma/jz4780-dma.txt
>>  +++ b/Documentation/devicetree/bindings/dma/jz4780-dma.txt
>>  @@ -3,7 +3,8 @@
>>   Required properties:
>> 
>>   - compatible: Should be "ingenic,jz4780-dma"
>>  -- reg: Should contain the DMA controller registers location and 
>> length.
>>  +- reg: Should contain the DMA channel registers location and 
>> length, followed
>>  +  by the DMA controller registers location and length.
>>   - interrupts: Should contain the interrupt specifier of the DMA 
>> controller.
>>   - interrupt-parent: Should be the phandle of the interrupt 
>> controller that
>>   - clocks: Should contain a clock specifier for the JZ4780 PDMA 
>> clock.
>>  @@ -22,7 +23,8 @@ Example:
>> 
>>   dma: dma@13420000 {
>>   	compatible = "ingenic,jz4780-dma";
>>  -	reg = <0x13420000 0x10000>;
>>  +	reg = <0x13420000 0x400
>>  +	       0x13421000 0x40>;
> 
> Second should be optional or we break platform which may not have
> updated DT..

See comment below.

>>  -	jzdma->base = devm_ioremap_resource(dev, res);
>>  -	if (IS_ERR(jzdma->base))
>>  -		return PTR_ERR(jzdma->base);
>>  +	jzdma->chn_base = devm_ioremap_resource(dev, res);
>>  +	if (IS_ERR(jzdma->chn_base))
>>  +		return PTR_ERR(jzdma->chn_base);
>>  +
>>  +	res = platform_get_resource(pdev, IORESOURCE_MEM, 1);
>>  +	if (!res) {
>>  +		dev_err(dev, "failed to get I/O memory\n");
>>  +		return -EINVAL;
>>  +	}
> 
> okay and this breaks if you happen to get probed on older DT. I think 
> DT
> is treated as ABI so you need to continue support older method while
> finding if DT has split resources

See my response to PrasannaKumar. All the Ingenic-based boards do 
compile
the devicetree within the kernel, so I think it's still fine to add 
breaking
changes. I'll wait on @Rob to give his point of view on this, though.

(It's not something hard to change, but I'd like to know what's the 
policy
in that case. I have other DT-breaking patches to submit)

> --
> ~Vinod

             reply	other threads:[~2018-07-10 15:36 UTC|newest]

Thread overview: 97+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-07-10 15:36 Paul Cercueil [this message]
2018-07-10 15:36 ` [PATCH 02/14] dmaengine: dma-jz4780: Separate chan/ctrl registers Paul Cercueil
  -- strict thread matches above, loose matches on Subject: below --
2018-07-18  5:27 [05/14] dmaengine: dma-jz4780: Add support for the JZ4740 SoC Vinod Koul
2018-07-18  5:27 ` [PATCH 05/14] " Vinod
2018-07-17 17:40 [05/14] " Rob Herring
2018-07-17 17:40 ` [PATCH 05/14] " Rob Herring
2018-07-17 15:34 [05/14] " Vinod Koul
2018-07-17 15:34 ` [PATCH 05/14] " Vinod
2018-07-17 11:00 [05/14] " Paul Cercueil
2018-07-17 11:00 ` [PATCH 05/14] " Paul Cercueil
2018-07-16 21:33 [05/14] " Rob Herring
2018-07-16 21:33 ` [PATCH 05/14] " Rob Herring
2018-07-16 21:28 [02/14] dmaengine: dma-jz4780: Separate chan/ctrl registers Rob Herring
2018-07-16 21:28 ` [PATCH 02/14] " Rob Herring
2018-07-11 23:27 [02/14] " Paul Burton
2018-07-11 23:27 ` [PATCH 02/14] " Paul Burton
2018-07-11 23:13 [06/14] dmaengine: dma-jz4780: Add support for the JZ4725B SoC Paul Cercueil
2018-07-11 23:13 ` [PATCH 06/14] " Paul Cercueil
2018-07-11 23:13 [02/14] dmaengine: dma-jz4780: Separate chan/ctrl registers Paul Cercueil
2018-07-11 23:13 ` [PATCH 02/14] " Paul Cercueil
2018-07-11 12:18 [06/14] dmaengine: dma-jz4780: Add support for the JZ4725B SoC Vinod Koul
2018-07-11 12:18 ` [PATCH 06/14] " Vinod
2018-07-11 12:16 [02/14] dmaengine: dma-jz4780: Separate chan/ctrl registers Vinod Koul
2018-07-11 12:16 ` [PATCH 02/14] " Vinod
2018-07-11 12:14 [01/14] dmaengine: dma-jz4780: Avoid hardcoding number of channels Vinod Koul
2018-07-11 12:14 ` [PATCH 01/14] " Vinod
2018-07-10 15:45 [06/14] dmaengine: dma-jz4780: Add support for the JZ4725B SoC Paul Cercueil
2018-07-10 15:45 ` [PATCH 06/14] " Paul Cercueil
2018-07-10 15:41 [04/14] dmaengine: dma-jz4780: Add support for the JZ4770 SoC Paul Cercueil
2018-07-10 15:41 ` [PATCH 04/14] " Paul Cercueil
2018-07-09 17:14 [06/14] dmaengine: dma-jz4780: Add support for the JZ4725B SoC Vinod Koul
2018-07-09 17:14 ` [PATCH 06/14] " Vinod
2018-07-09 17:12 [05/14] dmaengine: dma-jz4780: Add support for the JZ4740 SoC Vinod Koul
2018-07-09 17:12 ` [PATCH 05/14] " Vinod
2018-07-09 17:10 [04/14] dmaengine: dma-jz4780: Add support for the JZ4770 SoC Vinod Koul
2018-07-09 17:10 ` [PATCH 04/14] " Vinod
2018-07-09 17:03 [02/14] dmaengine: dma-jz4780: Separate chan/ctrl registers Vinod Koul
2018-07-09 17:03 ` [PATCH 02/14] " Vinod
2018-07-07 11:01 [01/14] dmaengine: dma-jz4780: Avoid hardcoding number of channels Paul Cercueil
2018-07-07 11:01 ` [PATCH 01/14] " Paul Cercueil
2018-07-07  7:34 [01/14] " PrasannaKumar Muralidharan
2018-07-07  7:34 ` [PATCH 01/14] " PrasannaKumar Muralidharan
2018-07-07  7:27 [02/14] dmaengine: dma-jz4780: Separate chan/ctrl registers PrasannaKumar Muralidharan
2018-07-07  7:27 ` [PATCH 02/14] " PrasannaKumar Muralidharan
2018-07-05 21:45 [02/14] " Paul Cercueil
2018-07-05 21:45 ` [PATCH 02/14] " Paul Cercueil
2018-07-05 18:26 [01/14] dmaengine: dma-jz4780: Avoid hardcoding number of channels Paul Cercueil
2018-07-05 18:26 ` [PATCH 01/14] " Paul Cercueil
2018-07-05 18:23 [02/14] dmaengine: dma-jz4780: Separate chan/ctrl registers Paul Cercueil
2018-07-05 18:23 ` [PATCH 02/14] " Paul Cercueil
2018-07-04 17:00 [07/14] dmaengine: dma-jz4780: Enable Fast DMA to the AIC PrasannaKumar Muralidharan
2018-07-04 17:00 ` [PATCH 07/14] " PrasannaKumar Muralidharan
2018-07-04 16:55 [06/14] dmaengine: dma-jz4780: Add support for the JZ4725B SoC PrasannaKumar Muralidharan
2018-07-04 16:55 ` [PATCH 06/14] " PrasannaKumar Muralidharan
2018-07-04 16:52 [05/14] dmaengine: dma-jz4780: Add support for the JZ4740 SoC PrasannaKumar Muralidharan
2018-07-04 16:52 ` [PATCH 05/14] " PrasannaKumar Muralidharan
2018-07-04 16:40 [03/14] dmaengine: dma-jz4780: Use 4-word descriptors PrasannaKumar Muralidharan
2018-07-04 16:40 ` [PATCH 03/14] " PrasannaKumar Muralidharan
2018-07-04 16:35 [02/14] dmaengine: dma-jz4780: Separate chan/ctrl registers PrasannaKumar Muralidharan
2018-07-04 16:35 ` [PATCH 02/14] " PrasannaKumar Muralidharan
2018-07-04 16:28 [01/14] dmaengine: dma-jz4780: Avoid hardcoding number of channels PrasannaKumar Muralidharan
2018-07-04 16:28 ` [PATCH 01/14] " PrasannaKumar Muralidharan
2018-07-03 16:53 [02/14] dmaengine: dma-jz4780: Separate chan/ctrl registers Paul Burton
2018-07-03 16:53 ` [PATCH 02/14] " Paul Burton
2018-07-03 12:32 [14/14] MIPS: JZ4770: DTS: Add DMA nodes Paul Cercueil
2018-07-03 12:32 ` [PATCH 14/14] " Paul Cercueil
2018-07-03 12:32 [13/14] MIPS: JZ4780: DTS: Update DMA node to match driver changes Paul Cercueil
2018-07-03 12:32 ` [PATCH 13/14] " Paul Cercueil
2018-07-03 12:32 [12/14] dmaengine: dma-jz4780: Use dma_set_residue() Paul Cercueil
2018-07-03 12:32 ` [PATCH 12/14] " Paul Cercueil
2018-07-03 12:32 [11/14] dmaengine: dma-jz4780: Further residue status fix Paul Cercueil
2018-07-03 12:32 ` [PATCH 11/14] " Paul Cercueil
2018-07-03 12:32 [10/14] dmaengine: dma-jz4780: Set DTCn register explicitly Paul Cercueil
2018-07-03 12:32 ` [PATCH 10/14] " Paul Cercueil
2018-07-03 12:32 [09/14] dmaengine: dma-jz4780: Simplify jz4780_dma_desc_residue() Paul Cercueil
2018-07-03 12:32 ` [PATCH 09/14] " Paul Cercueil
2018-07-03 12:32 [08/14] dmaengine: dma-jz4780: Add missing residue DTC mask Paul Cercueil
2018-07-03 12:32 ` [PATCH 08/14] " Paul Cercueil
2018-07-03 12:32 [07/14] dmaengine: dma-jz4780: Enable Fast DMA to the AIC Paul Cercueil
2018-07-03 12:32 ` [PATCH 07/14] " Paul Cercueil
2018-07-03 12:32 [06/14] dmaengine: dma-jz4780: Add support for the JZ4725B SoC Paul Cercueil
2018-07-03 12:32 ` [PATCH 06/14] " Paul Cercueil
2018-07-03 12:32 [05/14] dmaengine: dma-jz4780: Add support for the JZ4740 SoC Paul Cercueil
2018-07-03 12:32 ` [PATCH 05/14] " Paul Cercueil
2018-07-03 12:32 [04/14] dmaengine: dma-jz4780: Add support for the JZ4770 SoC Paul Cercueil
2018-07-03 12:32 ` [PATCH 04/14] " Paul Cercueil
2018-07-03 12:32 [03/14] dmaengine: dma-jz4780: Use 4-word descriptors Paul Cercueil
2018-07-03 12:32 ` [PATCH 03/14] " Paul Cercueil
2018-07-03 12:32 [02/14] dmaengine: dma-jz4780: Separate chan/ctrl registers Paul Cercueil
2018-07-03 12:32 ` [PATCH 02/14] " Paul Cercueil
2018-07-03 12:32 [PATCH 00/14] dma-jz4780 improvements Paul Cercueil
2018-07-03 12:32 ` [01/14] dmaengine: dma-jz4780: Avoid hardcoding number of channels Paul Cercueil
2018-07-03 12:32   ` [PATCH 01/14] " Paul Cercueil
2018-07-09 16:59   ` [01/14] " Vinod Koul
2018-07-09 16:59     ` [PATCH 01/14] " Vinod
2018-07-10 15:29     ` Paul Cercueil
2018-07-03 19:32 ` [PATCH 00/14] dma-jz4780 improvements Mathieu Malaterre

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=1531237019.17118.1@crapouillou.net \
    --to=paul@crapouillou.net \
    --cc=Zubair.Kakakhel@imgtec.com \
    --cc=dansilsby@gmail.com \
    --cc=devicetree@vger.kernel.org \
    --cc=dmaengine@vger.kernel.org \
    --cc=jhogan@kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-mips@linux-mips.org \
    --cc=malat@debian.org \
    --cc=mark.rutland@arm.com \
    --cc=paul.burton@mips.com \
    --cc=ralf@linux-mips.org \
    --cc=robh+dt@kernel.org \
    --cc=vkoul@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 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.