對Android源碼分析總結
在Android中進行處理Android源碼中,hardware/ril目錄中包含著Android的telephony源碼,下面就由我向大家介紹這些目錄其中包含了三個子目錄,下面是對三個子目錄進行具體的分析說明。
一、目錄hardware/ril/include分析:
只有一個頭文件ril.h包含在此目錄下。ril.h中定義了76個如下類型的宏:這些宏代表著客戶進程可以向Android源碼telephony發送的命令,包括SIM卡相關的功能,打電話,發短信,網絡信號查詢等。好像沒有操作地址本的功能?
二、目錄hardware/ril/libril分析。本目錄下代碼負責與客戶進程進行交互。在接收客戶進程命令后,調用相應函數進行處理,然后將命令響應結果傳回客戶進程。在收到來自網絡端的事件后,也傳給客戶進程。
文件ril_commands.h:列出了telephony可以接收的命令;每個命令對應的處理函數;以及命令響應的處理函數。 文件ril_unsol_commands.h:列出了telephony可以接收的事件類型;對每個事件的處理函數;
以及WAKE Type??? 文件ril_event.h/cpp:處理與事件源(端口,modem等)相關的功能。ril_event_loop監視所有注冊的事件源,當某事件源有數據到來時,相應事件源的回調函數被觸發(firePending -> ev->func())
listenCallback函數:當與客戶進程連接建立時,此函數被調用。此函數接著調用processCommandsCallback處理來自客戶進程的命令請求processCommandsCallback函數:具體處理來自客戶進程的命令請求。
對每一個命令,ril_commands.h中都規定了對應的命令處理函數(dispatchXXX),processCommandsCallback會調用這個命令處理函數進行處理。dispatch系列函數:此函數接收來自客戶進程的命令己相應參數,并調用onRequest進行處理。
RIL_onUnsolicitedResponse函數:將來自網絡端的事件封裝(通過調用responseXXX)后傳給客戶進程,RIL_onRequestComplete函數:將命令的最終響應結構封裝(通過調用responseXXX)后傳給客戶進程。
response系列函數:對每一個命令,都規定了一個對應的response函數來處理命令的最終響應;對每一個網絡端的事件,也規定了一個對應的 response函數來處理此事件。response函數可被onUnsolicitedResponse或者onRequestComplete調用。
三、目錄hardware/ril/reference-ril分析。本目錄下代碼主要負責與modem進行交互。 文件reference-ril.c:此文件核心是兩個函數:onRequest和onUnsolicited 。
onRequest 函數:在這個函數里,對每一個RIL_REQUEST_XXX請求,都轉化成相應的AT command,發送給modem,然后睡眠等待。當收到此AT command的最終響應后,線程被喚醒,將響應傳給客戶進程(RIL_onRequestComplete -> sendResponse)。
onUnsolicited函數:這個函數處理modem從網絡端收到的各種事件,如網絡信號變化,撥入的電話,收到短信等。然后將時間傳給客戶進程(RIL_onUnsolicitedResponse -> sendResponse)文件atchannel.c:負責向modem讀寫數據。其中,寫數據(主要是AT command)功能運行在主線程中,讀數據功能運行在一個單獨的讀線程中。
Android源碼at_send_command_full_nolock:運行在主線程里面。將一個AT command命令寫入modem后進入睡眠狀態(使用 pthread_cond_wait或類似函數),直到modem讀線程將其喚醒。喚醒后此函數獲得了AT command的最終響應并返回。
函數readerLoop運行在一個單獨的讀線程里面,負責從modem中讀取數據。讀到的數據可分為三種類型:網絡端傳入的事件;modem對當前AT command的部分響應;modem對當前AT command的全部響應。對第三種類型的數據(AT command的全部響應),讀線程喚醒(pthread_cond_signal)睡眠狀態的主線程。
【編輯推薦】