android vendor 机制,深入理解Android Telephony 之vendor ril

本文详述了Android Telephony中RIL Daemon(RILD)的工作原理,包括RIL_startEventLoop的事件分发、RIL_Init的通道初始化与消息读取以及RIL_register的命令注册。在厂商定制的vendor ril中,主要针对RIL_Init的socket通道与RIL_register的自定义AT命令进行扩展,以适应不同硬件和功能需求。同时,onUnsolicited回调函数处理了自定义的未请求响应。
摘要由CSDN通过智能技术生成

通过深入理解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++) {

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值