當(dāng)前位置:首頁(yè) > 單片機(jī) > 單片機(jī)
[導(dǎo)讀] 六.接收數(shù)據(jù)包模塊RTL8019AS接收數(shù)據(jù)有中斷模式和查詢模式兩種。?采用中斷模式時(shí),需要在初始化程序中配置中斷。當(dāng)有一個(gè)正確的數(shù)據(jù)包到達(dá)時(shí),RTL8019AS會(huì)產(chǎn)生一個(gè)中斷信號(hào),在中斷處理程序中進(jìn)行接收數(shù)

六.接收數(shù)據(jù)包模塊

RTL8019AS接收數(shù)據(jù)有中斷模式和查詢模式兩種。

?采用中斷模式時(shí),需要在初始化程序中配置中斷。當(dāng)有一個(gè)正確的數(shù)據(jù)包到達(dá)時(shí),RTL8019AS會(huì)產(chǎn)生一個(gè)中斷信號(hào),在中斷處理程序中進(jìn)行接收數(shù)據(jù)處理。

?采用查詢模式時(shí),由主程序定時(shí)對(duì)接收緩沖區(qū)進(jìn)行查詢,當(dāng)檢測(cè)到有新的數(shù)據(jù)時(shí),通過(guò)遠(yuǎn)程DMA方式將數(shù)據(jù)從RTL8019AS的RAM空間讀出進(jìn)行處理。

驅(qū)動(dòng)系統(tǒng)采用查詢方式實(shí)現(xiàn)數(shù)據(jù)包的接收

6.1接收數(shù)據(jù)包模塊的功能

在接收數(shù)據(jù)時(shí),接收緩沖區(qū)構(gòu)成一個(gè)循環(huán)FIFO隊(duì)列。PSTART,PSTOP兩個(gè)寄存器限定了循環(huán)隊(duì)列的開始頁(yè)和結(jié)束頁(yè),CURR為寫入指針,受RTL8019芯片控制,BNRY為讀出指針,有主機(jī)程序控制。根據(jù)CURR是否等于BNRY+1,來(lái)判斷是否收到新的數(shù)據(jù)包,新收到的數(shù)據(jù)包存于CURR指定地址的RAM中。當(dāng)CURR=BNRY時(shí),RTL8019芯片停止接收數(shù)據(jù)包,反之,CURR按模增加。

6.2接收數(shù)據(jù)包模塊的數(shù)據(jù)結(jié)構(gòu)

?REC_BUFF_UNION:定義共用體REC_BUFF_UNION來(lái)存儲(chǔ)接收到的以太網(wǎng)幀,因?yàn)橐粋€(gè)最大以太網(wǎng)幀長(zhǎng)度為1518bit,所以定義公用體容量為1536bit。

?unionREC_BUFF_UNIONREC_BUFF[MAX_REC_BUFF];

REC_BUFF數(shù)組用來(lái)存儲(chǔ)以太網(wǎng)幀,此系統(tǒng)定義最多可以接收5條最大以太網(wǎng)幀。

1>實(shí)現(xiàn)形式

#define MAX_REC_BUFF5

unionREC_BUFF_UNION

{

uint32Dwords[384];

uint16words[768];

uint8bytes[1536];

};

REC_BUFF_UNIONREC_BUFF[MAX_REC_BUFF];

2>定義uint16*REC_BUFF_PTR_WORDS,

uint8* REC_BUFF_PTR_BYTES,

用REC_BUF_PTR_WORDS來(lái)接收2字節(jié)數(shù)據(jù),用REC_BUFF_PTR_BYTES來(lái)接收1字節(jié)數(shù)據(jù)。

3>以太以太網(wǎng)幀格式

6.3接收數(shù)據(jù)包模塊的組成

第一步:RTL8019AS以太網(wǎng)芯片從以太網(wǎng)讀數(shù)據(jù)

該過(guò)程涉及的寄存器如下:

?PSTART,PSTOP:以太網(wǎng)芯片接收數(shù)據(jù)緩沖區(qū)的起始,末頁(yè)地址。形成一個(gè)接收緩沖區(qū),每頁(yè)256字節(jié)。

?CURR:接收緩沖區(qū)寫頁(yè)指針

?BNRY:接收緩沖區(qū)讀指針

這四個(gè)寄存器在芯片初始化模塊中被設(shè)置。

在初始化TPSR,BNRY,PSTART,PSTOP寄存器后,就定義了接收緩沖區(qū)和發(fā)送緩沖的容量和起始地址:

當(dāng)有新數(shù)據(jù)包到來(lái)時(shí),網(wǎng)絡(luò)芯片會(huì)自動(dòng)判斷是否發(fā)送給本機(jī);若是有新數(shù)據(jù)到來(lái),則用本地DMA存入接收緩沖區(qū),并自動(dòng)修改寫指針。


1>接收數(shù)據(jù)包操作之前,先關(guān)中斷

2>判斷是否發(fā)生溢出和復(fù)位。若發(fā)生,則初始化芯片,結(jié)束程序。

3>獲取讀頁(yè)指針bnry和寫頁(yè)指針curr。

4>判斷寫頁(yè)指針是否讀取正確。若錯(cuò)誤,則開中斷,結(jié)束程序

5>判斷bnry+1是超過(guò)接收緩沖區(qū)末地址,若超過(guò),則從接收緩沖區(qū)首地址開始讀。

第二步:ARM LPC2210從網(wǎng)絡(luò)芯片RTL8019AS中讀數(shù)據(jù)

該過(guò)程涉及的寄存器同上,當(dāng)對(duì)寄存器的具體賦值不同。

?遠(yuǎn)程DMA起始地址的高字節(jié)位,賦為最后一次已經(jīng)讀取頁(yè)的地址。低地址為0.

?遠(yuǎn)程DMA的字節(jié)計(jì)數(shù)寄存器為待讀的數(shù)據(jù)長(zhǎng)度。

?設(shè)置CR為0XA發(fā)送數(shù)據(jù)包


1>判斷curr是否等于bnry+1,若不等于則有新的數(shù)據(jù)包到來(lái),CURR按模增加。當(dāng)CURR=BNRY時(shí),RTL8019芯片停止接收數(shù)據(jù)包。

2>接收數(shù)據(jù)包之前,先判斷接收緩沖環(huán)區(qū)是否達(dá)到最大(此系統(tǒng),限定接收緩沖區(qū)最大為5)。若達(dá)到最大,則重第一個(gè)緩沖區(qū)開始存。

3>設(shè)定遠(yuǎn)程DMA起始地址和遠(yuǎn)程DMA數(shù)據(jù)字節(jié)計(jì)數(shù)器啟動(dòng)DMA讀取以太網(wǎng)幀頭部前4個(gè)字節(jié)存入程序數(shù)組。

4>清零遠(yuǎn)程DMA字節(jié)計(jì)數(shù)器并中止DMA讀操作

5>根據(jù)接收到的以太網(wǎng)幀頭判斷接收幀是否錯(cuò)誤,若有錯(cuò)誤則進(jìn)行錯(cuò)誤處理,然后程序結(jié)束。

錯(cuò)誤類型有:

?接收狀態(tài)是否錯(cuò)誤

?下一頁(yè)指針是否正確

?幀的長(zhǎng)度是否大于1536

6>若數(shù)據(jù)包是完成的,讀取剩下的數(shù)據(jù)

?把bnry+4的地址賦值給遠(yuǎn)程DMA起始地址寄存器(RASR1,RSAR0)

?把幀的長(zhǎng)度賦值給遠(yuǎn)程DMA計(jì)算寄存器(RBCR0,RBCR1)

?啟動(dòng)遠(yuǎn)程DMA讀

7>從0x10遠(yuǎn)程DMA端口處,讀取數(shù)據(jù)存放到緩沖區(qū)中

8>清零遠(yuǎn)程DMA字節(jié)計(jì)數(shù)器寄存器(RSCR1,RSCR0),并終止DMA操作。

9>讀完一個(gè)幀后,修改讀頁(yè)bnry指針

10>修改完頁(yè)指針后,判讀讀頁(yè)指針是否到接收緩沖區(qū)首地址,若小于0X4C,則將binry恢復(fù)到接收緩沖區(qū)末地址處。

11>把修改過(guò)的讀頁(yè)指針寫入BNRY處

12>清除所有中斷標(biāo)志

13>判斷以太網(wǎng)中的下一條協(xié)議字段值是否是ARP數(shù)據(jù)報(bào)或IP數(shù)據(jù)報(bào),如果是則調(diào)用上層程序進(jìn)行處理。如果不是則不處理。

?判斷是ARP或IP協(xié)議時(shí),則REC_BUFF_NUM+1,在下一個(gè)緩沖區(qū)接收新的以太網(wǎng)幀。

?開中斷

?調(diào)用以太網(wǎng)報(bào)處理函數(shù)

?循環(huán)判斷是否有新的數(shù)據(jù)包到來(lái)

6.4接收數(shù)據(jù)包模塊接口

接收包模塊調(diào)用了寫數(shù)據(jù)子模塊,讀數(shù)據(jù)子模塊和頁(yè)面切換子模塊

?讀數(shù)據(jù)子模塊:從RTL8019AS中把數(shù)據(jù)讀出。

?寫數(shù)據(jù)子模塊:將數(shù)據(jù)寫入RTL2019AS芯片中

?頁(yè)面切換子模塊:可選擇Page0,Page1,Page3三個(gè)頁(yè)面

6.5接收數(shù)據(jù)包模塊程序

/****************************Copyright(c)********************

**西安郵電學(xué)院

**graduate school

**XNMS實(shí)驗(yàn)室

**Author:冀博

**Time:2011年2月21日

**http://blog.csdn.net/tigerjb

**

**--------------FileInfo---------------------------------------------------------------------

****************************Copyright(c)******************** /

/**********************************************************

**函數(shù)原型:unsigned char * Rec_Packet()

**入口參數(shù):無(wú)

**返回值:程序正確返回0

**說(shuō)明:查詢是否有新數(shù)據(jù)包并接收進(jìn)緩沖區(qū)

**********************************************************/

uint8 Rec_Packet()

{void Send_Packet(struct _pkst *TxdData)//

{

static uint8 REC_BUFF_NUM=0;

//定義讀頁(yè)號(hào)bnry和寫頁(yè)號(hào)curr

static uint8 bnry,curr;

//存放以太網(wǎng)幀報(bào)頭

static uint16 tmp[2];

uint16 * REC_BUFF_PTR_WORDS;

uint8 * REC_BUFF_PTR_BYTES;

uint8 i;

uint16 ii,length;

OS_ENTER_CRITICAL();

rea1:

page(0);

i=ReadFromNet(0X07);

//如果復(fù)位或益出就重新初試化

if((i&0x90)!=0)

{

InitNic(0);

O

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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