blob: 70180f8a7a1ef776d4694ecae39504b8d057c103 [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
17#include <stdint.h>
18#include <sys/types.h>
Aravind Akellad9441e42014-05-13 18:20:30 -070019#include <sys/limits.h>
Mathias Agopian589ce852010-07-13 22:21:56 -070020
21#include <utils/Errors.h>
22#include <utils/String8.h>
23#include <utils/Flattenable.h>
24
25#include <hardware/sensors.h>
26
27#include <gui/Sensor.h>
Aravind Akellad9441e42014-05-13 18:20:30 -070028#include <log/log.h>
Mathias Agopian589ce852010-07-13 22:21:56 -070029
30// ----------------------------------------------------------------------------
31namespace android {
32// ----------------------------------------------------------------------------
33
34Sensor::Sensor()
35 : mHandle(0), mType(0),
36 mMinValue(0), mMaxValue(0), mResolution(0),
Aravind Akella9a844cf2014-02-11 18:58:52 -080037 mPower(0), mMinDelay(0), mFifoReservedEventCount(0), mFifoMaxEventCount(0),
Aravind Akellad9441e42014-05-13 18:20:30 -070038 mMaxDelay(0), mWakeUpSensor(false)
Mathias Agopian589ce852010-07-13 22:21:56 -070039{
40}
41
Aravind Akella724d91d2013-06-27 12:04:23 -070042Sensor::Sensor(struct sensor_t const* hwSensor, int halVersion)
Mathias Agopiana7352c92010-07-14 23:41:37 -070043{
44 mName = hwSensor->name;
45 mVendor = hwSensor->vendor;
Mathias Agopian2ebc4d62012-05-04 15:47:13 -070046 mVersion = hwSensor->version;
Mathias Agopiana7352c92010-07-14 23:41:37 -070047 mHandle = hwSensor->handle;
48 mType = hwSensor->type;
49 mMinValue = 0; // FIXME: minValue
50 mMaxValue = hwSensor->maxRange; // FIXME: maxValue
51 mResolution = hwSensor->resolution;
52 mPower = hwSensor->power;
Mathias Agopiana48bcf62010-07-29 16:51:38 -070053 mMinDelay = hwSensor->minDelay;
Aravind Akella9a844cf2014-02-11 18:58:52 -080054 mWakeUpSensor = false;
Aravind Akella70018042014-04-07 22:52:37 +000055
Aravind Akella724d91d2013-06-27 12:04:23 -070056 // Set fifo event count zero for older devices which do not support batching. Fused
57 // sensors also have their fifo counts set to zero.
58 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_1) {
59 mFifoReservedEventCount = hwSensor->fifoReservedEventCount;
60 mFifoMaxEventCount = hwSensor->fifoMaxEventCount;
Aravind Akellad35e3af2014-05-12 17:14:56 -070061 } else {
62 mFifoReservedEventCount = 0;
63 mFifoMaxEventCount = 0;
Aravind Akella70018042014-04-07 22:52:37 +000064 }
65
Aravind Akellad9441e42014-05-13 18:20:30 -070066 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) {
67 if (hwSensor->maxDelay > INT_MAX) {
68 // Max delay is declared as a 64 bit integer for 64 bit architectures. But it should
69 // always fit in a 32 bit integer, log error and cap it to INT_MAX.
70 ALOGE("Sensor maxDelay overflow error %s %lld", mName.string(), hwSensor->maxDelay);
71 mMaxDelay = INT_MAX;
72 } else {
73 mMaxDelay = (int32_t) hwSensor->maxDelay;
74 }
75 } else {
76 // For older hals set maxDelay to 0.
77 mMaxDelay = 0;
78 }
79
Aravind Akella70018042014-04-07 22:52:37 +000080 // Ensure existing sensors have correct string type and required
81 // permissions.
82 switch (mType) {
83 case SENSOR_TYPE_ACCELEROMETER:
84 mStringType = SENSOR_STRING_TYPE_ACCELEROMETER;
85 break;
86 case SENSOR_TYPE_AMBIENT_TEMPERATURE:
87 mStringType = SENSOR_STRING_TYPE_AMBIENT_TEMPERATURE;
88 break;
89 case SENSOR_TYPE_GAME_ROTATION_VECTOR:
90 mStringType = SENSOR_STRING_TYPE_GAME_ROTATION_VECTOR;
91 break;
92 case SENSOR_TYPE_GEOMAGNETIC_ROTATION_VECTOR:
93 mStringType = SENSOR_STRING_TYPE_GEOMAGNETIC_ROTATION_VECTOR;
94 break;
95 case SENSOR_TYPE_GRAVITY:
96 mStringType = SENSOR_STRING_TYPE_GRAVITY;
97 break;
98 case SENSOR_TYPE_GYROSCOPE:
99 mStringType = SENSOR_STRING_TYPE_GYROSCOPE;
100 break;
101 case SENSOR_TYPE_GYROSCOPE_UNCALIBRATED:
102 mStringType = SENSOR_STRING_TYPE_GYROSCOPE_UNCALIBRATED;
103 break;
104 case SENSOR_TYPE_HEART_RATE:
105 mStringType = SENSOR_STRING_TYPE_HEART_RATE;
106 mRequiredPermission = SENSOR_PERMISSION_BODY_SENSORS;
107 break;
108 case SENSOR_TYPE_LIGHT:
109 mStringType = SENSOR_STRING_TYPE_LIGHT;
110 break;
111 case SENSOR_TYPE_LINEAR_ACCELERATION:
112 mStringType = SENSOR_STRING_TYPE_LINEAR_ACCELERATION;
113 break;
114 case SENSOR_TYPE_MAGNETIC_FIELD:
115 mStringType = SENSOR_STRING_TYPE_MAGNETIC_FIELD;
116 break;
117 case SENSOR_TYPE_MAGNETIC_FIELD_UNCALIBRATED:
118 mStringType = SENSOR_STRING_TYPE_MAGNETIC_FIELD_UNCALIBRATED;
119 break;
120 case SENSOR_TYPE_ORIENTATION:
121 mStringType = SENSOR_STRING_TYPE_ORIENTATION;
122 break;
123 case SENSOR_TYPE_PRESSURE:
124 mStringType = SENSOR_STRING_TYPE_PRESSURE;
125 break;
126 case SENSOR_TYPE_PROXIMITY:
127 mStringType = SENSOR_STRING_TYPE_PROXIMITY;
Aravind Akella9a844cf2014-02-11 18:58:52 -0800128 mWakeUpSensor = true;
Aravind Akella70018042014-04-07 22:52:37 +0000129 break;
130 case SENSOR_TYPE_RELATIVE_HUMIDITY:
131 mStringType = SENSOR_STRING_TYPE_RELATIVE_HUMIDITY;
132 break;
133 case SENSOR_TYPE_ROTATION_VECTOR:
134 mStringType = SENSOR_STRING_TYPE_ROTATION_VECTOR;
135 break;
136 case SENSOR_TYPE_SIGNIFICANT_MOTION:
137 mStringType = SENSOR_STRING_TYPE_SIGNIFICANT_MOTION;
Aravind Akella9a844cf2014-02-11 18:58:52 -0800138 mWakeUpSensor = true;
Aravind Akella70018042014-04-07 22:52:37 +0000139 break;
140 case SENSOR_TYPE_STEP_COUNTER:
141 mStringType = SENSOR_STRING_TYPE_STEP_COUNTER;
142 break;
143 case SENSOR_TYPE_STEP_DETECTOR:
144 mStringType = SENSOR_STRING_TYPE_STEP_DETECTOR;
145 break;
146 case SENSOR_TYPE_TEMPERATURE:
147 mStringType = SENSOR_STRING_TYPE_TEMPERATURE;
148 break;
Aravind Akella9a844cf2014-02-11 18:58:52 -0800149 case SENSOR_TYPE_NON_WAKE_UP_PROXIMITY_SENSOR:
150 mStringType = SENSOR_STRING_TYPE_NON_WAKE_UP_PROXIMITY_SENSOR;
151 break;
152 case SENSOR_TYPE_WAKE_UP_ACCELEROMETER:
153 mStringType = SENSOR_STRING_TYPE_WAKE_UP_ACCELEROMETER;
154 mWakeUpSensor = true;
155 break;
156 case SENSOR_TYPE_WAKE_UP_MAGNETIC_FIELD:
157 mStringType = SENSOR_STRING_TYPE_WAKE_UP_MAGNETIC_FIELD;
158 mWakeUpSensor = true;
159 break;
160 case SENSOR_TYPE_WAKE_UP_ORIENTATION:
161 mStringType = SENSOR_STRING_TYPE_WAKE_UP_ORIENTATION;
162 mWakeUpSensor = true;
163 break;
164 case SENSOR_TYPE_WAKE_UP_GYROSCOPE:
165 mStringType = SENSOR_STRING_TYPE_WAKE_UP_GYROSCOPE;
166 mWakeUpSensor = true;
167 break;
168 case SENSOR_TYPE_WAKE_UP_LIGHT:
169 mStringType = SENSOR_STRING_TYPE_WAKE_UP_LIGHT;
170 mWakeUpSensor = true;
171 break;
172 case SENSOR_TYPE_WAKE_UP_PRESSURE:
173 mStringType = SENSOR_STRING_TYPE_WAKE_UP_PRESSURE;
174 mWakeUpSensor = true;
175 break;
176 case SENSOR_TYPE_WAKE_UP_GRAVITY:
177 mStringType = SENSOR_STRING_TYPE_WAKE_UP_GRAVITY;
178 mWakeUpSensor = true;
179 break;
180 case SENSOR_TYPE_WAKE_UP_LINEAR_ACCELERATION:
181 mStringType = SENSOR_STRING_TYPE_WAKE_UP_LINEAR_ACCELERATION;
182 mWakeUpSensor = true;
183 break;
184 case SENSOR_TYPE_WAKE_UP_ROTATION_VECTOR:
185 mStringType = SENSOR_STRING_TYPE_WAKE_UP_ROTATION_VECTOR;
186 mWakeUpSensor = true;
187 break;
188 case SENSOR_TYPE_WAKE_UP_RELATIVE_HUMIDITY:
189 mStringType = SENSOR_STRING_TYPE_WAKE_UP_RELATIVE_HUMIDITY;
190 mWakeUpSensor = true;
191 break;
192 case SENSOR_TYPE_WAKE_UP_AMBIENT_TEMPERATURE:
193 mStringType = SENSOR_STRING_TYPE_WAKE_UP_AMBIENT_TEMPERATURE;
194 mWakeUpSensor = true;
195 break;
196 case SENSOR_TYPE_WAKE_UP_MAGNETIC_FIELD_UNCALIBRATED:
197 mStringType = SENSOR_STRING_TYPE_WAKE_UP_MAGNETIC_FIELD_UNCALIBRATED;
198 mWakeUpSensor = true;
199 break;
200 case SENSOR_TYPE_WAKE_UP_GAME_ROTATION_VECTOR:
201 mStringType = SENSOR_STRING_TYPE_WAKE_UP_GAME_ROTATION_VECTOR;
202 mWakeUpSensor = true;
203 break;
204 case SENSOR_TYPE_WAKE_UP_GYROSCOPE_UNCALIBRATED:
205 mStringType = SENSOR_STRING_TYPE_WAKE_UP_GYROSCOPE_UNCALIBRATED;
206 mWakeUpSensor = true;
207 break;
208 case SENSOR_TYPE_WAKE_UP_STEP_DETECTOR:
209 mStringType = SENSOR_STRING_TYPE_WAKE_UP_STEP_DETECTOR;
210 mWakeUpSensor = true;
211 break;
212 case SENSOR_TYPE_WAKE_UP_STEP_COUNTER:
213 mStringType = SENSOR_STRING_TYPE_WAKE_UP_STEP_COUNTER;
214 mWakeUpSensor = true;
215 break;
216 case SENSOR_TYPE_WAKE_UP_GEOMAGNETIC_ROTATION_VECTOR:
217 mStringType = SENSOR_STRING_TYPE_WAKE_UP_GEOMAGNETIC_ROTATION_VECTOR;
218 mWakeUpSensor = true;
219 break;
220 case SENSOR_TYPE_WAKE_UP_HEART_RATE:
221 mStringType = SENSOR_STRING_TYPE_WAKE_UP_HEART_RATE;
222 mRequiredPermission = SENSOR_PERMISSION_BODY_SENSORS;
223 mWakeUpSensor = true;
224 break;
Etienne Le Grande284a902014-05-07 19:49:05 -0700225 case SENSOR_TYPE_WAKE_GESTURE:
226 mStringType = SENSOR_STRING_TYPE_WAKE_GESTURE;
227 mWakeUpSensor = true;
228 break;
Aravind Akella70018042014-04-07 22:52:37 +0000229 default:
Aravind Akella9a844cf2014-02-11 18:58:52 -0800230 // Only pipe the stringType, requiredPermission and flags for custom sensors.
Aravind Akella70018042014-04-07 22:52:37 +0000231 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_2 && hwSensor->stringType) {
232 mStringType = hwSensor->stringType;
233 }
234 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_2 && hwSensor->requiredPermission) {
235 mRequiredPermission = hwSensor->requiredPermission;
236 }
Aravind Akella9a844cf2014-02-11 18:58:52 -0800237 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) {
238 mWakeUpSensor = hwSensor->flags & SENSOR_FLAG_WAKE_UP;
239 }
Aravind Akella70018042014-04-07 22:52:37 +0000240 break;
Aravind Akella724d91d2013-06-27 12:04:23 -0700241 }
Mathias Agopiana7352c92010-07-14 23:41:37 -0700242}
243
Mathias Agopian589ce852010-07-13 22:21:56 -0700244Sensor::~Sensor()
245{
246}
247
248const String8& Sensor::getName() const {
249 return mName;
250}
251
252const String8& Sensor::getVendor() const {
253 return mVendor;
254}
255
256int32_t Sensor::getHandle() const {
257 return mHandle;
258}
259
260int32_t Sensor::getType() const {
261 return mType;
262}
263
264float Sensor::getMinValue() const {
265 return mMinValue;
266}
267
268float Sensor::getMaxValue() const {
269 return mMaxValue;
270}
271
272float Sensor::getResolution() const {
273 return mResolution;
274}
275
276float Sensor::getPowerUsage() const {
277 return mPower;
278}
279
Mathias Agopiana48bcf62010-07-29 16:51:38 -0700280int32_t Sensor::getMinDelay() const {
281 return mMinDelay;
282}
283
Mathias Agopianb62013f2011-05-17 22:54:42 -0700284nsecs_t Sensor::getMinDelayNs() const {
285 return getMinDelay() * 1000;
286}
287
288int32_t Sensor::getVersion() const {
289 return mVersion;
290}
291
Aravind Akella724d91d2013-06-27 12:04:23 -0700292int32_t Sensor::getFifoReservedEventCount() const {
293 return mFifoReservedEventCount;
294}
295
296int32_t Sensor::getFifoMaxEventCount() const {
297 return mFifoMaxEventCount;
298}
299
Aravind Akella70018042014-04-07 22:52:37 +0000300const String8& Sensor::getStringType() const {
301 return mStringType;
302}
303
304const String8& Sensor::getRequiredPermission() const {
305 return mRequiredPermission;
306}
307
Aravind Akellad9441e42014-05-13 18:20:30 -0700308int32_t Sensor::getMaxDelay() const {
309 return mMaxDelay;
310}
311
Aravind Akella9a844cf2014-02-11 18:58:52 -0800312bool Sensor::isWakeUpSensor() const {
313 return mWakeUpSensor;
314}
315
Mathias Agopiane1424282013-07-29 21:24:40 -0700316size_t Sensor::getFlattenedSize() const
Mathias Agopian589ce852010-07-13 22:21:56 -0700317{
Mathias Agopiane1424282013-07-29 21:24:40 -0700318 size_t fixedSize =
Mathias Agopian2ebc4d62012-05-04 15:47:13 -0700319 sizeof(int32_t) * 3 +
Mathias Agopiana48bcf62010-07-29 16:51:38 -0700320 sizeof(float) * 4 +
Aravind Akellad9441e42014-05-13 18:20:30 -0700321 sizeof(int32_t) * 4 +
322 sizeof(bool) * 1;
Mathias Agopiane1424282013-07-29 21:24:40 -0700323
324 size_t variableSize =
Aravind Akella70018042014-04-07 22:52:37 +0000325 sizeof(uint32_t) + FlattenableUtils::align<4>(mName.length()) +
326 sizeof(uint32_t) + FlattenableUtils::align<4>(mVendor.length()) +
327 sizeof(uint32_t) + FlattenableUtils::align<4>(mStringType.length()) +
328 sizeof(uint32_t) + FlattenableUtils::align<4>(mRequiredPermission.length());
Mathias Agopiane1424282013-07-29 21:24:40 -0700329
330 return fixedSize + variableSize;
Mathias Agopian589ce852010-07-13 22:21:56 -0700331}
332
Mathias Agopiane1424282013-07-29 21:24:40 -0700333status_t Sensor::flatten(void* buffer, size_t size) const {
334 if (size < getFlattenedSize()) {
335 return NO_MEMORY;
336 }
Mathias Agopian589ce852010-07-13 22:21:56 -0700337
Aravind Akella70018042014-04-07 22:52:37 +0000338 flattenString8(buffer, size, mName);
339 flattenString8(buffer, size, mVendor);
Mathias Agopiane1424282013-07-29 21:24:40 -0700340 FlattenableUtils::write(buffer, size, mVersion);
341 FlattenableUtils::write(buffer, size, mHandle);
342 FlattenableUtils::write(buffer, size, mType);
343 FlattenableUtils::write(buffer, size, mMinValue);
344 FlattenableUtils::write(buffer, size, mMaxValue);
345 FlattenableUtils::write(buffer, size, mResolution);
346 FlattenableUtils::write(buffer, size, mPower);
347 FlattenableUtils::write(buffer, size, mMinDelay);
Aravind Akella724d91d2013-06-27 12:04:23 -0700348 FlattenableUtils::write(buffer, size, mFifoReservedEventCount);
349 FlattenableUtils::write(buffer, size, mFifoMaxEventCount);
Aravind Akella70018042014-04-07 22:52:37 +0000350 flattenString8(buffer, size, mStringType);
351 flattenString8(buffer, size, mRequiredPermission);
Aravind Akellad9441e42014-05-13 18:20:30 -0700352 FlattenableUtils::write(buffer, size, mMaxDelay);
353 FlattenableUtils::write(buffer, size, mWakeUpSensor);
Mathias Agopian589ce852010-07-13 22:21:56 -0700354 return NO_ERROR;
355}
356
Mathias Agopiane1424282013-07-29 21:24:40 -0700357status_t Sensor::unflatten(void const* buffer, size_t size) {
Aravind Akella70018042014-04-07 22:52:37 +0000358 if (!unflattenString8(buffer, size, mName)) {
Mathias Agopiane1424282013-07-29 21:24:40 -0700359 return NO_MEMORY;
360 }
Aravind Akella70018042014-04-07 22:52:37 +0000361 if (!unflattenString8(buffer, size, mVendor)) {
Mathias Agopiane1424282013-07-29 21:24:40 -0700362 return NO_MEMORY;
363 }
Mathias Agopiane1424282013-07-29 21:24:40 -0700364
365 size_t fixedSize =
366 sizeof(int32_t) * 3 +
367 sizeof(float) * 4 +
Aravind Akellad9441e42014-05-13 18:20:30 -0700368 sizeof(int32_t) * 4 +
369 sizeof(bool) * 1;
Mathias Agopiane1424282013-07-29 21:24:40 -0700370 if (size < fixedSize) {
371 return NO_MEMORY;
372 }
373
374 FlattenableUtils::read(buffer, size, mVersion);
375 FlattenableUtils::read(buffer, size, mHandle);
376 FlattenableUtils::read(buffer, size, mType);
377 FlattenableUtils::read(buffer, size, mMinValue);
378 FlattenableUtils::read(buffer, size, mMaxValue);
379 FlattenableUtils::read(buffer, size, mResolution);
380 FlattenableUtils::read(buffer, size, mPower);
381 FlattenableUtils::read(buffer, size, mMinDelay);
Aravind Akella724d91d2013-06-27 12:04:23 -0700382 FlattenableUtils::read(buffer, size, mFifoReservedEventCount);
383 FlattenableUtils::read(buffer, size, mFifoMaxEventCount);
Aravind Akella70018042014-04-07 22:52:37 +0000384
385 if (!unflattenString8(buffer, size, mStringType)) {
386 return NO_MEMORY;
387 }
388 if (!unflattenString8(buffer, size, mRequiredPermission)) {
389 return NO_MEMORY;
390 }
Aravind Akellad9441e42014-05-13 18:20:30 -0700391 FlattenableUtils::read(buffer, size, mMaxDelay);
392 FlattenableUtils::read(buffer, size, mWakeUpSensor);
Mathias Agopian589ce852010-07-13 22:21:56 -0700393 return NO_ERROR;
394}
395
Aravind Akella70018042014-04-07 22:52:37 +0000396void Sensor::flattenString8(void*& buffer, size_t& size,
397 const String8& string8) {
398 uint32_t len = string8.length();
399 FlattenableUtils::write(buffer, size, len);
400 memcpy(static_cast<char*>(buffer), string8.string(), len);
401 FlattenableUtils::advance(buffer, size, FlattenableUtils::align<4>(len));
402}
403
404bool Sensor::unflattenString8(void const*& buffer, size_t& size, String8& outputString8) {
405 uint32_t len;
406 if (size < sizeof(len)) {
407 return false;
408 }
409 FlattenableUtils::read(buffer, size, len);
410 if (size < len) {
411 return false;
412 }
413 outputString8.setTo(static_cast<char const*>(buffer), len);
414 FlattenableUtils::advance(buffer, size, FlattenableUtils::align<4>(len));
415 return true;
416}
417
Mathias Agopian589ce852010-07-13 22:21:56 -0700418// ----------------------------------------------------------------------------
419}; // namespace android