uboot 和內(nèi)核里 phy 的初始化,以及內(nèi)核里的雙網(wǎng)絡(luò)配置及 phy 的初始化。
本文以盈鵬飛嵌入式的CoM-335x(基于AM335x)核心板及網(wǎng)絡(luò)芯片LAN8720 為例,說明修改步驟。 LAN8720 是 RMII 接口的 10/100M 以太網(wǎng) phy 芯片,其與 CoM-335x 的硬件連接和設(shè)計(jì)請參考《CoM-335X 底板設(shè)計(jì)手冊》。以下內(nèi)容為具體步驟說明。
CoM-335x核心板:()
一、u-boot里面如何修改phy
1.引腳初始化
打開 board/eac/com335x/mux.c 文件,增加以下內(nèi)容:
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)函數(shù)中,做以下修改:
void enable_board_pin_mux(void)
{
......
// configure_module_pin_mux(rgmii1_pin_mux);
configure_module_pin_mux(rmii1_pin_mux);
......
}
2.驅(qū)動(dòng)初始化
打開 board/eac/com335x/board.c,在 cpsw_slaves[]結(jié)構(gòu)體中,修改 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)函數(shù)中,修改 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 信號(hào)由 phy 芯片提供而不是由
CPU 提供,該參數(shù)由硬件設(shè)計(jì)決定。在底板設(shè)計(jì)指導(dǎo)手冊中,使用的是 LAN8720 輸出的 rmii_refclk 信號(hào),
因此需要添加改參數(shù),否則會(huì)導(dǎo)致 rmii_refclk 信號(hào)出現(xiàn)問題;如果硬件設(shè)計(jì)為由 CPU 提供的話,則無需
添加該參數(shù)。
另外,要確保 include/configs/com335x.h 文件中有如下宏定義;
#define CONFIG_PHY_SMSC
該定義為 phy 芯片驅(qū)動(dòng)配置,文件中默認(rèn)有定義,無需修改。至此, uboot 修改完畢,重新編譯即可。
二、kernel里如何修改phy(單網(wǎng)絡(luò),rmii1接口)
1.內(nèi)核配置
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.引腳初始化
打開板級(jí)初始化文件 arch/arm/mach-omap2/board-com335x.c,增加以下內(nèi)容:
/* 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},
};
注意:引腳不要被其它功能復(fù)用!
3.驅(qū)動(dòng)初始化
在 board-com335x.c 文件的 com335x_eth_init(void)函數(shù)中,做以下修改:
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)里的第一個(gè)參數(shù)為指定 RMII 模
式,第二個(gè)參數(shù)為 rmii1 接口上的 phy_addr,第三個(gè)參數(shù)為 rmii2 接口上的 phy_addr。修改完成后,保存文
件。
在上一節(jié)提到,我們的設(shè)計(jì)中, rmii_refclk 信號(hào)由 phy 芯片提供,因此需要使能 rmii1_refclk 為輸入,
打開 arch/arm/mach-omap2/devices.c 文件,在 am33xx_cpsw_init 函數(shù)中,增加以下內(nèi)容:
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));
......
}
修改完成后,保存退出。重新編譯系統(tǒng)即可。
三、kernel里如何修改phy(雙網(wǎng)絡(luò),rmii1、rmii2接口)
1.內(nèi)核配置
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.引腳初始化
打開板級(jí)初始化文件 arch/arm/mach-omap2/board-com335x.c,增加以下內(nèi)容:
/* 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},
};
注意:引腳不要被其它功能復(fù)用!另外,根據(jù)底板設(shè)計(jì)手冊,在 rmii2 接口中,由于 rmii2_rxerr 腳已
經(jīng)被 gpmc 使用,因此 rmii2_rxerr 未與 LAN8720 連接,經(jīng)測試,未發(fā)現(xiàn)此情況下對網(wǎng)絡(luò)有影響。
3.驅(qū)動(dòng)初始化
在 board-com335x.c 文件的 com335x_eth_init(void)函數(shù)中,做以下修改:
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);
}
注:詳細(xì)說明請參考上一節(jié)。修改完成后,保存文件。
使能 rmii1_refclk、 rmii2_refclk 為輸入(參考上一節(jié)),打開 arch/arm/mach-omap2/devices.c 文件,在
am33xx_cpsw_init 函數(shù)中,增加以下內(nèi)容:
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));
......
}
修改完成后,保存退出。重新編譯系統(tǒng)即可。
4.雙網(wǎng)絡(luò)使用說明
將上述步驟編譯的內(nèi)核燒錄到 COM335X,系統(tǒng)啟動(dòng)后,在終端輸入 ifconfig -a 命令可以查看到 eth0
和 eth1 兩個(gè)設(shè)備。如需同時(shí)使用 eth0 和 eth1,必須注意兩者不能在同一網(wǎng)段!
-
嵌入式
+關(guān)注
關(guān)注
5082文章
19104瀏覽量
304800 -
以太網(wǎng)
+關(guān)注
關(guān)注
40文章
5419瀏覽量
171598 -
LAN8720
+關(guān)注
關(guān)注
0文章
4瀏覽量
11043
發(fā)布評(píng)論請先 登錄
相關(guān)推薦
評(píng)論