分类: LINUX
2009-11-19 15:42:26
Android 无线接口层(Radio Layer Interface)
INDEX
介绍
RIL 初始化
RIL 交互
主动请求
被动请求
实现RIL
RIL初始化
RIL函数
RIL 主动命令请求
RIL 被动请求的命令
实现RIL
为了实现一个通讯专用RIL,需要执行一系列函数以创建一个共享库,保证Android能够相应无线通信请求。所需要的函数被定义在RIL头部(/include/telephony/ril.h)
Android通讯接口是通讯无关的,Vendor RIL可以使用任意协议进行无线通讯。Android提供了一个参考Vendor
RIL,使用的是贺式(Hayes)AT命令设备,可作为一个商用的快速入门指导以及通讯测试使用。RIL参考源码在/commands
/reference-ril/。
通常将你自己的Vendor RIL编译为以下形式:
libril-
比如:
libril-acme-124.so
其中:
libril:所有vendor RIL的开头;
so:文件扩展
RIL初始化
特定的Vendor RIL必须定义一个初始化函数,提供一系列句柄函数以处理每一个通讯请求。Android RIL守护进程会在启动时调用RIL_Init以初始化RIL。
RIL_RadioFunctions *RIL_Init (RIL_Env* env, int argc, char **argv);
RIL_Init 返回一个RIL_RadioFunctions结构体包含无线电函数指针。
type structure {
int RIL_version;
RIL_RequestFunc onRequest;
RIL_RadioStateRequest onStateRequest;
RIL_Supports supports;
RIL_Cancel onCancel;
RIL_GetVersion getVersion;
}
RIL_RadioFunctions;
RIL函数
ril.h定义了RIL状态和变量,比如RIL_UNSOL_STK_CALL_SETUP, RIL_SIM_READY, RIL_SIM_NOT_READY,具体函数描述见下表。忽略头文件细节。
RIL主动命令请求
Vendor RIL必须提供下表中的函数用以发送主动命令。RIL主动命令请求类型定义在ril.h的RIL_REQUEST_prefix中。
名称
描述
void (*RIL_RequestFunc) (int request, void *data, size_t datalen, RIL_Token t);
RIL主动命令入口指针,必须能够处理各种RIL主动请求(定义于ril.h的RIL_REQUEST_ prefix)
* request 是一种 RIL_REQUEST_*
* data 是一个指向RIL_REQUEST_*数据的指针
* t 应当被用于RIL_onResponse的后续调用
* datalen 由调用者所有,应当由被调者修改或释放
必须调用RIL_onRequestComplete()函数完成通讯。?RIL_onRequestComplete()
在这个函数返回前或之后可能被任意线程调用。这个函数总会调用同一个线程,因此返回到这里意味着无线通讯准备去处理其他命令(无论前面命令是否完成传
输)。
RIL_RadioState (*RIL_RadioStateRequest)();
这个函数应该返回当前通讯同步状态
int (*RIL_Supports)(int requestCode);
如果提供指定RIL_REQUEST代码,返回1,否则返回0.
void (*RIL_Cancel)(RIL_Token t);
本函数用来指示取消一个待处理请求。函数将被一个独立线程所调用,而不是RIL_RequestFunc函数。
一旦取消,被调用者应当尽量放弃请求并在这之后调用RIL_onRequestComplete 函数的RIL_Errno CANCELLED 。
响应请求后调用 RIL_onRequestComplete 并产生其他结果是可以被接受的,但会被忽略(理应忽略被取消的请求)。
RIL_Cancel 调用应该被立刻返回,不需要等待取消。
const char * (*RIL_GetVersion) (void);
向你的Vendor RIL返回版本字符串
Vendor RIL使用以下回调函数与Android RIL守护进程通讯。
名称
描述
void RIL_onRequestComplete(RIL_Token t, RIL_Errno e, void *response, size_t responselen);
* t 是之前通讯传递至RIL_Notification的参数
* 如果e != SUCCESS,则可以没有相应,并且被忽略
* response 由调用者所有,应当由被调用者修改或者释放。
* RIL_onRequestComplete 将尽快返回