blob: 8c9f95b0cbbf97bc4f4f1079cb5b731169f2ad5f [file] [log] [blame]
Mathias Agopian589ce852010-07-13 22:21:56 -07001/*
2 * Copyright (C) 2010 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Mathias Agopiana7352c92010-07-14 23:41:37 -070017#define LOG_TAG "Sensors"
18
Mathias Agopian589ce852010-07-13 22:21:56 -070019#include <stdint.h>
20#include <sys/types.h>
21
22#include <utils/Errors.h>
23#include <utils/RefBase.h>
24#include <utils/Singleton.h>
25
Mathias Agopian1a2b83a2011-10-16 22:15:23 -070026#include <binder/IBinder.h>
Mathias Agopiana7352c92010-07-14 23:41:37 -070027#include <binder/IServiceManager.h>
28
Mathias Agopian589ce852010-07-13 22:21:56 -070029#include <gui/ISensorServer.h>
30#include <gui/ISensorEventConnection.h>
31#include <gui/Sensor.h>
32#include <gui/SensorManager.h>
33#include <gui/SensorEventQueue.h>
34
35// ----------------------------------------------------------------------------
36namespace android {
37// ----------------------------------------------------------------------------
38
Svetoslavb412f6e2015-04-29 16:50:41 -070039SensorManager::SensorManager(const String16& opPackageName)
40 : mSensorList(0), mOpPackageName(opPackageName)
Mathias Agopian589ce852010-07-13 22:21:56 -070041{
Mathias Agopian1a2b83a2011-10-16 22:15:23 -070042 // okay we're not locked here, but it's not needed during construction
43 assertStateLocked();
Mathias Agopian589ce852010-07-13 22:21:56 -070044}
45
46SensorManager::~SensorManager()
47{
Mathias Agopiana7352c92010-07-14 23:41:37 -070048 free(mSensorList);
Mathias Agopian589ce852010-07-13 22:21:56 -070049}
50
Mathias Agopian1a2b83a2011-10-16 22:15:23 -070051void SensorManager::sensorManagerDied()
52{
53 Mutex::Autolock _l(mLock);
54 mSensorServer.clear();
55 free(mSensorList);
56 mSensorList = NULL;
57 mSensors.clear();
58}
59
60status_t SensorManager::assertStateLocked() const {
61 if (mSensorServer == NULL) {
62 // try for one second
63 const String16 name("sensorservice");
64 for (int i=0 ; i<4 ; i++) {
65 status_t err = getService(name, &mSensorServer);
66 if (err == NAME_NOT_FOUND) {
67 usleep(250000);
68 continue;
69 }
70 if (err != NO_ERROR) {
71 return err;
72 }
73 break;
74 }
75
76 class DeathObserver : public IBinder::DeathRecipient {
77 SensorManager& mSensorManger;
78 virtual void binderDied(const wp<IBinder>& who) {
Steve Block32397c12012-01-05 23:22:43 +000079 ALOGW("sensorservice died [%p]", who.unsafe_get());
Mathias Agopian1a2b83a2011-10-16 22:15:23 -070080 mSensorManger.sensorManagerDied();
81 }
82 public:
83 DeathObserver(SensorManager& mgr) : mSensorManger(mgr) { }
84 };
85
86 mDeathObserver = new DeathObserver(*const_cast<SensorManager *>(this));
Marco Nelissen2ea926b2014-11-14 08:01:01 -080087 IInterface::asBinder(mSensorServer)->linkToDeath(mDeathObserver);
Mathias Agopian1a2b83a2011-10-16 22:15:23 -070088
Svetoslavb412f6e2015-04-29 16:50:41 -070089 mSensors = mSensorServer->getSensorList(mOpPackageName);
Mathias Agopian1a2b83a2011-10-16 22:15:23 -070090 size_t count = mSensors.size();
Dan Stozad723bd72014-11-18 10:24:03 -080091 mSensorList =
92 static_cast<Sensor const**>(malloc(count * sizeof(Sensor*)));
Mathias Agopian1a2b83a2011-10-16 22:15:23 -070093 for (size_t i=0 ; i<count ; i++) {
94 mSensorList[i] = mSensors.array() + i;
95 }
96 }
97
98 return NO_ERROR;
99}
100
Mathias Agopiana7352c92010-07-14 23:41:37 -0700101ssize_t SensorManager::getSensorList(Sensor const* const** list) const
Mathias Agopian589ce852010-07-13 22:21:56 -0700102{
Mathias Agopian1a2b83a2011-10-16 22:15:23 -0700103 Mutex::Autolock _l(mLock);
104 status_t err = assertStateLocked();
105 if (err < 0) {
Dan Stozad723bd72014-11-18 10:24:03 -0800106 return static_cast<ssize_t>(err);
Mathias Agopian1a2b83a2011-10-16 22:15:23 -0700107 }
Mathias Agopian589ce852010-07-13 22:21:56 -0700108 *list = mSensorList;
Dan Stozad723bd72014-11-18 10:24:03 -0800109 return static_cast<ssize_t>(mSensors.size());
Mathias Agopian589ce852010-07-13 22:21:56 -0700110}
111
Mathias Agopiana7352c92010-07-14 23:41:37 -0700112Sensor const* SensorManager::getDefaultSensor(int type)
Mathias Agopian589ce852010-07-13 22:21:56 -0700113{
Mathias Agopian1a2b83a2011-10-16 22:15:23 -0700114 Mutex::Autolock _l(mLock);
115 if (assertStateLocked() == NO_ERROR) {
Aravind Akellab37ba392014-08-05 14:53:07 -0700116 bool wakeUpSensor = false;
117 // For the following sensor types, return a wake-up sensor. These types are by default
118 // defined as wake-up sensors. For the rest of the sensor types defined in sensors.h return
119 // a non_wake-up version.
120 if (type == SENSOR_TYPE_PROXIMITY || type == SENSOR_TYPE_SIGNIFICANT_MOTION ||
121 type == SENSOR_TYPE_TILT_DETECTOR || type == SENSOR_TYPE_WAKE_GESTURE ||
122 type == SENSOR_TYPE_GLANCE_GESTURE || type == SENSOR_TYPE_PICK_UP_GESTURE) {
123 wakeUpSensor = true;
124 }
Mathias Agopian1a2b83a2011-10-16 22:15:23 -0700125 // For now we just return the first sensor of that type we find.
126 // in the future it will make sense to let the SensorService make
127 // that decision.
128 for (size_t i=0 ; i<mSensors.size() ; i++) {
Aravind Akellab37ba392014-08-05 14:53:07 -0700129 if (mSensorList[i]->getType() == type &&
130 mSensorList[i]->isWakeUpSensor() == wakeUpSensor) {
Mathias Agopian1a2b83a2011-10-16 22:15:23 -0700131 return mSensorList[i];
Aravind Akellab37ba392014-08-05 14:53:07 -0700132 }
Mathias Agopian1a2b83a2011-10-16 22:15:23 -0700133 }
Mathias Agopiana7352c92010-07-14 23:41:37 -0700134 }
135 return NULL;
Mathias Agopian589ce852010-07-13 22:21:56 -0700136}
137
Aravind Akellaa9e6cc32015-04-16 18:57:31 -0700138sp<SensorEventQueue> SensorManager::createEventQueue(String8 packageName, int mode) {
Mathias Agopianbe58de02011-10-16 00:38:30 -0700139 sp<SensorEventQueue> queue;
140
Mathias Agopian1a2b83a2011-10-16 22:15:23 -0700141 Mutex::Autolock _l(mLock);
142 while (assertStateLocked() == NO_ERROR) {
143 sp<ISensorEventConnection> connection =
Svetoslavb412f6e2015-04-29 16:50:41 -0700144 mSensorServer->createSensorEventConnection(packageName, mode, mOpPackageName);
Mathias Agopian1a2b83a2011-10-16 22:15:23 -0700145 if (connection == NULL) {
Aravind Akellaa9e6cc32015-04-16 18:57:31 -0700146 // SensorService just died or the app doesn't have required permissions.
147 ALOGE("createEventQueue: connection is NULL.");
148 return NULL;
Mathias Agopian1a2b83a2011-10-16 22:15:23 -0700149 }
150 queue = new SensorEventQueue(connection);
151 break;
Mathias Agopianbe58de02011-10-16 00:38:30 -0700152 }
Mathias Agopianbe58de02011-10-16 00:38:30 -0700153 return queue;
Mathias Agopian589ce852010-07-13 22:21:56 -0700154}
155
Aravind Akellaa9e6cc32015-04-16 18:57:31 -0700156status_t SensorManager::enableDataInjection(bool enable) {
157 Mutex::Autolock _l(mLock);
158 if (assertStateLocked() == NO_ERROR) {
159 return mSensorServer->enableDataInjection(enable);
160 }
161 return INVALID_OPERATION;
162}
163
Mathias Agopian589ce852010-07-13 22:21:56 -0700164// ----------------------------------------------------------------------------
165}; // namespace android