* Re: [PATCH] ata: sata_rcar: add gen[123] fallback compatibility strings
[not found] ` <1457400642-19377-1-git-send-email-horms+renesas-/R6kz+dDXgpPR4JQBCEnsQ@public.gmane.org>
@ 2016-03-08 1:33 ` Simon Horman
2016-03-08 8:37 ` Geert Uytterhoeven
0 siblings, 1 reply; 3+ messages in thread
From: Simon Horman @ 2016-03-08 1:33 UTC (permalink / raw)
To: Tejun Heo
Cc: linux-ide-u79uwXL29TY76Z2rM5mHXA,
linux-renesas-soc-u79uwXL29TY76Z2rM5mHXA, Magnus Damm,
devicetree-u79uwXL29TY76Z2rM5mHXA
[CC devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org]
On Tue, Mar 08, 2016 at 10:30:42AM +0900, Simon Horman wrote:
> Add fallback compatibility string for R-Car Gen 1, 2 and 3.
>
> In the case of Renesas R-Car hardware we know that there are generations of
> SoCs, e.g. Gen 1 and 2. But beyond that its not clear what the relationship
> between IP blocks might be. For example, I believe that r8a7779 is older
> than r8a7778 but that doesn't imply that the latter is a descendant of the
> former or vice versa.
>
> We can, however, by examining the documentation and behaviour of the
> hardware at run-time observe that the current driver implementation appears
> to be compatible with the IP blocks on SoCs within a given generation.
>
> For the above reasons and convenience when enabling new SoCs a
> per-generation fallback compatibility string scheme being adopted for
> drivers for Renesas SoCs.
>
> Signed-off-by: Simon Horman <horms+renesas-/R6kz+dDXgpPR4JQBCEnsQ@public.gmane.org>
> ---
> Based on libata/for-next
> ---
> Documentation/devicetree/bindings/ata/sata_rcar.txt | 15 ++++++++++++---
> drivers/ata/sata_rcar.c | 12 ++++++++++++
> 2 files changed, 24 insertions(+), 3 deletions(-)
>
> diff --git a/Documentation/devicetree/bindings/ata/sata_rcar.txt b/Documentation/devicetree/bindings/ata/sata_rcar.txt
> index 0764f9ab63dc..b44048176938 100644
> --- a/Documentation/devicetree/bindings/ata/sata_rcar.txt
> +++ b/Documentation/devicetree/bindings/ata/sata_rcar.txt
> @@ -1,14 +1,23 @@
> * Renesas R-Car SATA
>
> Required properties:
> -- compatible : should contain one of the following:
> +- compatible : should contain one or more of the following:
> - "renesas,sata-r8a7779" for R-Car H1
> - ("renesas,rcar-sata" is deprecated)
> - "renesas,sata-r8a7790-es1" for R-Car H2 ES1
> - "renesas,sata-r8a7790" for R-Car H2 other than ES1
> - "renesas,sata-r8a7791" for R-Car M2-W
> - "renesas,sata-r8a7793" for R-Car M2-N
> - "renesas,sata-r8a7795" for R-Car H3
> + - "renesas,rcar-gen1-sata" for a generic R-Car Gen1 compatible device
> + - "renesas,rcar-gen2-sata" for a generic R-Car Gen2 compatible device
> + - "renesas,rcar-gen3-sata" for a generic R-Car Gen3 compatible device
> + - "renesas,rcar-sata" is deprecated
> +
> + When compatible with the generic version, nodes
> + must list the SoC-specific version corresponding
> + to the platform first followed by the generic
> + version.
> +
> - reg : address and length of the SATA registers;
> - interrupts : must consist of one interrupt specifier.
> - clocks : must contain a reference to the functional clock.
> @@ -16,7 +25,7 @@ Required properties:
> Example:
>
> sata0: sata@ee300000 {
> - compatible = "renesas,sata-r8a7791";
> + compatible = "renesas,sata-r8a7791", "renesas,rcar-gen2-sata";
> reg = <0 0xee300000 0 0x2000>;
> interrupt-parent = <&gic>;
> interrupts = <0 105 IRQ_TYPE_LEVEL_HIGH>;
> diff --git a/drivers/ata/sata_rcar.c b/drivers/ata/sata_rcar.c
> index f72d601e300a..09d4ba3f0bc4 100644
> --- a/drivers/ata/sata_rcar.c
> +++ b/drivers/ata/sata_rcar.c
> @@ -858,6 +858,18 @@ static struct of_device_id sata_rcar_match[] = {
> .compatible = "renesas,sata-r8a7795",
> .data = (void *)RCAR_GEN2_SATA
> },
> + {
> + .compatible = "renesas,rcar-gen1-sata",
> + .data = (void *)RCAR_GEN1_SATA
> + },
> + {
> + .compatible = "renesas,rcar-gen2-sata",
> + .data = (void *)RCAR_GEN2_SATA
> + },
> + {
> + .compatible = "renesas,rcar-gen3-sata",
> + .data = (void *)RCAR_GEN2_SATA
> + },
> { },
> };
> MODULE_DEVICE_TABLE(of, sata_rcar_match);
> --
> 2.1.4
>
--
To unsubscribe from this list: send the line "unsubscribe devicetree" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH] ata: sata_rcar: add gen[123] fallback compatibility strings
2016-03-08 1:33 ` [PATCH] ata: sata_rcar: add gen[123] fallback compatibility strings Simon Horman
@ 2016-03-08 8:37 ` Geert Uytterhoeven
2016-03-09 2:24 ` Simon Horman
0 siblings, 1 reply; 3+ messages in thread
From: Geert Uytterhoeven @ 2016-03-08 8:37 UTC (permalink / raw)
To: Simon Horman
Cc: Tejun Heo, linux-ide@vger.kernel.org, linux-renesas-soc,
Magnus Damm, devicetree@vger.kernel.org
Hi Simon,
On Tue, Mar 8, 2016 at 2:33 AM, Simon Horman <horms@verge.net.au> wrote:
> On Tue, Mar 08, 2016 at 10:30:42AM +0900, Simon Horman wrote:
>> Add fallback compatibility string for R-Car Gen 1, 2 and 3.
>>
>> In the case of Renesas R-Car hardware we know that there are generations of
>> SoCs, e.g. Gen 1 and 2. But beyond that its not clear what the relationship
>> between IP blocks might be. For example, I believe that r8a7779 is older
>> than r8a7778 but that doesn't imply that the latter is a descendant of the
>> former or vice versa.
>>
>> We can, however, by examining the documentation and behaviour of the
>> hardware at run-time observe that the current driver implementation appears
>> to be compatible with the IP blocks on SoCs within a given generation.
>>
>> For the above reasons and convenience when enabling new SoCs a
>> per-generation fallback compatibility string scheme being adopted for
>> drivers for Renesas SoCs.
>>
>> Signed-off-by: Simon Horman <horms+renesas@verge.net.au>
>> ---
>> Based on libata/for-next
>> ---
>> Documentation/devicetree/bindings/ata/sata_rcar.txt | 15 ++++++++++++---
>> drivers/ata/sata_rcar.c | 12 ++++++++++++
>> 2 files changed, 24 insertions(+), 3 deletions(-)
>>
>> diff --git a/Documentation/devicetree/bindings/ata/sata_rcar.txt b/Documentation/devicetree/bindings/ata/sata_rcar.txt
>> index 0764f9ab63dc..b44048176938 100644
>> --- a/Documentation/devicetree/bindings/ata/sata_rcar.txt
>> +++ b/Documentation/devicetree/bindings/ata/sata_rcar.txt
>> @@ -1,14 +1,23 @@
>> * Renesas R-Car SATA
>>
>> Required properties:
>> -- compatible : should contain one of the following:
>> +- compatible : should contain one or more of the following:
>> - "renesas,sata-r8a7779" for R-Car H1
>> - ("renesas,rcar-sata" is deprecated)
>> - "renesas,sata-r8a7790-es1" for R-Car H2 ES1
>> - "renesas,sata-r8a7790" for R-Car H2 other than ES1
>> - "renesas,sata-r8a7791" for R-Car M2-W
>> - "renesas,sata-r8a7793" for R-Car M2-N
>> - "renesas,sata-r8a7795" for R-Car H3
>> + - "renesas,rcar-gen1-sata" for a generic R-Car Gen1 compatible device
Given R-Car H1 is the only member of the R-Car Gen1 family that has SATA
(both M1A and E1 don't seem to have it), do we want to support
"renesas,rcar-gen1-sata" in the bindings...
>> + - "renesas,rcar-gen2-sata" for a generic R-Car Gen2 compatible device
>> + - "renesas,rcar-gen3-sata" for a generic R-Car Gen3 compatible device
>> + - "renesas,rcar-sata" is deprecated
>> --- a/drivers/ata/sata_rcar.c
>> +++ b/drivers/ata/sata_rcar.c
>> @@ -858,6 +858,18 @@ static struct of_device_id sata_rcar_match[] = {
>> .compatible = "renesas,sata-r8a7795",
>> .data = (void *)RCAR_GEN2_SATA
>> },
>> + {
>> + .compatible = "renesas,rcar-gen1-sata",
>> + .data = (void *)RCAR_GEN1_SATA
>> + },
... and in the driver?
It already matches on (deprecated) "renesas,rcar-sata" and
"renesas,sata-r8a7779"?
>> + {
>> + .compatible = "renesas,rcar-gen2-sata",
>> + .data = (void *)RCAR_GEN2_SATA
>> + },
>> + {
>> + .compatible = "renesas,rcar-gen3-sata",
>> + .data = (void *)RCAR_GEN2_SATA
>> + },
>> { },
Gr{oetje,eeting}s,
Geert
--
Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert@linux-m68k.org
In personal conversations with technical people, I call myself a hacker. But
when I'm talking to journalists I just say "programmer" or something like that.
-- Linus Torvalds
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH] ata: sata_rcar: add gen[123] fallback compatibility strings
2016-03-08 8:37 ` Geert Uytterhoeven
@ 2016-03-09 2:24 ` Simon Horman
0 siblings, 0 replies; 3+ messages in thread
From: Simon Horman @ 2016-03-09 2:24 UTC (permalink / raw)
To: Geert Uytterhoeven
Cc: Tejun Heo, linux-ide@vger.kernel.org, linux-renesas-soc,
Magnus Damm, devicetree@vger.kernel.org
On Tue, Mar 08, 2016 at 09:37:24AM +0100, Geert Uytterhoeven wrote:
> Hi Simon,
>
> On Tue, Mar 8, 2016 at 2:33 AM, Simon Horman <horms@verge.net.au> wrote:
> > On Tue, Mar 08, 2016 at 10:30:42AM +0900, Simon Horman wrote:
> >> Add fallback compatibility string for R-Car Gen 1, 2 and 3.
> >>
> >> In the case of Renesas R-Car hardware we know that there are generations of
> >> SoCs, e.g. Gen 1 and 2. But beyond that its not clear what the relationship
> >> between IP blocks might be. For example, I believe that r8a7779 is older
> >> than r8a7778 but that doesn't imply that the latter is a descendant of the
> >> former or vice versa.
> >>
> >> We can, however, by examining the documentation and behaviour of the
> >> hardware at run-time observe that the current driver implementation appears
> >> to be compatible with the IP blocks on SoCs within a given generation.
> >>
> >> For the above reasons and convenience when enabling new SoCs a
> >> per-generation fallback compatibility string scheme being adopted for
> >> drivers for Renesas SoCs.
> >>
> >> Signed-off-by: Simon Horman <horms+renesas@verge.net.au>
> >> ---
> >> Based on libata/for-next
> >> ---
> >> Documentation/devicetree/bindings/ata/sata_rcar.txt | 15 ++++++++++++---
> >> drivers/ata/sata_rcar.c | 12 ++++++++++++
> >> 2 files changed, 24 insertions(+), 3 deletions(-)
> >>
> >> diff --git a/Documentation/devicetree/bindings/ata/sata_rcar.txt b/Documentation/devicetree/bindings/ata/sata_rcar.txt
> >> index 0764f9ab63dc..b44048176938 100644
> >> --- a/Documentation/devicetree/bindings/ata/sata_rcar.txt
> >> +++ b/Documentation/devicetree/bindings/ata/sata_rcar.txt
> >> @@ -1,14 +1,23 @@
> >> * Renesas R-Car SATA
> >>
> >> Required properties:
> >> -- compatible : should contain one of the following:
> >> +- compatible : should contain one or more of the following:
> >> - "renesas,sata-r8a7779" for R-Car H1
> >> - ("renesas,rcar-sata" is deprecated)
> >> - "renesas,sata-r8a7790-es1" for R-Car H2 ES1
> >> - "renesas,sata-r8a7790" for R-Car H2 other than ES1
> >> - "renesas,sata-r8a7791" for R-Car M2-W
> >> - "renesas,sata-r8a7793" for R-Car M2-N
> >> - "renesas,sata-r8a7795" for R-Car H3
> >> + - "renesas,rcar-gen1-sata" for a generic R-Car Gen1 compatible device
>
> Given R-Car H1 is the only member of the R-Car Gen1 family that has SATA
> (both M1A and E1 don't seem to have it), do we want to support
> "renesas,rcar-gen1-sata" in the bindings...
I added it mainly for consistency. I'm happy to drop it if you like.
> >> + - "renesas,rcar-gen2-sata" for a generic R-Car Gen2 compatible device
> >> + - "renesas,rcar-gen3-sata" for a generic R-Car Gen3 compatible device
> >> + - "renesas,rcar-sata" is deprecated
>
> >> --- a/drivers/ata/sata_rcar.c
> >> +++ b/drivers/ata/sata_rcar.c
> >> @@ -858,6 +858,18 @@ static struct of_device_id sata_rcar_match[] = {
> >> .compatible = "renesas,sata-r8a7795",
> >> .data = (void *)RCAR_GEN2_SATA
> >> },
> >> + {
> >> + .compatible = "renesas,rcar-gen1-sata",
> >> + .data = (void *)RCAR_GEN1_SATA
> >> + },
>
> ... and in the driver?
> It already matches on (deprecated) "renesas,rcar-sata" and
> "renesas,sata-r8a7779"?
>
> >> + {
> >> + .compatible = "renesas,rcar-gen2-sata",
> >> + .data = (void *)RCAR_GEN2_SATA
> >> + },
> >> + {
> >> + .compatible = "renesas,rcar-gen3-sata",
> >> + .data = (void *)RCAR_GEN2_SATA
> >> + },
> >> { },
>
> Gr{oetje,eeting}s,
>
> Geert
>
> --
> Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert@linux-m68k.org
>
> In personal conversations with technical people, I call myself a hacker. But
> when I'm talking to journalists I just say "programmer" or something like that.
> -- Linus Torvalds
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2016-03-09 2:24 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <1457400642-19377-1-git-send-email-horms+renesas@verge.net.au>
[not found] ` <1457400642-19377-1-git-send-email-horms+renesas-/R6kz+dDXgpPR4JQBCEnsQ@public.gmane.org>
2016-03-08 1:33 ` [PATCH] ata: sata_rcar: add gen[123] fallback compatibility strings Simon Horman
2016-03-08 8:37 ` Geert Uytterhoeven
2016-03-09 2:24 ` Simon Horman
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).