mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-09 09:28:31 -04:00
I2C: convert barometer library to new I2C library
this also adds a healthy attribute and error checking
This commit is contained in:
parent
acf4e9b61d
commit
7ba744a11a
@ -1,3 +1,4 @@
|
|||||||
|
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
||||||
|
|
||||||
#ifndef __AP_BARO_H__
|
#ifndef __AP_BARO_H__
|
||||||
#define __AP_BARO_H__
|
#define __AP_BARO_H__
|
||||||
@ -7,15 +8,16 @@
|
|||||||
class AP_Baro
|
class AP_Baro
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
AP_Baro() {}
|
bool healthy;
|
||||||
virtual void init(AP_PeriodicProcess *scheduler)=0;
|
AP_Baro() {}
|
||||||
virtual uint8_t read() = 0;
|
virtual bool init(AP_PeriodicProcess *scheduler)=0;
|
||||||
virtual int32_t get_pressure() = 0;
|
virtual uint8_t read() = 0;
|
||||||
virtual int16_t get_temperature() = 0;
|
virtual int32_t get_pressure() = 0;
|
||||||
virtual float get_altitude() = 0;
|
virtual int16_t get_temperature() = 0;
|
||||||
|
virtual float get_altitude() = 0;
|
||||||
|
|
||||||
virtual int32_t get_raw_pressure() = 0;
|
virtual int32_t get_raw_pressure() = 0;
|
||||||
virtual int32_t get_raw_temp() = 0;
|
virtual int32_t get_raw_temp() = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
#include "AP_Baro_MS5611.h"
|
#include "AP_Baro_MS5611.h"
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
||||||
/*
|
/*
|
||||||
APM_BMP085.cpp - Arduino Library for BMP085 absolute pressure sensor
|
APM_BMP085.cpp - Arduino Library for BMP085 absolute pressure sensor
|
||||||
Code by Jordi Mu<EFBFBD>oz and Jose Julio. DIYDrones.com
|
Code by Jordi Mu<EFBFBD>oz and Jose Julio. DIYDrones.com
|
||||||
@ -41,7 +42,9 @@ extern "C" {
|
|||||||
#include "WConstants.h"
|
#include "WConstants.h"
|
||||||
}
|
}
|
||||||
|
|
||||||
#include <Wire.h>
|
#include <AP_Common.h>
|
||||||
|
#include <AP_Math.h> // ArduPilot Mega Vector/Matrix math Library
|
||||||
|
#include <I2C.h>
|
||||||
#include "AP_Baro_BMP085.h"
|
#include "AP_Baro_BMP085.h"
|
||||||
|
|
||||||
#define BMP085_ADDRESS 0x77 //(0xEE >> 1)
|
#define BMP085_ADDRESS 0x77 //(0xEE >> 1)
|
||||||
@ -55,34 +58,19 @@ extern "C" {
|
|||||||
|
|
||||||
|
|
||||||
// Public Methods //////////////////////////////////////////////////////////////
|
// Public Methods //////////////////////////////////////////////////////////////
|
||||||
void AP_Baro_BMP085::init( AP_PeriodicProcess * scheduler )
|
bool AP_Baro_BMP085::init( AP_PeriodicProcess * scheduler )
|
||||||
{
|
{
|
||||||
byte buff[22];
|
byte buff[22];
|
||||||
int i = 0;
|
|
||||||
|
|
||||||
pinMode(BMP085_EOC, INPUT); // End Of Conversion (PC7) input
|
pinMode(BMP085_EOC, INPUT); // End Of Conversion (PC7) input
|
||||||
|
|
||||||
oss = 3; // Over Sampling setting 3 = High resolution
|
oss = 3; // Over Sampling setting 3 = High resolution
|
||||||
BMP085_State = 0; // Initial state
|
BMP085_State = 0; // Initial state
|
||||||
|
|
||||||
// We read the calibration data registers
|
// We read the calibration data registers
|
||||||
Wire.beginTransmission(BMP085_ADDRESS);
|
if (I2c.read(BMP085_ADDRESS, 0xAA, 22, buff) != 0) {
|
||||||
Wire.send(0xAA);
|
healthy = false;
|
||||||
if (Wire.endTransmission() != 0) {
|
return false;
|
||||||
// Error!
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
Wire.requestFrom(BMP085_ADDRESS, 22);
|
|
||||||
|
|
||||||
//Wire.endTransmission();
|
|
||||||
while(Wire.available()){
|
|
||||||
buff[i] = Wire.receive(); // receive one byte
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
if (i != 22) {
|
|
||||||
// Error!
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ac1 = ((int)buff[0] << 8) | buff[1];
|
ac1 = ((int)buff[0] << 8) | buff[1];
|
||||||
@ -97,10 +85,12 @@ void AP_Baro_BMP085::init( AP_PeriodicProcess * scheduler )
|
|||||||
mc = ((int)buff[18] << 8) | buff[19];
|
mc = ((int)buff[18] << 8) | buff[19];
|
||||||
md = ((int)buff[20] << 8) | buff[21];
|
md = ((int)buff[20] << 8) | buff[21];
|
||||||
|
|
||||||
//Send a command to read Temp
|
//Send a command to read Temp
|
||||||
Command_ReadTemp();
|
Command_ReadTemp();
|
||||||
BMP085_State = 1;
|
BMP085_State = 1;
|
||||||
return;
|
|
||||||
|
healthy = true;
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read the sensor. This is a state machine
|
// Read the sensor. This is a state machine
|
||||||
@ -152,48 +142,27 @@ int32_t AP_Baro_BMP085::get_raw_temp() {
|
|||||||
// Send command to Read Pressure
|
// Send command to Read Pressure
|
||||||
void AP_Baro_BMP085::Command_ReadPress()
|
void AP_Baro_BMP085::Command_ReadPress()
|
||||||
{
|
{
|
||||||
Wire.beginTransmission(BMP085_ADDRESS);
|
if (I2c.write(BMP085_ADDRESS, 0xF4, 0x34+(oss << 6)) != 0) {
|
||||||
Wire.send(0xF4);
|
healthy = false;
|
||||||
Wire.send(0x34+(oss << 6)); // write_register(0xF4, 0x34+(oversampling_setting << 6));
|
}
|
||||||
Wire.endTransmission();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read Raw Pressure values
|
// Read Raw Pressure values
|
||||||
void AP_Baro_BMP085::ReadPress()
|
void AP_Baro_BMP085::ReadPress()
|
||||||
{
|
{
|
||||||
byte msb;
|
uint8_t buf[3];
|
||||||
byte lsb;
|
|
||||||
byte xlsb;
|
|
||||||
|
|
||||||
Wire.beginTransmission(BMP085_ADDRESS);
|
if (I2c.read(BMP085_ADDRESS, 0xF6, 3, buf) != 0) {
|
||||||
Wire.send(0xF6);
|
healthy = false;
|
||||||
Wire.endTransmission();
|
return;
|
||||||
|
|
||||||
Wire.requestFrom(BMP085_ADDRESS, 3); // read a byte
|
|
||||||
|
|
||||||
while(!Wire.available()) {
|
|
||||||
// waiting
|
|
||||||
}
|
}
|
||||||
|
|
||||||
msb = Wire.receive();
|
RawPress = (((long)buf[0] << 16) | ((long)buf[1] << 8) | ((long)buf[2])) >> (8 - oss);
|
||||||
|
|
||||||
while(!Wire.available()) {
|
|
||||||
// waiting
|
|
||||||
}
|
|
||||||
|
|
||||||
lsb = Wire.receive();
|
|
||||||
|
|
||||||
while(!Wire.available()) {
|
|
||||||
// waiting
|
|
||||||
}
|
|
||||||
|
|
||||||
xlsb = Wire.receive();
|
|
||||||
RawPress = (((long)msb << 16) | ((long)lsb << 8) | ((long)xlsb)) >> (8 - oss);
|
|
||||||
|
|
||||||
if(_offset_press == 0){
|
if(_offset_press == 0){
|
||||||
_offset_press = RawPress;
|
_offset_press = RawPress;
|
||||||
RawPress = 0;
|
RawPress = 0;
|
||||||
}else{
|
} else{
|
||||||
RawPress -= _offset_press;
|
RawPress -= _offset_press;
|
||||||
}
|
}
|
||||||
// filter
|
// filter
|
||||||
@ -203,8 +172,9 @@ void AP_Baro_BMP085::ReadPress()
|
|||||||
_press_index = 0;
|
_press_index = 0;
|
||||||
|
|
||||||
RawPress = 0;
|
RawPress = 0;
|
||||||
|
|
||||||
// sum our filter
|
// sum our filter
|
||||||
for(uint8_t i = 0; i < PRESS_FILTER_SIZE; i++){
|
for (uint8_t i = 0; i < PRESS_FILTER_SIZE; i++){
|
||||||
RawPress += _press_filter[i];
|
RawPress += _press_filter[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -217,35 +187,27 @@ void AP_Baro_BMP085::ReadPress()
|
|||||||
// Send Command to Read Temperature
|
// Send Command to Read Temperature
|
||||||
void AP_Baro_BMP085::Command_ReadTemp()
|
void AP_Baro_BMP085::Command_ReadTemp()
|
||||||
{
|
{
|
||||||
Wire.beginTransmission(BMP085_ADDRESS);
|
if (I2c.write(BMP085_ADDRESS, 0xF4, 0x2E) != 0) {
|
||||||
Wire.send(0xF4);
|
healthy = false;
|
||||||
Wire.send(0x2E);
|
}
|
||||||
Wire.endTransmission();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read Raw Temperature values
|
// Read Raw Temperature values
|
||||||
void AP_Baro_BMP085::ReadTemp()
|
void AP_Baro_BMP085::ReadTemp()
|
||||||
{
|
{
|
||||||
byte tmp;
|
uint8_t buf[2];
|
||||||
Wire.beginTransmission(BMP085_ADDRESS);
|
|
||||||
Wire.send(0xF6);
|
|
||||||
Wire.endTransmission();
|
|
||||||
|
|
||||||
Wire.beginTransmission(BMP085_ADDRESS);
|
if (I2c.read(BMP085_ADDRESS, 0xF6, 2, buf) != 0) {
|
||||||
Wire.requestFrom(BMP085_ADDRESS,2);
|
healthy = false;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
RawTemp = buf[0];
|
||||||
|
RawTemp = (RawTemp << 8) | buf[1];
|
||||||
|
|
||||||
while(!Wire.available()); // wait
|
if (_offset_temp == 0){
|
||||||
RawTemp = Wire.receive();
|
|
||||||
|
|
||||||
while(!Wire.available()); // wait
|
|
||||||
tmp = Wire.receive();
|
|
||||||
|
|
||||||
RawTemp = RawTemp << 8 | tmp;
|
|
||||||
|
|
||||||
if(_offset_temp == 0){
|
|
||||||
_offset_temp = RawTemp;
|
_offset_temp = RawTemp;
|
||||||
RawTemp = 0;
|
RawTemp = 0;
|
||||||
}else{
|
} else {
|
||||||
RawTemp -= _offset_temp;
|
RawTemp -= _offset_temp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
||||||
#ifndef __AP_BARO_BMP085_H__
|
#ifndef __AP_BARO_BMP085_H__
|
||||||
#define __AP_BARO_BMP085_H__
|
#define __AP_BARO_BMP085_H__
|
||||||
|
|
||||||
@ -16,7 +17,7 @@ class AP_Baro_BMP085 : public AP_Baro
|
|||||||
|
|
||||||
|
|
||||||
/* AP_Baro public interface: */
|
/* AP_Baro public interface: */
|
||||||
void init(AP_PeriodicProcess * scheduler);
|
bool init(AP_PeriodicProcess * scheduler);
|
||||||
uint8_t read();
|
uint8_t read();
|
||||||
int32_t get_pressure();
|
int32_t get_pressure();
|
||||||
int16_t get_temperature();
|
int16_t get_temperature();
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
// AVR LibC Includes
|
// AVR LibC Includes
|
||||||
@ -14,9 +15,10 @@ AP_Baro_BMP085_HIL::AP_Baro_BMP085_HIL()
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Public Methods //////////////////////////////////////////////////////////////
|
// Public Methods //////////////////////////////////////////////////////////////
|
||||||
void AP_Baro_BMP085_HIL::init(AP_PeriodicProcess * scheduler)
|
bool AP_Baro_BMP085_HIL::init(AP_PeriodicProcess * scheduler)
|
||||||
{
|
{
|
||||||
BMP085_State=1;
|
BMP085_State=1;
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -46,6 +48,7 @@ void AP_Baro_BMP085_HIL::setHIL(float _Temp, float _Press)
|
|||||||
// TODO: map floats to raw
|
// TODO: map floats to raw
|
||||||
Temp = _Temp;
|
Temp = _Temp;
|
||||||
Press = _Press;
|
Press = _Press;
|
||||||
|
healthy = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t AP_Baro_BMP085_HIL::get_pressure() {
|
int32_t AP_Baro_BMP085_HIL::get_pressure() {
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
||||||
|
|
||||||
#ifndef __AP_BARO_BMP085_HIL_H__
|
#ifndef __AP_BARO_BMP085_HIL_H__
|
||||||
#define __AP_BARO_BMP085_HIL_H__
|
#define __AP_BARO_BMP085_HIL_H__
|
||||||
@ -6,16 +7,18 @@
|
|||||||
|
|
||||||
class AP_Baro_BMP085_HIL
|
class AP_Baro_BMP085_HIL
|
||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
uint8_t BMP085_State;
|
uint8_t BMP085_State;
|
||||||
int16_t Temp;
|
int16_t Temp;
|
||||||
int32_t Press;
|
int32_t Press;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
AP_Baro_BMP085_HIL(); // Constructor
|
AP_Baro_BMP085_HIL(); // Constructor
|
||||||
//int Altitude;
|
//int Altitude;
|
||||||
|
bool healthy;
|
||||||
|
|
||||||
uint8_t oss;
|
uint8_t oss;
|
||||||
void init(AP_PeriodicProcess * scheduler);
|
bool init(AP_PeriodicProcess * scheduler);
|
||||||
uint8_t read();
|
uint8_t read();
|
||||||
int32_t get_pressure();
|
int32_t get_pressure();
|
||||||
int16_t get_temperature();
|
int16_t get_temperature();
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
||||||
/*
|
/*
|
||||||
APM_MS5611.cpp - Arduino Library for MS5611-01BA01 absolute pressure sensor
|
APM_MS5611.cpp - Arduino Library for MS5611-01BA01 absolute pressure sensor
|
||||||
Code by Jose Julio, Pat Hickey and Jordi Muñoz. DIYDrones.com
|
Code by Jose Julio, Pat Hickey and Jordi Muñoz. DIYDrones.com
|
||||||
@ -110,11 +111,11 @@ void AP_Baro_MS5611::_spi_write(uint8_t reg)
|
|||||||
|
|
||||||
// Public Methods //////////////////////////////////////////////////////////////
|
// Public Methods //////////////////////////////////////////////////////////////
|
||||||
// SPI should be initialized externally
|
// SPI should be initialized externally
|
||||||
void AP_Baro_MS5611::init( AP_PeriodicProcess *scheduler )
|
bool AP_Baro_MS5611::init( AP_PeriodicProcess *scheduler )
|
||||||
{
|
{
|
||||||
pinMode(MS5611_CS, OUTPUT); // Chip select Pin
|
pinMode(MS5611_CS, OUTPUT); // Chip select Pin
|
||||||
digitalWrite(MS5611_CS, HIGH);
|
digitalWrite(MS5611_CS, HIGH);
|
||||||
delay(1);
|
delay(1);
|
||||||
|
|
||||||
_spi_write(CMD_MS5611_RESET);
|
_spi_write(CMD_MS5611_RESET);
|
||||||
delay(4);
|
delay(4);
|
||||||
@ -128,14 +129,17 @@ void AP_Baro_MS5611::init( AP_PeriodicProcess *scheduler )
|
|||||||
C6 = _spi_read_16bits(CMD_MS5611_PROM_C6);
|
C6 = _spi_read_16bits(CMD_MS5611_PROM_C6);
|
||||||
|
|
||||||
|
|
||||||
//Send a command to read Temp first
|
//Send a command to read Temp first
|
||||||
_spi_write(CMD_CONVERT_D2_OSR4096);
|
_spi_write(CMD_CONVERT_D2_OSR4096);
|
||||||
_timer = micros();
|
_timer = micros();
|
||||||
_state = 1;
|
_state = 1;
|
||||||
Temp=0;
|
Temp=0;
|
||||||
Press=0;
|
Press=0;
|
||||||
|
|
||||||
scheduler->register_process( AP_Baro_MS5611::_update );
|
scheduler->register_process( AP_Baro_MS5611::_update );
|
||||||
|
|
||||||
|
healthy = true;
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
||||||
|
|
||||||
#ifndef __AP_BARO_MS5611_H__
|
#ifndef __AP_BARO_MS5611_H__
|
||||||
#define __AP_BARO_MS5611_H__
|
#define __AP_BARO_MS5611_H__
|
||||||
@ -10,7 +11,7 @@ class AP_Baro_MS5611 : public AP_Baro
|
|||||||
AP_Baro_MS5611() {} // Constructor
|
AP_Baro_MS5611() {} // Constructor
|
||||||
|
|
||||||
/* AP_Baro public interface: */
|
/* AP_Baro public interface: */
|
||||||
void init(AP_PeriodicProcess *scheduler);
|
bool init(AP_PeriodicProcess *scheduler);
|
||||||
uint8_t read();
|
uint8_t read();
|
||||||
int32_t get_pressure(); // in mbar*100 units
|
int32_t get_pressure(); // in mbar*100 units
|
||||||
int16_t get_temperature(); // in celsius degrees * 100 units
|
int16_t get_temperature(); // in celsius degrees * 100 units
|
||||||
|
@ -4,27 +4,42 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <FastSerial.h>
|
#include <FastSerial.h>
|
||||||
#include <Wire.h>
|
#include <I2C.h>
|
||||||
#include <APM_BMP085.h> // ArduPilot Mega BMP085 Library
|
#include <SPI.h>
|
||||||
|
#include <AP_Baro.h> // ArduPilot Mega BMP085 Library
|
||||||
|
#include <Arduino_Mega_ISR_Registry.h>
|
||||||
|
#include <AP_PeriodicProcess.h>
|
||||||
|
#include <AP_InertialSensor.h>
|
||||||
|
#include <AP_Math.h>
|
||||||
|
#include <AP_Common.h>
|
||||||
|
|
||||||
APM_BMP085_Class APM_BMP085;
|
#ifndef APM2_HARDWARE
|
||||||
|
# define APM2_HARDWARE 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
AP_Baro_BMP085 APM_BMP085(APM2_HARDWARE);
|
||||||
|
|
||||||
unsigned long timer;
|
unsigned long timer;
|
||||||
|
|
||||||
FastSerialPort0(Serial);
|
FastSerialPort0(Serial);
|
||||||
|
|
||||||
#ifdef APM2_HARDWARE
|
|
||||||
static bool apm2_hardware = true;
|
Arduino_Mega_ISR_Registry isr_registry;
|
||||||
#else
|
AP_TimerProcess scheduler;
|
||||||
static bool apm2_hardware = false;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void setup()
|
void setup()
|
||||||
{
|
{
|
||||||
Serial.begin(115200);
|
Serial.begin(115200);
|
||||||
Serial.println("ArduPilot Mega BMP085 library test");
|
Serial.println("ArduPilot Mega BMP085 library test");
|
||||||
Serial.println("Initialising barometer..."); delay(100);
|
Serial.println("Initialising barometer..."); delay(100);
|
||||||
if (!APM_BMP085.Init(1, apm2_hardware)) {
|
|
||||||
|
I2c.begin();
|
||||||
|
I2c.timeOut(20);
|
||||||
|
|
||||||
|
isr_registry.init();
|
||||||
|
scheduler.init(&isr_registry);
|
||||||
|
|
||||||
|
if (!APM_BMP085.init(&scheduler)) {
|
||||||
Serial.println("Barometer initialisation FAILED\n");
|
Serial.println("Barometer initialisation FAILED\n");
|
||||||
}
|
}
|
||||||
Serial.println("initialisation complete."); delay(100);
|
Serial.println("initialisation complete."); delay(100);
|
||||||
@ -34,19 +49,22 @@ void setup()
|
|||||||
|
|
||||||
void loop()
|
void loop()
|
||||||
{
|
{
|
||||||
int ch;
|
|
||||||
float tmp_float;
|
float tmp_float;
|
||||||
float Altitude;
|
float Altitude;
|
||||||
|
|
||||||
if((millis()- timer) > 50){
|
if((millis()- timer) > 50){
|
||||||
timer = millis();
|
timer = millis();
|
||||||
APM_BMP085.Read();
|
APM_BMP085.read();
|
||||||
|
if (!APM_BMP085.healthy) {
|
||||||
|
Serial.println("not healthy");
|
||||||
|
return;
|
||||||
|
}
|
||||||
Serial.print("Pressure:");
|
Serial.print("Pressure:");
|
||||||
Serial.print(APM_BMP085.Press);
|
Serial.print(APM_BMP085.get_pressure());
|
||||||
Serial.print(" Temperature:");
|
Serial.print(" Temperature:");
|
||||||
Serial.print(APM_BMP085.Temp / 10.0);
|
Serial.print(APM_BMP085.get_temperature());
|
||||||
Serial.print(" Altitude:");
|
Serial.print(" Altitude:");
|
||||||
tmp_float = (APM_BMP085.Press / 101325.0);
|
tmp_float = (APM_BMP085.get_pressure() / 101325.0);
|
||||||
tmp_float = pow(tmp_float, 0.190295);
|
tmp_float = pow(tmp_float, 0.190295);
|
||||||
Altitude = 44330 * (1.0 - tmp_float);
|
Altitude = 44330 * (1.0 - tmp_float);
|
||||||
Serial.print(Altitude);
|
Serial.print(Altitude);
|
||||||
|
Loading…
Reference in New Issue
Block a user