| Mathias Agopian | fc32881 | 2010-07-14 23:41:37 -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 |  | 
|  | 17 | #ifndef ANDROID_SENSOR_SERVICE_H | 
|  | 18 | #define ANDROID_SENSOR_SERVICE_H | 
|  | 19 |  | 
| Peng Xu | 755c451 | 2016-04-07 23:15:14 -0700 | [diff] [blame] | 20 | #include "SensorList.h" | 
| Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 21 | #include "RecentEventLogger.h" | 
| Mathias Agopian | fc32881 | 2010-07-14 23:41:37 -0700 | [diff] [blame] | 22 |  | 
| Brian Duddie | 967ce17 | 2019-06-10 11:08:27 -0700 | [diff] [blame] | 23 | #include <android-base/macros.h> | 
| Brian Stack | 793f464 | 2019-04-18 17:21:34 -0700 | [diff] [blame] | 24 | #include <binder/AppOpsManager.h> | 
| Mathias Agopian | fc32881 | 2010-07-14 23:41:37 -0700 | [diff] [blame] | 25 | #include <binder/BinderService.h> | 
| Svet Ganov | e752a5c | 2018-01-15 17:14:20 -0800 | [diff] [blame] | 26 | #include <binder/IUidObserver.h> | 
| Peng Xu | 755c451 | 2016-04-07 23:15:14 -0700 | [diff] [blame] | 27 | #include <cutils/compiler.h> | 
| Tanmay Patil | d33a182 | 2019-04-11 18:38:55 -0700 | [diff] [blame] | 28 | #include <cutils/multiuser.h> | 
| Mathias Agopian | 801ea09 | 2017-03-06 15:05:04 -0800 | [diff] [blame] | 29 | #include <sensor/ISensorServer.h> | 
|  | 30 | #include <sensor/ISensorEventConnection.h> | 
|  | 31 | #include <sensor/Sensor.h> | 
| Michael Groover | 5e1f60b | 2018-12-04 22:34:29 -0800 | [diff] [blame] | 32 | #include "android/hardware/BnSensorPrivacyListener.h" | 
| Mathias Agopian | fc32881 | 2010-07-14 23:41:37 -0700 | [diff] [blame] | 33 |  | 
| Peng Xu | 755c451 | 2016-04-07 23:15:14 -0700 | [diff] [blame] | 34 | #include <utils/AndroidThreads.h> | 
|  | 35 | #include <utils/KeyedVector.h> | 
|  | 36 | #include <utils/Looper.h> | 
|  | 37 | #include <utils/SortedVector.h> | 
|  | 38 | #include <utils/String8.h> | 
|  | 39 | #include <utils/Vector.h> | 
|  | 40 | #include <utils/threads.h> | 
|  | 41 |  | 
|  | 42 | #include <stdint.h> | 
|  | 43 | #include <sys/types.h> | 
| Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 44 | #include <unordered_map> | 
| Peng Xu | 755c451 | 2016-04-07 23:15:14 -0700 | [diff] [blame] | 45 | #include <unordered_set> | 
| Brian Duddie | 967ce17 | 2019-06-10 11:08:27 -0700 | [diff] [blame] | 46 | #include <vector> | 
| Mathias Agopian | f001c92 | 2010-11-11 17:58:51 -0800 | [diff] [blame] | 47 |  | 
| Bernhard Rosenkränzer | 72952ef | 2014-11-17 21:03:39 +0100 | [diff] [blame] | 48 | #if __clang__ | 
| Peng Xu | eb4d628 | 2015-12-10 18:02:41 -0800 | [diff] [blame] | 49 | // Clang warns about SensorEventConnection::dump hiding BBinder::dump. The cause isn't fixable | 
|  | 50 | // without changing the API, so let's tell clang this is indeed intentional. | 
| Bernhard Rosenkränzer | 72952ef | 2014-11-17 21:03:39 +0100 | [diff] [blame] | 51 | #pragma clang diagnostic ignored "-Woverloaded-virtual" | 
|  | 52 | #endif | 
|  | 53 |  | 
| Mathias Agopian | fc32881 | 2010-07-14 23:41:37 -0700 | [diff] [blame] | 54 | // --------------------------------------------------------------------------- | 
| Peng Xu | f66684a | 2015-07-23 11:41:53 -0700 | [diff] [blame] | 55 | #define IGNORE_HARDWARE_FUSION  false | 
| Mathias Agopian | a1b7db9 | 2011-05-27 16:23:58 -0700 | [diff] [blame] | 56 | #define DEBUG_CONNECTIONS   false | 
| Aravind Akella | 56ae426 | 2014-07-10 16:01:10 -0700 | [diff] [blame] | 57 | // Max size is 100 KB which is enough to accept a batch of about 1000 events. | 
| Chih-Hung Hsieh | a389c7a | 2016-05-20 11:40:04 -0700 | [diff] [blame] | 58 | #define MAX_SOCKET_BUFFER_SIZE_BATCHED (100 * 1024) | 
| Aravind Akella | 56ae426 | 2014-07-10 16:01:10 -0700 | [diff] [blame] | 59 | // For older HALs which don't support batching, use a smaller socket buffer size. | 
| Chih-Hung Hsieh | a389c7a | 2016-05-20 11:40:04 -0700 | [diff] [blame] | 60 | #define SOCKET_BUFFER_SIZE_NON_BATCHED (4 * 1024) | 
| Mathias Agopian | a1b7db9 | 2011-05-27 16:23:58 -0700 | [diff] [blame] | 61 |  | 
| Peng Xu | 363b3fd | 2016-07-07 15:40:08 -0700 | [diff] [blame] | 62 | #define SENSOR_REGISTRATIONS_BUF_SIZE 200 | 
| Aravind Akella | 444f267 | 2015-05-07 12:40:52 -0700 | [diff] [blame] | 63 |  | 
| Anh Pham | af91a91 | 2021-02-10 14:10:53 +0100 | [diff] [blame] | 64 | // Apps that targets S+ and do not have HIGH_SAMPLING_RATE_SENSORS permission will be capped | 
| Anh Pham | 5198c99 | 2021-02-10 14:15:30 +0100 | [diff] [blame] | 65 | // at 200 Hz. The cap also applies to all requests when the mic toggle is flipped to on, regardless | 
|  | 66 | // of their target SDKs and permission. | 
| Anh Pham | af91a91 | 2021-02-10 14:10:53 +0100 | [diff] [blame] | 67 | // Capped sampling periods for apps that have non-direct sensor connections. | 
|  | 68 | #define SENSOR_SERVICE_CAPPED_SAMPLING_PERIOD_NS (5 * 1000 * 1000) | 
|  | 69 | // Capped sampling rate level for apps that have direct sensor connections. | 
|  | 70 | // The enum SENSOR_DIRECT_RATE_NORMAL corresponds to a rate value of at most 110 Hz. | 
|  | 71 | #define SENSOR_SERVICE_CAPPED_SAMPLING_RATE_LEVEL SENSOR_DIRECT_RATE_NORMAL | 
|  | 72 |  | 
| Mathias Agopian | fc32881 | 2010-07-14 23:41:37 -0700 | [diff] [blame] | 73 | namespace android { | 
|  | 74 | // --------------------------------------------------------------------------- | 
| Peng Xu | 755c451 | 2016-04-07 23:15:14 -0700 | [diff] [blame] | 75 | class SensorInterface; | 
| Mathias Agopian | fc32881 | 2010-07-14 23:41:37 -0700 | [diff] [blame] | 76 |  | 
|  | 77 | class SensorService : | 
|  | 78 | public BinderService<SensorService>, | 
|  | 79 | public BnSensorServer, | 
|  | 80 | protected Thread | 
|  | 81 | { | 
| Peng Xu | eb4d628 | 2015-12-10 18:02:41 -0800 | [diff] [blame] | 82 | // nested class/struct for internal use | 
|  | 83 | class SensorEventConnection; | 
| Peng Xu | e36e347 | 2016-11-03 11:57:10 -0700 | [diff] [blame] | 84 | class SensorDirectConnection; | 
| Peng Xu | eb4d628 | 2015-12-10 18:02:41 -0800 | [diff] [blame] | 85 |  | 
|  | 86 | public: | 
| Arthur Ishiguro | 539c27c | 2020-04-13 09:47:59 -0700 | [diff] [blame] | 87 | enum UidState { | 
|  | 88 | UID_STATE_ACTIVE = 0, | 
|  | 89 | UID_STATE_IDLE, | 
|  | 90 | }; | 
|  | 91 |  | 
| Arthur Ishiguro | 5e3eaa8 | 2021-11-11 18:05:56 +0000 | [diff] [blame] | 92 | enum Mode { | 
|  | 93 | // The regular operating mode where any application can register/unregister/call flush on | 
|  | 94 | // sensors. | 
|  | 95 | NORMAL = 0, | 
|  | 96 | // This mode is only used for testing purposes. Not all HALs support this mode. In this mode, | 
|  | 97 | // the HAL ignores the sensor data provided by physical sensors and accepts the data that is | 
|  | 98 | // injected from the SensorService as if it were the real sensor data. This mode is primarily | 
|  | 99 | // used for testing various algorithms like vendor provided SensorFusion, Step Counter and | 
|  | 100 | // Step Detector etc. Typically in this mode, there will be a client (a | 
|  | 101 | // SensorEventConnection) which will be injecting sensor data into the HAL. Normal apps can | 
|  | 102 | // unregister and register for any sensor that supports injection. Registering to sensors | 
|  | 103 | // that do not support injection will give an error.  TODO: Allow exactly one | 
|  | 104 | // client to inject sensor data at a time. | 
|  | 105 | DATA_INJECTION = 1, | 
|  | 106 | // This mode is used only for testing sensors. Each sensor can be tested in isolation with | 
|  | 107 | // the required sampling_rate and maxReportLatency parameters without having to think about | 
|  | 108 | // the data rates requested by other applications. End user devices are always expected to be | 
|  | 109 | // in NORMAL mode. When this mode is first activated, all active sensors from all connections | 
|  | 110 | // are disabled. Calling flush() will return an error. In this mode, only the requests from | 
|  | 111 | // selected apps whose package names are allowlisted are allowed (typically CTS apps).  Only | 
|  | 112 | // these apps can register/unregister/call flush() on sensors. If SensorService switches to | 
|  | 113 | // NORMAL mode again, all sensors that were previously registered to are activated with the | 
|  | 114 | // corresponding parameters if the application hasn't unregistered for sensors in the mean | 
|  | 115 | // time.  NOTE: Non allowlisted app whose sensors were previously deactivated may still | 
|  | 116 | // receive events if a allowlisted app requests data from the same sensor. | 
|  | 117 | RESTRICTED = 2 | 
|  | 118 |  | 
|  | 119 | // State Transitions supported. | 
|  | 120 | //     RESTRICTED   <---  NORMAL   ---> DATA_INJECTION | 
|  | 121 | //                  --->           <--- | 
|  | 122 |  | 
|  | 123 | // Shell commands to switch modes in SensorService. | 
|  | 124 | // 1) Put SensorService in RESTRICTED mode with packageName .cts. If it is already in | 
|  | 125 | // restricted mode it is treated as a NO_OP (and packageName is NOT changed). | 
|  | 126 | // | 
|  | 127 | //     $ adb shell dumpsys sensorservice restrict .cts. | 
|  | 128 | // | 
|  | 129 | // 2) Put SensorService in DATA_INJECTION mode with packageName .xts. If it is already in | 
|  | 130 | // data_injection mode it is treated as a NO_OP (and packageName is NOT changed). | 
|  | 131 | // | 
|  | 132 | //     $ adb shell dumpsys sensorservice data_injection .xts. | 
|  | 133 | // | 
|  | 134 | // 3) Reset sensorservice back to NORMAL mode. | 
|  | 135 | //     $ adb shell dumpsys sensorservice enable | 
|  | 136 | }; | 
|  | 137 |  | 
| Andrew Lehmer | 3a60257 | 2021-03-25 15:19:56 -0700 | [diff] [blame] | 138 | class ProximityActiveListener : public virtual RefBase { | 
|  | 139 | public: | 
|  | 140 | // Note that the callback is invoked from an async thread and can interact with the | 
|  | 141 | // SensorService directly. | 
|  | 142 | virtual void onProximityActive(bool isActive) = 0; | 
|  | 143 | }; | 
|  | 144 |  | 
|  | 145 | static char const* getServiceName() ANDROID_API { return "sensorservice"; } | 
|  | 146 | SensorService() ANDROID_API; | 
|  | 147 |  | 
| Peng Xu | eb4d628 | 2015-12-10 18:02:41 -0800 | [diff] [blame] | 148 | void cleanupConnection(SensorEventConnection* connection); | 
| Peng Xu | e36e347 | 2016-11-03 11:57:10 -0700 | [diff] [blame] | 149 | void cleanupConnection(SensorDirectConnection* c); | 
| Peng Xu | eb4d628 | 2015-12-10 18:02:41 -0800 | [diff] [blame] | 150 |  | 
| Andrew Lehmer | 3a60257 | 2021-03-25 15:19:56 -0700 | [diff] [blame] | 151 | // Call with mLock held. | 
| Chris Kuiper | df11ff2 | 2021-10-12 16:30:01 -0700 | [diff] [blame] | 152 | void checkAndReportProxStateChangeLocked(); | 
|  | 153 | void notifyProximityStateLocked(const bool isActive, | 
|  | 154 | const std::vector<sp<ProximityActiveListener>>& listeners); | 
| Andrew Lehmer | 3a60257 | 2021-03-25 15:19:56 -0700 | [diff] [blame] | 155 |  | 
| Peng Xu | eb4d628 | 2015-12-10 18:02:41 -0800 | [diff] [blame] | 156 | status_t enable(const sp<SensorEventConnection>& connection, int handle, | 
|  | 157 | nsecs_t samplingPeriodNs,  nsecs_t maxBatchReportLatencyNs, int reservedFlags, | 
|  | 158 | const String16& opPackageName); | 
|  | 159 |  | 
|  | 160 | status_t disable(const sp<SensorEventConnection>& connection, int handle); | 
|  | 161 |  | 
|  | 162 | status_t setEventRate(const sp<SensorEventConnection>& connection, int handle, nsecs_t ns, | 
|  | 163 | const String16& opPackageName); | 
|  | 164 |  | 
|  | 165 | status_t flushSensor(const sp<SensorEventConnection>& connection, | 
|  | 166 | const String16& opPackageName); | 
|  | 167 |  | 
| Andrew Lehmer | 3a60257 | 2021-03-25 15:19:56 -0700 | [diff] [blame] | 168 | status_t addProximityActiveListener(const sp<ProximityActiveListener>& callback) ANDROID_API; | 
|  | 169 | status_t removeProximityActiveListener(const sp<ProximityActiveListener>& callback) ANDROID_API; | 
|  | 170 |  | 
| Anh Pham | af91a91 | 2021-02-10 14:10:53 +0100 | [diff] [blame] | 171 | // Returns true if a sensor should be throttled according to our rate-throttling rules. | 
|  | 172 | static bool isSensorInCappedSet(int sensorType); | 
| Svet Ganov | e752a5c | 2018-01-15 17:14:20 -0800 | [diff] [blame] | 173 |  | 
|  | 174 | virtual status_t shellCommand(int in, int out, int err, Vector<String16>& args); | 
|  | 175 |  | 
| Peng Xu | eb4d628 | 2015-12-10 18:02:41 -0800 | [diff] [blame] | 176 | private: | 
| Mathias Agopian | b6df7d0 | 2013-05-09 14:53:35 -0700 | [diff] [blame] | 177 | friend class BinderService<SensorService>; | 
| Mathias Agopian | fc32881 | 2010-07-14 23:41:37 -0700 | [diff] [blame] | 178 |  | 
| Peng Xu | eb4d628 | 2015-12-10 18:02:41 -0800 | [diff] [blame] | 179 | // nested class/struct for internal use | 
| Brian Duddie | 967ce17 | 2019-06-10 11:08:27 -0700 | [diff] [blame] | 180 | class ConnectionSafeAutolock; | 
|  | 181 | class SensorConnectionHolder; | 
| Peng Xu | eb4d628 | 2015-12-10 18:02:41 -0800 | [diff] [blame] | 182 | class SensorEventAckReceiver; | 
| Brian Duddie | 967ce17 | 2019-06-10 11:08:27 -0700 | [diff] [blame] | 183 | class SensorRecord; | 
| Peng Xu | 5122468 | 2017-03-10 16:57:27 -0800 | [diff] [blame] | 184 | class SensorRegistrationInfo; | 
| Peng Xu | eb4d628 | 2015-12-10 18:02:41 -0800 | [diff] [blame] | 185 |  | 
| Brian Duddie | 967ce17 | 2019-06-10 11:08:27 -0700 | [diff] [blame] | 186 | // Promoting a SensorEventConnection or SensorDirectConnection from wp to sp must be done with | 
|  | 187 | // mLock held, but destroying that sp must be done unlocked to avoid a race condition that | 
|  | 188 | // causes a deadlock (remote dies while we hold a local sp, then our decStrong() call invokes | 
|  | 189 | // the dtor -> cleanupConnection() tries to re-lock the mutex). This class ensures safe usage | 
|  | 190 | // by wrapping a Mutex::Autolock on SensorService's mLock, plus vectors that hold promoted sp<> | 
|  | 191 | // references until the lock is released, when they are safely destroyed. | 
|  | 192 | // All read accesses to the connection lists in mConnectionHolder must be done via this class. | 
|  | 193 | class ConnectionSafeAutolock final { | 
|  | 194 | public: | 
|  | 195 | // Returns a list of non-null promoted connection references | 
|  | 196 | const std::vector<sp<SensorEventConnection>>& getActiveConnections(); | 
|  | 197 | const std::vector<sp<SensorDirectConnection>>& getDirectConnections(); | 
|  | 198 |  | 
|  | 199 | private: | 
|  | 200 | // Constructed via SensorConnectionHolder::lock() | 
|  | 201 | friend class SensorConnectionHolder; | 
|  | 202 | explicit ConnectionSafeAutolock(SensorConnectionHolder& holder, Mutex& mutex); | 
|  | 203 | DISALLOW_IMPLICIT_CONSTRUCTORS(ConnectionSafeAutolock); | 
|  | 204 |  | 
|  | 205 | // NOTE: Order of these members is important, as the destructor for non-static members | 
|  | 206 | // get invoked in the reverse order of their declaration. Here we are relying on the | 
|  | 207 | // Autolock to be destroyed *before* the vectors, so the sp<> objects are destroyed without | 
|  | 208 | // the lock held, which avoids the deadlock. | 
|  | 209 | SensorConnectionHolder& mConnectionHolder; | 
|  | 210 | std::vector<std::vector<sp<SensorEventConnection>>> mReferencedActiveConnections; | 
|  | 211 | std::vector<std::vector<sp<SensorDirectConnection>>> mReferencedDirectConnections; | 
|  | 212 | Mutex::Autolock mAutolock; | 
|  | 213 |  | 
|  | 214 | template<typename ConnectionType> | 
|  | 215 | const std::vector<sp<ConnectionType>>& getConnectionsHelper( | 
|  | 216 | const SortedVector<wp<ConnectionType>>& connectionList, | 
|  | 217 | std::vector<std::vector<sp<ConnectionType>>>* referenceHolder); | 
|  | 218 | }; | 
|  | 219 |  | 
|  | 220 | // Encapsulates the collection of active SensorEventConection and SensorDirectConnection | 
|  | 221 | // references. Write access is done through this class with mLock held, but all read access | 
|  | 222 | // must be routed through ConnectionSafeAutolock. | 
|  | 223 | class SensorConnectionHolder { | 
|  | 224 | public: | 
|  | 225 | void addEventConnectionIfNotPresent(const sp<SensorEventConnection>& connection); | 
|  | 226 | void removeEventConnection(const wp<SensorEventConnection>& connection); | 
|  | 227 |  | 
|  | 228 | void addDirectConnection(const sp<SensorDirectConnection>& connection); | 
|  | 229 | void removeDirectConnection(const wp<SensorDirectConnection>& connection); | 
|  | 230 |  | 
|  | 231 | // Pass in the mutex that protects this connection holder; acquires the lock and returns an | 
|  | 232 | // object that can be used to safely read the lists of connections | 
|  | 233 | ConnectionSafeAutolock lock(Mutex& mutex); | 
|  | 234 |  | 
|  | 235 | private: | 
|  | 236 | friend class ConnectionSafeAutolock; | 
|  | 237 | SortedVector< wp<SensorEventConnection> > mActiveConnections; | 
|  | 238 | SortedVector< wp<SensorDirectConnection> > mDirectConnections; | 
|  | 239 | }; | 
|  | 240 |  | 
| Svet Ganov | e752a5c | 2018-01-15 17:14:20 -0800 | [diff] [blame] | 241 | // If accessing a sensor we need to make sure the UID has access to it. If | 
|  | 242 | // the app UID is idle then it cannot access sensors and gets no trigger | 
|  | 243 | // events, no on-change events, flush event behavior does not change, and | 
|  | 244 | // recurring events are the same as the first one delivered in idle state | 
|  | 245 | // emulating no sensor change. As soon as the app UID transitions to an | 
|  | 246 | // active state we will start reporting events as usual and vise versa. This | 
|  | 247 | // approach transparently handles observing sensors while the app UID transitions | 
|  | 248 | // between idle/active state avoiding to get stuck in a state receiving sensor | 
|  | 249 | // data while idle or not receiving sensor data while active. | 
|  | 250 | class UidPolicy : public BnUidObserver { | 
|  | 251 | public: | 
|  | 252 | explicit UidPolicy(wp<SensorService> service) | 
|  | 253 | : mService(service) {} | 
|  | 254 | void registerSelf(); | 
|  | 255 | void unregisterSelf(); | 
|  | 256 |  | 
|  | 257 | bool isUidActive(uid_t uid); | 
|  | 258 |  | 
|  | 259 | void onUidGone(uid_t uid, bool disabled); | 
|  | 260 | void onUidActive(uid_t uid); | 
|  | 261 | void onUidIdle(uid_t uid, bool disabled); | 
| Eric Laurent | 0559589 | 2018-10-18 14:56:24 -0700 | [diff] [blame] | 262 | void onUidStateChanged(uid_t uid __unused, int32_t procState __unused, | 
| Hui Yu | ee03b78 | 2019-08-22 14:48:40 -0700 | [diff] [blame] | 263 | int64_t procStateSeq __unused, int32_t capability __unused) {} | 
| Svet Ganov | e752a5c | 2018-01-15 17:14:20 -0800 | [diff] [blame] | 264 |  | 
|  | 265 | void addOverrideUid(uid_t uid, bool active); | 
|  | 266 | void removeOverrideUid(uid_t uid); | 
|  | 267 | private: | 
|  | 268 | bool isUidActiveLocked(uid_t uid); | 
|  | 269 | void updateOverrideUid(uid_t uid, bool active, bool insert); | 
|  | 270 |  | 
|  | 271 | Mutex mUidLock; | 
|  | 272 | wp<SensorService> mService; | 
|  | 273 | std::unordered_set<uid_t> mActiveUids; | 
|  | 274 | std::unordered_map<uid_t, bool> mOverrideUids; | 
|  | 275 | }; | 
|  | 276 |  | 
| Arthur Ishiguro | 539c27c | 2020-04-13 09:47:59 -0700 | [diff] [blame] | 277 | bool isUidActive(uid_t uid); | 
|  | 278 |  | 
| Michael Groover | 5e1f60b | 2018-12-04 22:34:29 -0800 | [diff] [blame] | 279 | // Sensor privacy allows a user to disable access to all sensors on the device. When | 
|  | 280 | // enabled sensor privacy will prevent all apps, including active apps, from accessing | 
|  | 281 | // sensors, they will not receive trigger nor on-change events, flush event behavior | 
|  | 282 | // does not change, and recurring events are the same as the first one delivered when | 
|  | 283 | // sensor privacy was enabled. All sensor direct connections will be stopped as well | 
|  | 284 | // and new direct connections will not be allowed while sensor privacy is enabled. | 
|  | 285 | // Once sensor privacy is disabled access to sensors will be restored for active | 
|  | 286 | // apps, previously stopped direct connections will be restarted, and new direct | 
|  | 287 | // connections will be allowed again. | 
|  | 288 | class SensorPrivacyPolicy : public hardware::BnSensorPrivacyListener { | 
|  | 289 | public: | 
| Greg Kaiser | 1706759 | 2021-02-17 22:05:25 -0800 | [diff] [blame] | 290 | explicit SensorPrivacyPolicy(wp<SensorService> service) | 
|  | 291 | : mService(service), mIsIndividualMic(false), mUserId(0) {} | 
| Michael Groover | 5e1f60b | 2018-12-04 22:34:29 -0800 | [diff] [blame] | 292 | void registerSelf(); | 
|  | 293 | void unregisterSelf(); | 
|  | 294 |  | 
| Anh Pham | 5198c99 | 2021-02-10 14:15:30 +0100 | [diff] [blame] | 295 | status_t registerSelfForIndividual(int userId); | 
|  | 296 |  | 
| Michael Groover | 5e1f60b | 2018-12-04 22:34:29 -0800 | [diff] [blame] | 297 | bool isSensorPrivacyEnabled(); | 
|  | 298 |  | 
|  | 299 | binder::Status onSensorPrivacyChanged(bool enabled); | 
|  | 300 |  | 
|  | 301 | private: | 
|  | 302 | wp<SensorService> mService; | 
| Anh Pham | 5198c99 | 2021-02-10 14:15:30 +0100 | [diff] [blame] | 303 | Mutex mSensorPrivacyLock; | 
| Michael Groover | 5e1f60b | 2018-12-04 22:34:29 -0800 | [diff] [blame] | 304 | std::atomic_bool mSensorPrivacyEnabled; | 
| Anh Pham | 5198c99 | 2021-02-10 14:15:30 +0100 | [diff] [blame] | 305 | bool mIsIndividualMic; | 
|  | 306 | userid_t mUserId; | 
| Michael Groover | 5e1f60b | 2018-12-04 22:34:29 -0800 | [diff] [blame] | 307 | }; | 
|  | 308 |  | 
| Anh Pham | b04658b | 2021-03-22 18:17:17 +0100 | [diff] [blame] | 309 | // A class automatically clearing and restoring binder caller identity inside | 
|  | 310 | // a code block (scoped variable). | 
|  | 311 | // Declare one systematically before calling SensorPrivacyManager methods so that they are | 
|  | 312 | // executed with the same level of privilege as the SensorService process. | 
|  | 313 | class AutoCallerClear { | 
|  | 314 | public: | 
|  | 315 | AutoCallerClear() : | 
|  | 316 | mToken(IPCThreadState::self()->clearCallingIdentity()) {} | 
|  | 317 | ~AutoCallerClear() { | 
|  | 318 | IPCThreadState::self()->restoreCallingIdentity(mToken); | 
|  | 319 | } | 
|  | 320 |  | 
|  | 321 | private: | 
|  | 322 | const int64_t mToken; | 
|  | 323 | }; | 
|  | 324 |  | 
| Mathias Agopian | b6df7d0 | 2013-05-09 14:53:35 -0700 | [diff] [blame] | 325 | static const char* WAKE_LOCK_NAME; | 
| Mathias Agopian | fc32881 | 2010-07-14 23:41:37 -0700 | [diff] [blame] | 326 | virtual ~SensorService(); | 
|  | 327 |  | 
|  | 328 | virtual void onFirstRef(); | 
|  | 329 |  | 
|  | 330 | // Thread interface | 
|  | 331 | virtual bool threadLoop(); | 
|  | 332 |  | 
|  | 333 | // ISensorServer interface | 
| Svetoslav | b412f6e | 2015-04-29 16:50:41 -0700 | [diff] [blame] | 334 | virtual Vector<Sensor> getSensorList(const String16& opPackageName); | 
| Peng Xu | 2576cb6 | 2016-01-20 00:22:09 -0800 | [diff] [blame] | 335 | virtual Vector<Sensor> getDynamicSensorList(const String16& opPackageName); | 
| Peng Xu | eb4d628 | 2015-12-10 18:02:41 -0800 | [diff] [blame] | 336 | virtual sp<ISensorEventConnection> createSensorEventConnection( | 
|  | 337 | const String8& packageName, | 
| Arthur Ishiguro | 340882c | 2021-02-18 15:17:44 -0800 | [diff] [blame] | 338 | int requestedMode, const String16& opPackageName, const String16& attributionTag); | 
| Aravind Akella | 5c53805 | 2015-06-29 12:37:48 -0700 | [diff] [blame] | 339 | virtual int isDataInjectionEnabled(); | 
| Peng Xu | e36e347 | 2016-11-03 11:57:10 -0700 | [diff] [blame] | 340 | virtual sp<ISensorEventConnection> createSensorDirectConnection(const String16& opPackageName, | 
|  | 341 | uint32_t size, int32_t type, int32_t format, const native_handle *resource); | 
| Peng Xu | dd5c5cb | 2017-03-16 17:39:43 -0700 | [diff] [blame] | 342 | virtual int setOperationParameter( | 
| Alexey Polyudov | 88711e8 | 2017-05-23 19:54:04 -0700 | [diff] [blame] | 343 | int32_t handle, int32_t type, const Vector<float> &floats, const Vector<int32_t> &ints); | 
| Mathias Agopian | fc32881 | 2010-07-14 23:41:37 -0700 | [diff] [blame] | 344 | virtual status_t dump(int fd, const Vector<String16>& args); | 
| Andrew Lehmer | 3a60257 | 2021-03-25 15:19:56 -0700 | [diff] [blame] | 345 |  | 
| Mike Ma | 2474386 | 2020-01-29 00:36:55 -0800 | [diff] [blame] | 346 | status_t dumpProtoLocked(int fd, ConnectionSafeAutolock* connLock) const; | 
| Mathias Agopian | f001c92 | 2010-11-11 17:58:51 -0800 | [diff] [blame] | 347 | String8 getSensorName(int handle) const; | 
| Arthur Ishiguro | 883748c | 2020-10-28 13:18:02 -0700 | [diff] [blame] | 348 | String8 getSensorStringType(int handle) const; | 
| Aravind Akella | b4099e7 | 2013-10-15 15:43:10 -0700 | [diff] [blame] | 349 | bool isVirtualSensor(int handle) const; | 
| Peng Xu | 755c451 | 2016-04-07 23:15:14 -0700 | [diff] [blame] | 350 | sp<SensorInterface> getSensorInterfaceFromHandle(int handle) const; | 
| Aravind Akella | 9a844cf | 2014-02-11 18:58:52 -0800 | [diff] [blame] | 351 | bool isWakeUpSensor(int type) const; | 
| Aravind Akella | 0ec2066 | 2014-09-14 17:29:48 -0700 | [diff] [blame] | 352 | void recordLastValueLocked(sensors_event_t const* buffer, size_t count); | 
| Mathias Agopian | f001c92 | 2010-11-11 17:58:51 -0800 | [diff] [blame] | 353 | static void sortEventBuffer(sensors_event_t* buffer, size_t count); | 
| Peng Xu | 0cc8f80 | 2016-04-05 23:46:03 -0700 | [diff] [blame] | 354 | const Sensor& registerSensor(SensorInterface* sensor, | 
|  | 355 | bool isDebug = false, bool isVirtual = false); | 
|  | 356 | const Sensor& registerVirtualSensor(SensorInterface* sensor, bool isDebug = false); | 
| Peng Xu | 6a2d3a0 | 2015-12-21 12:00:23 -0800 | [diff] [blame] | 357 | const Sensor& registerDynamicSensorLocked(SensorInterface* sensor, bool isDebug = false); | 
|  | 358 | bool unregisterDynamicSensorLocked(int handle); | 
| Peng Xu | eb4d628 | 2015-12-10 18:02:41 -0800 | [diff] [blame] | 359 | status_t cleanupWithoutDisable(const sp<SensorEventConnection>& connection, int handle); | 
|  | 360 | status_t cleanupWithoutDisableLocked(const sp<SensorEventConnection>& connection, int handle); | 
| Aravind Akella | 9a844cf | 2014-02-11 18:58:52 -0800 | [diff] [blame] | 361 | void cleanupAutoDisabledSensorLocked(const sp<SensorEventConnection>& connection, | 
| Mathias Agopian | b6df7d0 | 2013-05-09 14:53:35 -0700 | [diff] [blame] | 362 | sensors_event_t const* buffer, const int count); | 
| Svetoslav | b412f6e | 2015-04-29 16:50:41 -0700 | [diff] [blame] | 363 | static bool canAccessSensor(const Sensor& sensor, const char* operation, | 
|  | 364 | const String16& opPackageName); | 
| Brian Stack | 793f464 | 2019-04-18 17:21:34 -0700 | [diff] [blame] | 365 | static bool hasPermissionForSensor(const Sensor& sensor); | 
|  | 366 | static int getTargetSdkVersion(const String16& opPackageName); | 
| Aravind Akella | 9a844cf | 2014-02-11 18:58:52 -0800 | [diff] [blame] | 367 | // SensorService acquires a partial wakelock for delivering events from wake up sensors. This | 
|  | 368 | // method checks whether all the events from these wake up sensors have been delivered to the | 
|  | 369 | // corresponding applications, if yes the wakelock is released. | 
|  | 370 | void checkWakeLockState(); | 
| Brian Duddie | 967ce17 | 2019-06-10 11:08:27 -0700 | [diff] [blame] | 371 | void checkWakeLockStateLocked(ConnectionSafeAutolock* connLock); | 
| Aravind Akella | b4373ac | 2014-10-29 17:55:20 -0700 | [diff] [blame] | 372 | bool isWakeLockAcquired(); | 
| Aravind Akella | 9a844cf | 2014-02-11 18:58:52 -0800 | [diff] [blame] | 373 | bool isWakeUpSensorEvent(const sensors_event_t& event) const; | 
| Aravind Akella | 56ae426 | 2014-07-10 16:01:10 -0700 | [diff] [blame] | 374 |  | 
|  | 375 | sp<Looper> getLooper() const; | 
|  | 376 |  | 
| Aravind Akella | b4373ac | 2014-10-29 17:55:20 -0700 | [diff] [blame] | 377 | // Reset mWakeLockRefCounts for all SensorEventConnections to zero. This may happen if | 
|  | 378 | // SensorService did not receive any acknowledgements from apps which have registered for | 
|  | 379 | // wake_up sensors. | 
|  | 380 | void resetAllWakeLockRefCounts(); | 
|  | 381 |  | 
| Peng Xu | eb4d628 | 2015-12-10 18:02:41 -0800 | [diff] [blame] | 382 | // Acquire or release wake_lock. If wake_lock is acquired, set the timeout in the looper to 5 | 
|  | 383 | // seconds and wake the looper. | 
| Aravind Akella | b4373ac | 2014-10-29 17:55:20 -0700 | [diff] [blame] | 384 | void setWakeLockAcquiredLocked(bool acquire); | 
|  | 385 |  | 
|  | 386 | // Send events from the event cache for this particular connection. | 
|  | 387 | void sendEventsFromCache(const sp<SensorEventConnection>& connection); | 
|  | 388 |  | 
| Aravind Akella | 4949c50 | 2015-02-11 15:54:35 -0800 | [diff] [blame] | 389 | // If SensorService is operating in RESTRICTED mode, only select whitelisted packages are | 
|  | 390 | // allowed to register for or call flush on sensors. Typically only cts test packages are | 
|  | 391 | // allowed. | 
|  | 392 | bool isWhiteListedPackage(const String8& packageName); | 
| Arthur Ishiguro | e3ed3d2 | 2020-04-13 10:29:44 -0700 | [diff] [blame] | 393 |  | 
|  | 394 | // Returns true if a connection with the specified opPackageName has no access to sensors | 
|  | 395 | // in the RESTRICTED mode (i.e. the service is in RESTRICTED mode, and the package is not | 
|  | 396 | // whitelisted). mLock must be held to invoke this method. | 
|  | 397 | bool isOperationRestrictedLocked(const String16& opPackageName); | 
| Aravind Akella | 4949c50 | 2015-02-11 15:54:35 -0800 | [diff] [blame] | 398 |  | 
| Anh Pham | af91a91 | 2021-02-10 14:10:53 +0100 | [diff] [blame] | 399 | status_t adjustSamplingPeriodBasedOnMicAndPermission(nsecs_t* requestedPeriodNs, | 
|  | 400 | const String16& opPackageName); | 
|  | 401 | status_t adjustRateLevelBasedOnMicAndPermission(int* requestedRateLevel, | 
|  | 402 | const String16& opPackageName); | 
|  | 403 | bool isRateCappedBasedOnPermission(const String16& opPackageName); | 
|  | 404 | bool isPackageDebuggable(const String16& opPackageName); | 
|  | 405 |  | 
| Aravind Akella | a9e6cc3 | 2015-04-16 18:57:31 -0700 | [diff] [blame] | 406 | // Reset the state of SensorService to NORMAL mode. | 
|  | 407 | status_t resetToNormalMode(); | 
|  | 408 | status_t resetToNormalModeLocked(); | 
|  | 409 |  | 
| Greg Kaiser | 53ca2e0 | 2016-06-21 16:11:14 -0700 | [diff] [blame] | 410 | // Transforms the UUIDs for all the sensors into proper IDs. | 
|  | 411 | void makeUuidsIntoIdsForSensorList(Vector<Sensor> &sensorList) const; | 
|  | 412 | // Gets the appropriate ID from the given UUID. | 
|  | 413 | int32_t getIdFromUuid(const Sensor::uuid_t &uuid) const; | 
|  | 414 | // Either read from storage or create a new one. | 
|  | 415 | static bool initializeHmacKey(); | 
|  | 416 |  | 
| Peng Xu | 98d30f6 | 2016-08-01 18:12:11 -0700 | [diff] [blame] | 417 | // Enable SCHED_FIFO priority for thread | 
|  | 418 | void enableSchedFifoMode(); | 
| Greg Kaiser | 53ca2e0 | 2016-06-21 16:11:14 -0700 | [diff] [blame] | 419 |  | 
| Svet Ganov | e752a5c | 2018-01-15 17:14:20 -0800 | [diff] [blame] | 420 | // Sets whether the given UID can get sensor data | 
| Arthur Ishiguro | 539c27c | 2020-04-13 09:47:59 -0700 | [diff] [blame] | 421 | void onUidStateChanged(uid_t uid, UidState state); | 
| Svet Ganov | e752a5c | 2018-01-15 17:14:20 -0800 | [diff] [blame] | 422 |  | 
| Arthur Ishiguro | e3ed3d2 | 2020-04-13 10:29:44 -0700 | [diff] [blame] | 423 | // Returns true if a connection with the given uid and opPackageName | 
|  | 424 | // currently has access to sensors. | 
|  | 425 | bool hasSensorAccess(uid_t uid, const String16& opPackageName); | 
|  | 426 | // Same as hasSensorAccess but with mLock held. | 
|  | 427 | bool hasSensorAccessLocked(uid_t uid, const String16& opPackageName); | 
|  | 428 |  | 
| Svet Ganov | e752a5c | 2018-01-15 17:14:20 -0800 | [diff] [blame] | 429 | // Overrides the UID state as if it is idle | 
|  | 430 | status_t handleSetUidState(Vector<String16>& args, int err); | 
|  | 431 | // Clears the override for the UID state | 
|  | 432 | status_t handleResetUidState(Vector<String16>& args, int err); | 
|  | 433 | // Gets the UID state | 
|  | 434 | status_t handleGetUidState(Vector<String16>& args, int out, int err); | 
|  | 435 | // Prints the shell command help | 
|  | 436 | status_t printHelp(int out); | 
|  | 437 |  | 
| Michael Groover | 5e1f60b | 2018-12-04 22:34:29 -0800 | [diff] [blame] | 438 | // temporarily stops all active direct connections and disables all sensors | 
|  | 439 | void disableAllSensors(); | 
| Brian Duddie | 967ce17 | 2019-06-10 11:08:27 -0700 | [diff] [blame] | 440 | void disableAllSensorsLocked(ConnectionSafeAutolock* connLock); | 
| Michael Groover | 5e1f60b | 2018-12-04 22:34:29 -0800 | [diff] [blame] | 441 | // restarts the previously stopped direct connections and enables all sensors | 
|  | 442 | void enableAllSensors(); | 
| Brian Duddie | 967ce17 | 2019-06-10 11:08:27 -0700 | [diff] [blame] | 443 | void enableAllSensorsLocked(ConnectionSafeAutolock* connLock); | 
| Michael Groover | 5e1f60b | 2018-12-04 22:34:29 -0800 | [diff] [blame] | 444 |  | 
| Anh Pham | 5198c99 | 2021-02-10 14:15:30 +0100 | [diff] [blame] | 445 | // Caps active direct connections (when the mic toggle is flipped to on) | 
|  | 446 | void capRates(userid_t userId); | 
|  | 447 | // Removes the capped rate on active direct connections (when the mic toggle is flipped to off) | 
|  | 448 | void uncapRates(userid_t userId); | 
|  | 449 |  | 
| Greg Kaiser | 53ca2e0 | 2016-06-21 16:11:14 -0700 | [diff] [blame] | 450 | static uint8_t sHmacGlobalKey[128]; | 
|  | 451 | static bool sHmacGlobalKeyIsValid; | 
|  | 452 |  | 
| Andrew Lehmer | 3a60257 | 2021-03-25 15:19:56 -0700 | [diff] [blame] | 453 | static std::atomic_uint64_t curProxCallbackSeq; | 
|  | 454 | static std::atomic_uint64_t completedCallbackSeq; | 
|  | 455 |  | 
| Brian Stack | 4baa5be | 2018-09-18 14:03:13 -0700 | [diff] [blame] | 456 | SensorServiceUtil::SensorList mSensors; | 
| Mathias Agopian | 50df295 | 2010-07-19 19:09:10 -0700 | [diff] [blame] | 457 | status_t mInitCheck; | 
| Peng Xu | eb4d628 | 2015-12-10 18:02:41 -0800 | [diff] [blame] | 458 |  | 
| Aravind Akella | 5466c3d | 2014-08-22 16:11:10 -0700 | [diff] [blame] | 459 | // Socket buffersize used to initialize BitTube. This size depends on whether batching is | 
|  | 460 | // supported or not. | 
| Peng Xu | 755c451 | 2016-04-07 23:15:14 -0700 | [diff] [blame] | 461 | uint32_t mSocketBufferSize; | 
|  | 462 | sp<Looper> mLooper; | 
|  | 463 | sp<SensorEventAckReceiver> mAckReceiver; | 
| Mathias Agopian | fc32881 | 2010-07-14 23:41:37 -0700 | [diff] [blame] | 464 |  | 
|  | 465 | // protected by mLock | 
|  | 466 | mutable Mutex mLock; | 
| Mathias Agopian | fc32881 | 2010-07-14 23:41:37 -0700 | [diff] [blame] | 467 | DefaultKeyedVector<int, SensorRecord*> mActiveSensors; | 
| Peng Xu | 755c451 | 2016-04-07 23:15:14 -0700 | [diff] [blame] | 468 | std::unordered_set<int> mActiveVirtualSensors; | 
| Brian Duddie | 967ce17 | 2019-06-10 11:08:27 -0700 | [diff] [blame] | 469 | SensorConnectionHolder mConnectionHolder; | 
| Aravind Akella | 9a844cf | 2014-02-11 18:58:52 -0800 | [diff] [blame] | 470 | bool mWakeLockAcquired; | 
| Aravind Akella | 8493b79 | 2014-09-08 15:45:47 -0700 | [diff] [blame] | 471 | sensors_event_t *mSensorEventBuffer, *mSensorEventScratch; | 
| Brian Duddie | 967ce17 | 2019-06-10 11:08:27 -0700 | [diff] [blame] | 472 | // WARNING: these SensorEventConnection instances must not be promoted to sp, except via | 
|  | 473 | // modification to add support for them in ConnectionSafeAutolock | 
| Peng Xu | ded526e | 2016-08-12 16:39:44 -0700 | [diff] [blame] | 474 | wp<const SensorEventConnection> * mMapFlushEventsToConnections; | 
| Brian Stack | 4baa5be | 2018-09-18 14:03:13 -0700 | [diff] [blame] | 475 | std::unordered_map<int, SensorServiceUtil::RecentEventLogger*> mRecentEvent; | 
| Aravind Akella | a9e6cc3 | 2015-04-16 18:57:31 -0700 | [diff] [blame] | 476 | Mode mCurrentOperatingMode; | 
| Peng Xu | eb4d628 | 2015-12-10 18:02:41 -0800 | [diff] [blame] | 477 |  | 
| Aravind Akella | 5c53805 | 2015-06-29 12:37:48 -0700 | [diff] [blame] | 478 | // This packagaName is set when SensorService is in RESTRICTED or DATA_INJECTION mode. Only | 
|  | 479 | // applications with this packageName are allowed to activate/deactivate or call flush on | 
|  | 480 | // sensors. To run CTS this is can be set to ".cts." and only CTS tests will get access to | 
|  | 481 | // sensors. | 
|  | 482 | String8 mWhiteListedPackage; | 
| Aravind Akella | 8493b79 | 2014-09-08 15:45:47 -0700 | [diff] [blame] | 483 |  | 
| Aravind Akella | 18d6d51 | 2015-06-18 14:18:28 -0700 | [diff] [blame] | 484 | int mNextSensorRegIndex; | 
|  | 485 | Vector<SensorRegistrationInfo> mLastNSensorRegistrations; | 
| Svet Ganov | e752a5c | 2018-01-15 17:14:20 -0800 | [diff] [blame] | 486 |  | 
|  | 487 | sp<UidPolicy> mUidPolicy; | 
| Michael Groover | 5e1f60b | 2018-12-04 22:34:29 -0800 | [diff] [blame] | 488 | sp<SensorPrivacyPolicy> mSensorPrivacyPolicy; | 
| Brian Stack | 793f464 | 2019-04-18 17:21:34 -0700 | [diff] [blame] | 489 |  | 
|  | 490 | static AppOpsManager sAppOpsManager; | 
|  | 491 | static std::map<String16, int> sPackageTargetVersion; | 
|  | 492 | static Mutex sPackageTargetVersionLock; | 
| Anthony Stange | 07eb421 | 2020-08-28 14:50:28 -0400 | [diff] [blame] | 493 | static String16 sSensorInterfaceDescriptorPrefix; | 
| Anh Pham | 5198c99 | 2021-02-10 14:15:30 +0100 | [diff] [blame] | 494 |  | 
|  | 495 | // Map from user to SensorPrivacyPolicy | 
|  | 496 | std::map<userid_t, sp<SensorPrivacyPolicy>> mMicSensorPrivacyPolicies; | 
|  | 497 | // Checks if the mic sensor privacy is enabled for the uid | 
|  | 498 | bool isMicSensorPrivacyEnabledForUid(uid_t uid); | 
| Andrew Lehmer | 3a60257 | 2021-03-25 15:19:56 -0700 | [diff] [blame] | 499 |  | 
| Chris Kuiper | df11ff2 | 2021-10-12 16:30:01 -0700 | [diff] [blame] | 500 | // Keeps track of the handles of all proximity sensors in the system. | 
|  | 501 | std::vector<int32_t> mProxSensorHandles; | 
|  | 502 | // The last proximity sensor active state reported to listeners. | 
|  | 503 | bool mLastReportedProxIsActive; | 
|  | 504 | // Listeners subscribed to receive updates on the proximity sensor active state. | 
| Andrew Lehmer | 3a60257 | 2021-03-25 15:19:56 -0700 | [diff] [blame] | 505 | std::vector<sp<ProximityActiveListener>> mProximityActiveListeners; | 
| Mathias Agopian | fc32881 | 2010-07-14 23:41:37 -0700 | [diff] [blame] | 506 | }; | 
|  | 507 |  | 
| Peng Xu | eb4d628 | 2015-12-10 18:02:41 -0800 | [diff] [blame] | 508 | } // namespace android | 
| Mathias Agopian | fc32881 | 2010-07-14 23:41:37 -0700 | [diff] [blame] | 509 | #endif // ANDROID_SENSOR_SERVICE_H |