From e27a07631e7a3615d5b83f328cebf9271f0767e8 Mon Sep 17 00:00:00 2001 From: Alessio Morale Date: Sun, 17 Feb 2013 02:02:12 +0100 Subject: [PATCH] op-848 MPU6000 support user configurabe accel/gyro scales and filter bandwidth. board definitions can override any of this settings for special applications. Also include cleanup from "magic numbers" and fix for inverted ranges --- flight/CopterControl/Makefile | 1 + flight/CopterControl/System/pios_board.c | 6 +- flight/PiOS/Common/pios_mpu6000.c | 261 +++++++++++++----- flight/PiOS/inc/pios_mpu6000.h | 7 +- flight/RevoMini/System/pios_board.c | 6 +- flight/RevoMini/UAVObjects.inc | 2 +- flight/Revolution/System/pios_board.c | 6 +- flight/Revolution/UAVObjects.inc | 1 + .../src/plugins/uavobjects/uavobjects.pro | 6 +- .../uavobjectdefinition/mpu6000settings.xml | 38 +++ 10 files changed, 245 insertions(+), 89 deletions(-) create mode 100644 shared/uavobjectdefinition/mpu6000settings.xml diff --git a/flight/CopterControl/Makefile b/flight/CopterControl/Makefile index 9b46bead1..dc20ea525 100644 --- a/flight/CopterControl/Makefile +++ b/flight/CopterControl/Makefile @@ -233,6 +233,7 @@ SRC += $(OPUAVSYNTHDIR)/ratedesired.c SRC += $(OPUAVSYNTHDIR)/baroaltitude.c SRC += $(OPUAVSYNTHDIR)/txpidsettings.c SRC += $(OPUAVSYNTHDIR)/airspeedactual.c +SRC += $(OPUAVSYNTHDIR)/mpu6000settings.c endif diff --git a/flight/CopterControl/System/pios_board.c b/flight/CopterControl/System/pios_board.c index 057767105..20f8e49a9 100644 --- a/flight/CopterControl/System/pios_board.c +++ b/flight/CopterControl/System/pios_board.c @@ -117,9 +117,9 @@ static const struct pios_mpu6000_cfg pios_mpu6000_cfg = { .interrupt_en = PIOS_MPU6000_INTEN_DATA_RDY, .User_ctl = PIOS_MPU6000_USERCTL_FIFO_EN | PIOS_MPU6000_USERCTL_DIS_I2C, .Pwr_mgmt_clk = PIOS_MPU6000_PWRMGMT_PLL_X_CLK, - .accel_range = PIOS_MPU6000_ACCEL_8G, - .gyro_range = PIOS_MPU6000_SCALE_500_DEG, - .filter = PIOS_MPU6000_LOWPASS_256_HZ, + .accel_range = PIOS_MPU6000_ACCEL_FROM_SETTINGS, + .gyro_range = PIOS_MPU6000_SCALE_FROM_SETTINGS, + .filter = PIOS_MPU6000_LOWPASS_FROM_SETTINGS, .orientation = PIOS_MPU6000_TOP_180DEG }; #endif /* PIOS_INCLUDE_MPU6000 */ diff --git a/flight/PiOS/Common/pios_mpu6000.c b/flight/PiOS/Common/pios_mpu6000.c index f62d09859..78ba7415d 100644 --- a/flight/PiOS/Common/pios_mpu6000.c +++ b/flight/PiOS/Common/pios_mpu6000.c @@ -31,7 +31,7 @@ /* Project Includes */ #include "pios.h" - +#include "mpu6000settings.h" #if defined(PIOS_INCLUDE_MPU6000) #include "fifo_buffer.h" @@ -48,6 +48,8 @@ struct mpu6000_dev { uint32_t slave_num; xQueueHandle queue; const struct pios_mpu6000_cfg * cfg; + enum pios_mpu6000_range gyro_range; + enum pios_mpu6000_accel_range accel_range; enum pios_mpu6000_dev_magic magic; }; @@ -62,6 +64,10 @@ static void PIOS_MPU6000_Config(struct pios_mpu6000_cfg const * cfg); static int32_t PIOS_MPU6000_SetReg(uint8_t address, uint8_t buffer); static int32_t PIOS_MPU6000_GetReg(uint8_t address); +static uint8_t getGyroRange(enum pios_mpu6000_range range); +static uint8_t getAccelRange(enum pios_mpu6000_accel_range accel); +static uint8_t getFilterSetting(enum pios_mpu6000_filter filter); + #define DEG_TO_RAD (M_PI / 180.0) #define GRAV 9.81f @@ -137,15 +143,24 @@ static void PIOS_MPU6000_Config(struct pios_mpu6000_cfg const * cfg) PIOS_MPU6000_Test(); + //initialize settings for acc/gyro Scale and filter + Mpu6000SettingsInitialize(); + // Reset chip - while (PIOS_MPU6000_SetReg(PIOS_MPU6000_PWR_MGMT_REG, 0x80) != 0); + while (PIOS_MPU6000_SetReg(PIOS_MPU6000_PWR_MGMT_REG, PIOS_MPU6000_PWRMGMT_IMU_RST) != 0); PIOS_DELAY_WaitmS(300); // Reset chip and fifo - while (PIOS_MPU6000_SetReg(PIOS_MPU6000_USER_CTRL_REG, 0x80 | 0x01 | 0x02 | 0x04) != 0); + while (PIOS_MPU6000_SetReg(PIOS_MPU6000_USER_CTRL_REG, + PIOS_MPU6000_USERCTL_GYRO_RST | + PIOS_MPU6000_USERCTL_SIG_COND | + PIOS_MPU6000_USERCTL_FIFO_RST) != 0); // Wait for reset to finish - while (PIOS_MPU6000_GetReg(PIOS_MPU6000_USER_CTRL_REG) & 0x07); + while (PIOS_MPU6000_GetReg(PIOS_MPU6000_USER_CTRL_REG) & + (PIOS_MPU6000_USERCTL_GYRO_RST | + PIOS_MPU6000_USERCTL_SIG_COND | + PIOS_MPU6000_USERCTL_FIFO_RST)); //Power management configuration while (PIOS_MPU6000_SetReg(PIOS_MPU6000_PWR_MGMT_REG, cfg->Pwr_mgmt_clk) != 0) ; @@ -158,8 +173,9 @@ static void PIOS_MPU6000_Config(struct pios_mpu6000_cfg const * cfg) // FIFO storage #if defined(PIOS_MPU6000_ACCEL) - // Set the accel scale - while (PIOS_MPU6000_SetReg(PIOS_MPU6000_ACCEL_CFG_REG, cfg->accel_range) != 0); + // Set the accel range + dev->accel_range = getAccelRange(cfg->accel_range); + while (PIOS_MPU6000_SetReg(PIOS_MPU6000_ACCEL_CFG_REG, dev->accel_range) != 0); while (PIOS_MPU6000_SetReg(PIOS_MPU6000_FIFO_EN_REG, cfg->Fifo_store | PIOS_MPU6000_ACCEL_OUT) != 0); #else @@ -170,10 +186,13 @@ static void PIOS_MPU6000_Config(struct pios_mpu6000_cfg const * cfg) while (PIOS_MPU6000_SetReg(PIOS_MPU6000_SMPLRT_DIV_REG, cfg->Smpl_rate_div) != 0) ; // Digital low-pass filter and scale - while (PIOS_MPU6000_SetReg(PIOS_MPU6000_DLPF_CFG_REG, cfg->filter) != 0) ; + uint8_t filterSetting; + filterSetting = getFilterSetting(cfg->filter); + while (PIOS_MPU6000_SetReg(PIOS_MPU6000_DLPF_CFG_REG, filterSetting) != 0) ; - // Digital low-pass filter and scale - while (PIOS_MPU6000_SetReg(PIOS_MPU6000_GYRO_CFG_REG, cfg->gyro_range) != 0) ; + // Gyro range + dev->gyro_range = getGyroRange(cfg->gyro_range); + while (PIOS_MPU6000_SetReg(PIOS_MPU6000_GYRO_CFG_REG, dev->gyro_range) != 0) ; // Interrupt configuration while (PIOS_MPU6000_SetReg(PIOS_MPU6000_USER_CTRL_REG, cfg->User_ctl) != 0) ; @@ -322,13 +341,14 @@ xQueueHandle PIOS_MPU6000_GetQueue() float PIOS_MPU6000_GetScale() { - switch (dev->cfg->gyro_range) { + switch (dev->gyro_range) { case PIOS_MPU6000_SCALE_250_DEG: return 1.0f / 131.0f; case PIOS_MPU6000_SCALE_500_DEG: return 1.0f / 65.5f; case PIOS_MPU6000_SCALE_1000_DEG: return 1.0f / 32.8f; + case PIOS_MPU6000_SCALE_FROM_SETTINGS: case PIOS_MPU6000_SCALE_2000_DEG: return 1.0f / 16.4f; } @@ -337,12 +357,13 @@ float PIOS_MPU6000_GetScale() float PIOS_MPU6000_GetAccelScale() { - switch (dev->cfg->accel_range) { + switch (dev->accel_range) { case PIOS_MPU6000_ACCEL_2G: return GRAV / 16384.0f; case PIOS_MPU6000_ACCEL_4G: return GRAV / 8192.0f; case PIOS_MPU6000_ACCEL_8G: + case PIOS_MPU6000_ACCEL_FROM_SETTINGS: return GRAV / 4096.0f; case PIOS_MPU6000_ACCEL_16G: return GRAV / 2048.0f; @@ -411,20 +432,20 @@ bool PIOS_MPU6000_IRQHandler(void) mpu6000_interval_us = PIOS_DELAY_DiffuS(timeval); timeval = PIOS_DELAY_GetRaw(); - if(!mpu6000_configured) + if (!mpu6000_configured) return false; mpu6000_count = PIOS_MPU6000_FifoDepth(); - if(mpu6000_count < sizeof(struct pios_mpu6000_data)) + if (mpu6000_count < sizeof(struct pios_mpu6000_data)) return false; - - if(PIOS_MPU6000_ClaimBus() != 0) + + if (PIOS_MPU6000_ClaimBus() != 0) return false; - - uint8_t mpu6000_send_buf[1+sizeof(struct pios_mpu6000_data)] = {PIOS_MPU6000_FIFO_REG | 0x80, 0, 0, 0, 0, 0, 0, 0, 0}; - uint8_t mpu6000_rec_buf[1+sizeof(struct pios_mpu6000_data)]; - - if(PIOS_SPI_TransferBlock(dev->spi_id, &mpu6000_send_buf[0], &mpu6000_rec_buf[0], sizeof(mpu6000_send_buf), NULL) < 0) { + + uint8_t mpu6000_send_buf[1 + sizeof(struct pios_mpu6000_data) ] = {PIOS_MPU6000_FIFO_REG | 0x80, 0, 0, 0, 0, 0, 0, 0, 0}; + uint8_t mpu6000_rec_buf[1 + sizeof(struct pios_mpu6000_data) ]; + + if (PIOS_SPI_TransferBlock(dev->spi_id, &mpu6000_send_buf[0], &mpu6000_rec_buf[0], sizeof(mpu6000_send_buf), NULL) < 0) { PIOS_MPU6000_ReleaseBus(); mpu6000_fails++; return false; @@ -437,85 +458,173 @@ bool PIOS_MPU6000_IRQHandler(void) // In the case where extras samples backed up grabbed an extra if (mpu6000_count >= (sizeof(data) * 2)) { mpu6000_fifo_backup++; - if(PIOS_MPU6000_ClaimBus() != 0) - return false; - - if(PIOS_SPI_TransferBlock(dev->spi_id, &mpu6000_send_buf[0], &mpu6000_rec_buf[0], sizeof(mpu6000_send_buf), NULL) < 0) { + if (PIOS_MPU6000_ClaimBus() != 0) + return false; + + if (PIOS_SPI_TransferBlock(dev->spi_id, &mpu6000_send_buf[0], &mpu6000_rec_buf[0], sizeof(mpu6000_send_buf), NULL) < 0) { PIOS_MPU6000_ReleaseBus(); mpu6000_fails++; return false; } - + PIOS_MPU6000_ReleaseBus(); } - + // Rotate the sensor to OP convention. The datasheet defines X as towards the right // and Y as forward. OP convention transposes this. Also the Z is defined negatively // to our convention #if defined(PIOS_MPU6000_ACCEL) // Currently we only support rotations on top so switch X/Y accordingly - switch(dev->cfg->orientation) { - case PIOS_MPU6000_TOP_0DEG: - data.accel_y = mpu6000_rec_buf[1] << 8 | mpu6000_rec_buf[2]; // chip X - data.accel_x = mpu6000_rec_buf[3] << 8 | mpu6000_rec_buf[4]; // chip Y - data.gyro_y = mpu6000_rec_buf[9] << 8 | mpu6000_rec_buf[10]; // chip X - data.gyro_x = mpu6000_rec_buf[11] << 8 | mpu6000_rec_buf[12]; // chip Y - break; - case PIOS_MPU6000_TOP_90DEG: - data.accel_y = -(mpu6000_rec_buf[3] << 8 | mpu6000_rec_buf[4]); // chip Y - data.accel_x = mpu6000_rec_buf[1] << 8 | mpu6000_rec_buf[2]; // chip X - data.gyro_y = -(mpu6000_rec_buf[11] << 8 | mpu6000_rec_buf[12]); // chip Y - data.gyro_x = mpu6000_rec_buf[9] << 8 | mpu6000_rec_buf[10]; // chip X - break; - case PIOS_MPU6000_TOP_180DEG: - data.accel_y = -(mpu6000_rec_buf[1] << 8 | mpu6000_rec_buf[2]); // chip X - data.accel_x = -(mpu6000_rec_buf[3] << 8 | mpu6000_rec_buf[4]); // chip Y - data.gyro_y = -(mpu6000_rec_buf[9] << 8 | mpu6000_rec_buf[10]); // chip X - data.gyro_x = -(mpu6000_rec_buf[11] << 8 | mpu6000_rec_buf[12]); // chip Y - break; - case PIOS_MPU6000_TOP_270DEG: - data.accel_y = mpu6000_rec_buf[3] << 8 | mpu6000_rec_buf[4]; // chip Y - data.accel_x = -(mpu6000_rec_buf[1] << 8 | mpu6000_rec_buf[2]); // chip X - data.gyro_y = mpu6000_rec_buf[11] << 8 | mpu6000_rec_buf[12]; // chip Y - data.gyro_x = -(mpu6000_rec_buf[9] << 8 | mpu6000_rec_buf[10]); // chip X - break; + switch (dev->cfg->orientation) { + case PIOS_MPU6000_TOP_0DEG: + data.accel_y = mpu6000_rec_buf[1] << 8 | mpu6000_rec_buf[2]; // chip X + data.accel_x = mpu6000_rec_buf[3] << 8 | mpu6000_rec_buf[4]; // chip Y + data.gyro_y = mpu6000_rec_buf[9] << 8 | mpu6000_rec_buf[10]; // chip X + data.gyro_x = mpu6000_rec_buf[11] << 8 | mpu6000_rec_buf[12]; // chip Y + break; + case PIOS_MPU6000_TOP_90DEG: + // -1 to bring it back to -32768 +32767 range + data.accel_y = -1 - (mpu6000_rec_buf[3] << 8 | mpu6000_rec_buf[4]); // chip Y + data.accel_x = mpu6000_rec_buf[1] << 8 | mpu6000_rec_buf[2]; // chip X + data.gyro_y = -1 - (mpu6000_rec_buf[11] << 8 | mpu6000_rec_buf[12]); // chip Y + data.gyro_x = mpu6000_rec_buf[9] << 8 | mpu6000_rec_buf[10]; // chip X + break; + case PIOS_MPU6000_TOP_180DEG: + data.accel_y = -1 - (mpu6000_rec_buf[1] << 8 | mpu6000_rec_buf[2]); // chip X + data.accel_x = -1 - (mpu6000_rec_buf[3] << 8 | mpu6000_rec_buf[4]); // chip Y + data.gyro_y = -1 - (mpu6000_rec_buf[9] << 8 | mpu6000_rec_buf[10]); // chip X + data.gyro_x = -1 - (mpu6000_rec_buf[11] << 8 | mpu6000_rec_buf[12]); // chip Y + break; + case PIOS_MPU6000_TOP_270DEG: + data.accel_y = mpu6000_rec_buf[3] << 8 | mpu6000_rec_buf[4]; // chip Y + data.accel_x = -1 - (mpu6000_rec_buf[1] << 8 | mpu6000_rec_buf[2]); // chip X + data.gyro_y = mpu6000_rec_buf[11] << 8 | mpu6000_rec_buf[12]; // chip Y + data.gyro_x = -1 - (mpu6000_rec_buf[9] << 8 | mpu6000_rec_buf[10]); // chip X + break; } - data.gyro_z = -(mpu6000_rec_buf[13] << 8 | mpu6000_rec_buf[14]); - data.accel_z = -(mpu6000_rec_buf[5] << 8 | mpu6000_rec_buf[6]); + data.gyro_z = -1 - (mpu6000_rec_buf[13] << 8 | mpu6000_rec_buf[14]); + data.accel_z = -1 - (mpu6000_rec_buf[5] << 8 | mpu6000_rec_buf[6]); data.temperature = mpu6000_rec_buf[7] << 8 | mpu6000_rec_buf[8]; #else data.gyro_x = mpu6000_rec_buf[3] << 8 | mpu6000_rec_buf[4]; data.gyro_y = mpu6000_rec_buf[5] << 8 | mpu6000_rec_buf[6]; - switch(dev->cfg->orientation) { - case PIOS_MPU6000_TOP_0DEG: - data.gyro_y = mpu6000_rec_buf[3] << 8 | mpu6000_rec_buf[4]; - data.gyro_x = mpu6000_rec_buf[5] << 8 | mpu6000_rec_buf[6]; - break; - case PIOS_MPU6000_TOP_90DEG: - data.gyro_y = -(mpu6000_rec_buf[5] << 8 | mpu6000_rec_buf[6]); // chip Y - data.gyro_x = mpu6000_rec_buf[3] << 8 | mpu6000_rec_buf[4]; // chip X - break; - case PIOS_MPU6000_TOP_180DEG: - data.gyro_y = -(mpu6000_rec_buf[3] << 8 | mpu6000_rec_buf[4]); - data.gyro_x = -(mpu6000_rec_buf[5] << 8 | mpu6000_rec_buf[6]); - break; - case PIOS_MPU6000_TOP_270DEG: - data.gyro_y = mpu6000_rec_buf[5] << 8 | mpu6000_rec_buf[6]; // chip Y - data.gyro_x = -(mpu6000_rec_buf[3] << 8 | mpu6000_rec_buf[4]); // chip X - break; + switch (dev->cfg->orientation) { + case PIOS_MPU6000_TOP_0DEG: + data.gyro_y = mpu6000_rec_buf[3] << 8 | mpu6000_rec_buf[4]; + data.gyro_x = mpu6000_rec_buf[5] << 8 | mpu6000_rec_buf[6]; + break; + case PIOS_MPU6000_TOP_90DEG: + data.gyro_y = -1 - (mpu6000_rec_buf[5] << 8 | mpu6000_rec_buf[6]); // chip Y + data.gyro_x = mpu6000_rec_buf[3] << 8 | mpu6000_rec_buf[4]; // chip X + break; + case PIOS_MPU6000_TOP_180DEG: + data.gyro_y = -1 - (mpu6000_rec_buf[3] << 8 | mpu6000_rec_buf[4]); + data.gyro_x = -1 - (mpu6000_rec_buf[5] << 8 | mpu6000_rec_buf[6]); + break; + case PIOS_MPU6000_TOP_270DEG: + data.gyro_y = mpu6000_rec_buf[5] << 8 | mpu6000_rec_buf[6]; // chip Y + data.gyro_x = -1 - (mpu6000_rec_buf[3] << 8 | mpu6000_rec_buf[4]); // chip X + break; } - data.gyro_z = -(mpu6000_rec_buf[7] << 8 | mpu6000_rec_buf[8]); + data.gyro_z = -1 - (mpu6000_rec_buf[7] << 8 | mpu6000_rec_buf[8]); data.temperature = mpu6000_rec_buf[1] << 8 | mpu6000_rec_buf[2]; #endif - + portBASE_TYPE xHigherPriorityTaskWoken; xQueueSendToBackFromISR(dev->queue, (void *) &data, &xHigherPriorityTaskWoken); - + mpu6000_irq++; - + mpu6000_time_us = PIOS_DELAY_DiffuS(timeval); - - return xHigherPriorityTaskWoken == pdTRUE; + + return xHigherPriorityTaskWoken == pdTRUE; +} + +/** + * @brief Return the gyro range setting based on config and/or mpu6000settings. + * \return the chosen gyro range + */ +static uint8_t getGyroRange(enum pios_mpu6000_range gyro) +{ + // if the setting is overridden by the board config then use the board value + if (gyro != PIOS_MPU6000_SCALE_FROM_SETTINGS) + return(uint8_t) gyro; + + uint8_t gyroSettings; + Mpu6000SettingsGyroScaleGet(&gyroSettings); + + switch (gyroSettings) { + case MPU6000SETTINGS_GYROSCALE_SCALE_250: + return PIOS_MPU6000_SCALE_250_DEG; + case MPU6000SETTINGS_GYROSCALE_SCALE_500: + return PIOS_MPU6000_SCALE_500_DEG; + case MPU6000SETTINGS_GYROSCALE_SCALE_1000: + return PIOS_MPU6000_SCALE_1000_DEG; + case MPU6000SETTINGS_GYROSCALE_SCALE_2000: + return PIOS_MPU6000_SCALE_2000_DEG; + default: + return PIOS_MPU6000_SCALE_2000_DEG; + } +} + +/** + * @brief Return the accel range setting based on config and/or mpu6000settings. + * \return the chosen accel range + */ +static uint8_t getAccelRange(enum pios_mpu6000_accel_range accel) +{ + // if the setting is overridden by the board config then use the board value + if (accel != PIOS_MPU6000_ACCEL_FROM_SETTINGS) + return (uint8_t) accel; + + uint8_t accelSetting; + Mpu6000SettingsAccelScaleGet(&accelSetting); + + switch (accelSetting) { + case MPU6000SETTINGS_ACCELSCALE_SCALE_2G: + return PIOS_MPU6000_ACCEL_2G; + case MPU6000SETTINGS_ACCELSCALE_SCALE_4G: + return PIOS_MPU6000_ACCEL_4G; + case MPU6000SETTINGS_ACCELSCALE_SCALE_8G: + return PIOS_MPU6000_ACCEL_8G; + case MPU6000SETTINGS_ACCELSCALE_SCALE_16G: + return PIOS_MPU6000_ACCEL_16G; + default: + return PIOS_MPU6000_ACCEL_8G; + } +} + +/** + * @brief Return the filter settings based on config and/or mpu6000settings. + * \return the chosen filter settings + */ +static uint8_t getFilterSetting(enum pios_mpu6000_filter filter) +{ + // if the setting is overridden by the board config then use the board value + if (filter != PIOS_MPU6000_LOWPASS_FROM_SETTINGS) + return(uint8_t) filter; + + uint8_t filterSetting; + Mpu6000SettingsFilterSettingGet(&filterSetting); + + switch (filterSetting) { + case MPU6000SETTINGS_FILTERSETTING_LOWPASS_256_HZ: + return PIOS_MPU6000_LOWPASS_256_HZ; + case MPU6000SETTINGS_FILTERSETTING_LOWPASS_188_HZ: + return PIOS_MPU6000_LOWPASS_188_HZ; + case MPU6000SETTINGS_FILTERSETTING_LOWPASS_98_HZ: + return PIOS_MPU6000_LOWPASS_98_HZ; + case MPU6000SETTINGS_FILTERSETTING_LOWPASS_42_HZ: + return PIOS_MPU6000_LOWPASS_42_HZ; + case MPU6000SETTINGS_FILTERSETTING_LOWPASS_20_HZ: + return PIOS_MPU6000_LOWPASS_20_HZ; + case MPU6000SETTINGS_FILTERSETTING_LOWPASS_10_HZ: + return PIOS_MPU6000_LOWPASS_10_HZ; + case MPU6000SETTINGS_FILTERSETTING_LOWPASS_5_HZ: + return PIOS_MPU6000_LOWPASS_5_HZ; + default: + return PIOS_MPU6000_LOWPASS_256_HZ; + } } #endif diff --git a/flight/PiOS/inc/pios_mpu6000.h b/flight/PiOS/inc/pios_mpu6000.h index 254f10192..88233e645 100644 --- a/flight/PiOS/inc/pios_mpu6000.h +++ b/flight/PiOS/inc/pios_mpu6000.h @@ -87,8 +87,10 @@ /* User control functionality */ #define PIOS_MPU6000_USERCTL_FIFO_EN 0X40 +#define PIOS_MPU6000_USERCTL_I2C_MST_EN 0x20 #define PIOS_MPU6000_USERCTL_DIS_I2C 0X10 -#define PIOS_MPU6000_USERCTL_FIFO_RST 0X02 +#define PIOS_MPU6000_USERCTL_FIFO_RST 0X04 +#define PIOS_MPU6000_USERCTL_SIG_COND 0X02 #define PIOS_MPU6000_USERCTL_GYRO_RST 0X01 /* Power management and clock selection */ @@ -100,6 +102,7 @@ #define PIOS_MPU6000_PWRMGMT_STOP_CLK 0X07 enum pios_mpu6000_range { + PIOS_MPU6000_SCALE_FROM_SETTINGS = 0xFF, PIOS_MPU6000_SCALE_250_DEG = 0x00, PIOS_MPU6000_SCALE_500_DEG = 0x08, PIOS_MPU6000_SCALE_1000_DEG = 0x10, @@ -107,6 +110,7 @@ enum pios_mpu6000_range { }; enum pios_mpu6000_filter { + PIOS_MPU6000_LOWPASS_FROM_SETTINGS = 0xFF, PIOS_MPU6000_LOWPASS_256_HZ = 0x00, PIOS_MPU6000_LOWPASS_188_HZ = 0x01, PIOS_MPU6000_LOWPASS_98_HZ = 0x02, @@ -117,6 +121,7 @@ enum pios_mpu6000_filter { }; enum pios_mpu6000_accel_range { + PIOS_MPU6000_ACCEL_FROM_SETTINGS = 0xFF, PIOS_MPU6000_ACCEL_2G = 0x00, PIOS_MPU6000_ACCEL_4G = 0x08, PIOS_MPU6000_ACCEL_8G = 0x10, diff --git a/flight/RevoMini/System/pios_board.c b/flight/RevoMini/System/pios_board.c index 6f772acdf..1e2bfae7a 100644 --- a/flight/RevoMini/System/pios_board.c +++ b/flight/RevoMini/System/pios_board.c @@ -181,9 +181,9 @@ static const struct pios_mpu6000_cfg pios_mpu6000_cfg = { .interrupt_en = PIOS_MPU6000_INTEN_DATA_RDY, .User_ctl = PIOS_MPU6000_USERCTL_FIFO_EN | PIOS_MPU6000_USERCTL_DIS_I2C, .Pwr_mgmt_clk = PIOS_MPU6000_PWRMGMT_PLL_X_CLK, - .accel_range = PIOS_MPU6000_ACCEL_8G, - .gyro_range = PIOS_MPU6000_SCALE_500_DEG, - .filter = PIOS_MPU6000_LOWPASS_256_HZ, + .accel_range = PIOS_MPU6000_ACCEL_FROM_SETTINGS, + .gyro_range = PIOS_MPU6000_SCALE_FROM_SETTINGS, + .filter = PIOS_MPU6000_LOWPASS_FROM_SETTINGS, .orientation = PIOS_MPU6000_TOP_180DEG }; #endif /* PIOS_INCLUDE_MPU6000 */ diff --git a/flight/RevoMini/UAVObjects.inc b/flight/RevoMini/UAVObjects.inc index d07660a8f..6165f3d67 100644 --- a/flight/RevoMini/UAVObjects.inc +++ b/flight/RevoMini/UAVObjects.inc @@ -94,7 +94,7 @@ UAVOBJSRCFILENAMES += altitudeholdsettings UAVOBJSRCFILENAMES += altitudeholddesired UAVOBJSRCFILENAMES += waypoint UAVOBJSRCFILENAMES += waypointactive - +UAVOBJSRCFILENAMES += mpu6000settings UAVOBJSRCFILENAMES += txpidsettings UAVOBJSRC = $(foreach UAVOBJSRCFILE,$(UAVOBJSRCFILENAMES),$(UAVOBJSYNTHDIR)/$(UAVOBJSRCFILE).c ) diff --git a/flight/Revolution/System/pios_board.c b/flight/Revolution/System/pios_board.c index 37c9810b3..85281b0c5 100644 --- a/flight/Revolution/System/pios_board.c +++ b/flight/Revolution/System/pios_board.c @@ -222,9 +222,9 @@ static const struct pios_mpu6000_cfg pios_mpu6000_cfg = { .interrupt_en = PIOS_MPU6000_INTEN_DATA_RDY, .User_ctl = PIOS_MPU6000_USERCTL_FIFO_EN | PIOS_MPU6000_USERCTL_DIS_I2C, .Pwr_mgmt_clk = PIOS_MPU6000_PWRMGMT_PLL_X_CLK, - .accel_range = PIOS_MPU6000_ACCEL_8G, - .gyro_range = PIOS_MPU6000_SCALE_500_DEG, - .filter = PIOS_MPU6000_LOWPASS_256_HZ, + .accel_range = PIOS_MPU6000_ACCEL_FROM_SETTINGS, + .gyro_range = PIOS_MPU6000_SCALE_FROM_SETTINGS, + .filter = PIOS_MPU6000_LOWPASS_FROM_SETTINGS, .orientation = PIOS_MPU6000_TOP_0DEG }; #endif /* PIOS_INCLUDE_MPU6000 */ diff --git a/flight/Revolution/UAVObjects.inc b/flight/Revolution/UAVObjects.inc index 545f6ecc7..8202dc1b2 100644 --- a/flight/Revolution/UAVObjects.inc +++ b/flight/Revolution/UAVObjects.inc @@ -94,6 +94,7 @@ UAVOBJSRCFILENAMES += altitudeholdsettings UAVOBJSRCFILENAMES += altitudeholddesired UAVOBJSRCFILENAMES += waypoint UAVOBJSRCFILENAMES += waypointactive +UAVOBJSRCFILENAMES += mpu6000settings UAVOBJSRC = $(foreach UAVOBJSRCFILE,$(UAVOBJSRCFILENAMES),$(UAVOBJSYNTHDIR)/$(UAVOBJSRCFILE).c ) UAVOBJDEFINE = $(foreach UAVOBJSRCFILE,$(UAVOBJSRCFILENAMES),-DUAVOBJ_INIT_$(UAVOBJSRCFILE) ) diff --git a/ground/openpilotgcs/src/plugins/uavobjects/uavobjects.pro b/ground/openpilotgcs/src/plugins/uavobjects/uavobjects.pro index d0aeeed1b..5b61364fc 100644 --- a/ground/openpilotgcs/src/plugins/uavobjects/uavobjects.pro +++ b/ground/openpilotgcs/src/plugins/uavobjects/uavobjects.pro @@ -99,7 +99,8 @@ HEADERS += $$UAVOBJECT_SYNTHETICS/accessorydesired.h \ $$UAVOBJECT_SYNTHETICS/oplinkstatus.h \ $$UAVOBJECT_SYNTHETICS/osdsettings.h \ $$UAVOBJECT_SYNTHETICS/waypoint.h \ - $$UAVOBJECT_SYNTHETICS/waypointactive.h + $$UAVOBJECT_SYNTHETICS/waypointactive.h \ + $$UAVOBJECT_SYNTHETICS/mpu6000settings.h SOURCES += $$UAVOBJECT_SYNTHETICS/accessorydesired.cpp \ $$UAVOBJECT_SYNTHETICS/baroaltitude.cpp \ @@ -178,4 +179,5 @@ SOURCES += $$UAVOBJECT_SYNTHETICS/accessorydesired.cpp \ $$UAVOBJECT_SYNTHETICS/oplinkstatus.cpp \ $$UAVOBJECT_SYNTHETICS/osdsettings.cpp \ $$UAVOBJECT_SYNTHETICS/waypoint.cpp \ - $$UAVOBJECT_SYNTHETICS/waypointactive.cpp + $$UAVOBJECT_SYNTHETICS/waypointactive.cpp \ + $$UAVOBJECT_SYNTHETICS/mpu6000settings.cpp diff --git a/shared/uavobjectdefinition/mpu6000settings.xml b/shared/uavobjectdefinition/mpu6000settings.xml new file mode 100644 index 000000000..7f07a87b9 --- /dev/null +++ b/shared/uavobjectdefinition/mpu6000settings.xml @@ -0,0 +1,38 @@ + + + Settings for the @ref MPU6000 sensor used on CC3D and Revolution + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +