blob: bb8708bd1e5e01215ffd041a430fa4ff35421342 [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>
Peng Xu3b170172017-02-15 23:25:21 -080022#include <android/sharedmem.h>
23#include <cutils/native_handle.h>
Mathias Agopiancaf89302017-03-06 16:06:49 -080024#include <sensor/Sensor.h>
25#include <sensor/SensorManager.h>
26#include <sensor/SensorEventQueue.h>
Peng Xu3b170172017-02-15 23:25:21 -080027#include <utils/Looper.h>
28#include <utils/RefBase.h>
29#include <utils/Timers.h>
Jesse Hall5f73ab72017-04-17 08:54:43 -070030#include <vndk/hardware_buffer.h>
Mathias Agopianb957b9d2010-07-13 22:21:56 -070031
32#include <poll.h>
33
34using android::sp;
35using android::Sensor;
36using android::SensorManager;
37using android::SensorEventQueue;
38using android::String8;
Svet Ganovcbb56a82015-05-07 10:49:07 -070039using android::String16;
Mathias Agopianb957b9d2010-07-13 22:21:56 -070040
41/*****************************************************************************/
Peng Xu3b170172017-02-15 23:25:21 -080042#define ERROR_INVALID_PARAMETER(message) ALOGE("%s: " message, __func__)
43
Peng Xu63483ad2017-02-28 17:00:16 -080044// frequently used checks
Peng Xu3b170172017-02-15 23:25:21 -080045#define RETURN_IF_MANAGER_IS_NULL(retval) do {\
46 if (manager == nullptr) { \
47 ERROR_INVALID_PARAMETER("manager cannot be NULL"); \
48 return retval; \
49 } \
50 } while (false)
51#define RETURN_IF_SENSOR_IS_NULL(retval) do {\
52 if (sensor == nullptr) { \
53 ERROR_INVALID_PARAMETER("sensor cannot be NULL"); \
54 return retval; \
55 } \
56 } while (false)
Peng Xu63483ad2017-02-28 17:00:16 -080057#define RETURN_IF_QUEUE_IS_NULL(retval) do {\
58 if (queue == nullptr) { \
59 ERROR_INVALID_PARAMETER("queue cannot be NULL"); \
60 return retval; \
61 } \
62 } while (false)
Peng Xu3b170172017-02-15 23:25:21 -080063
Peng Xu63483ad2017-02-28 17:00:16 -080064ASensorManager* ASensorManager_getInstance() {
65 return ASensorManager_getInstanceForPackage(nullptr);
Svet Ganovcbb56a82015-05-07 10:49:07 -070066}
67
Peng Xu63483ad2017-02-28 17:00:16 -080068ASensorManager* ASensorManager_getInstanceForPackage(const char* packageName) {
Svet Ganovcbb56a82015-05-07 10:49:07 -070069 if (packageName) {
70 return &SensorManager::getInstanceForPackage(String16(packageName));
71 } else {
72 return &SensorManager::getInstanceForPackage(String16());
73 }
74}
75
Peng Xu63483ad2017-02-28 17:00:16 -080076int ASensorManager_getSensorList(ASensorManager* manager, ASensorList* list) {
77 RETURN_IF_MANAGER_IS_NULL(android::BAD_VALUE);
Mathias Agopian1bf79782010-07-14 23:41:37 -070078 Sensor const* const* l;
Mathias Agopianb957b9d2010-07-13 22:21:56 -070079 int c = static_cast<SensorManager*>(manager)->getSensorList(&l);
80 if (list) {
Mathias Agopian1bf79782010-07-14 23:41:37 -070081 *list = reinterpret_cast<ASensorList>(l);
Mathias Agopianb957b9d2010-07-13 22:21:56 -070082 }
83 return c;
84}
85
Erik Staats13ca5df2022-02-04 06:39:24 -080086ssize_t ASensorManager_getDynamicSensorList(ASensorManager* manager, ASensorList* list) {
87 RETURN_IF_MANAGER_IS_NULL(android::BAD_VALUE);
88 Sensor const* const* l;
89 ssize_t c = static_cast<SensorManager*>(manager)->getDynamicSensorList(&l);
90 if (list) {
91 *list = reinterpret_cast<ASensorList>(l);
92 }
93 return c;
94}
95
Peng Xu63483ad2017-02-28 17:00:16 -080096ASensor const* ASensorManager_getDefaultSensor(ASensorManager* manager, int type) {
97 RETURN_IF_MANAGER_IS_NULL(nullptr);
Mathias Agopianb957b9d2010-07-13 22:21:56 -070098 return static_cast<SensorManager*>(manager)->getDefaultSensor(type);
99}
100
Peng Xu63483ad2017-02-28 17:00:16 -0800101ASensor const* ASensorManager_getDefaultSensorEx(ASensorManager* manager, int type, bool wakeUp) {
102 RETURN_IF_MANAGER_IS_NULL(nullptr);
Aravind Akella99fe1652014-08-05 15:02:11 -0700103 Sensor const* const* sensorList;
104 size_t size = static_cast<SensorManager*>(manager)->getSensorList(&sensorList);
105 for (size_t i = 0; i < size; ++i) {
106 if (ASensor_getType(sensorList[i]) == type &&
107 ASensor_isWakeUpSensor(sensorList[i]) == wakeUp) {
108 return reinterpret_cast<ASensor const *>(sensorList[i]);
109 }
110 }
Peng Xu63483ad2017-02-28 17:00:16 -0800111 return nullptr;
Aravind Akella99fe1652014-08-05 15:02:11 -0700112}
113
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700114ASensorEventQueue* ASensorManager_createEventQueue(ASensorManager* manager,
Peng Xu63483ad2017-02-28 17:00:16 -0800115 ALooper* looper, int ident, ALooper_callbackFunc callback, void* data) {
116 RETURN_IF_MANAGER_IS_NULL(nullptr);
117
118 if (looper == nullptr) {
119 ERROR_INVALID_PARAMETER("looper cannot be NULL");
120 return nullptr;
121 }
122
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700123 sp<SensorEventQueue> queue =
124 static_cast<SensorManager*>(manager)->createEventQueue();
125 if (queue != 0) {
Jeff Brown4fe6c3e2010-09-13 23:17:30 -0700126 ALooper_addFd(looper, queue->getFd(), ident, ALOOPER_EVENT_INPUT, callback, data);
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700127 queue->looper = looper;
Brian Stack9da89b22019-01-14 12:15:58 -0800128 queue->requestAdditionalInfo = false;
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700129 queue->incStrong(manager);
130 }
131 return static_cast<ASensorEventQueue*>(queue.get());
132}
133
Peng Xu63483ad2017-02-28 17:00:16 -0800134int ASensorManager_destroyEventQueue(ASensorManager* manager, ASensorEventQueue* queue) {
135 RETURN_IF_MANAGER_IS_NULL(android::BAD_VALUE);
136 RETURN_IF_QUEUE_IS_NULL(android::BAD_VALUE);
137
138 sp<SensorEventQueue> q = static_cast<SensorEventQueue*>(queue);
139 ALooper_removeFd(q->looper, q->getFd());
140 q->decStrong(manager);
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700141 return 0;
142}
143
Peng Xu63483ad2017-02-28 17:00:16 -0800144int ASensorManager_createSharedMemoryDirectChannel(ASensorManager *manager, int fd, size_t size) {
Peng Xu3b170172017-02-15 23:25:21 -0800145 RETURN_IF_MANAGER_IS_NULL(android::BAD_VALUE);
146
147 if (fd < 0) {
148 ERROR_INVALID_PARAMETER("fd is invalid.");
149 return android::BAD_VALUE;
150 }
151
152 if (size < sizeof(ASensorEvent)) {
153 ERROR_INVALID_PARAMETER("size has to be greater or equal to sizeof(ASensorEvent).");
Peng Xu63483ad2017-02-28 17:00:16 -0800154 return android::BAD_VALUE;
Peng Xu3b170172017-02-15 23:25:21 -0800155 }
156
157 native_handle_t *resourceHandle = native_handle_create(1 /* nFd */, 0 /* nInt */);
158 if (!resourceHandle) {
159 return android::NO_MEMORY;
160 }
161
162 resourceHandle->data[0] = fd;
163 int ret = static_cast<SensorManager *>(manager)->createDirectChannel(
164 size, ASENSOR_DIRECT_CHANNEL_TYPE_SHARED_MEMORY, resourceHandle);
165 native_handle_delete(resourceHandle);
166 return ret;
167}
168
169int ASensorManager_createHardwareBufferDirectChannel(
170 ASensorManager *manager, AHardwareBuffer const *buffer, size_t size) {
171 RETURN_IF_MANAGER_IS_NULL(android::BAD_VALUE);
172
173 if (buffer == nullptr) {
174 ERROR_INVALID_PARAMETER("buffer cannot be NULL");
175 return android::BAD_VALUE;
176 }
177
178 if (size < sizeof(ASensorEvent)) {
179 ERROR_INVALID_PARAMETER("size has to be greater or equal to sizeof(ASensorEvent).");
Peng Xu63483ad2017-02-28 17:00:16 -0800180 return android::BAD_VALUE;
Peng Xu3b170172017-02-15 23:25:21 -0800181 }
182
183 const native_handle_t *resourceHandle = AHardwareBuffer_getNativeHandle(buffer);
184 if (!resourceHandle) {
185 return android::NO_MEMORY;
186 }
187
188 return static_cast<SensorManager *>(manager)->createDirectChannel(
189 size, ASENSOR_DIRECT_CHANNEL_TYPE_HARDWARE_BUFFER, resourceHandle);
190}
191
192void ASensorManager_destroyDirectChannel(ASensorManager *manager, int channelId) {
193 RETURN_IF_MANAGER_IS_NULL(void());
194
195 static_cast<SensorManager *>(manager)->destroyDirectChannel(channelId);
196}
197
198int ASensorManager_configureDirectReport(
199 ASensorManager *manager, ASensor const *sensor, int channelId, int rate) {
200 RETURN_IF_MANAGER_IS_NULL(android::BAD_VALUE);
201
202 int sensorHandle;
203 if (sensor == nullptr) {
204 if (rate != ASENSOR_DIRECT_RATE_STOP) {
205 ERROR_INVALID_PARAMETER(
206 "sensor cannot be null when rate is not ASENSOR_DIRECT_RATE_STOP");
207 return android::BAD_VALUE;
208 }
209 sensorHandle = -1;
210 } else {
211 sensorHandle = static_cast<Sensor const *>(sensor)->getHandle();
212 }
213 return static_cast<SensorManager *>(manager)->configureDirectChannel(
214 channelId, sensorHandle, rate);
215}
216
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700217/*****************************************************************************/
218
Aniroop Mathuree5c18f2015-11-03 02:02:09 +0530219int ASensorEventQueue_registerSensor(ASensorEventQueue* queue, ASensor const* sensor,
Peng Xu63483ad2017-02-28 17:00:16 -0800220 int32_t samplingPeriodUs, int64_t maxBatchReportLatencyUs) {
221 RETURN_IF_QUEUE_IS_NULL(android::BAD_VALUE);
222 RETURN_IF_SENSOR_IS_NULL(android::BAD_VALUE);
223 if (samplingPeriodUs < 0 || maxBatchReportLatencyUs < 0) {
224 ERROR_INVALID_PARAMETER("samplingPeriodUs and maxBatchReportLatencyUs cannot be negative");
225 return android::BAD_VALUE;
226 }
227
Aniroop Mathuree5c18f2015-11-03 02:02:09 +0530228 return static_cast<SensorEventQueue*>(queue)->enableSensor(
229 static_cast<Sensor const*>(sensor)->getHandle(), samplingPeriodUs,
230 maxBatchReportLatencyUs, 0);
231}
232
Peng Xu63483ad2017-02-28 17:00:16 -0800233int ASensorEventQueue_enableSensor(ASensorEventQueue* queue, ASensor const* sensor) {
234 RETURN_IF_QUEUE_IS_NULL(android::BAD_VALUE);
235 RETURN_IF_SENSOR_IS_NULL(android::BAD_VALUE);
236
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700237 return static_cast<SensorEventQueue*>(queue)->enableSensor(
Mathias Agopian1bf79782010-07-14 23:41:37 -0700238 static_cast<Sensor const*>(sensor));
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700239}
240
Peng Xu63483ad2017-02-28 17:00:16 -0800241int ASensorEventQueue_disableSensor(ASensorEventQueue* queue, ASensor const* sensor) {
242 RETURN_IF_QUEUE_IS_NULL(android::BAD_VALUE);
243 RETURN_IF_SENSOR_IS_NULL(android::BAD_VALUE);
244
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700245 return static_cast<SensorEventQueue*>(queue)->disableSensor(
Mathias Agopian1bf79782010-07-14 23:41:37 -0700246 static_cast<Sensor const*>(sensor));
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700247}
248
Peng Xu63483ad2017-02-28 17:00:16 -0800249int ASensorEventQueue_setEventRate(ASensorEventQueue* queue, ASensor const* sensor, int32_t usec) {
250 RETURN_IF_QUEUE_IS_NULL(android::BAD_VALUE);
251 RETURN_IF_SENSOR_IS_NULL(android::BAD_VALUE);
252
253 if (usec < 0) {
254 ERROR_INVALID_PARAMETER("usec cannot be negative");
255 return android::BAD_VALUE;
256 }
257
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700258 return static_cast<SensorEventQueue*>(queue)->setEventRate(
Mathias Agopian1bf79782010-07-14 23:41:37 -0700259 static_cast<Sensor const*>(sensor), us2ns(usec));
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700260}
261
Peng Xu63483ad2017-02-28 17:00:16 -0800262int ASensorEventQueue_hasEvents(ASensorEventQueue* queue) {
263 RETURN_IF_QUEUE_IS_NULL(android::BAD_VALUE);
264
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700265 struct pollfd pfd;
266 pfd.fd = static_cast<SensorEventQueue*>(queue)->getFd();
267 pfd.events = POLLIN;
268 pfd.revents = 0;
269
270 int nfd = poll(&pfd, 1, 0);
271
272 if (nfd < 0)
273 return -errno;
274
275 if (pfd.revents != POLLIN)
276 return -1;
277
278 return (nfd == 0) ? 0 : 1;
279}
280
Peng Xu63483ad2017-02-28 17:00:16 -0800281ssize_t ASensorEventQueue_getEvents(ASensorEventQueue* queue, ASensorEvent* events, size_t count) {
282 RETURN_IF_QUEUE_IS_NULL(android::BAD_VALUE);
283 if (events == nullptr) {
284 ERROR_INVALID_PARAMETER("events cannot be NULL");
285 return android::BAD_VALUE;
286 }
287
Brian Stack9da89b22019-01-14 12:15:58 -0800288 SensorEventQueue* sensorQueue = static_cast<SensorEventQueue*>(queue);
289 ssize_t actual = sensorQueue->read(events, count);
Aravind Akella35187bd2014-02-11 18:44:42 -0800290 if (actual > 0) {
Brian Stack9da89b22019-01-14 12:15:58 -0800291 sensorQueue->sendAck(events, actual);
Aravind Akella35187bd2014-02-11 18:44:42 -0800292 }
Brian Stack9da89b22019-01-14 12:15:58 -0800293
294 return sensorQueue->filterEvents(events, actual);
295}
296
297int ASensorEventQueue_requestAdditionalInfoEvents(ASensorEventQueue* queue, bool enable) {
298 RETURN_IF_QUEUE_IS_NULL(android::BAD_VALUE);
299 queue->requestAdditionalInfo = enable;
300 return android::OK;
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700301}
302
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700303/*****************************************************************************/
304
Peng Xu63483ad2017-02-28 17:00:16 -0800305const char* ASensor_getName(ASensor const* sensor) {
306 RETURN_IF_SENSOR_IS_NULL(nullptr);
Tomasz Wasilczyk3815d342023-08-10 23:54:44 +0000307 return static_cast<Sensor const*>(sensor)->getName().c_str();
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700308}
309
Peng Xu63483ad2017-02-28 17:00:16 -0800310const char* ASensor_getVendor(ASensor const* sensor) {
311 RETURN_IF_SENSOR_IS_NULL(nullptr);
Tomasz Wasilczyk3815d342023-08-10 23:54:44 +0000312 return static_cast<Sensor const*>(sensor)->getVendor().c_str();
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700313}
314
Peng Xu63483ad2017-02-28 17:00:16 -0800315int ASensor_getType(ASensor const* sensor) {
316 RETURN_IF_SENSOR_IS_NULL(ASENSOR_TYPE_INVALID);
Mathias Agopian1bf79782010-07-14 23:41:37 -0700317 return static_cast<Sensor const*>(sensor)->getType();
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700318}
319
Peng Xu63483ad2017-02-28 17:00:16 -0800320float ASensor_getResolution(ASensor const* sensor) {
321 RETURN_IF_SENSOR_IS_NULL(ASENSOR_RESOLUTION_INVALID);
Mathias Agopian1bf79782010-07-14 23:41:37 -0700322 return static_cast<Sensor const*>(sensor)->getResolution();
Mathias Agopianb957b9d2010-07-13 22:21:56 -0700323}
324
Peng Xu63483ad2017-02-28 17:00:16 -0800325int ASensor_getMinDelay(ASensor const* sensor) {
326 RETURN_IF_SENSOR_IS_NULL(ASENSOR_DELAY_INVALID);
Mathias Agopian050b5622010-07-29 16:51:38 -0700327 return static_cast<Sensor const*>(sensor)->getMinDelay();
328}
Aravind Akellacd9a7bb2014-04-07 22:55:21 +0000329
Peng Xu63483ad2017-02-28 17:00:16 -0800330int ASensor_getFifoMaxEventCount(ASensor const* sensor) {
331 RETURN_IF_SENSOR_IS_NULL(ASENSOR_FIFO_COUNT_INVALID);
Aravind Akellacd9a7bb2014-04-07 22:55:21 +0000332 return static_cast<Sensor const*>(sensor)->getFifoMaxEventCount();
333}
334
Peng Xu63483ad2017-02-28 17:00:16 -0800335int ASensor_getFifoReservedEventCount(ASensor const* sensor) {
336 RETURN_IF_SENSOR_IS_NULL(ASENSOR_FIFO_COUNT_INVALID);
Aravind Akellacd9a7bb2014-04-07 22:55:21 +0000337 return static_cast<Sensor const*>(sensor)->getFifoReservedEventCount();
338}
339
Peng Xu63483ad2017-02-28 17:00:16 -0800340const char* ASensor_getStringType(ASensor const* sensor) {
341 RETURN_IF_SENSOR_IS_NULL(nullptr);
Tomasz Wasilczyk3815d342023-08-10 23:54:44 +0000342 return static_cast<Sensor const*>(sensor)->getStringType().c_str();
Aravind Akellacd9a7bb2014-04-07 22:55:21 +0000343}
Aravind Akella27900352014-06-03 19:20:42 -0700344
Peng Xu63483ad2017-02-28 17:00:16 -0800345int ASensor_getReportingMode(ASensor const* sensor) {
346 RETURN_IF_SENSOR_IS_NULL(AREPORTING_MODE_INVALID);
Aravind Akella27900352014-06-03 19:20:42 -0700347 return static_cast<Sensor const*>(sensor)->getReportingMode();
348}
Aravind Akella99fe1652014-08-05 15:02:11 -0700349
Peng Xu63483ad2017-02-28 17:00:16 -0800350bool ASensor_isWakeUpSensor(ASensor const* sensor) {
351 RETURN_IF_SENSOR_IS_NULL(false);
Aravind Akella99fe1652014-08-05 15:02:11 -0700352 return static_cast<Sensor const*>(sensor)->isWakeUpSensor();
Aravind Akella2af91d02015-07-29 18:39:52 -0700353}
Peng Xu3b170172017-02-15 23:25:21 -0800354
355bool ASensor_isDirectChannelTypeSupported(ASensor const *sensor, int channelType) {
356 RETURN_IF_SENSOR_IS_NULL(false);
357 return static_cast<Sensor const *>(sensor)->isDirectChannelTypeSupported(channelType);
358}
359
360int ASensor_getHighestDirectReportRateLevel(ASensor const *sensor) {
361 RETURN_IF_SENSOR_IS_NULL(ASENSOR_DIRECT_RATE_STOP);
362 return static_cast<Sensor const *>(sensor)->getHighestDirectReportRateLevel();
363}
Brian Stack38c97d42019-01-09 13:41:00 -0800364
365int ASensor_getHandle(ASensor const* sensor) {
366 RETURN_IF_SENSOR_IS_NULL(ASENSOR_INVALID);
367 return static_cast<Sensor const*>(sensor)->getHandle();
368}