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