Change to comply with mbed os 5.1, as the attach function as used has been deprecated

Dependents:   Barometer-Example LoRaWAN-demo-72-bootcamp

Fork of BMP085 by silabs-abakurs

BMP085 library supporting mbed os low power

Revision:
0:fb197da45ba8
Child:
1:33acd2e1edab
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/BMP085.cpp	Sun Nov 15 18:05:18 2015 +0000
@@ -0,0 +1,121 @@
+#include "BMP085.h"
+
+void BMP085::init(void) {
+    _callback.attach(this, &BMP085::_callback_handler);
+    
+    _cal_data.ac1 = read_cal_register(BMP085_CAL_AC1);
+    _cal_data.ac2 = read_cal_register(BMP085_CAL_AC2);
+    _cal_data.ac3 = read_cal_register(BMP085_CAL_AC3);
+    _cal_data.ac4 = read_cal_register(BMP085_CAL_AC4);
+    _cal_data.ac5 = read_cal_register(BMP085_CAL_AC5);
+    _cal_data.ac6 = read_cal_register(BMP085_CAL_AC6);
+    _cal_data.b1 = read_cal_register(BMP085_CAL_B1);
+    _cal_data.b2 = read_cal_register(BMP085_CAL_B2);
+    _cal_data.mb = read_cal_register(BMP085_CAL_MB);
+    _cal_data.mc = read_cal_register(BMP085_CAL_MC);
+    _cal_data.md = read_cal_register(BMP085_CAL_MD);
+}
+
+uint16_t BMP085::read_cal_register(BMP085_Register reg) {
+    _tx_buf[0] = reg;
+    _state = BMP085_BUSY;
+    _i2c.transfer(BMP085_ADDR, (char*)_tx_buf, 1, (char*)_rx_buf, 2, _callback);
+    while(_state != BMP085_IDLE) {
+        sleep();
+    }
+    return (_rx_buf[0] << 8) | _rx_buf[1];
+}
+
+uint16_t BMP085::read_uc_temperature(void) {
+    LowPowerTimeout delay;
+    _tx_buf[0] = BMP085_CTRL;
+    _tx_buf[1] = BMP085_CMD_READ_TEMP;
+    _state = BMP085_BUSY;
+    _i2c.transfer(BMP085_ADDR, (char*)_tx_buf, 2, (char*)NULL, 0, _callback);
+    while(_state != BMP085_IDLE) {
+        sleep();
+    }
+
+    _state = BMP085_BUSY;
+    delay.attach(this, &BMP085::_callback_handler, 0.01);
+    while(_state != BMP085_IDLE) {
+        sleep();
+    }
+
+    _tx_buf[0] = BMP085_DATA_TEMP;
+    _state = BMP085_BUSY;
+    _i2c.transfer(BMP085_ADDR, (char*)_tx_buf, 1, (char*)_rx_buf, 2, _callback);
+    while(_state != BMP085_IDLE) {
+        sleep();
+    }
+    return (_rx_buf[0] << 8) | _rx_buf[1];
+}
+
+uint32_t BMP085::read_uc_pressure(void) {
+    LowPowerTimeout delay;
+    _tx_buf[0] = BMP085_CTRL;
+    _tx_buf[1] = BMP085_CMD_READ_PRESSURE + ((uint8_t)_mode << 6);
+    _state = BMP085_BUSY;
+    _i2c.transfer(BMP085_ADDR, (char*)_tx_buf, 2, (char*)NULL, 0, _callback);
+    while(_state != BMP085_IDLE) {
+        sleep();
+    }
+
+    _state = BMP085_BUSY;
+    delay.attach(this, &BMP085::_callback_handler, 0.01f);
+    while(_state != BMP085_IDLE) {
+        sleep();
+    }
+
+    _tx_buf[0] = BMP085_DATA_PRESSURE;
+    _state = BMP085_BUSY;
+    _i2c.transfer(BMP085_ADDR, (char*)_tx_buf, 1, (char*)_rx_buf, 3, _callback);
+    while(_state != BMP085_IDLE) {
+        sleep();
+    }
+    return ((_rx_buf[0] << 16) | (_rx_buf[1] << 8) | _rx_buf[2]) >> (8 - (uint8_t)_mode);    
+}
+
+void BMP085::measure() {
+    int t, p, ut, up, x1, x2, x3, b3, b5, b6;
+    uint32_t b4, b7;
+
+    ut = read_uc_temperature();
+
+    x1 = (ut - _cal_data.ac6) * _cal_data.ac5 / (1 << 15);
+    x2 = (int)_cal_data.mc * (1 << 11) / (x1 + _cal_data.md);
+    b5 = x1 + x2;
+    t = (b5 + 8) / (1 << 4);
+    _temperature = (float)t / 10.0;
+    
+    up = read_uc_pressure();
+    
+    b6 = b5 - 4000;
+    x1 = (_cal_data.b2 * (b6 * b6 / (1 << 12))) / (1 << 11);
+    x2 = _cal_data.ac2 * b6 / (1 << 11);
+    x3 = x1 + x2;
+    b3 = ((((unsigned int)_cal_data.ac1 * 4 + x3) << (int)_mode) + 2) / 4;
+    x1 = _cal_data.ac3 * b6 / (1 << 13);
+    x2 = (_cal_data.b1 * (b6 * b6 / (1 << 12))) / (1 << 16);
+    x3 = ((x1 + x2) + 2) / (1 << 2);
+    b4 = _cal_data.ac4 * (unsigned int)(x3 + 32768) / (1 << 15);
+    b7 = ((unsigned int)up - b3) * (50000 >> (int)_mode);
+    if (b7 < (unsigned int)0x80000000) {
+        p = (b7 * 2) / b4;
+    } else {
+        p = (b7 / b4) * 2;
+    }
+    x1 = (p / (1 << 8)) * (p / (1 << 8));
+    x1 = (x1 * 3038) / (1 << 16);
+    x2 = (-7357 * p) / (1 << 16);
+    p = p + (x1 + x2 + 3791) / (1 << 4);
+    _pressure = (float)p / 100.0;
+}
+
+void BMP085::_callback_handler(int event) {
+    _state = BMP085_IDLE;
+}
+
+void BMP085::_callback_handler() {
+    _state = BMP085_IDLE;
+}