lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Date:   Tue, 14 Jan 2020 11:09:36 +0000
From:   Christophe ROULLIER <christophe.roullier@...com>
To:     Rob Herring <robh@...nel.org>
CC:     "davem@...emloft.net" <davem@...emloft.net>,
        "mark.rutland@....com" <mark.rutland@....com>,
        "mripard@...nel.org" <mripard@...nel.org>,
        "martin.blumenstingl@...glemail.com" 
        <martin.blumenstingl@...glemail.com>,
        "alexandru.ardelean@...log.com" <alexandru.ardelean@...log.com>,
        "narmstrong@...libre.com" <narmstrong@...libre.com>,
        "mcoquelin.stm32@...il.com" <mcoquelin.stm32@...il.com>,
        Alexandre TORGUE <alexandre.torgue@...com>,
        "devicetree@...r.kernel.org" <devicetree@...r.kernel.org>,
        "netdev@...r.kernel.org" <netdev@...r.kernel.org>,
        "linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>,
        "linux-stm32@...md-mailman.stormreply.com" 
        <linux-stm32@...md-mailman.stormreply.com>,
        "linux-arm-kernel@...ts.infradead.org" 
        <linux-arm-kernel@...ts.infradead.org>
Subject: Re: [PATCH 2/2] dt-bindings: net: dwmac: Convert stm32 dwmac to DT
 schema

Hi Rob, all,

On 11/14/19 7:22 PM, Rob Herring wrote:
> On Fri, Nov 08, 2019 at 11:35:26AM +0100, Christophe Roullier wrote:
>> Convert stm32 dwmac to DT schema.
> Lots of checkpatch errors with trailing WS.
ok, sorry I forgot to execute checkpatch before upstream.
>> Signed-off-by: Christophe Roullier <christophe.roullier@...com>
>> ---
>>   .../devicetree/bindings/net/stm32-dwmac.txt   |  44 -----
>>   .../devicetree/bindings/net/stm32-dwmac.yaml  | 161 ++++++++++++++++++
>>   2 files changed, 161 insertions(+), 44 deletions(-)
>>   delete mode 100644 Documentation/devicetree/bindings/net/stm32-dwmac.txt
>>   create mode 100644 Documentation/devicetree/bindings/net/stm32-dwmac.yaml
>>
>> diff --git a/Documentation/devicetree/bindings/net/stm32-dwmac.txt b/Documentation/devicetree/bindings/net/stm32-dwmac.txt
>> deleted file mode 100644
>> index a90eef11dc46..000000000000
>> --- a/Documentation/devicetree/bindings/net/stm32-dwmac.txt
>> +++ /dev/null
>> @@ -1,44 +0,0 @@
>> -STMicroelectronics STM32 / MCU DWMAC glue layer controller
>> -
>> -This file documents platform glue layer for stmmac.
>> -Please see stmmac.txt for the other unchanged properties.
>> -
>> -The device node has following properties.
>> -
>> -Required properties:
>> -- compatible:  For MCU family should be "st,stm32-dwmac" to select glue, and
>> -	       "snps,dwmac-3.50a" to select IP version.
>> -	       For MPU family should be "st,stm32mp1-dwmac" to select
>> -	       glue, and "snps,dwmac-4.20a" to select IP version.
>> -- clocks: Must contain a phandle for each entry in clock-names.
>> -- clock-names: Should be "stmmaceth" for the host clock.
>> -	       Should be "mac-clk-tx" for the MAC TX clock.
>> -	       Should be "mac-clk-rx" for the MAC RX clock.
>> -	       For MPU family need to add also "ethstp" for power mode clock
>> -- interrupt-names: Should contain a list of interrupt names corresponding to
>> -           the interrupts in the interrupts property, if available.
>> -		   Should be "macirq" for the main MAC IRQ
>> -		   Should be "eth_wake_irq" for the IT which wake up system
>> -- st,syscon : Should be phandle/offset pair. The phandle to the syscon node which
>> -	       encompases the glue register, and the offset of the control register.
>> -
>> -Optional properties:
>> -- clock-names:     For MPU family "eth-ck" for PHY without quartz
>> -- st,eth-clk-sel (boolean) : set this property in RGMII PHY when you want to select RCC clock instead of ETH_CLK125.
>> -- st,eth-ref-clk-sel (boolean) :  set this property in RMII mode when you have PHY without crystal 50MHz and want to select RCC clock instead of ETH_REF_CLK.
>> -
>> -Example:
>> -
>> -	ethernet@...28000 {
>> -		compatible = "st,stm32-dwmac", "snps,dwmac-3.50a";
>> -		reg = <0x40028000 0x8000>;
>> -		reg-names = "stmmaceth";
>> -		interrupts = <0 61 0>, <0 62 0>;
>> -		interrupt-names = "macirq", "eth_wake_irq";
>> -		clock-names = "stmmaceth", "mac-clk-tx", "mac-clk-rx";
>> -		clocks = <&rcc 0 25>, <&rcc 0 26>, <&rcc 0 27>;
>> -		st,syscon = <&syscfg 0x4>;
>> -		snps,pbl = <8>;
>> -		snps,mixed-burst;
>> -		dma-ranges;
>> -	};
>> diff --git a/Documentation/devicetree/bindings/net/stm32-dwmac.yaml b/Documentation/devicetree/bindings/net/stm32-dwmac.yaml
>> new file mode 100644
>> index 000000000000..eb0fd831f59d
>> --- /dev/null
>> +++ b/Documentation/devicetree/bindings/net/stm32-dwmac.yaml
>> @@ -0,0 +1,161 @@
>> +# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause)
>> +# Copyright 2019 BayLibre, SAS
>> +%YAML 1.2
>> +---
>> +$id: "http://devicetree.org/schemas/net/stm32-dwmac.yaml#"
>> +$schema: "http://devicetree.org/meta-schemas/core.yaml#"
>> +
>> +title: STMicroelectronics STM32 / MCU DWMAC glue layer controller
>> +
>> +maintainers:
>> +  - Alexandre Torgue <alexandre.torgue@...com>
>> +  - Christophe Roullier <christophe.roullier@...com>
>> +
>> +description:
>> +  This file documents platform glue layer for stmmac.
>> +
>> +# We need a select here so we don't match all nodes with 'snps,dwmac'
>> +select:
>> +  properties:
>> +    compatible:
>> +      contains:
>> +        enum:
>> +          - st,stm32-dwmac
>> +          - st,stm32mp1-dwmac
>> +  required:
>> +    - compatible
>> +
>> +allOf:
>> +  - $ref: "snps,dwmac.yaml#"
>> +  - if:
>> +      properties:
>> +        compatible:
>> +          contains:
>> +            enum:
>> +              - st,stm32-dwmac
>> +              - st,stm32mp1-dwmac
>> +    then:
>> +      properties:
>> +       clocks:
>> +         minItems: 3
>> +         maxItems: 5
>> +         items:
>> +          - description: GMAC main clock
>> +          - description: MAC TX clock
>> +          - description: MAC RX clock
>> +          - description: For MPU family, used for power mode
> What does 'power mode' mean? IIRC, some DW MACs have a clock for WoL
> called LPI or something. Are you sure this is ST specific and not DW
> config or version specific?

Yes that right, it is clock used to manage WoL during suspend.

My problem it is may be to manage MCU and MPU family in same yaml file

Because in MCU family only 3 clocks used (GMAC main clock, MAC TX clock 
and MAC RX clock)

In MPU family it is same clocks + clock to manage WoL and clock to 
manage PHY without Cristal

>> +          - description: For MPU family, used for PHY without quartz
> It would be cleaner to define the clock always present and use a
> fixed-clock when you have an external quartz.

You are right, I will define clocks always present and manage them in my 
driver (enable or disable it in function of phy mode, if with or without 
quartz in PHY etc..)

So for MCU (st,stm32-dwmac) I need 3 clocks and for MPU 
(st,stm32mp1-dwmac) 5 clocks

How to manage this in yaml ? 2 differents files ?

>> +
>> +       clock-names:
>> +         minItems: 3
>> +         maxItems: 5
>> +         contains:
>> +          enum:
>> +            - stmmaceth
>> +            - mac-clk-tx
>> +            - mac-clk-rx
>> +            - ethstp
>> +            - eth-ck
>> +
>> +properties:
>> +  compatible:
>> +    oneOf:
>> +      - items:
>> +          - enum:
>> +              - st,stm32mp1-dwmac
>> +          - const: snps,dwmac-4.20a
>> +      - items:
>> +          - enum:
>> +              - st,stm32-dwmac
>> +          - const: snps,dwmac-4.10a
>> +      - items:
>> +          - enum:
>> +              - st,stm32-dwmac
>> +          - const: snps,dwmac-3.50a
>> +
>> +  st,syscon:
>> +    allOf:
>> +      - $ref: "/schemas/types.yaml#/definitions/phandle-array"
>> +    description:
>> +      Should be phandle/offset pair. The phandle to the syscon node which
>> +      encompases the glue register, and the offset of the control register
>> +
>> +  st,eth-clk-sel:
>> +    description:
>> +      set this property in RGMII PHY when you want to select RCC clock instead of ETH_CLK125.
>> +    type: boolean
>> +
>> +  st,eth-ref-clk-sel:
>> +    description:
>> +      set this property in RMII mode when you have PHY without crystal 50MHz and want to select RCC clock instead of ETH_REF_CLK.
> Wrap lines.
ok
>> +    type: boolean
>> +
>> +required:
>> +  - compatible
>> +  - clocks
>> +  - clock-names
>> +  - st,syscon
>> +
>> +examples:
>> + - |
>> +    #include <dt-bindings/interrupt-controller/arm-gic.h>
>> +    #include <dt-bindings/clock/stm32mp1-clks.h>
>> +    #include <dt-bindings/reset/stm32mp1-resets.h>
>> +    #include <dt-bindings/mfd/stm32h7-rcc.h>
>> +    //Example 1
>> +     ethernet0: ethernet@...0a000 {
>> +       compatible = "st,stm32mp1-dwmac", "snps,dwmac-4.20a";
>> +       reg = <0x5800a000 0x2000>;
>> +       reg-names = "stmmaceth";
>> +       interrupts = <&intc GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>;
>> +       interrupt-names = "macirq";
>> +       clock-names = "stmmaceth",
>> +                     "mac-clk-tx",
>> +                     "mac-clk-rx",
>> +                     "ethstp",
>> +                     "eth-ck";				
>> +       clocks = <&rcc ETHMAC>,
>> +                <&rcc ETHTX>,
>> +                <&rcc ETHRX>,
>> +                <&rcc ETHSTP>,
>> +                <&rcc ETHCK_K>;	
>> +       st,syscon = <&syscfg 0x4>;
>> +       snps,pbl = <2>;
>> +       snps,axi-config = <&stmmac_axi_config_0>;
>> +       snps,tso;
>> +       status = "disabled";
>> +       phy-mode = "rgmii";
>> +       };
>> +
>> +    //Example 1 (MCU example)
> 2 Example 1's?
>
exact, I will rename it

Thanks Rob

>> +     ethernet1: ethernet@...28000 {
>> +       compatible = "st,stm32-dwmac", "snps,dwmac-3.50a";
>> +       reg = <0x40028000 0x8000>;
>> +       reg-names = "stmmaceth";
>> +       interrupts = <0 61 0>, <0 62 0>;
>> +       interrupt-names = "macirq", "eth_wake_irq";
>> +       clock-names = "stmmaceth", "mac-clk-tx", "mac-clk-rx";
>> +       clocks = <&rcc 0 25>, <&rcc 0 26>, <&rcc 0 27>;
>> +       st,syscon = <&syscfg 0x4>;
>> +       snps,pbl = <8>;
>> +       snps,mixed-burst;
>> +       dma-ranges;
>> +       phy-mode = "mii";
>> +       };
>> +
>> +    //Example 2
>> +     ethernet2: ethernet@...27000 {
>> +       compatible = "st,stm32-dwmac", "snps,dwmac-4.10a";
>> +       reg = <0x40028000 0x8000>;
>> +       reg-names = "stmmaceth";
>> +       interrupts = <61>;
>> +       interrupt-names = "macirq";
>> +       clock-names = "stmmaceth", "mac-clk-tx", "mac-clk-rx";
>> +       clocks = <&rcc 62>, <&rcc 61>, <&rcc 60>;
>> +       st,syscon = <&syscfg 0x4>;
>> +       snps,pbl = <8>;
>> +       status = "disabled";
>> +       phy-mode = "mii";
>> +       };
>> +
>> +
>> -- 
>> 2.17.1
>>

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ