乙太網驅動的流程淺析(三)-ifconfig的-19錯誤最底層分析【原創】

来源:https://www.cnblogs.com/sky-heaven/archive/2019/11/27/11941884.html
-Advertisement-
Play Games

乙太網驅動流程淺析(三) ifconfig的 19錯誤最底層分析 Author:張昺華 Email:[email protected] Time:2019年3月23日星期六 此文也在我的個人公眾號以及《Linux內核之旅》上有發表: "乙太網驅動流程淺析(三) ifconfig的 19錯誤最底層分析" ...


乙太網驅動流程淺析(三)-ifconfig的-19錯誤最底層分析

Author:張昺華
Email:[email protected]
Time:2019年3月23日星期六

此文也在我的個人公眾號以及《Linux內核之旅》上有發表:乙太網驅動流程淺析(三)-ifconfig的-19錯誤最底層分析

很喜歡一群人在研究技術,一起做有意思的東西,一起分享技術帶給我們的快樂,也希望中國有更多的人熱愛技術,喜歡一起研究、分享技術,然後可以一起用我們的技術來做一些好玩的東西,可以為這個社會創造一些東西來改善人們的生活。

如下是本人調試過程中的一點經驗分享,乙太網驅動架構畢竟涉及的東西太多,如下僅僅是針對載入流程和圍繞這個問題產生的分析過程和驅動載入流程部分,並不涉及乙太網協議層的數據流程分析。

【硬體環境】 Imx6ul

【Linux kernel版本】 Linux4.1.15

【乙太網phy】 Realtek8201f

1. 乙太網流程分析跟蹤

1.1 ifconfig的-19錯誤最底層分析


看了後我們知道是fec_enet_mii_probe函數返回的-19,繼續跟蹤進去:

哈哈,看到這裡答案出來了,-19就是這裡返回的,也就是說phy_dev是NULL
那為什麼呢?我們跟進去看下,of_phy_connect,功能註釋已經寫的很清楚了
Connect to the phy described in the device tree,從設備樹上獲取phy的相關描述信息,路徑:drivers/of/of_mdio.c

既然phy_device是空的,也就是說struct phy_device *phy = of_phy_find_device(phy_np);
沒有從這裡面拿到phy_device

看下如下兩個函數

這裡我需要解釋下了,bus_find_device(&mdio_bus_type, NULL, phy_np, of_phy_match);
從bus匯流排上找到device,也就是我們的phy_device,

如果找到就返回phy_device,否則就返回NULL
這個bus是指mdio_bus_type,如下:

1.2 乙太網硬體知識

那mdio又是什麼呢?這就是乙太網的知識了,我們看下乙太網的硬體接法:

如下內容轉自:https://blog.csdn.net/fun_tion/article/details/70270632

1.概述
MII即“媒體獨立介面”,也叫“獨立於介質的介面”。它是IEEE-802.3定義的乙太網行業標準。它包括一個數據介面,以及一個MAC和PHY之間的管理介面。RMII全稱為“簡化的媒體獨立介面”,是IEEE-802.3u標準中除MII介面之外的另一種實現。(此處內容來源於網路)

2.獨立於介質的介面(MII)
獨立於介質的介面(MII)用於MAC與外接的PHY互聯,支持10Mbit/s和100Mbit/s數據傳輸模式。MII的信號線如下圖所示:

MII_TX_CLK:發送數據使用的時鐘信號,對於10M位/s的數據傳輸,此時鐘為2.5MHz,對於100M位/s的數據傳輸,此時鐘為25MHz。
MII_RX_CLK:接收數據使用的時鐘信號,對於10M位/s的數據傳輸,此時鐘為2.5MHz,對於100M位/s的數據傳輸,此時鐘為25MHz。
MII_TX_EN:傳輸使能信號,此信號必需與數據前導符的起始位同步出現,併在傳輸完畢前一直保持。
MII_TXD[3:0]:發送數據線,每次傳輸4位數據,數據在MII_TX_EN信號有效時有效。MII_TXD[0]是數據的最低位,MII_TXD[3]是最高位。當MII_TX_EN信號無效時,PHY忽略傳輸的數據。
MII_CRS:載波偵聽信號,僅工作在半雙工模式下,由PHY控制,當發送或接收的介質非空閑時,使能此信號。 PHY必需保證MII_CRS信號在發生衝突的整個時間段內都保持有效,不需要此信號與發送/接收的時鐘同步。
MII_COL:衝突檢測信號,僅工作在半雙工模式下,由PHY控制,當檢測到介質發生衝突時,使能此信號,並且在整個衝突的持續時間內,保持此信號有效。此信號不需要和發送/接收的時鐘同步。
MII_RXD[3:0]:接收數據線,每次接收4位數據,數據在MII_RX_DV信號有效時有效。MII_RXD[0]是數據的最低位,MII_RXD[3]是最高位。當MII_RX_EN無效,而MII_RX_ER有效時,MII_RXD[3:0]數據值代表特定的信息(請參考表194)。
MII_RX_DV:接收數據使能信號,由PHY控制,當PHY準備好數據供MAC接收時,使能該信號。此信號必需和幀數據的首位同步出現,並保持有效直到數據傳輸完成。在傳送最後4位數據後的第一個時鐘之前,此信號必需變為無效狀態。為了正確的接收一個幀,有效電平不能滯後於數據線上的SFD位出現。
MII_RX_ER:接收出錯信號,保持一個或多個時鐘周期(MII_RX_CLK)的有效狀態,表明MAC在接收過程中檢測到錯誤。具體錯誤原因需配合MII_RX_DV的狀態及MII_RXD[3:0]的數據值。
3.精簡的獨立於介質的介面(RMII)
精簡的獨立於介質介面(RMII)規範減少了乙太網通信所需要的引腳數。根據IEEE802.3標準,MII介面需要16個數據和控制信號引腳,而RMII標準則將引腳數減少到了7個。RMII具有以下特性:
時鐘信號需要提高到50MHz。
MAC和外部的乙太網PHY需要使用同樣的時鐘源
使用2位寬度的數據收發
RMII的信號線如下圖所示:


如上內容轉自:https://blog.csdn.net/fun_tion/article/details/70270632

1.3 Mdio匯流排沒有找到phy_device

接下來回歸到軟體層面,那乙太網的通信收發數據包就是使用MDC/MDIO這樣的硬體介面
軟體的介面是:mdiobus_read與mdiobus_write


那這塊最終的read / write的實現函數在哪裡呢?去乙太網控制器drvier里看就好了fec_main.c中:



回歸到剛剛的-19錯誤最終發現是phy_device為NULL了,也就是在mdio bus上沒有找到對應的phy_device,那麼從這裡我們可以猜想註冊的時候是否根本就沒註冊進去呢?或者是註冊成功了後,在某個階段phy_device消失了?帶著這個疑問我們就要看下乙太網控制器載入的流程了。

4. 網址分享

http://stackoverflow.com/questions/5308090/set-ip-address-using-siocsifaddr-ioctl
http://www.ibm.com/support/knowledgecenter/ssw_aix_72/com.ibm.aix.commtrf2/ioctl_socket_control_operations.htm
https://lkml.org/lkml/2017/2/3/396
linux PHY驅動
http://www.latelee.org/programming-under-linux/linux-phy-driver.html
Linux PHY幾個狀態的跟蹤
http://www.latelee.org/programming-under-linux/linux-phy-state.html
第十六章PHY -基於Linux3.10
https://blog.csdn.net/shichaog/article/details/44682931

```

End


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、搭建pptp vpn 需開放1723埠和gre協議 1.阿裡雲有個安全組需要開放埠才能訪問,需添加新的安全組規則。 登陸阿裡雲伺服器管理控制台,添加安全組規則 入/出方向都填寫 埠範圍為1723/1723 具體如圖 2.同時伺服器內部也要開放1723埠 這個在後面講 二、安裝pptp s ...
  • 本文主要為0基礎的小白準備,有一定經驗的大神請忽略。因為最近剛接觸linux,在其中也是遇到無數的彎路,本著互惠互利原則,特寫這個博客,希望後來人能少走點彎路,更快的進入狀態。話不多說,上貨。 一,首先下載安裝vmware-pro15虛擬機。(相關軟體下載地址請看結尾) 二,安裝CentOS-7-M ...
  • http://nginx.org/ NGINX官網 創建文件夾mkdir nginx進入創建的文件夾 根據自己需要下載合適版本 通過 wget http://nginx.org/download/nginx-1.17.6.tar.gz 下載文件 安裝必要插件yum -y install gcc pc ...
  • 1. 前言 本文繼續“Linux電源管理(6)_Generic PM之Suspend功能”中有關suspend同步以及PM wakeup的話題。這個話題,是近幾年Linux kernel最具爭議的話題之一,在國外Linux開發論壇,經常可以看到圍繞該話題的辯論。辯論的時間跨度和空間跨度可以持續很長, ...
  • 回到: "Linux系列文章" "Shell系列文章" "Awk系列文章" 介紹 這些案例是我收集起來的,大多都是我自己遇到過的,有些比較經典,有些比較具有代表性。 這些awk案例我也錄了相關視頻的講解 "awk 18個經典實戰案例精講" ,歡迎大家去瞅瞅。 插入幾個新欄位 在"a b c d"的b ...
  • crontab 預設編輯器為vi,不支持foldenable 將預設編輯器改為vim即可解決 將這句話加入/root/.bashrc ...
  • 故障現象 解決方案(失敗) 無效,date命令顯示正常,但是放在腳本中的date命令依然報錯,並且日誌時間依然延後8小時 無效 依然沒有什麼鳥用 最後網上看了一篇文章大概是說可能是升級libc.so.6導致,嘗試以下方法總算成功了 解決方案(成功!) ...
  • 常見的FTP伺服器程式 IIS、Serv-U (windwards中) wu-ftpd(淘汰了)、Proftpd (Linux中) vsftpd(Very Secure FTP Daemon) (Linux中) 安裝 yum install vsftp –y 相關文件 主配置文件 /etc/vsft ...
一周排行
    -Advertisement-
    Play Games
  • C#TMS系統代碼-基礎頁面BaseCity學習 本人純新手,剛進公司跟領導報道,我說我是java全棧,他問我會不會C#,我說大學學過,他說這個TMS系統就給你來管了。外包已經把代碼給我了,這幾天先把增刪改查的代碼背一下,說不定後面就要趕鴨子上架了 Service頁面 //using => impo ...
  • 委托與事件 委托 委托的定義 委托是C#中的一種類型,用於存儲對方法的引用。它允許將方法作為參數傳遞給其他方法,實現回調、事件處理和動態調用等功能。通俗來講,就是委托包含方法的記憶體地址,方法匹配與委托相同的簽名,因此通過使用正確的參數類型來調用方法。 委托的特性 引用方法:委托允許存儲對方法的引用, ...
  • 前言 這幾天閑來沒事看看ABP vNext的文檔和源碼,關於關於依賴註入(屬性註入)這塊兒產生了興趣。 我們都知道。Volo.ABP 依賴註入容器使用了第三方組件Autofac實現的。有三種註入方式,構造函數註入和方法註入和屬性註入。 ABP的屬性註入原則參考如下: 這時候我就開始疑惑了,因為我知道 ...
  • C#TMS系統代碼-業務頁面ShippingNotice學習 學一個業務頁面,ok,領導開完會就被裁掉了,很突然啊,他收拾東西的時候我還以為他要旅游提前請假了,還在尋思為什麼回家連自己買的幾箱飲料都要叫跑腿帶走,怕被偷嗎?還好我在他開會之前拿了兩瓶芬達 感覺感覺前面的BaseCity差不太多,這邊的 ...
  • 概述:在C#中,通過`Expression`類、`AndAlso`和`OrElse`方法可組合兩個`Expression<Func<T, bool>>`,實現多條件動態查詢。通過創建表達式樹,可輕鬆構建複雜的查詢條件。 在C#中,可以使用AndAlso和OrElse方法組合兩個Expression< ...
  • 閑來無聊在我的Biwen.QuickApi中實現一下極簡的事件匯流排,其實代碼還是蠻簡單的,對於初學者可能有些幫助 就貼出來,有什麼不足的地方也歡迎板磚交流~ 首先定義一個事件約定的空介面 public interface IEvent{} 然後定義事件訂閱者介面 public interface I ...
  • 1. 案例 成某三甲醫預約系統, 該項目在2024年初進行上線測試,在正常運行了兩天後,業務系統報錯:The connection pool has been exhausted, either raise MaxPoolSize (currently 800) or Timeout (curren ...
  • 背景 我們有些工具在 Web 版中已經有了很好的實踐,而在 WPF 中重新開發也是一種費時費力的操作,那麼直接集成則是最省事省力的方法了。 思路解釋 為什麼要使用 WPF?莫問為什麼,老 C# 開發的堅持,另外因為 Windows 上已經裝了 Webview2/edge 整體打包比 electron ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...