blob: fb895f59b94ee3a87371387eb35d1db3546ca690 [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
Brian Stack793f4642019-04-18 17:21:34 -070025/*
26 * The permission to use for activity recognition sensors (like step counter).
27 * See sensor types for more details on what sensors should require this
28 * permission.
29 */
30#define SENSOR_PERMISSION_ACTIVITY_RECOGNITION "android.permission.ACTIVITY_RECOGNITION"
31
Mathias Agopian589ce852010-07-13 22:21:56 -070032// ----------------------------------------------------------------------------
33namespace android {
34// ----------------------------------------------------------------------------
35
Peng Xu6a2d3a02015-12-21 12:00:23 -080036Sensor::Sensor(const char * name) :
37 mName(name), mHandle(0), mType(0),
38 mMinValue(0), mMaxValue(0), mResolution(0),
39 mPower(0), mMinDelay(0), mVersion(0), mFifoReservedEventCount(0),
Peng Xu48328dd2017-06-04 18:15:32 -070040 mFifoMaxEventCount(0), mRequiredAppOp(-1),
Peng Xu6a2d3a02015-12-21 12:00:23 -080041 mMaxDelay(0), mFlags(0) {
Mathias Agopian589ce852010-07-13 22:21:56 -070042}
43
Peng Xu6a2d3a02015-12-21 12:00:23 -080044Sensor::Sensor(struct sensor_t const* hwSensor, int halVersion) :
45 Sensor(*hwSensor, uuid_t(), halVersion) {
46}
47
Peng Xu27cc5f92017-07-24 17:50:53 -070048Sensor::Sensor(struct sensor_t const& hwSensor, const uuid_t& uuid, int halVersion) :
49 Sensor("") {
Peng Xu6a2d3a02015-12-21 12:00:23 -080050 mName = hwSensor.name;
51 mVendor = hwSensor.vendor;
52 mVersion = hwSensor.version;
53 mHandle = hwSensor.handle;
54 mType = hwSensor.type;
Mathias Agopiana7352c92010-07-14 23:41:37 -070055 mMinValue = 0; // FIXME: minValue
Mathias Agopian801ea092017-03-06 15:05:04 -080056 mMaxValue = hwSensor.maxRange; // FIXME: maxValue
Peng Xu6a2d3a02015-12-21 12:00:23 -080057 mResolution = hwSensor.resolution;
58 mPower = hwSensor.power;
59 mMinDelay = hwSensor.minDelay;
Aravind Akella0e025c52014-06-03 19:19:57 -070060 mFlags = 0;
Peng Xu6a2d3a02015-12-21 12:00:23 -080061 mUuid = uuid;
Aravind Akella70018042014-04-07 22:52:37 +000062
Aravind Akella724d91d2013-06-27 12:04:23 -070063 // Set fifo event count zero for older devices which do not support batching. Fused
64 // sensors also have their fifo counts set to zero.
Aravind Akella8493b792014-09-08 15:45:47 -070065 if (halVersion > SENSORS_DEVICE_API_VERSION_1_0) {
Peng Xu6a2d3a02015-12-21 12:00:23 -080066 mFifoReservedEventCount = hwSensor.fifoReservedEventCount;
67 mFifoMaxEventCount = hwSensor.fifoMaxEventCount;
Aravind Akellad35e3af2014-05-12 17:14:56 -070068 } else {
69 mFifoReservedEventCount = 0;
70 mFifoMaxEventCount = 0;
Aravind Akella70018042014-04-07 22:52:37 +000071 }
72
Aravind Akellad9441e42014-05-13 18:20:30 -070073 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) {
Peng Xu6a2d3a02015-12-21 12:00:23 -080074 if (hwSensor.maxDelay > INT_MAX) {
Aravind Akellad9441e42014-05-13 18:20:30 -070075 // Max delay is declared as a 64 bit integer for 64 bit architectures. But it should
76 // always fit in a 32 bit integer, log error and cap it to INT_MAX.
Mark Salyzyn8f515ce2014-06-09 14:32:04 -070077 ALOGE("Sensor maxDelay overflow error %s %" PRId64, mName.string(),
Peng Xu6a2d3a02015-12-21 12:00:23 -080078 static_cast<int64_t>(hwSensor.maxDelay));
Aravind Akellad9441e42014-05-13 18:20:30 -070079 mMaxDelay = INT_MAX;
80 } else {
Peng Xu6a2d3a02015-12-21 12:00:23 -080081 mMaxDelay = static_cast<int32_t>(hwSensor.maxDelay);
Aravind Akellad9441e42014-05-13 18:20:30 -070082 }
83 } else {
84 // For older hals set maxDelay to 0.
85 mMaxDelay = 0;
86 }
87
Aravind Akella0e025c52014-06-03 19:19:57 -070088 // Ensure existing sensors have correct string type, required permissions and reporting mode.
Aravind Akella64ffcb02014-07-29 12:27:41 -070089 // Set reportingMode for all android defined sensor types, set wake-up flag only for proximity
90 // sensor, significant motion, tilt, pick_up gesture, wake gesture and glance gesture on older
91 // HALs. Newer HALs can define both wake-up and non wake-up proximity sensors.
92 // All the OEM defined defined sensors have flags set to whatever is provided by the HAL.
Aravind Akella70018042014-04-07 22:52:37 +000093 switch (mType) {
94 case SENSOR_TYPE_ACCELEROMETER:
95 mStringType = SENSOR_STRING_TYPE_ACCELEROMETER;
Aravind Akella0e025c52014-06-03 19:19:57 -070096 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +000097 break;
98 case SENSOR_TYPE_AMBIENT_TEMPERATURE:
99 mStringType = SENSOR_STRING_TYPE_AMBIENT_TEMPERATURE;
Aravind Akella0e025c52014-06-03 19:19:57 -0700100 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000101 break;
102 case SENSOR_TYPE_GAME_ROTATION_VECTOR:
103 mStringType = SENSOR_STRING_TYPE_GAME_ROTATION_VECTOR;
Aravind Akella0e025c52014-06-03 19:19:57 -0700104 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000105 break;
106 case SENSOR_TYPE_GEOMAGNETIC_ROTATION_VECTOR:
107 mStringType = SENSOR_STRING_TYPE_GEOMAGNETIC_ROTATION_VECTOR;
Aravind Akella0e025c52014-06-03 19:19:57 -0700108 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000109 break;
110 case SENSOR_TYPE_GRAVITY:
111 mStringType = SENSOR_STRING_TYPE_GRAVITY;
Aravind Akella0e025c52014-06-03 19:19:57 -0700112 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000113 break;
114 case SENSOR_TYPE_GYROSCOPE:
115 mStringType = SENSOR_STRING_TYPE_GYROSCOPE;
Aravind Akella0e025c52014-06-03 19:19:57 -0700116 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000117 break;
118 case SENSOR_TYPE_GYROSCOPE_UNCALIBRATED:
119 mStringType = SENSOR_STRING_TYPE_GYROSCOPE_UNCALIBRATED;
Aravind Akella0e025c52014-06-03 19:19:57 -0700120 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000121 break;
Svetoslavb412f6e2015-04-29 16:50:41 -0700122 case SENSOR_TYPE_HEART_RATE: {
Aravind Akella70018042014-04-07 22:52:37 +0000123 mStringType = SENSOR_STRING_TYPE_HEART_RATE;
124 mRequiredPermission = SENSOR_PERMISSION_BODY_SENSORS;
Svetoslavb412f6e2015-04-29 16:50:41 -0700125 AppOpsManager appOps;
Brian Stack793f4642019-04-18 17:21:34 -0700126 mRequiredAppOp = appOps.permissionToOpCode(String16(mRequiredPermission));
Aravind Akella0e025c52014-06-03 19:19:57 -0700127 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
Svetoslavb412f6e2015-04-29 16:50:41 -0700128 } break;
Aravind Akella70018042014-04-07 22:52:37 +0000129 case SENSOR_TYPE_LIGHT:
130 mStringType = SENSOR_STRING_TYPE_LIGHT;
Aravind Akella0e025c52014-06-03 19:19:57 -0700131 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000132 break;
133 case SENSOR_TYPE_LINEAR_ACCELERATION:
134 mStringType = SENSOR_STRING_TYPE_LINEAR_ACCELERATION;
Aravind Akella0e025c52014-06-03 19:19:57 -0700135 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000136 break;
137 case SENSOR_TYPE_MAGNETIC_FIELD:
138 mStringType = SENSOR_STRING_TYPE_MAGNETIC_FIELD;
Aravind Akella0e025c52014-06-03 19:19:57 -0700139 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000140 break;
141 case SENSOR_TYPE_MAGNETIC_FIELD_UNCALIBRATED:
142 mStringType = SENSOR_STRING_TYPE_MAGNETIC_FIELD_UNCALIBRATED;
Aravind Akella0e025c52014-06-03 19:19:57 -0700143 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000144 break;
145 case SENSOR_TYPE_ORIENTATION:
146 mStringType = SENSOR_STRING_TYPE_ORIENTATION;
Aravind Akella0e025c52014-06-03 19:19:57 -0700147 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000148 break;
149 case SENSOR_TYPE_PRESSURE:
150 mStringType = SENSOR_STRING_TYPE_PRESSURE;
Aravind Akella0e025c52014-06-03 19:19:57 -0700151 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000152 break;
153 case SENSOR_TYPE_PROXIMITY:
154 mStringType = SENSOR_STRING_TYPE_PROXIMITY;
Aravind Akella64ffcb02014-07-29 12:27:41 -0700155 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
156 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
157 mFlags |= SENSOR_FLAG_WAKE_UP;
158 }
Aravind Akella70018042014-04-07 22:52:37 +0000159 break;
160 case SENSOR_TYPE_RELATIVE_HUMIDITY:
161 mStringType = SENSOR_STRING_TYPE_RELATIVE_HUMIDITY;
Aravind Akella0e025c52014-06-03 19:19:57 -0700162 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000163 break;
164 case SENSOR_TYPE_ROTATION_VECTOR:
165 mStringType = SENSOR_STRING_TYPE_ROTATION_VECTOR;
Aravind Akella0e025c52014-06-03 19:19:57 -0700166 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000167 break;
168 case SENSOR_TYPE_SIGNIFICANT_MOTION:
169 mStringType = SENSOR_STRING_TYPE_SIGNIFICANT_MOTION;
Aravind Akella64ffcb02014-07-29 12:27:41 -0700170 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
171 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
172 mFlags |= SENSOR_FLAG_WAKE_UP;
173 }
Aravind Akella70018042014-04-07 22:52:37 +0000174 break;
Brian Stack793f4642019-04-18 17:21:34 -0700175 case SENSOR_TYPE_STEP_COUNTER: {
Aravind Akella70018042014-04-07 22:52:37 +0000176 mStringType = SENSOR_STRING_TYPE_STEP_COUNTER;
Brian Stack793f4642019-04-18 17:21:34 -0700177 mRequiredPermission = SENSOR_PERMISSION_ACTIVITY_RECOGNITION;
178 AppOpsManager appOps;
179 mRequiredAppOp =
180 appOps.permissionToOpCode(String16(mRequiredPermission));
Aravind Akella0e025c52014-06-03 19:19:57 -0700181 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
Brian Stack793f4642019-04-18 17:21:34 -0700182 } break;
183 case SENSOR_TYPE_STEP_DETECTOR: {
Aravind Akella70018042014-04-07 22:52:37 +0000184 mStringType = SENSOR_STRING_TYPE_STEP_DETECTOR;
Brian Stack793f4642019-04-18 17:21:34 -0700185 mRequiredPermission = SENSOR_PERMISSION_ACTIVITY_RECOGNITION;
186 AppOpsManager appOps;
187 mRequiredAppOp =
188 appOps.permissionToOpCode(String16(mRequiredPermission));
Aravind Akella0e025c52014-06-03 19:19:57 -0700189 mFlags |= SENSOR_FLAG_SPECIAL_REPORTING_MODE;
Brian Stack793f4642019-04-18 17:21:34 -0700190 } break;
Aravind Akella70018042014-04-07 22:52:37 +0000191 case SENSOR_TYPE_TEMPERATURE:
192 mStringType = SENSOR_STRING_TYPE_TEMPERATURE;
Aravind Akella0e025c52014-06-03 19:19:57 -0700193 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000194 break;
Aravind Akella64ffcb02014-07-29 12:27:41 -0700195 case SENSOR_TYPE_TILT_DETECTOR:
196 mStringType = SENSOR_STRING_TYPE_TILT_DETECTOR;
197 mFlags |= SENSOR_FLAG_SPECIAL_REPORTING_MODE;
198 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
199 mFlags |= SENSOR_FLAG_WAKE_UP;
200 }
Peng Xu2576cb62016-01-20 00:22:09 -0800201 break;
Etienne Le Grande284a902014-05-07 19:49:05 -0700202 case SENSOR_TYPE_WAKE_GESTURE:
203 mStringType = SENSOR_STRING_TYPE_WAKE_GESTURE;
Aravind Akella64ffcb02014-07-29 12:27:41 -0700204 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
205 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
206 mFlags |= SENSOR_FLAG_WAKE_UP;
207 }
Etienne Le Grande284a902014-05-07 19:49:05 -0700208 break;
Jeff Brown31d825d2014-07-17 15:13:55 -0700209 case SENSOR_TYPE_GLANCE_GESTURE:
210 mStringType = SENSOR_STRING_TYPE_GLANCE_GESTURE;
Aravind Akella64ffcb02014-07-29 12:27:41 -0700211 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
212 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
213 mFlags |= SENSOR_FLAG_WAKE_UP;
214 }
Jeff Brown31d825d2014-07-17 15:13:55 -0700215 break;
Aravind Akellafd8498c2014-07-28 18:01:11 -0700216 case SENSOR_TYPE_PICK_UP_GESTURE:
217 mStringType = SENSOR_STRING_TYPE_PICK_UP_GESTURE;
Aravind Akella64ffcb02014-07-29 12:27:41 -0700218 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
219 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
220 mFlags |= SENSOR_FLAG_WAKE_UP;
221 }
Aravind Akellafd8498c2014-07-28 18:01:11 -0700222 break;
Nick Vaccaro2e990eb2017-01-12 21:13:58 -0800223 case SENSOR_TYPE_LOW_LATENCY_OFFBODY_DETECT:
224 mStringType = SENSOR_STRING_TYPE_LOW_LATENCY_OFFBODY_DETECT;
225 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
226 break;
Nick Vaccaro9bb99b12015-01-21 15:27:23 -0800227 case SENSOR_TYPE_WRIST_TILT_GESTURE:
228 mStringType = SENSOR_STRING_TYPE_WRIST_TILT_GESTURE;
229 mFlags |= SENSOR_FLAG_SPECIAL_REPORTING_MODE;
230 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
231 mFlags |= SENSOR_FLAG_WAKE_UP;
232 }
233 break;
masonwang333cb242021-05-12 18:33:46 +0800234 case SENSOR_TYPE_DEVICE_ORIENTATION:
235 mStringType = SENSOR_STRING_TYPE_DEVICE_ORIENTATION;
236 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
237 break;
Peng Xu2576cb62016-01-20 00:22:09 -0800238 case SENSOR_TYPE_DYNAMIC_SENSOR_META:
239 mStringType = SENSOR_STRING_TYPE_DYNAMIC_SENSOR_META;
Peng Xu4e44cf52016-09-15 11:05:08 -0700240 mFlags |= SENSOR_FLAG_SPECIAL_REPORTING_MODE; // special trigger
241 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
242 mFlags |= SENSOR_FLAG_WAKE_UP;
243 }
Peng Xu2576cb62016-01-20 00:22:09 -0800244 break;
Ashutosh Joshi1b4566c2016-01-14 22:14:46 -0800245 case SENSOR_TYPE_POSE_6DOF:
246 mStringType = SENSOR_STRING_TYPE_POSE_6DOF;
247 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
248 break;
249 case SENSOR_TYPE_STATIONARY_DETECT:
250 mStringType = SENSOR_STRING_TYPE_STATIONARY_DETECT;
251 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
252 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
253 mFlags |= SENSOR_FLAG_WAKE_UP;
254 }
255 break;
256 case SENSOR_TYPE_MOTION_DETECT:
257 mStringType = SENSOR_STRING_TYPE_MOTION_DETECT;
258 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
259 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
260 mFlags |= SENSOR_FLAG_WAKE_UP;
261 }
262 break;
263 case SENSOR_TYPE_HEART_BEAT:
264 mStringType = SENSOR_STRING_TYPE_HEART_BEAT;
265 mFlags |= SENSOR_FLAG_SPECIAL_REPORTING_MODE;
266 break;
Ashutosh Joshiab4e1ff2017-01-12 11:35:19 -0800267 case SENSOR_TYPE_ACCELEROMETER_UNCALIBRATED:
268 mStringType = SENSOR_STRING_TYPE_ACCELEROMETER_UNCALIBRATED;
269 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
270 break;
Anthony Stangefdb1fc82020-01-16 15:02:48 -0500271 case SENSOR_TYPE_HINGE_ANGLE:
272 mStringType = SENSOR_STRING_TYPE_HINGE_ANGLE;
273 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
274 break;
Brian Duddie573da3b2021-12-10 14:34:07 -0800275 case SENSOR_TYPE_HEAD_TRACKER:
276 mStringType = SENSOR_STRING_TYPE_HEAD_TRACKER;
277 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
278 break;
Eva Chenc0420b72021-04-09 15:44:12 -0700279 case SENSOR_TYPE_ACCELEROMETER_LIMITED_AXES:
280 mStringType = SENSOR_STRING_TYPE_ACCELEROMETER_LIMITED_AXES;
281 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
282 break;
283 case SENSOR_TYPE_GYROSCOPE_LIMITED_AXES:
284 mStringType = SENSOR_STRING_TYPE_GYROSCOPE_LIMITED_AXES;
285 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
286 break;
287 case SENSOR_TYPE_ACCELEROMETER_LIMITED_AXES_UNCALIBRATED:
288 mStringType = SENSOR_STRING_TYPE_ACCELEROMETER_LIMITED_AXES_UNCALIBRATED;
289 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
290 break;
291 case SENSOR_TYPE_GYROSCOPE_LIMITED_AXES_UNCALIBRATED:
292 mStringType = SENSOR_STRING_TYPE_GYROSCOPE_LIMITED_AXES_UNCALIBRATED;
293 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
294 break;
Eva Chen72c71042022-01-10 21:07:51 -0800295 case SENSOR_TYPE_HEADING:
296 mStringType = SENSOR_STRING_TYPE_HEADING;
297 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
298 break;
Aravind Akella70018042014-04-07 22:52:37 +0000299 default:
Aravind Akella9a844cf2014-02-11 18:58:52 -0800300 // Only pipe the stringType, requiredPermission and flags for custom sensors.
Peng Xu6a2d3a02015-12-21 12:00:23 -0800301 if (halVersion > SENSORS_DEVICE_API_VERSION_1_0 && hwSensor.stringType) {
302 mStringType = hwSensor.stringType;
Aravind Akella70018042014-04-07 22:52:37 +0000303 }
Peng Xu6a2d3a02015-12-21 12:00:23 -0800304 if (halVersion > SENSORS_DEVICE_API_VERSION_1_0 && hwSensor.requiredPermission) {
305 mRequiredPermission = hwSensor.requiredPermission;
Prashant Malanie35c7d62015-08-20 17:19:05 -0700306 if (!strcmp(mRequiredPermission, SENSOR_PERMISSION_BODY_SENSORS)) {
307 AppOpsManager appOps;
308 mRequiredAppOp = appOps.permissionToOpCode(String16(SENSOR_PERMISSION_BODY_SENSORS));
309 }
Aravind Akella70018042014-04-07 22:52:37 +0000310 }
Aravind Akella0e025c52014-06-03 19:19:57 -0700311
Aravind Akella9a844cf2014-02-11 18:58:52 -0800312 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) {
Peng Xu6a2d3a02015-12-21 12:00:23 -0800313 mFlags = static_cast<uint32_t>(hwSensor.flags);
Aravind Akella0e025c52014-06-03 19:19:57 -0700314 } else {
315 // This is an OEM defined sensor on an older HAL. Use minDelay to determine the
316 // reporting mode of the sensor.
317 if (mMinDelay > 0) {
318 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
319 } else if (mMinDelay == 0) {
320 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
321 } else if (mMinDelay < 0) {
322 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
323 }
Aravind Akella9a844cf2014-02-11 18:58:52 -0800324 }
Aravind Akella70018042014-04-07 22:52:37 +0000325 break;
Aravind Akella724d91d2013-06-27 12:04:23 -0700326 }
Aravind Akella64ffcb02014-07-29 12:27:41 -0700327
Peng Xu6a2d3a02015-12-21 12:00:23 -0800328 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) {
329 // Wake-up flag of HAL 1.3 and above is set here
330 mFlags |= (hwSensor.flags & SENSOR_FLAG_WAKE_UP);
331
332 // Log error if the reporting mode is not as expected, but respect HAL setting.
333 int actualReportingMode = (hwSensor.flags & REPORTING_MODE_MASK) >> REPORTING_MODE_SHIFT;
334 int expectedReportingMode = (mFlags & REPORTING_MODE_MASK) >> REPORTING_MODE_SHIFT;
335 if (actualReportingMode != expectedReportingMode) {
336 ALOGE("Reporting Mode incorrect: sensor %s handle=%#010" PRIx32 " type=%" PRId32 " "
337 "actual=%d expected=%d",
338 mName.string(), mHandle, mType, actualReportingMode, expectedReportingMode);
339 }
340 }
341
342 // Feature flags
Peng Xu755c4512016-04-07 23:15:14 -0700343 // Set DYNAMIC_SENSOR_MASK and ADDITIONAL_INFO_MASK flag here. Compatible with HAL 1_3.
344 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) {
Peng Xue36e3472016-11-03 11:57:10 -0700345 mFlags |= hwSensor.flags & (DYNAMIC_SENSOR_MASK | ADDITIONAL_INFO_MASK);
346 }
347 // Set DIRECT_REPORT_MASK and DIRECT_CHANNEL_MASK flags. Compatible with HAL 1_3.
348 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) {
349 // only on continuous sensors direct report mode is defined
350 if ((mFlags & REPORTING_MODE_MASK) == SENSOR_FLAG_CONTINUOUS_MODE) {
351 mFlags |= hwSensor.flags
352 & (SENSOR_FLAG_MASK_DIRECT_REPORT | SENSOR_FLAG_MASK_DIRECT_CHANNEL);
353 }
Peng Xu755c4512016-04-07 23:15:14 -0700354 }
Aravind Akellaf9b7f852015-09-10 14:52:31 -0700355 // Set DATA_INJECTION flag here. Defined in HAL 1_4.
356 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_4) {
Peng Xu6a2d3a02015-12-21 12:00:23 -0800357 mFlags |= (hwSensor.flags & DATA_INJECTION_MASK);
Aravind Akella64ffcb02014-07-29 12:27:41 -0700358 }
Svetoslavb412f6e2015-04-29 16:50:41 -0700359
360 if (mRequiredPermission.length() > 0) {
361 // If the sensor is protected by a permission we need to know if it is
362 // a runtime one to determine whether we can use the permission cache.
363 sp<IBinder> binder = defaultServiceManager()->getService(String16("permission"));
Yi Kongd5e079f2018-07-17 16:08:27 -0700364 if (binder != nullptr) {
Svetoslavb412f6e2015-04-29 16:50:41 -0700365 sp<IPermissionController> permCtrl = interface_cast<IPermissionController>(binder);
366 mRequiredPermissionRuntime = permCtrl->isRuntimePermission(
367 String16(mRequiredPermission));
368 }
369 }
Mathias Agopiana7352c92010-07-14 23:41:37 -0700370}
371
Peng Xu6a2d3a02015-12-21 12:00:23 -0800372Sensor::~Sensor() {
Mathias Agopian589ce852010-07-13 22:21:56 -0700373}
374
375const String8& Sensor::getName() const {
376 return mName;
377}
378
379const String8& Sensor::getVendor() const {
380 return mVendor;
381}
382
383int32_t Sensor::getHandle() const {
384 return mHandle;
385}
386
387int32_t Sensor::getType() const {
388 return mType;
389}
390
391float Sensor::getMinValue() const {
392 return mMinValue;
393}
394
395float Sensor::getMaxValue() const {
396 return mMaxValue;
397}
398
399float Sensor::getResolution() const {
400 return mResolution;
401}
402
403float Sensor::getPowerUsage() const {
404 return mPower;
405}
406
Mathias Agopiana48bcf62010-07-29 16:51:38 -0700407int32_t Sensor::getMinDelay() const {
408 return mMinDelay;
409}
410
Mathias Agopianb62013f2011-05-17 22:54:42 -0700411nsecs_t Sensor::getMinDelayNs() const {
412 return getMinDelay() * 1000;
413}
414
415int32_t Sensor::getVersion() const {
416 return mVersion;
417}
418
Dan Stozad723bd72014-11-18 10:24:03 -0800419uint32_t Sensor::getFifoReservedEventCount() const {
Aravind Akella724d91d2013-06-27 12:04:23 -0700420 return mFifoReservedEventCount;
421}
422
Dan Stozad723bd72014-11-18 10:24:03 -0800423uint32_t Sensor::getFifoMaxEventCount() const {
Aravind Akella724d91d2013-06-27 12:04:23 -0700424 return mFifoMaxEventCount;
425}
426
Aravind Akella70018042014-04-07 22:52:37 +0000427const String8& Sensor::getStringType() const {
428 return mStringType;
429}
430
431const String8& Sensor::getRequiredPermission() const {
432 return mRequiredPermission;
433}
434
Svetoslavb412f6e2015-04-29 16:50:41 -0700435bool Sensor::isRequiredPermissionRuntime() const {
436 return mRequiredPermissionRuntime;
437}
438
439int32_t Sensor::getRequiredAppOp() const {
440 return mRequiredAppOp;
441}
442
Aravind Akellad9441e42014-05-13 18:20:30 -0700443int32_t Sensor::getMaxDelay() const {
444 return mMaxDelay;
445}
446
Dan Stozad723bd72014-11-18 10:24:03 -0800447uint32_t Sensor::getFlags() const {
Aravind Akella0e025c52014-06-03 19:19:57 -0700448 return mFlags;
449}
450
Aravind Akella9a844cf2014-02-11 18:58:52 -0800451bool Sensor::isWakeUpSensor() const {
Peng Xu6a2d3a02015-12-21 12:00:23 -0800452 return (mFlags & SENSOR_FLAG_WAKE_UP) != 0;
Aravind Akella0e025c52014-06-03 19:19:57 -0700453}
454
Peng Xu0cc8f802016-04-05 23:46:03 -0700455bool Sensor::isDynamicSensor() const {
Peng Xu6a2d3a02015-12-21 12:00:23 -0800456 return (mFlags & SENSOR_FLAG_DYNAMIC_SENSOR) != 0;
457}
458
Peng Xu48328dd2017-06-04 18:15:32 -0700459bool Sensor::isDataInjectionSupported() const {
460 return (mFlags & SENSOR_FLAG_DATA_INJECTION) != 0;
461}
462
Peng Xu6a2d3a02015-12-21 12:00:23 -0800463bool Sensor::hasAdditionalInfo() const {
464 return (mFlags & SENSOR_FLAG_ADDITIONAL_INFO) != 0;
Peng Xu0cc8f802016-04-05 23:46:03 -0700465}
466
Peng Xue36e3472016-11-03 11:57:10 -0700467int32_t Sensor::getHighestDirectReportRateLevel() const {
468 return ((mFlags & SENSOR_FLAG_MASK_DIRECT_REPORT) >> SENSOR_FLAG_SHIFT_DIRECT_REPORT);
469}
470
471bool Sensor::isDirectChannelTypeSupported(int32_t sharedMemType) const {
472 switch (sharedMemType) {
473 case SENSOR_DIRECT_MEM_TYPE_ASHMEM:
474 return mFlags & SENSOR_FLAG_DIRECT_CHANNEL_ASHMEM;
475 case SENSOR_DIRECT_MEM_TYPE_GRALLOC:
476 return mFlags & SENSOR_FLAG_DIRECT_CHANNEL_GRALLOC;
477 default:
478 return false;
479 }
480}
481
Aravind Akella0e025c52014-06-03 19:19:57 -0700482int32_t Sensor::getReportingMode() const {
483 return ((mFlags & REPORTING_MODE_MASK) >> REPORTING_MODE_SHIFT);
Aravind Akella9a844cf2014-02-11 18:58:52 -0800484}
485
Peng Xu2576cb62016-01-20 00:22:09 -0800486const Sensor::uuid_t& Sensor::getUuid() const {
487 return mUuid;
488}
489
Greg Kaiser53ca2e02016-06-21 16:11:14 -0700490void Sensor::setId(int32_t id) {
Eric Laurente3f27df2022-01-05 19:20:32 +0100491 mId = id;
492}
493
494int32_t Sensor::getId() const {
495 return mId;
496}
497
498void Sensor::anonymizeUuid() {
499 mUuid.i64[0] = mId;
Greg Kaiser53ca2e02016-06-21 16:11:14 -0700500 mUuid.i64[1] = 0;
501}
502
Anh Pham4e291332021-02-10 14:17:56 +0100503void Sensor::capMinDelayMicros(int32_t cappedMinDelay) {
504 if (mMinDelay < cappedMinDelay) {
505 mMinDelay = cappedMinDelay;
506 }
507}
508
509void Sensor::capHighestDirectReportRateLevel(int32_t cappedRateLevel) {
510 if (cappedRateLevel < getHighestDirectReportRateLevel()) {
511 mFlags &= ~SENSOR_FLAG_MASK_DIRECT_REPORT;
512 mFlags |= cappedRateLevel << SENSOR_FLAG_SHIFT_DIRECT_REPORT;
513 }
514}
515
Peng Xu6a2d3a02015-12-21 12:00:23 -0800516size_t Sensor::getFlattenedSize() const {
Mathias Agopiane1424282013-07-29 21:24:40 -0700517 size_t fixedSize =
Peng Xu2576cb62016-01-20 00:22:09 -0800518 sizeof(mVersion) + sizeof(mHandle) + sizeof(mType) +
519 sizeof(mMinValue) + sizeof(mMaxValue) + sizeof(mResolution) +
520 sizeof(mPower) + sizeof(mMinDelay) + sizeof(mFifoMaxEventCount) +
521 sizeof(mFifoMaxEventCount) + sizeof(mRequiredPermissionRuntime) +
Eric Laurente3f27df2022-01-05 19:20:32 +0100522 sizeof(mRequiredAppOp) + sizeof(mMaxDelay) + sizeof(mFlags) +
523 sizeof(mUuid) + sizeof(mId);
Mathias Agopiane1424282013-07-29 21:24:40 -0700524
525 size_t variableSize =
Aravind Akella70018042014-04-07 22:52:37 +0000526 sizeof(uint32_t) + FlattenableUtils::align<4>(mName.length()) +
527 sizeof(uint32_t) + FlattenableUtils::align<4>(mVendor.length()) +
528 sizeof(uint32_t) + FlattenableUtils::align<4>(mStringType.length()) +
529 sizeof(uint32_t) + FlattenableUtils::align<4>(mRequiredPermission.length());
Mathias Agopiane1424282013-07-29 21:24:40 -0700530
531 return fixedSize + variableSize;
Mathias Agopian589ce852010-07-13 22:21:56 -0700532}
533
Mathias Agopiane1424282013-07-29 21:24:40 -0700534status_t Sensor::flatten(void* buffer, size_t size) const {
535 if (size < getFlattenedSize()) {
536 return NO_MEMORY;
537 }
Mathias Agopian589ce852010-07-13 22:21:56 -0700538
Aravind Akella70018042014-04-07 22:52:37 +0000539 flattenString8(buffer, size, mName);
540 flattenString8(buffer, size, mVendor);
Mathias Agopiane1424282013-07-29 21:24:40 -0700541 FlattenableUtils::write(buffer, size, mVersion);
542 FlattenableUtils::write(buffer, size, mHandle);
543 FlattenableUtils::write(buffer, size, mType);
544 FlattenableUtils::write(buffer, size, mMinValue);
545 FlattenableUtils::write(buffer, size, mMaxValue);
546 FlattenableUtils::write(buffer, size, mResolution);
547 FlattenableUtils::write(buffer, size, mPower);
548 FlattenableUtils::write(buffer, size, mMinDelay);
Aravind Akella724d91d2013-06-27 12:04:23 -0700549 FlattenableUtils::write(buffer, size, mFifoReservedEventCount);
550 FlattenableUtils::write(buffer, size, mFifoMaxEventCount);
Aravind Akella70018042014-04-07 22:52:37 +0000551 flattenString8(buffer, size, mStringType);
552 flattenString8(buffer, size, mRequiredPermission);
Svetoslavb412f6e2015-04-29 16:50:41 -0700553 FlattenableUtils::write(buffer, size, mRequiredPermissionRuntime);
554 FlattenableUtils::write(buffer, size, mRequiredAppOp);
Aravind Akellad9441e42014-05-13 18:20:30 -0700555 FlattenableUtils::write(buffer, size, mMaxDelay);
Aravind Akella0e025c52014-06-03 19:19:57 -0700556 FlattenableUtils::write(buffer, size, mFlags);
Eric Laurente3f27df2022-01-05 19:20:32 +0100557 FlattenableUtils::write(buffer, size, mUuid);
558 FlattenableUtils::write(buffer, size, mId);
Mathias Agopian589ce852010-07-13 22:21:56 -0700559 return NO_ERROR;
560}
561
Mathias Agopiane1424282013-07-29 21:24:40 -0700562status_t Sensor::unflatten(void const* buffer, size_t size) {
Aravind Akella70018042014-04-07 22:52:37 +0000563 if (!unflattenString8(buffer, size, mName)) {
Mathias Agopiane1424282013-07-29 21:24:40 -0700564 return NO_MEMORY;
565 }
Aravind Akella70018042014-04-07 22:52:37 +0000566 if (!unflattenString8(buffer, size, mVendor)) {
Mathias Agopiane1424282013-07-29 21:24:40 -0700567 return NO_MEMORY;
568 }
Mathias Agopiane1424282013-07-29 21:24:40 -0700569
Peng Xu2576cb62016-01-20 00:22:09 -0800570 size_t fixedSize1 =
571 sizeof(mVersion) + sizeof(mHandle) + sizeof(mType) + sizeof(mMinValue) +
572 sizeof(mMaxValue) + sizeof(mResolution) + sizeof(mPower) + sizeof(mMinDelay) +
573 sizeof(mFifoMaxEventCount) + sizeof(mFifoMaxEventCount);
574 if (size < fixedSize1) {
Mathias Agopiane1424282013-07-29 21:24:40 -0700575 return NO_MEMORY;
576 }
577
578 FlattenableUtils::read(buffer, size, mVersion);
579 FlattenableUtils::read(buffer, size, mHandle);
580 FlattenableUtils::read(buffer, size, mType);
581 FlattenableUtils::read(buffer, size, mMinValue);
582 FlattenableUtils::read(buffer, size, mMaxValue);
583 FlattenableUtils::read(buffer, size, mResolution);
584 FlattenableUtils::read(buffer, size, mPower);
585 FlattenableUtils::read(buffer, size, mMinDelay);
Aravind Akella724d91d2013-06-27 12:04:23 -0700586 FlattenableUtils::read(buffer, size, mFifoReservedEventCount);
587 FlattenableUtils::read(buffer, size, mFifoMaxEventCount);
Aravind Akella70018042014-04-07 22:52:37 +0000588
589 if (!unflattenString8(buffer, size, mStringType)) {
590 return NO_MEMORY;
591 }
592 if (!unflattenString8(buffer, size, mRequiredPermission)) {
593 return NO_MEMORY;
594 }
Peng Xu2576cb62016-01-20 00:22:09 -0800595
596 size_t fixedSize2 =
597 sizeof(mRequiredPermissionRuntime) + sizeof(mRequiredAppOp) + sizeof(mMaxDelay) +
Eric Laurente3f27df2022-01-05 19:20:32 +0100598 sizeof(mFlags) + sizeof(mUuid) + sizeof(mId);
Peng Xu2576cb62016-01-20 00:22:09 -0800599 if (size < fixedSize2) {
600 return NO_MEMORY;
601 }
602
Svetoslavb412f6e2015-04-29 16:50:41 -0700603 FlattenableUtils::read(buffer, size, mRequiredPermissionRuntime);
604 FlattenableUtils::read(buffer, size, mRequiredAppOp);
Aravind Akellad9441e42014-05-13 18:20:30 -0700605 FlattenableUtils::read(buffer, size, mMaxDelay);
Aravind Akella0e025c52014-06-03 19:19:57 -0700606 FlattenableUtils::read(buffer, size, mFlags);
Peng Xu2576cb62016-01-20 00:22:09 -0800607 FlattenableUtils::read(buffer, size, mUuid);
Eric Laurente3f27df2022-01-05 19:20:32 +0100608 FlattenableUtils::read(buffer, size, mId);
Mathias Agopian589ce852010-07-13 22:21:56 -0700609 return NO_ERROR;
610}
611
Aravind Akella70018042014-04-07 22:52:37 +0000612void Sensor::flattenString8(void*& buffer, size_t& size,
613 const String8& string8) {
Dan Stozad723bd72014-11-18 10:24:03 -0800614 uint32_t len = static_cast<uint32_t>(string8.length());
Aravind Akella70018042014-04-07 22:52:37 +0000615 FlattenableUtils::write(buffer, size, len);
616 memcpy(static_cast<char*>(buffer), string8.string(), len);
Steven Morelandd58cf5a2019-10-07 17:30:23 -0700617 FlattenableUtils::advance(buffer, size, len);
618 size -= FlattenableUtils::align<4>(buffer);
Aravind Akella70018042014-04-07 22:52:37 +0000619}
620
621bool Sensor::unflattenString8(void const*& buffer, size_t& size, String8& outputString8) {
622 uint32_t len;
623 if (size < sizeof(len)) {
624 return false;
625 }
626 FlattenableUtils::read(buffer, size, len);
627 if (size < len) {
628 return false;
629 }
630 outputString8.setTo(static_cast<char const*>(buffer), len);
631 FlattenableUtils::advance(buffer, size, FlattenableUtils::align<4>(len));
632 return true;
633}
634
Mathias Agopian589ce852010-07-13 22:21:56 -0700635// ----------------------------------------------------------------------------
636}; // namespace android