split out gyro code
This commit is contained in:
@ -90,54 +90,6 @@ const uint8_t ACCEL_REG_TRIM_GP1 = 0x3C;
|
||||
const uint8_t ACCEL_REG_FIFO_CONFIG_1 = 0x3E;
|
||||
const uint8_t ACCEL_REG_FIFO_DATA = 0x3F;
|
||||
|
||||
const uint8_t GYRO_REG_CHIP_ID = 0x00;
|
||||
const uint8_t GYRO_REG_RATE_X_LSB = 0x02;
|
||||
const uint8_t GYRO_REG_RATE_X_MSB = 0x03;
|
||||
const uint8_t GYRO_REG_RATE_Y_LSB = 0x04;
|
||||
const uint8_t GYRO_REG_RATE_Y_MSB = 0x05;
|
||||
const uint8_t GYRO_REG_RATE_Z_LSB = 0x06;
|
||||
const uint8_t GYRO_REG_RATE_Z_MSB = 0x07;
|
||||
const uint8_t GYRO_REG_INT_STATUS_0 = 0x09;
|
||||
const uint8_t GYRO_REG_INT_STATUS_1 = 0x0A;
|
||||
const uint8_t GYRO_REG_INT_STATUS_2 = 0x0B;
|
||||
const uint8_t GYRO_REG_INT_STATUS_3 = 0x0C;
|
||||
const uint8_t GYRO_REG_FIFO_STATUS = 0x0E;
|
||||
const uint8_t GYRO_REG_RANGE = 0x0F;
|
||||
const uint8_t GYRO_REG_BW = 0x10;
|
||||
const uint8_t GYRO_REG_LPM1 = 0x11;
|
||||
const uint8_t GYRO_REG_LPM2 = 0x12;
|
||||
const uint8_t GYRO_REG_RATE_HBW = 0x13;
|
||||
const uint8_t GYRO_REG_BGW_SOFTRESET = 0x14;
|
||||
const uint8_t GYRO_REG_INT_EN_0 = 0x15;
|
||||
const uint8_t GYRO_REG_INT_EN_1 = 0x16;
|
||||
const uint8_t GYRO_REG_INT_MAP_0 = 0x17;
|
||||
const uint8_t GYRO_REG_INT_MAP_1 = 0x18;
|
||||
const uint8_t GYRO_REG_INT_MAP_2 = 0x19;
|
||||
const uint8_t GYRO_REG_INT_SOURCE_1 = 0x1A;
|
||||
const uint8_t GYRO_REG_INT_SOURCE_2 = 0x1B;
|
||||
// const uint8_t GYRO_REG_ = 0x1C;
|
||||
// const uint8_t GYRO_REG_ = 0x1E;
|
||||
const uint8_t GYRO_REG_INT_RST_LATCH = 0x21;
|
||||
const uint8_t GYRO_REG_HIGH_TH_X = 0x22;
|
||||
const uint8_t GYRO_REG_HIGH_DUR_X = 0x23;
|
||||
const uint8_t GYRO_REG_HIGH_TH_Y = 0x24;
|
||||
const uint8_t GYRO_REG_HIGH_DUR_Y = 0x25;
|
||||
const uint8_t GYRO_REG_HIGH_TH_Z = 0x26;
|
||||
const uint8_t GYRO_REG_HIGH_DUR_Z = 0x27;
|
||||
const uint8_t GYRO_REG_SOC = 0x31;
|
||||
const uint8_t GYRO_REG_A_FOC = 0x32;
|
||||
const uint8_t GYRO_REG_TRIM_NVM_CTRL = 0x33;
|
||||
const uint8_t GYRO_REG_BGW_SPI3_WDT = 0x34;
|
||||
const uint8_t GYRO_REG_OFC1 = 0x36;
|
||||
const uint8_t GYRO_REG_OFC2 = 0x37;
|
||||
const uint8_t GYRO_REG_OFC3 = 0x38;
|
||||
const uint8_t GYRO_REG_OFC4 = 0x39;
|
||||
const uint8_t GYRO_REG_TRIM_GP0 = 0x3A;
|
||||
const uint8_t GYRO_REG_TRIM_GP1 = 0x3B;
|
||||
const uint8_t GYRO_REG_BIST = 0x3C;
|
||||
const uint8_t GYRO_REG_FIFO_CONFIG_0 = 0x3D;
|
||||
const uint8_t GYRO_REG_FIFO_CONFIG_1 = 0x3E;
|
||||
|
||||
const uint8_t MAG_REG_CHIP_ID = 0x40;
|
||||
const uint8_t MAG_REG_DATA_X_LSB = 0x42;
|
||||
const uint8_t MAG_REG_DATA_X_MSB = 0x43;
|
||||
@ -173,9 +125,6 @@ struct bma255_data
|
||||
int16_t accel_x;
|
||||
int16_t accel_y;
|
||||
int16_t accel_z;
|
||||
int16_t gyro_x;
|
||||
int16_t gyro_y;
|
||||
int16_t gyro_z;
|
||||
int16_t mag_x;
|
||||
int16_t mag_y;
|
||||
int16_t mag_z;
|
||||
@ -211,26 +160,13 @@ static int bma255_sample_fetch(const struct device *dev,
|
||||
data->accel_y = ((int16_t)sys_get_le16(&accel[2])) >> 4;
|
||||
data->accel_z = ((int16_t)sys_get_le16(&accel[4])) >> 4;
|
||||
|
||||
uint8_t gyro[6];
|
||||
struct i2c_dt_spec gyro_bus = config->bus;
|
||||
gyro_bus.addr = 0x68;
|
||||
ret = i2c_burst_read_dt(&gyro_bus, GYRO_REG_RATE_X_LSB, gyro, sizeof(gyro));
|
||||
if (ret < 0)
|
||||
{
|
||||
LOG_ERR("Failed to read gyro registers!");
|
||||
return ret;
|
||||
}
|
||||
data->gyro_x = ((int16_t)sys_get_le16(&gyro[0]));
|
||||
data->gyro_y = ((int16_t)sys_get_le16(&gyro[2]));
|
||||
data->gyro_z = ((int16_t)sys_get_le16(&gyro[4]));
|
||||
|
||||
uint8_t mag[6];
|
||||
struct i2c_dt_spec mag_bus = config->bus;
|
||||
mag_bus.addr = 0x10;
|
||||
ret = i2c_burst_read_dt(&mag_bus, MAG_REG_DATA_X_LSB, mag, sizeof(mag));
|
||||
if (ret < 0)
|
||||
{
|
||||
LOG_ERR("Failed to read gyro registers!");
|
||||
LOG_ERR("Failed to read mag registers!");
|
||||
return ret;
|
||||
}
|
||||
data->mag_x = ((int16_t)sys_get_le16(&mag[0])) >> 1;
|
||||
@ -289,28 +225,6 @@ static int bma255_channel_get(const struct device *dev,
|
||||
val->val2 = (accel - val->val1) * 1000000;
|
||||
break;
|
||||
}
|
||||
// radians/second
|
||||
case SENSOR_CHAN_GYRO_X:
|
||||
{
|
||||
float rate = data->gyro_x * 2000.0 / 32767;
|
||||
val->val1 = rate;
|
||||
val->val2 = (rate - val->val1) * 1000000;
|
||||
break;
|
||||
}
|
||||
case SENSOR_CHAN_GYRO_Y:
|
||||
{
|
||||
float rate = data->gyro_y * 2000.0 / 32767;
|
||||
val->val1 = rate;
|
||||
val->val2 = (rate - val->val1) * 1000000;
|
||||
break;
|
||||
}
|
||||
case SENSOR_CHAN_GYRO_Z:
|
||||
{
|
||||
float rate = data->gyro_z * 2000.0 / 32767;
|
||||
val->val1 = rate;
|
||||
val->val2 = (rate - val->val1) * 1000000;
|
||||
break;
|
||||
}
|
||||
// Gauss
|
||||
case SENSOR_CHAN_MAGN_X:
|
||||
{
|
||||
@ -394,21 +308,6 @@ static int bma255_init(const struct device *dev)
|
||||
uint8_t hbw = (1 << 7); // data_high_bw (read filtered data) and enable lsb/msb shadowing
|
||||
i2c_burst_write_dt(&config->bus, ACCEL_REG_ACCD_HBW, &hbw, sizeof(hbw));
|
||||
|
||||
struct i2c_dt_spec gyro_bus = config->bus;
|
||||
gyro_bus.addr = 0x68;
|
||||
uint8_t gyro_chip_id;
|
||||
ret = i2c_burst_read_dt(&gyro_bus, GYRO_REG_CHIP_ID, &gyro_chip_id, sizeof(gyro_chip_id));
|
||||
if (ret < 0)
|
||||
{
|
||||
LOG_ERR("Failed to read gyro chip ID register!");
|
||||
return ret;
|
||||
}
|
||||
const uint8_t GYRO_CHIP_ID = 0x0f;
|
||||
if (gyro_chip_id != GYRO_CHIP_ID)
|
||||
{
|
||||
LOG_ERR("Gyro chip ID read from %s incorrect. Read 0x%02X, expected 0x%02X", dev->name, gyro_chip_id, GYRO_CHIP_ID);
|
||||
}
|
||||
|
||||
struct i2c_dt_spec mag_bus = config->bus;
|
||||
mag_bus.addr = 0x10;
|
||||
|
||||
|
Reference in New Issue
Block a user