blob: 797efbe5dfb292df69ca08caec1a6d0f9dbe19a4 [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>
Scarlett Songb7a1db62024-07-22 18:15:29 +000024#include <android_permission_flags.h>
Peng Xu6a2d3a02015-12-21 12:00:23 -080025
Brian Stack793f4642019-04-18 17:21:34 -070026/*
27 * The permission to use for activity recognition sensors (like step counter).
28 * See sensor types for more details on what sensors should require this
29 * permission.
30 */
31#define SENSOR_PERMISSION_ACTIVITY_RECOGNITION "android.permission.ACTIVITY_RECOGNITION"
32
Mathias Agopian589ce852010-07-13 22:21:56 -070033// ----------------------------------------------------------------------------
34namespace android {
35// ----------------------------------------------------------------------------
36
Peng Xu6a2d3a02015-12-21 12:00:23 -080037Sensor::Sensor(const char * name) :
38 mName(name), mHandle(0), mType(0),
39 mMinValue(0), mMaxValue(0), mResolution(0),
40 mPower(0), mMinDelay(0), mVersion(0), mFifoReservedEventCount(0),
Peng Xu48328dd2017-06-04 18:15:32 -070041 mFifoMaxEventCount(0), mRequiredAppOp(-1),
Peng Xu6a2d3a02015-12-21 12:00:23 -080042 mMaxDelay(0), mFlags(0) {
Mathias Agopian589ce852010-07-13 22:21:56 -070043}
44
Peng Xu6a2d3a02015-12-21 12:00:23 -080045Sensor::Sensor(struct sensor_t const* hwSensor, int halVersion) :
46 Sensor(*hwSensor, uuid_t(), halVersion) {
47}
48
Peng Xu27cc5f92017-07-24 17:50:53 -070049Sensor::Sensor(struct sensor_t const& hwSensor, const uuid_t& uuid, int halVersion) :
50 Sensor("") {
Peng Xu6a2d3a02015-12-21 12:00:23 -080051 mName = hwSensor.name;
52 mVendor = hwSensor.vendor;
53 mVersion = hwSensor.version;
54 mHandle = hwSensor.handle;
55 mType = hwSensor.type;
Mathias Agopiana7352c92010-07-14 23:41:37 -070056 mMinValue = 0; // FIXME: minValue
Mathias Agopian801ea092017-03-06 15:05:04 -080057 mMaxValue = hwSensor.maxRange; // FIXME: maxValue
Peng Xu6a2d3a02015-12-21 12:00:23 -080058 mResolution = hwSensor.resolution;
59 mPower = hwSensor.power;
60 mMinDelay = hwSensor.minDelay;
Aravind Akella0e025c52014-06-03 19:19:57 -070061 mFlags = 0;
Peng Xu6a2d3a02015-12-21 12:00:23 -080062 mUuid = uuid;
Aravind Akella70018042014-04-07 22:52:37 +000063
Aravind Akella724d91d2013-06-27 12:04:23 -070064 // Set fifo event count zero for older devices which do not support batching. Fused
65 // sensors also have their fifo counts set to zero.
Aravind Akella8493b792014-09-08 15:45:47 -070066 if (halVersion > SENSORS_DEVICE_API_VERSION_1_0) {
Peng Xu6a2d3a02015-12-21 12:00:23 -080067 mFifoReservedEventCount = hwSensor.fifoReservedEventCount;
68 mFifoMaxEventCount = hwSensor.fifoMaxEventCount;
Aravind Akellad35e3af2014-05-12 17:14:56 -070069 } else {
70 mFifoReservedEventCount = 0;
71 mFifoMaxEventCount = 0;
Aravind Akella70018042014-04-07 22:52:37 +000072 }
73
Aravind Akellad9441e42014-05-13 18:20:30 -070074 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) {
Peng Xu6a2d3a02015-12-21 12:00:23 -080075 if (hwSensor.maxDelay > INT_MAX) {
Aravind Akellad9441e42014-05-13 18:20:30 -070076 // Max delay is declared as a 64 bit integer for 64 bit architectures. But it should
77 // always fit in a 32 bit integer, log error and cap it to INT_MAX.
Tomasz Wasilczyk83aa0ab2023-08-11 00:06:51 +000078 ALOGE("Sensor maxDelay overflow error %s %" PRId64, mName.c_str(),
Peng Xu6a2d3a02015-12-21 12:00:23 -080079 static_cast<int64_t>(hwSensor.maxDelay));
Aravind Akellad9441e42014-05-13 18:20:30 -070080 mMaxDelay = INT_MAX;
81 } else {
Peng Xu6a2d3a02015-12-21 12:00:23 -080082 mMaxDelay = static_cast<int32_t>(hwSensor.maxDelay);
Aravind Akellad9441e42014-05-13 18:20:30 -070083 }
84 } else {
85 // For older hals set maxDelay to 0.
86 mMaxDelay = 0;
87 }
88
Aravind Akella0e025c52014-06-03 19:19:57 -070089 // Ensure existing sensors have correct string type, required permissions and reporting mode.
Aravind Akella64ffcb02014-07-29 12:27:41 -070090 // Set reportingMode for all android defined sensor types, set wake-up flag only for proximity
91 // sensor, significant motion, tilt, pick_up gesture, wake gesture and glance gesture on older
92 // HALs. Newer HALs can define both wake-up and non wake-up proximity sensors.
93 // All the OEM defined defined sensors have flags set to whatever is provided by the HAL.
Aravind Akella70018042014-04-07 22:52:37 +000094 switch (mType) {
95 case SENSOR_TYPE_ACCELEROMETER:
96 mStringType = SENSOR_STRING_TYPE_ACCELEROMETER;
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_AMBIENT_TEMPERATURE:
100 mStringType = SENSOR_STRING_TYPE_AMBIENT_TEMPERATURE;
Aravind Akella0e025c52014-06-03 19:19:57 -0700101 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000102 break;
103 case SENSOR_TYPE_GAME_ROTATION_VECTOR:
104 mStringType = SENSOR_STRING_TYPE_GAME_ROTATION_VECTOR;
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_GEOMAGNETIC_ROTATION_VECTOR:
108 mStringType = SENSOR_STRING_TYPE_GEOMAGNETIC_ROTATION_VECTOR;
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_GRAVITY:
112 mStringType = SENSOR_STRING_TYPE_GRAVITY;
Aravind Akella0e025c52014-06-03 19:19:57 -0700113 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000114 break;
115 case SENSOR_TYPE_GYROSCOPE:
116 mStringType = SENSOR_STRING_TYPE_GYROSCOPE;
Aravind Akella0e025c52014-06-03 19:19:57 -0700117 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000118 break;
119 case SENSOR_TYPE_GYROSCOPE_UNCALIBRATED:
120 mStringType = SENSOR_STRING_TYPE_GYROSCOPE_UNCALIBRATED;
Aravind Akella0e025c52014-06-03 19:19:57 -0700121 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000122 break;
Svetoslavb412f6e2015-04-29 16:50:41 -0700123 case SENSOR_TYPE_HEART_RATE: {
Aravind Akella70018042014-04-07 22:52:37 +0000124 mStringType = SENSOR_STRING_TYPE_HEART_RATE;
Scarlett Songb7a1db62024-07-22 18:15:29 +0000125 mRequiredPermission =
126 android::permission::flags::replace_body_sensor_permission_enabled() ?
127 SENSOR_PERMISSION_READ_HEART_RATE : SENSOR_PERMISSION_BODY_SENSORS;
Svetoslavb412f6e2015-04-29 16:50:41 -0700128 AppOpsManager appOps;
Brian Stack793f4642019-04-18 17:21:34 -0700129 mRequiredAppOp = appOps.permissionToOpCode(String16(mRequiredPermission));
Aravind Akella0e025c52014-06-03 19:19:57 -0700130 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
Svetoslavb412f6e2015-04-29 16:50:41 -0700131 } break;
Aravind Akella70018042014-04-07 22:52:37 +0000132 case SENSOR_TYPE_LIGHT:
133 mStringType = SENSOR_STRING_TYPE_LIGHT;
Aravind Akella0e025c52014-06-03 19:19:57 -0700134 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000135 break;
136 case SENSOR_TYPE_LINEAR_ACCELERATION:
137 mStringType = SENSOR_STRING_TYPE_LINEAR_ACCELERATION;
Aravind Akella0e025c52014-06-03 19:19:57 -0700138 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000139 break;
140 case SENSOR_TYPE_MAGNETIC_FIELD:
141 mStringType = SENSOR_STRING_TYPE_MAGNETIC_FIELD;
Aravind Akella0e025c52014-06-03 19:19:57 -0700142 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000143 break;
144 case SENSOR_TYPE_MAGNETIC_FIELD_UNCALIBRATED:
145 mStringType = SENSOR_STRING_TYPE_MAGNETIC_FIELD_UNCALIBRATED;
Aravind Akella0e025c52014-06-03 19:19:57 -0700146 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000147 break;
148 case SENSOR_TYPE_ORIENTATION:
149 mStringType = SENSOR_STRING_TYPE_ORIENTATION;
Aravind Akella0e025c52014-06-03 19:19:57 -0700150 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000151 break;
152 case SENSOR_TYPE_PRESSURE:
153 mStringType = SENSOR_STRING_TYPE_PRESSURE;
Aravind Akella0e025c52014-06-03 19:19:57 -0700154 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000155 break;
156 case SENSOR_TYPE_PROXIMITY:
157 mStringType = SENSOR_STRING_TYPE_PROXIMITY;
Aravind Akella64ffcb02014-07-29 12:27:41 -0700158 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
159 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
160 mFlags |= SENSOR_FLAG_WAKE_UP;
161 }
Aravind Akella70018042014-04-07 22:52:37 +0000162 break;
163 case SENSOR_TYPE_RELATIVE_HUMIDITY:
164 mStringType = SENSOR_STRING_TYPE_RELATIVE_HUMIDITY;
Aravind Akella0e025c52014-06-03 19:19:57 -0700165 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000166 break;
167 case SENSOR_TYPE_ROTATION_VECTOR:
168 mStringType = SENSOR_STRING_TYPE_ROTATION_VECTOR;
Aravind Akella0e025c52014-06-03 19:19:57 -0700169 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000170 break;
171 case SENSOR_TYPE_SIGNIFICANT_MOTION:
172 mStringType = SENSOR_STRING_TYPE_SIGNIFICANT_MOTION;
Aravind Akella64ffcb02014-07-29 12:27:41 -0700173 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
174 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
175 mFlags |= SENSOR_FLAG_WAKE_UP;
176 }
Aravind Akella70018042014-04-07 22:52:37 +0000177 break;
Brian Stack793f4642019-04-18 17:21:34 -0700178 case SENSOR_TYPE_STEP_COUNTER: {
Aravind Akella70018042014-04-07 22:52:37 +0000179 mStringType = SENSOR_STRING_TYPE_STEP_COUNTER;
Brian Stack793f4642019-04-18 17:21:34 -0700180 mRequiredPermission = SENSOR_PERMISSION_ACTIVITY_RECOGNITION;
181 AppOpsManager appOps;
182 mRequiredAppOp =
183 appOps.permissionToOpCode(String16(mRequiredPermission));
Aravind Akella0e025c52014-06-03 19:19:57 -0700184 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
Brian Stack793f4642019-04-18 17:21:34 -0700185 } break;
186 case SENSOR_TYPE_STEP_DETECTOR: {
Aravind Akella70018042014-04-07 22:52:37 +0000187 mStringType = SENSOR_STRING_TYPE_STEP_DETECTOR;
Brian Stack793f4642019-04-18 17:21:34 -0700188 mRequiredPermission = SENSOR_PERMISSION_ACTIVITY_RECOGNITION;
189 AppOpsManager appOps;
190 mRequiredAppOp =
191 appOps.permissionToOpCode(String16(mRequiredPermission));
Aravind Akella0e025c52014-06-03 19:19:57 -0700192 mFlags |= SENSOR_FLAG_SPECIAL_REPORTING_MODE;
Brian Stack793f4642019-04-18 17:21:34 -0700193 } break;
Aravind Akella70018042014-04-07 22:52:37 +0000194 case SENSOR_TYPE_TEMPERATURE:
195 mStringType = SENSOR_STRING_TYPE_TEMPERATURE;
Aravind Akella0e025c52014-06-03 19:19:57 -0700196 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
Aravind Akella70018042014-04-07 22:52:37 +0000197 break;
Aravind Akella64ffcb02014-07-29 12:27:41 -0700198 case SENSOR_TYPE_TILT_DETECTOR:
199 mStringType = SENSOR_STRING_TYPE_TILT_DETECTOR;
200 mFlags |= SENSOR_FLAG_SPECIAL_REPORTING_MODE;
201 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
202 mFlags |= SENSOR_FLAG_WAKE_UP;
203 }
Peng Xu2576cb62016-01-20 00:22:09 -0800204 break;
Etienne Le Grande284a902014-05-07 19:49:05 -0700205 case SENSOR_TYPE_WAKE_GESTURE:
206 mStringType = SENSOR_STRING_TYPE_WAKE_GESTURE;
Aravind Akella64ffcb02014-07-29 12:27:41 -0700207 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
208 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
209 mFlags |= SENSOR_FLAG_WAKE_UP;
210 }
Etienne Le Grande284a902014-05-07 19:49:05 -0700211 break;
Jeff Brown31d825d2014-07-17 15:13:55 -0700212 case SENSOR_TYPE_GLANCE_GESTURE:
213 mStringType = SENSOR_STRING_TYPE_GLANCE_GESTURE;
Aravind Akella64ffcb02014-07-29 12:27:41 -0700214 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
215 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
216 mFlags |= SENSOR_FLAG_WAKE_UP;
217 }
Jeff Brown31d825d2014-07-17 15:13:55 -0700218 break;
Aravind Akellafd8498c2014-07-28 18:01:11 -0700219 case SENSOR_TYPE_PICK_UP_GESTURE:
220 mStringType = SENSOR_STRING_TYPE_PICK_UP_GESTURE;
Aravind Akella64ffcb02014-07-29 12:27:41 -0700221 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
222 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
223 mFlags |= SENSOR_FLAG_WAKE_UP;
224 }
Aravind Akellafd8498c2014-07-28 18:01:11 -0700225 break;
Nick Vaccaro2e990eb2017-01-12 21:13:58 -0800226 case SENSOR_TYPE_LOW_LATENCY_OFFBODY_DETECT:
227 mStringType = SENSOR_STRING_TYPE_LOW_LATENCY_OFFBODY_DETECT;
228 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
229 break;
Nick Vaccaro9bb99b12015-01-21 15:27:23 -0800230 case SENSOR_TYPE_WRIST_TILT_GESTURE:
231 mStringType = SENSOR_STRING_TYPE_WRIST_TILT_GESTURE;
232 mFlags |= SENSOR_FLAG_SPECIAL_REPORTING_MODE;
233 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
234 mFlags |= SENSOR_FLAG_WAKE_UP;
235 }
236 break;
masonwang333cb242021-05-12 18:33:46 +0800237 case SENSOR_TYPE_DEVICE_ORIENTATION:
238 mStringType = SENSOR_STRING_TYPE_DEVICE_ORIENTATION;
239 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
240 break;
Peng Xu2576cb62016-01-20 00:22:09 -0800241 case SENSOR_TYPE_DYNAMIC_SENSOR_META:
242 mStringType = SENSOR_STRING_TYPE_DYNAMIC_SENSOR_META;
Peng Xu4e44cf52016-09-15 11:05:08 -0700243 mFlags |= SENSOR_FLAG_SPECIAL_REPORTING_MODE; // special trigger
244 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
245 mFlags |= SENSOR_FLAG_WAKE_UP;
246 }
Peng Xu2576cb62016-01-20 00:22:09 -0800247 break;
Ashutosh Joshi1b4566c2016-01-14 22:14:46 -0800248 case SENSOR_TYPE_POSE_6DOF:
249 mStringType = SENSOR_STRING_TYPE_POSE_6DOF;
250 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
251 break;
252 case SENSOR_TYPE_STATIONARY_DETECT:
253 mStringType = SENSOR_STRING_TYPE_STATIONARY_DETECT;
254 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
255 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
256 mFlags |= SENSOR_FLAG_WAKE_UP;
257 }
258 break;
259 case SENSOR_TYPE_MOTION_DETECT:
260 mStringType = SENSOR_STRING_TYPE_MOTION_DETECT;
261 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
262 if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) {
263 mFlags |= SENSOR_FLAG_WAKE_UP;
264 }
265 break;
266 case SENSOR_TYPE_HEART_BEAT:
267 mStringType = SENSOR_STRING_TYPE_HEART_BEAT;
268 mFlags |= SENSOR_FLAG_SPECIAL_REPORTING_MODE;
269 break;
Ashutosh Joshiab4e1ff2017-01-12 11:35:19 -0800270 case SENSOR_TYPE_ACCELEROMETER_UNCALIBRATED:
271 mStringType = SENSOR_STRING_TYPE_ACCELEROMETER_UNCALIBRATED;
272 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
273 break;
Anthony Stangefdb1fc82020-01-16 15:02:48 -0500274 case SENSOR_TYPE_HINGE_ANGLE:
275 mStringType = SENSOR_STRING_TYPE_HINGE_ANGLE;
276 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
277 break;
Brian Duddie573da3b2021-12-10 14:34:07 -0800278 case SENSOR_TYPE_HEAD_TRACKER:
279 mStringType = SENSOR_STRING_TYPE_HEAD_TRACKER;
280 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
281 break;
Eva Chenc0420b72021-04-09 15:44:12 -0700282 case SENSOR_TYPE_ACCELEROMETER_LIMITED_AXES:
283 mStringType = SENSOR_STRING_TYPE_ACCELEROMETER_LIMITED_AXES;
284 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
285 break;
286 case SENSOR_TYPE_GYROSCOPE_LIMITED_AXES:
287 mStringType = SENSOR_STRING_TYPE_GYROSCOPE_LIMITED_AXES;
288 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
289 break;
290 case SENSOR_TYPE_ACCELEROMETER_LIMITED_AXES_UNCALIBRATED:
291 mStringType = SENSOR_STRING_TYPE_ACCELEROMETER_LIMITED_AXES_UNCALIBRATED;
292 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
293 break;
294 case SENSOR_TYPE_GYROSCOPE_LIMITED_AXES_UNCALIBRATED:
295 mStringType = SENSOR_STRING_TYPE_GYROSCOPE_LIMITED_AXES_UNCALIBRATED;
296 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
297 break;
Eva Chen72c71042022-01-10 21:07:51 -0800298 case SENSOR_TYPE_HEADING:
299 mStringType = SENSOR_STRING_TYPE_HEADING;
300 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
301 break;
Aravind Akella70018042014-04-07 22:52:37 +0000302 default:
Aravind Akella9a844cf2014-02-11 18:58:52 -0800303 // Only pipe the stringType, requiredPermission and flags for custom sensors.
Peng Xu6a2d3a02015-12-21 12:00:23 -0800304 if (halVersion > SENSORS_DEVICE_API_VERSION_1_0 && hwSensor.stringType) {
305 mStringType = hwSensor.stringType;
Aravind Akella70018042014-04-07 22:52:37 +0000306 }
Peng Xu6a2d3a02015-12-21 12:00:23 -0800307 if (halVersion > SENSORS_DEVICE_API_VERSION_1_0 && hwSensor.requiredPermission) {
308 mRequiredPermission = hwSensor.requiredPermission;
Justin Lannin0980aa82024-11-06 07:25:00 +0000309 bool requiresBodySensorPermission =
310 !strcmp(mRequiredPermission, SENSOR_PERMISSION_BODY_SENSORS);
311 if (android::permission::flags::replace_body_sensor_permission_enabled()) {
312 if (requiresBodySensorPermission) {
313 ALOGE("Sensor %s using deprecated Body Sensor permission", mName.c_str());
314 }
315
316 AppOpsManager appOps;
317 // Lookup to see if an AppOp exists for the permission. If none
318 // does, the default value of -1 is used.
319 mRequiredAppOp = appOps.permissionToOpCode(String16(mRequiredPermission));
320 } else if (requiresBodySensorPermission) {
Prashant Malanie35c7d62015-08-20 17:19:05 -0700321 AppOpsManager appOps;
322 mRequiredAppOp = appOps.permissionToOpCode(String16(SENSOR_PERMISSION_BODY_SENSORS));
323 }
Aravind Akella70018042014-04-07 22:52:37 +0000324 }
Aravind Akella0e025c52014-06-03 19:19:57 -0700325
Aravind Akella9a844cf2014-02-11 18:58:52 -0800326 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) {
Peng Xu6a2d3a02015-12-21 12:00:23 -0800327 mFlags = static_cast<uint32_t>(hwSensor.flags);
Aravind Akella0e025c52014-06-03 19:19:57 -0700328 } else {
329 // This is an OEM defined sensor on an older HAL. Use minDelay to determine the
330 // reporting mode of the sensor.
331 if (mMinDelay > 0) {
332 mFlags |= SENSOR_FLAG_CONTINUOUS_MODE;
333 } else if (mMinDelay == 0) {
334 mFlags |= SENSOR_FLAG_ON_CHANGE_MODE;
335 } else if (mMinDelay < 0) {
336 mFlags |= SENSOR_FLAG_ONE_SHOT_MODE;
337 }
Aravind Akella9a844cf2014-02-11 18:58:52 -0800338 }
Aravind Akella70018042014-04-07 22:52:37 +0000339 break;
Aravind Akella724d91d2013-06-27 12:04:23 -0700340 }
Aravind Akella64ffcb02014-07-29 12:27:41 -0700341
Peng Xu6a2d3a02015-12-21 12:00:23 -0800342 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) {
343 // Wake-up flag of HAL 1.3 and above is set here
344 mFlags |= (hwSensor.flags & SENSOR_FLAG_WAKE_UP);
345
346 // Log error if the reporting mode is not as expected, but respect HAL setting.
347 int actualReportingMode = (hwSensor.flags & REPORTING_MODE_MASK) >> REPORTING_MODE_SHIFT;
348 int expectedReportingMode = (mFlags & REPORTING_MODE_MASK) >> REPORTING_MODE_SHIFT;
349 if (actualReportingMode != expectedReportingMode) {
350 ALOGE("Reporting Mode incorrect: sensor %s handle=%#010" PRIx32 " type=%" PRId32 " "
351 "actual=%d expected=%d",
Tomasz Wasilczyk83aa0ab2023-08-11 00:06:51 +0000352 mName.c_str(), mHandle, mType, actualReportingMode, expectedReportingMode);
Peng Xu6a2d3a02015-12-21 12:00:23 -0800353 }
354 }
355
356 // Feature flags
Peng Xu755c4512016-04-07 23:15:14 -0700357 // Set DYNAMIC_SENSOR_MASK and ADDITIONAL_INFO_MASK flag here. Compatible with HAL 1_3.
358 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) {
Peng Xue36e3472016-11-03 11:57:10 -0700359 mFlags |= hwSensor.flags & (DYNAMIC_SENSOR_MASK | ADDITIONAL_INFO_MASK);
360 }
361 // Set DIRECT_REPORT_MASK and DIRECT_CHANNEL_MASK flags. Compatible with HAL 1_3.
362 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) {
363 // only on continuous sensors direct report mode is defined
364 if ((mFlags & REPORTING_MODE_MASK) == SENSOR_FLAG_CONTINUOUS_MODE) {
365 mFlags |= hwSensor.flags
366 & (SENSOR_FLAG_MASK_DIRECT_REPORT | SENSOR_FLAG_MASK_DIRECT_CHANNEL);
367 }
Peng Xu755c4512016-04-07 23:15:14 -0700368 }
Aravind Akellaf9b7f852015-09-10 14:52:31 -0700369 // Set DATA_INJECTION flag here. Defined in HAL 1_4.
370 if (halVersion >= SENSORS_DEVICE_API_VERSION_1_4) {
Peng Xu6a2d3a02015-12-21 12:00:23 -0800371 mFlags |= (hwSensor.flags & DATA_INJECTION_MASK);
Aravind Akella64ffcb02014-07-29 12:27:41 -0700372 }
Svetoslavb412f6e2015-04-29 16:50:41 -0700373
374 if (mRequiredPermission.length() > 0) {
375 // If the sensor is protected by a permission we need to know if it is
376 // a runtime one to determine whether we can use the permission cache.
377 sp<IBinder> binder = defaultServiceManager()->getService(String16("permission"));
Yi Kongd5e079f2018-07-17 16:08:27 -0700378 if (binder != nullptr) {
Svetoslavb412f6e2015-04-29 16:50:41 -0700379 sp<IPermissionController> permCtrl = interface_cast<IPermissionController>(binder);
380 mRequiredPermissionRuntime = permCtrl->isRuntimePermission(
381 String16(mRequiredPermission));
382 }
383 }
Mathias Agopiana7352c92010-07-14 23:41:37 -0700384}
385
Peng Xu6a2d3a02015-12-21 12:00:23 -0800386Sensor::~Sensor() {
Mathias Agopian589ce852010-07-13 22:21:56 -0700387}
388
389const String8& Sensor::getName() const {
390 return mName;
391}
392
393const String8& Sensor::getVendor() const {
394 return mVendor;
395}
396
397int32_t Sensor::getHandle() const {
398 return mHandle;
399}
400
401int32_t Sensor::getType() const {
402 return mType;
403}
404
405float Sensor::getMinValue() const {
406 return mMinValue;
407}
408
409float Sensor::getMaxValue() const {
410 return mMaxValue;
411}
412
413float Sensor::getResolution() const {
414 return mResolution;
415}
416
417float Sensor::getPowerUsage() const {
418 return mPower;
419}
420
Mathias Agopiana48bcf62010-07-29 16:51:38 -0700421int32_t Sensor::getMinDelay() const {
422 return mMinDelay;
423}
424
Mathias Agopianb62013f2011-05-17 22:54:42 -0700425nsecs_t Sensor::getMinDelayNs() const {
426 return getMinDelay() * 1000;
427}
428
429int32_t Sensor::getVersion() const {
430 return mVersion;
431}
432
Dan Stozad723bd72014-11-18 10:24:03 -0800433uint32_t Sensor::getFifoReservedEventCount() const {
Aravind Akella724d91d2013-06-27 12:04:23 -0700434 return mFifoReservedEventCount;
435}
436
Dan Stozad723bd72014-11-18 10:24:03 -0800437uint32_t Sensor::getFifoMaxEventCount() const {
Aravind Akella724d91d2013-06-27 12:04:23 -0700438 return mFifoMaxEventCount;
439}
440
Aravind Akella70018042014-04-07 22:52:37 +0000441const String8& Sensor::getStringType() const {
442 return mStringType;
443}
444
445const String8& Sensor::getRequiredPermission() const {
446 return mRequiredPermission;
447}
448
Svetoslavb412f6e2015-04-29 16:50:41 -0700449bool Sensor::isRequiredPermissionRuntime() const {
450 return mRequiredPermissionRuntime;
451}
452
453int32_t Sensor::getRequiredAppOp() const {
454 return mRequiredAppOp;
455}
456
Aravind Akellad9441e42014-05-13 18:20:30 -0700457int32_t Sensor::getMaxDelay() const {
458 return mMaxDelay;
459}
460
Dan Stozad723bd72014-11-18 10:24:03 -0800461uint32_t Sensor::getFlags() const {
Aravind Akella0e025c52014-06-03 19:19:57 -0700462 return mFlags;
463}
464
Aravind Akella9a844cf2014-02-11 18:58:52 -0800465bool Sensor::isWakeUpSensor() const {
Peng Xu6a2d3a02015-12-21 12:00:23 -0800466 return (mFlags & SENSOR_FLAG_WAKE_UP) != 0;
Aravind Akella0e025c52014-06-03 19:19:57 -0700467}
468
Peng Xu0cc8f802016-04-05 23:46:03 -0700469bool Sensor::isDynamicSensor() const {
Peng Xu6a2d3a02015-12-21 12:00:23 -0800470 return (mFlags & SENSOR_FLAG_DYNAMIC_SENSOR) != 0;
471}
472
Peng Xu48328dd2017-06-04 18:15:32 -0700473bool Sensor::isDataInjectionSupported() const {
474 return (mFlags & SENSOR_FLAG_DATA_INJECTION) != 0;
475}
476
Peng Xu6a2d3a02015-12-21 12:00:23 -0800477bool Sensor::hasAdditionalInfo() const {
478 return (mFlags & SENSOR_FLAG_ADDITIONAL_INFO) != 0;
Peng Xu0cc8f802016-04-05 23:46:03 -0700479}
480
Peng Xue36e3472016-11-03 11:57:10 -0700481int32_t Sensor::getHighestDirectReportRateLevel() const {
482 return ((mFlags & SENSOR_FLAG_MASK_DIRECT_REPORT) >> SENSOR_FLAG_SHIFT_DIRECT_REPORT);
483}
484
485bool Sensor::isDirectChannelTypeSupported(int32_t sharedMemType) const {
486 switch (sharedMemType) {
487 case SENSOR_DIRECT_MEM_TYPE_ASHMEM:
488 return mFlags & SENSOR_FLAG_DIRECT_CHANNEL_ASHMEM;
489 case SENSOR_DIRECT_MEM_TYPE_GRALLOC:
490 return mFlags & SENSOR_FLAG_DIRECT_CHANNEL_GRALLOC;
491 default:
492 return false;
493 }
494}
495
Aravind Akella0e025c52014-06-03 19:19:57 -0700496int32_t Sensor::getReportingMode() const {
497 return ((mFlags & REPORTING_MODE_MASK) >> REPORTING_MODE_SHIFT);
Aravind Akella9a844cf2014-02-11 18:58:52 -0800498}
499
Peng Xu2576cb62016-01-20 00:22:09 -0800500const Sensor::uuid_t& Sensor::getUuid() const {
501 return mUuid;
502}
503
Greg Kaiser53ca2e02016-06-21 16:11:14 -0700504void Sensor::setId(int32_t id) {
Eric Laurente3f27df2022-01-05 19:20:32 +0100505 mId = id;
506}
507
508int32_t Sensor::getId() const {
509 return mId;
510}
511
512void Sensor::anonymizeUuid() {
513 mUuid.i64[0] = mId;
Greg Kaiser53ca2e02016-06-21 16:11:14 -0700514 mUuid.i64[1] = 0;
515}
516
Anh Pham4e291332021-02-10 14:17:56 +0100517void Sensor::capMinDelayMicros(int32_t cappedMinDelay) {
518 if (mMinDelay < cappedMinDelay) {
519 mMinDelay = cappedMinDelay;
520 }
521}
522
523void Sensor::capHighestDirectReportRateLevel(int32_t cappedRateLevel) {
524 if (cappedRateLevel < getHighestDirectReportRateLevel()) {
525 mFlags &= ~SENSOR_FLAG_MASK_DIRECT_REPORT;
526 mFlags |= cappedRateLevel << SENSOR_FLAG_SHIFT_DIRECT_REPORT;
527 }
528}
529
Peng Xu6a2d3a02015-12-21 12:00:23 -0800530size_t Sensor::getFlattenedSize() const {
Mathias Agopiane1424282013-07-29 21:24:40 -0700531 size_t fixedSize =
Peng Xu2576cb62016-01-20 00:22:09 -0800532 sizeof(mVersion) + sizeof(mHandle) + sizeof(mType) +
533 sizeof(mMinValue) + sizeof(mMaxValue) + sizeof(mResolution) +
534 sizeof(mPower) + sizeof(mMinDelay) + sizeof(mFifoMaxEventCount) +
535 sizeof(mFifoMaxEventCount) + sizeof(mRequiredPermissionRuntime) +
Eric Laurente3f27df2022-01-05 19:20:32 +0100536 sizeof(mRequiredAppOp) + sizeof(mMaxDelay) + sizeof(mFlags) +
537 sizeof(mUuid) + sizeof(mId);
Mathias Agopiane1424282013-07-29 21:24:40 -0700538
539 size_t variableSize =
Aravind Akella70018042014-04-07 22:52:37 +0000540 sizeof(uint32_t) + FlattenableUtils::align<4>(mName.length()) +
541 sizeof(uint32_t) + FlattenableUtils::align<4>(mVendor.length()) +
542 sizeof(uint32_t) + FlattenableUtils::align<4>(mStringType.length()) +
543 sizeof(uint32_t) + FlattenableUtils::align<4>(mRequiredPermission.length());
Mathias Agopiane1424282013-07-29 21:24:40 -0700544
545 return fixedSize + variableSize;
Mathias Agopian589ce852010-07-13 22:21:56 -0700546}
547
Mathias Agopiane1424282013-07-29 21:24:40 -0700548status_t Sensor::flatten(void* buffer, size_t size) const {
549 if (size < getFlattenedSize()) {
550 return NO_MEMORY;
551 }
Mathias Agopian589ce852010-07-13 22:21:56 -0700552
Aravind Akella70018042014-04-07 22:52:37 +0000553 flattenString8(buffer, size, mName);
554 flattenString8(buffer, size, mVendor);
Mathias Agopiane1424282013-07-29 21:24:40 -0700555 FlattenableUtils::write(buffer, size, mVersion);
556 FlattenableUtils::write(buffer, size, mHandle);
557 FlattenableUtils::write(buffer, size, mType);
558 FlattenableUtils::write(buffer, size, mMinValue);
559 FlattenableUtils::write(buffer, size, mMaxValue);
560 FlattenableUtils::write(buffer, size, mResolution);
561 FlattenableUtils::write(buffer, size, mPower);
562 FlattenableUtils::write(buffer, size, mMinDelay);
Aravind Akella724d91d2013-06-27 12:04:23 -0700563 FlattenableUtils::write(buffer, size, mFifoReservedEventCount);
564 FlattenableUtils::write(buffer, size, mFifoMaxEventCount);
Aravind Akella70018042014-04-07 22:52:37 +0000565 flattenString8(buffer, size, mStringType);
566 flattenString8(buffer, size, mRequiredPermission);
Svetoslavb412f6e2015-04-29 16:50:41 -0700567 FlattenableUtils::write(buffer, size, mRequiredPermissionRuntime);
568 FlattenableUtils::write(buffer, size, mRequiredAppOp);
Aravind Akellad9441e42014-05-13 18:20:30 -0700569 FlattenableUtils::write(buffer, size, mMaxDelay);
Aravind Akella0e025c52014-06-03 19:19:57 -0700570 FlattenableUtils::write(buffer, size, mFlags);
Eric Laurente3f27df2022-01-05 19:20:32 +0100571 FlattenableUtils::write(buffer, size, mUuid);
572 FlattenableUtils::write(buffer, size, mId);
Mathias Agopian589ce852010-07-13 22:21:56 -0700573 return NO_ERROR;
574}
575
Mathias Agopiane1424282013-07-29 21:24:40 -0700576status_t Sensor::unflatten(void const* buffer, size_t size) {
Aravind Akella70018042014-04-07 22:52:37 +0000577 if (!unflattenString8(buffer, size, mName)) {
Mathias Agopiane1424282013-07-29 21:24:40 -0700578 return NO_MEMORY;
579 }
Aravind Akella70018042014-04-07 22:52:37 +0000580 if (!unflattenString8(buffer, size, mVendor)) {
Mathias Agopiane1424282013-07-29 21:24:40 -0700581 return NO_MEMORY;
582 }
Mathias Agopiane1424282013-07-29 21:24:40 -0700583
Peng Xu2576cb62016-01-20 00:22:09 -0800584 size_t fixedSize1 =
585 sizeof(mVersion) + sizeof(mHandle) + sizeof(mType) + sizeof(mMinValue) +
586 sizeof(mMaxValue) + sizeof(mResolution) + sizeof(mPower) + sizeof(mMinDelay) +
587 sizeof(mFifoMaxEventCount) + sizeof(mFifoMaxEventCount);
588 if (size < fixedSize1) {
Mathias Agopiane1424282013-07-29 21:24:40 -0700589 return NO_MEMORY;
590 }
591
592 FlattenableUtils::read(buffer, size, mVersion);
593 FlattenableUtils::read(buffer, size, mHandle);
594 FlattenableUtils::read(buffer, size, mType);
595 FlattenableUtils::read(buffer, size, mMinValue);
596 FlattenableUtils::read(buffer, size, mMaxValue);
597 FlattenableUtils::read(buffer, size, mResolution);
598 FlattenableUtils::read(buffer, size, mPower);
599 FlattenableUtils::read(buffer, size, mMinDelay);
Aravind Akella724d91d2013-06-27 12:04:23 -0700600 FlattenableUtils::read(buffer, size, mFifoReservedEventCount);
601 FlattenableUtils::read(buffer, size, mFifoMaxEventCount);
Aravind Akella70018042014-04-07 22:52:37 +0000602
603 if (!unflattenString8(buffer, size, mStringType)) {
604 return NO_MEMORY;
605 }
606 if (!unflattenString8(buffer, size, mRequiredPermission)) {
607 return NO_MEMORY;
608 }
Peng Xu2576cb62016-01-20 00:22:09 -0800609
610 size_t fixedSize2 =
611 sizeof(mRequiredPermissionRuntime) + sizeof(mRequiredAppOp) + sizeof(mMaxDelay) +
Eric Laurente3f27df2022-01-05 19:20:32 +0100612 sizeof(mFlags) + sizeof(mUuid) + sizeof(mId);
Peng Xu2576cb62016-01-20 00:22:09 -0800613 if (size < fixedSize2) {
614 return NO_MEMORY;
615 }
616
Svetoslavb412f6e2015-04-29 16:50:41 -0700617 FlattenableUtils::read(buffer, size, mRequiredPermissionRuntime);
618 FlattenableUtils::read(buffer, size, mRequiredAppOp);
Aravind Akellad9441e42014-05-13 18:20:30 -0700619 FlattenableUtils::read(buffer, size, mMaxDelay);
Aravind Akella0e025c52014-06-03 19:19:57 -0700620 FlattenableUtils::read(buffer, size, mFlags);
Peng Xu2576cb62016-01-20 00:22:09 -0800621 FlattenableUtils::read(buffer, size, mUuid);
Eric Laurente3f27df2022-01-05 19:20:32 +0100622 FlattenableUtils::read(buffer, size, mId);
Mathias Agopian589ce852010-07-13 22:21:56 -0700623 return NO_ERROR;
624}
625
Aravind Akella70018042014-04-07 22:52:37 +0000626void Sensor::flattenString8(void*& buffer, size_t& size,
627 const String8& string8) {
Dan Stozad723bd72014-11-18 10:24:03 -0800628 uint32_t len = static_cast<uint32_t>(string8.length());
Aravind Akella70018042014-04-07 22:52:37 +0000629 FlattenableUtils::write(buffer, size, len);
Tomasz Wasilczyk83aa0ab2023-08-11 00:06:51 +0000630 memcpy(static_cast<char*>(buffer), string8.c_str(), len);
Steven Morelandd58cf5a2019-10-07 17:30:23 -0700631 FlattenableUtils::advance(buffer, size, len);
632 size -= FlattenableUtils::align<4>(buffer);
Aravind Akella70018042014-04-07 22:52:37 +0000633}
634
635bool Sensor::unflattenString8(void const*& buffer, size_t& size, String8& outputString8) {
636 uint32_t len;
637 if (size < sizeof(len)) {
638 return false;
639 }
640 FlattenableUtils::read(buffer, size, len);
641 if (size < len) {
642 return false;
643 }
Tomasz Wasilczykd89f6092023-08-24 16:57:29 +0000644 outputString8 = String8(static_cast<char const*>(buffer), len);
Devin Moore1ee72ac2023-02-17 17:12:46 +0000645
646 if (size < FlattenableUtils::align<4>(len)) {
647 ALOGE("Malformed Sensor String8 field. Should be in a 4-byte aligned buffer but is not.");
648 return false;
649 }
Aravind Akella70018042014-04-07 22:52:37 +0000650 FlattenableUtils::advance(buffer, size, FlattenableUtils::align<4>(len));
Devin Moore1ee72ac2023-02-17 17:12:46 +0000651
Aravind Akella70018042014-04-07 22:52:37 +0000652 return true;
653}
654
Mathias Agopian589ce852010-07-13 22:21:56 -0700655// ----------------------------------------------------------------------------
656}; // namespace android