色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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,必須注意兩者不能在同一網段!

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 嵌入式
    +關注

    關注

    5082

    文章

    19104

    瀏覽量

    304829
  • 以太網
    +關注

    關注

    40

    文章

    5419

    瀏覽量

    171605
  • LAN8720
    +關注

    關注

    0

    文章

    4

    瀏覽量

    11043
收藏 人收藏

    評論

    相關推薦

    OMAP5912多媒體處理器初始化參考指南

    電子發燒友網站提供《OMAP5912多媒體處理器初始化參考指南.pdf》資料免費下載
    發表于 12-17 16:20 ?0次下載
    OMAP5912多媒體處理器<b class='flag-5'>初始化</b>參考指南

    STM32F407 MCU使用SD NAND?不斷電初始化失效解決方案

    STM32F407微控制器單元(MCU)與SD NAND的結合提供了強大的存儲解決方案。然而,不斷電初始化失效問題可能會導致系統穩定性和數據完整性受損。我們將STM32F407與SD NAND集成時可能遇到的初始化問題,并提供專業的解決方案。
    的頭像 發表于 12-11 10:51 ?310次閱讀
    STM32F407 MCU使用SD NAND?不斷電<b class='flag-5'>初始化</b>失效解決方案

    segger編譯器初始化問題

    的圖; 2.第二張圖是該變量在文件中的所有操作,第一行是初始化,該行代碼在初始化部分最后一個,執行完就是主循環了; 3.第2,3行也是對變量的賦值,在主循環中; 4.第4行已注釋; 5.第6行是對變量
    發表于 12-09 18:06

    請問LMX2595配置時如何進行初始化

    您好,查閱手冊說初始化按照1.r0的rest置為1;2.r0的reset置為1;3.按照寄存器表格配置寄存器;4.fcal_en置為1的順序來初始化。請問在第三步中,按照寄存器表配置
    發表于 11-12 06:51

    基于旋轉平移解耦框架的視覺慣性初始化方法

    精確和魯棒的初始化對于視覺慣性里程計(VIO)至關重要,因為不良的初始化會嚴重降低姿態精度。
    的頭像 發表于 11-01 10:16 ?324次閱讀
    基于旋轉平移解耦框架的視覺慣性<b class='flag-5'>初始化</b>方法

    TMS320C6000 McBSP初始化

    電子發燒友網站提供《TMS320C6000 McBSP初始化.pdf》資料免費下載
    發表于 10-26 10:10 ?0次下載
    TMS320C6000 McBSP<b class='flag-5'>初始化</b>

    如何在i.MX RT微控制器上初始化LWIP協議棧

    在i.MX RT微控制器上初始化LWIP協議棧是一個復雜但有趣的過程,它涉及多個步驟和關鍵組件的配置.
    的頭像 發表于 10-12 11:48 ?356次閱讀
    如何在i.MX RT微控制器上<b class='flag-5'>初始化</b>LWIP協議棧

    瀚海微SD NAND應用之SD協議存儲功能描述2 初始化命令

    初始化和識別過程: 總線激活后,主機啟動卡初始化和識別過程。 初始化過程從SD SEND OP COND (ACMD41)開始,通過設置其操作條件和OCR中的HCS位。HCS (Host
    的頭像 發表于 07-22 10:54 ?355次閱讀
    瀚海微SD NAND應用之SD協議存儲功能描述2 <b class='flag-5'>初始化</b>命令

    VSCodeESP-IDF初始化報錯和亂碼怎么解決?

    在VSCode配置了espidf的開發環境,測試前幾個官方example的時候都能正常運行。但是自從調試了cmake例程以后,打開vscode、espidf在初始化之后總會報錯(如下),并且跳轉到esp-idf的安裝界面。有時
    發表于 06-11 06:48

    初始化IO口為外部中斷線的時候,最先初始化的會被后初始化的覆蓋掉為什么?

    初始化IO口為外部中斷線的時候,比如GPIOA6與GPIOB6先后初始化為外部中斷,最先初始化的會被后初始化的覆蓋掉,不知道是為什么?
    發表于 05-14 08:26

    使用STM32CubeIDE初始化STM32407的SPI1(PB3)初始化失敗的原因?怎么解決?

    使用STM32CubeIDE初始化STM32407的SPI1(PB3)初始化失敗,有人知道原因嗎?
    發表于 03-25 07:50

    字符型、指針型等變量等該如何初始化

     對于數值類型的變量往往初始化為0,但對于其他類型的變量,如字符型、指針型等變量等該如何初始化呢?
    的頭像 發表于 03-18 11:02 ?1434次閱讀

    MCU單片機GPIO初始化該按什么順序配置?為什么初始化時有電平跳變?

    GPIO初始化時有時鐘配置、模式配置、輸出配置、復用配置,那么在編寫初始化代碼時,到底該按什么順
    的頭像 發表于 02-22 11:07 ?1528次閱讀
    MCU單片機GPIO<b class='flag-5'>初始化</b>該按什么順序<b class='flag-5'>配置</b>?為什么<b class='flag-5'>初始化</b>時有電平跳變?

    串口初始化一般是初始化哪些內容

    串口初始化是指在使用串口進行數據通信之前,對串口進行一系列的設置和配置,以確保串口能夠正常工作。串口初始化的內容主要包括以下幾個方面: 串口硬件設置:首先,需要確定要使用的串口是哪一個,通常計算機
    的頭像 發表于 01-04 09:39 ?3155次閱讀

    labview運行后如何初始化

    LabVIEW是一款強大的圖形編程軟件,在運行之前通常需要進行一些初始化操作。本文將詳細介紹LabVIEW運行前的初始化過程,并提供了一些常用的初始化方法。 創建新項目: 在LabV
    的頭像 發表于 12-28 17:24 ?2627次閱讀
    主站蜘蛛池模板: 九九精彩视频在线观看视频| 无颜之月5集全免费看无删除| 一级做a爰片久久毛片免费| 国产精品高潮呻吟AV久久96| 青青娱乐网| 99久久精品国内| 蜜臀AV色欲A片无码一区| 亚洲另类中文字幕| 国产在线精彩亚洲久久| 无码欧美XXXXX在线观看裸| 丰满少妇69激懒啪啪无码| 欧美一夜爽爽爽爽爽爽| 99热久久这里只精品国产WWW| 老司机试看午夜| 最近中文字幕完整版免费高清| 久久久久激情免费观看| 永久adc视频年龄确认| 久久a在线视频观看| 一本色道久久综合亚洲精品加| 精品久久久麻豆国产精品| 亚洲欧洲日韩天堂无吗| 江苏电台在线收听| 亚洲无吗在线视频| 久久er99热精品一区二区| 亚洲无吗在线视频| 久久人妻少妇嫩草AV无码| 中国人泡妞xxxxxxxx19| 凌馨baby| 99香蕉视频| 全黄h全肉短篇禁乱np| 成人精品视频在线观看| 日韩一区二区三区视频在线观看| 被免费网站在线视频| 色小姐电影qvod播放| 国产成人无码区免费内射一片色欲 | a在线观看免费视频| 暖暖视频免费高清在线观看 视频| 99国产在线观看| 青年医生插曲| 国产AV电影区二区三区曰曰骚网| 玩高中女同桌肉色短丝袜脚文|