通过深入理解Android Telephony 之RILD机制分析对原生RILD的分析,可以总结成以下三点:
1、RIL_startEventLoop创建s_tid_dispatch主线程,用来监听RILJ下发到socket的消息并分发。
2、RIL_Init创建s_tid_mainloop线程,负责初始化RILD与modem的socket通道,创建s_tid_reader线程来读取modem上报给RILD的信息。
3、RIL_register注册RILD与RILJ之间的socket,并为每个socket注册监听器,把监听的事件添加到s_tid_dispatch线程中。
厂商定制化原生ril,形成vendor ril,就从上面三点来定制。
1、RIL_startEventLoop不需要怎么修改,因为只是负责监听socket是否有消息,然后分发,与具体的消息内容关系不大。
2、RIL_Init负责初始化RILD与modem的socket通道,这里可以定制有多个socket通道,而每个socket都需要有自己的tid_reader线程来读取socket信息,而且可以增加厂商自己的unsolicited type命令。
s_tid_mainloop线程的循环体mainLoop中,打开RILD与modem的socket通道时调用openChannelFds,看看都做了啥
void openChannelFds() {
RILChannelCtx *p_channel;
//遍历支持的通道,然后打开
for (i = 0; i < getSupportChannels(); i++) {