0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

0101以太網(wǎng)簡(jiǎn)介以及SMI接口

Q4MP_gh_c472c21 ? 來(lái)源:嵌入式ARM ? 作者:Firefly ? 2021-01-26 16:42 ? 次閱讀

0101以太網(wǎng)簡(jiǎn)介

STM32F20X和STM32F21的以太網(wǎng)外設(shè)可接受和發(fā)送數(shù)據(jù)按照IEE802.3-2002標(biāo)準(zhǔn)。

以太網(wǎng)提供一個(gè)完整的、靈活的外設(shè)去滿足不同應(yīng)用和要求。它支持與外部相連(PHY)的兩個(gè)標(biāo)準(zhǔn)的工業(yè)接口:默認(rèn)情況使用在IEEE802.3規(guī)范中定義的獨(dú)立介質(zhì)接口(MII)和精簡(jiǎn)介質(zhì)獨(dú)立接口(RMII)。它可以被用于大量的需求,例如開關(guān)(交換機(jī))、網(wǎng)絡(luò)接口卡等等。

以太網(wǎng)滿足下列標(biāo)準(zhǔn):

● IEEE 802.3-2002,用于以太網(wǎng)MAC。

● IEEE 1588-2008標(biāo)準(zhǔn),用于規(guī)定聯(lián)網(wǎng)時(shí)鐘同步的精度。

● AMBA 2.0,用于AHB主/從端口。

● RMII聯(lián)盟的RMII規(guī)范。

02 STM32F207的ETH介紹

STM32F207支持MII接口和RMII接口。STM32F207以太網(wǎng)外設(shè)包括一個(gè)MAC802.3(介質(zhì)訪問控制)和一個(gè)DMA控制器。它默認(rèn)情況下支持MII和RMII接口,通過一個(gè)選擇位進(jìn)行切換(參考SYSCFG_PMC寄存器)。

DMA控制器通過AHB主從接口和內(nèi)核與內(nèi)存相連。AHB主接口控制數(shù)據(jù)傳輸,AHB從接口用于訪問控制和狀態(tài)寄存器(CSR)空間。

在MAC內(nèi)核發(fā)送數(shù)據(jù)之前,數(shù)據(jù)經(jīng)過DMA的方式發(fā)送到FIFO中緩存。同樣的,接收FIFO存儲(chǔ)通過線路收到的以太網(wǎng)數(shù)據(jù)幀,直到這些數(shù)據(jù)幀通過DMA被傳輸?shù)较到y(tǒng)內(nèi)存。

以太網(wǎng)外設(shè)也包括一個(gè)SMI,用于和外部PHY通訊。通過一組寄存器的配置,用戶可以選擇MAC和DMA控制器的不同模式和功能。

當(dāng)使用以太網(wǎng)時(shí),AHB時(shí)鐘必須至少25MHZ。

下面是ETH的框圖

7d48642a-5f64-11eb-8b86-12bb97331649.png

關(guān)于AHB的連接信息

區(qū)域1:我們稱為SMI接口,用于配置外部PHY芯片。

區(qū)域2:是數(shù)據(jù)交換接口,也就是上面我們說的MII接口和RMII接口。

03 SMI接口

3.1、站管理接口:SMI

站管理接口允許任何PHY寄存器請(qǐng)求通過2線時(shí)鐘和數(shù)據(jù)線。這個(gè)接口支持最多到32個(gè)PHY。

應(yīng)用程序可以從32個(gè)PHY中選擇一個(gè)PHY,然后從任意PHY包含的32個(gè)寄存器中選擇一個(gè)寄存器,發(fā)送控制數(shù)據(jù)或接收狀態(tài)信息。任意給定時(shí)間內(nèi)只能對(duì)一個(gè)PHY中的一個(gè)寄存器進(jìn)行尋址。

MDC時(shí)鐘線和MDIO數(shù)據(jù)線在微控制器中均用作復(fù)用功能I/O:

MDC:周期性時(shí)鐘,提供以最大頻率2.5 MHz傳輸數(shù)據(jù)時(shí)的參考時(shí)序。MDC的最短高電平時(shí)間和最短低電平時(shí)間必須均為160 ns。MDC的最小周期必須為400 ns。在空閑狀態(tài)下,SMI管理接口將MDC時(shí)鐘信號(hào)驅(qū)動(dòng)為低電平。

MDIO:數(shù)據(jù)輸入/輸出比特流,用于通過MDC時(shí)鐘信號(hào)向/從PHY設(shè)備同步傳輸狀態(tài)信息。

7e24e012-5f64-11eb-8b86-12bb97331649.png

3.2、SMI幀結(jié)構(gòu)

下圖給出了讀操作和寫操作幀結(jié)構(gòu),位傳輸必須要求從左到右。

7e884918-5f64-11eb-8b86-12bb97331649.png

Preamble(32bit前導(dǎo)符):每個(gè)傳輸(讀或者寫)都必須以前導(dǎo)符開始,前導(dǎo)符是MDIO線上連續(xù)的32個(gè)邏輯’1’信號(hào),和對(duì)應(yīng)MDC線上的32個(gè)時(shí)鐘信號(hào)。這部分信號(hào)用于和PHY設(shè)備建立同步。

Start(起始符):幀的起始符定義為’01’,也就是MDIO線從邏輯’1’降到’0’再回到’1’,以標(biāo)記傳輸?shù)摹?/p>

開始。

Operation(操作符):用于定義操作的類型:讀或者寫。

PADDR:PHY的地址有5位,可以區(qū)分32個(gè)PHY。高位先被發(fā)送和接收。

RADDR:寄存器的地址有5位,可以尋址32個(gè)獨(dú)立的寄存器。高位先被發(fā)送和接收。

TA:2位的轉(zhuǎn)向符,插在RADDR和數(shù)據(jù)(DATA)之間,用于避免讀操作時(shí)發(fā)生沖突。讀操作時(shí),在TA的這2位時(shí)間內(nèi),MAC控制器保持MDIO線的高阻狀態(tài),PHY設(shè)備則先保持1位的高阻狀態(tài),在第2位時(shí)輸出’0’信號(hào)。寫操作時(shí),在TA的這2位時(shí)間內(nèi),MAC控制器驅(qū)動(dòng)MDIO線輸出’10’信號(hào),而PHY設(shè)置則保持高阻狀態(tài)。

DATA(數(shù)據(jù)):16位的數(shù)據(jù)域。最先發(fā)送和接收的是ETH_MIID寄存器的第15位。

空閑位:MDIO線保持在高阻狀態(tài)。取消所有的三態(tài)驅(qū)動(dòng),由PHY的上拉電阻保證MDIO線處于邏輯’1’。

3.3、SMI寫操作

當(dāng)應(yīng)用程序設(shè)置了MII寫和忙位(以太網(wǎng)MACMII地址寄存器(ETH_MACMIIAR)),SMI接口會(huì)向PHY傳 送PHY地 址 和PHY寄 存 器 地 址 ,然 后 傳 輸 數(shù) 據(jù) (以 太 網(wǎng)MAC MII數(shù)據(jù) 寄 存器(ETH_MACMIIDR))。在SMI接口傳輸數(shù)據(jù)的過程中,不能修改MII地址寄存器和MII數(shù)據(jù)寄存器的內(nèi)容;在此過程中(忙位為高),對(duì)MII地址寄存器或MII數(shù)據(jù)寄存器的寫操作將被忽視,并且不影響整個(gè)傳輸?shù)恼_完成。當(dāng)完成寫操作時(shí),SMI接口將清除忙位,告知應(yīng)用程序。

下圖描述了寫操作時(shí)的幀格式。

7ec0e53e-5f64-11eb-8b86-12bb97331649.png

3.4、SMI讀操作

當(dāng)程序把以太網(wǎng)MACMII地址寄存器(ETH_MACMIIAR)的MII忙位置為’1’,而保持MII寫位為’0’,SMI接口則發(fā)送PHY地址和PHY寄存器地址,執(zhí)行讀PHY寄存器的操作。在整個(gè)傳輸過程中,應(yīng)用程序不能修改MII地址寄存器和MII數(shù)據(jù)寄存器的內(nèi)容。在傳輸過程中(忙位為高),對(duì)MII地址寄存器或者M(jìn)II數(shù)據(jù)寄存器的寫操作將被忽視,并且不影響整個(gè)傳輸?shù)恼_完成。在讀操作完成后,SMI接口將清除忙位,并把從PHY讀回的數(shù)據(jù)更新到MII數(shù)據(jù)寄存器中。

下圖描述了讀操作的幀格式

7f174a0a-5f64-11eb-8b86-12bb97331649.png

3.5、SMI時(shí)鐘選擇

MAC啟動(dòng)管理寫/讀操作。SMI時(shí)鐘是一個(gè)分頻時(shí)鐘,其時(shí)鐘源為應(yīng)用時(shí)鐘(AHB時(shí)鐘)。分頻系數(shù)取決于MII地址寄存器中設(shè)置的時(shí)鐘范圍。這里既然說到了時(shí)鐘,就再次提一下上文提到的內(nèi)容:當(dāng)使用以太網(wǎng)時(shí),AHB時(shí)鐘必須至少25MHZ。

7fe6e4f4-5f64-11eb-8b86-12bb97331649.png

04 代碼

o4YBAGAP1jmAVq1gAADBCKebuAY401.jpg

pIYBAGAP1kGAcagHAAAwcZ58eQQ219.jpg

責(zé)任編輯:xj

原文標(biāo)題:STM32網(wǎng)絡(luò)之SMI接口

文章出處:【微信公眾號(hào):嵌入式ARM】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 以太網(wǎng)
    +關(guān)注

    關(guān)注

    40

    文章

    5348

    瀏覽量

    170853
  • STM32
    +關(guān)注

    關(guān)注

    2265

    文章

    10858

    瀏覽量

    354414
  • SMI
    SMI
    +關(guān)注

    關(guān)注

    0

    文章

    23

    瀏覽量

    12392

原文標(biāo)題:STM32網(wǎng)絡(luò)之SMI接口

文章出處:【微信號(hào):gh_c472c2199c88,微信公眾號(hào):嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    使用C2000 EtherCAT從站控制器的SMI進(jìn)行以太網(wǎng)PHY配置

    電子發(fā)燒友網(wǎng)站提供《使用C2000 EtherCAT從站控制器的SMI進(jìn)行以太網(wǎng)PHY配置.pdf》資料免費(fèi)下載
    發(fā)表于 09-07 10:37 ?0次下載
    使用C2000 EtherCAT從站控制器的<b class='flag-5'>SMI</b>進(jìn)行<b class='flag-5'>以太網(wǎng)</b>PHY配置

    以太網(wǎng)端口的類型和特性

    以太網(wǎng)端口,即以太網(wǎng)接口,是網(wǎng)絡(luò)中用于連接設(shè)備并進(jìn)行數(shù)據(jù)交換的端口。它基于IEEE 802.3標(biāo)準(zhǔn),并使用以太網(wǎng)協(xié)議進(jìn)行數(shù)據(jù)傳輸。以太網(wǎng)端口
    的頭像 發(fā)表于 08-07 15:27 ?1022次閱讀

    車載以太網(wǎng)與傳統(tǒng)以太網(wǎng)的區(qū)別

    車載以太網(wǎng)與傳統(tǒng)以太網(wǎng)在多個(gè)方面存在顯著的差異,這些差異主要體現(xiàn)在傳輸速率、實(shí)時(shí)性、可靠性、物理層標(biāo)準(zhǔn)、應(yīng)用場(chǎng)景以及技術(shù)發(fā)展等方面。
    的頭像 發(fā)表于 07-25 11:12 ?1342次閱讀

    以太網(wǎng)要怎么連接

    的步驟和注意事項(xiàng)。 首先,我們需要檢查設(shè)備是否支持以太網(wǎng)連接。現(xiàn)代計(jì)算機(jī)和筆記本電腦通常都內(nèi)置有以太網(wǎng)接口,可以直接使用以太網(wǎng)電纜進(jìn)行連接。然而,一些較舊的設(shè)備或特定類型的設(shè)備可能沒有
    的頭像 發(fā)表于 07-09 10:28 ?933次閱讀

    車載以太網(wǎng)硬件接口VN5620設(shè)備展示與介紹#車載以太網(wǎng)

    車載以太網(wǎng)
    北匯信息POLELINK
    發(fā)布于 :2024年05月31日 10:27:03

    以太網(wǎng)接口的數(shù)據(jù)傳輸原理詳解

    以太網(wǎng)接口作為計(jì)算機(jī)網(wǎng)絡(luò)中的關(guān)鍵組成部分,承擔(dān)著數(shù)據(jù)傳輸?shù)闹匾氊?zé)。在了解以太網(wǎng)接口的數(shù)據(jù)傳輸原理之前,我們首先需要明確以太網(wǎng)的基本概念和工
    的頭像 發(fā)表于 05-29 16:47 ?1437次閱讀

    以太網(wǎng)接口與網(wǎng)線接口的關(guān)系

    ,對(duì)于許多人來(lái)說,以太網(wǎng)接口與網(wǎng)線接口之間的關(guān)系可能并不清晰。本文將深入探討以太網(wǎng)接口的概念、功能、技術(shù)背景
    的頭像 發(fā)表于 05-29 16:38 ?2040次閱讀

    RJ45接口以太網(wǎng)接口的區(qū)別

    在當(dāng)今的計(jì)算機(jī)網(wǎng)絡(luò)世界中,RJ45接口以太網(wǎng)接口是兩個(gè)常見的術(shù)語(yǔ),它們?cè)诰W(wǎng)絡(luò)通信中扮演著不可或缺的角色。然而,盡管它們都與網(wǎng)絡(luò)連接有關(guān),但它們?cè)诙x、功能和應(yīng)用上存在明顯的區(qū)別。本文將詳細(xì)探討RJ45
    的頭像 發(fā)表于 05-29 16:33 ?3901次閱讀

    RS485接口怎么轉(zhuǎn)換以太網(wǎng)接口

    在工業(yè)自動(dòng)化、智能監(jiān)控、數(shù)據(jù)采集等領(lǐng)域,RS485接口以太網(wǎng)接口是兩種常見的通信方式。RS485接口以其長(zhǎng)距離傳輸、多節(jié)點(diǎn)連接和抗干擾能力強(qiáng)等特點(diǎn),廣泛應(yīng)用于各種工業(yè)現(xiàn)場(chǎng)。而
    的頭像 發(fā)表于 05-29 16:32 ?6002次閱讀

    車載以太網(wǎng)硬件接口VN5650--基于Network-based模式的配置過程#車載以太網(wǎng) #CANoe

    車載以太網(wǎng)
    北匯信息POLELINK
    發(fā)布于 :2024年05月15日 17:28:47

    車載以太網(wǎng)接口VN5650使用場(chǎng)景介紹#車載以太網(wǎng)

    以太網(wǎng)
    北匯信息POLELINK
    發(fā)布于 :2024年05月11日 17:58:05

    車載以太網(wǎng)硬件接口VN5650配置模式--Network-based mode 功能介紹#車載以太網(wǎng)

    以太網(wǎng)接口
    北匯信息POLELINK
    發(fā)布于 :2024年05月11日 17:13:47

    科普科普以太網(wǎng)的定義、種類以及晶振在以太網(wǎng)上的應(yīng)用

    科普科普以太網(wǎng)的定義、種類以及晶振在以太網(wǎng)上的應(yīng)用? 以太網(wǎng)是一種用于局域網(wǎng)通信的傳輸技術(shù),它是一種在計(jì)算機(jī)網(wǎng)絡(luò)中常用的傳輸協(xié)議,用于將數(shù)據(jù)包從一個(gè)節(jié)點(diǎn)傳輸?shù)搅硪粋€(gè)節(jié)點(diǎn)。本文將詳細(xì)介紹
    的頭像 發(fā)表于 01-24 16:11 ?967次閱讀

    簡(jiǎn)單認(rèn)識(shí)以太網(wǎng)接口集成電路

    以太網(wǎng)是一種用于局域網(wǎng) (Local Area Network, LAN)和城域網(wǎng) ( Metropolitan Area Network,MAN)通信的計(jì)算機(jī)網(wǎng)絡(luò)技術(shù),連接這些網(wǎng)絡(luò)設(shè)備的各種
    的頭像 發(fā)表于 12-27 09:58 ?601次閱讀

    PC電腦如何讀取車載以太網(wǎng)接口的激光雷達(dá)數(shù)據(jù)

    電腦的普通以太網(wǎng)如何讀取車載以太網(wǎng)接口的激光雷達(dá)數(shù)據(jù)呢?智嵌物聯(lián)自主研發(fā)的一款百兆車載以太網(wǎng)轉(zhuǎn)換器,可以實(shí)現(xiàn)普通以太網(wǎng)
    的頭像 發(fā)表于 11-18 15:09 ?1084次閱讀
    PC電腦如何讀取車載<b class='flag-5'>以太網(wǎng)</b><b class='flag-5'>接口</b>的激光雷達(dá)數(shù)據(jù)