• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
yuzaipiaofei
博客园    首页    新随笔    联系   管理    订阅  订阅

Android RIL CDMA分支总结(1)

Android RIL CDMA分支总结(1)

      

1. CDMA分支代码结构

代码结构如下:
ril
|-- include
| `-- telephony
| |-- ril.h
| `-- ril_cdma_sms.h
|-- libril
| |-- ril.cpp
| |-- ril_commands.h
| |-- ril_event.cpp
| |-- ril_event.h
| `-- ril_unsol_commands.h
|-- reference-cdma-sms
| |-- reference-cdma-sms.c
| `-- reference-cdma-sms.h
|-- reference-ril
| |-- at_tok.c
| |-- at_tok.h
| |-- atchannel.c
| |-- atchannel.h
| |-- misc.c
| |-- misc.h
| `-- reference-ril.c
`-- rild
|-- radiooptions.c
`-- rild.c

 

reference-ril->libference-ril.so 主要负责modem通信(包含通话、上网、短信以及modem初始化功能等等)

 

rild -> rild  rild守护进程,是整个android ril层的入口点。

 

libril -> libril.so rild的共享库,驻留在rild中,完成和上层通信的工作,接受ril请求并传递给libreference-ril.so来通知modem,与此同时将其反馈回传给调用进程。

 

radiooptions -> radiooptions  无线通信测试程序。

 

reference-cdma-sms -> cdma模组特殊定义用于cdma(evdo)通信使用,主要定义短信接口(实现短息的编码解码工作)。

 

 

2.AT从界面到模组流程

 

通话外例:

 

按通话图标->>

DialtactsActivity(4个Tab 分别由TwelveKeyDialer<拨号>、RecentCallsListActivity<最近联系人>,两个activity-alias DialtactsContactsEntryActivity<联系人>和DialtactsFavoritesEntryActivity<收藏>)

 

输入拨号号码

TwelveKeyDialer

 

        mehod: Onclick

        placecall()

            Intent intent =new Intent(Intent.ACTION_CALL_PRIVILEGED,

                       Uri.fromParts("tel",number,null));

                       intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);

                       startActivity(intent);

启动拨号->>>>>>

 

 

intert.ACTION_CALL_PRIVILEGED实际字符串为android.intent.action.CALL_PRIVILEGED,通过查找知道了packegs/phone

下面的androidmanifest.xml中PrivilegedOutgoingCallBroadcaster activity-alias设置了intent-filter,所以需要找到其targetactivity为OutgoingCallBroadcaster。所以进入OutgoingCallBroadcaster的

  method:onCreate()

  //如果为紧急号码马上启动intent.setClass(this, InCallScreen.class); startActivity(intent);

  Intent broadcastIntent = new Intent(Intent.ACTION_NEW_OUTGOING_CALL);

        if (number != null) broadcastIntent.putExtra(Intent.EXTRA_PHONE_NUMBER, number);

        broadcastIntent.putExtra(EXTRA_ALREADY_CALLED, callNow);

        broadcastIntent.putExtra(EXTRA_ORIGINAL_URI, intent.getData().toString());

        if (LOGV) Log.v(TAG, "Broadcasting intent " + broadcastIntent + ".");

        sendOrderedBroadcast(broadcastIntent, PERMISSION, null, null,

                             Activity.RESULT_OK, number, null);

   

 

 

Intent.ACTION_NEW_OUTGOING_CALL实际字符串为android.intent.action.NEW_OUTGOING_CALL,通过查找知道了packegs/phone下面的androidmanifest.xml中OutgoingCallReceiver Receiver接收此intent消息。找到OutgoingCallReceiver,执行

mothod:onReceive()函数

  Intent newIntent = new Intent(Intent.ACTION_CALL, uri);

        newIntent.putExtra(Intent.EXTRA_PHONE_NUMBER, number);

        newIntent.setClass(context, InCallScreen.class);

        newIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);

 

《整个流程》

mothod:onCreate(第一次)/onNewIntent(非第一次)

  internalResolveIntent

    placeCall(intent);

      PhoneUtils.placeCall(mPhone, number, intent.getData());

        phone.dial(number);

          mCT.dial(newDialString);

            dial(dialString, CommandsInterface.CLIR_DEFAULT);

              cm.dial(pendingMO.address, clirMode, obtainCompleteMessage());//obtainCompleteMessage(EVENT_OPERATION_COMPLETE);

                send(rr);

                  msg = mSender.obtainMessage(EVENT_SEND, rr);

                  acquireWakeLock();

                  msg.sendToTarget();

                RILSender.handleMessage()  //已经到系统java ril<gsm &cdma>处理部分

                  case EVENT_SEND:

                    ...

                    s.getOutputStream().write(dataLength);                   

                    s.getOutputStream().write(data);//从这里流程跑到下面ril.cpp中监听部份

 

 

RIL层

 

rild守护进程 rild->main=>RIL_startEventLoop

      //建立事件循环线程

    ret = pthread_create(&s_tid_dispatch, &attr, eventLoop, NULL);

      //注册进程唤醒事件回调

      ril_event_set (&s_wakeupfd_event, s_fdWakeupRead, true,

                processWakeupCallback, NULL);

      rilEventAddWakeup (&s_wakeupfd_event);

      //建立事件循环

      ril_event_loop

        for (;;) {

          ...

          n = select(nfds, &rfds, NULL, NULL, ptv);

          // Check for timeouts

          processTimeouts();

          // Check for read-ready

          processReadReadies(&rfds, n);

          // Fire away

          firePending();

        }

 

       funcs = rilInit(&s_rilEnv, argc, rilArgv);//实际是通过动态加载动态库的方式执行reference-ril.c中的RIL_Init

 

    

      //单独启动一个线程读取串口数据

       ret = pthread_create(&s_tid_mainloop, &attr, mainLoop, NULL);

       fd = open (s_device_path, O_RDWR);//打开虚拟模组

       ret = at_open(fd, onUnsolicited);  //设置模组主动上报

       ret = pthread_create(&s_tid_reader, &attr, readerLoop, &attr);

       RIL_requestTimedCallback(initializeCallback, NULL, &TIMEVAL_0);

 

reference-ril.so 处理方式(rild动态加载libreference-ril.so库)

      (处理模型)

      >static void request(x x x)

         switch(x)    //判断请求类型

              request_dail //电话请求

                  function()  //请求处理函数AT指令

 

     设置事件回报//

 

参考文献:

http://blog.csdn.net/basonjiang_sz/archive/2011/03/17/6255881.aspx

Android GSM驱动模块详细分析(作者:熊猫哥哥)

posted @ 2012-06-11 12:25  yuzaipiaofei  阅读(198)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3