Linux Device Tree Config and External ADIN1300 PHY

取消
显示结果 
显示  仅  | 搜索替代 
您的意思是: 

Linux Device Tree Config and External ADIN1300 PHY

407 次查看
tractor-rover
Contributor I

Hi,

I am attempting to configure the device tree to get an external ADIN1300 phy managed by a MDIO on our custom hardware board working. The SOM is the iMX8MP and the carrier board is our in-house design. The link LEDs for both Ethernets light up but no connection is established with the test laptop. FULL DISCLOSURE I am relatively new to the Linux Device Tree stuff.

 

This is what the relevant parts of the device tree look like: 

reg_fec_phy: regulator-fec-phy {
compatible = "regulator-fixed";
regulator-name = "fec-phy";
regulator-min-microvolt = <1800000>;
regulator-max-microvolt = <1800000>;
regulator-enable-ramp-delay = <20000>;
gpios = <&gpio_exp1 16 GPIO_ACTIVE_LOW>; // EXP_MDIO_EN
regulator-always-on;
regulator-boot-on;
};

vddio1: vddio-regulator {
compatible = "regulator-fixed";
regulator-name = "vddio1";
regulator-min-microvolt = <1800000>;
regulator-max-microvolt = <1800000>;
regulator-always-on;
regulator-boot-on;
};

&fec {
compatible = "fsl,imx8mp-fec", "fsl,imx8mq-fec", "fsl,imx6sx-fec";
pinctrl-names = "default";
pinctrl-0 = <&pinctrl_fec>;
phy-mode = "rgmii";
phy-handle = <&ethphy1>;
phy-supply = <&reg_fec_phy>;
status = "okay";

mdio {
#address-cells = <1>;
#size-cells = <0>;

ethphy1: ethernet-phy@5 {
compatible = "adi,adin1300", "ethernet-phy-ieee802.3-c22";
reg = <5>;
eee-broken-100tx;
eee-broken-1000t;
reset-gpios = <&gpio_exp1 15 GPIO_ACTIVE_LOW>; // EXP_ENET1_RESET_B
reset-assert-us = <10000>;
reset-deassert-us = <20000>;
vddio-supply = <&vddio1>;
};
};
};

pinctrl_fec: fecgrp {
fsl,pins = <
MX8MP_IOMUXC_SAI1_RXD2__ENET1_MDC 0x140
MX8MP_IOMUXC_SAI1_RXD3__ENET1_MDIO 0x140
MX8MP_IOMUXC_SAI1_RXD4__ENET1_RGMII_RD0 0x91 // SCHMITT, FAST
MX8MP_IOMUXC_SAI1_RXD5__ENET1_RGMII_RD1 0x91 // SCHMITT, FAST
MX8MP_IOMUXC_SAI1_RXD6__ENET1_RGMII_RD2 0x91
MX8MP_IOMUXC_SAI1_RXD7__ENET1_RGMII_RD3 0x91
MX8MP_IOMUXC_SAI1_TXC__ENET1_RGMII_RXC 0x91
MX8MP_IOMUXC_SAI1_TXFS__ENET1_RGMII_RX_CTL 0x91
MX8MP_IOMUXC_SAI1_TXD0__ENET1_RGMII_TD0 0x1f
MX8MP_IOMUXC_SAI1_TXD1__ENET1_RGMII_TD1 0x1f
MX8MP_IOMUXC_SAI1_TXD2__ENET1_RGMII_TD2 0x1f
MX8MP_IOMUXC_SAI1_TXD3__ENET1_RGMII_TD3 0x1f
MX8MP_IOMUXC_SAI1_TXD4__ENET1_RGMII_TX_CTL 0x1f
MX8MP_IOMUXC_SAI1_TXD5__ENET1_RGMII_TXC 0x1f
MX8MP_IOMUXC_SAI1_MCLK__ENET1_TX_CLK 0x4000001f
>;
};

 

Any assistance is appreciated.

标记 (1)
0 项奖励
回复
1 回复

370 次查看
Zhiming_Liu
NXP TechSupport
NXP TechSupport

Hi @tractor-rover 

Please refer 3.3.2 RGMII mode in below application note about default RGMII setting.

Alternatively, you can refer to the settings in other device tree(arch/arm64/boot/dts/freescale/imx8mn-var-som.dtsi)

ENET1_TX_CLK is for RMII mode, so you should remove it if you are using RGMII. For other settings, please ensure that they meet the hardware requirements, such as reset behavior, etc.


Best Regards,
Zhiming

0 项奖励
回复
%3CLINGO-SUB%20id%3D%22lingo-sub-2343255%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3ELinux%20%E8%AE%BE%E5%A4%87%E6%A0%91%E9%85%8D%E7%BD%AE%E5%92%8C%E5%A4%96%E9%83%A8%20ADIN1300%20PHY%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2343255%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E6%82%A8%E5%A5%BD%EF%BC%8C%3C%2FP%3E%3CP%3E%E6%88%91%E6%AD%A3%E5%9C%A8%E5%B0%9D%E8%AF%95%E9%85%8D%E7%BD%AE%E8%AE%BE%E5%A4%87%E6%A0%91%EF%BC%8C%E8%AE%A9%E6%88%91%E4%BB%AC%E7%9A%84%E8%87%AA%E5%AE%9A%E4%B9%89%E7%A1%AC%E4%BB%B6%E6%9D%BF%E4%B8%8A%E7%94%B1%20MDIO%20%E7%AE%A1%E7%90%86%E7%9A%84%E5%A4%96%E9%83%A8%20ADIN1300%20phy%20%E6%AD%A3%E5%B8%B8%E5%B7%A5%E4%BD%9C%E3%80%82SOM%20%E6%98%AF%20imx8MP%EF%BC%8C%E8%BD%BD%E6%9D%BF%E6%98%AF%E6%88%91%E4%BB%AC%E5%86%85%E9%83%A8%E8%AE%BE%E8%AE%A1%E7%9A%84%E3%80%82%E4%B8%A4%E4%B8%AA%E4%BB%A5%E5%A4%AA%E7%BD%91%E7%9A%84%20LED%20%E9%93%BE%E6%8E%A5%E6%8C%87%E7%A4%BA%E7%81%AF%E9%83%BD%E4%BA%AE%E8%B5%B7%EF%BC%8C%E4%BD%86%E6%97%A0%E6%B3%95%E4%B8%8E%E6%B5%8B%E8%AF%95%E7%AC%94%E8%AE%B0%E6%9C%AC%E7%94%B5%E8%84%91%E5%BB%BA%E7%AB%8B%E8%BF%9E%E6%8E%A5%E3%80%82%E5%85%A8%E9%9D%A2%E6%8A%AB%E9%9C%B2%E6%88%91%E5%AF%B9%20Linux%20%E8%AE%BE%E5%A4%87%E6%A0%91%E7%9A%84%E5%86%85%E5%AE%B9%E6%AF%94%E8%BE%83%E9%99%8C%E7%94%9F%E3%80%82%3C%2FP%3E%3CBR%20%2F%3E%3CP%3E%E8%AE%BE%E5%A4%87%E6%A0%91%E7%9A%84%E7%9B%B8%E5%85%B3%E9%83%A8%E5%88%86%E5%A6%82%E4%B8%8B%E6%89%80%E7%A4%BA%EF%BC%9A%3C%2FP%3E%3CP%3Ereg_fec_phy%EF%BC%9Aregulator-fec-phy%20%7B%3CBR%20%2F%3E%20%E5%85%BC%E5%AE%B9%20%3D%20%22%3CBR%20%2F%3E%20%E8%B0%83%E8%8A%82%E5%99%A8%E5%B7%B2%E4%BF%AE%E5%A4%8D%20%22%EF%BC%9B%E8%B0%83%E8%8A%82%E5%99%A8%20%E5%90%8D%E7%A7%B0%20%3D%20%22%20fec-phy%20%22%EF%BC%9B%E8%B0%83%E8%8A%82%E5%99%A8%E6%9C%80%E5%B0%8F%E5%BE%AE%E4%BC%8F%3CBR%20%2F%3E%20%3D%26lt%3B1800000%26gt%3B%20%EF%BC%9B%E8%B0%83%E8%8A%82%E5%99%A8%E6%9C%80%E5%A4%A7%E5%BE%AE%E4%BC%8F%3CBR%20%2F%3E%20%3D%26lt%3B1800000%26gt%3B%20%EF%BC%9B%E8%B0%83%E8%8A%82%E5%99%A8%E5%90%AF%E7%94%A8%E6%96%9C%E5%9D%A1%E5%BB%B6%E8%BF%9F%3CBR%20%2F%3E%20%3D%26lt%3B20000%26gt%3B%20%26lt%3B%2020000%20%26gt%3B%3B%20gpios%20%3D%20%26lt%3B%20%26amp%3B%20gpio_exp1%2016%20GPIO_ACTIVE_LOW%20%26gt%3B%3B%2F%2FEXP_MDIO_EN%3CBR%20%2F%3E%3CBR%20%2F%3E%20regulator-always-On%3CBR%20%2F%3E%20%3CBR%20%2F%3Eregulator-always-on%EF%BC%9B%E8%B0%83%E8%8A%82%E5%99%A8%E5%90%AF%E5%8A%A8%E5%BC%80%E6%9C%BA%EF%BC%9B%7D%3B%3C%2FP%3E%3CP%3Evddio1%EF%BC%9Avdio-regulator%20%7B%3CBR%20%2F%3E%20%E5%85%BC%E5%AE%B9%20%3D%20%22%20%E7%A8%B3%E5%8E%8B%E5%99%A8%E5%B7%B2%E4%BF%AE%E5%A4%8D%20%22%EF%BC%9B%E8%B0%83%E8%8A%82%E5%99%A8%3CBR%20%2F%3E%20%E5%90%8D%E7%A7%B0%20%3D%20%22%20vdio1%20%22%EF%BC%9B%E8%B0%83%E8%8A%82%E5%99%A8%E6%9C%80%E5%B0%8F%E5%BE%AE%E4%BC%8F%3CBR%20%2F%3E%20%3D%26lt%3B1800000%26gt%3B%20%EF%BC%9B%E8%B0%83%E8%8A%82%E5%99%A8%E6%9C%80%E5%A4%A7%E5%BE%AE%E4%BC%8F%3CBR%20%2F%3E%20%3D%26lt%3B1800000%26gt%3B%20%EF%BC%9B%E7%A8%B3%E5%8E%8B%E5%99%A8%E6%B0%B8%E8%BF%9C%E5%BC%80%E5%90%AF%EF%BC%9B%3CBR%20%2F%3E%20%3CBR%20%2F%3E%3CBR%20%2F%3E%E8%B0%83%E8%8A%82%E5%99%A8%E5%90%AF%E5%8A%A8%EF%BC%9B%7D%EF%BC%9B%3C%2FP%3E%3CP%3E%26amp%3Bfec%20%7B%3CBR%20%2F%3Ecompatible%20%3D%22fsl%2Cimx8mp-fec%22%2C%22fsl%2Cimx8mq-fec%22%2C%22fsl%2Cimx6sx-fec%22%3B%3CBR%20%2F%3Epinctrl-names%20%3D%22default%22%3B%3CBR%20%2F%3Epinctrl-0%20%3D%26lt%3B%26amp%3B%20pinctrl_fec%26gt%3B%3B%3CBR%20%2F%3Ephy-mode%20%3D%22rgmii%22%3B%3CBR%20%2F%3Ephy-handle%20%3D%26lt%3B%26amp%3B%20ethphy1%26gt%3B%3B%3CBR%20%2F%3Ephy-supply%20%3D%26lt%3B%26amp%3B%20reg_fec_phy%26gt%3B%3B%3CBR%20%2F%3Estatus%20%3D%22okay%22%20%EF%BC%9B%3C%2FP%3E%3CP%3Emdio%20%7B%3CBR%20%2F%3E%23address-cells%20%3D%26lt%3B1%26gt%3B%3B%3CBR%20%2F%3E%23size-cells%20%3D%26lt%3B0%26gt%3B%20%EF%BC%9B%3C%2FP%3E%3CP%3Eethphy1%EF%BC%9Aethernet-phy%405%20%7B%3CBR%20%2F%3Ecompatible%20%3D%22adi%2Cadin1300%22%2C%22ethernet-phy-ieee802.3-c22%22%20%EF%BC%9B%3CBR%20%2F%3Ereg%20%3D%3B%26lt%3B5%26gt%3B%20%3CBR%20%2F%3Eeee-broken-100tx%3B%3CBR%20%2F%3E%20eee-broken-100%200t%3B%3CBR%20%2F%3E%20reset-gpios%20%3D%20%26lt%3B%20%26amp%3B%20gpio_exp1%2015%20GPIO_ACTIVE_LOW%20%26gt%3B%3B%2F%2FEXP_ENET1_RESET_B%3CBR%20%2F%3E%20reset-assert-us%20%3D%3B%26lt%3B10000%26gt%3B%20%3CBR%20%2F%3Ereset-deassert-us%20%3D%3B%26lt%3B20000%26gt%3B%20%3CBR%20%2F%3Evdio-supply%20%3D%20%26lt%3B%20%26amp%3B%20vdio1%20%26gt%3B%3B%7D%3B%7D%3B%3CBR%20%2F%3E%3CBR%20%2F%3E%3CBR%20%2F%3E%3C%2FP%3E%3CP%3Epinctrl_fec%EF%BC%9Afecgrp%20%7B%3CBR%20%2F%3Efsl%2Cpins%20%3D%26lt%3B%3CBR%20%2F%3E%20MX8MP_IOMUXC_SAI1_RXD2__ENET1_MDC%200x140%3CBR%20%2F%3EMX8MP_IOMUXC_SAI1_RXD3__ENET1_MDIO%200x140%3CBR%20%2F%3EMX8MP_IOMUXC_SAI1_RXD4__ENET1_RGMII_RD0%200x91%20%2F%2F%20SCHMITT%E3%80%81FAST%3CBR%20%2F%3EMX8MP_IOMUXC_SAI1_RXD5__ENET1_RGMII_RD1%200x91%20%2F%2F%20SCHMITT%E3%80%81FAST%3CBR%20%2F%3EMX8MP_IOMUXC_SAI1_RXD6__ENET1_RGMII_RD2%200x91%3CBR%20%2F%3EMX8MP_IOMUXC_SAI1_RXD7__ENET1_RGMII_RD3%200x91%3CBR%20%2F%3EMX8MP_IOMUXC_SAI1_TXC__ENET1_RGMII_RXC0x91%3CBR%20%2F%3EMX8MP_IOMUXC_SAI1_TXFS__ENET1_RGMII_RX_CTL%200x91%3CBR%20%2F%3EMX8MP_IOMUXC_SAI1_TXD0__ENET1_RGMII_TD0%200x1f%3CBR%20%2F%3EMX8MP_IOMUXC_SAI1_TXD1__ENET1_RGMII_TD10x1f%3CBR%20%2F%3EMX8MP_IOMUXC_SAI1_TXD2__ENET1_RGMII_TD2%200x1f%3CBR%20%2F%3EMX8MP_IOMUXC_SAI1_TXD3__ENET1_RGMII_TD3%200x1f%3CBR%20%2F%3EMX8MP_IOMUXC_SAI1_TXD4__ENET1_RGMII_TX_CTL0x1f%3CBR%20%2F%3EMX8MP_IOMUXC_SAI1_TXD5__ENET1_RGMII_TXC%200x1f%3CBR%20%2F%3EMX8MP_IOMUXC_SAI1_MCLK__ENET1_TX_CLK%200x4000001f%3CBR%20%2F%3E%26gt%3B%20%EF%BC%9B%3CBR%20%2F%3E%7D%3B%3C%2FP%3E%3CBR%20%2F%3E%3CP%3E%E5%B8%8C%E6%9C%9B%E5%BE%97%E5%88%B0%E4%BB%BB%E4%BD%95%E5%B8%AE%E5%8A%A9%E3%80%82%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2343457%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20Linux%20Device%20Tree%20Config%20and%20External%20ADIN1300%20PHY%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2343457%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E5%97%A8%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fuser%2Fviewprofilepage%2Fuser-id%2F261246%22%20target%3D%22_blank%22%3E%20%40tractor-rover%3C%2FA%3E%3CBR%20%2F%3E%3CBR%20%2F%3E%20%E8%AF%B7%E5%9C%A8%E4%B8%8B%E9%9D%A2%E7%9A%84%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Fpwmxy87654%2Fattachments%2Fpwmxy87654%2Fother%2F30470%2F1%2FAN14149%25EF%25BC%2588Ethernet%2520Controller%2520Configuration%2520on%2520i.MX%25208MP%2520and%2520i.MX%252093%2520Processors%25EF%25BC%2589.pdf%22%20target%3D%22_self%22%3E%20%E5%BA%94%E7%94%A8%E7%AC%94%E8%AE%B0%3C%2FA%3E%20%E4%B8%AD%E5%8F%82%E9%98%85%3CSTRONG%3E%203.3.2%20RGMII%20%E6%A8%A1%E5%BC%8F%3C%2FSTRONG%3E%20%E4%B8%AD%E6%9C%89%E5%85%B3%E9%BB%98%E8%AE%A4%20RGMII%20%E8%AE%BE%E7%BD%AE%E7%9A%84%E4%BF%A1%E6%81%AF%E3%80%82%3C%2FP%3E%0A%3CP%3E%E6%88%96%E8%80%85%EF%BC%8C%E4%BD%A0%E5%8F%AF%E4%BB%A5%E5%8F%82%E8%80%83%E5%85%B6%E4%BB%96%E8%AE%BE%E5%A4%87%E6%A0%91%E4%B8%AD%E7%9A%84%E8%AE%BE%E7%BD%AE%EF%BC%88arch%2Farm64%2Fboot%2Fdts%2Ffreescale%2Fimx8mn-var-som.dtsi%EF%BC%89%3C%2FP%3E%0A%3CP%3E%3CSPAN%3EENET1_TX_CLK%20%E7%94%A8%E4%BA%8E%20RMII%20%E6%A8%A1%E5%BC%8F%EF%BC%8C%E5%9B%A0%E6%AD%A4%E5%A6%82%E6%9E%9C%E4%BD%BF%E7%94%A8%20RGMII%EF%BC%8C%E5%88%99%E5%BA%94%E5%B0%86%E5%85%B6%E7%A7%BB%E9%99%A4%E3%80%82%E5%AF%B9%E4%BA%8E%E5%85%B6%E4%BB%96%E8%AE%BE%E7%BD%AE%EF%BC%8C%E8%AF%B7%E7%A1%AE%E4%BF%9D%E5%AE%83%E4%BB%AC%E7%AC%A6%E5%90%88%E7%A1%AC%E4%BB%B6%E8%A6%81%E6%B1%82%EF%BC%8C%E4%BE%8B%E5%A6%82%E9%87%8D%E7%BD%AE%E8%A1%8C%E4%B8%BA%E7%AD%89%E3%80%82%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%3E%3CBR%20%2F%3E%E8%87%B4%E6%95%AC%EF%BC%8C%3CBR%20%2F%3EZhiming%3C%2FP%3E%3C%2FLINGO-BODY%3E