<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > 基于A(yíng)RM處理器的HDLC通信的DMA實(shí)現

基于A(yíng)RM處理器的HDLC通信的DMA實(shí)現

作者: 時(shí)間:2012-11-16 來(lái)源:網(wǎng)絡(luò ) 收藏

1.3 緩沖描述符(BD)

緩沖描述符是S3C5410B使用的一種數據結構,通常構成循環(huán)鏈表。H引擎可以直接讀取結構的信息,用戶(hù)通過(guò)填寫(xiě)這些結構中的域去控制H的運行行為。如圖2所示,每個(gè)BD包括4個(gè)域:

①數據緩存指針(data buffer pointer)。第31位標識主權(ownership)關(guān)系,表示當前的BD在(1)控制器和CPU(0)之間的所屬關(guān)系,通常在發(fā)送和接收時(shí)要對其檢查。對于數據長(cháng)度,通常在發(fā)送時(shí)寫(xiě)入BD的幀長(cháng)度域,DMA引擎會(huì )根據其發(fā)送相應長(cháng)度的數據。接收數據長(cháng)度會(huì )自動(dòng)寫(xiě)入這個(gè)域。

②保留域。發(fā)送BD(Tx),低8位表示發(fā)送控制(如前同步信號、CRC模式、BIG/LITTLE端選擇等);接收BD(Rx),保留未用。

③長(cháng)度域。發(fā)送BD,用戶(hù)寫(xiě)入發(fā)送幀的數據長(cháng)度;接收BD,DMA控制器寫(xiě)入接收幀的數據長(cháng)度。

④Next BD指針。指向下一個(gè)BD,收發(fā)BD各自構成一組BD鏈。

HDMA控制器在使用過(guò)一個(gè)BD后,會(huì )自動(dòng)讀入下一個(gè)BD,裝入HDMA指針寄存器(HDMAXxPTR)。使用指針gpXxBDStart,指示當前的可用BD位置。在設備中定義為全局變量(X表示T或R)。

1.4 重要的數據類(lèi)型

BD結構的定義如圖2所示。

typedef struct BD{

U32 BufferData Ptr;

//數據緩存區指針,其中第31位標識BD的所有權

U32 Reserved;

//發(fā)送BD控制位,定義發(fā)送時(shí)操作的模式,接收BD保留

U32 StatusLength;

//運行狀態(tài),在ISR中檢測,也定義對應的數據緩存區的長(cháng)度

struct BD *NextBD;

//下一個(gè)BD指針

}sBuffer Descriptor;

HDLC幀(Frame)定義(如表1):

typedef struct HDLCFRAME{

U8 address[4]; //地址

U8 control; //控制信息通道為FFH

U8 information[1505]; //信息域,有效的數據

}sHdlcFrame;

HDLC設備結構定義:

typedef struct HDLC_Device {

U32 HDLC_Port; /

U32 HDLC_Baud; //HDLC波特率

U32 HDLC_Data_format;

//HDLC數據格式,NRZ,NRZI,FM0,FM1,Manchester

//……時(shí)鐘選擇(發(fā)送/接收時(shí)鐘源)……

sBufferDescriptor gpTxBDStart;/*當前的發(fā)送BD指針Start of TX BDs*/

sBufferDescriptor *gpRxBDStart; /*當前的接收BD指針Start of RX BDs */

//……狀態(tài)統計信息(Abort,CRC error,Null list)……

}Hdle_End_Device;

由于在中斷服務(wù)程序入口無(wú)法傳遞參數,故定義設備為全局變量,程序設計中使用指針傳遞,提高效率。



關(guān)鍵詞: ARM處理器 HDLC通信 DMA

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>