read pressure and temperature from LPS25h.

Dependencies:   mbed

LPS25H/LPS25H.cpp

Committer:
onaka
Date:
2015-04-13
Revision:
2:0c2bb6fe6885
Child:
3:844fb47ba7a2

File content as of revision 2:0c2bb6fe6885:

//**********************
// LPS25H.cpp for mbed
//
// LPS25H lps25h(P0_5,P0_4);
// or
// I2C i2c(P0_5,P0_4);
// LPS25H lps25h(i2c);
//
// (C)Copyright 2014 All rights reserved by Y.Onodera
// http://einstlab.web.fc2.com
//**********************

#include "mbed.h"
#include "LPS25H.h"

LPS25H::LPS25H (PinName sda, PinName scl) : _i2c(sda, scl) {
    init();
}
LPS25H::LPS25H (I2C& p_i2c) : _i2c(p_i2c) {
    init();
}

void LPS25H::put(unsigned char a, unsigned char b)
{
    buf[0]=a;
    buf[1]=b;
    _i2c.write(LPS25H_ADDR, buf, 2);
}


void LPS25H::get(unsigned char a)
{
    buf[0] = a;
    _i2c.write(LPS25H_ADDR, buf, 1, true); // no stop, repeated
    _i2c.read( LPS25H_ADDR, buf, 1);

}

long LPS25H::pressure()
{

    // XL first and H last
    // get press_xl
    get(LPS25H_PRESS_OUT_XL);
    press.byte.LB=buf[0];
    // get tpress_low
    get(LPS25H_PRESS_OUT_L);
    press.byte.HB=buf[0];
    // get press_high
    get(LPS25H_PRESS_OUT_H);
    press.byte.UB=buf[0];
    return press.Val;
 
    // hPa = press.Val / 4096
    // Pa = press.Val / 40.96   
}


short LPS25H::temperature()
{

    // L first and H last
    // get tpress_low
    get(LPS25H_TEMP_OUT_L);
    temp.byte.LB=buf[0];
    // get press_high
    get(LPS25H_TEMP_OUT_H);
    temp.byte.HB=buf[0];
    return temp.S;
 
    // C = 42.5 + temp.S / 480
    // range:0 to 80C
    // accuracy:+-2C
}


void LPS25H::init()
{
    // Resolution config
    put(LPS25H_RES_CONF, 0x05);
    // FIFO 4samples moving average
    put(LPS25H_FIFO_CTRL, 0xC3);
    // FIFO Enable
    put(LPS25H_CTRL_REG2, 0x40);
    // Power ON Cycle=12.5Hz
    put(LPS25H_CTRL_REG1, 0xB0);
}