當(dāng)前位置:首頁 > EDA > 電子設(shè)計自動化
[導(dǎo)讀]本文為實現(xiàn)高速數(shù)據(jù)的實時遠程傳輸處理,提出了采用FPGA直接控制DM9000A進行以太網(wǎng)數(shù)據(jù)收發(fā)的設(shè)計思路,實現(xiàn)了一種低成本、低功耗和高速率的網(wǎng)絡(luò)傳輸功能,最高傳輸速率可達100Mbps。 DM9000A簡介

本文為實現(xiàn)高速數(shù)據(jù)的實時遠程傳輸處理,提出了采用FPGA直接控制DM9000A進行以太網(wǎng)數(shù)據(jù)收發(fā)的設(shè)計思路,實現(xiàn)了一種低成本、低功耗和高速率的網(wǎng)絡(luò)傳輸功能,最高傳輸速率可達100Mbps。

        DM9000A簡介

        主要特點 
        DM9000A實現(xiàn)以太網(wǎng)媒體介質(zhì)訪問層(MAC)和物理層(PHY)的功能,包括MAC數(shù)據(jù)幀的組裝/拆分與收發(fā)、地址識別、CRC編碼/校驗、MLT-3編碼器、接收噪聲抑制、輸出脈沖成形、超時重傳、鏈路完整性測試、信號極性檢測與糾正等。

        工作原理
        DM9000A可以和微處理器以8位或16位的總線方式連接,并可根據(jù)需要以單工或全雙工等模式運行。在系統(tǒng)上電時,處理器通過總線配置DM9000A內(nèi)的網(wǎng)絡(luò)控制寄存器(NCR)、中斷寄存器(ISR)等,以完成DM9000A的初始化。隨后,DM9000A進人數(shù)據(jù)收發(fā)等待狀態(tài)。

        當(dāng)處理器要向以太網(wǎng)發(fā)送數(shù)據(jù)幀時,先將數(shù)據(jù)打包成UDP或IP數(shù)據(jù)包,并通過8位或16位總線逐字節(jié)發(fā)送到DM9000A的數(shù)據(jù)發(fā)送緩存中,然后將數(shù)據(jù)長度等信息填充到DM9000A的相應(yīng)寄存器內(nèi),隨后發(fā)送使能命令,DM9000A將緩存的數(shù)據(jù)和數(shù)據(jù)幀信息進行MAC組幀,并發(fā)送出去。

        當(dāng)DM9000A接收到外部網(wǎng)絡(luò)送來的以太網(wǎng)數(shù)據(jù)時,首先檢測數(shù)據(jù)幀的合法性,如果幀頭標(biāo)志有誤或存在CRC校驗錯誤,則將該幀數(shù)據(jù)丟棄,否則將數(shù)據(jù)幀緩存到內(nèi)部RAM,并通過中斷標(biāo)志位通知處理器,處理器收到中斷后將DM9000A接收RAM的數(shù)據(jù)讀出進行處理。

        DM9000A自動檢測網(wǎng)絡(luò)連接情況,根據(jù)網(wǎng)速設(shè)定內(nèi)部的數(shù)據(jù)收發(fā)速率是10Mbps或100Mbps。同時,DM9000A還能根據(jù)RJ45接口是采用對等還是交叉連接方式而改變數(shù)據(jù)收發(fā)引腳的方向,因此,無論外部網(wǎng)線采用對等還是交叉方式,系統(tǒng)均能正常通信。

        基于FPGA和DM9000A的網(wǎng)絡(luò)接口設(shè)計與實現(xiàn)

        下面給出DM9000A與FPGA的硬件設(shè)計和軟件配置方法。FPGA啟動以太網(wǎng)發(fā)送程序,將解調(diào)數(shù)據(jù)發(fā)送到DM9000A,完成數(shù)據(jù)發(fā)送過程。在接收方向,網(wǎng)絡(luò)工作站把控制指令按照一定的幀格式組幀發(fā)送到以太網(wǎng),DM9000A接收到發(fā)給自己的以太網(wǎng)幀并通知FPGA啟動以太網(wǎng)接收程序,F(xiàn)PGA將相應(yīng)的數(shù)據(jù)從DM9000A的接收FIFO讀出。

        與FPGA的數(shù)據(jù)接口和控制接口
        DM9000A的外部總線符合ISA標(biāo)準(zhǔn)。可通過ISA總線直接與FPGA無縫連接。其硬件連接原理如圖1所示。 
 

         初始化模塊
         DM9000A正常工作需要在上電后對內(nèi)部寄存器進行初始化,該過程通過FPGA對DM9000A外部控制總線和數(shù)據(jù)總線的讀寫操作完成。具體流程如下所示:

>激活PHY
設(shè)置GPR(REG_1F)CEPIO0bit[0]=0;
復(fù)位后,DM9000A恢復(fù)默認(rèn)的休眠狀態(tài),以降低功耗,因此需要首先喚醒PHY。

>進行兩次軟復(fù)位,步驟如下:
設(shè)置NCR(REG_00)bit[2:0]=011,至少保持20μs;
清除NCR(REG_00)bit[2:0]=000;
設(shè)置NCR(REG_00)bit[2:0]=011,至少保持20μs;
清除NCR(REG_00)bit[2:0]=000;

>配置NCR寄存器;
設(shè)置NCR(REG_00)bit[2:1]=00;配置為正常模式。
通過改變該寄存器可以選擇設(shè)置內(nèi)部或者外部PHY、全雙工或者半雙工模式、使能喚醒事件等網(wǎng)絡(luò)操作。

>清除發(fā)送狀態(tài);
設(shè)置NSR(REG_01)bit[5]=1bit[3]=1 bit[2]=1;

>設(shè)置IMR寄存器(REG_FF)PAR bit[7]=1,以肩用RX/TX FIFOSRAM讀/寫地址指針自動返回功能;

>通過IMR寄存器(REG_FF)PRM bit[0]/PTM bit[1],對RX/TX中斷使能。如果需要在一個數(shù)據(jù)幀發(fā)送完后產(chǎn)生一個中斷,就應(yīng)該將PTM bit[1]置1,如果需要在接收到一幀新數(shù)據(jù)時產(chǎn)生一個中斷,就應(yīng)該將PRM bit[1]置1;

>設(shè)置RCR寄存器,使能數(shù)據(jù)接收功能。

       通過以上步驟,可以通過LED指示燈觀測到DM9000A是否已成功初始化。

       發(fā)送模塊
       DM9000A中的發(fā)送緩沖區(qū)可以同時存儲兩幀數(shù)據(jù),可以按照先后順序命名為幀I和幀II。DM9000A上電初始化后,發(fā)送緩存區(qū)的起始地址是00H,當(dāng)前數(shù)據(jù)幀編號為幀I。兩幀數(shù)據(jù)的狀態(tài)控制字分別記錄在DM9000A的狀態(tài)寄存器03H和04H中。發(fā)送過程如下:

        首先,F(xiàn)PGA利用寫操作寄存器MWCMD(REG_F8)向DM9000A的發(fā)送緩存區(qū)中寫入發(fā)送數(shù)據(jù)幀,即需要先寫入6字節(jié)的目的MAC地址,再寫入6字節(jié)的源MAC地址,最后再寫入發(fā)送數(shù)據(jù)。隨后,F(xiàn)PGA利用寫操作寄存器MWCMD(REG_F8)將數(shù)據(jù)幀長度寫入寄存器FCH和FDH,數(shù)據(jù)長度為16位,將高8位寫入寄存器FCH,低8位寫入寄存器FDH。最后,F(xiàn)PGA將發(fā)送控制寄存器TCR(REG_02)的bit[1]置為高電平,向DM9000A發(fā)出發(fā)送數(shù)據(jù)指令。DM9000A會自動做一些處理才將數(shù)據(jù)發(fā)往以太網(wǎng),這包括:插入報頭和幀起始分隔符;插入來自上層協(xié)議的數(shù)據(jù),如果數(shù)據(jù)量小于64字節(jié),則自動補齊64字節(jié);根據(jù)目標(biāo)地址、源地址、長度/類型和數(shù)據(jù)產(chǎn)牛CRC校驗序列,并插入校驗序列位。這些處理都無需FPGA干預(yù)。處理完畢后,DM9000A即開始發(fā)送幀I,在幀I發(fā)送的同時,幀II的數(shù)據(jù)即可寫入發(fā)送緩存區(qū)。在幀I發(fā)送完后,將幀II的數(shù)據(jù)長度寫入寄存器FCH和FDH,最后將發(fā)送控制寄存器NSR(REG_01)的bit[1]置為高電平,即可開始幀II的發(fā)送。依此類推,下面發(fā)送的幀將會繼續(xù)編號為幀I、幀II、幀I、幀II……按照同樣的方式發(fā)送。

        如果FPGA將中斷屏蔽寄存器 IMR(REG_FF)的bit[1]置為高電平,那么發(fā)送完畢后,DM9000A將會產(chǎn)生一個指示發(fā)送完成的中斷信號。在發(fā)送過程中,F(xiàn)PGA可以查詢寄存器標(biāo)志位寄存器NSR(REG_01)中的TX1END bit[2]或者TX2END bit[3],得到數(shù)據(jù)幀的發(fā)送狀態(tài)。

        發(fā)送流程,寄存器ISR中的PTS標(biāo)志位是發(fā)送中斷標(biāo)志位,當(dāng)一幀數(shù)據(jù)發(fā)送完畢,PTS=0,F(xiàn)PCA檢測到該標(biāo)志后,應(yīng)清除標(biāo)志位以便發(fā)送新的數(shù)據(jù)幀。這里需要注意的是,向FC、FD所寫的幀長度應(yīng)該包含目的MAC地址段、源MAC地址段和有效數(shù)據(jù)的總長度。

        接收模塊
        DM9000A中的接收緩存區(qū)是一個環(huán)形結(jié)構(gòu),初始化后的起始地址為0C00H,每幀數(shù)據(jù)都有4字節(jié)長的首部,然后是有效數(shù)據(jù)和CRC校驗序列。首部4字節(jié)依次是01H、狀態(tài)、長度低字節(jié)和長度高字節(jié)。 首部4字節(jié)含義如下:

        第一個字節(jié)用來檢測接收緩存區(qū)中是否有數(shù)據(jù),如果這個字節(jié)是01H,表明接收到了數(shù)據(jù);如果為00H,則說明沒有數(shù)據(jù)。但是,如果第一個字節(jié)既不是01H,也不是00H,DM9000A就必須作一次軟復(fù)位來從這種異常狀態(tài)中恢復(fù)。

        第二個字節(jié)存儲著以太網(wǎng)幀狀態(tài),由此可判斷所接收幀是否正確。

        第三和第四字節(jié)存儲著以太網(wǎng)幀長度。后續(xù)的字節(jié)就是有效數(shù)據(jù)。

        接收過程如下:

       查看中斷狀態(tài)寄存器,如果接收到新數(shù)據(jù),寄存器ISR的PRS位將被置為0;如果檢測到PRS=0,清除PRS,F(xiàn)PGA開始讀接收緩存區(qū)數(shù)據(jù)。如果第一字節(jié)是01H,則說明有數(shù)據(jù),00H說明無數(shù)據(jù),否則要進行復(fù)位; 根據(jù)獲取的長度信息,判斷是否讀完一幀,如果讀完,接著讀下一幀,直到遇到首字節(jié)是00H的幀,說明接收數(shù)據(jù)已讀完。FPGA可以重新查看中斷狀態(tài)寄存器,等待新的有效數(shù)據(jù)幀。 

       結(jié)語
       本文對以太網(wǎng)控制器DM9000A進行了原理和功能介紹,并結(jié)合自行開發(fā)的SDR基帶信號處理平臺,基于FPGA設(shè)計實現(xiàn)了100M以太剛接口,其設(shè)計思路新穎,硬件連接簡單。整體系統(tǒng)具有功耗低,體積小,運行穩(wěn)定可靠等優(yōu)點。
本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉