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