You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
88 lines
2.2 KiB
88 lines
2.2 KiB
#include "bmx055_gyro.h"
|
|
|
|
#include <cassert>
|
|
#include <cmath>
|
|
|
|
#include "common/swaglog.h"
|
|
#include "common/util.h"
|
|
|
|
#define DEG2RAD(x) ((x) * M_PI / 180.0)
|
|
|
|
|
|
BMX055_Gyro::BMX055_Gyro(I2CBus *bus) : I2CSensor(bus) {}
|
|
|
|
int BMX055_Gyro::init() {
|
|
int ret = verify_chip_id(BMX055_GYRO_I2C_REG_ID, {BMX055_GYRO_CHIP_ID});
|
|
if (ret == -1) return -1;
|
|
|
|
ret = set_register(BMX055_GYRO_I2C_REG_LPM1, BMX055_GYRO_NORMAL_MODE);
|
|
if (ret < 0) {
|
|
goto fail;
|
|
}
|
|
// bmx055 gyro has a 30ms wakeup time from deep suspend mode
|
|
util::sleep_for(50);
|
|
|
|
// High bandwidth
|
|
// ret = set_register(BMX055_GYRO_I2C_REG_HBW, BMX055_GYRO_HBW_ENABLE);
|
|
// if (ret < 0) {
|
|
// goto fail;
|
|
// }
|
|
|
|
// Low bandwidth
|
|
ret = set_register(BMX055_GYRO_I2C_REG_HBW, BMX055_GYRO_HBW_DISABLE);
|
|
if (ret < 0) {
|
|
goto fail;
|
|
}
|
|
|
|
// 116 Hz filter
|
|
ret = set_register(BMX055_GYRO_I2C_REG_BW, BMX055_GYRO_BW_116HZ);
|
|
if (ret < 0) {
|
|
goto fail;
|
|
}
|
|
|
|
// +- 125 deg/s range
|
|
ret = set_register(BMX055_GYRO_I2C_REG_RANGE, BMX055_GYRO_RANGE_125);
|
|
if (ret < 0) {
|
|
goto fail;
|
|
}
|
|
|
|
fail:
|
|
return ret;
|
|
}
|
|
|
|
int BMX055_Gyro::shutdown() {
|
|
// enter deep suspend mode (lowest power mode)
|
|
int ret = set_register(BMX055_GYRO_I2C_REG_LPM1, BMX055_GYRO_DEEP_SUSPEND);
|
|
if (ret < 0) {
|
|
LOGE("Could not move BMX055 GYRO in deep suspend mode!");
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
bool BMX055_Gyro::get_event(MessageBuilder &msg, uint64_t ts) {
|
|
uint64_t start_time = nanos_since_boot();
|
|
uint8_t buffer[6];
|
|
int len = read_register(BMX055_GYRO_I2C_REG_RATE_X_LSB, buffer, sizeof(buffer));
|
|
assert(len == 6);
|
|
|
|
// 16 bit = +- 125 deg/s
|
|
float scale = 125.0f / (1 << 15);
|
|
float x = -DEG2RAD(read_16_bit(buffer[0], buffer[1]) * scale);
|
|
float y = -DEG2RAD(read_16_bit(buffer[2], buffer[3]) * scale);
|
|
float z = DEG2RAD(read_16_bit(buffer[4], buffer[5]) * scale);
|
|
|
|
auto event = msg.initEvent().initGyroscope2();
|
|
event.setSource(cereal::SensorEventData::SensorSource::BMX055);
|
|
event.setVersion(1);
|
|
event.setSensor(SENSOR_GYRO_UNCALIBRATED);
|
|
event.setType(SENSOR_TYPE_GYROSCOPE_UNCALIBRATED);
|
|
event.setTimestamp(start_time);
|
|
|
|
float xyz[] = {x, y, z};
|
|
auto svec = event.initGyroUncalibrated();
|
|
svec.setV(xyz);
|
|
svec.setStatus(true);
|
|
|
|
return true;
|
|
}
|
|
|