微控制器撥號上網(wǎng)的實(shí)現
微控制器(也稱(chēng)單片機)把所有常用的資源,如存儲器、模數轉換器、通用輸入輸出口、定時(shí)器等,與CPU集成在一個(gè)芯片上,具有體積小、功耗低、使用方便的特點(diǎn),廣泛應用于各種嵌入式系統中。隨著(zhù)互聯(lián)網(wǎng)(Internet)的興起與普及,使微控制器也接入到互聯(lián)網(wǎng),并通過(guò)互聯(lián)網(wǎng)傳送數據。但是實(shí)現單片機與互聯(lián)網(wǎng)通信的前提是需要在單片機上實(shí)現多種繁雜的互聯(lián)網(wǎng)協(xié)議。而微控制器一般處理能力較低、程序存儲器和數據存儲器資源有限,這就使微控制器上網(wǎng)變得非常困難。目前,一般采用微控制器直接驅動(dòng)網(wǎng)卡芯片的方案。網(wǎng)卡芯片封裝了底層的以太網(wǎng)協(xié)議(如IEEE802.3),微控制器只需控制網(wǎng)卡芯片并實(shí)現傳輸層與網(wǎng)絡(luò )層協(xié)議(例如TCP、IP協(xié)議)即可以上網(wǎng)。但其缺點(diǎn)是必須應用在已經(jīng)擁有局域網(wǎng)的地方,且網(wǎng)卡芯片(例如RTL8019等)價(jià)格不菲。
本文引用地址:http://dyxdggzs.com/article/149254.htm本文針對微控制器上網(wǎng)的問(wèn)題,提出一種在微控制器中實(shí)現PPP協(xié)議,并通過(guò)調制解調器(MODEM)連接到ISP(Internet Service Provider)實(shí)現上網(wǎng)的解決方案:微控制器控制MODEM撥號連接到ISP上,然后根據PPP協(xié)議(Point to Point Protocol)進(jìn)行通信協(xié)商、密碼認證等握手過(guò)程,如果成功就可以通過(guò)ISP上網(wǎng)傳送數據。這種方案的優(yōu)點(diǎn)在于:(1)可以應用于任何覆蓋電話(huà)網(wǎng)的地區,適用于廣大偏遠地區;(2)硬件實(shí)現比較簡(jiǎn)單,程序比較短??;(3)只需外接電話(huà)線(xiàn),安裝簡(jiǎn)便。
1 硬件連接與底層驅動(dòng)
微控制器撥號上網(wǎng)解決方案中的硬件連接非常簡(jiǎn)單,只需使用微控制器的標準串行口和I/O總線(xiàn)與MODEM相連。為了使程序更為簡(jiǎn)化,在硬件設計中可以不使用MODEM的硬件握手信號。最終只需四根連接線(xiàn)來(lái)控制MODEM(如圖1所示):串口發(fā)送(TXD)、串口接收(RXD)、載波檢測CD(Carrier Detect)和終端準備DTR(Data Terminal Ready)信號。CD信號可以檢測MODEM是處于數據傳送狀態(tài)還是AT命令傳送狀態(tài)。DTR信號用來(lái)通知MODEM傳送工作已經(jīng)結束。微控制器的串行口和I/O口不能直接與標準MODEM相連,需要使用電壓轉換芯片,如MAX232等,轉換為RS232標準。
為了方便軟件編程,需要針對硬件編寫(xiě)一些底層驅動(dòng)程序。首先是串行口的驅動(dòng)函數:打開(kāi)串口(OpenComm)、關(guān)閉串口(CloseComm)、讀串口數據(ReadComm)、寫(xiě)串口數據(WriteComm)等。然后在這些串口函數的基礎上編寫(xiě)MODEM的驅動(dòng)函數。單片機通過(guò)串行口控制MODEM,進(jìn)行撥號、設置等操作??刂品椒ú捎茫粒悦?,例如:ATDT命令用來(lái)?yè)芴?、ATV命令控制MODEM返回值的格式等。在控制MODEM撥打ISP的電?huà)號碼后,MODEM就轉入在線(xiàn)模式(On-Line),此時(shí)微控制器向串行口發(fā)送的所有數據都會(huì )直接傳送給ISP主機。同樣ISP主機的回答也傳回微控制器的串行口??梢哉f(shuō)此時(shí)的MODEM和電話(huà)線(xiàn)建立了一個(gè)從微控制器到ISP的透明數據連接。當數據傳送完成需要斷開(kāi)連接時(shí),微控制器通知MODEM結束會(huì )話(huà),并從在線(xiàn)模式轉回普通的命令模式。這可以通過(guò)置高MODEM的DTR線(xiàn)完成。同時(shí),處于在線(xiàn)模式下微控制器也要不斷檢測CD線(xiàn)是否處于高電平,當線(xiàn)路由于異常斷開(kāi)時(shí),CD線(xiàn)會(huì )回復到平常的低電平。根據這些操作,編寫(xiě)MODEM驅動(dòng)函數:(1)MODEM初始化函數(ModemInit);(2)撥號函數(ModemDial);(3)斷開(kāi)與ISP連接(ModemHangUp);(4)檢測MODEM是否處于在線(xiàn)狀態(tài)(ModemOnLine)等。 這些底層的驅動(dòng)函數將會(huì )使上層協(xié)議的編寫(xiě)很方便;更重要的是,它提供了一個(gè)硬件抽象層。當底層硬件改動(dòng)時(shí),只需要對底層的驅動(dòng)函數改動(dòng),而上層函數的代碼不變。
2 軟件整體結構
2.1 軟件層次結構
程序中的所有代碼都由C語(yǔ)言編寫(xiě),采用分層結構,從底到上分別為:串口驅動(dòng)層、MODEM驅動(dòng)層、PPP協(xié)議層、IP協(xié)議層、UDP協(xié)議層與應用層。上層函數的實(shí)現需要應用到底層函數,而底層函數的任務(wù)就是為上層函數提供服務(wù),最終完成應用層任務(wù),傳送數據。各層的主要函數如圖2所示。

{//串行口中斷處理函數
unsigned char c;
EA = 0;
if(RI)
{
RI = 0;
c = SBUF;//獲得串口數據
if(ModemState == COM)
ProModemCommand(c);//處于命令狀態(tài)
else
ProPPPReceive(c);//處于在線(xiàn)狀態(tài),尋找完整
的PPP報文
}
}

值得注意的是,PPP報文、LCP、PAP、IP報文與UDP報文是互相嵌套的。即PPP報文中嵌入了IP報文和LCP、PAP等報文,而IP報文中嵌入了UDP報文。當PPP報文的協(xié)議符為0021時(shí)表示嵌入了IP數據報,為C021時(shí)表示嵌入LCP數據報,而為C023表示嵌入PAP數據報。PPP報文的基本解析過(guò)程如圖3(b)所示。
3.1 登錄ISP的協(xié)議協(xié)商過(guò)程
系統的難點(diǎn)之一是微控制器登陸ISP并與ISP的協(xié)商過(guò)程,其中需要應用到LCP、PAP與IPCP協(xié)議。LCP、PAP與IPCP協(xié)議的幀結構大同小異,最常用的是請求(REQ)、同意(ACK)和拒絕(NAK)三種幀。微控制器與ISP協(xié)商時(shí),任何一方都可以發(fā)送REQ幀請求某方面的配制,另一方如果覺(jué)得配置不能接受會(huì )回應NAK幀,如果可以接受則回應ACK幀。為了節省資源,這里只處理這三種數據幀,其它鏈路問(wèn)題都由微控制器在程序控制下自己重新?lián)芴柦鉀Q。各種配置選項協(xié)商好以后,PPP才可以成功登陸。
在撥號成功連接后,ISP首先返回一個(gè)PAP REQ數據幀,微控制器發(fā)送一個(gè)空LCP REQ幀以強迫ISP進(jìn)行協(xié)議協(xié)商階段;隨后ISP發(fā)送LCP設置幀,微控制器拒絕所有的設置并請求驗證模式。ISP選擇CHAP或PAP方式驗證,這里只接受PAP方式。然后進(jìn)行PAP驗證用戶(hù)名和密碼過(guò)程,如果成功,ISP會(huì )返回IPCP報文設置IP地址。此時(shí),就完成了與ISP的協(xié)商過(guò)程,可以通過(guò)向ISP發(fā)送IP報文的方式連接互聯(lián)網(wǎng)傳送數據了。協(xié)商過(guò)程的狀態(tài)轉換圖如圖4所示。

相關(guān)推薦
技術(shù)專(zhuān)區
- FPGA
- DSP
- MCU
- 示波器
- 步進(jìn)電機
- Zigbee
- LabVIEW
- Arduino
- RFID
- NFC
- STM32
- Protel
- GPS
- MSP430
- Multisim
- 濾波器
- CAN總線(xiàn)
- 開(kāi)關(guān)電源
- 單片機
- PCB
- USB
- ARM
- CPLD
- 連接器
- MEMS
- CMOS
- MIPS
- EMC
- EDA
- ROM
- 陀螺儀
- VHDL
- 比較器
- Verilog
- 穩壓電源
- RAM
- AVR
- 傳感器
- 可控硅
- IGBT
- 嵌入式開(kāi)發(fā)
- 逆變器
- Quartus
- RS-232
- Cyclone
- 電位器
- 電機控制
- 藍牙
- PLC
- PWM
- 汽車(chē)電子
- 轉換器
- 電源管理
- 信號放大器
評論