当前位置:操作系统 > 安卓/Android >>

android usb大体流程解析



我分析这个流程也是从这张图来分析:
首先kernel层是由kernel_imx/drivers/power/下的bq27x00_battery.c和power_supply_core.c以及power_supply_sysfs.c三个文件来做,power_supply_core.c主要提供统一设备文件的创建以及发送power_supply相关的Uevent;bq27x00_battery.c主要提供具体的电池信息.
每当产生充放电中断时,驱动会调用中断函数ext_power_isr,该函数调用power_supply_core.c的power_supply_changed(&(id->bat))函数,发送一个power_supply属性的Uevent,java层的BatteryService接收到该事件后就会调用jni层的native——update函数来获得电池信息,然后通过intnet广播给相应的activity。

那么由kernel层发送一个Uevent,当插入usb时,然后通过NetLinkManage中的NetlinkManager::start()开始创建socket和bind:
mSock = socket(PF_NETLINK,
                        SOCK_DGRAM,NETLINK_KOBJECT_UEVENT,bind(mSock, (struct sockaddr *) &nladdr, sizeof(nladdr)
然后通过一个Handler传送给socketListener.cpp:
mHandler = new NetlinkHandler(mSock);mHandler->start();
然后socketListener.cpp的SocketListener::startListener() 开始监听
mSock = android_get_control_socket(mSocketName),
 mClients->push_back(new SocketClient(mSock));
创建线程pthread_create(&mThread, NULL, SocketListener::threadStart, this)不断监听。
而VolumeManager则通过NetLinkeEent的findParam方法在
handleSwitchEvent
handleBlockEvent
handleUsbCompositeEvent中来获取路径,而在notifyUmsAvailable中的getBroadcaster()则又通过VolumeManager.h调用的SocketListen的*getBroadcaster()。
再由NativeDaemonConnector.java来监听VolumeManager中而来的socket,
public void run() {   listenToSocket();}。
MountService的onEvent给IMountServiceListener传递数据,并且IMountService 通过MountServiceListene给MountService:如MountServiceBinderListener(IMountServiceListener listener)。

      IMountServiceListener通过AIDL向StorageManager传递
onStorageStateChanged(path, oldState, newState);和
onUsbMassStorageConnectionChanged(connected);
在StorageManager中去实现:
public void onUsbMassStorageConnectionChanged(boolean available) {
            final int size = mListeners.size();
            for (int i = 0; i < size; i++) {
                mListeners.get(i).sendShareAvailabilityChanged(available);
            }
public void onStorageStateChanged(String path, String oldState, String newState) {
            final int size = mListeners.size();
            for (int i = 0; i < size; i++) {
                mListeners.get(i).sendStorageStateChanged(path, oldState, newState);
            }
        }

在电池信息方面:由于电池电量变化时不能产生中断来通知上层读取电池信息,所以设置了一个定时器,每隔30s发送一个Uevent事件让BatteryService 来读取电池信息是否有变化 :在这里充当Uevent观察者的角色
private UEventObserver mUEventObserver = new UEventObserver() {
        @Override
        public void onUEvent(UEventObserver.UEvent event) {
            update();
        }
    };
这里只关注power_supply的事件:
mUEventObserver.startObserverving("SUBSYSTEM=power_supply");
当有power_supply相关的事件上报时,就会调用update函数。
update先调用native_update从sysfs中读取相关状态。
Update然后根据读到的状态更新BatteryService的成员变量,并广播一个Intent来通知其它关注电源状态的组件。
 private final void sendIntent() {
        //  Pack up the values and broadcast them to everyone
        Intent intent = new Intent(Intent.ACTION_BATTERY_CHANGED);
        intent.addFlags(Intent.FLAG_RECEIVER_REGISTERED_ONLY
                | Intent.FLAG_RECEIVER_REPLACE_PENDING);

        int icon = getIcon(mBatteryLevel);

        intent.putExtra(BatteryManager.EXTRA_STATUS, mBatteryStatus);
        intent.putExtra(BatteryManager.EXTRA_HEALTH, mBatteryHealth);
        intent.putExtra(BatteryManager.EXTRA_PRESENT, mBatteryPresent);
        intent.putExtra(BatteryManager.EXTRA_LEVEL, mBatteryLevel);
        intent.putExtra(BatteryManager.EXTRA_SCALE, BATTERY_SCALE);
        intent.putExtra(BatteryManager.EXTRA_ICON_SMALL, icon);
        intent.putExtra(BatteryManager.EXTRA_PLUGGED, mPlugType);
        Log.i("mPlugType","mPlugType="+mPlugType+"mBatteryLevel"+mBatteryLevel);
        intent.putExtra(BatteryManager.EXTRA_VOLTAGE, mBatteryVoltage);
        intent.putExtra(BatteryManager.EXTRA_TEMPERATURE, mBatteryTemperature);
        intent.putExtra(BatteryManager.EXTRA_TECHNOLOGY, mBatteryTechnology);
..........
当有变化时就调用JNI层的native_update()来 更新,通过JNI到   com_android_sever_batteryService.cpp的 android_server_BatteryService_update方法   :
static void android_server_BatteryService_update(JNIEnv* env, jobject obj)
{
    setBooleanField(env, obj, gPaths.acOnlinePath, gFieldIds.mAcOnline);
    setBooleanField(env, obj, gPaths.usbOnlinePath, gFieldIds.mUsbOnline);
    setBooleanField(env, obj, gPaths.batteryPresentPath, gFieldIds.mBatteryPresent);
    setIntField(env, obj, gPaths.batteryCapacityPath, gFieldIds.mBatteryLevel);
    setVoltageField(env, obj, gPaths.batteryVoltagePath, gFieldIds.mBatteryVoltage);
    setIntField(env, obj, gPaths.batteryTemperaturePath, gFieldIds.mBatteryTemperature);
const int SIZE = 128;
    char buf[SIZE];
    if (readFromFile(gPaths.batteryStatusPath, buf, SIZE) > 0)
        env->SetIntField(obj, gFieldIds.mBatteryStatus, getBatteryStatus(buf));
    else
        env->SetIntField(obj, gFieldIds.mBatteryStatus,
                         gConstants.statusUnknown);
   
    if (readFromFile(gPaths.batteryHealthPath, buf, SIZE) > 0)
        env->SetIntField(obj, gFieldIds.mBatteryHealth, getBatteryHealth(buf));

    if (readFromFile(gPaths.batteryTechnologyPath, buf, SIZE) > 0)
      &n

补充:移动开发 , Android ,
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,