blob: 4e7c6bededbab113bf9e44a97d5ea9674b350d0f [file] [log] [blame]
Mathias Agopianb957b9d2010-07-13 22:21:56 -07001/*
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>
Jeff Brown4fe6c3e2010-09-13 23:17:30 -070024#include <utils/Looper.h>
Mathias Agopianb957b9d2010-07-13 22:21:56 -070025#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
33using android::sp;
34using android::Sensor;
35using android::SensorManager;
36using android::SensorEventQueue;
37using android::String8;
38
39/*****************************************************************************/
40
Mathias Agopian1bf79782010-07-14 23:41:37 -070041int ASensorManager_getSensorList(ASensorManager* manager,
42 ASensorList* list)
Mathias Agopianb957b9d2010-07-13 22:21:56 -070043{
Mathias Agopian1bf79782010-07-14 23:41:37 -070044 Sensor const* const* l;
Mathias Agopianb957b9d2010-07-13 22:21:56 -070045 int c = static_cast<SensorManager*>(manager)->getSensorList(&l);
46 if (list) {
Mathias Agopian1bf79782010-07-14 23:41:37 -070047 *list = reinterpret_cast<ASensorList>(l);
Mathias Agopianb957b9d2010-07-13 22:21:56 -070048 }
49 return c;
50}
51
Mathias Agopian1bf79782010-07-14 23:41:37 -070052ASensor const* ASensorManager_getDefaultSensor(ASensorManager* manager, int type)
Mathias Agopianb957b9d2010-07-13 22:21:56 -070053{
54 return static_cast<SensorManager*>(manager)->getDefaultSensor(type);
55}
56
Aravind Akella99fe1652014-08-05 15:02:11 -070057ASensor const* ASensorManager_getDefaultSensorEx(ASensorManager* manager,
58 int type, bool wakeUp) {
59 Sensor const* const* sensorList;
60 size_t size = static_cast<SensorManager*>(manager)->getSensorList(&sensorList);
61 for (size_t i = 0; i < size; ++i) {
62 if (ASensor_getType(sensorList[i]) == type &&
63 ASensor_isWakeUpSensor(sensorList[i]) == wakeUp) {
64 return reinterpret_cast<ASensor const *>(sensorList[i]);
65 }
66 }
67 return NULL;
68}
69
Mathias Agopianb957b9d2010-07-13 22:21:56 -070070ASensorEventQueue* ASensorManager_createEventQueue(ASensorManager* manager,
Jeff Brown4fe6c3e2010-09-13 23:17:30 -070071 ALooper* looper, int ident, ALooper_callbackFunc callback, void* data)
Mathias Agopianb957b9d2010-07-13 22:21:56 -070072{
73 sp<SensorEventQueue> queue =
74 static_cast<SensorManager*>(manager)->createEventQueue();
75 if (queue != 0) {
Jeff Brown4fe6c3e2010-09-13 23:17:30 -070076 ALooper_addFd(looper, queue->getFd(), ident, ALOOPER_EVENT_INPUT, callback, data);
Mathias Agopianb957b9d2010-07-13 22:21:56 -070077 queue->looper = looper;
78 queue->incStrong(manager);
79 }
80 return static_cast<ASensorEventQueue*>(queue.get());
81}
82
83int ASensorManager_destroyEventQueue(ASensorManager* manager,
84 ASensorEventQueue* inQueue)
85{
86 sp<SensorEventQueue> queue = static_cast<SensorEventQueue*>(inQueue);
87 ALooper_removeFd(queue->looper, queue->getFd());
88 queue->decStrong(manager);
89 return 0;
90}
91
92/*****************************************************************************/
93
Mathias Agopian1bf79782010-07-14 23:41:37 -070094int ASensorEventQueue_enableSensor(ASensorEventQueue* queue, ASensor const* sensor)
Mathias Agopianb957b9d2010-07-13 22:21:56 -070095{
96 return static_cast<SensorEventQueue*>(queue)->enableSensor(
Mathias Agopian1bf79782010-07-14 23:41:37 -070097 static_cast<Sensor const*>(sensor));
Mathias Agopianb957b9d2010-07-13 22:21:56 -070098}
99
Mathias Agopian1bf79782010-07-14 23:41:37 -0700100int ASensorEventQueue_disableSensor(ASensorEventQueue* queue, ASensor const* sensor)
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700101{
102 return static_cast<SensorEventQueue*>(queue)->disableSensor(
Mathias Agopian1bf79782010-07-14 23:41:37 -0700103 static_cast<Sensor const*>(sensor));
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700104}
105
Mathias Agopian1bf79782010-07-14 23:41:37 -0700106int ASensorEventQueue_setEventRate(ASensorEventQueue* queue, ASensor const* sensor,
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700107 int32_t usec)
108{
109 return static_cast<SensorEventQueue*>(queue)->setEventRate(
Mathias Agopian1bf79782010-07-14 23:41:37 -0700110 static_cast<Sensor const*>(sensor), us2ns(usec));
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700111}
112
113int ASensorEventQueue_hasEvents(ASensorEventQueue* queue)
114{
115 struct pollfd pfd;
116 pfd.fd = static_cast<SensorEventQueue*>(queue)->getFd();
117 pfd.events = POLLIN;
118 pfd.revents = 0;
119
120 int nfd = poll(&pfd, 1, 0);
121
122 if (nfd < 0)
123 return -errno;
124
125 if (pfd.revents != POLLIN)
126 return -1;
127
128 return (nfd == 0) ? 0 : 1;
129}
130
131ssize_t ASensorEventQueue_getEvents(ASensorEventQueue* queue,
132 ASensorEvent* events, size_t count)
133{
Aravind Akella35187bd2014-02-11 18:44:42 -0800134 ssize_t actual = static_cast<SensorEventQueue*>(queue)->read(events, count);
135 if (actual > 0) {
136 static_cast<SensorEventQueue*>(queue)->sendAck(events, actual);
137 }
138 return actual;
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700139}
140
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700141/*****************************************************************************/
142
Mathias Agopian1bf79782010-07-14 23:41:37 -0700143const char* ASensor_getName(ASensor const* sensor)
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700144{
Mathias Agopian1bf79782010-07-14 23:41:37 -0700145 return static_cast<Sensor const*>(sensor)->getName().string();
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700146}
147
Mathias Agopian1bf79782010-07-14 23:41:37 -0700148const char* ASensor_getVendor(ASensor const* sensor)
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700149{
Mathias Agopian1bf79782010-07-14 23:41:37 -0700150 return static_cast<Sensor const*>(sensor)->getVendor().string();
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700151}
152
Mathias Agopian1bf79782010-07-14 23:41:37 -0700153int ASensor_getType(ASensor const* sensor)
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700154{
Mathias Agopian1bf79782010-07-14 23:41:37 -0700155 return static_cast<Sensor const*>(sensor)->getType();
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700156}
157
Mathias Agopian1bf79782010-07-14 23:41:37 -0700158float ASensor_getResolution(ASensor const* sensor)
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700159{
Mathias Agopian1bf79782010-07-14 23:41:37 -0700160 return static_cast<Sensor const*>(sensor)->getResolution();
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700161}
162
Mathias Agopian050b5622010-07-29 16:51:38 -0700163int ASensor_getMinDelay(ASensor const* sensor)
164{
165 return static_cast<Sensor const*>(sensor)->getMinDelay();
166}
Aravind Akellacd9a7bb2014-04-07 22:55:21 +0000167
168int ASensor_getFifoMaxEventCount(ASensor const* sensor)
169{
170 return static_cast<Sensor const*>(sensor)->getFifoMaxEventCount();
171}
172
173int ASensor_getFifoReservedEventCount(ASensor const* sensor)
174{
175 return static_cast<Sensor const*>(sensor)->getFifoReservedEventCount();
176}
177
178const char* ASensor_getStringType(ASensor const* sensor)
179{
180 return static_cast<Sensor const*>(sensor)->getStringType().string();
181}
Aravind Akella27900352014-06-03 19:20:42 -0700182
183int ASensor_getReportingMode(ASensor const* sensor)
184{
185 return static_cast<Sensor const*>(sensor)->getReportingMode();
186}
Aravind Akella99fe1652014-08-05 15:02:11 -0700187
188bool ASensor_isWakeUpSensor(ASensor const* sensor)
189{
190 return static_cast<Sensor const*>(sensor)->isWakeUpSensor();
191}