zynq-7000系列基于zynq-zed的MAC->MAC 的实现(fixed-link)
来源:互联网 发布:js 闪动效果 编辑:程序博客网 时间:2024/05/23 15:44
zynq-7000系列基于zynq-zed的MAC->MAC 的实现(fixed-link)
作者:卢浩
时间:2017.2.20
转载请注明出处
前言:在项目实际使用中,我们有一些应用可以省去以太网phy芯片的,这里我就拿zynq-zed开发板做评估测试。
在VIVADO工程中去掉以太网的MDIO MDC配置,这样就无法读取PHY状态了,因为mac->mac这种连接就是无phy模式下的通讯。
修改内核drivers/net/ethernet/cadence/macb.c文件
@@ -383,27 +383,37 @@ static int macb_mii_probe(struct net_device *dev
int phy_irq; int ret; -phydev = phy_find_first(bp->mii_bus);-if (!phydev) {-netdev_err(dev, "no PHY found\n");-return -ENXIO;-}+if (bp->phy_node) {+phydev = of_phy_connect(dev, bp->phy_node,+&macb_handle_link_change, 0,+bp->phy_interface);+if (!phydev)+return -ENODEV;+} else {+phydev = phy_find_first(bp->mii_bus);+if (!phydev) {+netdev_err(dev, "no PHY found\n");+return -ENXIO;+} -pdata = dev_get_platdata(&bp->pdev->dev);-if (pdata && gpio_is_valid(pdata->phy_irq_pin)) {-ret = devm_gpio_request(&bp->pdev->dev, pdata->phy_irq_pin, "phy int");-if (!ret) {-phy_irq = gpio_to_irq(pdata->phy_irq_pin);-phydev->irq = (phy_irq < 0) ? PHY_POLL : phy_irq;+pdata = dev_get_platdata(&bp->pdev->dev);+if (pdata && gpio_is_valid(pdata->phy_irq_pin)) {+ret = devm_gpio_request(&bp->pdev->dev,+pdata->phy_irq_pin, "phy int");+if (!ret) {+phy_irq = gpio_to_irq(pdata->phy_irq_pin);+phydev->irq = (phy_irq < 0) ?+ PHY_POLL : phy_irq;+} }-} -/* attach the mac to the phy */-ret = phy_connect_direct(dev, phydev, &macb_handle_link_change,- bp->phy_interface);-if (ret) {-netdev_err(dev, "Could not attach to PHY\n");-return ret;+/* attach the mac to the phy */+ret = phy_connect_direct(dev, phydev, &macb_handle_link_change,+ bp->phy_interface);+if (ret) {+netdev_err(dev, "Could not attach to PHY\n");+return ret;+} } /* mask with MAC supported features */ @@ -3461,14 +3471,21 @@ static int macb_probe(struct platform_device *pdev) macb_get_hwaddr(bp); /* Power up the PHY if there is a GPIO reset */-phy_node = of_get_next_available_child(np, NULL);-if (phy_node) {+phy_node = of_parse_phandle(np, "phy-handle", 0);+if (!phy_node && of_phy_is_fixed_link(np)) {+err = of_phy_register_fixed_link(np);+if (err < 0) {+dev_err(&pdev->dev, "broken fixed-link specification");+goto failed_phy;+}+phy_node = of_node_get(np);+bp->phy_node = phy_node;+} else { int gpio = of_get_named_gpio(phy_node, "reset-gpios", 0); if (gpio_is_valid(gpio)) bp->reset_gpio = gpio_to_desc(gpio); gpiod_set_value(bp->reset_gpio, GPIOD_OUT_HIGH); }-of_node_put(phy_node); err = of_get_phy_mode(np); if (err < 0) { @@ -3518,6 +3535,9 @@ static int macb_probe(struct platform_device *pdev) err_out_free_netdev: free_netdev(dev); +failed_phy:+of_node_put(phy_node);+ err_disable_clocks: clk_disable_unprepare(tx_clk); clk_disable_unprepare(hclk); @@ -3547,6 +3567,7 @@ static int macb_remove(struct platform_device *pdev) clk_disable_unprepare(bp->tx_clk); clk_disable_unprepare(bp->hclk); clk_disable_unprepare(bp->pclk);+of_node_put(bp->phy_node); free_netdev(dev); }
修改内核drivers/net/ethernet/cadence/macb.h文件
@@ -906,6 +906,7 @@ struct macb {
struct mii_bus*mii_bus; struct phy_device*phy_dev;+struct device_node*phy_node; int link; int speed; int duplex;
在内核配置文件中添加如下配置:
CONFIG_ETHERNET
CONFIG_NET_CADENCE
CONFIG_MACB
CONFIG_NETDEVICES
CONFIG_HAS_DMA
CONFIG_NET_CADENCE
CONFIG_MACB
CONFIG_NETDEVICES
CONFIG_HAS_DMA
在dts文件增加如下修改:
修改前:
51 &gem0 {
52 status = "okay";
53 phy-mode = "rgmii-id";
54 phy-handle = <ðernet_phy>;
55
56 ethernet_phy: ethernet-phy@0 {
57 reg = <0>;
58 };
59 };
52 status = "okay";
53 phy-mode = "rgmii-id";
54 phy-handle = <ðernet_phy>;
55
56 ethernet_phy: ethernet-phy@0 {
57 reg = <0>;
58 };
59 };
修改后:
55 &gem0 {
56 status = "okay";
57 phy-mode = "rgmii-id";
58 fixed-link {
59 speed = <1000>;
60 full-duplex;
61 };
68 };
56 status = "okay";
57 phy-mode = "rgmii-id";
58 fixed-link {
59 speed = <1000>;
60 full-duplex;
61 };
68 };
重新编译内核和dts文件。
上电启动zynq-zed开发板,对网卡进行测试,此时网卡被强制到1000M FULL模式。PHYADDR是0-31.
0 0
- zynq-7000系列基于zynq-zed的MAC->MAC 的实现(fixed-link)
- zynq-7000系列基于zynq-zed的AMP模式的实现(linux+bare-metal)
- zynq-7000系列基于zynq-zed的linux-uboot的编译
- zynq-7000系列基于zynq-zed的ramdisk文件系统的修改
- zynq-7000系列基于zynq-zed的RGMII以太网控制器稳定性的问题
- zynq-7000系列基于zynq-zed的vivado初步设计之使用jtag->uart(MDM)
- zynq-7000系列基于zynq-zed双核ARM-Cortex-A9性能的评估测试(多核的使用)
- zynq-7000系列基于zynq-zed的vivado初步设计之linux下控制PL扩展的UART
- zynq-7000系列解决部分用户反映MAC地址每次启动都变化的问题
- 基于Zynq的光流法软硬件协同实现
- zynq-7000系列基于7015的linux下IIC->RTC的扩展使用(DS3232)
- zynq MAC地址设置
- zynq-7000系列基于zynq-7015的vivado初步设计之linux下控制PL扩展的光以太网(1000BASE-X)
- zynq zed device tree
- Xilinx ZYNQ 7000+Vivado2015.2系列(五)之ZYNQ的三种启动方式-JTAG、SD card、Flash
- zynq-7000系列基于7015的linux下 I2C-bus switch的扩展使用
- 基于Zynq的光流法软硬件协同设计与实现
- 基于Zynq的RT3070 WIFI + hostapd 实现Wifi和WifiAP
- JavaWeb 之 HttpServletResponse
- Angular2 ngFor, <template> 的用法
- VS2013集成Qt5.6.0
- BZOJ4753 [Jsoi2016]最佳团体
- Double 中的 NAN与INFINITY
- zynq-7000系列基于zynq-zed的MAC->MAC 的实现(fixed-link)
- android setTag (int key, Object tag)抛出IllegalArgumentException的问题
- 信息安全——对称密码体制
- cdoj 31 饭卡(card) 01背包
- 封装DOM查找元素方法
- 排序—选择排序
- 解决戴尔电脑win10无法正常关机现象
- selenium踩过的坑
- 奇数位上都是奇数或者偶数位上都是偶数