我们平板项目从android4.1开始就读不到SIM卡短信了,包括s203, s77, s88(android 4.2)都是这样。S203 andorid 4.0的版本是没有这个问题的,而4.0和4.1用的ril代码基本一样,所以应该不是ril库的问题。所以看了下读SIM卡短信的流程,现整理如下:
首先最上面肯定是从Mms Apk中开始,3G模块正常工作且检测到SIM卡之后,Mms的设置菜单中会有一个管理Sim卡短信的选项,点击可以打开SIM卡短信管理的界面。这个界面一个叫ManageSimMessages 的 activity.
在该activity的onCreate中,可以看到,使用了一个 AsyncQueryHandler的异步查询框架。当时看到这个地方就开始没头绪了,因为这个类算是android的系统API,这里只能看到调了startQuery和 onQueryComplete,没法看到startQuery之后如何工作的。
上层没线索了,就从最下层开始。查SIM卡短信,其实是给模块发AT+CRSM命令,ril HAL里面看,是Framework里面下发RIL_REQUEST_SIM_IO这个命令。所以到frameworkRIL.java里面找这个命令,可以很容易追到这个命令的地方。但是从Mms里面的startQuery怎么调到这个地方的还是很难追踪,这种情况有个小技巧,在这个地方写个空指针爆掉的操作,然后去看mainlog,整个调用栈就全打印出来了。
看到调用流程之后,再从上面开始整理一下。
从调用栈来看,A