我们平板项目从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,整个调用栈就全打印出来了。
看到调用流程之后,再从上面开始整理一下。
&nbs

本文介绍了在Android 4.1及以上版本中,平板项目无法读取SIM卡短信的问题。问题源于Android对SIM卡短信的数据库抽象及管理,通过AsyncQueryHandler启动查询,但在RIL_REQUEST_SIM_IO命令处理时出现兼容性问题。在Android 4.1的代码中,由于缺少对data[RESPONSE_DATA_FILE_TYPE]==0的判断,导致无法读取短信。通过对日志中data数据的分析,发现此处数据为0,触发了异常,从而揭示了解决问题的关键。

1014

被折叠的 条评论
为什么被折叠?



