1fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian/* 2fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian * Copyright (C) 2010 The Android Open Source Project 3fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian * 4fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian * Licensed under the Apache License, Version 2.0 (the "License"); 5fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian * you may not use this file except in compliance with the License. 6fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian * You may obtain a copy of the License at 7fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian * 8fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian * http://www.apache.org/licenses/LICENSE-2.0 9fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian * 10fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian * Unless required by applicable law or agreed to in writing, software 11fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian * distributed under the License is distributed on an "AS IS" BASIS, 12fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian * See the License for the specific language governing permissions and 14fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian * limitations under the License. 15fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian */ 16fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 17fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian#ifndef ANDROID_SENSOR_SERVICE_H 18fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian#define ANDROID_SENSOR_SERVICE_H 19fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 20fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian#include <stdint.h> 21fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian#include <sys/types.h> 22fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 23fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian#include <utils/Vector.h> 24fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian#include <utils/SortedVector.h> 25fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian#include <utils/KeyedVector.h> 26fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian#include <utils/threads.h> 27fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian#include <utils/RefBase.h> 28fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 29fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian#include <binder/BinderService.h> 30fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 31fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian#include <gui/Sensor.h> 32b3989276d17f2b083bec67b695d1078fb86c6c53Mathias Agopian#include <gui/BitTube.h> 33fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian#include <gui/ISensorServer.h> 34fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian#include <gui/ISensorEventConnection.h> 35fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 36f001c92436b4a66eb7687286325ced7f10c9f917Mathias Agopian#include "SensorInterface.h" 37f001c92436b4a66eb7687286325ced7f10c9f917Mathias Agopian 38fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian// --------------------------------------------------------------------------- 39fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 40a1b7db95b6ccf5be9d8dfaac1b8f45494813edc0Mathias Agopian#define DEBUG_CONNECTIONS false 414c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella// Max size is 1 MB which is enough to accept a batch of about 10k events. 424c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella#define MAX_SOCKET_BUFFER_SIZE_BATCHED 1024 * 1024 434c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella#define SOCKET_BUFFER_SIZE_NON_BATCHED 4 * 1024 44a1b7db95b6ccf5be9d8dfaac1b8f45494813edc0Mathias Agopian 45fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopianstruct sensors_poll_device_t; 46fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopianstruct sensors_module_t; 47fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 48fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopiannamespace android { 49fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian// --------------------------------------------------------------------------- 50fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 51fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopianclass SensorService : 52fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian public BinderService<SensorService>, 53fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian public BnSensorServer, 54fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian protected Thread 55fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian{ 56b6df7d0e4c2117ca476662bd52b6745b3d8a305fMathias Agopian friend class BinderService<SensorService>; 57fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 58b6df7d0e4c2117ca476662bd52b6745b3d8a305fMathias Agopian static const char* WAKE_LOCK_NAME; 597c1c531872a95051cb11ec829e3daf890d9bb58aMathias Agopian 60b6df7d0e4c2117ca476662bd52b6745b3d8a305fMathias Agopian static char const* getServiceName() ANDROID_API { return "sensorservice"; } 61b6df7d0e4c2117ca476662bd52b6745b3d8a305fMathias Agopian SensorService() ANDROID_API; 62fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian virtual ~SensorService(); 63fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 64fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian virtual void onFirstRef(); 65fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 66fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian // Thread interface 67fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian virtual bool threadLoop(); 68fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 69fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian // ISensorServer interface 70fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian virtual Vector<Sensor> getSensorList(); 71fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian virtual sp<ISensorEventConnection> createSensorEventConnection(); 72fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian virtual status_t dump(int fd, const Vector<String16>& args); 73fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 74fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 75fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian class SensorEventConnection : public BnSensorEventConnection { 767c1c531872a95051cb11ec829e3daf890d9bb58aMathias Agopian virtual ~SensorEventConnection(); 777c1c531872a95051cb11ec829e3daf890d9bb58aMathias Agopian virtual void onFirstRef(); 78b3989276d17f2b083bec67b695d1078fb86c6c53Mathias Agopian virtual sp<BitTube> getSensorChannel() const; 79724d91d778e71c8186399f4955de14b54812b3edAravind Akella virtual status_t enableDisable(int handle, bool enabled, nsecs_t samplingPeriodNs, 80724d91d778e71c8186399f4955de14b54812b3edAravind Akella nsecs_t maxBatchReportLatencyNs, int reservedFlags); 81724d91d778e71c8186399f4955de14b54812b3edAravind Akella virtual status_t setEventRate(int handle, nsecs_t samplingPeriodNs); 82701166d9f60a6e1149ff568aec0e03f3f3925292Aravind Akella virtual status_t flush(); 834c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella // Count the number of flush complete events which are about to be dropped in the buffer. 844c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella // Increment mPendingFlushEventsToSend in mSensorInfo. These flush complete events will be 854c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella // sent separately before the next batch of events. 86c551eac5b16a53f872cbb692d3a0c81e39329725Aravind Akella void countFlushCompleteEventsLocked(sensors_event_t* scratch, int numEventsDropped); 877c1c531872a95051cb11ec829e3daf890d9bb58aMathias Agopian 88fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian sp<SensorService> const mService; 894c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella sp<BitTube> mChannel; 905307d17fe33fc26eeeacd6339a9fbfe96cf56873Mathias Agopian uid_t mUid; 9171d7a5c289c6ef6b5fc86dd4784a075ca6470e38Mathias Agopian mutable Mutex mConnectionLock; 927c1c531872a95051cb11ec829e3daf890d9bb58aMathias Agopian 934c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella struct FlushInfo { 944c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella // The number of flush complete events dropped for this sensor is stored here. 954c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella // They are sent separately before the next batch of events. 964c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella int mPendingFlushEventsToSend; 974c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella // Every activate is preceded by a flush. Only after the first flush complete is 984c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella // received, the events for the sensor are sent on that *connection*. 994c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella bool mFirstFlushPending; 1004c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella FlushInfo() : mPendingFlushEventsToSend(0), mFirstFlushPending(false) {} 1014c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella }; 1024c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella // protected by SensorService::mLock. Key for this vector is the sensor handle. 1034c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella KeyedVector<int, FlushInfo> mSensorInfo; 1047c1c531872a95051cb11ec829e3daf890d9bb58aMathias Agopian 105fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian public: 1065307d17fe33fc26eeeacd6339a9fbfe96cf56873Mathias Agopian SensorEventConnection(const sp<SensorService>& service, uid_t uid); 1077c1c531872a95051cb11ec829e3daf890d9bb58aMathias Agopian 108cf51001dbf28e9885fcacd4048902f1c75768fe9Mathias Agopian status_t sendEvents(sensors_event_t const* buffer, size_t count, 1093560fb24b668675627934356f210d84d19bf4e56Mathias Agopian sensors_event_t* scratch = NULL); 110fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian bool hasSensor(int32_t handle) const; 111fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian bool hasAnySensor() const; 1127c1c531872a95051cb11ec829e3daf890d9bb58aMathias Agopian bool addSensor(int32_t handle); 1137c1c531872a95051cb11ec829e3daf890d9bb58aMathias Agopian bool removeSensor(int32_t handle); 1144c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella void setFirstFlushPending(int32_t handle, bool value); 1154c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella void dump(String8& result); 1165307d17fe33fc26eeeacd6339a9fbfe96cf56873Mathias Agopian 1175307d17fe33fc26eeeacd6339a9fbfe96cf56873Mathias Agopian uid_t getUid() const { return mUid; } 118fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian }; 119fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 120fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian class SensorRecord { 121fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian SortedVector< wp<SensorEventConnection> > mConnections; 122fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian public: 123fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian SensorRecord(const sp<SensorEventConnection>& connection); 1247c1c531872a95051cb11ec829e3daf890d9bb58aMathias Agopian bool addConnection(const sp<SensorEventConnection>& connection); 125fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian bool removeConnection(const wp<SensorEventConnection>& connection); 126fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian size_t getNumConnections() const { return mConnections.size(); } 127fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian }; 128fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 129fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian SortedVector< wp<SensorEventConnection> > getActiveConnections() const; 130f001c92436b4a66eb7687286325ced7f10c9f917Mathias Agopian DefaultKeyedVector<int, SensorInterface*> getActiveVirtualSensors() const; 131fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 132f001c92436b4a66eb7687286325ced7f10c9f917Mathias Agopian String8 getSensorName(int handle) const; 133b4099e77ec2bf8e9d4259ff30f0cb1d621deed91Aravind Akella bool isVirtualSensor(int handle) const; 13494e8f6813f3fb2beaa9bcbfb1ad9b4ae2eb46949Mathias Agopian void recordLastValue(sensors_event_t const * buffer, size_t count); 135f001c92436b4a66eb7687286325ced7f10c9f917Mathias Agopian static void sortEventBuffer(sensors_event_t* buffer, size_t count); 1360319306670b0344da99efa606b6f172dde575a39Mathias Agopian Sensor registerSensor(SensorInterface* sensor); 1370319306670b0344da99efa606b6f172dde575a39Mathias Agopian Sensor registerVirtualSensor(SensorInterface* sensor); 138ac9a96da65f6eae4513654adaad8a457d1c1575cMathias Agopian status_t cleanupWithoutDisable( 139ac9a96da65f6eae4513654adaad8a457d1c1575cMathias Agopian const sp<SensorEventConnection>& connection, int handle); 140ac9a96da65f6eae4513654adaad8a457d1c1575cMathias Agopian status_t cleanupWithoutDisableLocked( 141ac9a96da65f6eae4513654adaad8a457d1c1575cMathias Agopian const sp<SensorEventConnection>& connection, int handle); 1424342fdf14ffb792a36c1de25ad14b745df628da2Jaikumar Ganesh void cleanupAutoDisabledSensor(const sp<SensorEventConnection>& connection, 143b6df7d0e4c2117ca476662bd52b6745b3d8a305fMathias Agopian sensors_event_t const* buffer, const int count); 14494e8f6813f3fb2beaa9bcbfb1ad9b4ae2eb46949Mathias Agopian 145fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian // constants 146fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian Vector<Sensor> mSensorList; 14733264868ba0aaccb9d4b5e5a067a79a43633f6ecMathias Agopian Vector<Sensor> mUserSensorListDebug; 148010e42230135815907e76e5d7e5f30edf9e1799dMathias Agopian Vector<Sensor> mUserSensorList; 149f001c92436b4a66eb7687286325ced7f10c9f917Mathias Agopian DefaultKeyedVector<int, SensorInterface*> mSensorMap; 150f001c92436b4a66eb7687286325ced7f10c9f917Mathias Agopian Vector<SensorInterface *> mVirtualSensorList; 15150df2959e58fc7408f98d11d77c8428397dca445Mathias Agopian status_t mInitCheck; 1524c8b951f8d6a121e758bd3905fa8987c77863790Aravind Akella size_t mSocketBufferSize; 153fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 154fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian // protected by mLock 155fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian mutable Mutex mLock; 156fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian DefaultKeyedVector<int, SensorRecord*> mActiveSensors; 157f001c92436b4a66eb7687286325ced7f10c9f917Mathias Agopian DefaultKeyedVector<int, SensorInterface*> mActiveVirtualSensors; 158fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian SortedVector< wp<SensorEventConnection> > mActiveConnections; 159fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 1603560fb24b668675627934356f210d84d19bf4e56Mathias Agopian // The size of this vector is constant, only the items are mutable 1613560fb24b668675627934356f210d84d19bf4e56Mathias Agopian KeyedVector<int32_t, sensors_event_t> mLastEventSeen; 1623560fb24b668675627934356f210d84d19bf4e56Mathias Agopian 163fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopianpublic: 164db5b4bce9e65ec9c2c7762b601297e4abadbc22aMathias Agopian void cleanupConnection(SensorEventConnection* connection); 165724d91d778e71c8186399f4955de14b54812b3edAravind Akella status_t enable(const sp<SensorEventConnection>& connection, int handle, 166724d91d778e71c8186399f4955de14b54812b3edAravind Akella nsecs_t samplingPeriodNs, nsecs_t maxBatchReportLatencyNs, int reservedFlags); 167fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian status_t disable(const sp<SensorEventConnection>& connection, int handle); 1687c1c531872a95051cb11ec829e3daf890d9bb58aMathias Agopian status_t setEventRate(const sp<SensorEventConnection>& connection, int handle, nsecs_t ns); 169724d91d778e71c8186399f4955de14b54812b3edAravind Akella status_t flushSensor(const sp<SensorEventConnection>& connection, int handle); 170fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian}; 171fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 172fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian// --------------------------------------------------------------------------- 173fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian}; // namespace android 174fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian 175fc32881fcc68640d008c7515cdd1bcd866f72cd5Mathias Agopian#endif // ANDROID_SENSOR_SERVICE_H 176