0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

uboot和内核里phy的初始化_内核里的双网络配置及phy的初始化

电子工程师 来源:网络整理 作者:工程师d 2018-05-17 08:19 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

uboot 和内核里 phy 的初始化,以及内核里的双网络配置及 phy 的初始化。

本文以盈鹏飞嵌入式的CoM-335x(基于AM335x)核心板及网络芯片LAN8720 为例,说明修改步骤。 LAN8720 是 RMII 接口的 10/100M 以太网 phy 芯片,其与 CoM-335x 的硬件连接和设计请参考《CoM-335X 底板设计手册》。以下内容为具体步骤说明。

CoM-335x核心板:()

一、u-boot里面如何修改phy

1.引脚初始化

打开 board/eac/com335x/mux.c 文件,增加以下内容:
static struct module_pin_mux rmii1_pin_mux[] = {
{OFFSET(mii1_crs), MODE(1) | RXACTIVE},/* RMII1_CRS */
{OFFSET(mii1_rxerr), MODE(1) | RXACTIVE}, /* RMII1_RXERR */
{OFFSET(mii1_txen), MODE(1)},
{OFFSET(mii1_txd1), MODE(1)},
{OFFSET(mii1_txd0), MODE(1)},/* RMII1_TXEN */
/* RMII1_TXD1 */
/* RMII1_TXD0 */
{OFFSET(mii1_rxd1), MODE(1) | RXACTIVE},
{OFFSET(mii1_rxd0), MODE(1) | RXACTIVE},/* RMII1_RXD1 */
/* RMII1_RXD0 */
{OFFSET(mdio_data), MODE(0) | RXACTIVE | PULLUP_EN}, /* MDIO_DATA */
{OFFSET(mdio_clk), MODE(0) | PULLUP_EN},/* MDIO_CLK */
{OFFSET(rmii1_refclk), MODE(0) | RXACTIVE}, /* RMII1_REFCLK */
{-1},
};
在 enable_board_pin_mux(void)函数中,做以下修改:
void enable_board_pin_mux(void)
{
......
// configure_module_pin_mux(rgmii1_pin_mux);
configure_module_pin_mux(rmii1_pin_mux);
......
}

2.驱动初始化

打开 board/eac/com335x/board.c,在 cpsw_slaves[]结构体中,修改 phy_addr(由 LAN8720 的硬件连接决
定,本文以 0 为例):
static struct cpsw_slave_data cpsw_slaves[] = {
{
.slave_reg_ofs = 0x208,
.sliver_reg_ofs = 0xd80,
.phy_addr = 0x00,
},
......
};
在 board_eth_init(bd_t *bis)函数中,修改 cpsw 的通信模式为 RMII:
int board_eth_init(bd_t *bis)
{
.......
writel((RMII_MODE_ENABLE | RMII_CHIPCKL_ENABLE), &cdev->miisel);
........
}
注: RMII_CHIPCKL_ENABLE 为 rmii_refclk 输入使能,即 rmii_refclk 信号由 phy 芯片提供而不是由
CPU 提供,该参数由硬件设计决定。在底板设计指导手册中,使用的是 LAN8720 输出的 rmii_refclk 信号,
因此需要添加改参数,否则会导致 rmii_refclk 信号出现问题;如果硬件设计为由 CPU 提供的话,则无需
添加该参数。
另外,要确保 include/configs/com335x.h 文件中有如下宏定义;
#define CONFIG_PHY_SMSC

该定义为 phy 芯片驱动配置,文件中默认有定义,无需修改。至此, uboot 修改完毕,重新编译即可。


二、kernel里如何修改phy(单网络,rmii1接口)

1.内核配置

Device Drivers --->

Network device support --->
Ethernet driver support --->
Texas Instruments (TI) devices
-*- TI DaVinci MDIO Support
-*- TI DaVinci CPDMA Support
<*> TI CPSW Switch Support
[] TI CPSW Switch as Dual EMAC
-*-PHY Device support and infrastructure --->
<*>Drivers for SMSC PHYs

2.引脚初始化

打开板级初始化文件 arch/arm/mach-omap2/board-com335x.c,增加以下内容:
/* Module pin mux for rmii1 */
static struct pinmux_config rmii1_pin_mux[] = {
{"mii1_crs.rmii1_crs_dv", OMAP_MUX_MODE1 | AM33XX_PIN_INPUT_PULLDOWN},
{"mii1_rxerr.mii1_rxerr", OMAP_MUX_MODE1 | AM33XX_PIN_INPUT_PULLDOWN},
{"mii1_txen.mii1_txen", OMAP_MUX_MODE1 | AM33XX_PIN_OUTPUT},
{"mii1_txd1.mii1_txd1", OMAP_MUX_MODE1 | AM33XX_PIN_OUTPUT},
{"mii1_txd0.mii1_txd0", OMAP_MUX_MODE1 | AM33XX_PIN_OUTPUT},
{"mii1_rxd1.mii1_rxd1", OMAP_MUX_MODE1 | AM33XX_PIN_INPUT_PULLDOWN},
{"mii1_rxd0.mii1_rxd0", OMAP_MUX_MODE1 | AM33XX_PIN_INPUT_PULLDOWN},
{"rmii1_refclk.rmii1_refclk", OMAP_MUX_MODE0 | AM33XX_PIN_INPUT_PULLDOWN},
{"mdio_data.mdio_data", OMAP_MUX_MODE0 | AM33XX_PIN_INPUT_PULLUP},
{"mdio_clk.mdio_clk", OMAP_MUX_MODE0 | AM33XX_PIN_OUTPUT_PULLUP},
{NULL, 0},
};
注意:引脚不要被其它功能复用!

3.驱动初始化

在 board-com335x.c 文件的 com335x_eth_init(void)函数中,做以下修改:
static void com335x_eth_init(void)
{
setup_pin_mux(rmii1_pin_mux);
am33xx_cpsw_init(AM33XX_CPSW_MODE_RMII, "0:00", NULL);
// int ret = phy_register_fixup_for_uid(COM335X_EVM_PHY_ID, COM335X_PHY_MASK,
am33xx_tx_clk_dly_phy_fixup);
}
注: am33xx_cpsw_init(AM33XX_CPSW_MODE_RMII, "0:00", NULL)里的第一个参数为指定 RMII 模
式,第二个参数为 rmii1 接口上的 phy_addr,第三个参数为 rmii2 接口上的 phy_addr。修改完成后,保存文
件。
在上一节提到,我们的设计中, rmii_refclk 信号由 phy 芯片提供,因此需要使能 rmii1_refclk 为输入,
打开 arch/arm/mach-omap2/devices.c 文件,在 am33xx_cpsw_init 函数中,增加以下内容:
int am33xx_cpsw_init(enum am33xx_cpsw_mac_mode mode, unsigned char *phy_id0,
unsigned char *phy_id1)
{
......
#define RMII1_IO_CLK_EN 1 << 6
gmii_sel |= (RMII1_IO_CLK_EN);
writel(gmii_sel, AM33XX_CTRL_REGADDR(AM33XX_CONTROL_GMII_SEL_OFFSET));
......
}
修改完成后,保存退出。重新编译系统即可。

三、kernel里如何修改phy(双网络,rmii1、rmii2接口)

1.内核配置

Device Drivers --->

Network device support --->
Ethernet driver support --->
Texas Instruments (TI) devices
-*- TI DaVinci MDIO Support
-*- TI DaVinci CPDMA Support
<*> TI CPSW Switch Support
TI CPSW Switch as Dual EMAC
-*-PHY Device support and infrastructure --->
<*>Drivers for SMSC PHYs

2.引脚初始化

打开板级初始化文件 arch/arm/mach-omap2/board-com335x.c,增加以下内容:
/* Module pin mux for rmii1 */
static struct pinmux_config rmii1_pin_mux[] = {
{"mii1_crs.rmii1_crs_dv", OMAP_MUX_MODE1 | AM33XX_PIN_INPUT_PULLDOWN},
{"mii1_rxerr.mii1_rxerr", OMAP_MUX_MODE1 | AM33XX_PIN_INPUT_PULLDOWN},
{"mii1_txen.mii1_txen", OMAP_MUX_MODE1 | AM33XX_PIN_OUTPUT},
{"mii1_txd1.mii1_txd1", OMAP_MUX_MODE1 | AM33XX_PIN_OUTPUT},
{"mii1_txd0.mii1_txd0", OMAP_MUX_MODE1 | AM33XX_PIN_OUTPUT},
{"mii1_rxd1.mii1_rxd1", OMAP_MUX_MODE1 | AM33XX_PIN_INPUT_PULLDOWN},
{"mii1_rxd0.mii1_rxd0", OMAP_MUX_MODE1 | AM33XX_PIN_INPUT_PULLDOWN},
{"rmii1_refclk.rmii1_refclk", OMAP_MUX_MODE0 | AM33XX_PIN_INPUT_PULLDOWN},
{"mdio_data.mdio_data", OMAP_MUX_MODE0 | AM33XX_PIN_INPUT_PULLUP},
{"mdio_clk.mdio_clk", OMAP_MUX_MODE0 | AM33XX_PIN_OUTPUT_PULLUP},
{NULL, 0},
};
/* Module pin mux for rmii2 */
static struct pinmux_config rmii2_pin_mux[] = {
{"gpmc_csn3.rmii2_crs_dv", OMAP_MUX_MODE2 | AM33XX_PIN_INPUT_PULLDOWN},
//{"gpmc_wpn.rmii2_rxerr", OMAP_MUX_MODE3 | AM33XX_PIN_INPUT_PULLDOWN},
{"gpmc_a0.rmii2_txen", OMAP_MUX_MODE3 | AM33XX_PIN_OUTPUT},
{"gpmc_a4.rmii2_txd1", OMAP_MUX_MODE3 | AM33XX_PIN_OUTPUT},
{"gpmc_a5.rmii2_txd0", OMAP_MUX_MODE3 | AM33XX_PIN_OUTPUT},
{"gpmc_a10.rmii2_rxd1", OMAP_MUX_MODE3 | AM33XX_PIN_INPUT_PULLDOWN},
{"gpmc_a11.rmii2_rxd0", OMAP_MUX_MODE3 | AM33XX_PIN_INPUT_PULLDOWN},
{"mii1_col.rmii2_refclk", OMAP_MUX_MODE1 | AM33XX_PIN_INPUT_PULLDOWN},
{"mdio_data.mdio_data", OMAP_MUX_MODE0 | AM33XX_PIN_INPUT_PULLUP},
{"mdio_clk.mdio_clk", OMAP_MUX_MODE0 | AM33XX_PIN_OUTPUT_PULLUP},
{NULL, 0},
};
注意:引脚不要被其它功能复用!另外,根据底板设计手册,在 rmii2 接口中,由于 rmii2_rxerr 脚已
经被 gpmc 使用,因此 rmii2_rxerr 未与 LAN8720 连接,经测试,未发现此情况下对网络有影响。

3.驱动初始化

在 board-com335x.c 文件的 com335x_eth_init(void)函数中,做以下修改:
static void com335x_eth_init(void)
{
setup_pin_mux(rmii1_pin_mux);
setup_pin_mux(rmii2_pin_mux);
am33xx_cpsw_init(AM33XX_CPSW_MODE_RMII, "0:00", "0:01");
// int ret = phy_register_fixup_for_uid(COM335X_EVM_PHY_ID, COM335X_PHY_MASK,
am33xx_tx_clk_dly_phy_fixup);
}
注:详细说明请参考上一节。修改完成后,保存文件。
使能 rmii1_refclk、 rmii2_refclk 为输入(参考上一节),打开 arch/arm/mach-omap2/devices.c 文件,在
am33xx_cpsw_init 函数中,增加以下内容:
int am33xx_cpsw_init(enum am33xx_cpsw_mac_mode mode, unsigned char *phy_id0,
unsigned char *phy_id1)
{
......
#define RMII1_IO_CLK_EN 1 << 6
#define RMII2_IO_CLK_EN 1 << 7
gmii_sel |= (RMII1_IO_CLK_EN);
writel(gmii_sel, AM33XX_CTRL_REGADDR(AM33XX_CONTROL_GMII_SEL_OFFSET));
......
}
修改完成后,保存退出。重新编译系统即可。

4.双网络使用说明

将上述步骤编译的内核烧录到 COM335X,系统启动后,在终端输入 ifconfig -a 命令可以查看到 eth0
和 eth1 两个设备。如需同时使用 eth0 和 eth1,必须注意两者不能在同一网段!

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 嵌入式
    +关注

    关注

    5210

    文章

    20692

    浏览量

    337586
  • 以太网
    +关注

    关注

    41

    文章

    6217

    浏览量

    181677
  • LAN8720
    +关注

    关注

    0

    文章

    4

    浏览量

    11345
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    嵌入式2---在单片机实现module_init机制

    嵌入式2---在单片机实现module_init机制 很多朋友在写单片机程序时,常会遇到这样的问题:所有模块的初始化函数(比如LED初始化、串口初始化、传感器
    的头像 发表于 05-04 11:24 7299次阅读
    嵌入式2---在单片机<b class='flag-5'>里</b>实现module_init机制

    MCXN947 EVK 无法初始化 PHY是怎么回事?如何处理?

    FRDM 上运行正常,但无法在 EVK 上运行。我在 EVK 上不断收到“无法初始化 PHY”。两块板似乎都有相同的 PHY 芯片 (lan8741A-EN)。有人能就这个问题提供一些指导,将不胜感激。
    发表于 04-17 08:39

    ELF-RV112B RKNN模型加载与运行时初始化

    ELF-RV112B RKNN模型加载与运行时初始化
    的头像 发表于 04-03 16:08 197次阅读
    ELF-RV112B RKNN模型加载与运行时<b class='flag-5'>初始化</b>

    PC强实时运动控制(一):C#的EtherCAT总线初始化(下)

    通过使用配置工具导出ZAR文件进行EtherCAT总线初始化
    的头像 发表于 02-05 10:00 2549次阅读
    PC强实时运动控制(一):C#的EtherCAT总线<b class='flag-5'>初始化</b>(下)

    国民技术发布N32Cube芯片配置初始化代码生成工具

    1月30日,国民技术(NSING)正式发布N32Cube——芯片配置初始化代码生成工具,让时钟、引脚与外设的配置一目了然、轻松上手!
    的头像 发表于 02-02 15:26 959次阅读
    国民技术发布N32Cube芯片<b class='flag-5'>配置</b>与<b class='flag-5'>初始化</b>代码生成工具

    MCU工程初始化,到底该不该交给工具?

    背景 工程初始化重复性高,但出错成本大。工程师常问:交给工具是不是会丢失掌控? 工具可做的事 时钟树、引脚复用、外设配置 工程生成、代码模板套用 参数校验和约束检查 工程师仍需做的事 特殊业务逻辑
    的头像 发表于 01-29 10:18 266次阅读
    MCU工程<b class='flag-5'>初始化</b>,到底该不该交给工具?

    掌握 LuatIO:GPIO 复用模式初始化配置全流程解析

    在使用 LuatIO 进行嵌入式应用开发时,合理配置 GPIO 的复用功能是实现外设控制的前提。本文全面解析 GPIO 引脚由普通 IO 转换为复用功能引脚的初始化流程,包括时钟使能、模式选择、速度
    的头像 发表于 01-23 15:28 2662次阅读
    掌握 LuatIO:GPIO 复用模式<b class='flag-5'>初始化</b><b class='flag-5'>配置</b>全流程解析

    EtherCAT总线初始化步骤

    的关键环节,涉及硬件配置、软件设置以及网络拓扑的建立。以下是EtherCAT总线初始化的详细步骤,结合实际应用场景和常见问题解决方案,为工程师提供系统的操作指南。 1. 硬件连接与物
    的头像 发表于 12-22 10:10 1045次阅读
    EtherCAT总线<b class='flag-5'>初始化</b>步骤

    串口通信基石:Air8000下Modbus RTU串口初始化详解!

    串口初始化是Modbus RTU通信稳定可靠的关键起点。本篇深入剖析Air8000开发板串口参数配置初始化代码实现及调试要点,结合master_rtu示例,分享实际操作中的经验与避坑指南,让您
    的头像 发表于 10-28 16:33 1806次阅读
    串口通信基石:Air8000下Modbus RTU串口<b class='flag-5'>初始化</b>详解!

    NVMe高速传输之摆脱XDMA设计33:初始化功能验证与分析

    本文主要交流NVMe设计思路,在本博客已给出相关博文五十多篇,希望对初学者有一定作用 初始化功能主要实现 PCIe 链路设备的初始化配置和 NVMe 初始化
    发表于 10-08 08:02

    GraniStudio:IO初始化以及IO资源配置例程

    1.文件运行 导入工程 双击运行桌面GraniStudio.exe。 通过引导界面导入IO初始化以及IO资源配置例程,点击导入按钮。 打开IO初始化以及IO资源配置例程所在路径,选中I
    的头像 发表于 08-22 17:34 1104次阅读
    GraniStudio:IO<b class='flag-5'>初始化</b>以及IO资源<b class='flag-5'>配置</b>例程

    GraniStudio:初始化例程

    1.文件运行 导入工程 双击运行桌面GraniStudio.exe。 通过引导界面导入初始化例程,点击导入按钮。 打开初始化例程所在路径,选中初始化.gsp文件,点击打开,完成导入。 2.功能
    的头像 发表于 08-22 16:45 1073次阅读
    GraniStudio:<b class='flag-5'>初始化</b>例程

    MCU外设初始化:为什么参数配置必须优先于使能

    在微控制器领域,初始化参数配置阶段至关重要。此时,虽无电源驱动,但微控制器在使能信号到来前,借初始化参数配置这一精细步骤,开启关键准备进程。初始化
    的头像 发表于 08-13 10:38 1006次阅读

    定义IO初始化结构体

    由上述IOPORT相关功能的枚举类型我们可以知道,在对IOPORT模块进行初始化时需要根据情况配置它们。因此我们定义一个IOPORT初始化的结构体类型IOPORT_Init_t,它的成员包括了由上述所有枚举类型所声明的变量,因此
    的头像 发表于 07-16 16:26 1610次阅读

    IM 系列设备过载保护机制下界面初始化中断的底层逻辑与解决方案

    一、过载保护机制与界面初始化的关联基础 IM 系列设备的过载保护机制是保障设备安全运行的核心功能,其通过传感器实时采集设备运行参数,如电流、电压、温度、系统资源占用率等。一旦这些参数超出预设阈值
    的头像 发表于 06-27 09:58 712次阅读