Mathias Agopian | 589ce85 | 2010-07-13 22:21:56 -0700 | [diff] [blame] | 1 | /* |
| 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 | |
Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 17 | |
| 18 | #include <binder/AppOpsManager.h> |
| 19 | #include <binder/IServiceManager.h> |
| 20 | #include <gui/Sensor.h> |
| 21 | #include <hardware/sensors.h> |
| 22 | #include <log/log.h> |
| 23 | #include <utils/Errors.h> |
| 24 | #include <utils/String8.h> |
| 25 | #include <utils/Flattenable.h> |
| 26 | |
Mark Salyzyn | 8f515ce | 2014-06-09 14:32:04 -0700 | [diff] [blame] | 27 | #include <inttypes.h> |
Mathias Agopian | 589ce85 | 2010-07-13 22:21:56 -0700 | [diff] [blame] | 28 | #include <stdint.h> |
| 29 | #include <sys/types.h> |
Aravind Akella | d9441e4 | 2014-05-13 18:20:30 -0700 | [diff] [blame] | 30 | #include <sys/limits.h> |
Mathias Agopian | 589ce85 | 2010-07-13 22:21:56 -0700 | [diff] [blame] | 31 | |
Mathias Agopian | 589ce85 | 2010-07-13 22:21:56 -0700 | [diff] [blame] | 32 | // ---------------------------------------------------------------------------- |
| 33 | namespace android { |
| 34 | // ---------------------------------------------------------------------------- |
| 35 | |
Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 36 | Sensor::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), |
| 40 | mFifoMaxEventCount(0), mRequiredAppOp(0), |
| 41 | mMaxDelay(0), mFlags(0) { |
Mathias Agopian | 589ce85 | 2010-07-13 22:21:56 -0700 | [diff] [blame] | 42 | } |
| 43 | |
Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 44 | Sensor::Sensor(struct sensor_t const* hwSensor, int halVersion) : |
| 45 | Sensor(*hwSensor, uuid_t(), halVersion) { |
| 46 | } |
| 47 | |
| 48 | Sensor::Sensor(struct sensor_t const& hwSensor, const uuid_t& uuid, int halVersion) { |
| 49 | mName = hwSensor.name; |
| 50 | mVendor = hwSensor.vendor; |
| 51 | mVersion = hwSensor.version; |
| 52 | mHandle = hwSensor.handle; |
| 53 | mType = hwSensor.type; |
Mathias Agopian | a7352c9 | 2010-07-14 23:41:37 -0700 | [diff] [blame] | 54 | mMinValue = 0; // FIXME: minValue |
Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 55 | mMaxValue = hwSensor.maxRange; // FIXME: maxValue |
| 56 | mResolution = hwSensor.resolution; |
| 57 | mPower = hwSensor.power; |
| 58 | mMinDelay = hwSensor.minDelay; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 59 | mFlags = 0; |
Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 60 | mUuid = uuid; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 61 | |
Aravind Akella | 724d91d | 2013-06-27 12:04:23 -0700 | [diff] [blame] | 62 | // Set fifo event count zero for older devices which do not support batching. Fused |
| 63 | // sensors also have their fifo counts set to zero. |
Aravind Akella | 8493b79 | 2014-09-08 15:45:47 -0700 | [diff] [blame] | 64 | if (halVersion > SENSORS_DEVICE_API_VERSION_1_0) { |
Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 65 | mFifoReservedEventCount = hwSensor.fifoReservedEventCount; |
| 66 | mFifoMaxEventCount = hwSensor.fifoMaxEventCount; |
Aravind Akella | d35e3af | 2014-05-12 17:14:56 -0700 | [diff] [blame] | 67 | } else { |
| 68 | mFifoReservedEventCount = 0; |
| 69 | mFifoMaxEventCount = 0; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 70 | } |
| 71 | |
Aravind Akella | d9441e4 | 2014-05-13 18:20:30 -0700 | [diff] [blame] | 72 | if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) { |
Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 73 | if (hwSensor.maxDelay > INT_MAX) { |
Aravind Akella | d9441e4 | 2014-05-13 18:20:30 -0700 | [diff] [blame] | 74 | // Max delay is declared as a 64 bit integer for 64 bit architectures. But it should |
| 75 | // always fit in a 32 bit integer, log error and cap it to INT_MAX. |
Mark Salyzyn | 8f515ce | 2014-06-09 14:32:04 -0700 | [diff] [blame] | 76 | ALOGE("Sensor maxDelay overflow error %s %" PRId64, mName.string(), |
Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 77 | static_cast<int64_t>(hwSensor.maxDelay)); |
Aravind Akella | d9441e4 | 2014-05-13 18:20:30 -0700 | [diff] [blame] | 78 | mMaxDelay = INT_MAX; |
| 79 | } else { |
Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 80 | mMaxDelay = static_cast<int32_t>(hwSensor.maxDelay); |
Aravind Akella | d9441e4 | 2014-05-13 18:20:30 -0700 | [diff] [blame] | 81 | } |
| 82 | } else { |
| 83 | // For older hals set maxDelay to 0. |
| 84 | mMaxDelay = 0; |
| 85 | } |
| 86 | |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 87 | // Ensure existing sensors have correct string type, required permissions and reporting mode. |
Aravind Akella | 64ffcb0 | 2014-07-29 12:27:41 -0700 | [diff] [blame] | 88 | // Set reportingMode for all android defined sensor types, set wake-up flag only for proximity |
| 89 | // sensor, significant motion, tilt, pick_up gesture, wake gesture and glance gesture on older |
| 90 | // HALs. Newer HALs can define both wake-up and non wake-up proximity sensors. |
| 91 | // All the OEM defined defined sensors have flags set to whatever is provided by the HAL. |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 92 | switch (mType) { |
| 93 | case SENSOR_TYPE_ACCELEROMETER: |
| 94 | mStringType = SENSOR_STRING_TYPE_ACCELEROMETER; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 95 | mFlags |= SENSOR_FLAG_CONTINUOUS_MODE; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 96 | break; |
| 97 | case SENSOR_TYPE_AMBIENT_TEMPERATURE: |
| 98 | mStringType = SENSOR_STRING_TYPE_AMBIENT_TEMPERATURE; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 99 | mFlags |= SENSOR_FLAG_ON_CHANGE_MODE; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 100 | break; |
| 101 | case SENSOR_TYPE_GAME_ROTATION_VECTOR: |
| 102 | mStringType = SENSOR_STRING_TYPE_GAME_ROTATION_VECTOR; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 103 | mFlags |= SENSOR_FLAG_CONTINUOUS_MODE; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 104 | break; |
| 105 | case SENSOR_TYPE_GEOMAGNETIC_ROTATION_VECTOR: |
| 106 | mStringType = SENSOR_STRING_TYPE_GEOMAGNETIC_ROTATION_VECTOR; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 107 | mFlags |= SENSOR_FLAG_CONTINUOUS_MODE; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 108 | break; |
| 109 | case SENSOR_TYPE_GRAVITY: |
| 110 | mStringType = SENSOR_STRING_TYPE_GRAVITY; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 111 | mFlags |= SENSOR_FLAG_CONTINUOUS_MODE; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 112 | break; |
| 113 | case SENSOR_TYPE_GYROSCOPE: |
| 114 | mStringType = SENSOR_STRING_TYPE_GYROSCOPE; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 115 | mFlags |= SENSOR_FLAG_CONTINUOUS_MODE; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 116 | break; |
| 117 | case SENSOR_TYPE_GYROSCOPE_UNCALIBRATED: |
| 118 | mStringType = SENSOR_STRING_TYPE_GYROSCOPE_UNCALIBRATED; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 119 | mFlags |= SENSOR_FLAG_CONTINUOUS_MODE; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 120 | break; |
Svetoslav | b412f6e | 2015-04-29 16:50:41 -0700 | [diff] [blame] | 121 | case SENSOR_TYPE_HEART_RATE: { |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 122 | mStringType = SENSOR_STRING_TYPE_HEART_RATE; |
| 123 | mRequiredPermission = SENSOR_PERMISSION_BODY_SENSORS; |
Svetoslav | b412f6e | 2015-04-29 16:50:41 -0700 | [diff] [blame] | 124 | AppOpsManager appOps; |
| 125 | mRequiredAppOp = appOps.permissionToOpCode(String16(SENSOR_PERMISSION_BODY_SENSORS)); |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 126 | mFlags |= SENSOR_FLAG_ON_CHANGE_MODE; |
Svetoslav | b412f6e | 2015-04-29 16:50:41 -0700 | [diff] [blame] | 127 | } break; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 128 | case SENSOR_TYPE_LIGHT: |
| 129 | mStringType = SENSOR_STRING_TYPE_LIGHT; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 130 | mFlags |= SENSOR_FLAG_ON_CHANGE_MODE; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 131 | break; |
| 132 | case SENSOR_TYPE_LINEAR_ACCELERATION: |
| 133 | mStringType = SENSOR_STRING_TYPE_LINEAR_ACCELERATION; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 134 | mFlags |= SENSOR_FLAG_CONTINUOUS_MODE; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 135 | break; |
| 136 | case SENSOR_TYPE_MAGNETIC_FIELD: |
| 137 | mStringType = SENSOR_STRING_TYPE_MAGNETIC_FIELD; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 138 | mFlags |= SENSOR_FLAG_CONTINUOUS_MODE; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 139 | break; |
| 140 | case SENSOR_TYPE_MAGNETIC_FIELD_UNCALIBRATED: |
| 141 | mStringType = SENSOR_STRING_TYPE_MAGNETIC_FIELD_UNCALIBRATED; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 142 | mFlags |= SENSOR_FLAG_CONTINUOUS_MODE; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 143 | break; |
| 144 | case SENSOR_TYPE_ORIENTATION: |
| 145 | mStringType = SENSOR_STRING_TYPE_ORIENTATION; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 146 | mFlags |= SENSOR_FLAG_CONTINUOUS_MODE; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 147 | break; |
| 148 | case SENSOR_TYPE_PRESSURE: |
| 149 | mStringType = SENSOR_STRING_TYPE_PRESSURE; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 150 | mFlags |= SENSOR_FLAG_CONTINUOUS_MODE; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 151 | break; |
| 152 | case SENSOR_TYPE_PROXIMITY: |
| 153 | mStringType = SENSOR_STRING_TYPE_PROXIMITY; |
Aravind Akella | 64ffcb0 | 2014-07-29 12:27:41 -0700 | [diff] [blame] | 154 | mFlags |= SENSOR_FLAG_ON_CHANGE_MODE; |
| 155 | if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) { |
| 156 | mFlags |= SENSOR_FLAG_WAKE_UP; |
| 157 | } |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 158 | break; |
| 159 | case SENSOR_TYPE_RELATIVE_HUMIDITY: |
| 160 | mStringType = SENSOR_STRING_TYPE_RELATIVE_HUMIDITY; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 161 | mFlags |= SENSOR_FLAG_ON_CHANGE_MODE; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 162 | break; |
| 163 | case SENSOR_TYPE_ROTATION_VECTOR: |
| 164 | mStringType = SENSOR_STRING_TYPE_ROTATION_VECTOR; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 165 | mFlags |= SENSOR_FLAG_CONTINUOUS_MODE; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 166 | break; |
| 167 | case SENSOR_TYPE_SIGNIFICANT_MOTION: |
| 168 | mStringType = SENSOR_STRING_TYPE_SIGNIFICANT_MOTION; |
Aravind Akella | 64ffcb0 | 2014-07-29 12:27:41 -0700 | [diff] [blame] | 169 | mFlags |= SENSOR_FLAG_ONE_SHOT_MODE; |
| 170 | if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) { |
| 171 | mFlags |= SENSOR_FLAG_WAKE_UP; |
| 172 | } |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 173 | break; |
| 174 | case SENSOR_TYPE_STEP_COUNTER: |
| 175 | mStringType = SENSOR_STRING_TYPE_STEP_COUNTER; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 176 | mFlags |= SENSOR_FLAG_ON_CHANGE_MODE; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 177 | break; |
| 178 | case SENSOR_TYPE_STEP_DETECTOR: |
| 179 | mStringType = SENSOR_STRING_TYPE_STEP_DETECTOR; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 180 | mFlags |= SENSOR_FLAG_SPECIAL_REPORTING_MODE; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 181 | break; |
| 182 | case SENSOR_TYPE_TEMPERATURE: |
| 183 | mStringType = SENSOR_STRING_TYPE_TEMPERATURE; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 184 | mFlags |= SENSOR_FLAG_ON_CHANGE_MODE; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 185 | break; |
Aravind Akella | 64ffcb0 | 2014-07-29 12:27:41 -0700 | [diff] [blame] | 186 | case SENSOR_TYPE_TILT_DETECTOR: |
| 187 | mStringType = SENSOR_STRING_TYPE_TILT_DETECTOR; |
| 188 | mFlags |= SENSOR_FLAG_SPECIAL_REPORTING_MODE; |
| 189 | if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) { |
| 190 | mFlags |= SENSOR_FLAG_WAKE_UP; |
| 191 | } |
Peng Xu | 2576cb6 | 2016-01-20 00:22:09 -0800 | [diff] [blame] | 192 | break; |
Etienne Le Grand | e284a90 | 2014-05-07 19:49:05 -0700 | [diff] [blame] | 193 | case SENSOR_TYPE_WAKE_GESTURE: |
| 194 | mStringType = SENSOR_STRING_TYPE_WAKE_GESTURE; |
Aravind Akella | 64ffcb0 | 2014-07-29 12:27:41 -0700 | [diff] [blame] | 195 | mFlags |= SENSOR_FLAG_ONE_SHOT_MODE; |
| 196 | if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) { |
| 197 | mFlags |= SENSOR_FLAG_WAKE_UP; |
| 198 | } |
Etienne Le Grand | e284a90 | 2014-05-07 19:49:05 -0700 | [diff] [blame] | 199 | break; |
Jeff Brown | 31d825d | 2014-07-17 15:13:55 -0700 | [diff] [blame] | 200 | case SENSOR_TYPE_GLANCE_GESTURE: |
| 201 | mStringType = SENSOR_STRING_TYPE_GLANCE_GESTURE; |
Aravind Akella | 64ffcb0 | 2014-07-29 12:27:41 -0700 | [diff] [blame] | 202 | mFlags |= SENSOR_FLAG_ONE_SHOT_MODE; |
| 203 | if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) { |
| 204 | mFlags |= SENSOR_FLAG_WAKE_UP; |
| 205 | } |
Jeff Brown | 31d825d | 2014-07-17 15:13:55 -0700 | [diff] [blame] | 206 | break; |
Aravind Akella | fd8498c | 2014-07-28 18:01:11 -0700 | [diff] [blame] | 207 | case SENSOR_TYPE_PICK_UP_GESTURE: |
| 208 | mStringType = SENSOR_STRING_TYPE_PICK_UP_GESTURE; |
Aravind Akella | 64ffcb0 | 2014-07-29 12:27:41 -0700 | [diff] [blame] | 209 | mFlags |= SENSOR_FLAG_ONE_SHOT_MODE; |
| 210 | if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) { |
| 211 | mFlags |= SENSOR_FLAG_WAKE_UP; |
| 212 | } |
Aravind Akella | fd8498c | 2014-07-28 18:01:11 -0700 | [diff] [blame] | 213 | break; |
Nick Vaccaro | 9bb99b1 | 2015-01-21 15:27:23 -0800 | [diff] [blame] | 214 | case SENSOR_TYPE_WRIST_TILT_GESTURE: |
| 215 | mStringType = SENSOR_STRING_TYPE_WRIST_TILT_GESTURE; |
| 216 | mFlags |= SENSOR_FLAG_SPECIAL_REPORTING_MODE; |
| 217 | if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) { |
| 218 | mFlags |= SENSOR_FLAG_WAKE_UP; |
| 219 | } |
| 220 | break; |
Peng Xu | 2576cb6 | 2016-01-20 00:22:09 -0800 | [diff] [blame] | 221 | case SENSOR_TYPE_DYNAMIC_SENSOR_META: |
| 222 | mStringType = SENSOR_STRING_TYPE_DYNAMIC_SENSOR_META; |
| 223 | mFlags = SENSOR_FLAG_SPECIAL_REPORTING_MODE; // special trigger and non-wake up |
| 224 | break; |
Ashutosh Joshi | 1b4566c | 2016-01-14 22:14:46 -0800 | [diff] [blame] | 225 | case SENSOR_TYPE_POSE_6DOF: |
| 226 | mStringType = SENSOR_STRING_TYPE_POSE_6DOF; |
| 227 | mFlags |= SENSOR_FLAG_CONTINUOUS_MODE; |
| 228 | break; |
| 229 | case SENSOR_TYPE_STATIONARY_DETECT: |
| 230 | mStringType = SENSOR_STRING_TYPE_STATIONARY_DETECT; |
| 231 | mFlags |= SENSOR_FLAG_ONE_SHOT_MODE; |
| 232 | if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) { |
| 233 | mFlags |= SENSOR_FLAG_WAKE_UP; |
| 234 | } |
| 235 | break; |
| 236 | case SENSOR_TYPE_MOTION_DETECT: |
| 237 | mStringType = SENSOR_STRING_TYPE_MOTION_DETECT; |
| 238 | mFlags |= SENSOR_FLAG_ONE_SHOT_MODE; |
| 239 | if (halVersion < SENSORS_DEVICE_API_VERSION_1_3) { |
| 240 | mFlags |= SENSOR_FLAG_WAKE_UP; |
| 241 | } |
| 242 | break; |
| 243 | case SENSOR_TYPE_HEART_BEAT: |
| 244 | mStringType = SENSOR_STRING_TYPE_HEART_BEAT; |
| 245 | mFlags |= SENSOR_FLAG_SPECIAL_REPORTING_MODE; |
| 246 | break; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 247 | default: |
Aravind Akella | 9a844cf | 2014-02-11 18:58:52 -0800 | [diff] [blame] | 248 | // Only pipe the stringType, requiredPermission and flags for custom sensors. |
Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 249 | if (halVersion > SENSORS_DEVICE_API_VERSION_1_0 && hwSensor.stringType) { |
| 250 | mStringType = hwSensor.stringType; |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 251 | } |
Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 252 | if (halVersion > SENSORS_DEVICE_API_VERSION_1_0 && hwSensor.requiredPermission) { |
| 253 | mRequiredPermission = hwSensor.requiredPermission; |
Prashant Malani | e35c7d6 | 2015-08-20 17:19:05 -0700 | [diff] [blame] | 254 | if (!strcmp(mRequiredPermission, SENSOR_PERMISSION_BODY_SENSORS)) { |
| 255 | AppOpsManager appOps; |
| 256 | mRequiredAppOp = appOps.permissionToOpCode(String16(SENSOR_PERMISSION_BODY_SENSORS)); |
| 257 | } |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 258 | } |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 259 | |
Aravind Akella | 9a844cf | 2014-02-11 18:58:52 -0800 | [diff] [blame] | 260 | if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) { |
Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 261 | mFlags = static_cast<uint32_t>(hwSensor.flags); |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 262 | } else { |
| 263 | // This is an OEM defined sensor on an older HAL. Use minDelay to determine the |
| 264 | // reporting mode of the sensor. |
| 265 | if (mMinDelay > 0) { |
| 266 | mFlags |= SENSOR_FLAG_CONTINUOUS_MODE; |
| 267 | } else if (mMinDelay == 0) { |
| 268 | mFlags |= SENSOR_FLAG_ON_CHANGE_MODE; |
| 269 | } else if (mMinDelay < 0) { |
| 270 | mFlags |= SENSOR_FLAG_ONE_SHOT_MODE; |
| 271 | } |
Aravind Akella | 9a844cf | 2014-02-11 18:58:52 -0800 | [diff] [blame] | 272 | } |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 273 | break; |
Aravind Akella | 724d91d | 2013-06-27 12:04:23 -0700 | [diff] [blame] | 274 | } |
Aravind Akella | 64ffcb0 | 2014-07-29 12:27:41 -0700 | [diff] [blame] | 275 | |
Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 276 | if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) { |
| 277 | // Wake-up flag of HAL 1.3 and above is set here |
| 278 | mFlags |= (hwSensor.flags & SENSOR_FLAG_WAKE_UP); |
| 279 | |
| 280 | // Log error if the reporting mode is not as expected, but respect HAL setting. |
| 281 | int actualReportingMode = (hwSensor.flags & REPORTING_MODE_MASK) >> REPORTING_MODE_SHIFT; |
| 282 | int expectedReportingMode = (mFlags & REPORTING_MODE_MASK) >> REPORTING_MODE_SHIFT; |
| 283 | if (actualReportingMode != expectedReportingMode) { |
| 284 | ALOGE("Reporting Mode incorrect: sensor %s handle=%#010" PRIx32 " type=%" PRId32 " " |
| 285 | "actual=%d expected=%d", |
| 286 | mName.string(), mHandle, mType, actualReportingMode, expectedReportingMode); |
| 287 | } |
| 288 | } |
| 289 | |
| 290 | // Feature flags |
Peng Xu | 755c451 | 2016-04-07 23:15:14 -0700 | [diff] [blame] | 291 | // Set DYNAMIC_SENSOR_MASK and ADDITIONAL_INFO_MASK flag here. Compatible with HAL 1_3. |
| 292 | if (halVersion >= SENSORS_DEVICE_API_VERSION_1_3) { |
Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 293 | mFlags |= (hwSensor.flags & (DYNAMIC_SENSOR_MASK | ADDITIONAL_INFO_MASK)); |
Peng Xu | 755c451 | 2016-04-07 23:15:14 -0700 | [diff] [blame] | 294 | } |
Aravind Akella | f9b7f85 | 2015-09-10 14:52:31 -0700 | [diff] [blame] | 295 | // Set DATA_INJECTION flag here. Defined in HAL 1_4. |
| 296 | if (halVersion >= SENSORS_DEVICE_API_VERSION_1_4) { |
Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 297 | mFlags |= (hwSensor.flags & DATA_INJECTION_MASK); |
Aravind Akella | 64ffcb0 | 2014-07-29 12:27:41 -0700 | [diff] [blame] | 298 | } |
Svetoslav | b412f6e | 2015-04-29 16:50:41 -0700 | [diff] [blame] | 299 | |
| 300 | if (mRequiredPermission.length() > 0) { |
| 301 | // If the sensor is protected by a permission we need to know if it is |
| 302 | // a runtime one to determine whether we can use the permission cache. |
| 303 | sp<IBinder> binder = defaultServiceManager()->getService(String16("permission")); |
| 304 | if (binder != 0) { |
| 305 | sp<IPermissionController> permCtrl = interface_cast<IPermissionController>(binder); |
| 306 | mRequiredPermissionRuntime = permCtrl->isRuntimePermission( |
| 307 | String16(mRequiredPermission)); |
| 308 | } |
| 309 | } |
Mathias Agopian | a7352c9 | 2010-07-14 23:41:37 -0700 | [diff] [blame] | 310 | } |
| 311 | |
Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 312 | Sensor::~Sensor() { |
Mathias Agopian | 589ce85 | 2010-07-13 22:21:56 -0700 | [diff] [blame] | 313 | } |
| 314 | |
| 315 | const String8& Sensor::getName() const { |
| 316 | return mName; |
| 317 | } |
| 318 | |
| 319 | const String8& Sensor::getVendor() const { |
| 320 | return mVendor; |
| 321 | } |
| 322 | |
| 323 | int32_t Sensor::getHandle() const { |
| 324 | return mHandle; |
| 325 | } |
| 326 | |
| 327 | int32_t Sensor::getType() const { |
| 328 | return mType; |
| 329 | } |
| 330 | |
| 331 | float Sensor::getMinValue() const { |
| 332 | return mMinValue; |
| 333 | } |
| 334 | |
| 335 | float Sensor::getMaxValue() const { |
| 336 | return mMaxValue; |
| 337 | } |
| 338 | |
| 339 | float Sensor::getResolution() const { |
| 340 | return mResolution; |
| 341 | } |
| 342 | |
| 343 | float Sensor::getPowerUsage() const { |
| 344 | return mPower; |
| 345 | } |
| 346 | |
Mathias Agopian | a48bcf6 | 2010-07-29 16:51:38 -0700 | [diff] [blame] | 347 | int32_t Sensor::getMinDelay() const { |
| 348 | return mMinDelay; |
| 349 | } |
| 350 | |
Mathias Agopian | b62013f | 2011-05-17 22:54:42 -0700 | [diff] [blame] | 351 | nsecs_t Sensor::getMinDelayNs() const { |
| 352 | return getMinDelay() * 1000; |
| 353 | } |
| 354 | |
| 355 | int32_t Sensor::getVersion() const { |
| 356 | return mVersion; |
| 357 | } |
| 358 | |
Dan Stoza | d723bd7 | 2014-11-18 10:24:03 -0800 | [diff] [blame] | 359 | uint32_t Sensor::getFifoReservedEventCount() const { |
Aravind Akella | 724d91d | 2013-06-27 12:04:23 -0700 | [diff] [blame] | 360 | return mFifoReservedEventCount; |
| 361 | } |
| 362 | |
Dan Stoza | d723bd7 | 2014-11-18 10:24:03 -0800 | [diff] [blame] | 363 | uint32_t Sensor::getFifoMaxEventCount() const { |
Aravind Akella | 724d91d | 2013-06-27 12:04:23 -0700 | [diff] [blame] | 364 | return mFifoMaxEventCount; |
| 365 | } |
| 366 | |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 367 | const String8& Sensor::getStringType() const { |
| 368 | return mStringType; |
| 369 | } |
| 370 | |
| 371 | const String8& Sensor::getRequiredPermission() const { |
| 372 | return mRequiredPermission; |
| 373 | } |
| 374 | |
Svetoslav | b412f6e | 2015-04-29 16:50:41 -0700 | [diff] [blame] | 375 | bool Sensor::isRequiredPermissionRuntime() const { |
| 376 | return mRequiredPermissionRuntime; |
| 377 | } |
| 378 | |
| 379 | int32_t Sensor::getRequiredAppOp() const { |
| 380 | return mRequiredAppOp; |
| 381 | } |
| 382 | |
Aravind Akella | d9441e4 | 2014-05-13 18:20:30 -0700 | [diff] [blame] | 383 | int32_t Sensor::getMaxDelay() const { |
| 384 | return mMaxDelay; |
| 385 | } |
| 386 | |
Dan Stoza | d723bd7 | 2014-11-18 10:24:03 -0800 | [diff] [blame] | 387 | uint32_t Sensor::getFlags() const { |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 388 | return mFlags; |
| 389 | } |
| 390 | |
Aravind Akella | 9a844cf | 2014-02-11 18:58:52 -0800 | [diff] [blame] | 391 | bool Sensor::isWakeUpSensor() const { |
Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 392 | return (mFlags & SENSOR_FLAG_WAKE_UP) != 0; |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 393 | } |
| 394 | |
Peng Xu | 0cc8f80 | 2016-04-05 23:46:03 -0700 | [diff] [blame] | 395 | bool Sensor::isDynamicSensor() const { |
Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 396 | return (mFlags & SENSOR_FLAG_DYNAMIC_SENSOR) != 0; |
| 397 | } |
| 398 | |
| 399 | bool Sensor::hasAdditionalInfo() const { |
| 400 | return (mFlags & SENSOR_FLAG_ADDITIONAL_INFO) != 0; |
Peng Xu | 0cc8f80 | 2016-04-05 23:46:03 -0700 | [diff] [blame] | 401 | } |
| 402 | |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 403 | int32_t Sensor::getReportingMode() const { |
| 404 | return ((mFlags & REPORTING_MODE_MASK) >> REPORTING_MODE_SHIFT); |
Aravind Akella | 9a844cf | 2014-02-11 18:58:52 -0800 | [diff] [blame] | 405 | } |
| 406 | |
Peng Xu | 2576cb6 | 2016-01-20 00:22:09 -0800 | [diff] [blame] | 407 | const Sensor::uuid_t& Sensor::getUuid() const { |
| 408 | return mUuid; |
| 409 | } |
| 410 | |
Greg Kaiser | 53ca2e0 | 2016-06-21 16:11:14 -0700 | [diff] [blame] | 411 | void Sensor::setId(int32_t id) { |
| 412 | mUuid.i64[0] = id; |
| 413 | mUuid.i64[1] = 0; |
| 414 | } |
| 415 | |
| 416 | int32_t Sensor::getId() const { |
| 417 | return int32_t(mUuid.i64[0]); |
| 418 | } |
| 419 | |
Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 420 | size_t Sensor::getFlattenedSize() const { |
Mathias Agopian | e142428 | 2013-07-29 21:24:40 -0700 | [diff] [blame] | 421 | size_t fixedSize = |
Peng Xu | 2576cb6 | 2016-01-20 00:22:09 -0800 | [diff] [blame] | 422 | sizeof(mVersion) + sizeof(mHandle) + sizeof(mType) + |
| 423 | sizeof(mMinValue) + sizeof(mMaxValue) + sizeof(mResolution) + |
| 424 | sizeof(mPower) + sizeof(mMinDelay) + sizeof(mFifoMaxEventCount) + |
| 425 | sizeof(mFifoMaxEventCount) + sizeof(mRequiredPermissionRuntime) + |
| 426 | sizeof(mRequiredAppOp) + sizeof(mMaxDelay) + sizeof(mFlags) + sizeof(mUuid); |
Mathias Agopian | e142428 | 2013-07-29 21:24:40 -0700 | [diff] [blame] | 427 | |
| 428 | size_t variableSize = |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 429 | sizeof(uint32_t) + FlattenableUtils::align<4>(mName.length()) + |
| 430 | sizeof(uint32_t) + FlattenableUtils::align<4>(mVendor.length()) + |
| 431 | sizeof(uint32_t) + FlattenableUtils::align<4>(mStringType.length()) + |
| 432 | sizeof(uint32_t) + FlattenableUtils::align<4>(mRequiredPermission.length()); |
Mathias Agopian | e142428 | 2013-07-29 21:24:40 -0700 | [diff] [blame] | 433 | |
| 434 | return fixedSize + variableSize; |
Mathias Agopian | 589ce85 | 2010-07-13 22:21:56 -0700 | [diff] [blame] | 435 | } |
| 436 | |
Mathias Agopian | e142428 | 2013-07-29 21:24:40 -0700 | [diff] [blame] | 437 | status_t Sensor::flatten(void* buffer, size_t size) const { |
| 438 | if (size < getFlattenedSize()) { |
| 439 | return NO_MEMORY; |
| 440 | } |
Mathias Agopian | 589ce85 | 2010-07-13 22:21:56 -0700 | [diff] [blame] | 441 | |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 442 | flattenString8(buffer, size, mName); |
| 443 | flattenString8(buffer, size, mVendor); |
Mathias Agopian | e142428 | 2013-07-29 21:24:40 -0700 | [diff] [blame] | 444 | FlattenableUtils::write(buffer, size, mVersion); |
| 445 | FlattenableUtils::write(buffer, size, mHandle); |
| 446 | FlattenableUtils::write(buffer, size, mType); |
| 447 | FlattenableUtils::write(buffer, size, mMinValue); |
| 448 | FlattenableUtils::write(buffer, size, mMaxValue); |
| 449 | FlattenableUtils::write(buffer, size, mResolution); |
| 450 | FlattenableUtils::write(buffer, size, mPower); |
| 451 | FlattenableUtils::write(buffer, size, mMinDelay); |
Aravind Akella | 724d91d | 2013-06-27 12:04:23 -0700 | [diff] [blame] | 452 | FlattenableUtils::write(buffer, size, mFifoReservedEventCount); |
| 453 | FlattenableUtils::write(buffer, size, mFifoMaxEventCount); |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 454 | flattenString8(buffer, size, mStringType); |
| 455 | flattenString8(buffer, size, mRequiredPermission); |
Svetoslav | b412f6e | 2015-04-29 16:50:41 -0700 | [diff] [blame] | 456 | FlattenableUtils::write(buffer, size, mRequiredPermissionRuntime); |
| 457 | FlattenableUtils::write(buffer, size, mRequiredAppOp); |
Aravind Akella | d9441e4 | 2014-05-13 18:20:30 -0700 | [diff] [blame] | 458 | FlattenableUtils::write(buffer, size, mMaxDelay); |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 459 | FlattenableUtils::write(buffer, size, mFlags); |
Greg Kaiser | 53ca2e0 | 2016-06-21 16:11:14 -0700 | [diff] [blame] | 460 | if (mUuid.i64[1] != 0) { |
| 461 | // We should never hit this case with our current API, but we |
| 462 | // could via a careless API change. If that happens, |
| 463 | // this code will keep us from leaking our UUID (while probably |
| 464 | // breaking dynamic sensors). See b/29547335. |
| 465 | ALOGW("Sensor with UUID being flattened; sending 0. Expect " |
| 466 | "bad dynamic sensor behavior"); |
| 467 | uuid_t tmpUuid; // default constructor makes this 0. |
| 468 | FlattenableUtils::write(buffer, size, tmpUuid); |
| 469 | } else { |
| 470 | FlattenableUtils::write(buffer, size, mUuid); |
| 471 | } |
Mathias Agopian | 589ce85 | 2010-07-13 22:21:56 -0700 | [diff] [blame] | 472 | return NO_ERROR; |
| 473 | } |
| 474 | |
Mathias Agopian | e142428 | 2013-07-29 21:24:40 -0700 | [diff] [blame] | 475 | status_t Sensor::unflatten(void const* buffer, size_t size) { |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 476 | if (!unflattenString8(buffer, size, mName)) { |
Mathias Agopian | e142428 | 2013-07-29 21:24:40 -0700 | [diff] [blame] | 477 | return NO_MEMORY; |
| 478 | } |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 479 | if (!unflattenString8(buffer, size, mVendor)) { |
Mathias Agopian | e142428 | 2013-07-29 21:24:40 -0700 | [diff] [blame] | 480 | return NO_MEMORY; |
| 481 | } |
Mathias Agopian | e142428 | 2013-07-29 21:24:40 -0700 | [diff] [blame] | 482 | |
Peng Xu | 2576cb6 | 2016-01-20 00:22:09 -0800 | [diff] [blame] | 483 | size_t fixedSize1 = |
| 484 | sizeof(mVersion) + sizeof(mHandle) + sizeof(mType) + sizeof(mMinValue) + |
| 485 | sizeof(mMaxValue) + sizeof(mResolution) + sizeof(mPower) + sizeof(mMinDelay) + |
| 486 | sizeof(mFifoMaxEventCount) + sizeof(mFifoMaxEventCount); |
| 487 | if (size < fixedSize1) { |
Mathias Agopian | e142428 | 2013-07-29 21:24:40 -0700 | [diff] [blame] | 488 | return NO_MEMORY; |
| 489 | } |
| 490 | |
| 491 | FlattenableUtils::read(buffer, size, mVersion); |
| 492 | FlattenableUtils::read(buffer, size, mHandle); |
| 493 | FlattenableUtils::read(buffer, size, mType); |
| 494 | FlattenableUtils::read(buffer, size, mMinValue); |
| 495 | FlattenableUtils::read(buffer, size, mMaxValue); |
| 496 | FlattenableUtils::read(buffer, size, mResolution); |
| 497 | FlattenableUtils::read(buffer, size, mPower); |
| 498 | FlattenableUtils::read(buffer, size, mMinDelay); |
Aravind Akella | 724d91d | 2013-06-27 12:04:23 -0700 | [diff] [blame] | 499 | FlattenableUtils::read(buffer, size, mFifoReservedEventCount); |
| 500 | FlattenableUtils::read(buffer, size, mFifoMaxEventCount); |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 501 | |
| 502 | if (!unflattenString8(buffer, size, mStringType)) { |
| 503 | return NO_MEMORY; |
| 504 | } |
| 505 | if (!unflattenString8(buffer, size, mRequiredPermission)) { |
| 506 | return NO_MEMORY; |
| 507 | } |
Peng Xu | 2576cb6 | 2016-01-20 00:22:09 -0800 | [diff] [blame] | 508 | |
| 509 | size_t fixedSize2 = |
| 510 | sizeof(mRequiredPermissionRuntime) + sizeof(mRequiredAppOp) + sizeof(mMaxDelay) + |
| 511 | sizeof(mFlags) + sizeof(mUuid); |
| 512 | if (size < fixedSize2) { |
| 513 | return NO_MEMORY; |
| 514 | } |
| 515 | |
Svetoslav | b412f6e | 2015-04-29 16:50:41 -0700 | [diff] [blame] | 516 | FlattenableUtils::read(buffer, size, mRequiredPermissionRuntime); |
| 517 | FlattenableUtils::read(buffer, size, mRequiredAppOp); |
Aravind Akella | d9441e4 | 2014-05-13 18:20:30 -0700 | [diff] [blame] | 518 | FlattenableUtils::read(buffer, size, mMaxDelay); |
Aravind Akella | 0e025c5 | 2014-06-03 19:19:57 -0700 | [diff] [blame] | 519 | FlattenableUtils::read(buffer, size, mFlags); |
Peng Xu | 2576cb6 | 2016-01-20 00:22:09 -0800 | [diff] [blame] | 520 | FlattenableUtils::read(buffer, size, mUuid); |
Mathias Agopian | 589ce85 | 2010-07-13 22:21:56 -0700 | [diff] [blame] | 521 | return NO_ERROR; |
| 522 | } |
| 523 | |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 524 | void Sensor::flattenString8(void*& buffer, size_t& size, |
| 525 | const String8& string8) { |
Dan Stoza | d723bd7 | 2014-11-18 10:24:03 -0800 | [diff] [blame] | 526 | uint32_t len = static_cast<uint32_t>(string8.length()); |
Aravind Akella | 7001804 | 2014-04-07 22:52:37 +0000 | [diff] [blame] | 527 | FlattenableUtils::write(buffer, size, len); |
| 528 | memcpy(static_cast<char*>(buffer), string8.string(), len); |
| 529 | FlattenableUtils::advance(buffer, size, FlattenableUtils::align<4>(len)); |
| 530 | } |
| 531 | |
| 532 | bool Sensor::unflattenString8(void const*& buffer, size_t& size, String8& outputString8) { |
| 533 | uint32_t len; |
| 534 | if (size < sizeof(len)) { |
| 535 | return false; |
| 536 | } |
| 537 | FlattenableUtils::read(buffer, size, len); |
| 538 | if (size < len) { |
| 539 | return false; |
| 540 | } |
| 541 | outputString8.setTo(static_cast<char const*>(buffer), len); |
| 542 | FlattenableUtils::advance(buffer, size, FlattenableUtils::align<4>(len)); |
| 543 | return true; |
| 544 | } |
| 545 | |
Mathias Agopian | 589ce85 | 2010-07-13 22:21:56 -0700 | [diff] [blame] | 546 | // ---------------------------------------------------------------------------- |
| 547 | }; // namespace android |