Ejemplo de uso del MPU9250 por puerto I2C

Dependencies:   mbed

Revision:
0:cecf4940adf1
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/mpu9250Define.h	Sun Oct 25 15:28:55 2015 +0000
@@ -0,0 +1,241 @@
+#ifndef MPU9250DEFINE_H
+#define MPU9250DEFINE_H
+
+/*-bit-*/
+#define BIT_1               (1)
+#define BIT_2               (2)
+#define BIT_3               (3)
+#define BIT_4               (4)
+#define BIT_5               (5)
+#define BIT_6               (6)
+
+/*-send command-*/
+#define CLEAR_COMMAND       (0x00)
+
+#define X_AXIS              (1)
+#define Y_AXIS              (2)
+#define Z_AXIS              (5)
+#define ALL_AXIS            (X_AXIS+Y_AXIS+Z_AXIS)
+
+/*-MPU-9150 address-*/
+#define MPU9250_ADDRESS     (0x68<<1)  // 0b1101000 AD0=L
+
+/*-MPU-9150 register-*/                     //| Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
+#define SELF_TEST_X_GYRO    (0x00)                  
+#define SELF_TEST_Y_GYRO    (0x01)                                                                          
+#define SELF_TEST_Z_GYRO    (0x02)
+#define SELF_TEST_X_ACCEL   (0x0D)  // R/W  //|     XA_TEST[4-2]   |              XG_TEST[4-0]        |
+#define SELF_TEST_Y_ACCEL   (0x0E)  // R/W  //|     YA_TEST[4-2]   |              YG_TEST[4-0]        |
+#define SELE_TEST_Z_ACCEL   (0x0F)  // R/W  //|     ZA_TEST[4-2]   |              ZA_TEST[4-0]        |
+
+#define SELF_TEST_A         (0x10)  // R/W  //|   RESERVED  | XA_TEST[1-0]| YA_TEST[1-0]| ZA_TEST[1-0]|
+#define XG_OFFSET_H         (0x13)  // User-defined trim values for gyroscope
+#define XG_OFFSET_L         (0x14)
+#define YG_OFFSET_H         (0x15)
+#define YG_OFFSET_L         (0x16)
+#define ZG_OFFSET_H         (0x17)
+#define ZG_OFFSET_L         (0x18)
+#define SMPLRT_DIV          (0x19)  // R/W  //|                     SMPLRT_DIV[7:0]                   |
+#define CONFIG              (0x1A)  // R/W  //|   -  |   -  |  EXT_SYNC_SET[2:0] |    DLPE_CFG[2:0]   |
+#define GYRO_CONFIG         (0x1B)  // R/W  //| XG_ST| YG_ST| ZG_ST| FS_SEL[1:0] |   -  |   -  |   -  |
+#define ACCEL_CONFIG        (0x1C)  // R/W  //| XA_ST| YA_ST| ZA_ST| AFS_SEL[1:0]|          -         |
+#define ACCEL_CONFIG2       (0x1D)
+#define LP_ACCEL_ODR        (0x1E)   
+#define WOM_THR             (0x1F)  
+
+#define MOT_DUR             (0x20)  // Duration counter threshold for motion interrupt generation, 1 kHz rate, LSB = 1 ms
+#define ZMOT_THR            (0x21)  // Zero-motion detection threshold bits [7:0]
+#define ZRMOT_DUR           (0x22)  // Duration counter threshold for zero motion interrupt generation, 16 Hz rate, LSB = 64 ms
+ 
+#define FIFO_EN             (0x23)  // R/W  //| TEMP_FIFO_EN | XG_FIFO_EN | YG_FIFO_EN | ZG_FIFO_EN | ACCEL_FIFO_EN | SLV2_FIFO_EN | SLV1_FIFO_EN | SLV0_FIFO_EN |
+#define I2C_MST_CTRL        (0x24)  // R/W  //| MULT_MST_EN | WAIT_FOR_ES | SLV_3_FIFO_EN | I2C_MST_P_NSR | I2C_MST_CLK[3:0] |
+#define I2C_SLV0_ADDR       (0x25)  // R/W  //| I2C_SLV0_RW |              I2C_SLV0_ADDR[6:0]         |
+#define I2C_SLV0_REG        (0x26)  // R/W  //|                            I2C_SLV0_REG[7:0]          |
+#define I2C_SLV0_CTRL       (0x27)  // R/W  //| I2C_SLV0_EN | I2C_SLV0_BYTE_SW | I2C_SLV0_REG_DIS | I2C_SLV0_GRP | I2C_SLV0_LEN[3:0] |
+#define I2C_SLV1_ADDR       (0x28)  // R/W
+#define I2C_SLV1_REG        (0x29)  // R/W
+#define I2C_SLV1_CTRL       (0x2A)  // R/W
+#define I2C_SLV2_ADDR       (0x2B)  // R/W
+#define I2C_SLV2_REG        (0x2C)  // R/W
+#define I2C_SLV2_CTRL       (0x2D)  // R/W
+#define I2C_SLV3_ADDR       (0x2E)  // R/W
+#define I2C_SLV3_REG        (0x2F)  // R/W
+#define I2C_SLV3_CTRL       (0x30)  // R/W
+#define I2C_SLV4_ADDR       (0x31)  // R/W
+#define I2C_SLV4_REG        (0x32)  // R/W
+#define I2C_SLV4_DO         (0x33)  // R/W
+#define I2C_SLV4_CTRL       (0x34)  // R/W
+#define I2C_SLV4_DI         (0x35)  // R
+
+#define I2C_MST_STATUS      (0x36)  // R
+#define INT_PIN_CFG         (0x37)  // R/W  // This register configures the behavior of the interrupt signals at the INT pins.
+#define INT_ENBLE           (0x38)  // R/W
+#define DMP_INT_STATUS      (0x39)  // Check DMP interrupt
+#define INT_STATUS          (0x3A)  // R
+
+#define ACCEL_XOUT_H        (0x3B)  // R    //ACCEL_XOUT[15:8]
+#define ACCEL_XOUT_L        (0x3C)  // R    //ACCEL_XOUT[7:0]
+#define ACCEL_YOUT_H        (0x3D)  // R    //ACCEL_YOUT[15:8]
+#define ACCEL_YOUT_L        (0x3E)  // R    //ACCEL_YOUT[7:0]
+#define ACCEL_ZOUT_H        (0x3F)  // R    //ACCEL_ZOUT[15:8]
+#define ACCEL_ZOUT_L        (0x40)  // R    //ACCEL_ZOUT[7:0]
+
+#define TEMP_OUT_H          (0x41)  // R
+#define TEMP_OUT_L          (0x42)  // R
+
+#define GYRO_XOUT_H         (0x43)  // R    //GYRO_XOUT[15:8]
+#define GYRO_XOUT_L         (0x44)  // R    //GYRO_XOUT[7:0]
+#define GYRO_YOUT_H         (0x45)  // R    //GYRO_YOUT[15:8]
+#define GYRO_YOUT_L         (0x46)  // R    //GYRO_YOUT[7:0]
+#define GYRO_ZOUT_H         (0x47)  // R    //GYRO_ZOUT[15:8]
+#define GYRO_ZOUT_L         (0x48)  // R    //GYRO_ZOUT[7:0]
+
+#define EXT_SENS_DATA_00    (0x49)  // R
+#define EXT_SENS_DATA_01    (0x4A)  // R
+#define EXT_SENS_DATA_02    (0x4B)  // R
+#define EXT_SENS_DATA_03    (0x4C)  // R
+#define EXT_SENS_DATA_04    (0x4D)  // R
+#define EXT_SENS_DATA_05    (0x4E)  // R
+#define EXT_SENS_DATA_06    (0x4F)  // R
+#define EXT_SENS_DATA_07    (0x50)  // R
+#define EXT_SENS_DATA_08    (0x51)  // R
+#define EXT_SENS_DATA_09    (0x52)  // R
+#define EXT_SENS_DATA_10    (0x53)  // R
+#define EXT_SENS_DATA_11    (0x54)  // R
+#define EXT_SENS_DATA_12    (0x55)  // R
+#define EXT_SENS_DATA_13    (0x56)  // R
+#define EXT_SENS_DATA_14    (0x57)  // R
+#define EXT_SENS_DATA_15    (0x58)  // R
+#define EXT_SENS_DATA_16    (0x59)  // R
+#define EXT_SENS_DATA_17    (0x5A)  // R
+#define EXT_SENS_DATA_18    (0x5B)  // R
+#define EXT_SENS_DATA_19    (0x5C)  // R
+#define EXT_SENS_DATA_20    (0x5D)  // R
+#define EXT_SENS_DATA_21    (0x5E)  // R
+#define EXT_SENS_DATA_22    (0x5F)  // R
+#define EXT_SENS_DATA_23    (0x60)  // R
+
+#define I2C_SLV0_DO         (0x63)  // R/W
+#define I2C_SLV1_DO         (0x64)  // R/W
+#define I2C_SLV2_DO         (0x65)  // R/W
+#define I2C_SLV3_DO         (0x66)  // R/W
+#define I2C_MST_DELAY_CTRL  (0x67)  // R/W
+#define SIGNAL_PATH_RESET   (0x68)  // R/W
+#define USER_CTRL           (0x6A)  // R/W
+#define PWR_MGMT_1          (0x6B)  // R/W
+#define PER_MGMT_2          (0x6C)  // R/W
+
+#define FIFO_COUNTH         (0x72)  // R/W
+#define FIFO_COUNTL         (0x73)  // R/W
+#define FIFO_R_W            (0x74)  // R/W
+#define WHO_AM_I            (0x75)  // R
+
+#define XA_OFFSET_H         (0x77)
+#define XA_OFFSET_L         (0x78)
+#define YA_OFFSET_H         (0x7A)
+#define YA_OFFSET_L         (0x7B)
+#define ZA_OFFSET_H         (0x7D)
+#define ZA_OFFSET_L         (0x7E)
+
+/*-MPU-9150 setting command-*/
+#define ACCEL_CONFIG_AFS_SEL_2      (0x00 << 3) //16384 LSB/mg
+#define ACCEL_CONFIG_AFS_SEL_4      (0x01 << 3) //8192  LSB/mg
+#define ACCEL_CONFIG_AFS_SEL_8      (0x02 << 3) //4096  LSB/mg
+#define ACCEL_CONFIG_AFS_SEL_16     (0x03 << 3) //2048  LSB/mg
+
+#define GYRO_CONFIG_FS_SEL_250      (0x00 << 3) //131  LSB/deg/sce
+#define GYRO_CONFIG_FS_SEL_500      (0x01 << 3) //65.5 LSB/deg/sec
+#define GYRO_CONFIG_FS_SEL_1000     (0x02 << 3) //32.8 LSB/deg/sec
+#define GYRO_CONFIG_FS_SEL_2000     (0x03 << 3) //16.4 LSB/deg/sec
+
+/*-MPU-9150 clock source-*/
+#define PWR_MGMT_1_CLKSEL_0         (0x00)      //Internal 8MHz oscillator
+#define PWR_MGMT_1_CLKSEL_1         (0x01)      //PLL with X axis gyroscope reference
+#define PWR_MGMT_1_CLKSEL_2         (0x02)      //PLL with Y axis gyroscope reference
+#define PWR_MGMT_1_CLKSEL_3         (0x03)      //PLL with Z axis gyroscope reference
+#define PWR_MGMT_1_CLKSEL_4         (0x04)      //PLL with external 32.768kHz reference
+#define PWR_MGMT_1_CLKSEL_5         (0x05)      //PLL with external 19.2MHz reference
+#define PWR_MGMT_1_CLKSEL_6         (0x06)      //Reserved
+#define PWR_MGMT_1_CLKSEL_7         (0x07)      //Stops the clock and keeps the timing generator in reset
+
+#define INT_PIN_DFG_I2C_BYPASS_EN   (0x02)
+
+enum AccelSensitivity {
+    AFS_SEL_2=0,
+    AFS_SEL_4,
+    AFS_SEL_8,
+    AFS_SEL_16,
+};
+
+char getAccelSensitivity(AccelSensitivity mode)
+{
+    switch(mode) {
+        case AFS_SEL_2:
+            return ACCEL_CONFIG_AFS_SEL_2;
+        case AFS_SEL_4:
+            return ACCEL_CONFIG_AFS_SEL_4;
+        case AFS_SEL_8:
+            return ACCEL_CONFIG_AFS_SEL_8;
+        case AFS_SEL_16:
+            return ACCEL_CONFIG_AFS_SEL_16;
+        default:
+            return ACCEL_CONFIG_AFS_SEL_2;
+    }
+};
+
+double getAccelLSB2MG(AccelSensitivity mode)
+{   
+    switch(mode) {
+        case AFS_SEL_2:
+            return (2.0/32768.0);
+        case AFS_SEL_4:
+            return (4.0/32768.0);
+        case AFS_SEL_8:
+            return (8.0/32768.0);
+        case AFS_SEL_16:
+            return (16.0/32768.0);
+        default:
+            return (2.0/32768.0);
+    }
+};
+
+enum GyroSensitivity {
+    FS_SEL_250=0,
+    FS_SEL_500,
+    FS_SEL_1000,
+    FS_SEL_2000,
+};
+
+char getGyroSensitivity(GyroSensitivity mode)
+{
+    switch(mode) {
+        case FS_SEL_250:
+            return GYRO_CONFIG_FS_SEL_250;
+        case FS_SEL_500:
+            return GYRO_CONFIG_FS_SEL_500;
+        case FS_SEL_1000:
+            return GYRO_CONFIG_FS_SEL_1000;
+        case FS_SEL_2000:
+            return GYRO_CONFIG_FS_SEL_2000;
+        default:
+            return GYRO_CONFIG_FS_SEL_250;
+    }
+};
+
+double getGyroLSB2DegPerSec(GyroSensitivity mode)
+{
+    switch(mode) {
+        case FS_SEL_250:
+            return (250.0/32768.0);
+        case FS_SEL_500:
+            return (500.0/32768.0);
+        case FS_SEL_1000:
+            return (1000.0/32768.0);
+        case FS_SEL_2000:
+            return (2000.0/32768.0);
+        default:
+            return (250.0/32768.0);
+    }
+};
+
+#endif  /* MPU9250DEFINE_H */
\ No newline at end of file