The AST2600 contains two dies, each with its own MAC, and these MACs require different delay configurations. Previously, these delay values were configured during the bootloader stage rather than in the driver. This change introduces the use of the standard properties defined in ethernet-controller.yaml to configure the delay values directly in the driver. Add the new property, "aspeed,rgmii-delay-ps", to specify per step of RGMII delay in different MACs. And for Aspeed platform, the total steps of RGMII delay configuraion is 32 steps, so the total delay is "apseed,rgmii-delay-ps' * 32. Default delay values are declared so that tx-internal-delay-ps and rx-internal-delay-ps become optional. If these properties are not present, the driver will use the default values instead. Add conditional schema constraints for Aspeed AST2600 MAC controllers: - For MAC0/1, aspeed,rgmii-delay-ps property is 45 ps - For MAC2/3, aspeed,rgmii-delay-ps property is 250 ps - Both require the "aspeed,scu" and "aspeed,rgmii-delay-ps" properties. Other compatible values remain unrestricted. Signed-off-by: Jacky Chou --- .../devicetree/bindings/net/faraday,ftgmac100.yaml | 35 ++++++++++++++++++++++ 1 file changed, 35 insertions(+) diff --git a/Documentation/devicetree/bindings/net/faraday,ftgmac100.yaml b/Documentation/devicetree/bindings/net/faraday,ftgmac100.yaml index d14410018bcf..66377cff737f 100644 --- a/Documentation/devicetree/bindings/net/faraday,ftgmac100.yaml +++ b/Documentation/devicetree/bindings/net/faraday,ftgmac100.yaml @@ -69,6 +69,36 @@ properties: mdio: $ref: /schemas/net/mdio.yaml# + aspeed,scu: + $ref: /schemas/types.yaml#/definitions/phandle + description: + Phandle to the SCU (System Control Unit) syscon node for Aspeed platform. + This reference is used by the MAC controller to configure the RGMII delays. + + aspeed,rgmii-delay-ps: + description: + Speccify the one step for RGMII delay. In AST2600, MAC0 and MAC1 are 45 ps, + MAC2 and MAC3 are 250 ps. + type: integer + + rx-internal-delay-ps: + description: + RGMII Receive Clock Delay defined in pico seconds. There are 32 + steps of RGMII delay for Aspeed platform. According to the + aspeed,delay-ps to specify the one step delay, the total delay is + calculated by aspeed,delay-ps * 32. A value of 0 ps will disable any + delay. The Default is no delay. + default: 0 + + tx-internal-delay-ps: + description: + RGMII Transmit Clock Delay defined in pico seconds. There are 32 + steps of RGMII delay for Aspeed platform. According to the + aspeed,delay-ps to specify the one step delay, the total delay is + calculated by aspeed,delay-ps * 32. A value of 0 ps will disable any + delay. The Default is no delay. + default: 0 + required: - compatible - reg @@ -85,6 +115,11 @@ allOf: then: properties: resets: true + rx-internal-delay-ps: true + tx-internal-delay-ps: true + required: + - aspeed,rgmii-delay-ps + - aspeed,scu else: properties: resets: false -- 2.34.1