[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID:
<TYCPR01MB113329C425A1AC666909624D186D3A@TYCPR01MB11332.jpnprd01.prod.outlook.com>
Date: Sun, 23 Nov 2025 15:53:21 +0000
From: Biju Das <biju.das.jz@...renesas.com>
To: Krzysztof Kozlowski <krzk@...nel.org>, biju.das.au
<biju.das.au@...il.com>, Marc Kleine-Budde <mkl@...gutronix.de>, Vincent
Mailhol <mailhol@...nel.org>, Rob Herring <robh@...nel.org>, Krzysztof
Kozlowski <krzk+dt@...nel.org>, Conor Dooley <conor+dt@...nel.org>, Geert
Uytterhoeven <geert+renesas@...der.be>, magnus.damm <magnus.damm@...il.com>
CC: Fabrizio Castro <fabrizio.castro.jz@...esas.com>,
"linux-can@...r.kernel.org" <linux-can@...r.kernel.org>,
"devicetree@...r.kernel.org" <devicetree@...r.kernel.org>,
"linux-renesas-soc@...r.kernel.org" <linux-renesas-soc@...r.kernel.org>,
"linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>, Prabhakar
Mahadev Lad <prabhakar.mahadev-lad.rj@...renesas.com>
Subject: RE: [PATCH v2 1/2] dt-bindings: can: renesas,rcar-canfd: Document
renesas,fd-only property
Hi Krzysztof Kozlowski,
Thanks for the feedback.
> -----Original Message-----
> From: Krzysztof Kozlowski <krzk@...nel.org>
> Sent: 23 November 2025 15:23
> Subject: Re: [PATCH v2 1/2] dt-bindings: can: renesas,rcar-canfd: Document renesas,fd-only property
>
> On 23/11/2025 16:15, Biju Das wrote:
> > Hi Krzysztof Kozlowski,
> >
> >> -----Original Message-----
> >> From: Krzysztof Kozlowski <krzk@...nel.org>
> >> Sent: 23 November 2025 14:22
> >> Subject: Re: [PATCH v2 1/2] dt-bindings: can: renesas,rcar-canfd:
> >> Document renesas,fd-only property
> >>
> >> On 23/11/2025 15:17, Biju Das wrote:
> >>> Hi Krzysztof Kozlowski,
> >>>
> >>>> -----Original Message-----
> >>>> From: Biju Das
> >>>> Sent: 23 November 2025 14:06
> >>>> Subject: RE: [PATCH v2 1/2] dt-bindings: can: renesas,rcar-canfd:
> >>>> Document renesas,fd-only property
> >>>>
> >>>>
> >>>>
> >>>>> -----Original Message-----
> >>>>> From: Krzysztof Kozlowski <krzk@...nel.org>
> >>>>> Sent: 23 November 2025 13:26
> >>>>> Subject: Re: [PATCH v2 1/2] dt-bindings: can: renesas,rcar-canfd:
> >>>>> Document renesas,fd-only property
> >>>>>
> >>>>> On 23/11/2025 12:23, Biju wrote:
> >>>>>> From: Biju Das <biju.das.jz@...renesas.com>
> >>>>>>
> >>>>>> The CANFD on RZ/{G2L,G3E} and R-Car Gen4 support 3 modes FD-Only
> >>>>>> mode, Classical CAN mode and CAN-FD mode. In FD-Only mode,
> >>>>>> communication in Classical CAN frame format is disabled. Document
> >>>>>> renesas,fd-only to handle this mode. As these SoCs support 3
> >>>>>> modes, update the description of renesas,no-can-fd property and disallow it for R-Car Gen3.
> >>>>>>
> >>>>>> Signed-off-by: Biju Das <biju.das.jz@...renesas.com>
> >>>>>> ---
> >>>>>> v1->v2:
> >>>>>> * Added conditional check to disallow fd-only mode for R-Car Gen3.
> >>>>>> ---
> >>>>>> .../bindings/net/can/renesas,rcar-canfd.yaml | 24
> >>>>>> ++++++++++++++++---
> >>>>>> 1 file changed, 21 insertions(+), 3 deletions(-)
> >>>>>>
> >>>>>> diff --git
> >>>>>> a/Documentation/devicetree/bindings/net/can/renesas,rcar-canfd.ya
> >>>>>> ml
> >>>>>> b/Documentation/devicetree/bindings/net/can/renesas,rcar-canfd.ya
> >>>>>> ml index f4ac21c68427..a52244f0b5d1 100644
> >>>>>> ---
> >>>>>> a/Documentation/devicetree/bindings/net/can/renesas,rcar-canfd.ya
> >>>>>> ml
> >>>>>> +++ b/Documentation/devicetree/bindings/net/can/renesas,rcar-canfd.
> >>>>>> +++ y
> >>>>>> +++ am
> >>>>>> +++ l
> >>>>>> @@ -125,9 +125,17 @@ properties:
> >>>>>> renesas,no-can-fd:
> >>>>>> $ref: /schemas/types.yaml#/definitions/flag
> >>>>>> description:
> >>>>>> - The controller can operate in either CAN FD only mode (default) or
> >>>>>> - Classical CAN only mode. The mode is global to all channels.
> >>>>>> - Specify this property to put the controller in Classical CAN only mode.
> >>>>>> + The controller can operate in either CAN-FD mode (default) or FD-Only
> >>>>>> + mode (RZ/{G2L,G3E} and R-Car Gen4) or Classical CAN mode. Specify this
> >>>>>> + property to put the controller in Classical CAN mode.
> >>>>>> +
> >>>>>> + renesas,fd-only:
> >>>>>> + $ref: /schemas/types.yaml#/definitions/flag
> >>>>>> + description:
> >>>>>> + The CANFD on RZ/{G2L,G3E} and R-Car Gen4 SoCs support 3 modes FD-Only
> >>>>>> + mode, Classical CAN mode and CAN-FD mode (default). In FD-Only mode,
> >>>>>> + communication in Classical CAN frame format is disabled. Specify this
> >>>>>> + property to put the controller in FD-Only mode.
> >>>>>>
> >>>>>> assigned-clocks:
> >>>>>> description:
> >>>>>> @@ -267,6 +275,16 @@ allOf:
> >>>>>> patternProperties:
> >>>>>> "^channel[6-7]$": false
> >>>>>>
> >>>>>> + - if:
> >>>>>> + properties:
> >>>>>> + compatible:
> >>>>>> + contains:
> >>>>>> + enum:
> >>>>>> + - renesas,rcar-gen3-canfd
> >>>>>> + then:
> >>>>>> + properties:
> >>>>>> + renesas,fd-only: false
> >>>>>> +
> >>>>>
> >>>>> You did not respond to my first paragraph from previous version.
> >>>>> As I said, you now need oneOf to restrict these, since you are not using simple enum.
> >>>>
> >>>> This is restricting for R-Car Gen3. DT binding check returns error if 'renesas,fd-only"
> >>>> is defined for R-Car Gen3.
> >>>>
> >>>> Am I missing anything here?
> >>
> >> Add on G2L no-can-fd and fd-only. What do you see? What is expected?
> >
> > Can you please point me to an example where two boolean properties
> > handled like this? I did not find one.
> >
> > In my case, oneOf check is not valid under allOf??
> >
> > For eg: RS485, We cannot set both boolean properties active-high and active-low together.
> >
>
>
> I none of them are required then indeed not oneOf, but some if:then:.
>
> https://elixir.bootlin.com/linux/v6.4-
> rc7/source/Documentation/devicetree/bindings/net/qcom,ipa.yaml#L174
>
> And that's why you should have used enum in the first place for the first property.
Thanks for the pointer. Looks the below logic fits under all OFF
+
+ - if:
+ required:
+ - renesas,no-can-fd
+ then:
+ properties:
+ renesas,fd-only: false
+
+ - if:
+ required:
+ - renesas,fd-only
+ then:
+ properties:
+ renesas,no-can-fd: false
Cheers,
Biju
Powered by blists - more mailing lists