• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2009 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 
17 #define LOG_TAG "sensor"
18 #include <utils/Log.h>
19 
20 #include <android/looper.h>
21 #include <android/sensor.h>
22 
23 #include <utils/RefBase.h>
24 #include <utils/Looper.h>
25 #include <utils/Timers.h>
26 
27 #include <gui/Sensor.h>
28 #include <gui/SensorManager.h>
29 #include <gui/SensorEventQueue.h>
30 
31 #include <poll.h>
32 
33 using android::sp;
34 using android::Sensor;
35 using android::SensorManager;
36 using android::SensorEventQueue;
37 using android::String8;
38 using android::String16;
39 
40 /*****************************************************************************/
ASensorManager_getInstance()41 ASensorManager* ASensorManager_getInstance()
42 {
43     return ASensorManager_getInstanceForPackage(NULL);
44 }
45 
ASensorManager_getInstanceForPackage(const char * packageName)46 ASensorManager* ASensorManager_getInstanceForPackage(const char* packageName)
47 {
48     if (packageName) {
49         return &SensorManager::getInstanceForPackage(String16(packageName));
50     } else {
51         return &SensorManager::getInstanceForPackage(String16());
52     }
53 }
54 
ASensorManager_getSensorList(ASensorManager * manager,ASensorList * list)55 int ASensorManager_getSensorList(ASensorManager* manager,
56         ASensorList* list)
57 {
58     Sensor const* const* l;
59     int c = static_cast<SensorManager*>(manager)->getSensorList(&l);
60     if (list) {
61         *list = reinterpret_cast<ASensorList>(l);
62     }
63     return c;
64 }
65 
ASensorManager_getDefaultSensor(ASensorManager * manager,int type)66 ASensor const* ASensorManager_getDefaultSensor(ASensorManager* manager, int type)
67 {
68     return static_cast<SensorManager*>(manager)->getDefaultSensor(type);
69 }
70 
ASensorManager_getDefaultSensorEx(ASensorManager * manager,int type,bool wakeUp)71 ASensor const* ASensorManager_getDefaultSensorEx(ASensorManager* manager,
72         int type, bool wakeUp) {
73     Sensor const* const* sensorList;
74     size_t size = static_cast<SensorManager*>(manager)->getSensorList(&sensorList);
75     for (size_t i = 0; i < size; ++i) {
76         if (ASensor_getType(sensorList[i]) == type &&
77             ASensor_isWakeUpSensor(sensorList[i]) == wakeUp) {
78             return reinterpret_cast<ASensor const *>(sensorList[i]);
79        }
80     }
81     return NULL;
82 }
83 
ASensorManager_createEventQueue(ASensorManager * manager,ALooper * looper,int ident,ALooper_callbackFunc callback,void * data)84 ASensorEventQueue* ASensorManager_createEventQueue(ASensorManager* manager,
85         ALooper* looper, int ident, ALooper_callbackFunc callback, void* data)
86 {
87     sp<SensorEventQueue> queue =
88             static_cast<SensorManager*>(manager)->createEventQueue();
89     if (queue != 0) {
90         ALooper_addFd(looper, queue->getFd(), ident, ALOOPER_EVENT_INPUT, callback, data);
91         queue->looper = looper;
92         queue->incStrong(manager);
93     }
94     return static_cast<ASensorEventQueue*>(queue.get());
95 }
96 
ASensorManager_destroyEventQueue(ASensorManager * manager,ASensorEventQueue * inQueue)97 int ASensorManager_destroyEventQueue(ASensorManager* manager,
98         ASensorEventQueue* inQueue)
99 {
100     sp<SensorEventQueue> queue = static_cast<SensorEventQueue*>(inQueue);
101     ALooper_removeFd(queue->looper, queue->getFd());
102     queue->decStrong(manager);
103     return 0;
104 }
105 
106 /*****************************************************************************/
107 
ASensorEventQueue_enableSensor(ASensorEventQueue * queue,ASensor const * sensor)108 int ASensorEventQueue_enableSensor(ASensorEventQueue* queue, ASensor const* sensor)
109 {
110     return static_cast<SensorEventQueue*>(queue)->enableSensor(
111             static_cast<Sensor const*>(sensor));
112 }
113 
ASensorEventQueue_disableSensor(ASensorEventQueue * queue,ASensor const * sensor)114 int ASensorEventQueue_disableSensor(ASensorEventQueue* queue, ASensor const* sensor)
115 {
116     return static_cast<SensorEventQueue*>(queue)->disableSensor(
117             static_cast<Sensor const*>(sensor));
118 }
119 
ASensorEventQueue_setEventRate(ASensorEventQueue * queue,ASensor const * sensor,int32_t usec)120 int ASensorEventQueue_setEventRate(ASensorEventQueue* queue, ASensor const* sensor,
121         int32_t usec)
122 {
123     return static_cast<SensorEventQueue*>(queue)->setEventRate(
124             static_cast<Sensor const*>(sensor), us2ns(usec));
125 }
126 
ASensorEventQueue_hasEvents(ASensorEventQueue * queue)127 int ASensorEventQueue_hasEvents(ASensorEventQueue* queue)
128 {
129     struct pollfd pfd;
130     pfd.fd = static_cast<SensorEventQueue*>(queue)->getFd();
131     pfd.events = POLLIN;
132     pfd.revents = 0;
133 
134     int nfd = poll(&pfd, 1, 0);
135 
136     if (nfd < 0)
137         return -errno;
138 
139     if (pfd.revents != POLLIN)
140         return -1;
141 
142     return (nfd == 0) ? 0 : 1;
143 }
144 
ASensorEventQueue_getEvents(ASensorEventQueue * queue,ASensorEvent * events,size_t count)145 ssize_t ASensorEventQueue_getEvents(ASensorEventQueue* queue,
146                 ASensorEvent* events, size_t count)
147 {
148     ssize_t actual = static_cast<SensorEventQueue*>(queue)->read(events, count);
149     if (actual > 0) {
150         static_cast<SensorEventQueue*>(queue)->sendAck(events, actual);
151     }
152     return actual;
153 }
154 
155 /*****************************************************************************/
156 
ASensor_getName(ASensor const * sensor)157 const char* ASensor_getName(ASensor const* sensor)
158 {
159     return static_cast<Sensor const*>(sensor)->getName().string();
160 }
161 
ASensor_getVendor(ASensor const * sensor)162 const char* ASensor_getVendor(ASensor const* sensor)
163 {
164     return static_cast<Sensor const*>(sensor)->getVendor().string();
165 }
166 
ASensor_getType(ASensor const * sensor)167 int ASensor_getType(ASensor const* sensor)
168 {
169     return static_cast<Sensor const*>(sensor)->getType();
170 }
171 
ASensor_getResolution(ASensor const * sensor)172 float ASensor_getResolution(ASensor const* sensor)
173 {
174     return static_cast<Sensor const*>(sensor)->getResolution();
175 }
176 
ASensor_getMinDelay(ASensor const * sensor)177 int ASensor_getMinDelay(ASensor const* sensor)
178 {
179     return static_cast<Sensor const*>(sensor)->getMinDelay();
180 }
181 
ASensor_getFifoMaxEventCount(ASensor const * sensor)182 int ASensor_getFifoMaxEventCount(ASensor const* sensor)
183 {
184     return static_cast<Sensor const*>(sensor)->getFifoMaxEventCount();
185 }
186 
ASensor_getFifoReservedEventCount(ASensor const * sensor)187 int ASensor_getFifoReservedEventCount(ASensor const* sensor)
188 {
189     return static_cast<Sensor const*>(sensor)->getFifoReservedEventCount();
190 }
191 
ASensor_getStringType(ASensor const * sensor)192 const char* ASensor_getStringType(ASensor const* sensor)
193 {
194     return static_cast<Sensor const*>(sensor)->getStringType().string();
195 }
196 
ASensor_getReportingMode(ASensor const * sensor)197 int ASensor_getReportingMode(ASensor const* sensor)
198 {
199     return static_cast<Sensor const*>(sensor)->getReportingMode();
200 }
201 
ASensor_isWakeUpSensor(ASensor const * sensor)202 bool ASensor_isWakeUpSensor(ASensor const* sensor)
203 {
204     return static_cast<Sensor const*>(sensor)->isWakeUpSensor();
205 }
206