探秘Android GSM的特性說明
但是,我們認(rèn)為全球移動(dòng)用戶從中能獲得的潛在利益是值得付出這些努力的。如果你也是一個(gè)開發(fā)者,并對(duì)我們的想法感興趣,就請(qǐng)?jiān)俳o我們一星期的時(shí)間,屆時(shí)谷歌便能提供 Android GSM了。
這個(gè)任務(wù)的入口是RIL_Init, RIL_Init首先通過參數(shù)獲取硬件接口的設(shè)備文件或模擬硬件接口的socket. 接下來便新開一個(gè)線程繼續(xù)初始化, 即mainLoop。mainLoop的主要任務(wù)是建立起與硬件的通信,然后通過read方法阻塞等待硬件的主動(dòng)上報(bào)或響應(yīng)。在注冊(cè)一些基礎(chǔ)回調(diào)(timeout,readerclose)后。
mainLoop首先打開硬件設(shè)備文件,建立起與硬件的通信,s_device_path和s_port是前面獲取的設(shè)備路徑參數(shù),將其打開(兩者可以同時(shí)打開并擁有各自的reader,這里也很容易添加雙卡雙待等支持)。
接下來通過at_open函數(shù)建立起這一設(shè)備文件上的reader等待循環(huán),這也是通過新建一個(gè)線程完成, ret = pthread_create(&s_tid_reader, &attr, readerLoop, &attr),入口點(diǎn)readerLoop。
AT命令都是以\r\n或\n\r的換行符來作為分隔符的,所以readerLoop是line驅(qū)動(dòng)的,除非出錯(cuò),超時(shí)等,否則會(huì)讀到一行完整的響應(yīng)或主動(dòng)上報(bào),才會(huì)返回。這個(gè)循環(huán)跑起來以后,我們基本的AT響應(yīng)機(jī)制已經(jīng)建立了起來。它的具體分析,包括at_open中掛接的ATUnsolHandler, 我們都放到后面分析response的連載文章里去。
有了響應(yīng)的機(jī)制(當(dāng)然,能與硬件通信也已經(jīng)可以發(fā)請(qǐng)求了),通過RIL_requestTimedCallback(initializeCallback, NULL, &TIMEVAL_0),跑到initializeCallback中,執(zhí)行一些Modem的初始化命令,主要都是AT命令的方式。
AT命令的流程,我們放到后面分析request的連載文章里。這里可以看到,主要是一些參數(shù)配置,以及網(wǎng)絡(luò)狀態(tài)的檢查等。其中最重要的是onRequest域,上層來的請(qǐng)求都由這個(gè)函數(shù)進(jìn)行映射后轉(zhuǎn)換成對(duì)應(yīng)的AT命令發(fā)給硬件。
rild通過RIL_register注冊(cè)這一指針。RIL_register中要完成的另外一個(gè)任務(wù),就是打開前面提到的跟上層通信的socket接口(s_fdListen是主接口,s_fdDebug供調(diào)試時(shí)使用)。然后將這兩個(gè)socket接口使用任務(wù)一中實(shí)現(xiàn)的機(jī)制進(jìn)行注冊(cè)(僅列出s_fdListen)ril_event_set (&s_listen_event, s_fdListen, false,
這樣將兩個(gè)Android GSM加到任務(wù)一中建立起來多路復(fù)用I/O的檢查句柄集合中,一旦有上層來的(調(diào)試)請(qǐng)求,event機(jī)制便能響應(yīng)處理了。rr是以RIL_REQUEST_DIAL為request號(hào)而申請(qǐng)的一個(gè)RILRequest對(duì)象.這個(gè)request號(hào)在java框架和rild庫(kù)中共享(參考RILConstants.java中這些值的由來:)
RILRequest初始化的時(shí)候,會(huì)連接名為rild的socket(也就是rild中s_listen_event綁定的socket),初始化數(shù)據(jù)傳輸?shù)耐ǖ馈r.mp是Parcel對(duì)象,Parcel是一套簡(jiǎn)單的序列化協(xié)議,用于將對(duì)象(或?qū)ο蟮某蓡T)序列化成字節(jié)流,以供傳遞參數(shù)之用。
這里可以看到Android GSM和int clirMode都是將依次序列化的成員.在這之前,rr初始化的時(shí)候,request號(hào)跟request的序列號(hào)(自動(dòng)生成的遞增數(shù)),已經(jīng)成為頭兩個(gè)將被序列化的成員.這為后面的request解析打下了基礎(chǔ)。
【編輯推薦】