rild進程
rild進程 init.rc中描述:
service ril-daemon /system/bin/rild
class main
socket rild stream 660 root radio
socket rild-debug stream 660 radio system
user root
進程rild.c中:
int main(int argc, char **argv) { const char * rilLibPath = NULL; const RIL_RadioFunctions *(*rilInit)(const struct RIL_Env *, int, char **); RIL_setRilSocketName("rild"); //通過屬性系統獲取lib路徑:rild.libpath
property_get(LIB_PATH_PROPERTY, rilLibPath, NULL);
//動態加載鏈接庫返回句柄 dlclose卸載掉動態鏈接庫
dlHandle = dlopen(rilLibPath, RTLD_NOW);
//創建客戶端事件監聽線程
RIL_startEventLoop();
//通過dlsym定位到需要執行的函數指針
rilInit = (const RIL_RadioFunctions *(*)(const struct RIL_Env *, int, char **))dlsym(dlHandle, "RIL_Init");
//通過屬性系統獲取參數:rild.libargs
property_get(LIB_ARGS_PROPERTY, args, ""); argc = make_argv(args, s_argv); //reference-ril.so初始化 處理客戶端請求的模塊reference-ril.c //s_rilEnv建立應答回調機制 //返回處理請求的相關接口
funcs_inst[0] = rilInit(&s_rilEnv, argc, s_argv);
//多卡模式
if (isMultiSimEnabled() && !isMultiRild()) { } RIL_setMaxNumClients(numClients); //注冊客戶端事件處理接口,並創建socket監聽事件
for (i = 0; i < numClients; i++) { RIL_register(funcs_inst[i], i); } done: while(1) { // sleep(UINT32_MAX) seems to return immediately on bionic
sleep(0x00ffffff); } }
在這里主要是建立ril事件機制對客戶端請求監聽和處理機制。
EventLoop與RequestHandle:ril.cpp與reference-ril.c
EventLoop與RequestHandle兩個模塊要進行通信
按照上面初始化及相關接口注冊過程:
EventLoop向RequestHandle傳遞消息————通過RequestHandle初始化返回的funcs_inst:
funcs_inst[0] = rilInit(&s_rilEnv, argc, s_argv);
返回: s_callbacks 注冊給EventLoop:
注冊: RIL_register(funcs_inst[i], i);
static const RIL_RadioFunctions s_callbacks = {
RIL_VERSION,
onRequest,
currentState,
onSupports,
onCancel,
getVersion
};
RequestHandle向EventLoop傳遞消息————通過初始化RequestHandle時傳遞回調接口:
funcs_inst[0] = rilInit(&s_rilEnv, argc, s_argv);
傳遞s_rilEnv給RIL_Init:
static struct RIL_Env s_rilEnv = {
RIL_onRequestComplete,
RIL_onUnsolicitedResponse,
RIL_requestTimedCallback
};
通過屬性系統獲取ril相關庫的路徑和ril執行相關的參數:
通過build.prop中獲取具體的參數值:
Android的build.prop文件是在Android編譯時收集的各種property(LCD density/語言/編譯時間, etc.),
編譯完成之后,文件生成在out/target/product/<board>/system/build.prop
例如
高通:
rild.libpath=/system/lib/libreference-ril.so
rild.libargs=-d /dev/ttyS0 //終端串口
MTK:
rild.libpath=/system/lib/mtk-ril.so
rild.libargs=-d /dev/ttyC0 //終端串口
通過dlopen加載動態鏈接庫:
dlopen()是一個強大的庫函數。該函數將打開一個新庫,並把它裝入內存。
該函數主要用來加載庫中的符號,這些符號在編譯的時候是不知道的。