blob: 2b1571d6de38dd47934de61d58ea280a867d4288 [file] [log] [blame]
/*
* Copyright (C) 2011 Invensense, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/*************Removed the gesture related info for Google check in : Meenakshi Ramamoorthi: May 31st *********/
#ifndef ANDROID_MPL_SENSOR_H
#define ANDROID_MPL_SENSOR_H
#include <stdint.h>
#include <errno.h>
#include <sys/cdefs.h>
#include <sys/types.h>
#include <poll.h>
#include <utils/Vector.h>
#include <utils/KeyedVector.h>
#include "sensors.h"
#include "SensorBase.h"
/*****************************************************************************/
/** MPLSensor implementation which fits into the HAL example for crespo provided
* * by Google.
* * WARNING: there may only be one instance of MPLSensor, ever.
*/
class MPLSensor: public SensorBase
{
typedef void (MPLSensor::*hfunc_t)(sensors_event_t*, uint32_t*, int);
public:
MPLSensor();
virtual ~MPLSensor();
enum
{
Gyro=0,
Accelerometer,
MagneticField,
Orientation,
RotationVector,
LinearAccel,
Gravity,
numSensors
};
virtual int setDelay(int32_t handle, int64_t ns);
virtual int enable(int32_t handle, int enabled);
virtual int readEvents(sensors_event_t *data, int count);
virtual int getFd() const;
virtual int getAccelFd() const;
virtual int getTimerFd() const;
virtual int getPowerFd() const;
virtual int getPollTime();
virtual bool hasPendingEvents() const;
virtual void handlePowerEvent();
virtual void sleepEvent();
virtual void wakeEvent();
int populateSensorList(struct sensor_t *list, int len);
void cbOnMotion(uint16_t);
void cbProcData();
protected:
void clearIrqData(bool* irq_set);
void setPowerStates(int enabledsensor);
void initMPL();
void setupFIFO();
void setupCallbacks();
void gyroHandler(sensors_event_t *data, uint32_t *pendmask, int index);
void accelHandler(sensors_event_t *data, uint32_t *pendmask, int index);
void compassHandler(sensors_event_t *data, uint32_t *pendmask, int index);
void rvHandler(sensors_event_t *data, uint32_t *pendmask, int index);
void laHandler(sensors_event_t *data, uint32_t *pendmask, int index);
void gravHandler(sensors_event_t *data, uint32_t *pendmask, int index);
void orienHandler(sensors_event_t *data, uint32_t *pendmask, int index);
void calcOrientationSensor(float *Rx, float *Val);
int estimateCompassAccuracy();
int mMpuAccuracy; //global storage for the current accuracy status
int mNewData; //flag indicating that the MPL calculated new output values
int mDmpStarted;
long mMasterSensorMask;
long mLocalSensorMask;
int mPollTime;
int mCurFifoRate; //current fifo rate
bool mHaveGoodMpuCal; //flag indicating that the cal file can be written
bool mHaveGoodCompassCal;
bool mUseTimerIrqAccel;
bool mUsetimerIrqCompass;
bool mUseTimerirq;
struct pollfd mPollFds[4];
int mSampleCount;
pthread_mutex_t mMplMutex;
int64_t now_ns();
int64_t select_ns(unsigned long long time_set[]);
enum FILEHANDLES
{
MPUIRQ_FD, ACCELIRQ_FD, COMPASSIRQ_FD, TIMERIRQ_FD,
};
private:
int update_delay();
int accel_fd;
int timer_fd;
uint32_t mEnabled;
uint32_t mPendingMask;
sensors_event_t mPendingEvents[numSensors];
uint64_t mDelays[numSensors];
hfunc_t mHandlers[numSensors];
bool mForceSleep;
long int mOldEnabledMask;
android::KeyedVector<int, int> mIrqFds;
/* added for dynamic get sensor list */
bool mNineAxisEnabled;
void fillAccel(unsigned char accel, struct sensor_t *list);
void fillCompass(unsigned char compass, struct sensor_t *list);
void fillGyro(const char* gyro, struct sensor_t *list);
void fillRV(struct sensor_t *list);
void fillOrientation(struct sensor_t *list);
void fillGravity(struct sensor_t *list);
void fillLinearAccel(struct sensor_t *list);
};
void setCallbackObject(MPLSensor*);
/*****************************************************************************/
#endif // ANDROID_MPL_SENSOR_H