blob: d9a986ed00ed59bb96bfbeaa21da3d5fb65bee47 [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
Mathias Agopian801ea092017-03-06 15:05:04 -080017#include <sensor/Sensor.h>
18
Mark Salyzyna5e161b2016-09-29 08:08:05 -070019#include <inttypes.h>
Peng Xu6a2d3a02015-12-21 12:00:23 -080020
21#include <binder/AppOpsManager.h>
Mathias Agopian801ea092017-03-06 15:05:04 -080022#include <binder/IPermissionController.h>
Peng Xu6a2d3a02015-12-21 12:00:23 -080023#include <binder/IServiceManager.h>
Peng Xu6a2d3a02015-12-21 12:00:23 -080024
Mathias Agopian589ce852010-07-13 22:21:56 -070025// ----------------------------------------------------------------------------
26namespace android {
27// ----------------------------------------------------------------------------
28
Peng Xu6a2d3a02015-12-21 12:00:23 -080029Sensor::Sensor(const char * name) :
30 mName(name), mHandle(0), mType(0),
31 mMinValue(0), mMaxValue(0), mResolution(0),
32 mPower(0), mMinDelay(0), mVersion(0), mFifoReservedEventCount(0),
Peng Xu48328dd2017-06-04 18:15:32 -070033 mFifoMaxEventCount(0), mRequiredAppOp(-1),
Peng Xu6a2d3a02015-12-21 12:00:23 -080034 mMaxDelay(0), mFlags(0) {
Mathias Agopian589ce852010-07-13 22:21:56 -070035}
36
Peng Xu6a2d3a02015-12-21 12:00:23 -080037Sensor::Sensor(struct sensor_t const* hwSensor, int halVersion) :
38 Sensor(*hwSensor, uuid_t(), halVersion) {
39}
40
Peng Xu27cc5f92017-07-24 17:50:53 -070041Sensor::Sensor(struct sensor_t const& hwSensor, const uuid_t& uuid, int halVersion) :
42 Sensor("") {
Peng Xu6a2d3a02015-12-21 12:00:23 -080043 mName = hwSensor.name;
44 mVendor = hwSensor.vendor;
45 mVersion = hwSensor.version;
46 mHandle = hwSensor.handle;
47 mType = hwSensor.type;
Mathias Agopiana7352c92010-07-14 23:41:37 -070048 mMinValue = 0; // FIXME: minValue
Mathias Agopian801ea092017-03-06 15:05:04 -080049 mMaxValue = hwSensor.maxRange; // FIXME: maxValue
Peng Xu6a2d3a02015-12-21 12:00:23 -080050 mResolution = hwSensor.resolution;
51 mPower = hwSensor.power;
52 mMinDelay = hwSensor.minDelay;
Aravind Akella0e025c52014-06-03 19:19:57 -070053 mFlags = 0;
Peng Xu6a2d3a02015-12-21 12:00:23 -080054 mUuid = uuid;
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.
Aravind Akella8493b792014-09-08 15:45:47 -070058 if (halVersion > SENSORS_DEVICE_API_VERSION_1_0) {
Peng Xu6a2d3a02015-12-21 12:00:23 -080059 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) {
Peng Xu6a2d3a02015-12-21 12:00:23 -080067 if (hwSensor.maxDelay > INT_MAX) {
Aravind Akellad9441e42014-05-13 18:20:30 -070068 // 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.
Mark Salyzyn8f515ce2014-06-09 14:32:04 -070070 ALOGE("Sensor maxDelay overflow error %s %" PRId64, mName.string(),
Peng Xu6a2d3a02015-12-21 12:00:23 -080071 static_cast<int64_t>(hwSensor.maxDelay));
Aravind Akellad9441e42014-05-13 18:20:30 -070072 mMaxDelay = INT_MAX;
73 } else {
Peng Xu6a2d3a02015-12-21 12:00:23 -080074 mMaxDelay = static_cast<int32_t>(hwSensor.maxDelay);
Aravind Akellad9441e42014-05-13 18:20:30 -070075 }
76 } else {
77 // For older hals set maxDelay to 0.
78 mMaxDelay = 0;
79 }
80
Aravind Akella0e025c52014-06-03 19:19:57 -070081 // Ensure existing sensors have correct string type, required permissions and reporting mode.
Aravind Akella64ffcb02014-07-29 12:27:41 -070082 // Set reportingMode for all android defined sensor types, set wake-up flag only for proximity
83 // sensor, significant motion, tilt, pick_up gesture, wake gesture and glance gesture on older
84 // HALs. Newer HALs can define both wake-up and non wake-up proximity sensors.
85 // All the OEM defined defined sensors have flags set to whatever is provided by the HAL.
Aravind Akella70018042014-04-07 22:52:37 +000086 switch (mType) {
87 case SENSOR_TYPE_ACCELEROMETER:
88 mStringType = SENSOR_STRING_TYPE_ACCELEROMETER;
Aravind Akella0e025c52014-06-03 19:19:57 -070089 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +000090 break;
91 case SENSOR_TYPE_AMBIENT_TEMPERATURE:
92 mStringType = SENSOR_STRING_TYPE_AMBIENT_TEMPERATURE;
Aravind Akella0e025c52014-06-03 19:19:57 -070093 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
Aravind Akella70018042014-04-07 22:52:37 +000094 break;
95 case SENSOR_TYPE_GAME_ROTATION_VECTOR:
96 mStringType = SENSOR_STRING_TYPE_GAME_ROTATION_VECTOR;
Aravind Akella0e025c52014-06-03 19:19:57 -070097 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +000098 break;
99 case SENSOR_TYPE_GEOMAGNETIC_ROTATION_VECTOR:
100 mStringType = SENSOR_STRING_TYPE_GEOMAGNETIC_ROTATION_VECTOR;
Aravind Akella0e025c52014-06-03 19:19:57 -0700101 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000102 break;
103 case SENSOR_TYPE_GRAVITY:
104 mStringType = SENSOR_STRING_TYPE_GRAVITY;
Aravind Akella0e025c52014-06-03 19:19:57 -0700105 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000106 break;
107 case SENSOR_TYPE_GYROSCOPE:
108 mStringType = SENSOR_STRING_TYPE_GYROSCOPE;
Aravind Akella0e025c52014-06-03 19:19:57 -0700109 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000110 break;
111 case SENSOR_TYPE_GYROSCOPE_UNCALIBRATED:
112 mStringType = SENSOR_STRING_TYPE_GYROSCOPE_UNCALIBRATED;
Aravind Akella0e025c52014-06-03 19:19:57 -0700113 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000114 break;
Svetoslavb412f6e2015-04-29 16:50:41 -0700115 case SENSOR_TYPE_HEART_RATE: {
Aravind Akella70018042014-04-07 22:52:37 +0000116 mStringType = SENSOR_STRING_TYPE_HEART_RATE;
117 mRequiredPermission = SENSOR_PERMISSION_BODY_SENSORS;
Svetoslavb412f6e2015-04-29 16:50:41 -0700118 AppOpsManager appOps;
119 mRequiredAppOp = appOps.permissionToOpCode(String16(SENSOR_PERMISSION_BODY_SENSORS));
Aravind Akella0e025c52014-06-03 19:19:57 -0700120 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
Svetoslavb412f6e2015-04-29 16:50:41 -0700121 } break;
Aravind Akella70018042014-04-07 22:52:37 +0000122 case SENSOR_TYPE_LIGHT:
123 mStringType = SENSOR_STRING_TYPE_LIGHT;
Aravind Akella0e025c52014-06-03 19:19:57 -0700124 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000125 break;
126 case SENSOR_TYPE_LINEAR_ACCELERATION:
127 mStringType = SENSOR_STRING_TYPE_LINEAR_ACCELERATION;
Aravind Akella0e025c52014-06-03 19:19:57 -0700128 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000129 break;
130 case SENSOR_TYPE_MAGNETIC_FIELD:
131 mStringType = SENSOR_STRING_TYPE_MAGNETIC_FIELD;
Aravind Akella0e025c52014-06-03 19:19:57 -0700132 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000133 break;
134 case SENSOR_TYPE_MAGNETIC_FIELD_UNCALIBRATED:
135 mStringType = SENSOR_STRING_TYPE_MAGNETIC_FIELD_UNCALIBRATED;
Aravind Akella0e025c52014-06-03 19:19:57 -0700136 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000137 break;
138 case SENSOR_TYPE_ORIENTATION:
139 mStringType = SENSOR_STRING_TYPE_ORIENTATION;
Aravind Akella0e025c52014-06-03 19:19:57 -0700140 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000141 break;
142 case SENSOR_TYPE_PRESSURE:
143 mStringType = SENSOR_STRING_TYPE_PRESSURE;
Aravind Akella0e025c52014-06-03 19:19:57 -0700144 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000145 break;
146 case SENSOR_TYPE_PROXIMITY:
147 mStringType = SENSOR_STRING_TYPE_PROXIMITY;
Aravind Akella64ffcb02014-07-29 12:27:41 -0700148 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
149 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
150 mFlags |= SENSOR_FLAG_WAKE_UP;
151 }
Aravind Akella70018042014-04-07 22:52:37 +0000152 break;
153 case SENSOR_TYPE_RELATIVE_HUMIDITY:
154 mStringType = SENSOR_STRING_TYPE_RELATIVE_HUMIDITY;
Aravind Akella0e025c52014-06-03 19:19:57 -0700155 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000156 break;
157 case SENSOR_TYPE_ROTATION_VECTOR:
158 mStringType = SENSOR_STRING_TYPE_ROTATION_VECTOR;
Aravind Akella0e025c52014-06-03 19:19:57 -0700159 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000160 break;
161 case SENSOR_TYPE_SIGNIFICANT_MOTION:
162 mStringType = SENSOR_STRING_TYPE_SIGNIFICANT_MOTION;
Aravind Akella64ffcb02014-07-29 12:27:41 -0700163 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
164 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
165 mFlags |= SENSOR_FLAG_WAKE_UP;
166 }
Aravind Akella70018042014-04-07 22:52:37 +0000167 break;
168 case SENSOR_TYPE_STEP_COUNTER:
169 mStringType = SENSOR_STRING_TYPE_STEP_COUNTER;
Aravind Akella0e025c52014-06-03 19:19:57 -0700170 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000171 break;
172 case SENSOR_TYPE_STEP_DETECTOR:
173 mStringType = SENSOR_STRING_TYPE_STEP_DETECTOR;
Aravind Akella0e025c52014-06-03 19:19:57 -0700174 mFlags |= SENSOR_FLAG_SPECIAL_REPORTING_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000175 break;
176 case SENSOR_TYPE_TEMPERATURE:
177 mStringType = SENSOR_STRING_TYPE_TEMPERATURE;
Aravind Akella0e025c52014-06-03 19:19:57 -0700178 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000179 break;
Aravind Akella64ffcb02014-07-29 12:27:41 -0700180 case SENSOR_TYPE_TILT_DETECTOR:
181 mStringType = SENSOR_STRING_TYPE_TILT_DETECTOR;
182 mFlags |= SENSOR_FLAG_SPECIAL_REPORTING_MODE;
183 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
184 mFlags |= SENSOR_FLAG_WAKE_UP;
185 }
Peng Xu2576cb62016-01-20 00:22:09 -0800186 break;
Etienne Le Grande284a902014-05-07 19:49:05 -0700187 case SENSOR_TYPE_WAKE_GESTURE:
188 mStringType = SENSOR_STRING_TYPE_WAKE_GESTURE;
Aravind Akella64ffcb02014-07-29 12:27:41 -0700189 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
190 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
191 mFlags |= SENSOR_FLAG_WAKE_UP;
192 }
Etienne Le Grande284a902014-05-07 19:49:05 -0700193 break;
Jeff Brown31d825d2014-07-17 15:13:55 -0700194 case SENSOR_TYPE_GLANCE_GESTURE:
195 mStringType = SENSOR_STRING_TYPE_GLANCE_GESTURE;
Aravind Akella64ffcb02014-07-29 12:27:41 -0700196 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
197 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
198 mFlags |= SENSOR_FLAG_WAKE_UP;
199 }
Jeff Brown31d825d2014-07-17 15:13:55 -0700200 break;
Aravind Akellafd8498c2014-07-28 18:01:11 -0700201 case SENSOR_TYPE_PICK_UP_GESTURE:
202 mStringType = SENSOR_STRING_TYPE_PICK_UP_GESTURE;
Aravind Akella64ffcb02014-07-29 12:27:41 -0700203 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
204 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
205 mFlags |= SENSOR_FLAG_WAKE_UP;
206 }
Aravind Akellafd8498c2014-07-28 18:01:11 -0700207 break;
Nick Vaccaro2e990eb2017-01-12 21:13:58 -0800208 case SENSOR_TYPE_LOW_LATENCY_OFFBODY_DETECT:
209 mStringType = SENSOR_STRING_TYPE_LOW_LATENCY_OFFBODY_DETECT;
210 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
211 break;
Nick Vaccaro9bb99b12015-01-21 15:27:23 -0800212 case SENSOR_TYPE_WRIST_TILT_GESTURE:
213 mStringType = SENSOR_STRING_TYPE_WRIST_TILT_GESTURE;
214 mFlags |= SENSOR_FLAG_SPECIAL_REPORTING_MODE;
215 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
216 mFlags |= SENSOR_FLAG_WAKE_UP;
217 }
218 break;
Peng Xu2576cb62016-01-20 00:22:09 -0800219 case SENSOR_TYPE_DYNAMIC_SENSOR_META:
220 mStringType = SENSOR_STRING_TYPE_DYNAMIC_SENSOR_META;
Peng Xu4e44cf52016-09-15 11:05:08 -0700221 mFlags |= SENSOR_FLAG_SPECIAL_REPORTING_MODE; // special trigger
222 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
223 mFlags |= SENSOR_FLAG_WAKE_UP;
224 }
Peng Xu2576cb62016-01-20 00:22:09 -0800225 break;
Ashutosh Joshi1b4566c2016-01-14 22:14:46 -0800226 case SENSOR_TYPE_POSE_6DOF:
227 mStringType = SENSOR_STRING_TYPE_POSE_6DOF;
228 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
229 break;
230 case SENSOR_TYPE_STATIONARY_DETECT:
231 mStringType = SENSOR_STRING_TYPE_STATIONARY_DETECT;
232 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
233 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
234 mFlags |= SENSOR_FLAG_WAKE_UP;
235 }
236 break;
237 case SENSOR_TYPE_MOTION_DETECT:
238 mStringType = SENSOR_STRING_TYPE_MOTION_DETECT;
239 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
240 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
241 mFlags |= SENSOR_FLAG_WAKE_UP;
242 }
243 break;
244 case SENSOR_TYPE_HEART_BEAT:
245 mStringType = SENSOR_STRING_TYPE_HEART_BEAT;
246 mFlags |= SENSOR_FLAG_SPECIAL_REPORTING_MODE;
247 break;
Ashutosh Joshiab4e1ff2017-01-12 11:35:19 -0800248
249 // TODO: Placeholder for LLOB sensor type
250
251
252 case SENSOR_TYPE_ACCELEROMETER_UNCALIBRATED:
253 mStringType = SENSOR_STRING_TYPE_ACCELEROMETER_UNCALIBRATED;
254 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
255 break;
Aravind Akella70018042014-04-07 22:52:37 +0000256 default:
Aravind Akella9a844cf2014-02-11 18:58:52 -0800257 // Only pipe the stringType, requiredPermission and flags for custom sensors.
Peng Xu6a2d3a02015-12-21 12:00:23 -0800258 if (halVersion > SENSORS_DEVICE_API_VERSION_1_0 && hwSensor.stringType) {
259 mStringType = hwSensor.stringType;
Aravind Akella70018042014-04-07 22:52:37 +0000260 }
Peng Xu6a2d3a02015-12-21 12:00:23 -0800261 if (halVersion > SENSORS_DEVICE_API_VERSION_1_0 && hwSensor.requiredPermission) {
262 mRequiredPermission = hwSensor.requiredPermission;
Prashant Malanie35c7d62015-08-20 17:19:05 -0700263 if (!strcmp(mRequiredPermission, SENSOR_PERMISSION_BODY_SENSORS)) {
264 AppOpsManager appOps;
265 mRequiredAppOp = appOps.permissionToOpCode(String16(SENSOR_PERMISSION_BODY_SENSORS));
266 }
Aravind Akella70018042014-04-07 22:52:37 +0000267 }
Aravind Akella0e025c52014-06-03 19:19:57 -0700268
Aravind Akella9a844cf2014-02-11 18:58:52 -0800269 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) {
Peng Xu6a2d3a02015-12-21 12:00:23 -0800270 mFlags = static_cast<uint32_t>(hwSensor.flags);
Aravind Akella0e025c52014-06-03 19:19:57 -0700271 } else {
272 // This is an OEM defined sensor on an older HAL. Use minDelay to determine the
273 // reporting mode of the sensor.
274 if (mMinDelay > 0) {
275 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
276 } else if (mMinDelay == 0) {
277 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
278 } else if (mMinDelay < 0) {
279 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
280 }
Aravind Akella9a844cf2014-02-11 18:58:52 -0800281 }
Aravind Akella70018042014-04-07 22:52:37 +0000282 break;
Aravind Akella724d91d2013-06-27 12:04:23 -0700283 }
Aravind Akella64ffcb02014-07-29 12:27:41 -0700284
Peng Xu6a2d3a02015-12-21 12:00:23 -0800285 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) {
286 // Wake-up flag of HAL 1.3 and above is set here
287 mFlags |= (hwSensor.flags & SENSOR_FLAG_WAKE_UP);
288
289 // Log error if the reporting mode is not as expected, but respect HAL setting.
290 int actualReportingMode = (hwSensor.flags & REPORTING_MODE_MASK) >> REPORTING_MODE_SHIFT;
291 int expectedReportingMode = (mFlags & REPORTING_MODE_MASK) >> REPORTING_MODE_SHIFT;
292 if (actualReportingMode != expectedReportingMode) {
293 ALOGE("Reporting Mode incorrect: sensor %s handle=%#010" PRIx32 " type=%" PRId32 " "
294 "actual=%d expected=%d",
295 mName.string(), mHandle, mType, actualReportingMode, expectedReportingMode);
296 }
297 }
298
299 // Feature flags
Peng Xu755c4512016-04-07 23:15:14 -0700300 // Set DYNAMIC_SENSOR_MASK and ADDITIONAL_INFO_MASK flag here. Compatible with HAL 1_3.
301 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) {
Peng Xue36e3472016-11-03 11:57:10 -0700302 mFlags |= hwSensor.flags & (DYNAMIC_SENSOR_MASK | ADDITIONAL_INFO_MASK);
303 }
304 // Set DIRECT_REPORT_MASK and DIRECT_CHANNEL_MASK flags. Compatible with HAL 1_3.
305 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) {
306 // only on continuous sensors direct report mode is defined
307 if ((mFlags & REPORTING_MODE_MASK) == SENSOR_FLAG_CONTINUOUS_MODE) {
308 mFlags |= hwSensor.flags
309 & (SENSOR_FLAG_MASK_DIRECT_REPORT | SENSOR_FLAG_MASK_DIRECT_CHANNEL);
310 }
Peng Xu755c4512016-04-07 23:15:14 -0700311 }
Aravind Akellaf9b7f852015-09-10 14:52:31 -0700312 // Set DATA_INJECTION flag here. Defined in HAL 1_4.
313 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_4) {
Peng Xu6a2d3a02015-12-21 12:00:23 -0800314 mFlags |= (hwSensor.flags & DATA_INJECTION_MASK);
Aravind Akella64ffcb02014-07-29 12:27:41 -0700315 }
Svetoslavb412f6e2015-04-29 16:50:41 -0700316
317 if (mRequiredPermission.length() > 0) {
318 // If the sensor is protected by a permission we need to know if it is
319 // a runtime one to determine whether we can use the permission cache.
320 sp<IBinder> binder = defaultServiceManager()->getService(String16("permission"));
Yi Kongd5e079f2018-07-17 16:08:27 -0700321 if (binder != nullptr) {
Svetoslavb412f6e2015-04-29 16:50:41 -0700322 sp<IPermissionController> permCtrl = interface_cast<IPermissionController>(binder);
323 mRequiredPermissionRuntime = permCtrl->isRuntimePermission(
324 String16(mRequiredPermission));
325 }
326 }
Mathias Agopiana7352c92010-07-14 23:41:37 -0700327}
328
Peng Xu6a2d3a02015-12-21 12:00:23 -0800329Sensor::~Sensor() {
Mathias Agopian589ce852010-07-13 22:21:56 -0700330}
331
332const String8& Sensor::getName() const {
333 return mName;
334}
335
336const String8& Sensor::getVendor() const {
337 return mVendor;
338}
339
340int32_t Sensor::getHandle() const {
341 return mHandle;
342}
343
344int32_t Sensor::getType() const {
345 return mType;
346}
347
348float Sensor::getMinValue() const {
349 return mMinValue;
350}
351
352float Sensor::getMaxValue() const {
353 return mMaxValue;
354}
355
356float Sensor::getResolution() const {
357 return mResolution;
358}
359
360float Sensor::getPowerUsage() const {
361 return mPower;
362}
363
Mathias Agopiana48bcf62010-07-29 16:51:38 -0700364int32_t Sensor::getMinDelay() const {
365 return mMinDelay;
366}
367
Mathias Agopianb62013f2011-05-17 22:54:42 -0700368nsecs_t Sensor::getMinDelayNs() const {
369 return getMinDelay() * 1000;
370}
371
372int32_t Sensor::getVersion() const {
373 return mVersion;
374}
375
Dan Stozad723bd72014-11-18 10:24:03 -0800376uint32_t Sensor::getFifoReservedEventCount() const {
Aravind Akella724d91d2013-06-27 12:04:23 -0700377 return mFifoReservedEventCount;
378}
379
Dan Stozad723bd72014-11-18 10:24:03 -0800380uint32_t Sensor::getFifoMaxEventCount() const {
Aravind Akella724d91d2013-06-27 12:04:23 -0700381 return mFifoMaxEventCount;
382}
383
Aravind Akella70018042014-04-07 22:52:37 +0000384const String8& Sensor::getStringType() const {
385 return mStringType;
386}
387
388const String8& Sensor::getRequiredPermission() const {
389 return mRequiredPermission;
390}
391
Svetoslavb412f6e2015-04-29 16:50:41 -0700392bool Sensor::isRequiredPermissionRuntime() const {
393 return mRequiredPermissionRuntime;
394}
395
396int32_t Sensor::getRequiredAppOp() const {
397 return mRequiredAppOp;
398}
399
Aravind Akellad9441e42014-05-13 18:20:30 -0700400int32_t Sensor::getMaxDelay() const {
401 return mMaxDelay;
402}
403
Dan Stozad723bd72014-11-18 10:24:03 -0800404uint32_t Sensor::getFlags() const {
Aravind Akella0e025c52014-06-03 19:19:57 -0700405 return mFlags;
406}
407
Aravind Akella9a844cf2014-02-11 18:58:52 -0800408bool Sensor::isWakeUpSensor() const {
Peng Xu6a2d3a02015-12-21 12:00:23 -0800409 return (mFlags & SENSOR_FLAG_WAKE_UP) != 0;
Aravind Akella0e025c52014-06-03 19:19:57 -0700410}
411
Peng Xu0cc8f802016-04-05 23:46:03 -0700412bool Sensor::isDynamicSensor() const {
Peng Xu6a2d3a02015-12-21 12:00:23 -0800413 return (mFlags & SENSOR_FLAG_DYNAMIC_SENSOR) != 0;
414}
415
Peng Xu48328dd2017-06-04 18:15:32 -0700416bool Sensor::isDataInjectionSupported() const {
417 return (mFlags & SENSOR_FLAG_DATA_INJECTION) != 0;
418}
419
Peng Xu6a2d3a02015-12-21 12:00:23 -0800420bool Sensor::hasAdditionalInfo() const {
421 return (mFlags & SENSOR_FLAG_ADDITIONAL_INFO) != 0;
Peng Xu0cc8f802016-04-05 23:46:03 -0700422}
423
Peng Xue36e3472016-11-03 11:57:10 -0700424int32_t Sensor::getHighestDirectReportRateLevel() const {
425 return ((mFlags & SENSOR_FLAG_MASK_DIRECT_REPORT) >> SENSOR_FLAG_SHIFT_DIRECT_REPORT);
426}
427
428bool Sensor::isDirectChannelTypeSupported(int32_t sharedMemType) const {
429 switch (sharedMemType) {
430 case SENSOR_DIRECT_MEM_TYPE_ASHMEM:
431 return mFlags & SENSOR_FLAG_DIRECT_CHANNEL_ASHMEM;
432 case SENSOR_DIRECT_MEM_TYPE_GRALLOC:
433 return mFlags & SENSOR_FLAG_DIRECT_CHANNEL_GRALLOC;
434 default:
435 return false;
436 }
437}
438
Aravind Akella0e025c52014-06-03 19:19:57 -0700439int32_t Sensor::getReportingMode() const {
440 return ((mFlags & REPORTING_MODE_MASK) >> REPORTING_MODE_SHIFT);
Aravind Akella9a844cf2014-02-11 18:58:52 -0800441}
442
Peng Xu2576cb62016-01-20 00:22:09 -0800443const Sensor::uuid_t& Sensor::getUuid() const {
444 return mUuid;
445}
446
Greg Kaiser53ca2e02016-06-21 16:11:14 -0700447void Sensor::setId(int32_t id) {
448 mUuid.i64[0] = id;
449 mUuid.i64[1] = 0;
450}
451
452int32_t Sensor::getId() const {
453 return int32_t(mUuid.i64[0]);
454}
455
Peng Xu6a2d3a02015-12-21 12:00:23 -0800456size_t Sensor::getFlattenedSize() const {
Mathias Agopiane1424282013-07-29 21:24:40 -0700457 size_t fixedSize =
Peng Xu2576cb62016-01-20 00:22:09 -0800458 sizeof(mVersion) + sizeof(mHandle) + sizeof(mType) +
459 sizeof(mMinValue) + sizeof(mMaxValue) + sizeof(mResolution) +
460 sizeof(mPower) + sizeof(mMinDelay) + sizeof(mFifoMaxEventCount) +
461 sizeof(mFifoMaxEventCount) + sizeof(mRequiredPermissionRuntime) +
462 sizeof(mRequiredAppOp) + sizeof(mMaxDelay) + sizeof(mFlags) + sizeof(mUuid);
Mathias Agopiane1424282013-07-29 21:24:40 -0700463
464 size_t variableSize =
Aravind Akella70018042014-04-07 22:52:37 +0000465 sizeof(uint32_t) + FlattenableUtils::align<4>(mName.length()) +
466 sizeof(uint32_t) + FlattenableUtils::align<4>(mVendor.length()) +
467 sizeof(uint32_t) + FlattenableUtils::align<4>(mStringType.length()) +
468 sizeof(uint32_t) + FlattenableUtils::align<4>(mRequiredPermission.length());
Mathias Agopiane1424282013-07-29 21:24:40 -0700469
470 return fixedSize + variableSize;
Mathias Agopian589ce852010-07-13 22:21:56 -0700471}
472
Mathias Agopiane1424282013-07-29 21:24:40 -0700473status_t Sensor::flatten(void* buffer, size_t size) const {
474 if (size < getFlattenedSize()) {
475 return NO_MEMORY;
476 }
Mathias Agopian589ce852010-07-13 22:21:56 -0700477
Aravind Akella70018042014-04-07 22:52:37 +0000478 flattenString8(buffer, size, mName);
479 flattenString8(buffer, size, mVendor);
Mathias Agopiane1424282013-07-29 21:24:40 -0700480 FlattenableUtils::write(buffer, size, mVersion);
481 FlattenableUtils::write(buffer, size, mHandle);
482 FlattenableUtils::write(buffer, size, mType);
483 FlattenableUtils::write(buffer, size, mMinValue);
484 FlattenableUtils::write(buffer, size, mMaxValue);
485 FlattenableUtils::write(buffer, size, mResolution);
486 FlattenableUtils::write(buffer, size, mPower);
487 FlattenableUtils::write(buffer, size, mMinDelay);
Aravind Akella724d91d2013-06-27 12:04:23 -0700488 FlattenableUtils::write(buffer, size, mFifoReservedEventCount);
489 FlattenableUtils::write(buffer, size, mFifoMaxEventCount);
Aravind Akella70018042014-04-07 22:52:37 +0000490 flattenString8(buffer, size, mStringType);
491 flattenString8(buffer, size, mRequiredPermission);
Svetoslavb412f6e2015-04-29 16:50:41 -0700492 FlattenableUtils::write(buffer, size, mRequiredPermissionRuntime);
493 FlattenableUtils::write(buffer, size, mRequiredAppOp);
Aravind Akellad9441e42014-05-13 18:20:30 -0700494 FlattenableUtils::write(buffer, size, mMaxDelay);
Aravind Akella0e025c52014-06-03 19:19:57 -0700495 FlattenableUtils::write(buffer, size, mFlags);
Greg Kaiser53ca2e02016-06-21 16:11:14 -0700496 if (mUuid.i64[1] != 0) {
497 // We should never hit this case with our current API, but we
498 // could via a careless API change. If that happens,
499 // this code will keep us from leaking our UUID (while probably
500 // breaking dynamic sensors). See b/29547335.
501 ALOGW("Sensor with UUID being flattened; sending 0. Expect "
502 "bad dynamic sensor behavior");
503 uuid_t tmpUuid; // default constructor makes this 0.
504 FlattenableUtils::write(buffer, size, tmpUuid);
505 } else {
506 FlattenableUtils::write(buffer, size, mUuid);
507 }
Mathias Agopian589ce852010-07-13 22:21:56 -0700508 return NO_ERROR;
509}
510
Mathias Agopiane1424282013-07-29 21:24:40 -0700511status_t Sensor::unflatten(void const* buffer, size_t size) {
Aravind Akella70018042014-04-07 22:52:37 +0000512 if (!unflattenString8(buffer, size, mName)) {
Mathias Agopiane1424282013-07-29 21:24:40 -0700513 return NO_MEMORY;
514 }
Aravind Akella70018042014-04-07 22:52:37 +0000515 if (!unflattenString8(buffer, size, mVendor)) {
Mathias Agopiane1424282013-07-29 21:24:40 -0700516 return NO_MEMORY;
517 }
Mathias Agopiane1424282013-07-29 21:24:40 -0700518
Peng Xu2576cb62016-01-20 00:22:09 -0800519 size_t fixedSize1 =
520 sizeof(mVersion) + sizeof(mHandle) + sizeof(mType) + sizeof(mMinValue) +
521 sizeof(mMaxValue) + sizeof(mResolution) + sizeof(mPower) + sizeof(mMinDelay) +
522 sizeof(mFifoMaxEventCount) + sizeof(mFifoMaxEventCount);
523 if (size < fixedSize1) {
Mathias Agopiane1424282013-07-29 21:24:40 -0700524 return NO_MEMORY;
525 }
526
527 FlattenableUtils::read(buffer, size, mVersion);
528 FlattenableUtils::read(buffer, size, mHandle);
529 FlattenableUtils::read(buffer, size, mType);
530 FlattenableUtils::read(buffer, size, mMinValue);
531 FlattenableUtils::read(buffer, size, mMaxValue);
532 FlattenableUtils::read(buffer, size, mResolution);
533 FlattenableUtils::read(buffer, size, mPower);
534 FlattenableUtils::read(buffer, size, mMinDelay);
Aravind Akella724d91d2013-06-27 12:04:23 -0700535 FlattenableUtils::read(buffer, size, mFifoReservedEventCount);
536 FlattenableUtils::read(buffer, size, mFifoMaxEventCount);
Aravind Akella70018042014-04-07 22:52:37 +0000537
538 if (!unflattenString8(buffer, size, mStringType)) {
539 return NO_MEMORY;
540 }
541 if (!unflattenString8(buffer, size, mRequiredPermission)) {
542 return NO_MEMORY;
543 }
Peng Xu2576cb62016-01-20 00:22:09 -0800544
545 size_t fixedSize2 =
546 sizeof(mRequiredPermissionRuntime) + sizeof(mRequiredAppOp) + sizeof(mMaxDelay) +
547 sizeof(mFlags) + sizeof(mUuid);
548 if (size < fixedSize2) {
549 return NO_MEMORY;
550 }
551
Svetoslavb412f6e2015-04-29 16:50:41 -0700552 FlattenableUtils::read(buffer, size, mRequiredPermissionRuntime);
553 FlattenableUtils::read(buffer, size, mRequiredAppOp);
Aravind Akellad9441e42014-05-13 18:20:30 -0700554 FlattenableUtils::read(buffer, size, mMaxDelay);
Aravind Akella0e025c52014-06-03 19:19:57 -0700555 FlattenableUtils::read(buffer, size, mFlags);
Peng Xu2576cb62016-01-20 00:22:09 -0800556 FlattenableUtils::read(buffer, size, mUuid);
Mathias Agopian589ce852010-07-13 22:21:56 -0700557 return NO_ERROR;
558}
559
Aravind Akella70018042014-04-07 22:52:37 +0000560void Sensor::flattenString8(void*& buffer, size_t& size,
561 const String8& string8) {
Dan Stozad723bd72014-11-18 10:24:03 -0800562 uint32_t len = static_cast<uint32_t>(string8.length());
Aravind Akella70018042014-04-07 22:52:37 +0000563 FlattenableUtils::write(buffer, size, len);
564 memcpy(static_cast<char*>(buffer), string8.string(), len);
565 FlattenableUtils::advance(buffer, size, FlattenableUtils::align<4>(len));
566}
567
568bool Sensor::unflattenString8(void const*& buffer, size_t& size, String8& outputString8) {
569 uint32_t len;
570 if (size < sizeof(len)) {
571 return false;
572 }
573 FlattenableUtils::read(buffer, size, len);
574 if (size < len) {
575 return false;
576 }
577 outputString8.setTo(static_cast<char const*>(buffer), len);
578 FlattenableUtils::advance(buffer, size, FlattenableUtils::align<4>(len));
579 return true;
580}
581
Mathias Agopian589ce852010-07-13 22:21:56 -0700582// ----------------------------------------------------------------------------
583}; // namespace android