??? 摘? 要: 介紹清華嵌入式操作系統(tǒng)的掌上電腦中所使用的IrDial協(xié)議,并提出IrDial協(xié)議在移動互聯(lián)網(wǎng)中的應用模型以及具體的實現(xiàn)方案,。?
??? 關鍵詞: IrDial? PPP協(xié)議棧? Modem命令集? NDIS
?
??? 隨著以計算機技術,、通訊技術、消費電子技術為主的IT產業(yè)的快速發(fā)展和互聯(lián)網(wǎng)的廣泛應用,過去許多由純硬件實現(xiàn)的嵌入式系統(tǒng)與產品已轉向由軟,、硬件共同來實現(xiàn),。當前,以具有無線通訊功能的個人數(shù)字助理PDA、手持個人電腦HPC,、交互式網(wǎng)絡信息家電為代表的新一輪智能型3C(Computer,Communication,Consumer)合一的類PC嵌入式系統(tǒng)與技術[1]進入了一個嶄新的智能化、網(wǎng)絡化的發(fā)展階段,。類PC嵌入式系統(tǒng)[1]與產品所采用的嵌入式操作系統(tǒng)及其應用軟件也同時得到了空前的發(fā)展與繁榮,。?
??? 掌上電腦是一種采用了嵌入式操作系統(tǒng)的設備,它具有強大的功能,正在成為一種越來越普及的集個人信息管理與娛樂功能于一身的攜式設備。但是目前的掌上電腦大多不具有無線上網(wǎng)的功能,。目前業(yè)界看好的采用藍牙技術[7]的無線互聯(lián)方案,由于成本高,、兼容性差,還得不到實際應用。紅外技術是一種成熟的,、低成本的技術,。目前的大多數(shù)掌上電腦和手機都具備紅外設備。因此利用紅外技術來進行無線互聯(lián)就成為一種不錯的選擇,。?
1 IrDial協(xié)議簡介?
??? IrDial協(xié)議是一種為了使支持IrDA協(xié)議棧的設備使用PPP協(xié)議棧與Internet或其它網(wǎng)絡相連而設計的紅外撥號協(xié)議,。IrDial協(xié)議并不是IrDA組織所規(guī)定的標準,它由微軟、諾基牙和愛立信公司共同推出,其目的是為移動設備的互聯(lián)網(wǎng)接入提供一種方便的,、價格低廉的手段,。IrDial協(xié)議除規(guī)定了基于AT命令集的modem撥號協(xié)議外,還規(guī)定了在IrDA協(xié)議中的PPP幀封裝。?
??? IrDial支持兩臺計算機間的直接點對點連接,、計算機-網(wǎng)絡間的訪問點(access point)連接以及計算機-網(wǎng)絡間通過modem的訪問點連接,。?
??? IrDial以兩種模式工作:直接連接(Direct Connect)或撥號連接(Dial Connect): ?
??? · 直接連接模式:用于對網(wǎng)絡和網(wǎng)絡訪問點連接。它忽略撥號信息,直接進入PPP協(xié)議協(xié)商階段,。使用TinyTP service data unit (SDU)[16]進行PPP封裝[17]來成幀,。撥號連接通過modem的網(wǎng)絡訪問點連接。?
??? · 撥號連接模式:通過modem的網(wǎng)絡訪問點連接,。撥號連接模式在進入PPP pass-through模式前必須進行成功的AT撥號命令交換,。使用傳統(tǒng)的PPP 高級數(shù)據(jù)鏈路控制協(xié)議(HDLC)來對數(shù)據(jù)封裝和成幀。?
1.1 直接連接模式?
??? 直接連接有兩種方式:對等網(wǎng)絡中的直接連接和網(wǎng)絡中的直接連接,其網(wǎng)絡協(xié)議模型如圖1和圖2所示,。IrDial協(xié)議工作在IrLMP/TinyTP之上,為PPP協(xié)議提供服務,。?
?
?
?
1.1.1 連接建立?
??? 為初始化一個直接連接模式的連接,客戶必須先調用Information Access Service (IAS)。IAS是一個紅外服務的數(shù)據(jù)庫,它提供了系統(tǒng)所能提供的設備和服務的一個列表,使用GetValueByClass 函數(shù),將參數(shù)中的類名設為 “IrNetv1”,類屬性設為“IrDA:TinyTP:LsapSel”,。然后再初始化一個IrDA Tiny Transport Protocol (TinyTP)連接以返回Link Service Access Point selector(LSAP-SEL),。?
1.1.2? PPP封裝和成幀?
??? 所有的IP(或者其它的網(wǎng)絡協(xié)議)包都以RFC1661中規(guī)定的PPP封裝來進行封裝。以PPP封裝的包直接以TinyTP SDU的格式來成幀,。一個PPP封裝的包可以分成幾個TinyTP 協(xié)議數(shù)據(jù)單元,。?
1.2 撥號連接模式?
??? 撥號連接的網(wǎng)絡協(xié)議模型如圖3所示,。在應用中,由于要使用手機作為無線連接設備,即把手機作為一個外置modem,主要采用撥號連接協(xié)議。?
?
?
1.2.1 連接建立?
??? 為了初始化一個撥號連接模式的連接,客戶必須先執(zhí)行Information Access Service (IAS) GetValueByClass 函數(shù),它的參數(shù)中的類名是“IrModem”,類屬性為“IrDA:TinyTP:LsapSel”,。然后再初始化一個IrDA Tiny Transport Protocol (TinyTP)連接以返回 (LSAP-SEL),。撥號命令和數(shù)據(jù)幀的交換都在TinyTP連接中進行。?
??? MODEM或Host能夠中斷連接,只要發(fā)送一個LM-Disconnect IrLMP消息即可,。?
1.2.2 撥號命令成幀?
??? AT命令序列成幀時要在命令前后加上
1.2.3 PPP封裝和成幀?
??? 所有的IP包都以RFC1661中規(guī)定的PPP封裝來進行封裝,。以PPP封裝的包按RFC1662中規(guī)定的HDLC來進行成幀,。這與TinyTP成幀不同。?
1.3 撥號協(xié)議簡介?
1.3.1 Modem工作模式?
??? Modem有兩種工作模式: ?
??? · 離線命令模式(Offline Command Mode):在此模式下沒有電話撥號,Modem正在接收AT命令,。會話正是在這種模式下被啟動,。 ?
??? · 在線數(shù)據(jù)模式(Online Data Mode): 在此模式下,有一個電話連接,modem能夠接收和傳輸數(shù)據(jù);只有一個命令+++ATH能被傳送。?
1.3.2 在IrDial中使用的AT命令?
??? AT命令在TinyTP幀中傳輸,。不能把一個AT命令字符串分成幾部分在幾個幀中傳輸,。但是可以在一個幀中傳輸幾個AT命令,這時命令的間隔必須符合V.25ter中的規(guī)定?;貜秃蛻饎t沒有這個限制,可以在幾個TinyTP幀中傳輸,。?
??? 所有的命令必須以
???
1.3.3 鏈接控制命令?
??? (1) ATD,, Dial?
??? 這個命令初始化一個數(shù)據(jù)呼叫,后跟電話號碼和其它符號來建立一個連接,。在ATD連接過程中,接收到CONNECT前發(fā)送任何字符就可以放棄連接。?
??? 命令執(zhí)行的格式如下:?
??? D
??? (2) ATH,, Hook Control. 中斷一個連接。?
??? (3) ATA,, Answer. 應答呼入的數(shù)據(jù)呼叫,。為了接收呼入的數(shù)據(jù)呼叫,Modem必須是以IrDA連接并且處于離線命令模式。如果有一個呼入呼叫,modem以如下形式發(fā)送一個結果代碼:?
?? ?
??? 然后就可以使用ATA來應答呼入的數(shù)據(jù)呼叫,。?
1.3.4初始化命令?
??? AT+DS 數(shù)據(jù)壓縮模式(Data Compression Mode),。?
??? 定義了V.42bis使用的壓縮參數(shù)和協(xié)議。?
??? 命令格式如下:?
??? +DS=[
??? 關于modem撥號的詳細文檔可以參考Windows Modem設備驅動開發(fā)包的幫助文檔[13],。?
2 IrDial協(xié)議的應用模型?
??? IrDial協(xié)議設計是為方便具有紅外設備的移動裝置能夠通過帶紅外設備的移動通信設備實現(xiàn)與網(wǎng)絡的互聯(lián)。這里的移動裝置可以是掌上電腦和筆記本電腦等,。最常用的移動通信設備是手機,。大多數(shù)的掌上電腦和筆記本電腦都具有紅外端口,。目前已經有越來越多的手機開始支持紅外通信方式。目前的手機上網(wǎng)采用WAP方式,但是由于WAP所能提供的網(wǎng)絡服務內容十分有限,而且在手機的小屏幕上來瀏覽網(wǎng)絡的內容十分不便,。使用IrDial協(xié)議則可以把手機作為一個無線的Modem,直接可以通過撥號ISP來瀏覽WWW頁面的內容,。這對于那些攜帶筆記本和掌上電腦,經常需要在外面跑的人來說很重要。這種方式使它們可以在任何時候,、任何地方,只要有一個支持紅外通信和IrDial協(xié)議及數(shù)據(jù)通信的手機就可以很容易地實現(xiàn)上網(wǎng)瀏覽,、收發(fā)郵件等。
??? IrDial協(xié)議的應用模型如圖4所示,。 ?
?
?
??? 在圖4的模型中,筆記本與手機通過紅外通信來進行數(shù)據(jù)交換,。手機通過無線網(wǎng)絡訪問ISP服務器,并通過ISP服務器訪問WWW服務器。處理流程如下:?
??? (1)筆記本與手機間建立紅外連接;?
??? (2)筆記本在已建立的紅外連接上,通過IrDial協(xié)議向手機發(fā)送AT命令進行撥號;?
??? (3)手機接收AT命令并向ISP服務器撥號;?
??? (4)撥號成功,則在筆記本和ISP間建立一個網(wǎng)絡連接,。?
??? 然后用戶就可以使用筆記本上的瀏覽器來進行網(wǎng)絡的瀏覽了。由圖4可以看出,要實現(xiàn)通過IrDial的無線上網(wǎng),要求筆記本(掌上電腦)和手機必須都支持IrDial協(xié)議,。目前大部分的筆記本電腦和掌上電腦都帶有紅外裝置,以方便信息的交換,。但是要通過紅外手機上網(wǎng)還需要安裝新的驅動程序。在Windows系統(tǒng)上,一般是將紅外手機看做是一個Modem,將其按照Modem驅動程序的設計規(guī)范來實現(xiàn),。手機除了要具有紅外裝置,支持IrDial協(xié)議外,還必須開通數(shù)據(jù)服務功能,。只有這樣,系統(tǒng)才能夠實現(xiàn)無線上網(wǎng)。?
3 IrDial協(xié)議的實現(xiàn)方案?
??? IrDial協(xié)議實際上包括兩部分:在移動通信設備上的實現(xiàn)和在便攜式設備如掌上電腦上的實現(xiàn),。目前大多數(shù)的手機都支持IrDial協(xié)議,即可以作為一個外置的紅外modem,因此這一部分的實現(xiàn)由手機廠商完成,。在便攜式設備如掌上電腦上的實現(xiàn),根據(jù)所采用的操作系統(tǒng)的不同,筆者采用了Windows CE操作系統(tǒng)。?
??? Windows CE操作系統(tǒng)支持NDIS網(wǎng)絡驅動程序接口規(guī)范[14,19],NDIS支持IRDA協(xié)議,。這使用戶可以使用NDIS所提供IRDA協(xié)議函數(shù)來實現(xiàn)紅外撥號協(xié)議,。在NDIS中可以包含一個miniport的可插入模塊,采用miniport的方式將IrDial協(xié)議加入到IRDA協(xié)議棧中。在IrDial的小端口驅動程序中,其上層接口為PPP協(xié)議,下層接口為IRDA協(xié)議,。IrDial的小端口驅動程序負責PPP協(xié)議和IRDA協(xié)議之間的數(shù)據(jù)包的轉換,。?
??? 本文介紹了IrDial協(xié)議及其應用和實現(xiàn)。IrDial協(xié)議為用戶提供了一種通過紅外方式來進行無線網(wǎng)絡接入的方式,。與其它無線互聯(lián)方案相比,采用IrDial協(xié)議有它獨特的優(yōu)點,。首先它是一種價格低廉、易于實現(xiàn)的無線解決方案,目前的大多數(shù)移動終端設備(筆記本和掌上電腦)都具有紅外設備,只需要添加IrDial協(xié)議的實現(xiàn)就可以了;而使用WAP方式進行無線聯(lián)網(wǎng)則需要運營商增加新的設備,成本較高,。其次,使用它不僅可以瀏覽WAP網(wǎng)頁,也可以瀏覽WWW網(wǎng)頁,而使用WAP方式的無線互聯(lián)方案則只能瀏覽WAP網(wǎng)頁,。此外,由于大多數(shù)手機、掌上電腦和筆記本電腦都支持紅外通信,使其實現(xiàn)更加簡單,成本更低,。目前已經有很多支持IrDial的產品出現(xiàn),。?
參考文獻?
1 梁金千.清華嵌入式操作系統(tǒng)的設計與實現(xiàn).清華大學碩士研究生論文,2001年4月?
2 梁金千,張躍,甄成.Linux設備驅動程序的設計與實現(xiàn),計算機應用,2001,(12)?
3 Liang Jinqian, Zhang Yue.The Description of HAL in?Embedded OS.International Conference on eCommerce Engineering:New Challenges for Global Manufacture in the 21?Century. 2001.?
4 Zhen Chen,, Zhang Yue,Liang Jinqian. Design and Implementation of File System With Real-time Data Compression.International Conference on eCommerce Engineering:New Challenges for Global Manufacture in the 21 Century.2001.?
5 劉森,何希順,何榮森.HPC相關新技術的發(fā)展及其應用.電子技術應用,2000,26(12)?
6 劉森,何希順,慕春棣.掌上電腦研制中的關鍵技術,電子產品世界,2001,(4),。?
7 何榮森,王宏寶,張躍.Bluetooth(藍牙)協(xié)議體系結構和硬件設計.電子技術,2001,(10)?
8 張 躍,慕春棣.數(shù)字電視系統(tǒng).計算機世界,2001,(7):C1~C6?
9 張 躍,張衍圣.現(xiàn)行數(shù)字電視的局限性.計算機世界,2001,(7):C7?
10 張 躍,施 陽.清華-賽格高清晰度數(shù)字電視HDTV.計算機世界,2001,(7)C8~C9?
11 張 躍,梁金千.數(shù)字電視向何處去.計算機世界,2001,(7):C9?
12 IrDial:PPP Over IrDA. microsoft?
13 Preliminary Windows Modem Device Driver Kit. Microsoft?
14 Window CE驅動程序開發(fā).Microsoft Press,,1999?
15 IRDA TTP: Tiny Transport Protocol, TinyTP,, Version?1.0,, Infrared Data Association?
16 RFC 1661: Point-to-Point Protocol (PPP)?
17 RFC 1662: PPP in HDLC-like Framing?
18 V.25ter:ITU-T Recommendation for datacom. over the?telephone network: Serial Asynchronous Automatic Dialing?and Control?
19 Infrared Extensions to the NDIS Version 4.0 Functional?Specification. MSDN of Microsoft Visual Studio