Improve MPU power-cycling logic:
* Keep MPU_PWR low when the sensor is not in use * Deselect the sensor when not in use, in order to restore the I2C ping state * Explicitly control the MPU_INT pin * Don't shutdown the sensor when it's shut down * Remove explicit shutdown-related API extension. It is no longer required
This commit is contained in:
parent
eb5b11a85a
commit
6e7d52b5df
3 changed files with 37 additions and 60 deletions
|
@ -74,7 +74,8 @@ shutdown_handler(uint8_t mode)
|
||||||
SENSORS_DEACTIVATE(opt_3001_sensor);
|
SENSORS_DEACTIVATE(opt_3001_sensor);
|
||||||
SENSORS_DEACTIVATE(tmp_007_sensor);
|
SENSORS_DEACTIVATE(tmp_007_sensor);
|
||||||
SENSORS_DEACTIVATE(hdc_1000_sensor);
|
SENSORS_DEACTIVATE(hdc_1000_sensor);
|
||||||
mpu_9250_sensor.configure(MPU_9250_SENSOR_SHUTDOWN, 0);
|
SENSORS_DEACTIVATE(mpu_9250_sensor);
|
||||||
|
ti_lib_gpio_pin_clear(BOARD_MPU_POWER);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* In all cases, stop the I2C */
|
/* In all cases, stop the I2C */
|
||||||
|
|
|
@ -212,12 +212,12 @@ static uint8_t acc_range_reg;
|
||||||
static uint8_t val;
|
static uint8_t val;
|
||||||
static uint8_t interrupt_status;
|
static uint8_t interrupt_status;
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
#define SENSOR_STATUS_DISABLED 0
|
#define SENSOR_STATE_DISABLED 0
|
||||||
#define SENSOR_STATUS_BOOTING 1
|
#define SENSOR_STATE_BOOTING 1
|
||||||
#define SENSOR_STATUS_ENABLED 2
|
#define SENSOR_STATE_ENABLED 2
|
||||||
|
|
||||||
static int enabled = SENSOR_STATUS_DISABLED;
|
static int state = SENSOR_STATE_DISABLED;
|
||||||
static int elements;
|
static int elements = MPU_9250_SENSOR_TYPE_NONE;
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
/* 3 16-byte words for all sensor readings */
|
/* 3 16-byte words for all sensor readings */
|
||||||
#define SENSOR_DATA_BUF_SIZE 3
|
#define SENSOR_DATA_BUF_SIZE 3
|
||||||
|
@ -289,7 +289,9 @@ static void
|
||||||
select_axes(void)
|
select_axes(void)
|
||||||
{
|
{
|
||||||
val = ~mpu_config;
|
val = ~mpu_config;
|
||||||
|
SENSOR_SELECT();
|
||||||
sensor_common_write_reg(PWR_MGMT_2, &val, 1);
|
sensor_common_write_reg(PWR_MGMT_2, &val, 1);
|
||||||
|
SENSOR_DESELECT();
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
static void
|
static void
|
||||||
|
@ -334,37 +336,6 @@ acc_set_range(uint8_t new_range)
|
||||||
return success;
|
return success;
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
/**
|
|
||||||
* \brief Initialise the MPU
|
|
||||||
* \return True if success
|
|
||||||
*/
|
|
||||||
static bool
|
|
||||||
init_sensor(void)
|
|
||||||
{
|
|
||||||
bool ret;
|
|
||||||
|
|
||||||
interrupt_status = false;
|
|
||||||
acc_range = ACC_RANGE_INVALID;
|
|
||||||
mpu_config = 0; /* All axes off */
|
|
||||||
|
|
||||||
/* Device reset */
|
|
||||||
val = 0x80;
|
|
||||||
SENSOR_SELECT();
|
|
||||||
ret = sensor_common_write_reg(PWR_MGMT_1, &val, 1);
|
|
||||||
SENSOR_DESELECT();
|
|
||||||
|
|
||||||
if(ret) {
|
|
||||||
delay_ms(200);
|
|
||||||
|
|
||||||
/* Initial configuration */
|
|
||||||
acc_set_range(ACC_RANGE_8G);
|
|
||||||
/* Power save */
|
|
||||||
sensor_sleep();
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
/*---------------------------------------------------------------------------*/
|
|
||||||
/**
|
/**
|
||||||
* \brief Check whether a data or wake on motion interrupt has occurred
|
* \brief Check whether a data or wake on motion interrupt has occurred
|
||||||
* \return Return the interrupt status
|
* \return Return the interrupt status
|
||||||
|
@ -450,13 +421,13 @@ gyro_read(uint16_t *data)
|
||||||
/* Burst read of all gyroscope values */
|
/* Burst read of all gyroscope values */
|
||||||
success = sensor_common_read_reg(GYRO_XOUT_H, (uint8_t *)data, DATA_SIZE);
|
success = sensor_common_read_reg(GYRO_XOUT_H, (uint8_t *)data, DATA_SIZE);
|
||||||
|
|
||||||
SENSOR_DESELECT();
|
|
||||||
|
|
||||||
if(success) {
|
if(success) {
|
||||||
convert_to_le((uint8_t *)data, DATA_SIZE);
|
convert_to_le((uint8_t *)data, DATA_SIZE);
|
||||||
} else {
|
} else {
|
||||||
sensor_common_set_error_data((uint8_t *)data, DATA_SIZE);
|
sensor_common_set_error_data((uint8_t *)data, DATA_SIZE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SENSOR_DESELECT();
|
||||||
} else {
|
} else {
|
||||||
success = false;
|
success = false;
|
||||||
}
|
}
|
||||||
|
@ -514,15 +485,13 @@ gyro_convert(int16_t raw_data)
|
||||||
static void
|
static void
|
||||||
notify_ready(void *not_used)
|
notify_ready(void *not_used)
|
||||||
{
|
{
|
||||||
enabled = SENSOR_STATUS_ENABLED;
|
state = SENSOR_STATE_ENABLED;
|
||||||
sensors_changed(&mpu_9250_sensor);
|
sensors_changed(&mpu_9250_sensor);
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
static void
|
static void
|
||||||
initialise(void *not_used)
|
initialise(void *not_used)
|
||||||
{
|
{
|
||||||
init_sensor();
|
|
||||||
|
|
||||||
/* Configure the accelerometer range */
|
/* Configure the accelerometer range */
|
||||||
if((elements & MPU_9250_SENSOR_TYPE_ACC) != 0) {
|
if((elements & MPU_9250_SENSOR_TYPE_ACC) != 0) {
|
||||||
acc_set_range(MPU_9250_SENSOR_ACC_RANGE);
|
acc_set_range(MPU_9250_SENSOR_ACC_RANGE);
|
||||||
|
@ -537,7 +506,7 @@ static void
|
||||||
power_up(void)
|
power_up(void)
|
||||||
{
|
{
|
||||||
ti_lib_gpio_pin_write(BOARD_MPU_POWER, 1);
|
ti_lib_gpio_pin_write(BOARD_MPU_POWER, 1);
|
||||||
enabled = SENSOR_STATUS_BOOTING;
|
state = SENSOR_STATE_BOOTING;
|
||||||
|
|
||||||
ctimer_set(&startup_timer, SENSOR_BOOT_DELAY, initialise, NULL);
|
ctimer_set(&startup_timer, SENSOR_BOOT_DELAY, initialise, NULL);
|
||||||
}
|
}
|
||||||
|
@ -553,7 +522,7 @@ value(int type)
|
||||||
int rv;
|
int rv;
|
||||||
float converted_val = 0;
|
float converted_val = 0;
|
||||||
|
|
||||||
if(enabled == SENSOR_STATUS_DISABLED) {
|
if(state == SENSOR_STATE_DISABLED) {
|
||||||
PRINTF("MPU: Sensor Disabled\n");
|
PRINTF("MPU: Sensor Disabled\n");
|
||||||
return CC26XX_SENSOR_READING_ERROR;
|
return CC26XX_SENSOR_READING_ERROR;
|
||||||
}
|
}
|
||||||
|
@ -632,33 +601,42 @@ configure(int type, int enable)
|
||||||
{
|
{
|
||||||
switch(type) {
|
switch(type) {
|
||||||
case SENSORS_HW_INIT:
|
case SENSORS_HW_INIT:
|
||||||
|
ti_lib_rom_ioc_pin_type_gpio_input(BOARD_IOID_MPU_INT);
|
||||||
|
ti_lib_ioc_io_port_pull_set(BOARD_IOID_MPU_INT, IOC_IOPULL_DOWN);
|
||||||
|
ti_lib_ioc_io_hyst_set(BOARD_IOID_MPU_INT, IOC_HYST_ENABLE);
|
||||||
|
|
||||||
|
ti_lib_rom_ioc_pin_type_gpio_output(BOARD_IOID_MPU_POWER);
|
||||||
|
ti_lib_ioc_io_drv_strength_set(BOARD_IOID_MPU_POWER, IOC_CURRENT_4MA,
|
||||||
|
IOC_STRENGTH_MAX);
|
||||||
|
ti_lib_gpio_pin_clear(BOARD_MPU_POWER);
|
||||||
elements = MPU_9250_SENSOR_TYPE_NONE;
|
elements = MPU_9250_SENSOR_TYPE_NONE;
|
||||||
break;
|
break;
|
||||||
case SENSORS_ACTIVE:
|
case SENSORS_ACTIVE:
|
||||||
if((enable & MPU_9250_SENSOR_TYPE_ACC) != 0 ||
|
if(((enable & MPU_9250_SENSOR_TYPE_ACC) != 0) ||
|
||||||
(enable & MPU_9250_SENSOR_TYPE_GYRO) != 0) {
|
((enable & MPU_9250_SENSOR_TYPE_GYRO) != 0)) {
|
||||||
PRINTF("MPU: Enabling\n");
|
PRINTF("MPU: Enabling\n");
|
||||||
elements = enable & MPU_9250_SENSOR_TYPE_ALL;
|
elements = enable & MPU_9250_SENSOR_TYPE_ALL;
|
||||||
|
|
||||||
power_up();
|
power_up();
|
||||||
|
|
||||||
enabled = SENSOR_STATUS_BOOTING;
|
state = SENSOR_STATE_BOOTING;
|
||||||
} else {
|
} else {
|
||||||
PRINTF("MPU: Disabling\n");
|
PRINTF("MPU: Disabling\n");
|
||||||
ctimer_stop(&startup_timer);
|
if(HWREG(GPIO_BASE + GPIO_O_DOUT31_0) & BOARD_MPU_POWER) {
|
||||||
|
/* Then check our state */
|
||||||
elements = MPU_9250_SENSOR_TYPE_NONE;
|
elements = MPU_9250_SENSOR_TYPE_NONE;
|
||||||
enable_sensor(0);
|
ctimer_stop(&startup_timer);
|
||||||
|
sensor_sleep();
|
||||||
while(ti_lib_i2c_master_busy(I2C0_BASE));
|
while(ti_lib_i2c_master_busy(I2C0_BASE));
|
||||||
enabled = SENSOR_STATUS_DISABLED;
|
state = SENSOR_STATE_DISABLED;
|
||||||
|
ti_lib_gpio_pin_clear(BOARD_MPU_POWER);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
break;
|
|
||||||
case MPU_9250_SENSOR_SHUTDOWN:
|
|
||||||
ti_lib_gpio_pin_write(BOARD_MPU_POWER, 0);
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return enabled;
|
return state;
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
/**
|
/**
|
||||||
|
@ -672,12 +650,12 @@ status(int type)
|
||||||
switch(type) {
|
switch(type) {
|
||||||
case SENSORS_ACTIVE:
|
case SENSORS_ACTIVE:
|
||||||
case SENSORS_READY:
|
case SENSORS_READY:
|
||||||
return enabled;
|
return state;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return SENSOR_STATUS_DISABLED;
|
return SENSOR_STATE_DISABLED;
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
SENSORS_SENSOR(mpu_9250_sensor, "MPU9250", value, configure, status);
|
SENSORS_SENSOR(mpu_9250_sensor, "MPU9250", value, configure, status);
|
||||||
|
|
|
@ -86,8 +86,6 @@
|
||||||
#define MPU_9250_SENSOR_TYPE_NONE 0
|
#define MPU_9250_SENSOR_TYPE_NONE 0
|
||||||
#define MPU_9250_SENSOR_TYPE_ALL (MPU_9250_SENSOR_TYPE_ACC | \
|
#define MPU_9250_SENSOR_TYPE_ALL (MPU_9250_SENSOR_TYPE_ACC | \
|
||||||
MPU_9250_SENSOR_TYPE_GYRO)
|
MPU_9250_SENSOR_TYPE_GYRO)
|
||||||
|
|
||||||
#define MPU_9250_SENSOR_SHUTDOWN 0xFF
|
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
/* Accelerometer range */
|
/* Accelerometer range */
|
||||||
#define MPU_9250_SENSOR_ACC_RANGE_2G 0
|
#define MPU_9250_SENSOR_ACC_RANGE_2G 0
|
||||||
|
|
Loading…
Reference in a new issue