Android平台开发-3G RIL模块分析

本文深入探讨了Android RIL层的概念、作用以及与3G模块驱动之间的交互过程,详细解析了RIL守护进程的启动方式、功能库的使用以及与上层框架的通信机制。重点介绍了RIL层如何实现消息的中转,处理不同通信模块的AT命令集不一致的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 ril是radio interface layer的缩写,是android里电话部分很重要的一层,如图:
 
(1) ril层的作用就是消息中转,承上启下,和之前的红外的lirc差不多。
3G模块的驱动就是一个usbserial.ko,USB转串的驱动,insmod后会生成ttyUSB*节点,作为AT命令通道和数据传输通道,至于对应关系还要在研究,是否可以只用一个ttyUSB0还要研究,不过发送at命令至ttyUSB0还是没问题的,
cat /dev/ttyUSB0 &  然后再echo "at+cgmi" > /dev/ttyUSB0会返回
Manufacturer
OK
之所以会要有ril这一层来处理主要是考虑不同的通信模块AT命令集和格式不通,通过ril可以做一个中转,
当上层要打电话或3g上网时,将产生的消息转化为相应的AT命令发送到串口,再传给下层通信模块,反过来,当通信模块把数据传到串口时,ril再解析数据,将之转化为上层可是别的格式,以消息的方式发出,这就是ril的基本功能。

(2)rild守护进程(代码位置/hardware/ril/rild/rild.c)需要在init.rc中启动,
     属于native framework层
         service ril-daemon /system/bin/rild -l /system/lib/libreference-ril.so --
                                  -d /dev/ttyUSB*
         socket rild stream 660 root radio
         socket rild-debug stream 660 radio system
         user root
         group radio cache inet misc audio
         这里通过-l /system/lib/libreference-ril.so指定ril所用的功能库libreference-ril.so,很重要,负责解释上层的命令同时读取解析AT端口ttyUSB*信息,并上报给上层,代码位置/hardware/ril/reference-ril/reference-ril.c,
接下来建立了两个socket,用来和上层的java framework层通信
 socket rild stream 660 root radio
 socket rild-debug stream 660 radio system
 
同时注意到rild在启动的时候,还开启了两个以名称做标识的socket,rild和rild-debug,rild socket就是上层的framework和rild程序通信的手段,而rild-debug socket是留给radiooptions等程序调试使用的,后来这个rild-debug的socket起到了很重要的作用。
 
那rild做了什么呢,这个得在好好读程序分析,现在网上看来就是:
获取ril的参数->打开功能库->建立时间循环线程->执行RIL_Init->RIL_register。
首先从/proc/cmdline 的android.ril=读取tty节点信息,但是我的板子却没有android.ril参数,所以怀疑这是问题的一个关键所在,
代码中有个
#define  KERNEL_OPTION  "android.ril="
不知是要kernel配置是弄好才会产生还是这里加上/dev/ttyUSB0,明天试一下,因为proc文件系统是一个伪文件系统,它只存在内存当中,而不占用外存空间,运行时才产生的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值