Web服務(wù)在TM1300上的實(shí)現(xiàn)
系統(tǒng)的核心是運(yùn)行pSOS操作系統(tǒng)的TM1300芯片。視頻輸入和輸出接口利用TM1300本身提供的視頻輸入/輸出單元,結(jié)合外圍的視頻A/D、D/A芯片共同完成。其中,視頻A/D使用Philips公司的SAA7111,而D/A則使用SAA7121。它們可以與TM1300進(jìn)行無(wú)縫連接。事實(shí)上,所有與CCIR656/CCIR601兼容的視頻A/D、D/A芯片均可以直接與TM1300的視頻輸入輸出單元相連。
音頻輸入/輸出接口上的A/D、D/A芯片采用了Analog Devices公司的AD1849立體聲處理芯片。AD1849是16位串行接口立體聲信號(hào)編解碼器。它具有多個(gè)輸入通道和輸出通道,支持μ率PCM、A率PCM、16位線性PCM和8位無(wú)符號(hào)PCM四種編碼方式。
除音頻、視頻接口外,還設(shè)計(jì)了基于CS8900的以太網(wǎng)接口,以便能將多媒體處理的結(jié)果直接發(fā)送到以太網(wǎng)。RS-232接口是本設(shè)計(jì)的另一個(gè)通用接口,計(jì)算機(jī)可以通過(guò)該接口對(duì)系統(tǒng)的運(yùn)行進(jìn)行控制,并獲取系統(tǒng)運(yùn)行狀況。
在實(shí)際應(yīng)用過(guò)程中,由于用戶的需求各不相同且經(jīng)常變化,這就要求多媒體處理平臺(tái)的參數(shù)需要經(jīng)常調(diào)整,某些時(shí)候還需要實(shí)時(shí)調(diào)整。盡管這些功能可以通過(guò)RS-232接口實(shí)現(xiàn),但這要求操作人員到現(xiàn)場(chǎng)用計(jì)算機(jī)對(duì)多媒體處理平臺(tái)進(jìn)行控制,很不方便。為此,設(shè)計(jì)一個(gè)嵌入式Web服務(wù)器,利用網(wǎng)絡(luò)對(duì)整個(gè)平臺(tái)進(jìn)行控制成為一種必然的選擇。一方面它可以為用戶提供可視化的圖形界面,方便用戶進(jìn)行各種參數(shù)控制;另一方面,用戶可以在任何時(shí)間對(duì)參數(shù)進(jìn)行調(diào)整,滿足自己的需要。
1 嵌入式Web服務(wù)器開(kāi)發(fā)的難點(diǎn)
談到Web服務(wù)器,人們自然會(huì)想到目前常見(jiàn)的Web服務(wù)器, 如Windows IIS、Apache、CERN Server、Netscape
Enterprise Server等。由于這些服務(wù)器程序的功能非常強(qiáng)大,通常需要在高性能計(jì)算機(jī)上運(yùn)行,以便為用戶提供高速、并發(fā)的訪問(wèn)。
相對(duì)于計(jì)算機(jī)上運(yùn)行的Web服務(wù)程序,在TM1300上運(yùn)行的Web服務(wù)有很多獨(dú)特的特點(diǎn):
首先,盡管TM1300的運(yùn)算處理能力非常強(qiáng)大,但由于其主要功能是完成多媒體信息的處理,使得Web服務(wù)所能使用的系統(tǒng)資源非常有限。這就意味著不能將傳統(tǒng)的Web服務(wù)程序直接移植到TM1300上,而必須對(duì)其功能進(jìn)行裁減,去除那些不需要的功能,減少其對(duì)資源的要求,提高運(yùn)行效率。
其次,TM1300沒(méi)有自己的文件系統(tǒng),這就意味著不能依賴文件系統(tǒng)來(lái)保存網(wǎng)頁(yè),而必須要Web服務(wù)器自己來(lái)維護(hù)和提供不同功能的網(wǎng)頁(yè)。
此外,由于該Web服務(wù)主要用于控制多媒體平臺(tái)的運(yùn)行參數(shù),通常情況下不會(huì)有很大的外部訪問(wèn)流量。因此Web服務(wù)器的功能相對(duì)簡(jiǎn)單。
根據(jù)以上特點(diǎn),筆者設(shè)計(jì)了在TM1300上運(yùn)行的Web服務(wù)器程序。該程序首先對(duì)接收到的HTTP消息進(jìn)行解析,然后調(diào)用不同的處理程序進(jìn)行處理,最后將處理的結(jié)果以HTTP消息的方式回送給瀏覽器。
2 Web服務(wù)在TM1300上的實(shí)現(xiàn)
本W(wǎng)eb服務(wù)程序主要負(fù)責(zé)接收IE瀏覽器發(fā)送的請(qǐng)求,然后對(duì)請(qǐng)求進(jìn)行分析和處理,并將處理結(jié)果以HTML方式返回給瀏覽器。核心是對(duì)HTTP請(qǐng)求進(jìn)行分析。下面以修改圖像編碼尺寸為例,介紹具體的實(shí)現(xiàn)方法。
假定在某個(gè)時(shí)刻用戶希望修改多媒體平臺(tái)所處理的圖像尺寸,于是通過(guò)IE瀏覽器訪問(wèn)所設(shè)計(jì)的Web服務(wù)器,得到圖2(a)所示的界面。當(dāng)用戶在文本框中輸入合適的數(shù)值后,點(diǎn)擊“確定”按鈕,IE瀏覽器將向Web服務(wù)器發(fā)送圖2(b)所示的HTTP報(bào)文。
其中最重要的是第一行和最后一行。在第一行中,/changimagesize 告訴服務(wù)器程序用戶希望修改圖像尺寸。最后一行中的xsize=352和ysize=288表示新的圖像尺寸。由于 HTTP數(shù)據(jù)包是純文本格式[1],因此在Web服務(wù)程序需要對(duì)第一行文本進(jìn)行分析,取出字符串“POST”和“HTTP”之間的字符串即可判斷出用戶操作的類型。
接下來(lái)需要從HTTP頭信息[2]中,找到Content-Length這一行。如果Content-Length=0,則表明后面沒(méi)有參數(shù),否則在這個(gè)HTTP數(shù)據(jù)包中包含用戶提交的信息,并且信息的長(zhǎng)度值就是Content-Length的值。
假定用戶在HTTP消息中帶有消息體,那么首先要找到一個(gè)空白行(即:Cache-Control:no-cache后面一行),因?yàn)樗窍Ⅲw和HTTP頭信息的分界線。接下來(lái)需要分析消息主體的內(nèi)容。這方面的工作非常簡(jiǎn)單,就是根據(jù)字符‘&’將文本串分為三部分,即:xsize=352,ysize=288,submit=%CC%E1%BD%BB。然后根據(jù)字符‘=’進(jìn)一步區(qū)分參數(shù)的名稱和對(duì)應(yīng)的值。通過(guò)分析知道參數(shù)xsize的值為352,ysize的值為288。
通過(guò)對(duì)HTTP消息的解析,可以確定用戶需要完成的操作及操作所需要的參數(shù),進(jìn)而可以對(duì)底層的硬件或軟件進(jìn)行控制,以完成用戶的請(qǐng)求。
由此可以看出,服務(wù)器程序的核心工作就是對(duì)HTTP數(shù)據(jù)包解析,決定下一步的處理。針對(duì)上面的例子,Web服務(wù)程序首先要對(duì)視頻輸入輸出接口進(jìn)行控制,改變輸入輸出圖像的尺寸;接下來(lái)還要輸出HTTP數(shù)據(jù)包送給IE瀏覽器,圖3給出了Web服務(wù)程序產(chǎn)生的HTTP數(shù)據(jù)包及用戶看到的界面。
圖3(a)是服務(wù)器回送給IE瀏覽器的HTTP消息。第一行HTTP/1.1 200 OK通知IE瀏覽器,剛才的請(qǐng)求已經(jīng)被服務(wù)器處理。下面一行是服務(wù)器的處理時(shí)間。 Content-type:text/html這一行通知IE瀏覽器HTTP消息主體部分傳送的內(nèi)容是純文本格式的HTML網(wǎng)頁(yè)。后面的空行是HTTP頭信息與HTTP消息主體的分界線。當(dāng)IE瀏覽器獲取HTTP頭信息后,就可以根據(jù)消息主體的格式調(diào)用對(duì)應(yīng)的HTML解析器對(duì)內(nèi)容進(jìn)行解析,并將解析的結(jié)果顯示在瀏覽器的窗口中。
3 Web服務(wù)進(jìn)程與其他進(jìn)程間的通信
由于多媒體處理平臺(tái)需要同時(shí)進(jìn)行音頻、視頻處理及網(wǎng)絡(luò)通信,即在同一個(gè)時(shí)刻需要有多個(gè)任務(wù)同時(shí)運(yùn)行,并且這些任務(wù)之間需要進(jìn)行通信,例如:當(dāng)用戶改變了系統(tǒng)編碼參數(shù)后,Web服務(wù)器需要通知視頻編碼進(jìn)程,讓它們?cè)诤罄m(xù)的編碼過(guò)程中采用新的參數(shù)。由于TM1300運(yùn)行pSOS系統(tǒng),而pSOS只有進(jìn)程,沒(méi)有線程,因此Web服務(wù)程序作為一個(gè)單獨(dú)的進(jìn)程來(lái)運(yùn)行。當(dāng)需要與其他任務(wù)通信時(shí),采用了信號(hào)量方法。圖4以Web服務(wù)進(jìn)程和視頻編碼進(jìn)程之間的通信為例,給出了系統(tǒng)實(shí)現(xiàn)進(jìn)程間通信的過(guò)程。
首先在Flash中開(kāi)辟一塊區(qū)域,專門用來(lái)存儲(chǔ)所需修改的參數(shù)。當(dāng)Web服務(wù)器接收到客戶端提交的修改參數(shù)的請(qǐng)求時(shí),采用以下步驟進(jìn)行處理:(1)Web服務(wù)進(jìn)程將信號(hào)量鎖定;(2)Web服務(wù)進(jìn)程將用戶提交的參數(shù)寫(xiě)入到參數(shù)區(qū);(3)Web服務(wù)器進(jìn)程釋放信號(hào)量;(4)Web服務(wù)進(jìn)程向視頻處理進(jìn)程發(fā)送信號(hào)[3],通知視頻編碼進(jìn)程讀取參數(shù);(5)視頻處理進(jìn)程將信號(hào)量鎖定;(6)視頻處理進(jìn)程讀取參數(shù);(7)視頻處理信號(hào)釋放信號(hào)量。經(jīng)過(guò)一系列操作后,Web服務(wù)器進(jìn)程和視頻編碼進(jìn)程間的通信結(jié)束,完成了一次參數(shù)的修改。Web服務(wù)進(jìn)程與音頻編碼進(jìn)程間的通信與上述過(guò)程類似。
本文重點(diǎn)探討了在TM1300上實(shí)現(xiàn)嵌入式Web服務(wù)器的方法與具體實(shí)現(xiàn)中的一些關(guān)鍵問(wèn)題。通過(guò)在現(xiàn)有的多媒體處理平臺(tái)中增加Web服務(wù),用戶可以采用Web頁(yè)面的方式來(lái)監(jiān)控硬件的運(yùn)行狀態(tài),并能對(duì)系統(tǒng)運(yùn)行參數(shù)進(jìn)行在線修改,降低了系統(tǒng)的使用難度,提高了交互的友好性,進(jìn)而增強(qiáng)了系統(tǒng)的功能和可用性。目前,筆者開(kāi)發(fā)的Web服務(wù)已經(jīng)在TM1300上穩(wěn)定運(yùn)行,下一步工作主要是擴(kuò)充其功能,并提供網(wǎng)管功能。
參考文獻(xiàn)
1 RFC 822.Standard for ARPA Internet Text Messages[s].1982
2 RFC2616.Hypertext Transfer Protocol----HTTP/1.1[s].1999
3 W. Richard Stevens著,尤晉元譯. UNIX環(huán)境高級(jí)編程.北京:機(jī)械工業(yè)出版社,2000