當前位置:首頁 > 嵌入式 > 嵌入式軟件
[導(dǎo)讀]基于SIP協(xié)議棧的嵌入式環(huán)境下的設(shè)計方法介紹

會話初始協(xié)議(SIP協(xié)議)是一種用于IP網(wǎng)絡(luò)多媒體通信的應(yīng)用層控制協(xié)議,可建立、修改、和終止多媒體會話。SIP具有良好的互操作性和開放性,支持多種服務(wù)且具有多媒體協(xié)商能力,能夠在不同設(shè)備之間通過SIP服務(wù)器或其他網(wǎng)絡(luò)服務(wù)器進行交互。同時SIP易于擴展,支持用戶移動性,能夠充分滿足設(shè)備對移動性服務(wù)的需求,而且SIP簡單靈活,計算量小,尤其適合在嵌入式應(yīng)用環(huán)境中應(yīng)用。因此,將SIP引入到嵌入式應(yīng)用中,憑借SIP自身的特性可有效提高嵌入式網(wǎng)絡(luò)設(shè)備的互操作性和接入網(wǎng)絡(luò)的便利性。但SIP協(xié)議本身只給出SIP消息的文法定義以及自然語言描述的消息處理,并未給出SIP協(xié)議棧的實現(xiàn)機制。這里討論在嵌入式終端設(shè)備上建立嵌入式Linux系統(tǒng),并完成SIP的嵌入式,以及代碼的嵌入式移植和測試。

  1 嵌入式LilIHX系統(tǒng)開發(fā)

  1.1 建立交叉編譯環(huán)境

  本文使用的是實驗室的ARMSYS2410-B開發(fā)板。準備好必要的軟件包后,建立交叉編譯環(huán)境實際上就是對cross2.95.3.tar.bz2的解壓過程。具體過程如下:

  1)在編譯Linux之前,先安裝交叉編譯toolclhain,在/usr/local目錄下建立名為ann的目錄,進入該目錄,執(zhí)行解包:

  cd/usr/local/armtar xjvf/mnf/cdrom/linux/toolchain/cross-2.95.3.tar.bz2

  2)編輯/etc/profile,找到pathmunge/usr/local/sbin,在其下面添加一行:

  Pathmunge/usr/local/arm/2.95.3/bin這樣,內(nèi)核或其他應(yīng)用程序均可使用arm-linux-來指定使用該交叉編譯器。

  1.2 Boot Loader移植

  Boot Loader是在嵌入式Linux操作系統(tǒng)內(nèi)核運行之前運行的一段小程序。通過這段程序可以將內(nèi)核從Flash存儲器拷貝到RAM,并執(zhí)行內(nèi)核。還要完成初始化硬件設(shè)備,建立內(nèi)存空間的映射圖,從而將系統(tǒng)的軟硬件環(huán)境帶到一個合適的狀態(tài)。用燒錄軟件jflash-s3c2410通過JTAG口向硬件板下載Boot Loader二進制文件,向硬件板Flash中下載引導(dǎo)程序,這樣Boot Loader就可以成功運行。

  1.3 重新編譯內(nèi)核

  從官方網(wǎng)站上下載的內(nèi)核不能直接在硬件平臺上運行,需要根據(jù)具體的硬件平臺重新裁剪、編譯內(nèi)核,根據(jù)硬件平臺特性編寫相關(guān)代碼,將Linux移植到平臺上。以下是對內(nèi)核代碼的修改:1)修改內(nèi)核目錄樹根下的Makefile,指明交叉編譯器;2)配置Flash分區(qū),修改arch-/arm/mach-s3c2410/devs.c,用以指明分區(qū)信息,該文件的內(nèi)容建立Nand Flash分區(qū)表;修改arch/arm/machs3c2410/machsmdk241-0.c文件指定啟動時初始化,kernel啟動時依據(jù)對分區(qū)的設(shè)置進行初始配置:3)配置和編譯內(nèi)核,在Linux源文件目錄下,執(zhí)行make menuc-onfig命令,配置內(nèi)核產(chǎn)生config文件。然后依次運行#make clean;#make dep;#make zImage,完成對內(nèi)核的編譯。

  2 嵌入式SIP協(xié)議棧的設(shè)計與實現(xiàn)

  2.1 嵌入式下實現(xiàn)SIP協(xié)議棧

  嵌入式環(huán)境下SIP協(xié)議的開發(fā),主要需要考慮嵌入式系統(tǒng)資源有限的局限性,需根據(jù)系統(tǒng)應(yīng)用的特點,在設(shè)計時充分考慮CPU、存儲空間等系統(tǒng)資源的利用。由于資源的限制,嵌入式系統(tǒng)一般作為用戶終端設(shè)備,故這里主要實現(xiàn)協(xié)議棧中用戶代理(UAC/UAS)的功能。

  首先是協(xié)議棧的簡化。根據(jù)RFC3261中定義的SIP協(xié)議棧模型可知,SIP是一個分層體系結(jié)構(gòu)的協(xié)議。該協(xié)議主要由4層組成,底層為語法編解碼層(Syntax&Encoding);第2層是傳輸層(TransportLayer),該層定義網(wǎng)絡(luò)上的客戶機和服務(wù)器如何接收請求和發(fā)送響應(yīng);第3層為事務(wù)層(TransacTIon),負責事務(wù)處理;最上面一層為事務(wù)用戶層(Transaction User),每個SIP實體都是事務(wù)用戶,當一個事務(wù)用戶希望發(fā)送請求時,就創(chuàng)建一個客戶機事務(wù)實例以發(fā)送請求。

  這種協(xié)議棧的設(shè)計實現(xiàn)方法應(yīng)用到嵌入式環(huán)境中有以下不足:1)協(xié)議棧設(shè)計層次過多會增加系統(tǒng)堆棧的開銷。為了不過多占用堆棧,在系統(tǒng)資源分配時需分配較大的堆??臻g。而嵌入式環(huán)境下的空間資源是有限的,SIP模塊占用過多的堆??臻g,會造成其他任務(wù)空間分配受到限制。2)層次與層次之間的調(diào)用會增加系統(tǒng)的延時,降低系統(tǒng)的實效性。而作為用戶終端設(shè)備,快速響應(yīng)是設(shè)計的重要準則。

  2.2 SIP協(xié)議棧的總體結(jié)構(gòu)

  根據(jù)以上分析,在設(shè)計中需對SIP協(xié)議棧進行修改和裁剪,使其盡量少地占用資源并能最大限度地實現(xiàn)快速響應(yīng)。本文設(shè)計的嵌入式SIP協(xié)議棧模型如圖1所示。

  


  協(xié)議棧主要分成傳輸層和事務(wù)層。傳輸層主要負責收發(fā)消息,它管理套接字(socket)和網(wǎng)絡(luò)連接,使用TCP或UDP傳送數(shù)據(jù)。事務(wù)層則負責創(chuàng)建并管理事務(wù)對象。每個事務(wù)對象負責維持狀態(tài),并發(fā)消息和使用傳輸層重傳消息。事務(wù)層也需要將從傳輸層傳來的消息映射到相應(yīng)的事務(wù)。

  SIP協(xié)議棧管理層負責系統(tǒng)配置、分配內(nèi)管理資源、提供登錄協(xié)議棧和進行管理的命令以及所有其他層的初始化和關(guān)閉。應(yīng)用程序使用該協(xié)議棧前,必須先調(diào)用該層的初始化接口以初始化要使用的層,在結(jié)束應(yīng)用程序前,必須調(diào)用該層的關(guān)閉接口關(guān)閉相應(yīng)的層。

  SIP編碼解析是協(xié)議棧運行過程中比較耗費時間的一個模塊,為滿足嵌入式環(huán)境,該協(xié)議棧使用了一種“懶漢”解析策略,當從網(wǎng)絡(luò)上收到一個原始的SIP消息時,消息被解析成很多“關(guān)鍵字和關(guān)鍵字值對”,關(guān)鍵字是請求行或SIP頭域名,關(guān)鍵字值是沒有解析的請求行和頭域值。到事務(wù)層,在應(yīng)用程序要訪問請求行或某個頭域時,才會對其完全解析,這種策略可有效提高SIP解碼的速度,極大提高那些需要處理繁重網(wǎng)絡(luò)流量的應(yīng)用。

  2.3 事務(wù)層和傳輸層的實現(xiàn)

  圖2為事務(wù)層和傳輸層的軟件結(jié)構(gòu)。這2層都使用SIP消息編碼解析層的功能處理SIP消息。其中傳輸層包含3個模塊:1)TcpConn模塊使用TCP實現(xiàn)收發(fā)消息功能;2)UdpConn模塊使用UDP現(xiàn)收發(fā)消息功能;3)SipMessageSendRcv模塊利用TcpConn和UdpConn向應(yīng)用程序提供統(tǒng)一的消息收發(fā)接口。在TcpConn和UdpConn中,都會創(chuàng)建2個線程,分別負責接收和發(fā)送SIP消息。

  

[!--empirenews.page--]
事務(wù)層創(chuàng)建并管理事務(wù)對象。TransacTIonSendRcv提供發(fā)送不同SIP消息的接口,并以回調(diào)函數(shù)的方式在收到消息時通知應(yīng)用程序。Tr-ansactionSendRcv使用傳輸SipMessageSendRcv提供的收發(fā)消息功能收發(fā)SIP消息,并根據(jù)收發(fā)的消息類型產(chǎn)生事件,將事件以及事件體(主要是SIP消息)作為參數(shù)傳遞給相應(yīng)模塊UACTransactFSM和UASTransactlFSM。事務(wù)層的核心就是這2個模塊,分別表示UA客戶端和服務(wù)器端收到不同消息的處理流程,具體的狀態(tài)轉(zhuǎn)換如圖3所示。

  

 

  3 SIP協(xié)議棧的測試結(jié)果

  本文實現(xiàn)的系統(tǒng)將在ARM9平臺的設(shè)備終端上運行,將交叉調(diào)試好的程序燒寫到ARM9的Flash存儲模塊中,再進行調(diào)試和運行測試。其測試方法是在ARM9平臺上實現(xiàn)一個簡單的SIP終端系統(tǒng),該系統(tǒng)利用SIP偵聽程序,當一段用戶發(fā)起呼叫時,雙發(fā)的SIP模塊開始通信。利用SIP信令主動發(fā)起呼叫或接收對方呼叫建立會話連接,連接建立好后傳送RTP數(shù)據(jù),直到一方用戶提出結(jié)束請求,終止該次會話,系統(tǒng)恢復(fù)SIP偵聽狀態(tài)。SIP終端之間呼叫流程如圖4所示,開始時主叫(IP=192.168.36.1)向代理服務(wù)器(IP=192.168.51.24)發(fā)起呼叫,當主叫與被叫的鏈路搭建成功后,主叫與被叫開始語音通信,語音通信采用的標準是G.729,主叫發(fā)送SIP信令給代理服務(wù)器采用UDP傳輸協(xié)議,主叫與代理服務(wù)器之間在SIP呼叫過程中也同時進行媒體協(xié)商,采用網(wǎng)絡(luò)協(xié)議分析工具Ethereal抓包分析,結(jié)果如表l~表3所示。

  

 

  

[!--empirenews.page--]
 由表2可見,代理服務(wù)器向被叫發(fā)起呼叫,并同時對主叫作出響應(yīng)。被叫對呼叫代理作出響應(yīng)主要采用SIP/SDP協(xié)議,是為了使主叫和被叫的媒體協(xié)商達成一致。由表3可見,被叫對主叫所發(fā)起的呼叫能夠作出響應(yīng),主叫與被叫之間能夠?qū)崿F(xiàn)SIP呼叫,并進行語音通信。測試結(jié)果證明,SIP協(xié)議棧在嵌入式Linux系統(tǒng)平臺下,運行良好,基本滿足設(shè)計需要。

  4 結(jié)束語

  本文探討了SIP協(xié)議在嵌入式環(huán)境下的應(yīng)用,討論了嵌入式SIP協(xié)議棧的設(shè)計方法。完成了在ARMSYS2410-B的實驗室開發(fā)板上建立嵌入式Linux系統(tǒng)并在其上實現(xiàn)SIP協(xié)議棧主要模塊的主要工作。測試結(jié)果表明:該協(xié)議棧占用空間小,呼叫建立時間短,呼叫成功率高,滿足嵌入式式設(shè)備對實時性、可靠性和存儲空間小的要求,具有良好的性能。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉