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:
George Oikonomou 2015-05-01 16:51:32 +01:00
parent eb5b11a85a
commit 6e7d52b5df
3 changed files with 37 additions and 60 deletions

View file

@ -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 */

View file

@ -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) {
elements = MPU_9250_SENSOR_TYPE_NONE; /* Then check our state */
enable_sensor(0); elements = MPU_9250_SENSOR_TYPE_NONE;
while(ti_lib_i2c_master_busy(I2C0_BASE)); ctimer_stop(&startup_timer);
enabled = SENSOR_STATUS_DISABLED; sensor_sleep();
while(ti_lib_i2c_master_busy(I2C0_BASE));
state = SENSOR_STATE_DISABLED;
ti_lib_gpio_pin_clear(BOARD_MPU_POWER);
}
} }
break; break;
case MPU_9250_SENSOR_SHUTDOWN:
ti_lib_gpio_pin_write(BOARD_MPU_POWER, 0);
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);

View file

@ -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