atbetaflight/src/main/drivers/accgyro/accgyro.h

198 lines
5.4 KiB
C

/*
* This file is part of Cleanflight and Betaflight.
*
* Cleanflight and Betaflight are free software. You can redistribute
* this software and/or modify this software under the terms of the
* GNU General Public License as published by the Free Software
* Foundation, either version 3 of the License, or (at your option)
* any later version.
*
* Cleanflight and Betaflight are distributed in the hope that they
* will be useful, but WITHOUT ANY WARRANTY; without even the implied
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this software.
*
* If not, see <http://www.gnu.org/licenses/>.
*/
#pragma once
#include "platform.h"
#include "common/axis.h"
#include "common/maths.h"
#include "common/sensor_alignment.h"
#include "common/time.h"
#include "drivers/exti.h"
#include "drivers/bus.h"
#include "drivers/sensor.h"
#include "drivers/accgyro/accgyro_mpu.h"
#pragma GCC diagnostic push
#if defined(SIMULATOR_BUILD) && defined(SIMULATOR_MULTITHREAD)
#include <pthread.h>
#endif
#define GYRO_SCALE_2000DPS (2000.0f / (1 << 15)) // 16.384 dps/lsb scalefactor for 2000dps sensors
#define GYRO_SCALE_2048DPS (2048.0f / (1 << 15)) // 16 dps/lsb scalefactor for 2048dps sensors
#define GYRO_SCALE_4000DPS (4000.0f / (1 << 15)) // 8.192 dps/lsb scalefactor for 4000dps sensors
typedef enum {
GYRO_NONE = 0,
GYRO_DEFAULT,
GYRO_MPU6050,
GYRO_L3G4200D,
GYRO_MPU3050,
GYRO_L3GD20,
GYRO_MPU6000,
GYRO_MPU6500,
GYRO_MPU9250,
GYRO_ICM20601,
GYRO_ICM20602,
GYRO_ICM20608G,
GYRO_ICM20649,
GYRO_ICM20689,
GYRO_ICM42605,
GYRO_ICM42688P,
GYRO_BMI160,
GYRO_BMI270,
GYRO_ASM330LHH,
GYRO_LSM6DS3,
GYRO_LSM6DSL,
GYRO_LSM6DSO,
GYRO_QMI8658,
GYRO_SH3001,
GYRO_FAKE
} gyroHardware_e;
typedef enum {
GYRO_HARDWARE_LPF_NORMAL,
GYRO_HARDWARE_LPF_OPTION_1,
GYRO_HARDWARE_LPF_OPTION_2,
#ifdef USE_GYRO_DLPF_EXPERIMENTAL
GYRO_HARDWARE_LPF_EXPERIMENTAL,
#endif
GYRO_HARDWARE_LPF_COUNT
} gyroHardwareLpf_e;
typedef enum {
GYRO_RATE_1_kHz,
GYRO_RATE_1100_Hz,
GYRO_RATE_1667_Hz,
GYRO_RATE_3200_Hz,
GYRO_RATE_6400_Hz,
GYRO_RATE_6664_Hz,
GYRO_RATE_7174_Hz,
GYRO_RATE_8_kHz,
GYRO_RATE_9_kHz,
GYRO_RATE_32_kHz,
} gyroRateKHz_e;
typedef enum {
GYRO_EXTI_INIT = 0,
GYRO_EXTI_INT_DMA,
GYRO_EXTI_INT,
GYRO_EXTI_NO_INT
} gyroModeSPI_e;
typedef struct gyroDev_s {
#if defined(SIMULATOR_BUILD) && defined(SIMULATOR_MULTITHREAD)
pthread_mutex_t lock;
#endif
sensorGyroInitFuncPtr initFn; // initialize function
sensorGyroReadFuncPtr readFn; // read 3 axis data function
sensorGyroReadDataFuncPtr temperatureFn; // read temperature if available
extiCallbackRec_t exti;
extDevice_t dev;
float scale; // scalefactor
float gyroZero[XYZ_AXIS_COUNT];
float gyroADC[XYZ_AXIS_COUNT]; // gyro data after calibration and alignment
int32_t gyroADCRawPrevious[XYZ_AXIS_COUNT];
int16_t gyroADCRaw[XYZ_AXIS_COUNT]; // raw data from sensor
int16_t temperature;
mpuDetectionResult_t mpuDetectionResult;
sensor_align_e gyroAlign;
gyroRateKHz_e gyroRateKHz;
gyroModeSPI_e gyroModeSPI;
#ifdef USE_GYRO_EXTI
uint32_t detectedEXTI;
uint32_t gyroLastEXTI;
uint32_t gyroSyncEXTI;
int32_t gyroShortPeriod;
int32_t gyroDmaMaxDuration;
busSegment_t segments[2];
#endif
volatile bool dataReady;
bool gyro_high_fsr;
uint8_t hardware_lpf;
uint8_t hardware_32khz_lpf;
uint8_t mpuDividerDrops;
ioTag_t mpuIntExtiTag;
uint8_t gyroHasOverflowProtection;
gyroHardware_e gyroHardware;
fp_rotationMatrix_t rotationMatrix;
uint16_t gyroSampleRateHz;
uint16_t accSampleRateHz;
uint8_t accDataReg;
uint8_t gyroDataReg;
} gyroDev_t;
typedef struct accDev_s {
#if defined(SIMULATOR_BUILD) && defined(SIMULATOR_MULTITHREAD)
pthread_mutex_t lock;
#endif
float acc_1G_rec;
sensorAccInitFuncPtr initFn; // initialize function
sensorAccReadFuncPtr readFn; // read 3 axis data function
uint16_t acc_1G;
int16_t ADCRaw[XYZ_AXIS_COUNT];
mpuDetectionResult_t mpuDetectionResult;
sensor_align_e accAlign;
bool dataReady;
gyroDev_t *gyro;
bool acc_high_fsr;
char revisionCode; // a revision code for the sensor, if known
uint8_t filler[2];
fp_rotationMatrix_t rotationMatrix;
} accDev_t;
static inline void accDevLock(accDev_t *acc)
{
#if defined(SIMULATOR_BUILD) && defined(SIMULATOR_MULTITHREAD)
pthread_mutex_lock(&acc->lock);
#else
(void)acc;
#endif
}
static inline void accDevUnLock(accDev_t *acc)
{
#if defined(SIMULATOR_BUILD) && defined(SIMULATOR_MULTITHREAD)
pthread_mutex_unlock(&acc->lock);
#else
(void)acc;
#endif
}
static inline void gyroDevLock(gyroDev_t *gyro)
{
#if defined(SIMULATOR_BUILD) && defined(SIMULATOR_MULTITHREAD)
pthread_mutex_lock(&gyro->lock);
#else
(void)gyro;
#endif
}
static inline void gyroDevUnLock(gyroDev_t *gyro)
{
#if defined(SIMULATOR_BUILD) && defined(SIMULATOR_MULTITHREAD)
pthread_mutex_unlock(&gyro->lock);
#else
(void)gyro;
#endif
}
#pragma GCC diagnostic pop