# Rockchip Developer Guide Linux GMAC Mode Configuration

文件标识: RK-KF-YF-144

发布版本: V1.2.0

日期: 2022-11-29

文件密级: □绝密 □秘密 □内部资料 ■公开

#### 免责声明

本文档按"现状"提供,瑞芯微电子股份有限公司("本公司",下同)不对本文档的任何陈述、信息和内容的准确性、可靠性、完整性、适销性、特定目的性和非侵权性提供任何明示或暗示的声明或保证。本文档仅作为使用指导的参考。

由于产品版本升级或其他原因,本文档将可能在未经任何通知的情况下,不定期进行更新或修改。

#### 商标声明

"Rockchip"、"瑞芯微"、"瑞芯"均为本公司的注册商标,归本公司所有。

本文档可能提及的其他所有注册商标或商标,由其各自拥有者所有。

#### 版权所有 © 2021 瑞芯微电子股份有限公司

超越合理使用范畴,非经本公司书面许可,任何单位和个人不得擅自摘抄、复制本文档内容的部分或全部,并不得以任何形式传播。

瑞芯微电子股份有限公司

Rockchip Electronics Co., Ltd.

地址: 福建省福州市铜盘路软件园A区18号

网址: <u>www.rock-chips.com</u>

客户服务电话: +86-4007-700-590

客户服务传真: +86-591-83951833

客户服务邮箱: fae@rock-chips.com

#### 前言

#### 概述

本文提供 Rockchip 平台以太网 GMAC 接口不同模式下的配置用例,用于解决以太网配置问题。

#### 产品版本

| 芯片名称        | 内核版本 |
|-------------|------|
| ROCKCHIP 芯片 | 所有版本 |

#### 读者对象

#### 本文档(本指南)主要适用于以下工程师:

技术支持工程师

软件开发工程师

#### 修订记录

| 版本号    | 作者  | 修改日期       | 修改说明   |
|--------|-----|------------|--------|
| V1.0.0 | 吴达超 | 2021-01-26 | 初始版本   |
| V1.1.0 | 吴达超 | 2021-12-28 | 支持3588 |
| V1.1.1 | 吴达超 | 2022-11-28 | 修正错误   |
| V1.2.0 | 吴达超 | 2022-11-29 | 支持3528 |

#### 目录

#### **Rockchip Developer Guide Linux GMAC Mode Configuration**

```
RGMII 模式
    PLL output 125M for TX_CLK, Crystal 25M for PHY
    PLL output 125M for TX_CLK, PLL 25M for PHY
    125M TX_CLK input from PHY, PLL 25M for PHY
    125M TX_CLK input from PHY, Crystal 25M for PHY
RMII 模式
    RMII Clock Output
    RMII Clock Input
模式配置
    PX30
        RMII Clock Output
        RMII Clock Input
    RK1808
        RMII Clock Output:
        RMII Clock Input
        RGMII Clock Output
        RGMII Clock Input
    RK3128
        RMII Clock Output
        RMII Clock Input
        RGMII Clock Input
    RK3228
        RMII Clock Output
        RMII Clock Input
        RGMII Clock Output
        RGMII Clock Input
        Internal EPHY
    RK3288
        RMII Clock Output
        RMII Clock Input
        RGMII Clock Input
    RK3328
        RMII Clock Output
        RMII Clock Input
```

**RGMII Clock Input** Internal EPHY

```
RK3368
    RMII Clock Output
   RMII Clock Input
   RGMII Clock Input
RK3399
    RMII Clock Output
    RMII Clock Input
    RGMII Clock Input
RK3528
    GMAC1 RMII Clock 50M Output, PLL 25M Output
    GMAC1 RMII Clock 50M Input, PLL 25M Output
    GMAC1 RGMII PLL output 25M for PHY, PLL output 125M for TX CLK
    GMAC1 RGMII Crystal 25M for PHY, PLL output 125M for TX_CLK
    GMAC1 RGMII PLL output 25M for PHY, RGMII_CLK input 125M for TX_CLK
    GMAC1 RGMII Crystal 25M for PHY, RGMII CLK input 125M for TX CLK
    GMACO & FEPHY
RK3568
    RMII Clock Output
    RMII Clock Input
    RGMII PLL output 25M for PHY, PLL output 125M for TX CLK
    RGMII PLL output 25M for PHY, RGMII CLK input 125M for TX CLK
    RGMII Crystal 25M for PHY, PLL output 125M for TX CLK
    RGMII Crystal 25M for PHY, RGMII_CLK input 125M for TX_CLK
    SGMII
    QSGMII
RK3588
    RMII Clock Output
    RMII Clock Input
    RGMII PLL output 25M for PHY, PLL output 125M for TX CLK
    RGMII PLL output 25M for PHY, RGMII_CLK input 125M for TX_CLK
    RGMII Crystal 25M for PHY, PLL output 125M for TX_CLK
    RGMII Crystal 25M for PHY, RGMII CLK input 125M for TX CLK
RV1108
    RMII Clock Input
    RMII Clock Output
RV1126
    RGMII PLL output 25M for PHY, PLL output 125M for TX CLK
    RGMII PLL output 25M for PHY, RGMII Clock input 125M for TX CLK
    RGMII Crytal 25M for PHY, PLL output 125M for TX_CLK
    RGMII Crytal 25M for PHY, RGMII_CLK input 125M for TX_CLK
    RMII Clock Output
    RMII Clock Input
```

RGMII/RMII 主要模式连接图罗列如下:

# RGMII 模式

一般使用主控 PLL 输出 时钟 output 方式,PHY 提供的 125M 时钟作为 input 方式为备选方案。

# PLL output 125M for TX\_CLK, Crystal 25M for PHY

主控 PLL 提供 TXCLK 所需时钟, PHY 25M 时钟由晶振提供。



PLL output 125M for TX\_CLK, PLL 25M for PHY

主控 PLL 提供 TXCLK 所需时钟, PHY 25M 时钟由主控提供。



125M TX\_CLK input from PHY, PLL 25M for PHY

TXCLK 所需时钟由 PHY 提供,PHY 25M 时钟由主控提供。



125M TX\_CLK input from PHY, Crystal 25M for PHY

TXCLK 所需时钟由 PHY 提供, PHY 25M 时钟由晶振提供。



# RMII 模式

# **RMII Clock Output**

主控提供 RMII 所需时钟



# **RMII Clock Input**

PHY 提供 RMII 所需时钟



同样, RMII 模式下, 晶振也可以由主控输出 25M 替代。

# 模式配置

不同模式下的配置主要包含了 phy mode, clock 和 pinctrl 的配置,这些配置都是关联的,需要同时配置,否则无法工作。

以下是各芯片不同模式下,以 SDK 板级 DTS 为例的不同配置方式的参考,关注 dts 中 gmac 节点里 '+' 部分的修改。

#### **PX30**

# **RMII Clock Output**

## **RMII Clock Input**

#### **RK1808**

# **RMII Clock Output:**

```
&gmac {
        phy-supply = <&vcc_phy>;
         phy-mode = "rmii";
         clocks = <&cru SCLK_GMAC>, <&cru SCLK_GMAC_RX_TX>,
                  <&cru SCLK_GMAC_RX_TX>, <&cru SCLK_GMAC_REF>,
                  <&cru SCLK_GMAC_REFOUT>, <&cru ACLK_GMAC>,
                  <&cru PCLK_GMAC>, <&cru SCLK_GMAC_RMII_SPEED>;
         clock-names = "stmmaceth", "mac_clk_rx",
                       "mac_clk_tx", "clk_mac_ref"
                       "clk_mac_refout", "aclk_mac",
                       "pclk_mac", "clk_mac_speed";
         assigned-clocks = <&cru SCLK_GMAC_RX_TX>;
         assigned-clock-parents = <&cru SCLK_GMAC_RMII_SPEED>;
        snps,reset-gpio = <&gpio0 10 GPIO_ACTIVE_LOW>;
        snps, reset-active-low;
        snps, reset-delays-us = <0 50000 50000>;
         pinctrl-names = "default";
         pinctrl-0 = <&rmii_pins>;
        status = "okay";
};
```

```
+&gmac_clkin {
         clock-frequency = <50000000>;
+};
&gmac {
        phy-supply = <&vcc_phy>;
        phy-mode = "rmii";
         clock_in_out = "input";
         clocks = <&cru SCLK_GMAC>, <&cru SCLK_GMAC_RX_TX>,
                  <&cru SCLK_GMAC_RX_TX>, <&cru SCLK_GMAC_REF>,
                  <&cru SCLK_GMAC_REFOUT>, <&cru ACLK_GMAC>,
                  <&cru PCLK_GMAC>, <&cru SCLK_GMAC_RMII_SPEED>;
         clock-names = "stmmaceth", "mac_clk_rx",
                       "mac_clk_tx", "clk_mac_ref",
                       "clk_mac_refout", "aclk_mac",
                       "pclk_mac", "clk_mac_speed";
         assigned-clocks = <&cru SCLK_GMAC_RX_TX>, <&cru SCLK_GMAC>;
         assigned-clock-parents = <&cru SCLK_GMAC_RMII_SPEED>, <&gmac_clkin>;
        snps,reset-gpio = <&gpio0 10 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        snps, reset-delays-us = <0 50000 50000>;
         pinctrl-names = "default";
         pinctrl-0 = <&rmii_pins>;
        status = "okay";
};
```

#### **RGMII Clock Output**

```
rx_delay = <0x3a>;
status = "okay";
};
```

## **RMII Clock Output**

## **RMII Clock Input**

```
+&clkin_gmac {
         clock-frequency = <50000000>;
+};
&gmac {
        assigned-clocks = <&cru SCLK_MAC>;
        assigned-clock-parents = <&clkin_gmac>;
        clock_in_out = "input";
        pinctrl-names = "default";
         pinctrl-0 = <&rmii_pins>;
        phy-supply = <&vcc_phy>;
         phy-mode = "rmii";
        snps,reset-active-low;
        snps, reset-delays-us = <0 10000 50000>;
        snps,reset-gpio = <&gpio2 24 GPIO_ACTIVE_LOW>;
        status = "okay";
};
```

```
tx_delay = <0x30>;
    rx_delay = <0x16>;
    status = "okay";
};
```

## **RMII Clock Output**

```
&gmac {
         assigned-clocks = <&cru SCLK_MAC_EXTCLK>, <&cru SCLK_MAC>;
+
         assigned-clock-parents = <&ext_gmac>, <&cru SCLK_MAC_EXTCLK>;
         assigned-clock-rates = <0>, <50000000>;
         clock_in_out = "output";
        phy-supply = <&vcc_phy>;
         phy-mode = "rmii";
         pinctrl-names = "default";
+
         pinctrl-0 = <&rmii_pins>;
        snps,reset-gpio = <&gpio2 RK_PDO GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        snps, reset-delays-us = <0 20000 100000>;
        status = "okay";
};
```

## **RMII Clock Input**

```
+&ext_gmac: external-gmac-clock {
         clock-frequency = <50000000>;
+}
&gmac {
         assigned-clocks = <&cru SCLK_MAC_EXTCLK>, <&cru SCLK_MAC>;
+
         assigned-clock-parents = <&ext_gmac>, <&cru SCLK_MAC_EXTCLK>;
         clock_in_out = "input";
        phy-supply = <&vcc_phy>;
         phy-mode = "rmii";
         pinctrl-names = "default";
         pinctrl-0 = <&rmii_pins>;
        snps,reset-gpio = <&gpio2 RK_PD0 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        snps,reset-delays-us = <0 20000 100000>;
        status = "okay";
};
```

# **RGMII Clock Output**

```
snps,reset-gpio = <&gpio2 RK_PD0 GPIO_ACTIVE_LOW>;
snps,reset-active-low;
snps,reset-delays-us = <0 20000 100000>;
tx_delay = <0x30>;
rx_delay = <0x10>;
status = "okay";
};
```

#### **RGMII Clock Input**

```
&gmac {
         assigned-clocks = <&cru SCLK_MAC_EXTCLK>, <&cru SCLK_MAC>;
+
         assigned-clock-parents = <&ext_gmac>, <&cru SCLK_MAC_EXTCLK>;
         clock_in_out = "input";
        phy-supply = <&vcc_phy>;
         phy-mode = "rgmii";
        pinctrl-names = "default";
+
         pinctrl-0 = <&rgmii_pins>;
        snps,reset-gpio = <&gpio2 RK_PDO GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        snps,reset-delays-us = <0 20000 100000>;
        tx_delay = <0x30>;
        rx_delay = <0x10>;
        status = "okay";
};
```

#### **Internal EPHY**

```
&gmac {
         assigned-clocks = <&cru SCLK_MAC_SRC>;
         assigned-clock-rates = <50000000>;
+
         clock_in_out = "output";
        phy-supply = <&vcc_phy>;
         phy-mode = "rmii";
        phy-handle = <&phy>;
        status = "okay";
        mdio {
                compatible = "snps,dwmac-mdio";
                #address-cells = <1>;
                #size-cells = <0>;
                phy: ethernet-phy@0 {
                        compatible = "ethernet-phy-id1234.d400", "ethernet-phy-
ieee802.3-c22";
                        reg = <0>;
                        clocks = <&cru SCLK_MAC_PHY>;
                        resets = <&cru SRST_MACPHY>;
                        phy-is-integrated;
                };
        };
};
```

## **RMII Clock Output**

```
&gmac {
        phy-supply = < &vcc_phy>;
         phy-mode = "rmii";
+
         clock_in_out = "output";
+
         assigned-clocks = <&cru SCLK_MAC>;
+
         assigned-clock-rates = <50000000>;
        snps,reset-gpio = <&gpio4 RK_PA7 GPIO_ACTIVE_HIGH>;
        snps,reset-active-low;
        snps,reset-delays-us = <0 20000 1000000>;
         pinctrl-names = "default";
+
         pinctrl-0 = <&rmii_pins>;
        status = "okay";
};
```

# **RMII Clock Input**

```
+&ext_gmac: external-gmac-clock {
         clock-frequency = <50000000>;
+}
&gmac {
        phy-supply = <&vcc_phy>;
        phy-mode = "rmii";
        clock_in_out = "input";
         assigned-clocks = <&cru SCLK_MAC>;
         assigned-clock-parents = <&ext_gmac>;
        snps,reset-gpio = <&gpio4 RK_PA7 GPIO_ACTIVE_HIGH>;
        snps,reset-active-low;
        snps,reset-delays-us = <0 20000 1000000>;
         pinctrl-names = "default";
         pinctrl-0 = <&rmii_pins>;
        status = "okay";
};
```

## **RMII Clock Output**

```
&gmac2io {
        phy-supply = < &vcc_phy>;
         phy-mode = "rmii";
         clock_in_out = "output";
+
         assigned-clocks = <&cru SCLK_MAC2I0>;
+
         assigned-clock-rates = <50000000>;
        snps,reset-gpio = <&gpio1 RK_PC2 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        snps, reset-delays-us = <0 20000 100000>;
         pinctrl-names = "default";
+
         pinctrl-0 = <&rmiim1_pins>;
        status = "okay";
};
```

## **RMII Clock Input**

```
+&clkin_gmac {
         clock-frequency = <50000000>;
+};
&gmac2io {
        phy-supply = <&vcc_phy>;
        phy-mode = "rmii";
        clock_in_out = "input";
         assigned-clocks = <&cru SCLK_MAC2IO>, <&cru SCLK_MAC2IO_EXT>;
         assigned-clock-parents = <&gmac_clkin>, <&gmac_clkin>;
        snps,reset-gpio = <&gpio1 RK_PC2 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        snps, reset-delays-us = <0 20000 100000>;
         pinctrl-names = "default";
         pinctrl-0 = <&rmiim1_pins>;
        status = "okay";
};
```

## **RMII Clock Output**

# RMII Clock Input

```
+&ext_gmac {
        clock-frequency = <50000000>;
+}
&gmac {
        phy-supply = <\&vcc_lan>;
        phy-mode = "rmii";
        clock_in_out = "input";
        assigned-clocks = <&cru SCLK_MAC>;
        assigned-clock-parents = <&ext_gmac>;
        snps,reset-gpio = <&gpio3 12 0>;
        snps,reset-active-low;
        snps,reset-delays-us = <0 20000 100000>;
        pinctrl-names = "default";
        pinctrl-0 = <&rmii_pins>;
        status = "ok";
};
```

#### **RMII Clock Output**

# **RMII Clock Input**

```
+&clkin_gmac {
         clock-frequency = <50000000>;
+};
&gmac {
         assigned-clocks = <&cru SCLK_RMII_SRC>;
         assigned-clock-parents = <&clkin_gmac>;
         clock_in_out = "input";
        phy-supply = <&vcc_phy>;
         phy-mode = "rmii";
         pinctrl-names = "default";
         pinctrl-0 = <&rmii_pins>;
        snps,reset-gpio = <&gpio3 RK_PB7 GPIO_ACTIVE_LOW>;
        snps, reset-active-low;
        snps, reset-delays-us = <0 20000 100000>;
        status = "okay";
};
```

```
&gmac {
```

```
+ assigned-clocks = <&cru SCLK_RMII_SRC>;
+ assigned-clock-parents = <&clkin_gmac>;
+ clock_in_out = "input";
    phy-supply = <&vcc_phy>;
+ phy-mode = "rgmii";
+ pinctrl-names = "default";
+ pinctrl-0 = <&rgmii_pins>;
    snps,reset-gpio = <&gpio3 RK_PB7 GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    snps,reset-delays-us = <0 20000 100000>;
    tx_delay = <0x28>;
    rx_delay = <0x11>;
    status = "okay";
};
```

## **GMAC1 RMII Clock 50M Output, PLL 25M Output**

```
&gmac1 {
    phy-mode = "rmii";
    clock_in_out = "output";
    snps,reset-gpio = <&gpio3 RK_PC3 GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    snps, reset-delays-us = <0 10000 50000>;
    pinctrl-names = "default";
    pinctrl-0 = <&rgmii_miim</pre>
             &rgmii_tx_bus2
             &rgmii_rx_bus2
             &rgmii_clk
             &eth_pins>;
    phy-handle = <&rmii1_phy>;
    status = "okay";
};
&mdio1 {
    rmii1_phy: phy@1 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x1>;
        clocks = <&cru CLK_GMAC1_VPU_25M>;
    };
};
```

# GMAC1 RMII Clock 50M Input, PLL 25M Output

```
&gmac1 {
    phy-mode = "rmii";
    clock_in_out = "input";

    snps,reset-gpio = <&gpio3 RK_PC3 GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    snps,reset-delays-us = <0 10000 50000>;
```

```
pinctrl-names = "default";
    pinctrl-0 = <&rgmii_miim</pre>
             &rgmii_tx_bus2
             &rgmii_rx_bus2
             &rgmii_clk
             &eth_pins>;
    phy-handle = <&rmii1_phy>;
    status = "okay";
};
&mdio1 {
    rmii1_phy: phy@1 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x1>;
        clocks = <&cru CLK_GMAC1_VPU_25M>;
    };
};
```

#### GMAC1 RGMII PLL output 25M for PHY, PLL output 125M for TX\_CLK

```
&gmac1 {
    /* Use rgmii-rxid mode to disable rx delay inside Soc */
    phy-mode = "rgmii-rxid";
    clock_in_out = "output";
    snps,reset-gpio = <&gpio4 RK_PC2 GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    /* Reset time is 20ms, 100ms for rtl8211f */
    snps,reset-delays-us = <0 20000 100000>;
    tx_delay = <0x30>;
    /* rx_delay = <0x3f>; */
    pinctrl-names = "default";
    pinctrl-0 = <&rgmii_miim</pre>
             &rgmii_tx_bus2
             &rgmii_rx_bus2
             &rgmii_rgmii_clk
             &rgmii_rgmii_bus
             &eth_pins>;
    phy-handle = <&rgmii_phy>;
    status = "okay";
};
&mdio1 {
    rgmii_phy: phy@1 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x1>;
        clocks = <&cru CLK_GMAC1_VPU_25M>;
    };
};
```

# GMAC1 RGMII Crystal 25M for PHY, PLL output 125M for TX\_CLK

```
&gmac1 {
    /* Use rgmii-rxid mode to disable rx delay inside Soc */
    phy-mode = "rgmii-rxid";
    clock_in_out = "output";
    snps,reset-gpio = <&gpio4 RK_PC2 GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    /* Reset time is 20ms, 100ms for rtl8211f */
    snps, reset-delays-us = <0 20000 100000>;
    tx_delay = <0x30>;
    /* rx_delay = <0x3f>; */
    pinctrl-names = "default";
    pinctrl-0 = <&rgmii_miim</pre>
             &rgmii_tx_bus2
             &rgmii_rx_bus2
             &rgmii_rgmii_clk
             &rgmii_rgmii_bus>;
    phy-handle = <&rgmii_phy>;
    status = "okay";
};
&mdio1 {
    rgmii_phy: phy@1 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x1>;
    };
};
```

# GMAC1 RGMII PLL output 25M for PHY, RGMII\_CLK input 125M for TX\_CLK

```
&gmac1 {
    /* Use rgmii-rxid mode to disable rx delay inside Soc */
    phy-mode = "rgmii-rxid";
    clock_in_out = "input";
    snps,reset-gpio = <&gpio4 RK_PC2 GPIO_ACTIVE_LOW>;
    snps, reset-active-low;
    /* Reset time is 20ms, 100ms for rtl8211f */
    snps, reset-delays-us = <0 20000 100000>;
    tx_delay = <0x30>;
    /* rx_delay = <0x3f>; */
    pinctrl-names = "default";
    pinctrl-0 = <&rgmii_miim</pre>
             &rgmii_tx_bus2
             &rgmii_rx_bus2
             &rgmii_rgmii_clk
             &rgmii_rgmii_bus
             &rgmii_clk
             &eth_pins>;
    phy-handle = <&rgmii_phy>;
    status = "okay";
```

```
%mdio1 {
    rgmii_phy: phy@1 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x1>;
        clocks = <&cru CLK_GMAC1_VPU_25M>;
    };
};
```

## GMAC1 RGMII Crystal 25M for PHY, RGMII\_CLK input 125M for TX\_CLK

```
&gmac1 {
    /* Use rgmii-rxid mode to disable rx delay inside Soc */
    phy-mode = "rgmii-rxid";
    clock_in_out = "input";
    snps,reset-gpio = <&gpio4 RK_PC2 GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    /* Reset time is 20ms, 100ms for rtl8211f */
    snps, reset-delays-us = <0 20000 100000>;
    tx_delay = <0x30>;
   /* rx_delay = <0x3f>; */
    pinctrl-names = "default";
    pinctrl-0 = <&rgmii_miim</pre>
             &rgmii_tx_bus2
             &rgmii_rx_bus2
             &rgmii_rgmii_clk
             &rgmii_rgmii_bus
             &rgmii_clk>;
    phy-handle = <&rgmii_phy>;
    status = "okay";
};
&mdio1 {
    rgmii_phy: phy@1 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x1>;
    };
};
```

#### **GMACO & FEPHY**

GMACO 与内部 FEPHY 相连,是固定的 RMII,没有模式可以配置;但可以根据硬件原理图配置 PHY led 功能,有 3 个功能 IO 可配置,配置对应 IO 的 iomux 即可,默认配置如下:

```
&rmii0_phy {
    pinctrl-names = "default";
    pinctrl-0 = <&fephym0_led_link &fephym0_led_spd>;
};
```

## **RMII Clock Output**

• gmac0

```
&gmac0 {
         phy-mode = "rmii";
+
         clock_in_out = "output";
+
         assigned-clocks = <&cru SCLK_GMACO_RX_TX>, <&cru SCLK_GMACO>;
+
         assigned-clock-parents = <&cru SCLK_GMACO_RMII_SPEED>;
         assigned-clock-rates = <0>, <50000000>;
        snps,reset-gpio = <&gpio3 RK_PC2 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        snps, reset-delays-us = <0 20000 100000>;
        pinctrl-names = "default";
        pinctrl-0 = <&gmac0_miim &gmac0_clkinout &gmac0_rx_bus2 &gmac0_tx_bus2>;
        phy-handle = <&rmii_phy0>;
        status = "okay";
};
&mdio0 {
        rmii_phy0: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
        };
};
```

• gmac1m0:

```
&gmac1 {
         phy-mode = "rmii";
         clock_in_out = "output";
         assigned-clocks = <&cru SCLK_GMAC1_RX_TX>, <&cru SCLK_GMAC1>;
         assigned-clock-parents = <&cru SCLK_GMAC1_RMII_SPEED>;
         assigned-clock-rates = <0>, <50000000>;
        snps,reset-gpio = <&gpio3 RK_PC2 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        snps,reset-delays-us = <0 20000 100000>;
         pinctrl-names = "default";
         pinctrl-0 = <&gmac1m0_miim &gmac1m0_clkinout &gmac1m0_rx_bus2</pre>
&gmac1m0_tx_bus2>;
        phy-handle = <&rmii_phy1>;
        status = "okay";
};
&mdio1 {
        rmii_phy1: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
        };
};
```

• gmac1m1:

```
&gmac1 {
         phy-mode = "rmii";
         clock_in_out = "output";
         assigned-clocks = <&cru SCLK_GMAC1_RX_TX>, <&cru SCLK_GMAC1>;
         assigned-clock-parents = <&cru SCLK_GMAC1_RMII_SPEED>;
         assigned-clock-rates = <0>, <50000000>;
        snps,reset-gpio = <&gpio3 RK_PC2 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        snps, reset-delays-us = <0 20000 100000>;
         pinctrl-names = "default";
         pinctrl-0 = <&gmac1m1_miim &gmac1m1_clkinout &gmac1m1_rx_bus2</pre>
&gmac1m1_tx_bus2>;
        phy-handle = <&rmii_phy1>;
        status = "okay";
};
&mdio1 {
        rmii_phy1: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
        };
};
```

#### **RMII Clock Input**

• gmac0

```
+&gmac0_clkin{
         clock-frequency = <50000000>;
+};
&gmac0 {
         phy-mode = "rmii";
         clock_in_out = "input";
        snps,reset-gpio = <&gpio3 RK_PC2 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        snps,reset-delays-us = <0 20000 100000>;
         assigned-clocks = <&cru SCLK_GMACO_RX_TX>, <&cru SCLK_GMACO>;
         assigned-clock-parents = <&cru SCLK_GMACO_RMII_SPEED>, <&gmac0_clkin>;
         pinctrl-names = "default";
         pinctrl-0 = <&gmac0_miim &gmac0_clkinout &gmac0_rx_bus2</pre>
&gmac0_tx_bus2>;
        phy-handle = <&rmii_phy0>;
        status = "okay";
};
&mdio0 {
        rmii_phy0: phy@0 {
```

```
compatible = "ethernet-phy-ieee802.3-c22";
reg = <0x0>;
};
};
```

• gmac1m0:

```
+&gmac1_clkin{
         clock-frequency = <50000000>;
+};
&gmac1 {
         phy-mode = "rmii";
         clock_in_out = "input";
        snps,reset-gpio = <&gpio3 RK_PC2 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        snps,reset-delays-us = <0 20000 100000>;
         assigned-clocks = <&cru SCLK_GMAC1_RX_TX>, <&cru SCLK_GMAC1>;
         assigned-clock-parents = <&cru SCLK_GMAC1_RMII_SPEED>, <&gmac1_clkin>;
         pinctrl-names = "default";
         pinctrl-0 = <&gmac1m0_miim &gmac1m0_clkinout &gmac1m0_rx_bus2</pre>
&gmac1m0_tx_bus2>;
        phy-handle = <&rmii_phy1>;
        status = "okay";
};
&mdio1 {
        rmii_phy1: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                 reg = \langle 0x0 \rangle;
        };
};
```

• gmac1m1:

#### RGMII PLL output 25M for PHY, PLL output 125M for TX\_CLK

• gmac0

```
&gmac0 {
         phy-mode = "rgmii";
         clock_in_out = "output";
         assigned-clocks = <&cru SCLK_GMACO_RX_TX>, <&cru SCLK_GMACO>, <&cru
CLK_MACO_OUT>;
         assigned-clock-parents = <&cru SCLK_GMACO_RGMII_SPEED>;
         assigned-clock-rates = <0>, <125000000>, <25000000>;
        snps,reset-gpio = <&gpio2 RK_PD3 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        /* Reset time is 20ms, 100ms for rtl8211f */
        snps,reset-delays-us = <0 20000 100000>;
         pinctrl-names = "default";
         pinctrl-0 = <&gmac0_miim</pre>
                       &gmac0_tx_bus2
                       &gmac0_rx_bus2
                       &gmac0_rgmii_clk
                       &gmac0_rgmii_bus
                       &eth0_pins>;
        tx_delay = <0x3c>;
        rx_delay = <0x2f>;
        phy-handle = <&rgmii_phy0>;
        status = "okay";
};
&mdio0 {
        rgmii_phy0: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = \langle 0x0 \rangle;
                 clocks = <&cru CLK_MAC0_OUT>;
        };
};
```

```
snps,reset-active-low;
        /* Reset time is 20ms, 100ms for rtl8211f */
        snps, reset-delays-us = <0 20000 100000>;
         assigned-clocks = <&cru SCLK_GMAC1_RX_TX>, <&cru SCLK_GMAC1>, <&cru
CLK_MAC1_OUT>;
         assigned-clock-parents = <&cru SCLK_GMAC1_RGMII_SPEED>;
         assigned-clock-rates = <0>, <125000000>, <25000000>;
         pinctrl-names = "default";
         pinctrl-0 = <&gmac1m0_miim</pre>
                      &gmac1m0_tx_bus2
                      &gmac1m0_rx_bus2
                      &gmac1m0_rgmii_clk
                      &gmac1m0_rgmii_bus
                      &eth1m0_pins>;
        tx_delay = <0x4f>;
        rx_delay = <0x26>;
        phy-handle = <&rgmii_phy1>;
        status = "okay";
};
&mdio1 {
        rgmii_phy1: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
                 clocks = <&cru CLK_MAC1_OUT>;
        };
};
```

```
&gmac1 {
         phy-mode = "rgmii";
         clock_in_out = "output";
        snps,reset-gpio = <&gpio2 RK_PD1 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        /* Reset time is 20ms, 100ms for rtl8211f */
        snps, reset-delays-us = <0 20000 100000>;
         assigned-clocks = <%cru SCLK_GMAC1_RX_TX>, <%cru SCLK_GMAC1>, <%cru
CLK_MAC1_OUT>;
         assigned-clock-parents = <&cru SCLK_GMAC1_RGMII_SPEED>;
         assigned-clock-rates = <0>, <125000000>, <25000000>;
         pinctrl-names = "default";
         pinctrl-0 = <&gmac1m1_miim</pre>
                      &gmac1m1_tx_bus2
                      &gmac1m1_rx_bus2
                      &gmac1m1_rgmii_clk
                      &gmac1m1_rgmii_bus
                      &eth1m1_pins>;
        tx_delay = <0x4f>;
```

```
rx_delay = <0x26>;

phy-handle = <&rgmii_phy1>;
status = "okay";
};

&mdio1 {
    rgmii_phy1: phy@0 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x0>;
        clocks = <&cru CLK_MAC1_OUT>;
    };
};
```

#### RGMII PLL output 25M for PHY, RGMII\_CLK input 125M for TX\_CLK

• gmac0

```
&gmac0 {
         phy-mode = "rgmii";
         clock_in_out = "input";
         assigned-clocks = <%cru SCLK_GMACO_RX_TX>, <%cru SCLK_GMACO>, <%cru
CLK_MACO_OUT>;
         assigned-clock-parents = <&cru SCLK_GMACO_RGMII_SPEED>, <&gmac0_clkin>;
         assigned-clock-rates = <0>, <125000000>, <25000000>;
        snps,reset-gpio = <&gpio2 RK_PD3 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        /* Reset time is 20ms, 100ms for rtl8211f */
        snps, reset-delays-us = <0 20000 100000>;
         pinctrl-names = "default";
         pinctrl-0 = <&gmac0_miim</pre>
                      &gmac0_tx_bus2
+
                      &gmac0_rx_bus2
                      &gmac0_rgmii_clk
                      &gmac0_rgmii_bus
                      &eth0_pins
                      &gmac0_clkinout>;
        tx_delay = <0x3c>;
        rx_delay = <0x2f>;
        phy-handle = <&rgmii_phy0>;
        status = "okay";
};
&mdio0 {
        rgmii_phy0: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
                 clocks = <&cru CLK_MAC0_OUT>;
        };
};
```

```
&gmac1 {
         phy-mode = "rgmii";
         clock_in_out = "input";
        snps,reset-gpio = <&gpio2 RK_PD1 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        /* Reset time is 20ms, 100ms for rtl8211f */
        snps,reset-delays-us = <0 20000 100000>;
         assigned-clocks = <&cru SCLK_GMAC1_RX_TX>, <&cru SCLK_GMAC1>, <&cru
CLK_MAC1_OUT>;
         assigned-clock-parents = <&cru SCLK_GMAC1_RGMII_SPEED>, <&gmac1_clkin>;
         assigned-clock-rates = <0>, <125000000>, <25000000>;
         pinctrl-names = "default";
         pinctrl-0 = <&gmac1m0_miim</pre>
                      &gmac1m0_tx_bus2
                      &gmac1m0_rx_bus2
                      &gmac1m0_rgmii_clk
                      &gmac1m0_rgmii_bus
                      &eth1m0_pins
                      &gmac1m0_clkinout>;
        tx_delay = <0x4f>;
        rx_delay = <0x26>;
        phy-handle = <&rgmii_phy1>;
        status = "okay";
};
&mdio0 {
        rgmii_phy1: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                req = <0x0>;
                 clocks = <&cru CLK_MAC0_OUT>;
        };
};
```

```
&gmac1m1_rx_bus2
                       &gmac1m1_rgmii_clk
                       &gmac1m1_rgmii_bus
                       &eth1m1_pins
                       &gmac1m1_clkinout>;
        tx_delay = <0x4f>;
        rx_delay = <0x26>;
        phy-handle = <&rgmii_phy1>;
        status = "okay";
};
&mdio1 {
        rgmii_phy1: phy@0 {
                 compatible = "ethernet-phy-ieee802.3-c22";
                 reg = \langle 0x0 \rangle;
                  clocks = <&cru CLK_MAC1_OUT>;
        };
};
```

## RGMII Crystal 25M for PHY, PLL output 125M for TX\_CLK

• gmac0

```
&gmac0 {
         phy-mode = "rgmii";
         clock_in_out = "output";
         assigned-clocks = <&cru SCLK_GMACO_RX_TX>, <&cru SCLK_GMACO>;
         assigned-clock-parents = <&cru SCLK_GMACO_RGMII_SPEED>;
         assigned-clock-rates = <0>, <125000000>;
        snps,reset-gpio = <&gpio2 RK_PD3 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        /* Reset time is 20ms, 100ms for rtl8211f */
        snps, reset-delays-us = <0 20000 100000>;
         pinctrl-names = "default";
         pinctrl-0 = <&gmac0_miim</pre>
                      &gmac0_tx_bus2
                      &gmac0_rx_bus2
                      &gmac0_rgmii_clk
                      &gmac0_rgmii_bus>;
        tx_delay = <0x3c>;
        rx_delay = <0x2f>;
        phy-handle = <&rgmii_phy0>;
        status = "okay";
};
&mdio0 {
        rgmii_phy0: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
        };
};
```

• gmac1m0

```
&gmac1 {
         phy-mode = "rgmii";
         clock_in_out = "output";
        snps,reset-gpio = <&gpio2 RK_PD1 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        /* Reset time is 20ms, 100ms for rtl8211f */
        snps, reset-delays-us = <0 20000 100000>;
         assigned-clocks = <&cru SCLK_GMAC1_RX_TX>, <&cru SCLK_GMAC1>;
         assigned-clock-parents = <&cru SCLK_GMAC1_RGMII_SPEED>;
         assigned-clock-rates = <0>, <125000000>;
         pinctrl-names = "default";
         pinctrl-0 = < &gmac1m0_miim
                      &gmac1m0_tx_bus2
+
                      &gmac1m0_rx_bus2
+
                      &gmac1m0_rgmii_clk
                      &gmac1m0_rgmii_bus>;
        tx_delay = <0x4f>;
        rx_delay = <0x26>;
        phy-handle = <&rgmii_phy1>;
        status = "okay";
};
&mdio1 {
        rgmii_phy1: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
        };
};
```

```
&gmac1 {
         phy-mode = "rgmii";
         clock_in_out = "output";
        snps,reset-gpio = <&gpio2 RK_PD1 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        /* Reset time is 20ms, 100ms for rtl8211f */
        snps,reset-delays-us = <0 20000 100000>;
         assigned-clocks = <&cru SCLK_GMAC1_RX_TX>, <&cru SCLK_GMAC1>;
         assigned-clock-parents = <&cru SCLK_GMAC1_RGMII_SPEED>;
         assigned-clock-rates = <0>, <125000000>;
         pinctrl-names = "default";
         pinctrl-0 = <&gmac1m1_miim</pre>
                      &gmac1m1_tx_bus2
                      &gmac1m1_rx_bus2
                      &gmac1m1_rgmii_clk
+
                      &gmac1m1_rgmii_bus>;
```

```
tx_delay = <0x4f>;
    rx_delay = <0x26>;

phy-handle = <&rgmii_phy1>;
    status = "okay";
};

&mdio1 {
        rgmii_phy1: phy@0 {
             compatible = "ethernet-phy-ieee802.3-c22";
             reg = <0x0>;
        };
};
```

## RGMII Crystal 25M for PHY, RGMII\_CLK input 125M for TX\_CLK

• gmac0

```
&gmac0 {
         phy-mode = "rgmii";
         clock_in_out = "input";
+
         assigned-clocks = <&cru SCLK_GMACO_RX_TX>, <&cru SCLK_GMACO>;
         assigned-clock-parents = <&cru SCLK_GMACO_RGMII_SPEED>, <&gmac0_clkin>;
         assigned-clock-rates = <0>, <125000000>;
        snps,reset-gpio = <&gpio2 RK_PD3 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        /* Reset time is 20ms, 100ms for rtl8211f */
        snps, reset-delays-us = <0 20000 100000>;
         pinctrl-names = "default";
         pinctrl-0 = <&gmac0_miim</pre>
                      &gmac0_tx_bus2
                      &gmac0_rx_bus2
                      &gmac0_rgmii_clk
                      &gmac0_rgmii_bus
                      &gmac0_clkinout>;
        tx_delay = <0x3c>;
        rx_delay = <0x2f>;
        phy-handle = <&rgmii_phy0>;
        status = "okay";
};
&mdio0 {
        rgmii_phy0: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
        };
};
```

```
&gmac1 {
+     phy-mode = "rgmii";
```

```
clock_in_out = "input";
        snps,reset-gpio = <&gpio2 RK_PD1 GPIO_ACTIVE_LOW>;
        snps, reset-active-low;
        /* Reset time is 20ms, 100ms for rtl8211f */
        snps, reset-delays-us = <0 20000 100000>;
         assigned-clocks = <&cru SCLK_GMAC1_RX_TX>, <&cru SCLK_GMAC1>;
         assigned-clock-parents = <&cru SCLK_GMAC1_RGMII_SPEED>, <&gmac1_clkin>;
         assigned-clock-rates = <0>, <125000000>;
         pinctrl-names = "default";
         pinctrl-0 = <&gmac1m0_miim</pre>
                      &gmac1m0_tx_bus2
                      &gmac1m0_rx_bus2
                      &gmac1m0_rgmii_clk
                      &gmac1m0_rgmii_bus
                      &gmac1m0_clkinout>;
        tx_delay = <0x4f>;
        rx_delay = <0x26>;
        phy-handle = <&rgmii_phy1>;
        status = "okay";
};
&mdio1 {
        rgmii_phy1: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
        };
};
```

```
&gmac1 {
         phy-mode = "rgmii";
         clock_in_out = "input";
        snps,reset-gpio = <&gpio2 RK_PD1 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        /* Reset time is 20ms, 100ms for rtl8211f */
        snps, reset-delays-us = <0 20000 100000>;
         assigned-clocks = <&cru SCLK_GMAC1_RX_TX>, <&cru SCLK_GMAC1>;
         assigned-clock-parents = <&cru SCLK_GMAC1_RGMII_SPEED>, <&gmac1_clkin>;
         assigned-clock-rates = <0>, <125000000>;
         pinctrl-names = "default";
         pinctrl-0 = <&gmac1m1_miim</pre>
                      &gmac1m1_tx_bus2
                      &gmac1m1_rx_bus2
+
                      &gmac1m1_rgmii_clk
                      &gmac1m1_rgmii_bus
                      &gmac1m1_clkinout>;
        tx_delay = <0x4f>;
```

```
rx_delay = <0x26>;

phy-handle = <&rgmii_phy1>;
status = "okay";
};

&mdio1 {
    rgmii_phy1: phy@0 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x0>;
    };
};
```

#### **SGMII**

DTS 除了配置 gmac 和 mac phy 节点外,还需要配置 xpcs 和 combophy 节点。

combophy

其中属性 rockchip, sgmii-mac-sel 表示使用的是哪个 gmac:

```
&combphy1_usq {
+    rockchip,sgmii-mac-sel = <0>; /* Use gmac0 for sgmii */
    status = "okay";
};
```

xpcs

```
&xpcs {
     status = "okay";
};
```

• gmac0

```
&gmac0 {
        phy-mode = "sgmii";
        rockchip,pipegrf = <&pipegrf>;
        rockchip,xpcs = <&xpcs>;
        snps,reset-gpio = <&gpio2 RK_PC2 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        snps,reset-delays-us = <0 20000 100000>;
        assigned-clocks = <&cru SCLK_GMAC0_RX_TX>;
        assigned-clock-parents = <&gmac0_xpcsclk>;
        pinctrl-names = "default";
        pinctrl-0 = < &gmac0_miim>;
        power-domains = <&power RK3568_PD_PIPE>;
        phys = <&combphy1_usq PHY_TYPE_SGMII>;
        phy-handle = <&sgmii_phy>;
        status = "okay";
};
```

• gmac1

```
&gmac1 {
        phy-mode = "sgmii";
        rockchip,pipegrf = <&pipegrf>;
        rockchip,xpcs = <&xpcs>;
        snps,reset-gpio = <&gpio2 RK_PC2 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        snps, reset-delays-us = <0 20000 100000>;
        assigned-clocks = <&cru SCLK_GMAC1_RX_TX>;
        assigned-clock-parents = <&gmac1_xpcsclk>;
        pinctrl-names = "default";
        pinctrl-0 = < &gmac1_miim>;
        power-domains = <&power RK3568_PD_PIPE>;
        phys = <&combphy1_usq PHY_TYPE_SGMII>;
        phy-handle = <&sgmii_phy>;
        status = "okay";
};
&mdio1 {
        sgmii_phy: phy@1 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x1>;
        };
};
```

#### **QSGMII**

同 SGMIII 类似,DTS 除了配置 gmac 和 mac phy 节点外,还需要配置 xpcs 和 combophy 节点。

combophy

```
&combphy2_psq {
    status = "okay";
};
```

xpcs

```
&xpcs {
    status = "okay";
};
```

```
&gmac0 {
```

```
phy-supply = <&pcie20_3v3>;
    phy-mode = "qsgmii";
    rockchip,xpcs = <&xpcs>;
    snps,reset-gpio = <&gpio2 RK_PC2 GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    snps, reset-delays-us = <0 20000 100000>;
    assigned-clocks = <&cru SCLK_GMAC0_RX_TX>;
    assigned-clock-parents = <&gmac0_xpcsclk>;
    pinctrl-names = "default";
    pinctrl-0 = <&gmac0_miim>;
    power-domains = <&power RK3568_PD_PIPE>;
    phys = <&combphy2_psq PHY_TYPE_QSGMII>;
    phy-handle = <&qsgmii_phy0>;
    status = "okay";
};
&gmac1 {
    phy-supply = <&pcie20_3v3>;
    phy-mode = "qsgmii";
    assigned-clocks = <&cru SCLK_GMAC1_RX_TX>;
    assigned-clock-parents = <&gmac1_xpcsclk>;
    power-domains = <&power RK3568_PD_PIPE>;
    phy-handle = <&qsgmii_phy1>;
    status = "okay";
};
&mdio0 {
    qsgmii_phy0: phy@0 {
        compatible = "ethernet-phy-id001c.c942", "ethernet-phy-ieee802.3-c22";
        reg = <0x0>;
    };
    qsgmii_phy1: phy@1 {
        compatible = "ethernet-phy-id001c.c942", "ethernet-phy-ieee802.3-c22";
        reg = <0x1>;
    };
    qsgmii_phy2: phy@2 {
        compatible = "ethernet-phy-id001c.c942", "ethernet-phy-ieee802.3-c22";
        reg = <0x2>;
    };
    qsgmii_phy3: phy@3 {
        compatible = "ethernet-phy-id001c.c942", "ethernet-phy-ieee802.3-c22";
        reg = <0x3>;
    };
};
```

• gmac0

```
&gmac0 {
        phy-mode = "rmii";
        clock_in_out = "output";
       snps, reset-gpio = < \&gpio4 RK_PB3 GPIO_ACTIVE_LOW>;
       snps,reset-active-low;
       /* Reset time is 20ms, 100ms for rtl8211f */
       snps, reset-delays-us = <0 20000 100000>;
        pinctrl-names = "default";
        pinctrl-0 = <&gmac0_miim</pre>
+
                      &gmac0_tx_bus2
+
                      &gmac0_rx_bus2
+
                      &gmac0_clkinout>;
       phy-handle = <&rmii_phy0>;
       status = "okay";
};
&mdio0 {
       rmii_phy0: phy@1 {
               compatible = "ethernet-phy-ieee802.3-c22";
               reg = <0x1>;
       };
};
```

• gmac1:

```
&gmac1 {
        phy-mode = "rmii";
        clock_in_out = "output";
       snps,reset-gpio = <&gpio3 RK_PB2 GPIO_ACTIVE_LOW>;
       snps,reset-active-low;
       /* Reset time is 20ms, 100ms for rt18211f */
       snps, reset-delays-us = <0 20000 100000>;
        pinctrl-names = "default";
        pinctrl-0 = <&gmac1_miim</pre>
                     &gmac1_tx_bus2
+
                      &gmac1_rx_bus2
                      &gmac1_clkinout>;
+
       phy-handle = <&rmii_phy1>;
       status = "okay";
};
&mdio1 {
       rmii_phy1: phy@1 {
               compatible = "ethernet-phy-ieee802.3-c22";
               reg = <0x1>;
       };
};
```

## **RMII Clock Input**

• gmac0

```
&gmac0 {
        phy-mode = "rmii";
        clock_in_out = "input";
       snps,reset-gpio = <&gpio4 RK_PB3 GPIO_ACTIVE_LOW>;
       snps,reset-active-low;
       /* Reset time is 20ms, 100ms for rtl8211f */
       snps, reset-delays-us = <0 20000 100000>;
        pinctrl-names = "default";
        pinctrl-0 = <&gmac0_miim</pre>
                     &gmac0_tx_bus2
+
                     &gmac0_rx_bus2
+
                     &gmac0_clkinout>;
+
       phy-handle = <&rmii_phy0>;
       status = "okay";
};
&mdio0 {
       rmii_phy0: phy@1 {
               compatible = "ethernet-phy-ieee802.3-c22";
               reg = <0x1>;
       };
};
```

• gmac1:

```
&gmac1 {
    phy-mode = "rmii";
    clock_in_out = "input";
    snps,reset-gpio = <&gpio3 RK_PB2 GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    /* Reset time is 20ms, 100ms for rtl8211f */
    snps, reset-delays-us = <0 20000 100000>;
    pinctrl-names = "default";
    pinctrl-0 = <&gmac1_miim</pre>
                 &gmac1_tx_bus2
                 &gmac1_rx_bus2
                 &gmac1_clkinout>;
    phy-handle = <&rmii_phy1>;
    status = "okay";
};
&mdio1 {
    rmii_phy1: phy@1 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x1>;
    };
};
```

### RGMII PLL output 25M for PHY, PLL output 125M for TX\_CLK

• gmac0

```
&gmac0 {
    /* Use rgmii-rxid mode to disable rx delay inside Soc */
  phy-mode = "rgmii-rxid";
    clock_in_out = "output";
    snps,reset-gpio = <&gpio4 RK_PB3 GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    /* Reset time is 20ms, 100ms for rtl8211f */
    snps,reset-delays-us = <0 20000 100000>;
    pinctrl-names = "default";
    pinctrl-0 = <&gmac0_miim</pre>
             &gmac0_tx_bus2
             &gmac0_rx_bus2
             &gmac0_rgmii_clk
             &gmac0_rgmii_bus
             &eth0_pins>;
    tx_delay = <0x45>;
    /* rx_delay = <0x43>; */
    phy-handle = <&rgmii_phy0>;
    status = "okay";
};
&mdio0 {
    rgmii_phy0: phy@1 {
        compatible = "ethernet-phy-ieee802.3-c22";
        req = <0x1>;
        clocks = <&cru REFCLKO25M_ETH0_OUT>;
    };
};
```

```
&gmac1 {
    /* Use rgmii-rxid mode to disable rx delay inside Soc */
+ phy-mode = "rgmii-rxid";
+ clock_in_out = "output";

snps,reset-gpio = <&gpio3 RK_PB2 GPIO_ACTIVE_LOW>;
snps,reset-active-low;
/* Reset time is 20ms, 100ms for rtl8211f */
snps,reset-delays-us = <0 20000 1000000>;

+ pinctrl-names = "default";
+ pinctrl-0 = <&gmac1_miim
+ &gmac1_tx_bus2
+ &gmac1_rx_bus2
+ &gmac1_rgmii_clk
+ &gmac1_rgmii_bus</pre>
```

```
tx_delay = <0x45>;
    tx_delay = <0x43>; */

phy-handle = <&rgmii_phy1>;
    status = "okay";
};

&mdio1 {
    rgmii_phy1: phy@1 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x1>;
        clocks = <&cru REFCLKO25M_ETHO_OUT>;
    };
};
```

# RGMII PLL output 25M for PHY, RGMII\_CLK input 125M for TX\_CLK

```
&gmac0 {
    /* Use rgmii-rxid mode to disable rx delay inside Soc */
    phy-mode = "rgmii-rxid";
  clock_in_out = "input";
    snps,reset-gpio = <&gpio4 RK_PB3 GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    /* Reset time is 20ms, 100ms for rtl8211f */
    snps, reset-delays-us = <0 20000 100000>;
    pinctrl-names = "default";
    pinctrl-0 = <&gmac0_miim</pre>
             &gmac0_tx_bus2
             &gmac0_rx_bus2
             &gmac0_rgmii_clk
             &gmac0_rgmii_bus
             &gmac0_clkinout
             &eth0_pins>;
    tx_delay = <0x45>;
    /* rx_delay = <0x43>; */
    phy-handle = <&rgmii_phy0>;
    status = "okay";
};
&mdio0 {
    rgmii_phy0: phy@1 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x1>;
        clocks = <&cru REFCLKO25M_ETH0_OUT>;
    };
};
```

```
&gmac1 {
    /* Use rgmii-rxid mode to disable rx delay inside Soc */
    phy-mode = "rgmii-rxid";
  clock_in_out = "input";
    snps,reset-gpio = <&gpio3 RK_PB2 GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    /* Reset time is 20ms, 100ms for rtl8211f */
    snps, reset-delays-us = <0 20000 100000>;
    pinctrl-names = "default";
    pinctrl-0 = <\&gmac1\_miim
             &gmac1_tx_bus2
             &gmac1_rx_bus2
             &gmac1_rgmii_clk
             &gmac1_rgmii_bus
             &gmac1_clkinout
             &eth1_pins>;
    tx_delay = <0x45>;
    /* rx_delay = <0x43>; */
    phy-handle = <&rgmii_phy1>;
    status = "okay";
};
&mdio1 {
    rgmii_phy1: phy@1 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x1>;
        clocks = <&cru REFCLKO25M_ETH0_OUT>;
    };
};
```

# RGMII Crystal 25M for PHY, PLL output 125M for TX\_CLK

• gmac1

```
&gmac1 {
    /* Use rgmii-rxid mode to disable rx delay inside Soc */
    phy-mode = "rgmii-rxid";
+ clock_in_out = "output";
    snps,reset-gpio = <&gpio3 RK_PB2 GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    /* Reset time is 20ms, 100ms for rtl8211f */
    snps,reset-delays-us = <0 20000 100000>;
  pinctrl-names = "default";
    pinctrl-0 = <&gmac1_miim</pre>
             &gmac1_tx_bus2
             &gmac1_rx_bus2
             &gmac1_rgmii_clk
+
             &gmac1_rgmii_bus>;
   tx_delay = <0x45>;
    /* rx_delay = <0x43>; */
    phy-handle = <&rgmii_phy1>;
    status = "okay";
};
&mdio1 {
        rgmii_phy1: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
        };
};
```

### RGMII Crystal 25M for PHY, RGMII\_CLK input 125M for TX\_CLK

```
&gmac0 {
    /* Use rgmii-rxid mode to disable rx delay inside Soc */
+ phy-mode = "rgmii-rxid";
+ clock_in_out = "input";

snps,reset-gpio = <&gpio4 RK_PB3 GPIO_ACTIVE_LOW>;
snps,reset-active-low;
```

```
/* Reset time is 20ms, 100ms for rtl8211f */
    snps,reset-delays-us = <0 20000 100000>;
    pinctrl-names = "default";
    pinctrl-0 = <&gmac0_miim</pre>
             &gmac0_tx_bus2
              &gmac0_rx_bus2
              &gmac0_rgmii_clk
+
              &gmac0_rgmii_bus
              &gmac0_clkinout>;
    tx_delay = <0x45>;
    /* rx_delay = <0x43>; */
    phy-handle = <&rgmii_phy0>;
    status = "okay";
};
&mdio0 {
        rgmii_phy0: phy@0 {
                 compatible = "ethernet-phy-ieee802.3-c22";
                 reg = \langle 0x0 \rangle;
        };
};
```

```
&gmac1 {
    /* Use rgmii-rxid mode to disable rx delay inside Soc */
    phy-mode = "rgmii-rxid";
  clock_in_out = "input";
    snps,reset-gpio = <&gpio3 RK_PB2 GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    /* Reset time is 20ms, 100ms for rtl8211f */
    snps, reset-delays-us = <0 20000 100000>;
    pinctrl-names = "default";
    pinctrl-0 = <&gmac1_miim</pre>
             &gmac1_tx_bus2
             &gmac1_rx_bus2
             &gmac1_rgmii_clk
             &gmac1_rgmii_bus
             &gmac1_clkinout>;
    tx_delay = <0x45>;
    /* rx_delay = <0x43>; */
    phy-handle = <&rgmii_phy1>;
    status = "okay";
};
&mdio1 {
        rgmii_phy1: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
        };
```

#### **RV1108**

## **RMII Clock Input**

```
+gmac_clkin: gmac_clkin {
        compatible = "fixed-clock";
         clock-output-names = "gmac_clkin";
         clock-frequency = <50000000>;
         #clock-cells = <0>;
+};
&gmac {
         phy-mode = "rmii";
        clock_in_out = "input";
        assigned-clocks = <&cru SCLK_MAC>;
+
        assigned-clock-parents = <&gmac_clkin>;
        snps,reset-gpio = <&gpio3 12 0>;
        snps,reset-active-low;
        snps, reset-delays-us = <0 20000 100000>;
        pinctrl-names = "default";
        pinctrl-0 = <&rmii_pins>;
        status = "ok";
};
```

## **RMII Clock Output**

#### **RV1126**

## RGMII PLL output 25M for PHY, PLL output 125M for TX\_CLK

```
&gmac {
+    phy-mode = "rgmii";
+    clock_in_out = "output";

snps,reset-gpio = <&gpio3 RK_PAO GPIO_ACTIVE_LOW>;
snps,reset-active-low;
/* Reset time is 20ms, 100ms for rtl8211f */
snps,reset-delays-us = <0 20000 100000>;
```

```
assigned-clocks = <%cru CLK_GMAC_SRC>, <%cru CLK_GMAC_TX_RX>, <%cru
CLK_GMAC_ETHERNET_OUT>;
    assigned-clock-parents = <&cru CLK_GMAC_SRC_M0>, <&cru RGMII_MODE_CLK>;
    assigned-clock-rates = <125000000>, <0>, <25000000>;
    pinctrl-names = "default";
    pinctrl-0 = <&rgmiim0_miim &rgmiim0_bus2 &rgmiim0_bus4 &clkm0_out_ethernet>;
    tx_delay = <0x2a>;
    rx_delay = <0x1a>;
    phy-handle = <&phy>;
    status = "okay";
};
&mdio {
    phy: phy@0 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x0>;
        clocks = <&cru CLK_GMAC_ETHERNET_OUT>;
    };
};
```

```
&gmac {
    phy-mode = "rgmii";
 clock_in_out = "output";
    snps,reset-gpio = <&gpio3 RK_PAO GPIO_ACTIVE_LOW>;
    snps, reset-active-low;
    /* Reset time is 20ms, 100ms for rtl8211f */
    snps,reset-delays-us = <0 20000 100000>;
    assigned-clocks = <&cru CLK_GMAC_SRC>, <&cru CLK_GMAC_TX_RX>, <&cru
CLK_GMAC_ETHERNET_OUT>;
    assigned-clock-parents = <&cru CLK_GMAC_SRC_M1>, <&cru RGMII_MODE_CLK>;
    assigned-clock-rates = <125000000>, <0>, <25000000>;
    pinctrl-names = "default";
    pinctrl-0 = <&rgmiim1_miim &rgmiim1_bus2 &rgmiim1_bus4 &clkm1_out_ethernet>;
    tx_delay = <0x2a>;
    rx_delay = <0x1a>;
    phy-handle = <&phy>;
    status = "okay";
};
&mdio {
    phy: phy@0 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x0>;
        clocks = <&cru CLK_GMAC_ETHERNET_OUT>;
    };
};
```

### RGMII PLL output 25M for PHY, RGMII Clock input 125M for TX\_CLK

• gmac m0

```
&gmac {
    phy-mode = "rgmii";
  clock_in_out = "input";
    snps,reset-gpio = <&gpio3 RK_PAO GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    /* Reset time is 20ms, 100ms for rt18211f */
    snps, reset-delays-us = <0 20000 100000>;
+ assigned-clocks = <%cru CLK_GMAC_SRC>, <%cru CLK_GMAC_TX_RX>, <%cru
CLK_GMAC_ETHERNET_OUT>;
    assigned-clock-parents = <&cru CLK_GMAC_SRC_M0>, <&cru RGMII_MODE_CLK>;
    assigned-clock-rates = <125000000>, <0>, <25000000>;
    pinctrl-names = "default";
    pinctrl-0 = <&rgmiim0_miim &rgmiim0_bus2 &rgmiim0_bus4 &clkm0_out_ethernet>;
    tx_delay = <0x2a>;
    rx_delay = <0x1a>;
    phy-handle = < & phy>;
    status = "okay";
};
&mdio {
    phy: phy@0 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x0>;
        clocks = <&cru CLK_GMAC_ETHERNET_OUT>;
    };
};
```

```
phy-handle = <&phy>;
status = "okay";
};

&mdio {
    phy: phy@0 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x0>;
        clocks = <&cru CLK_GMAC_ETHERNET_OUT>;
    };
};
```

### RGMII Crytal 25M for PHY, PLL output 125M for TX\_CLK

• gmac m0

```
&gmac {
    phy-mode = "rgmii";
  clock_in_out = "output";
    snps,reset-gpio = <&gpio3 RK_PAO GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    /* Reset time is 20ms, 100ms for rt18211f */
    snps, reset-delays-us = <0 20000 100000>;
  assigned-clocks = <&cru CLK_GMAC_SRC>, <&cru CLK_GMAC_TX_RX>;
   assigned-clock-parents = <&cru CLK_GMAC_SRC_M0>, <&cru RGMII_MODE_CLK>;
    assigned-clock-rates = <125000000>, <0>;
    pinctrl-names = "default";
    pinctrl-0 = <&rgmiim0_miim &rgmiim0_bus2 &rgmiim0_bus4 &clkm0_out_ethernet>;
    tx_delay = <0x2a>;
    rx_delay = <0x1a>;
    phy-handle = < & phy>;
    status = "okay";
};
&mdio {
    phy: phy@0 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x0>;
   };
};
```

```
&gmac {
+    phy-mode = "rgmii";
+    clock_in_out = "output";

snps,reset-gpio = <&gpio3 RK_PAO GPIO_ACTIVE_LOW>;
snps,reset-active-low;
/* Reset time is 20ms, 100ms for rtl8211f */
```

```
snps, reset-delays-us = <0 20000 100000>;
    assigned-clocks = <&cru CLK_GMAC_SRC>, <&cru CLK_GMAC_TX_RX>;
    assigned-clock-parents = <&cru CLK_GMAC_SRC_M1>, <&cru RGMII_MODE_CLK>;
    assigned-clock-rates = <125000000>, <0>;
    pinctrl-names = "default";
    pinctrl-0 = <&rgmiim1_miim &rgmiim1_bus2 &rgmiim1_bus4 &clkm1_out_ethernet>;
    tx_delay = <0x2a>;
    rx_delay = <0x1a>;
    phy-handle = <&phy>;
    status = "okay";
};
&mdio {
    phy: phy@0 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x0>;
    };
};
```

## RGMII Crytal 25M for PHY, RGMII\_CLK input 125M for TX\_CLK

```
&gmac {
    phy-mode = "rgmii";
  clock_in_out = "input";
    snps,reset-gpio = <&gpio3 RK_PAO GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    /* Reset time is 20ms, 100ms for rtl8211f */
    snps, reset-delays-us = <0 20000 100000>;
+ assigned-clocks = <&cru CLK_GMAC_RGMII_MO>, <&cru CLK_GMAC_SRC_MO>, <&cru
CLK_GMAC_SRC>, <&cru CLK_GMAC_TX_RX>;
   assigned-clock-parents = <&gmac_clkin_m0>, <&cru CLK_GMAC_RGMII_M0>, <&cru
CLK_GMAC_SRC_MO>, <&cru RGMII_MODE_CLK>;
    pinctrl-names = "default";
    pinctrl-0 = <&rgmiim0_miim &rgmiim0_bus2 &rgmiim0_bus4>;
    tx_delay = <0x2a>;
    rx_delay = <0x1a>;
    phy-handle = <&phy>;
    status = "okay";
};
&mdio {
    phy: phy@0 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x0>;
    };
};
```

```
&gmac {
    phy-mode = "rgmii";
   clock_in_out = "input";
    snps,reset-gpio = <&gpio3 RK_PAO GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    /* Reset time is 20ms, 100ms for rtl8211f */
    snps, reset-delays-us = <0 20000 100000>;
  assigned-clocks = <&cru CLK_GMAC_SRC>, <&cru CLK_GMAC_TX_RX>, <&cru
CLK_GMAC_ETHERNET_OUT>;
    assigned-clock-parents = <&cru CLK_GMAC_SRC_M1>, <&cru RGMII_MODE_CLK>;
    assigned-clock-rates = <125000000>, <0>, <25000000>;
    pinctrl-names = "default";
   pinctrl-0 = <&rgmiim1_miim &rgmiim1_bus2 &rgmiim1_bus4>;
    tx_delay = <0x2a>;
    rx_delay = <0x1a>;
    phy-handle = <&phy>;
    status = "okay";
};
&mdio {
    phy: phy@0 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x0>;
    };
};
```

### **RMII Clock Output**

```
&gmac {
                   phy-mode = "rmii";
          clock_in_out = "output";
                   snps,reset-gpio = <&gpio3 RK_PC5 GPIO_ACTIVE_LOW>;
                   snps,reset-active-low;
                   snps, reset-delays-us = <0 50000 50000>;
                  assigned-clocks = <%cru CLK_GMAC_SRC_M0>, <%cru CLK_GMAC_SRC>, <%cru
CLK_GMAC_TX_RX>;
                  assigned-clock-rates = <0>, <50000000>;
                   assigned-clock-parents = <a href="mailto:clk_gmac_rgmii_m0">assigned-clock-parents = <a href="mailto:clk_gmac_rgmii_m0">assigned-clcck-parents = <a href="mailto:clk_gmac_rgmii_m0">assigned-clcck-parents = <a href="mailto:clk_gmac_smii_m0">assigned-clcck-parents = <a href="mailto:clk_gmac_smii_m0">assigned-clcck-parents = <a href="mailto:clk_gmac_smii_m0">assigned-clcck-parents = <a href="mailto:clk_gmac_smii_m0">assigned-clk_gmac_smii_m0</a> and clk_gmac_smii_m0</a> and clk_gmac_smii_m0
 <&cru RMII_MODE_CLK>;
                  pinctrl-names = "default";
                   pinctrl-0 = <&rmiim0_miim &rgmiim0_rxer &rmiim0_bus2 &rgmiim0_mclkinout>;
                   phy-handle = <&phy>;
                   status = "okay";
};
```

```
&mdio {
    phy: phy@0 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x0>;
    };
};
```

```
&gmac {
   phy-mode = "rmii";
+ clock_in_out = "output";
    snps,reset-gpio = <&gpio3 RK_PC5 GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    snps, reset-delays-us = <0 50000 50000>;
+ assigned-clocks = <&cru CLK_GMAC_SRC_M1>, <&cru CLK_GMAC_SRC>, <&cru
CLK_GMAC_TX_RX>;
   assigned-clock-rates = <0>, <50000000>;
   assigned-clock-parents = <&cru CLK_GMAC_RGMII_M1>, <&cru CLK_GMAC_SRC_M1>,
<&cru RMII_MODE_CLK>;
  pinctrl-names = "default";
+ pinctrl-0 = <&rmiim1_miim &rgmiim1_rxer &rmiim10_bus2 &rgmiim1_mclkinout>;
    phy-handle = <&phy>;
   status = "okay";
};
&mdio {
    phy: phy@0 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x0>;
   };
};
```

## **RMII Clock Input**

```
+&gmac_clkin_m0 {
+    clock-frequency = <50000000>;
+};

&gmac {
+    phy-mode = "rmii";
+    clock_in_out = "input";

    snps,reset-gpio = <&gpio3 RK_PC5 GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    snps,reset-delays-us = <0 50000 50000>;

+    assigned-clocks = <&cru CLK_GMAC_RGMII_MO>, <&cru CLK_GMAC_SRC_MO>, <&cru CLK_GMAC_SRC>, <&cru CLK_GMAC_TX_RX>;
```

```
+ assigned-clock-rates = <0>, <0>, <500000000>;
+ assigned-clock-parents = <&gmac_clkin_m0>, <&cru CLK_GMAC_RGMII_M0>, <&cru CLK_GMAC_SRC_M0>, <&cru RMII_MODE_CLK>;

+ pinctrl-names = "default";
+ pinctrl-0 = <&rmiim0_miim &rgmiim0_rxer &rmiim0_bus2
&rgmiim0_mclkinout_level0>;

phy-handle = <&phy>;
status = "okay";
};

&mdio {
    phy: phy@0 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x0>;
    };
};
```

```
+&gmac_clkin_m1 {
+ clock-frequency = <50000000>;
+};
&gmac {
   phy-mode = "rmii";
+ clock_in_out = "input";
    snps,reset-gpio = <&gpio3 RK_PC5 GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    snps, reset-delays-us = <0 50000 50000>;
+ assigned-clocks = <%cru CLK_GMAC_RGMII_M1>, <%cru CLK_GMAC_SRC_M1>, <%cru
CLK_GMAC_SRC>, <&cru CLK_GMAC_TX_RX>;
    assigned-clock-rates = <0>, <0>, <50000000>;
    assigned-clock-parents = <&gmac_clkin_m1>,<&cru CLK_GMAC_RGMII_M1>, <&cru
CLK_GMAC_SRC_M1>, <&cru RMII_MODE_CLK>;
    pinctrl-names = "default";
    pinctrl-0 = <&rmiim1_miim &rgmiim1_rxer &rmiim1_bus2</pre>
&rgmiim1_mclkinout_level0>;
    phy-handle = <&phy>;
    status = "okay";
};
&mdio {
    phy: phy@0 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x0>;
    };
};
```