Ardupilot2/libraries/AP_Compass/AP_Compass_LSM303D.h

61 lines
1.5 KiB
C++

#pragma once
#include <AP_Common/AP_Common.h>
#include <AP_HAL/AP_HAL.h>
#include <AP_HAL/Device.h>
#include <AP_Math/AP_Math.h>
#include "AP_Compass.h"
#include "AP_Compass_Backend.h"
class AP_Compass_LSM303D : public AP_Compass_Backend
{
public:
static AP_Compass_Backend *probe(Compass &compass,
AP_HAL::OwnPtr<AP_HAL::Device> dev,
enum Rotation = ROTATION_NONE);
static constexpr const char *name = "LSM303D";
void read() override;
virtual ~AP_Compass_LSM303D() { }
private:
AP_Compass_LSM303D(Compass &compass, AP_HAL::OwnPtr<AP_HAL::Device> dev);
bool init(enum Rotation rotation);
uint8_t _register_read(uint8_t reg);
void _register_write(uint8_t reg, uint8_t val);
void _register_modify(uint8_t reg, uint8_t clearbits, uint8_t setbits);
bool _block_read(uint8_t reg, uint8_t *buf, uint32_t size);
bool _read_sample();
bool _data_ready();
bool _hardware_init();
bool _update();
void _disable_i2c();
bool _mag_set_range(uint8_t max_ga);
bool _mag_set_samplerate(uint16_t frequency);
AP_HAL::DigitalSource *_drdy_pin_m;
AP_HAL::OwnPtr<AP_HAL::Device> _dev;
float _mag_range_scale;
float _mag_x_accum;
float _mag_y_accum;
float _mag_z_accum;
int16_t _mag_x;
int16_t _mag_y;
int16_t _mag_z;
uint8_t _accum_count;
uint8_t _compass_instance;
bool _initialised;
uint8_t _mag_range_ga;
uint8_t _mag_samplerate;
uint8_t _reg7_expected;
};