国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

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

    關注

    5198

    文章

    20442

    瀏覽量

    333966
  • 以太網
    +關注

    關注

    41

    文章

    5997

    瀏覽量

    180796
  • LAN8720
    +關注

    關注

    0

    文章

    4

    瀏覽量

    11330
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    PC強實時運動控制(一):C#的EtherCAT總線初始化(下)

    通過使用配置工具導出ZAR文件進行EtherCAT總線初始化
    的頭像 發表于 02-05 10:00 ?915次閱讀
    PC強實時運動控制(一):C#的EtherCAT總線<b class='flag-5'>初始化</b>(下)

    國民技術發布N32Cube芯片配置初始化代碼生成工具

    1月30日,國民技術(NSING)正式發布N32Cube——芯片配置初始化代碼生成工具,讓時鐘、引腳與外設的配置一目了然、輕松上手!
    的頭像 發表于 02-02 15:26 ?539次閱讀
    國民技術發布N32Cube芯片<b class='flag-5'>配置</b>與<b class='flag-5'>初始化</b>代碼生成工具

    MCU工程初始化,到底該不該交給工具?

    背景 工程初始化重復性高,但出錯成本大。工程師常問:交給工具是不是會丟失掌控? 工具可做的事 時鐘樹、引腳復用、外設配置 工程生成、代碼模板套用 參數校驗和約束檢查 工程師仍需做的事 特殊業務邏輯
    的頭像 發表于 01-29 10:18 ?140次閱讀
    MCU工程<b class='flag-5'>初始化</b>,到底該不該交給工具?

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

    在使用 LuatIO 進行嵌入式應用開發時,合理配置 GPIO 的復用功能是實現外設控制的前提。本文全面解析 GPIO 引腳由普通 IO 轉換為復用功能引腳的初始化流程,包括時鐘使能、模式選擇、速度
    的頭像 發表于 01-23 15:28 ?1099次閱讀
    掌握 LuatIO:GPIO 復用模式<b class='flag-5'>初始化</b><b class='flag-5'>配置</b>全流程解析

    EtherCAT總線初始化步驟

    的關鍵環節,涉及硬件配置、軟件設置以及網絡拓撲的建立。以下是EtherCAT總線初始化的詳細步驟,結合實際應用場景和常見問題解決方案,為工程師提供系統的操作指南。 1. 硬件連接與物
    的頭像 發表于 12-22 10:10 ?575次閱讀
    EtherCAT總線<b class='flag-5'>初始化</b>步驟

    瀚海微SD NAND TF卡硬件識別與初始化類問題探討

    在瀚海微SD NAND/TF卡的實際應用中,硬件識別與初始化是保障設備正常運行的首要環節,該環節出現故障會直接導致存儲卡無法投入使用,尤其在工業控制、車載設備等關鍵場景中,可能引發設備停機、數據丟失
    的頭像 發表于 11-18 09:58 ?515次閱讀
    瀚海微SD NAND  TF卡硬件識別與<b class='flag-5'>初始化</b>類問題探討

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

    串口初始化是Modbus RTU通信穩定可靠的關鍵起點。本篇深入剖析Air8000開發板串口參數配置初始化代碼實現及調試要點,結合master_rtu示例,分享實際操作中的經驗與避坑指南,讓您
    的頭像 發表于 10-28 16:33 ?1653次閱讀
    串口通信基石: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 ?933次閱讀
    GraniStudio:IO<b class='flag-5'>初始化</b>以及IO資源<b class='flag-5'>配置</b>例程

    GraniStudio:初始化例程

    1.文件運行 導入工程 雙擊運行桌面GraniStudio.exe。 通過引導界面導入初始化例程,點擊導入按鈕。 打開初始化例程所在路徑,選中初始化.gsp文件,點擊打開,完成導入。 2.功能
    的頭像 發表于 08-22 16:45 ?891次閱讀
    GraniStudio:<b class='flag-5'>初始化</b>例程

    MCU外設初始化:為什么參數配置必須優先于使能

    在微控制器領域,初始化參數配置階段至關重要。此時,雖無電源驅動,但微控制器在使能信號到來前,借初始化參數配置這一精細步驟,開啟關鍵準備進程。初始化
    的頭像 發表于 08-13 10:38 ?788次閱讀

    定義IO初始化結構體

    由上述IOPORT相關功能的枚舉類型我們可以知道,在對IOPORT模塊進行初始化時需要根據情況配置它們。因此我們定義一個IOPORT初始化的結構體類型IOPORT_Init_t,它的成員包括了由上述所有枚舉類型所聲明的變量,因此
    的頭像 發表于 07-16 16:26 ?1407次閱讀

    NVMe高速傳輸之擺脫XDMA設計之七:系統初始化

    直接采用PCIe實現NVMe功能,它的系統初始化流程主要分為鏈路訓練、PCIe 初始化和 NVMe 初始化, 分別實現 PCIe鏈路連接、 PCIe 設備枚舉配置和 NVMe 設備
    發表于 07-04 09:14

    IM系列設備過載故障:界面初始化終止的診斷流程與修復指南

    當 IM 系列設備出現過載故障導致界面初始化終止時,通常表現為設備啟動后操作界面無顯示、指示燈異常閃爍或初始化進度條停滯不前,同時可能伴隨設備運行異響或異常發熱。初步判斷時,可觀察設備是否有錯
    的頭像 發表于 06-28 09:47 ?1207次閱讀

    IM 系列設備過載保護機制下界面初始化中斷的底層邏輯與解決方案

    一、過載保護機制與界面初始化的關聯基礎 IM 系列設備的過載保護機制是保障設備安全運行的核心功能,其通過傳感器實時采集設備運行參數,如電流、電壓、溫度、系統資源占用率等。一旦這些參數超出預設閾值
    的頭像 發表于 06-27 09:58 ?540次閱讀