Android sensor睡眠唤醒相关

本文探讨了Android系统中sensor HAL的日志等级设置、ActivityManager如何监听UID状态变化,以及如何通过UidObserver事件来控制传感器数据是否发送到应用。详细介绍了在UidActive和UidIdle状态下的处理函数,以及当设备睡眠唤醒时,如何处理SEE sensor的事件。重点分析了sensor数据在睡眠唤醒场景下的流向和控制机制。
摘要由CSDN通过智能技术生成

sensor hal log等级的设置

什么个逻辑可以动态控制log等

const char SENSORS_HAL_PROP_DEBUG[] = "persist.vendor.debug.sensors.hal";
/* map debug property value to log_level */
static const unordered_map<char, sensors_log::log_level> log_level_map = {
    { '0', sensors_log::SILENT },
    { '1', sensors_log::INFO },
    { 'e', sensors_log::ERROR },
    { 'E', sensors_log::ERROR },
    { 'i', sensors_log::INFO },
    { 'I', sensors_log::INFO },
    { 'd', sensors_log::DEBUG },
    { 'D', sensors_log::DEBUG },
    { 'v', sensors_log::VERBOSE },
    { 'V', sensors_log::VERBOSE },
};

void sensors_hal::get_system_config()
{
    char debug_prop[PROPERTY_VALUE_MAX];
    int len;
    len = property_get(SENSORS_HAL_PROP_DEBUG, debug_prop, "i");
    if (len > 0) {
        if (log_level_map.find(debug_prop[0]) != log_level_map.end()) {
            _sysconfig.log_level = log_level_map.at(debug_prop[0]);
        }
    }
    sns_logi("log_level: %d", _sysconfig.log_level);
}

ActivityManager 监听UidObserver事件:gone/idle/active/unknow

void SensorService::onFirstRef() { 
    // Start watching UID changes to apply policy.
    mUidPolicy->registerSelf();
}

void SensorService::UidPolicy::registerSelf() {                                                                                               
      ActivityManager am;
      am.registerUidObserver(this, ActivityManager::UID_OBSERVER_GONE
              | ActivityManager::UID_OBSERVER_IDLE
              | ActivityManager::UID_OBSERVER_ACTIVE,
              ActivityManager::PROCESS_STATE_UNKNOWN,
              String16("android"));
}

UidActive/UidIdle对应的处理函数

native app是怎样使用java service的?

void SensorService::UidPolicy::onUidActive(uid_t uid) {
      {
          Mutex::Autolock _l(mUidLock);
          mActiveUids.insert(uid);
      }
      sp<SensorService> service = mService.promote();
      if (service != nullptr) {
          service->setSensorAccess(uid, true);
      }
}
  
void SensorService::UidPolicy::onUidIdle(uid_t uid, __unused bool disabled) {
      bool deleted = false;
      {
          Mutex::Autolock _l(mUidLock);
          if (mActiveUids.erase(uid) > 0) {
              deleted = true;
          }
      }
      if (deleted) {
          sp<SensorService> service = mService.promote();
          if (service != nullptr) {
              service->setSensorAccess(uid, false);
          }
      }
}

最终调用函数 setSensorAccess:

void SensorService::setSensorAccess(uid_t uid, bool hasAccess) {
    ConnectionSafeAutolock connLock = mConnectionHolder.lock(mLock);
    for (const sp<SensorEventConnection>& conn : connLock.getActiveConnections()) {
        if (conn->getUid() == uid) {
            conn->setSensorAccess(hasAccess);
        }
    }
}

void SensorService::SensorEventConnection::setSensorAccess(const bool hasAccess) {
    Mutex::Autolock _l(mConnectionLock);
    mHasSensorAccess &

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值