ardupilot/libraries/AP_InertialSensor/AP_InertialSensor_LSM9DS1.h
Andrew Tridgell c99923d500 AP_InertialSensor: require gyro orientations in LSM9DS probe
this prevents a bug where they are missing in hwdef.dat
2019-08-27 19:29:37 +10:00

75 lines
1.9 KiB
C++

#pragma once
#include <AP_HAL/AP_HAL.h>
#include <AP_HAL/SPIDevice.h>
#include "AP_InertialSensor.h"
#include "AP_InertialSensor_Backend.h"
/* enable debug to see a register dump on startup */
#define LSM9DS1_DEBUG 0
class AP_InertialSensor_LSM9DS1 : public AP_InertialSensor_Backend
{
public:
virtual ~AP_InertialSensor_LSM9DS1() { }
void start(void) override;
bool update() override;
static AP_InertialSensor_Backend *probe(AP_InertialSensor &imu,
AP_HAL::OwnPtr<AP_HAL::SPIDevice> dev,
enum Rotation rotation);
private:
AP_InertialSensor_LSM9DS1(AP_InertialSensor &imu,
AP_HAL::OwnPtr<AP_HAL::SPIDevice> dev,
int drdy_pin_num_xg,
enum Rotation rotation);
static AP_InertialSensor_Backend *detect(AP_InertialSensor &imu);
struct PACKED sensor_raw_data {
int16_t x;
int16_t y;
int16_t z;
};
enum accel_scale {
A_SCALE_2G = 0,
A_SCALE_4G,
A_SCALE_8G,
A_SCALE_16G
};
void _poll_data();
void _fifo_reset();
bool _init_sensor();
bool _hardware_init();
void _gyro_init();
void _accel_init();
void _set_gyro_scale();
void _set_accel_scale(accel_scale scale);
uint8_t _register_read(uint8_t reg);
void _register_write(uint8_t reg, uint8_t val, bool checked=false);
void _read_data_transaction_x(uint16_t samples);
void _read_data_transaction_g(uint16_t samples);
#if LSM9DS1_DEBUG
void _dump_registers();
#endif
AP_HAL::OwnPtr<AP_HAL::SPIDevice> _dev;
AP_HAL::Semaphore *_spi_sem;
AP_HAL::DigitalSource * _drdy_pin_xg;
float _gyro_scale;
float _accel_scale;
int _drdy_pin_num_xg;
uint8_t _gyro_instance;
uint8_t _accel_instance;
enum Rotation _rotation;
};