基于CP2200的嵌入式以太網(wǎng)接口設(shè)計
4. 以太網(wǎng)接口軟件設(shè)計
4.1 CP2200驅(qū)動程序
以太網(wǎng)中,網(wǎng)絡(luò)接口就是一個以太網(wǎng)控制芯片及其驅(qū)動程序。以太網(wǎng)接口驅(qū)動程序包含管理控制器芯片與網(wǎng)絡(luò)協(xié)議棧中上一層之間通信的程序代碼,為了在以太網(wǎng)上傳送IP數(shù)據(jù)報,IP層將數(shù)據(jù)報傳遞給以太網(wǎng)控制器的驅(qū)動程序,驅(qū)動程序指示以太網(wǎng)控制器傳送以太網(wǎng)幀。在接收來自網(wǎng)絡(luò)的IP數(shù)據(jù)報時,以太網(wǎng)控制器檢查目標(biāo)地址是否與接口硬件地址或控制器可接收的組播或廣播地址一致,如果一致,則控制器檢查錯誤,驅(qū)動程序把數(shù)據(jù)報或出錯指示傳遞給IP層。
這里以太網(wǎng)接口驅(qū)動程序主要是CP2200的初始化配置和收發(fā)配置。
(1) CP2200復(fù)位初始化
CP2200復(fù)位初始化過程可以確保設(shè)備正常工作。復(fù)位開始時,首先要等待復(fù)位引腳升高,然后等待振蕩器初始化完成,振蕩器初始化完成后會發(fā)送一個中斷信號。之后是CP2200自身初始化,可以通過檢測INT0中斷狀態(tài)寄存器確定自身初始化的完成。由于系統(tǒng)默認(rèn)的是允許所有的中斷,通過設(shè)置INT0EN和INT1EN關(guān)閉哪些不被主處理器處理的中斷事件。初始化過程還包括物理層(PHY)的初始化,以及媒體訪問層(MAC)的初始化。最后配置接收過濾器,系統(tǒng)復(fù)位后,過濾器允許廣播包和組播包,通過設(shè)置RXFILT寄存器可以決定是接收還是忽略諸如廣播、組播、短幀(幀長度小于64字節(jié))或者CRC錯誤的幀等。初始化完成后,接收緩沖區(qū)為空,CP2200開始準(zhǔn)備發(fā)送或接收數(shù)據(jù).
圖3 CP2200發(fā)送流程圖
(2) 數(shù)據(jù)的接收和發(fā)送
單片機(jī)C8051F020通過使用CP2200的直接和間接寄存器來控制CP2200,直接寄存器可
以訪問RAM緩沖區(qū),F(xiàn)LASH存儲區(qū),間接的MAC配置寄存器及其它的狀態(tài)和控制寄存器。CP2200具有2K(0x0000–0x07FF)字節(jié)的發(fā)送緩沖區(qū)和4K(0x0000–0x0FFF)字節(jié)的接收緩沖區(qū),它們共享相同的地址空間,都使用RAMADDRH:RAMADDRL指針訪問,每個緩沖區(qū)都有一個專門的數(shù)據(jù)寄存器。其中CP2200發(fā)送數(shù)據(jù)的流程圖如圖3所示:
使用隨機(jī)儲存器訪問方法將該包裝入發(fā)送緩沖區(qū):
a.將RAMADDRH:RAMADDRL設(shè)為0x0000。
b.將第一個字節(jié)寫入 RAMTXDATA。
c.將RAMADDRH:RAMADDRL加1。
d.將另一個數(shù)據(jù)字節(jié)寫入 RAMTXDATA.
e.重復(fù)步驟c和d直到整個包全部裝入發(fā)送緩存區(qū)。
f.長度小于64字節(jié)的幀需要填充為至少64字節(jié)。
g.將TXENDH:TXENDL設(shè)置為最后一個字節(jié)的地址。該地址值必須大于等于0x0040。
評論