blob: 6f1a3f206ac3a0762345857f58240bf136e356a1 [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>
19
20#include <utils/Errors.h>
21#include <utils/String8.h>
22#include <utils/Flattenable.h>
23
24#include <hardware/sensors.h>
25
26#include <gui/Sensor.h>
27
28// ----------------------------------------------------------------------------
29namespace android {
30// ----------------------------------------------------------------------------
31
32Sensor::Sensor()
33 : mHandle(0), mType(0),
34 mMinValue(0), mMaxValue(0), mResolution(0),
Aravind Akella724d91d2013-06-27 12:04:23 -070035 mPower(0), mMinDelay(0), mFifoReservedEventCount(0), mFifoMaxEventCount(0)
Mathias Agopian589ce852010-07-13 22:21:56 -070036{
37}
38
Aravind Akella724d91d2013-06-27 12:04:23 -070039Sensor::Sensor(struct sensor_t const* hwSensor, int halVersion)
Mathias Agopiana7352c92010-07-14 23:41:37 -070040{
41 mName = hwSensor->name;
42 mVendor = hwSensor->vendor;
Mathias Agopian2ebc4d62012-05-04 15:47:13 -070043 mVersion = hwSensor->version;
Mathias Agopiana7352c92010-07-14 23:41:37 -070044 mHandle = hwSensor->handle;
45 mType = hwSensor->type;
46 mMinValue = 0; // FIXME: minValue
47 mMaxValue = hwSensor->maxRange; // FIXME: maxValue
48 mResolution = hwSensor->resolution;
49 mPower = hwSensor->power;
Mathias Agopiana48bcf62010-07-29 16:51:38 -070050 mMinDelay = hwSensor->minDelay;
Aravind Akella70018042014-04-07 22:52:37 +000051
Aravind Akella724d91d2013-06-27 12:04:23 -070052 // Set fifo event count zero for older devices which do not support batching. Fused
53 // sensors also have their fifo counts set to zero.
54 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_1) {
55 mFifoReservedEventCount = hwSensor->fifoReservedEventCount;
56 mFifoMaxEventCount = hwSensor->fifoMaxEventCount;
Aravind Akella70018042014-04-07 22:52:37 +000057 }
58
59 // Ensure existing sensors have correct string type and required
60 // permissions.
61 switch (mType) {
62 case SENSOR_TYPE_ACCELEROMETER:
63 mStringType = SENSOR_STRING_TYPE_ACCELEROMETER;
64 break;
65 case SENSOR_TYPE_AMBIENT_TEMPERATURE:
66 mStringType = SENSOR_STRING_TYPE_AMBIENT_TEMPERATURE;
67 break;
68 case SENSOR_TYPE_GAME_ROTATION_VECTOR:
69 mStringType = SENSOR_STRING_TYPE_GAME_ROTATION_VECTOR;
70 break;
71 case SENSOR_TYPE_GEOMAGNETIC_ROTATION_VECTOR:
72 mStringType = SENSOR_STRING_TYPE_GEOMAGNETIC_ROTATION_VECTOR;
73 break;
74 case SENSOR_TYPE_GRAVITY:
75 mStringType = SENSOR_STRING_TYPE_GRAVITY;
76 break;
77 case SENSOR_TYPE_GYROSCOPE:
78 mStringType = SENSOR_STRING_TYPE_GYROSCOPE;
79 break;
80 case SENSOR_TYPE_GYROSCOPE_UNCALIBRATED:
81 mStringType = SENSOR_STRING_TYPE_GYROSCOPE_UNCALIBRATED;
82 break;
83 case SENSOR_TYPE_HEART_RATE:
84 mStringType = SENSOR_STRING_TYPE_HEART_RATE;
85 mRequiredPermission = SENSOR_PERMISSION_BODY_SENSORS;
86 break;
87 case SENSOR_TYPE_LIGHT:
88 mStringType = SENSOR_STRING_TYPE_LIGHT;
89 break;
90 case SENSOR_TYPE_LINEAR_ACCELERATION:
91 mStringType = SENSOR_STRING_TYPE_LINEAR_ACCELERATION;
92 break;
93 case SENSOR_TYPE_MAGNETIC_FIELD:
94 mStringType = SENSOR_STRING_TYPE_MAGNETIC_FIELD;
95 break;
96 case SENSOR_TYPE_MAGNETIC_FIELD_UNCALIBRATED:
97 mStringType = SENSOR_STRING_TYPE_MAGNETIC_FIELD_UNCALIBRATED;
98 break;
99 case SENSOR_TYPE_ORIENTATION:
100 mStringType = SENSOR_STRING_TYPE_ORIENTATION;
101 break;
102 case SENSOR_TYPE_PRESSURE:
103 mStringType = SENSOR_STRING_TYPE_PRESSURE;
104 break;
105 case SENSOR_TYPE_PROXIMITY:
106 mStringType = SENSOR_STRING_TYPE_PROXIMITY;
107 break;
108 case SENSOR_TYPE_RELATIVE_HUMIDITY:
109 mStringType = SENSOR_STRING_TYPE_RELATIVE_HUMIDITY;
110 break;
111 case SENSOR_TYPE_ROTATION_VECTOR:
112 mStringType = SENSOR_STRING_TYPE_ROTATION_VECTOR;
113 break;
114 case SENSOR_TYPE_SIGNIFICANT_MOTION:
115 mStringType = SENSOR_STRING_TYPE_SIGNIFICANT_MOTION;
116 break;
117 case SENSOR_TYPE_STEP_COUNTER:
118 mStringType = SENSOR_STRING_TYPE_STEP_COUNTER;
119 break;
120 case SENSOR_TYPE_STEP_DETECTOR:
121 mStringType = SENSOR_STRING_TYPE_STEP_DETECTOR;
122 break;
123 case SENSOR_TYPE_TEMPERATURE:
124 mStringType = SENSOR_STRING_TYPE_TEMPERATURE;
125 break;
126 default:
127 // Only pipe the stringType and requiredPermission for custom sensors.
128 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_2 && hwSensor->stringType) {
129 mStringType = hwSensor->stringType;
130 }
131 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_2 && hwSensor->requiredPermission) {
132 mRequiredPermission = hwSensor->requiredPermission;
133 }
134 break;
Aravind Akella724d91d2013-06-27 12:04:23 -0700135 }
Mathias Agopiana7352c92010-07-14 23:41:37 -0700136}
137
Mathias Agopian589ce852010-07-13 22:21:56 -0700138Sensor::~Sensor()
139{
140}
141
142const String8& Sensor::getName() const {
143 return mName;
144}
145
146const String8& Sensor::getVendor() const {
147 return mVendor;
148}
149
150int32_t Sensor::getHandle() const {
151 return mHandle;
152}
153
154int32_t Sensor::getType() const {
155 return mType;
156}
157
158float Sensor::getMinValue() const {
159 return mMinValue;
160}
161
162float Sensor::getMaxValue() const {
163 return mMaxValue;
164}
165
166float Sensor::getResolution() const {
167 return mResolution;
168}
169
170float Sensor::getPowerUsage() const {
171 return mPower;
172}
173
Mathias Agopiana48bcf62010-07-29 16:51:38 -0700174int32_t Sensor::getMinDelay() const {
175 return mMinDelay;
176}
177
Mathias Agopianb62013f2011-05-17 22:54:42 -0700178nsecs_t Sensor::getMinDelayNs() const {
179 return getMinDelay() * 1000;
180}
181
182int32_t Sensor::getVersion() const {
183 return mVersion;
184}
185
Aravind Akella724d91d2013-06-27 12:04:23 -0700186int32_t Sensor::getFifoReservedEventCount() const {
187 return mFifoReservedEventCount;
188}
189
190int32_t Sensor::getFifoMaxEventCount() const {
191 return mFifoMaxEventCount;
192}
193
Aravind Akella70018042014-04-07 22:52:37 +0000194const String8& Sensor::getStringType() const {
195 return mStringType;
196}
197
198const String8& Sensor::getRequiredPermission() const {
199 return mRequiredPermission;
200}
201
Mathias Agopiane1424282013-07-29 21:24:40 -0700202size_t Sensor::getFlattenedSize() const
Mathias Agopian589ce852010-07-13 22:21:56 -0700203{
Mathias Agopiane1424282013-07-29 21:24:40 -0700204 size_t fixedSize =
Mathias Agopian2ebc4d62012-05-04 15:47:13 -0700205 sizeof(int32_t) * 3 +
Mathias Agopiana48bcf62010-07-29 16:51:38 -0700206 sizeof(float) * 4 +
Aravind Akella724d91d2013-06-27 12:04:23 -0700207 sizeof(int32_t) * 3;
Mathias Agopiane1424282013-07-29 21:24:40 -0700208
209 size_t variableSize =
Aravind Akella70018042014-04-07 22:52:37 +0000210 sizeof(uint32_t) + FlattenableUtils::align<4>(mName.length()) +
211 sizeof(uint32_t) + FlattenableUtils::align<4>(mVendor.length()) +
212 sizeof(uint32_t) + FlattenableUtils::align<4>(mStringType.length()) +
213 sizeof(uint32_t) + FlattenableUtils::align<4>(mRequiredPermission.length());
Mathias Agopiane1424282013-07-29 21:24:40 -0700214
215 return fixedSize + variableSize;
Mathias Agopian589ce852010-07-13 22:21:56 -0700216}
217
Mathias Agopiane1424282013-07-29 21:24:40 -0700218status_t Sensor::flatten(void* buffer, size_t size) const {
219 if (size < getFlattenedSize()) {
220 return NO_MEMORY;
221 }
Mathias Agopian589ce852010-07-13 22:21:56 -0700222
Aravind Akella70018042014-04-07 22:52:37 +0000223 flattenString8(buffer, size, mName);
224 flattenString8(buffer, size, mVendor);
Mathias Agopiane1424282013-07-29 21:24:40 -0700225 FlattenableUtils::write(buffer, size, mVersion);
226 FlattenableUtils::write(buffer, size, mHandle);
227 FlattenableUtils::write(buffer, size, mType);
228 FlattenableUtils::write(buffer, size, mMinValue);
229 FlattenableUtils::write(buffer, size, mMaxValue);
230 FlattenableUtils::write(buffer, size, mResolution);
231 FlattenableUtils::write(buffer, size, mPower);
232 FlattenableUtils::write(buffer, size, mMinDelay);
Aravind Akella724d91d2013-06-27 12:04:23 -0700233 FlattenableUtils::write(buffer, size, mFifoReservedEventCount);
234 FlattenableUtils::write(buffer, size, mFifoMaxEventCount);
Aravind Akella70018042014-04-07 22:52:37 +0000235 flattenString8(buffer, size, mStringType);
236 flattenString8(buffer, size, mRequiredPermission);
Mathias Agopian589ce852010-07-13 22:21:56 -0700237 return NO_ERROR;
238}
239
Mathias Agopiane1424282013-07-29 21:24:40 -0700240status_t Sensor::unflatten(void const* buffer, size_t size) {
Aravind Akella70018042014-04-07 22:52:37 +0000241 if (!unflattenString8(buffer, size, mName)) {
Mathias Agopiane1424282013-07-29 21:24:40 -0700242 return NO_MEMORY;
243 }
Aravind Akella70018042014-04-07 22:52:37 +0000244 if (!unflattenString8(buffer, size, mVendor)) {
Mathias Agopiane1424282013-07-29 21:24:40 -0700245 return NO_MEMORY;
246 }
Mathias Agopiane1424282013-07-29 21:24:40 -0700247
248 size_t fixedSize =
249 sizeof(int32_t) * 3 +
250 sizeof(float) * 4 +
Aravind Akella724d91d2013-06-27 12:04:23 -0700251 sizeof(int32_t) * 3;
Mathias Agopiane1424282013-07-29 21:24:40 -0700252 if (size < fixedSize) {
253 return NO_MEMORY;
254 }
255
256 FlattenableUtils::read(buffer, size, mVersion);
257 FlattenableUtils::read(buffer, size, mHandle);
258 FlattenableUtils::read(buffer, size, mType);
259 FlattenableUtils::read(buffer, size, mMinValue);
260 FlattenableUtils::read(buffer, size, mMaxValue);
261 FlattenableUtils::read(buffer, size, mResolution);
262 FlattenableUtils::read(buffer, size, mPower);
263 FlattenableUtils::read(buffer, size, mMinDelay);
Aravind Akella724d91d2013-06-27 12:04:23 -0700264 FlattenableUtils::read(buffer, size, mFifoReservedEventCount);
265 FlattenableUtils::read(buffer, size, mFifoMaxEventCount);
Aravind Akella70018042014-04-07 22:52:37 +0000266
267 if (!unflattenString8(buffer, size, mStringType)) {
268 return NO_MEMORY;
269 }
270 if (!unflattenString8(buffer, size, mRequiredPermission)) {
271 return NO_MEMORY;
272 }
Mathias Agopian589ce852010-07-13 22:21:56 -0700273 return NO_ERROR;
274}
275
Aravind Akella70018042014-04-07 22:52:37 +0000276void Sensor::flattenString8(void*& buffer, size_t& size,
277 const String8& string8) {
278 uint32_t len = string8.length();
279 FlattenableUtils::write(buffer, size, len);
280 memcpy(static_cast<char*>(buffer), string8.string(), len);
281 FlattenableUtils::advance(buffer, size, FlattenableUtils::align<4>(len));
282}
283
284bool Sensor::unflattenString8(void const*& buffer, size_t& size, String8& outputString8) {
285 uint32_t len;
286 if (size < sizeof(len)) {
287 return false;
288 }
289 FlattenableUtils::read(buffer, size, len);
290 if (size < len) {
291 return false;
292 }
293 outputString8.setTo(static_cast<char const*>(buffer), len);
294 FlattenableUtils::advance(buffer, size, FlattenableUtils::align<4>(len));
295 return true;
296}
297
Mathias Agopian589ce852010-07-13 22:21:56 -0700298// ----------------------------------------------------------------------------
299}; // namespace android