a quadcopter code

Dependencies:   Pulse RangeFinder mbed

Committer:
Gendy
Date:
Tue Nov 24 19:57:06 2015 +0000
Revision:
0:4a55d0a21ea9
Quad_project PID on angle;

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Gendy 0:4a55d0a21ea9 1 //ported from arduino library: https://github.com/jrowberg/i2cdevlib/tree/master/Arduino/MPU6050
Gendy 0:4a55d0a21ea9 2 //written by szymon gaertig (email: szymon@gaertig.com.pl)
Gendy 0:4a55d0a21ea9 3 //
Gendy 0:4a55d0a21ea9 4 //Changelog:
Gendy 0:4a55d0a21ea9 5 //2013-01-08 - first beta release
Gendy 0:4a55d0a21ea9 6
Gendy 0:4a55d0a21ea9 7 // I2Cdev library collection - MPU6050 I2C device class
Gendy 0:4a55d0a21ea9 8 // Based on InvenSense MPU-6050 register map document rev. 2.0, 5/19/2011 (RM-MPU-6000A-00)
Gendy 0:4a55d0a21ea9 9 // 10/3/2011 by Jeff Rowberg <jeff@rowberg.net>
Gendy 0:4a55d0a21ea9 10 // Updates should (hopefully) always be available at https://github.com/jrowberg/i2cdevlib
Gendy 0:4a55d0a21ea9 11 //
Gendy 0:4a55d0a21ea9 12 // Changelog:
Gendy 0:4a55d0a21ea9 13 // ... - ongoing debug release
Gendy 0:4a55d0a21ea9 14
Gendy 0:4a55d0a21ea9 15 // NOTE: THIS IS ONLY A PARIAL RELEASE. THIS DEVICE CLASS IS CURRENTLY UNDERGOING ACTIVE
Gendy 0:4a55d0a21ea9 16 // DEVELOPMENT AND IS STILL MISSING SOME IMPORTANT FEATURES. PLEASE KEEP THIS IN MIND IF
Gendy 0:4a55d0a21ea9 17 // YOU DECIDE TO USE THIS PARTICULAR CODE FOR ANYTHING.
Gendy 0:4a55d0a21ea9 18
Gendy 0:4a55d0a21ea9 19 /* ============================================
Gendy 0:4a55d0a21ea9 20 I2Cdev device library code is placed under the MIT license
Gendy 0:4a55d0a21ea9 21 Copyright (c) 2012 Jeff Rowberg
Gendy 0:4a55d0a21ea9 22
Gendy 0:4a55d0a21ea9 23 Permission is hereby granted, free of charge, to any person obtaining a copy
Gendy 0:4a55d0a21ea9 24 of this software and associated documentation files (the "Software"), to deal
Gendy 0:4a55d0a21ea9 25 in the Software without restriction, including without limitation the rights
Gendy 0:4a55d0a21ea9 26 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
Gendy 0:4a55d0a21ea9 27 copies of the Software, and to permit persons to whom the Software is
Gendy 0:4a55d0a21ea9 28 furnished to do so, subject to the following conditions:
Gendy 0:4a55d0a21ea9 29
Gendy 0:4a55d0a21ea9 30 The above copyright notice and this permission notice shall be included in
Gendy 0:4a55d0a21ea9 31 all copies or substantial portions of the Software.
Gendy 0:4a55d0a21ea9 32
Gendy 0:4a55d0a21ea9 33 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
Gendy 0:4a55d0a21ea9 34 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
Gendy 0:4a55d0a21ea9 35 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
Gendy 0:4a55d0a21ea9 36 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
Gendy 0:4a55d0a21ea9 37 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
Gendy 0:4a55d0a21ea9 38 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
Gendy 0:4a55d0a21ea9 39 THE SOFTWARE.
Gendy 0:4a55d0a21ea9 40 ===============================================
Gendy 0:4a55d0a21ea9 41 */
Gendy 0:4a55d0a21ea9 42
Gendy 0:4a55d0a21ea9 43 #ifndef _MPU6050_H_
Gendy 0:4a55d0a21ea9 44 #define _MPU6050_H_
Gendy 0:4a55d0a21ea9 45
Gendy 0:4a55d0a21ea9 46 #include "I2Cdev.h"
Gendy 0:4a55d0a21ea9 47 #include "helper_3dmath.h"
Gendy 0:4a55d0a21ea9 48
Gendy 0:4a55d0a21ea9 49 #define MPU6050_ADDRESS_AD0_LOW 0x69 // address pin low (GND), default for InvenSense evaluation board
Gendy 0:4a55d0a21ea9 50 #define MPU6050_ADDRESS_AD0_HIGH 0x68 // address pin high (VCC)
Gendy 0:4a55d0a21ea9 51 #define MPU6050_DEFAULT_ADDRESS MPU6050_ADDRESS_AD0_HIGH
Gendy 0:4a55d0a21ea9 52
Gendy 0:4a55d0a21ea9 53 #define MPU6050_RA_XG_OFFS_TC 0x00 //[7] PWR_MODE, [6:1] XG_OFFS_TC, [0] OTP_BNK_VLD
Gendy 0:4a55d0a21ea9 54 #define MPU6050_RA_YG_OFFS_TC 0x01 //[7] PWR_MODE, [6:1] YG_OFFS_TC, [0] OTP_BNK_VLD
Gendy 0:4a55d0a21ea9 55 #define MPU6050_RA_ZG_OFFS_TC 0x02 //[7] PWR_MODE, [6:1] ZG_OFFS_TC, [0] OTP_BNK_VLD
Gendy 0:4a55d0a21ea9 56 #define MPU6050_RA_X_FINE_GAIN 0x03 //[7:0] X_FINE_GAIN
Gendy 0:4a55d0a21ea9 57 #define MPU6050_RA_Y_FINE_GAIN 0x04 //[7:0] Y_FINE_GAIN
Gendy 0:4a55d0a21ea9 58 #define MPU6050_RA_Z_FINE_GAIN 0x05 //[7:0] Z_FINE_GAIN
Gendy 0:4a55d0a21ea9 59 #define MPU6050_RA_XA_OFFS_H 0x06 //[15:0] XA_OFFS
Gendy 0:4a55d0a21ea9 60 #define MPU6050_RA_XA_OFFS_L_TC 0x07
Gendy 0:4a55d0a21ea9 61 #define MPU6050_RA_YA_OFFS_H 0x08 //[15:0] YA_OFFS
Gendy 0:4a55d0a21ea9 62 #define MPU6050_RA_YA_OFFS_L_TC 0x09
Gendy 0:4a55d0a21ea9 63 #define MPU6050_RA_ZA_OFFS_H 0x0A //[15:0] ZA_OFFS
Gendy 0:4a55d0a21ea9 64 #define MPU6050_RA_ZA_OFFS_L_TC 0x0B
Gendy 0:4a55d0a21ea9 65 #define MPU6050_RA_XG_OFFS_USRH 0x13 //[15:0] XG_OFFS_USR
Gendy 0:4a55d0a21ea9 66 #define MPU6050_RA_XG_OFFS_USRL 0x14
Gendy 0:4a55d0a21ea9 67 #define MPU6050_RA_YG_OFFS_USRH 0x15 //[15:0] YG_OFFS_USR
Gendy 0:4a55d0a21ea9 68 #define MPU6050_RA_YG_OFFS_USRL 0x16
Gendy 0:4a55d0a21ea9 69 #define MPU6050_RA_ZG_OFFS_USRH 0x17 //[15:0] ZG_OFFS_USR
Gendy 0:4a55d0a21ea9 70 #define MPU6050_RA_ZG_OFFS_USRL 0x18
Gendy 0:4a55d0a21ea9 71 #define MPU6050_RA_SMPLRT_DIV 0x19
Gendy 0:4a55d0a21ea9 72 #define MPU6050_RA_CONFIG 0x1A
Gendy 0:4a55d0a21ea9 73 #define MPU6050_RA_GYRO_CONFIG 0x1B
Gendy 0:4a55d0a21ea9 74 #define MPU6050_RA_ACCEL_CONFIG 0x1C
Gendy 0:4a55d0a21ea9 75 #define MPU6050_RA_FF_THR 0x1D
Gendy 0:4a55d0a21ea9 76 #define MPU6050_RA_FF_DUR 0x1E
Gendy 0:4a55d0a21ea9 77 #define MPU6050_RA_MOT_THR 0x1F
Gendy 0:4a55d0a21ea9 78 #define MPU6050_RA_MOT_DUR 0x20
Gendy 0:4a55d0a21ea9 79 #define MPU6050_RA_ZRMOT_THR 0x21
Gendy 0:4a55d0a21ea9 80 #define MPU6050_RA_ZRMOT_DUR 0x22
Gendy 0:4a55d0a21ea9 81 #define MPU6050_RA_FIFO_EN 0x23
Gendy 0:4a55d0a21ea9 82 #define MPU6050_RA_I2C_MST_CTRL 0x24
Gendy 0:4a55d0a21ea9 83 #define MPU6050_RA_I2C_SLV0_ADDR 0x25
Gendy 0:4a55d0a21ea9 84 #define MPU6050_RA_I2C_SLV0_REG 0x26
Gendy 0:4a55d0a21ea9 85 #define MPU6050_RA_I2C_SLV0_CTRL 0x27
Gendy 0:4a55d0a21ea9 86 #define MPU6050_RA_I2C_SLV1_ADDR 0x28
Gendy 0:4a55d0a21ea9 87 #define MPU6050_RA_I2C_SLV1_REG 0x29
Gendy 0:4a55d0a21ea9 88 #define MPU6050_RA_I2C_SLV1_CTRL 0x2A
Gendy 0:4a55d0a21ea9 89 #define MPU6050_RA_I2C_SLV2_ADDR 0x2B
Gendy 0:4a55d0a21ea9 90 #define MPU6050_RA_I2C_SLV2_REG 0x2C
Gendy 0:4a55d0a21ea9 91 #define MPU6050_RA_I2C_SLV2_CTRL 0x2D
Gendy 0:4a55d0a21ea9 92 #define MPU6050_RA_I2C_SLV3_ADDR 0x2E
Gendy 0:4a55d0a21ea9 93 #define MPU6050_RA_I2C_SLV3_REG 0x2F
Gendy 0:4a55d0a21ea9 94 #define MPU6050_RA_I2C_SLV3_CTRL 0x30
Gendy 0:4a55d0a21ea9 95 #define MPU6050_RA_I2C_SLV4_ADDR 0x31
Gendy 0:4a55d0a21ea9 96 #define MPU6050_RA_I2C_SLV4_REG 0x32
Gendy 0:4a55d0a21ea9 97 #define MPU6050_RA_I2C_SLV4_DO 0x33
Gendy 0:4a55d0a21ea9 98 #define MPU6050_RA_I2C_SLV4_CTRL 0x34
Gendy 0:4a55d0a21ea9 99 #define MPU6050_RA_I2C_SLV4_DI 0x35
Gendy 0:4a55d0a21ea9 100 #define MPU6050_RA_I2C_MST_STATUS 0x36
Gendy 0:4a55d0a21ea9 101 #define MPU6050_RA_INT_PIN_CFG 0x37
Gendy 0:4a55d0a21ea9 102 #define MPU6050_RA_INT_ENABLE 0x38
Gendy 0:4a55d0a21ea9 103 #define MPU6050_RA_DMP_INT_STATUS 0x39
Gendy 0:4a55d0a21ea9 104 #define MPU6050_RA_INT_STATUS 0x3A
Gendy 0:4a55d0a21ea9 105
Gendy 0:4a55d0a21ea9 106 #define MPU6050_RA_ACCEL_XOUT_H 0x3B
Gendy 0:4a55d0a21ea9 107 #define MPU6050_RA_ACCEL_XOUT_L 0x3C
Gendy 0:4a55d0a21ea9 108 #define MPU6050_RA_ACCEL_YOUT_H 0x3D
Gendy 0:4a55d0a21ea9 109 #define MPU6050_RA_ACCEL_YOUT_L 0x3E
Gendy 0:4a55d0a21ea9 110 #define MPU6050_RA_ACCEL_ZOUT_H 0x3F
Gendy 0:4a55d0a21ea9 111 #define MPU6050_RA_ACCEL_ZOUT_L 0x40
Gendy 0:4a55d0a21ea9 112
Gendy 0:4a55d0a21ea9 113 #define MPU6050_RA_TEMP_OUT_H 0x41
Gendy 0:4a55d0a21ea9 114 #define MPU6050_RA_TEMP_OUT_L 0x42
Gendy 0:4a55d0a21ea9 115
Gendy 0:4a55d0a21ea9 116 #define MPU6050_RA_GYRO_XOUT_H 0x43
Gendy 0:4a55d0a21ea9 117 #define MPU6050_RA_GYRO_XOUT_L 0x44
Gendy 0:4a55d0a21ea9 118 #define MPU6050_RA_GYRO_YOUT_H 0x45
Gendy 0:4a55d0a21ea9 119 #define MPU6050_RA_GYRO_YOUT_L 0x46
Gendy 0:4a55d0a21ea9 120 #define MPU6050_RA_GYRO_ZOUT_H 0x47
Gendy 0:4a55d0a21ea9 121 #define MPU6050_RA_GYRO_ZOUT_L 0x48
Gendy 0:4a55d0a21ea9 122
Gendy 0:4a55d0a21ea9 123 #define MPU9150_RA_MAG_ADDRESS 0x0C
Gendy 0:4a55d0a21ea9 124 #define MPU9150_RA_MAG_XOUT_L 0x03
Gendy 0:4a55d0a21ea9 125 #define MPU9150_RA_MAG_XOUT_H 0x04
Gendy 0:4a55d0a21ea9 126 #define MPU9150_RA_MAG_YOUT_L 0x05
Gendy 0:4a55d0a21ea9 127 #define MPU9150_RA_MAG_YOUT_H 0x06
Gendy 0:4a55d0a21ea9 128 #define MPU9150_RA_MAG_ZOUT_L 0x07
Gendy 0:4a55d0a21ea9 129 #define MPU9150_RA_MAG_ZOUT_H 0x08
Gendy 0:4a55d0a21ea9 130
Gendy 0:4a55d0a21ea9 131 #define MPU6050_RA_EXT_SENS_DATA_00 0x49
Gendy 0:4a55d0a21ea9 132 #define MPU6050_RA_EXT_SENS_DATA_01 0x4A
Gendy 0:4a55d0a21ea9 133 #define MPU6050_RA_EXT_SENS_DATA_02 0x4B
Gendy 0:4a55d0a21ea9 134 #define MPU6050_RA_EXT_SENS_DATA_03 0x4C
Gendy 0:4a55d0a21ea9 135 #define MPU6050_RA_EXT_SENS_DATA_04 0x4D
Gendy 0:4a55d0a21ea9 136 #define MPU6050_RA_EXT_SENS_DATA_05 0x4E
Gendy 0:4a55d0a21ea9 137 #define MPU6050_RA_EXT_SENS_DATA_06 0x4F
Gendy 0:4a55d0a21ea9 138 #define MPU6050_RA_EXT_SENS_DATA_07 0x50
Gendy 0:4a55d0a21ea9 139 #define MPU6050_RA_EXT_SENS_DATA_08 0x51
Gendy 0:4a55d0a21ea9 140 #define MPU6050_RA_EXT_SENS_DATA_09 0x52
Gendy 0:4a55d0a21ea9 141 #define MPU6050_RA_EXT_SENS_DATA_10 0x53
Gendy 0:4a55d0a21ea9 142 #define MPU6050_RA_EXT_SENS_DATA_11 0x54
Gendy 0:4a55d0a21ea9 143 #define MPU6050_RA_EXT_SENS_DATA_12 0x55
Gendy 0:4a55d0a21ea9 144 #define MPU6050_RA_EXT_SENS_DATA_13 0x56
Gendy 0:4a55d0a21ea9 145 #define MPU6050_RA_EXT_SENS_DATA_14 0x57
Gendy 0:4a55d0a21ea9 146 #define MPU6050_RA_EXT_SENS_DATA_15 0x58
Gendy 0:4a55d0a21ea9 147 #define MPU6050_RA_EXT_SENS_DATA_16 0x59
Gendy 0:4a55d0a21ea9 148 #define MPU6050_RA_EXT_SENS_DATA_17 0x5A
Gendy 0:4a55d0a21ea9 149 #define MPU6050_RA_EXT_SENS_DATA_18 0x5B
Gendy 0:4a55d0a21ea9 150 #define MPU6050_RA_EXT_SENS_DATA_19 0x5C
Gendy 0:4a55d0a21ea9 151 #define MPU6050_RA_EXT_SENS_DATA_20 0x5D
Gendy 0:4a55d0a21ea9 152 #define MPU6050_RA_EXT_SENS_DATA_21 0x5E
Gendy 0:4a55d0a21ea9 153 #define MPU6050_RA_EXT_SENS_DATA_22 0x5F
Gendy 0:4a55d0a21ea9 154 #define MPU6050_RA_EXT_SENS_DATA_23 0x60
Gendy 0:4a55d0a21ea9 155 #define MPU6050_RA_MOT_DETECT_STATUS 0x61
Gendy 0:4a55d0a21ea9 156 #define MPU6050_RA_I2C_SLV0_DO 0x63
Gendy 0:4a55d0a21ea9 157 #define MPU6050_RA_I2C_SLV1_DO 0x64
Gendy 0:4a55d0a21ea9 158 #define MPU6050_RA_I2C_SLV2_DO 0x65
Gendy 0:4a55d0a21ea9 159 #define MPU6050_RA_I2C_SLV3_DO 0x66
Gendy 0:4a55d0a21ea9 160 #define MPU6050_RA_I2C_MST_DELAY_CTRL 0x67
Gendy 0:4a55d0a21ea9 161 #define MPU6050_RA_SIGNAL_PATH_RESET 0x68
Gendy 0:4a55d0a21ea9 162 #define MPU6050_RA_MOT_DETECT_CTRL 0x69
Gendy 0:4a55d0a21ea9 163 #define MPU6050_RA_USER_CTRL 0x6A
Gendy 0:4a55d0a21ea9 164 #define MPU6050_RA_PWR_MGMT_1 0x6B
Gendy 0:4a55d0a21ea9 165 #define MPU6050_RA_PWR_MGMT_2 0x6C
Gendy 0:4a55d0a21ea9 166 #define MPU6050_RA_BANK_SEL 0x6D
Gendy 0:4a55d0a21ea9 167 #define MPU6050_RA_MEM_START_ADDR 0x6E
Gendy 0:4a55d0a21ea9 168 #define MPU6050_RA_MEM_R_W 0x6F
Gendy 0:4a55d0a21ea9 169 #define MPU6050_RA_DMP_CFG_1 0x70
Gendy 0:4a55d0a21ea9 170 #define MPU6050_RA_DMP_CFG_2 0x71
Gendy 0:4a55d0a21ea9 171 #define MPU6050_RA_FIFO_COUNTH 0x72
Gendy 0:4a55d0a21ea9 172 #define MPU6050_RA_FIFO_COUNTL 0x73
Gendy 0:4a55d0a21ea9 173 #define MPU6050_RA_FIFO_R_W 0x74
Gendy 0:4a55d0a21ea9 174 #define MPU6050_RA_WHO_AM_I 0x75
Gendy 0:4a55d0a21ea9 175
Gendy 0:4a55d0a21ea9 176 #define MPU6050_TC_PWR_MODE_BIT 7
Gendy 0:4a55d0a21ea9 177 #define MPU6050_TC_OFFSET_BIT 6
Gendy 0:4a55d0a21ea9 178 #define MPU6050_TC_OFFSET_LENGTH 6
Gendy 0:4a55d0a21ea9 179 #define MPU6050_TC_OTP_BNK_VLD_BIT 0
Gendy 0:4a55d0a21ea9 180
Gendy 0:4a55d0a21ea9 181 #define MPU6050_VDDIO_LEVEL_VLOGIC 0
Gendy 0:4a55d0a21ea9 182 #define MPU6050_VDDIO_LEVEL_VDD 1
Gendy 0:4a55d0a21ea9 183
Gendy 0:4a55d0a21ea9 184 #define MPU6050_CFG_EXT_SYNC_SET_BIT 5
Gendy 0:4a55d0a21ea9 185 #define MPU6050_CFG_EXT_SYNC_SET_LENGTH 3
Gendy 0:4a55d0a21ea9 186 #define MPU6050_CFG_DLPF_CFG_BIT 2
Gendy 0:4a55d0a21ea9 187 #define MPU6050_CFG_DLPF_CFG_LENGTH 3
Gendy 0:4a55d0a21ea9 188
Gendy 0:4a55d0a21ea9 189 #define MPU6050_EXT_SYNC_DISABLED 0x0
Gendy 0:4a55d0a21ea9 190 #define MPU6050_EXT_SYNC_TEMP_OUT_L 0x1
Gendy 0:4a55d0a21ea9 191 #define MPU6050_EXT_SYNC_GYRO_XOUT_L 0x2
Gendy 0:4a55d0a21ea9 192 #define MPU6050_EXT_SYNC_GYRO_YOUT_L 0x3
Gendy 0:4a55d0a21ea9 193 #define MPU6050_EXT_SYNC_GYRO_ZOUT_L 0x4
Gendy 0:4a55d0a21ea9 194 #define MPU6050_EXT_SYNC_ACCEL_XOUT_L 0x5
Gendy 0:4a55d0a21ea9 195 #define MPU6050_EXT_SYNC_ACCEL_YOUT_L 0x6
Gendy 0:4a55d0a21ea9 196 #define MPU6050_EXT_SYNC_ACCEL_ZOUT_L 0x7
Gendy 0:4a55d0a21ea9 197
Gendy 0:4a55d0a21ea9 198 #define MPU6050_DLPF_BW_256 0x00
Gendy 0:4a55d0a21ea9 199 #define MPU6050_DLPF_BW_188 0x01
Gendy 0:4a55d0a21ea9 200 #define MPU6050_DLPF_BW_98 0x02
Gendy 0:4a55d0a21ea9 201 #define MPU6050_DLPF_BW_42 0x03
Gendy 0:4a55d0a21ea9 202 #define MPU6050_DLPF_BW_20 0x04
Gendy 0:4a55d0a21ea9 203 #define MPU6050_DLPF_BW_10 0x05
Gendy 0:4a55d0a21ea9 204 #define MPU6050_DLPF_BW_5 0x06
Gendy 0:4a55d0a21ea9 205
Gendy 0:4a55d0a21ea9 206 #define MPU6050_GCONFIG_FS_SEL_BIT 4
Gendy 0:4a55d0a21ea9 207 #define MPU6050_GCONFIG_FS_SEL_LENGTH 2
Gendy 0:4a55d0a21ea9 208
Gendy 0:4a55d0a21ea9 209 #define MPU6050_GYRO_FS_250 0x00
Gendy 0:4a55d0a21ea9 210 #define MPU6050_GYRO_FS_500 0x01
Gendy 0:4a55d0a21ea9 211 #define MPU6050_GYRO_FS_1000 0x02
Gendy 0:4a55d0a21ea9 212 #define MPU6050_GYRO_FS_2000 0x03
Gendy 0:4a55d0a21ea9 213
Gendy 0:4a55d0a21ea9 214 #define MPU6050_ACONFIG_XA_ST_BIT 7
Gendy 0:4a55d0a21ea9 215 #define MPU6050_ACONFIG_YA_ST_BIT 6
Gendy 0:4a55d0a21ea9 216 #define MPU6050_ACONFIG_ZA_ST_BIT 5
Gendy 0:4a55d0a21ea9 217 #define MPU6050_ACONFIG_AFS_SEL_BIT 4
Gendy 0:4a55d0a21ea9 218 #define MPU6050_ACONFIG_AFS_SEL_LENGTH 2
Gendy 0:4a55d0a21ea9 219 #define MPU6050_ACONFIG_ACCEL_HPF_BIT 2
Gendy 0:4a55d0a21ea9 220 #define MPU6050_ACONFIG_ACCEL_HPF_LENGTH 3
Gendy 0:4a55d0a21ea9 221
Gendy 0:4a55d0a21ea9 222 #define MPU6050_ACCEL_FS_2 0x00
Gendy 0:4a55d0a21ea9 223 #define MPU6050_ACCEL_FS_4 0x01
Gendy 0:4a55d0a21ea9 224 #define MPU6050_ACCEL_FS_8 0x02
Gendy 0:4a55d0a21ea9 225 #define MPU6050_ACCEL_FS_16 0x03
Gendy 0:4a55d0a21ea9 226
Gendy 0:4a55d0a21ea9 227 #define MPU6050_DHPF_RESET 0x00
Gendy 0:4a55d0a21ea9 228 #define MPU6050_DHPF_5 0x01
Gendy 0:4a55d0a21ea9 229 #define MPU6050_DHPF_2P5 0x02
Gendy 0:4a55d0a21ea9 230 #define MPU6050_DHPF_1P25 0x03
Gendy 0:4a55d0a21ea9 231 #define MPU6050_DHPF_0P63 0x04
Gendy 0:4a55d0a21ea9 232 #define MPU6050_DHPF_HOLD 0x07
Gendy 0:4a55d0a21ea9 233
Gendy 0:4a55d0a21ea9 234 #define MPU6050_TEMP_FIFO_EN_BIT 7
Gendy 0:4a55d0a21ea9 235 #define MPU6050_XG_FIFO_EN_BIT 6
Gendy 0:4a55d0a21ea9 236 #define MPU6050_YG_FIFO_EN_BIT 5
Gendy 0:4a55d0a21ea9 237 #define MPU6050_ZG_FIFO_EN_BIT 4
Gendy 0:4a55d0a21ea9 238 #define MPU6050_ACCEL_FIFO_EN_BIT 3
Gendy 0:4a55d0a21ea9 239 #define MPU6050_SLV2_FIFO_EN_BIT 2
Gendy 0:4a55d0a21ea9 240 #define MPU6050_SLV1_FIFO_EN_BIT 1
Gendy 0:4a55d0a21ea9 241 #define MPU6050_SLV0_FIFO_EN_BIT 0
Gendy 0:4a55d0a21ea9 242
Gendy 0:4a55d0a21ea9 243 #define MPU6050_MULT_MST_EN_BIT 7
Gendy 0:4a55d0a21ea9 244 #define MPU6050_WAIT_FOR_ES_BIT 6
Gendy 0:4a55d0a21ea9 245 #define MPU6050_SLV_3_FIFO_EN_BIT 5
Gendy 0:4a55d0a21ea9 246 #define MPU6050_I2C_MST_P_NSR_BIT 4
Gendy 0:4a55d0a21ea9 247 #define MPU6050_I2C_MST_CLK_BIT 3
Gendy 0:4a55d0a21ea9 248 #define MPU6050_I2C_MST_CLK_LENGTH 4
Gendy 0:4a55d0a21ea9 249
Gendy 0:4a55d0a21ea9 250 #define MPU6050_CLOCK_DIV_348 0x0
Gendy 0:4a55d0a21ea9 251 #define MPU6050_CLOCK_DIV_333 0x1
Gendy 0:4a55d0a21ea9 252 #define MPU6050_CLOCK_DIV_320 0x2
Gendy 0:4a55d0a21ea9 253 #define MPU6050_CLOCK_DIV_308 0x3
Gendy 0:4a55d0a21ea9 254 #define MPU6050_CLOCK_DIV_296 0x4
Gendy 0:4a55d0a21ea9 255 #define MPU6050_CLOCK_DIV_286 0x5
Gendy 0:4a55d0a21ea9 256 #define MPU6050_CLOCK_DIV_276 0x6
Gendy 0:4a55d0a21ea9 257 #define MPU6050_CLOCK_DIV_267 0x7
Gendy 0:4a55d0a21ea9 258 #define MPU6050_CLOCK_DIV_258 0x8
Gendy 0:4a55d0a21ea9 259 #define MPU6050_CLOCK_DIV_500 0x9
Gendy 0:4a55d0a21ea9 260 #define MPU6050_CLOCK_DIV_471 0xA
Gendy 0:4a55d0a21ea9 261 #define MPU6050_CLOCK_DIV_444 0xB
Gendy 0:4a55d0a21ea9 262 #define MPU6050_CLOCK_DIV_421 0xC
Gendy 0:4a55d0a21ea9 263 #define MPU6050_CLOCK_DIV_400 0xD
Gendy 0:4a55d0a21ea9 264 #define MPU6050_CLOCK_DIV_381 0xE
Gendy 0:4a55d0a21ea9 265 #define MPU6050_CLOCK_DIV_364 0xF
Gendy 0:4a55d0a21ea9 266
Gendy 0:4a55d0a21ea9 267 #define MPU6050_I2C_SLV_RW_BIT 7
Gendy 0:4a55d0a21ea9 268 #define MPU6050_I2C_SLV_ADDR_BIT 6
Gendy 0:4a55d0a21ea9 269 #define MPU6050_I2C_SLV_ADDR_LENGTH 7
Gendy 0:4a55d0a21ea9 270 #define MPU6050_I2C_SLV_EN_BIT 7
Gendy 0:4a55d0a21ea9 271 #define MPU6050_I2C_SLV_BYTE_SW_BIT 6
Gendy 0:4a55d0a21ea9 272 #define MPU6050_I2C_SLV_REG_DIS_BIT 5
Gendy 0:4a55d0a21ea9 273 #define MPU6050_I2C_SLV_GRP_BIT 4
Gendy 0:4a55d0a21ea9 274 #define MPU6050_I2C_SLV_LEN_BIT 3
Gendy 0:4a55d0a21ea9 275 #define MPU6050_I2C_SLV_LEN_LENGTH 4
Gendy 0:4a55d0a21ea9 276
Gendy 0:4a55d0a21ea9 277 #define MPU6050_I2C_SLV4_RW_BIT 7
Gendy 0:4a55d0a21ea9 278 #define MPU6050_I2C_SLV4_ADDR_BIT 6
Gendy 0:4a55d0a21ea9 279 #define MPU6050_I2C_SLV4_ADDR_LENGTH 7
Gendy 0:4a55d0a21ea9 280 #define MPU6050_I2C_SLV4_EN_BIT 7
Gendy 0:4a55d0a21ea9 281 #define MPU6050_I2C_SLV4_INT_EN_BIT 6
Gendy 0:4a55d0a21ea9 282 #define MPU6050_I2C_SLV4_REG_DIS_BIT 5
Gendy 0:4a55d0a21ea9 283 #define MPU6050_I2C_SLV4_MST_DLY_BIT 4
Gendy 0:4a55d0a21ea9 284 #define MPU6050_I2C_SLV4_MST_DLY_LENGTH 5
Gendy 0:4a55d0a21ea9 285
Gendy 0:4a55d0a21ea9 286 #define MPU6050_MST_PASS_THROUGH_BIT 7
Gendy 0:4a55d0a21ea9 287 #define MPU6050_MST_I2C_SLV4_DONE_BIT 6
Gendy 0:4a55d0a21ea9 288 #define MPU6050_MST_I2C_LOST_ARB_BIT 5
Gendy 0:4a55d0a21ea9 289 #define MPU6050_MST_I2C_SLV4_NACK_BIT 4
Gendy 0:4a55d0a21ea9 290 #define MPU6050_MST_I2C_SLV3_NACK_BIT 3
Gendy 0:4a55d0a21ea9 291 #define MPU6050_MST_I2C_SLV2_NACK_BIT 2
Gendy 0:4a55d0a21ea9 292 #define MPU6050_MST_I2C_SLV1_NACK_BIT 1
Gendy 0:4a55d0a21ea9 293 #define MPU6050_MST_I2C_SLV0_NACK_BIT 0
Gendy 0:4a55d0a21ea9 294
Gendy 0:4a55d0a21ea9 295 #define MPU6050_INTCFG_INT_LEVEL_BIT 7
Gendy 0:4a55d0a21ea9 296 #define MPU6050_INTCFG_INT_OPEN_BIT 6
Gendy 0:4a55d0a21ea9 297 #define MPU6050_INTCFG_LATCH_INT_EN_BIT 5
Gendy 0:4a55d0a21ea9 298 #define MPU6050_INTCFG_INT_RD_CLEAR_BIT 4
Gendy 0:4a55d0a21ea9 299 #define MPU6050_INTCFG_FSYNC_INT_LEVEL_BIT 3
Gendy 0:4a55d0a21ea9 300 #define MPU6050_INTCFG_FSYNC_INT_EN_BIT 2
Gendy 0:4a55d0a21ea9 301 #define MPU6050_INTCFG_I2C_BYPASS_EN_BIT 1
Gendy 0:4a55d0a21ea9 302 #define MPU6050_INTCFG_CLKOUT_EN_BIT 0
Gendy 0:4a55d0a21ea9 303
Gendy 0:4a55d0a21ea9 304 #define MPU6050_INTMODE_ACTIVEHIGH 0x00
Gendy 0:4a55d0a21ea9 305 #define MPU6050_INTMODE_ACTIVELOW 0x01
Gendy 0:4a55d0a21ea9 306
Gendy 0:4a55d0a21ea9 307 #define MPU6050_INTDRV_PUSHPULL 0x00
Gendy 0:4a55d0a21ea9 308 #define MPU6050_INTDRV_OPENDRAIN 0x01
Gendy 0:4a55d0a21ea9 309
Gendy 0:4a55d0a21ea9 310 #define MPU6050_INTLATCH_50USPULSE 0x00
Gendy 0:4a55d0a21ea9 311 #define MPU6050_INTLATCH_WAITCLEAR 0x01
Gendy 0:4a55d0a21ea9 312
Gendy 0:4a55d0a21ea9 313 #define MPU6050_INTCLEAR_STATUSREAD 0x00
Gendy 0:4a55d0a21ea9 314 #define MPU6050_INTCLEAR_ANYREAD 0x01
Gendy 0:4a55d0a21ea9 315
Gendy 0:4a55d0a21ea9 316 #define MPU6050_INTERRUPT_FF_BIT 7
Gendy 0:4a55d0a21ea9 317 #define MPU6050_INTERRUPT_MOT_BIT 6
Gendy 0:4a55d0a21ea9 318 #define MPU6050_INTERRUPT_ZMOT_BIT 5
Gendy 0:4a55d0a21ea9 319 #define MPU6050_INTERRUPT_FIFO_OFLOW_BIT 4
Gendy 0:4a55d0a21ea9 320 #define MPU6050_INTERRUPT_I2C_MST_INT_BIT 3
Gendy 0:4a55d0a21ea9 321 #define MPU6050_INTERRUPT_PLL_RDY_INT_BIT 2
Gendy 0:4a55d0a21ea9 322 #define MPU6050_INTERRUPT_DMP_INT_BIT 1
Gendy 0:4a55d0a21ea9 323 #define MPU6050_INTERRUPT_DATA_RDY_BIT 0
Gendy 0:4a55d0a21ea9 324
Gendy 0:4a55d0a21ea9 325 // TODO: figure out what these actually do
Gendy 0:4a55d0a21ea9 326 // UMPL source code is not very obivous
Gendy 0:4a55d0a21ea9 327 #define MPU6050_DMPINT_5_BIT 5
Gendy 0:4a55d0a21ea9 328 #define MPU6050_DMPINT_4_BIT 4
Gendy 0:4a55d0a21ea9 329 #define MPU6050_DMPINT_3_BIT 3
Gendy 0:4a55d0a21ea9 330 #define MPU6050_DMPINT_2_BIT 2
Gendy 0:4a55d0a21ea9 331 #define MPU6050_DMPINT_1_BIT 1
Gendy 0:4a55d0a21ea9 332 #define MPU6050_DMPINT_0_BIT 0
Gendy 0:4a55d0a21ea9 333
Gendy 0:4a55d0a21ea9 334 #define MPU6050_MOTION_MOT_XNEG_BIT 7
Gendy 0:4a55d0a21ea9 335 #define MPU6050_MOTION_MOT_XPOS_BIT 6
Gendy 0:4a55d0a21ea9 336 #define MPU6050_MOTION_MOT_YNEG_BIT 5
Gendy 0:4a55d0a21ea9 337 #define MPU6050_MOTION_MOT_YPOS_BIT 4
Gendy 0:4a55d0a21ea9 338 #define MPU6050_MOTION_MOT_ZNEG_BIT 3
Gendy 0:4a55d0a21ea9 339 #define MPU6050_MOTION_MOT_ZPOS_BIT 2
Gendy 0:4a55d0a21ea9 340 #define MPU6050_MOTION_MOT_ZRMOT_BIT 0
Gendy 0:4a55d0a21ea9 341
Gendy 0:4a55d0a21ea9 342 #define MPU6050_DELAYCTRL_DELAY_ES_SHADOW_BIT 7
Gendy 0:4a55d0a21ea9 343 #define MPU6050_DELAYCTRL_I2C_SLV4_DLY_EN_BIT 4
Gendy 0:4a55d0a21ea9 344 #define MPU6050_DELAYCTRL_I2C_SLV3_DLY_EN_BIT 3
Gendy 0:4a55d0a21ea9 345 #define MPU6050_DELAYCTRL_I2C_SLV2_DLY_EN_BIT 2
Gendy 0:4a55d0a21ea9 346 #define MPU6050_DELAYCTRL_I2C_SLV1_DLY_EN_BIT 1
Gendy 0:4a55d0a21ea9 347 #define MPU6050_DELAYCTRL_I2C_SLV0_DLY_EN_BIT 0
Gendy 0:4a55d0a21ea9 348
Gendy 0:4a55d0a21ea9 349 #define MPU6050_PATHRESET_GYRO_RESET_BIT 2
Gendy 0:4a55d0a21ea9 350 #define MPU6050_PATHRESET_ACCEL_RESET_BIT 1
Gendy 0:4a55d0a21ea9 351 #define MPU6050_PATHRESET_TEMP_RESET_BIT 0
Gendy 0:4a55d0a21ea9 352
Gendy 0:4a55d0a21ea9 353 #define MPU6050_DETECT_ACCEL_ON_DELAY_BIT 5
Gendy 0:4a55d0a21ea9 354 #define MPU6050_DETECT_ACCEL_ON_DELAY_LENGTH 2
Gendy 0:4a55d0a21ea9 355 #define MPU6050_DETECT_FF_COUNT_BIT 3
Gendy 0:4a55d0a21ea9 356 #define MPU6050_DETECT_FF_COUNT_LENGTH 2
Gendy 0:4a55d0a21ea9 357 #define MPU6050_DETECT_MOT_COUNT_BIT 1
Gendy 0:4a55d0a21ea9 358 #define MPU6050_DETECT_MOT_COUNT_LENGTH 2
Gendy 0:4a55d0a21ea9 359
Gendy 0:4a55d0a21ea9 360 #define MPU6050_DETECT_DECREMENT_RESET 0x0
Gendy 0:4a55d0a21ea9 361 #define MPU6050_DETECT_DECREMENT_1 0x1
Gendy 0:4a55d0a21ea9 362 #define MPU6050_DETECT_DECREMENT_2 0x2
Gendy 0:4a55d0a21ea9 363 #define MPU6050_DETECT_DECREMENT_4 0x3
Gendy 0:4a55d0a21ea9 364
Gendy 0:4a55d0a21ea9 365 #define MPU6050_USERCTRL_DMP_EN_BIT 7
Gendy 0:4a55d0a21ea9 366 #define MPU6050_USERCTRL_FIFO_EN_BIT 6
Gendy 0:4a55d0a21ea9 367 #define MPU6050_USERCTRL_I2C_MST_EN_BIT 5
Gendy 0:4a55d0a21ea9 368 #define MPU6050_USERCTRL_I2C_IF_DIS_BIT 4
Gendy 0:4a55d0a21ea9 369 #define MPU6050_USERCTRL_DMP_RESET_BIT 3
Gendy 0:4a55d0a21ea9 370 #define MPU6050_USERCTRL_FIFO_RESET_BIT 2
Gendy 0:4a55d0a21ea9 371 #define MPU6050_USERCTRL_I2C_MST_RESET_BIT 1
Gendy 0:4a55d0a21ea9 372 #define MPU6050_USERCTRL_SIG_COND_RESET_BIT 0
Gendy 0:4a55d0a21ea9 373
Gendy 0:4a55d0a21ea9 374 #define MPU6050_PWR1_DEVICE_RESET_BIT 7
Gendy 0:4a55d0a21ea9 375 #define MPU6050_PWR1_SLEEP_BIT 6
Gendy 0:4a55d0a21ea9 376 #define MPU6050_PWR1_CYCLE_BIT 5
Gendy 0:4a55d0a21ea9 377 #define MPU6050_PWR1_TEMP_DIS_BIT 3
Gendy 0:4a55d0a21ea9 378 #define MPU6050_PWR1_CLKSEL_BIT 2
Gendy 0:4a55d0a21ea9 379 #define MPU6050_PWR1_CLKSEL_LENGTH 3
Gendy 0:4a55d0a21ea9 380
Gendy 0:4a55d0a21ea9 381 #define MPU6050_CLOCK_INTERNAL 0x00
Gendy 0:4a55d0a21ea9 382 #define MPU6050_CLOCK_PLL_XGYRO 0x01
Gendy 0:4a55d0a21ea9 383 #define MPU6050_CLOCK_PLL_YGYRO 0x02
Gendy 0:4a55d0a21ea9 384 #define MPU6050_CLOCK_PLL_ZGYRO 0x03
Gendy 0:4a55d0a21ea9 385 #define MPU6050_CLOCK_PLL_EXT32K 0x04
Gendy 0:4a55d0a21ea9 386 #define MPU6050_CLOCK_PLL_EXT19M 0x05
Gendy 0:4a55d0a21ea9 387 #define MPU6050_CLOCK_KEEP_RESET 0x07
Gendy 0:4a55d0a21ea9 388
Gendy 0:4a55d0a21ea9 389 #define MPU6050_PWR2_LP_WAKE_CTRL_BIT 7
Gendy 0:4a55d0a21ea9 390 #define MPU6050_PWR2_LP_WAKE_CTRL_LENGTH 2
Gendy 0:4a55d0a21ea9 391 #define MPU6050_PWR2_STBY_XA_BIT 5
Gendy 0:4a55d0a21ea9 392 #define MPU6050_PWR2_STBY_YA_BIT 4
Gendy 0:4a55d0a21ea9 393 #define MPU6050_PWR2_STBY_ZA_BIT 3
Gendy 0:4a55d0a21ea9 394 #define MPU6050_PWR2_STBY_XG_BIT 2
Gendy 0:4a55d0a21ea9 395 #define MPU6050_PWR2_STBY_YG_BIT 1
Gendy 0:4a55d0a21ea9 396 #define MPU6050_PWR2_STBY_ZG_BIT 0
Gendy 0:4a55d0a21ea9 397
Gendy 0:4a55d0a21ea9 398 #define MPU6050_WAKE_FREQ_1P25 0x0
Gendy 0:4a55d0a21ea9 399 #define MPU6050_WAKE_FREQ_2P5 0x1
Gendy 0:4a55d0a21ea9 400 #define MPU6050_WAKE_FREQ_5 0x2
Gendy 0:4a55d0a21ea9 401 #define MPU6050_WAKE_FREQ_10 0x3
Gendy 0:4a55d0a21ea9 402
Gendy 0:4a55d0a21ea9 403 #define MPU6050_BANKSEL_PRFTCH_EN_BIT 6
Gendy 0:4a55d0a21ea9 404 #define MPU6050_BANKSEL_CFG_USER_BANK_BIT 5
Gendy 0:4a55d0a21ea9 405 #define MPU6050_BANKSEL_MEM_SEL_BIT 4
Gendy 0:4a55d0a21ea9 406 #define MPU6050_BANKSEL_MEM_SEL_LENGTH 5
Gendy 0:4a55d0a21ea9 407
Gendy 0:4a55d0a21ea9 408 #define MPU6050_WHO_AM_I_BIT 6
Gendy 0:4a55d0a21ea9 409 #define MPU6050_WHO_AM_I_LENGTH 6
Gendy 0:4a55d0a21ea9 410
Gendy 0:4a55d0a21ea9 411 #define MPU6050_DMP_MEMORY_BANKS 8
Gendy 0:4a55d0a21ea9 412 #define MPU6050_DMP_MEMORY_BANK_SIZE 256
Gendy 0:4a55d0a21ea9 413 #define MPU6050_DMP_MEMORY_CHUNK_SIZE 16
Gendy 0:4a55d0a21ea9 414
Gendy 0:4a55d0a21ea9 415 // note: DMP code memory blocks defined at end of header file
Gendy 0:4a55d0a21ea9 416
Gendy 0:4a55d0a21ea9 417 class MPU6050 {
Gendy 0:4a55d0a21ea9 418 private:
Gendy 0:4a55d0a21ea9 419 I2Cdev i2Cdev;
Gendy 0:4a55d0a21ea9 420 Serial debugSerial;
Gendy 0:4a55d0a21ea9 421 public:
Gendy 0:4a55d0a21ea9 422 MPU6050();
Gendy 0:4a55d0a21ea9 423 MPU6050(uint8_t address);
Gendy 0:4a55d0a21ea9 424
Gendy 0:4a55d0a21ea9 425 void initialize();
Gendy 0:4a55d0a21ea9 426 bool testConnection();
Gendy 0:4a55d0a21ea9 427
Gendy 0:4a55d0a21ea9 428 // AUX_VDDIO register
Gendy 0:4a55d0a21ea9 429 uint8_t getAuxVDDIOLevel();
Gendy 0:4a55d0a21ea9 430 void setAuxVDDIOLevel(uint8_t level);
Gendy 0:4a55d0a21ea9 431
Gendy 0:4a55d0a21ea9 432 // SMPLRT_DIV register
Gendy 0:4a55d0a21ea9 433 uint8_t getRate();
Gendy 0:4a55d0a21ea9 434 void setRate(uint8_t rate);
Gendy 0:4a55d0a21ea9 435
Gendy 0:4a55d0a21ea9 436 // CONFIG register
Gendy 0:4a55d0a21ea9 437 uint8_t getExternalFrameSync();
Gendy 0:4a55d0a21ea9 438 void setExternalFrameSync(uint8_t sync);
Gendy 0:4a55d0a21ea9 439 uint8_t getDLPFMode();
Gendy 0:4a55d0a21ea9 440 void setDLPFMode(uint8_t bandwidth);
Gendy 0:4a55d0a21ea9 441
Gendy 0:4a55d0a21ea9 442 // GYRO_CONFIG register
Gendy 0:4a55d0a21ea9 443 uint8_t getFullScaleGyroRange();
Gendy 0:4a55d0a21ea9 444 void setFullScaleGyroRange(uint8_t range);
Gendy 0:4a55d0a21ea9 445
Gendy 0:4a55d0a21ea9 446 // ACCEL_CONFIG register
Gendy 0:4a55d0a21ea9 447 bool getAccelXSelfTest();
Gendy 0:4a55d0a21ea9 448 void setAccelXSelfTest(bool enabled);
Gendy 0:4a55d0a21ea9 449 bool getAccelYSelfTest();
Gendy 0:4a55d0a21ea9 450 void setAccelYSelfTest(bool enabled);
Gendy 0:4a55d0a21ea9 451 bool getAccelZSelfTest();
Gendy 0:4a55d0a21ea9 452 void setAccelZSelfTest(bool enabled);
Gendy 0:4a55d0a21ea9 453 uint8_t getFullScaleAccelRange();
Gendy 0:4a55d0a21ea9 454 void setFullScaleAccelRange(uint8_t range);
Gendy 0:4a55d0a21ea9 455 uint8_t getDHPFMode();
Gendy 0:4a55d0a21ea9 456 void setDHPFMode(uint8_t mode);
Gendy 0:4a55d0a21ea9 457
Gendy 0:4a55d0a21ea9 458 // FF_THR register
Gendy 0:4a55d0a21ea9 459 uint8_t getFreefallDetectionThreshold();
Gendy 0:4a55d0a21ea9 460 void setFreefallDetectionThreshold(uint8_t threshold);
Gendy 0:4a55d0a21ea9 461
Gendy 0:4a55d0a21ea9 462 // FF_DUR register
Gendy 0:4a55d0a21ea9 463 uint8_t getFreefallDetectionDuration();
Gendy 0:4a55d0a21ea9 464 void setFreefallDetectionDuration(uint8_t duration);
Gendy 0:4a55d0a21ea9 465
Gendy 0:4a55d0a21ea9 466 // MOT_THR register
Gendy 0:4a55d0a21ea9 467 uint8_t getMotionDetectionThreshold();
Gendy 0:4a55d0a21ea9 468 void setMotionDetectionThreshold(uint8_t threshold);
Gendy 0:4a55d0a21ea9 469
Gendy 0:4a55d0a21ea9 470 // MOT_DUR register
Gendy 0:4a55d0a21ea9 471 uint8_t getMotionDetectionDuration();
Gendy 0:4a55d0a21ea9 472 void setMotionDetectionDuration(uint8_t duration);
Gendy 0:4a55d0a21ea9 473
Gendy 0:4a55d0a21ea9 474 // ZRMOT_THR register
Gendy 0:4a55d0a21ea9 475 uint8_t getZeroMotionDetectionThreshold();
Gendy 0:4a55d0a21ea9 476 void setZeroMotionDetectionThreshold(uint8_t threshold);
Gendy 0:4a55d0a21ea9 477
Gendy 0:4a55d0a21ea9 478 // ZRMOT_DUR register
Gendy 0:4a55d0a21ea9 479 uint8_t getZeroMotionDetectionDuration();
Gendy 0:4a55d0a21ea9 480 void setZeroMotionDetectionDuration(uint8_t duration);
Gendy 0:4a55d0a21ea9 481
Gendy 0:4a55d0a21ea9 482 // FIFO_EN register
Gendy 0:4a55d0a21ea9 483 bool getTempFIFOEnabled();
Gendy 0:4a55d0a21ea9 484 void setTempFIFOEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 485 bool getXGyroFIFOEnabled();
Gendy 0:4a55d0a21ea9 486 void setXGyroFIFOEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 487 bool getYGyroFIFOEnabled();
Gendy 0:4a55d0a21ea9 488 void setYGyroFIFOEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 489 bool getZGyroFIFOEnabled();
Gendy 0:4a55d0a21ea9 490 void setZGyroFIFOEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 491 bool getAccelFIFOEnabled();
Gendy 0:4a55d0a21ea9 492 void setAccelFIFOEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 493 bool getSlave2FIFOEnabled();
Gendy 0:4a55d0a21ea9 494 void setSlave2FIFOEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 495 bool getSlave1FIFOEnabled();
Gendy 0:4a55d0a21ea9 496 void setSlave1FIFOEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 497 bool getSlave0FIFOEnabled();
Gendy 0:4a55d0a21ea9 498 void setSlave0FIFOEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 499
Gendy 0:4a55d0a21ea9 500 // I2C_MST_CTRL register
Gendy 0:4a55d0a21ea9 501 bool getMultiMasterEnabled();
Gendy 0:4a55d0a21ea9 502 void setMultiMasterEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 503 bool getWaitForExternalSensorEnabled();
Gendy 0:4a55d0a21ea9 504 void setWaitForExternalSensorEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 505 bool getSlave3FIFOEnabled();
Gendy 0:4a55d0a21ea9 506 void setSlave3FIFOEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 507 bool getSlaveReadWriteTransitionEnabled();
Gendy 0:4a55d0a21ea9 508 void setSlaveReadWriteTransitionEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 509 uint8_t getMasterClockSpeed();
Gendy 0:4a55d0a21ea9 510 void setMasterClockSpeed(uint8_t speed);
Gendy 0:4a55d0a21ea9 511
Gendy 0:4a55d0a21ea9 512 // I2C_SLV* registers (Slave 0-3)
Gendy 0:4a55d0a21ea9 513 uint8_t getSlaveAddress(uint8_t num);
Gendy 0:4a55d0a21ea9 514 void setSlaveAddress(uint8_t num, uint8_t address);
Gendy 0:4a55d0a21ea9 515 uint8_t getSlaveRegister(uint8_t num);
Gendy 0:4a55d0a21ea9 516 void setSlaveRegister(uint8_t num, uint8_t reg);
Gendy 0:4a55d0a21ea9 517 bool getSlaveEnabled(uint8_t num);
Gendy 0:4a55d0a21ea9 518 void setSlaveEnabled(uint8_t num, bool enabled);
Gendy 0:4a55d0a21ea9 519 bool getSlaveWordByteSwap(uint8_t num);
Gendy 0:4a55d0a21ea9 520 void setSlaveWordByteSwap(uint8_t num, bool enabled);
Gendy 0:4a55d0a21ea9 521 bool getSlaveWriteMode(uint8_t num);
Gendy 0:4a55d0a21ea9 522 void setSlaveWriteMode(uint8_t num, bool mode);
Gendy 0:4a55d0a21ea9 523 bool getSlaveWordGroupOffset(uint8_t num);
Gendy 0:4a55d0a21ea9 524 void setSlaveWordGroupOffset(uint8_t num, bool enabled);
Gendy 0:4a55d0a21ea9 525 uint8_t getSlaveDataLength(uint8_t num);
Gendy 0:4a55d0a21ea9 526 void setSlaveDataLength(uint8_t num, uint8_t length);
Gendy 0:4a55d0a21ea9 527
Gendy 0:4a55d0a21ea9 528 // I2C_SLV* registers (Slave 4)
Gendy 0:4a55d0a21ea9 529 uint8_t getSlave4Address();
Gendy 0:4a55d0a21ea9 530 void setSlave4Address(uint8_t address);
Gendy 0:4a55d0a21ea9 531 uint8_t getSlave4Register();
Gendy 0:4a55d0a21ea9 532 void setSlave4Register(uint8_t reg);
Gendy 0:4a55d0a21ea9 533 void setSlave4OutputByte(uint8_t data);
Gendy 0:4a55d0a21ea9 534 bool getSlave4Enabled();
Gendy 0:4a55d0a21ea9 535 void setSlave4Enabled(bool enabled);
Gendy 0:4a55d0a21ea9 536 bool getSlave4InterruptEnabled();
Gendy 0:4a55d0a21ea9 537 void setSlave4InterruptEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 538 bool getSlave4WriteMode();
Gendy 0:4a55d0a21ea9 539 void setSlave4WriteMode(bool mode);
Gendy 0:4a55d0a21ea9 540 uint8_t getSlave4MasterDelay();
Gendy 0:4a55d0a21ea9 541 void setSlave4MasterDelay(uint8_t delay);
Gendy 0:4a55d0a21ea9 542 uint8_t getSlate4InputByte();
Gendy 0:4a55d0a21ea9 543
Gendy 0:4a55d0a21ea9 544 // I2C_MST_STATUS register
Gendy 0:4a55d0a21ea9 545 bool getPassthroughStatus();
Gendy 0:4a55d0a21ea9 546 bool getSlave4IsDone();
Gendy 0:4a55d0a21ea9 547 bool getLostArbitration();
Gendy 0:4a55d0a21ea9 548 bool getSlave4Nack();
Gendy 0:4a55d0a21ea9 549 bool getSlave3Nack();
Gendy 0:4a55d0a21ea9 550 bool getSlave2Nack();
Gendy 0:4a55d0a21ea9 551 bool getSlave1Nack();
Gendy 0:4a55d0a21ea9 552 bool getSlave0Nack();
Gendy 0:4a55d0a21ea9 553
Gendy 0:4a55d0a21ea9 554 // INT_PIN_CFG register
Gendy 0:4a55d0a21ea9 555 bool getInterruptMode();
Gendy 0:4a55d0a21ea9 556 void setInterruptMode(bool mode);
Gendy 0:4a55d0a21ea9 557 bool getInterruptDrive();
Gendy 0:4a55d0a21ea9 558 void setInterruptDrive(bool drive);
Gendy 0:4a55d0a21ea9 559 bool getInterruptLatch();
Gendy 0:4a55d0a21ea9 560 void setInterruptLatch(bool latch);
Gendy 0:4a55d0a21ea9 561 bool getInterruptLatchClear();
Gendy 0:4a55d0a21ea9 562 void setInterruptLatchClear(bool clear);
Gendy 0:4a55d0a21ea9 563 bool getFSyncInterruptLevel();
Gendy 0:4a55d0a21ea9 564 void setFSyncInterruptLevel(bool level);
Gendy 0:4a55d0a21ea9 565 bool getFSyncInterruptEnabled();
Gendy 0:4a55d0a21ea9 566 void setFSyncInterruptEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 567 bool getI2CBypassEnabled();
Gendy 0:4a55d0a21ea9 568 void setI2CBypassEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 569 bool getClockOutputEnabled();
Gendy 0:4a55d0a21ea9 570 void setClockOutputEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 571
Gendy 0:4a55d0a21ea9 572 // INT_ENABLE register
Gendy 0:4a55d0a21ea9 573 uint8_t getIntEnabled();
Gendy 0:4a55d0a21ea9 574 void setIntEnabled(uint8_t enabled);
Gendy 0:4a55d0a21ea9 575 bool getIntFreefallEnabled();
Gendy 0:4a55d0a21ea9 576 void setIntFreefallEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 577 bool getIntMotionEnabled();
Gendy 0:4a55d0a21ea9 578 void setIntMotionEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 579 bool getIntZeroMotionEnabled();
Gendy 0:4a55d0a21ea9 580 void setIntZeroMotionEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 581 bool getIntFIFOBufferOverflowEnabled();
Gendy 0:4a55d0a21ea9 582 void setIntFIFOBufferOverflowEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 583 bool getIntI2CMasterEnabled();
Gendy 0:4a55d0a21ea9 584 void setIntI2CMasterEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 585 bool getIntDataReadyEnabled();
Gendy 0:4a55d0a21ea9 586 void setIntDataReadyEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 587
Gendy 0:4a55d0a21ea9 588 // INT_STATUS register
Gendy 0:4a55d0a21ea9 589 uint8_t getIntStatus();
Gendy 0:4a55d0a21ea9 590 bool getIntFreefallStatus();
Gendy 0:4a55d0a21ea9 591 bool getIntMotionStatus();
Gendy 0:4a55d0a21ea9 592 bool getIntZeroMotionStatus();
Gendy 0:4a55d0a21ea9 593 bool getIntFIFOBufferOverflowStatus();
Gendy 0:4a55d0a21ea9 594 bool getIntI2CMasterStatus();
Gendy 0:4a55d0a21ea9 595 bool getIntDataReadyStatus();
Gendy 0:4a55d0a21ea9 596
Gendy 0:4a55d0a21ea9 597 // ACCEL_*OUT_* registers
Gendy 0:4a55d0a21ea9 598 void getMotion9(int16_t* ax, int16_t* ay, int16_t* az, int16_t* gx, int16_t* gy, int16_t* gz, int16_t* mx, int16_t* my, int16_t* mz);
Gendy 0:4a55d0a21ea9 599 void getMotion6(int16_t* ax, int16_t* ay, int16_t* az, int16_t* gx, int16_t* gy, int16_t* gz);
Gendy 0:4a55d0a21ea9 600 void getAcceleration(int16_t* x, int16_t* y, int16_t* z);
Gendy 0:4a55d0a21ea9 601 int16_t getAccelerationX();
Gendy 0:4a55d0a21ea9 602 int16_t getAccelerationY();
Gendy 0:4a55d0a21ea9 603 int16_t getAccelerationZ();
Gendy 0:4a55d0a21ea9 604
Gendy 0:4a55d0a21ea9 605 // TEMP_OUT_* registers
Gendy 0:4a55d0a21ea9 606 int16_t getTemperature();
Gendy 0:4a55d0a21ea9 607
Gendy 0:4a55d0a21ea9 608 // GYRO_*OUT_* registers
Gendy 0:4a55d0a21ea9 609 void getRotation(int16_t* x, int16_t* y, int16_t* z);
Gendy 0:4a55d0a21ea9 610 int16_t getRotationX();
Gendy 0:4a55d0a21ea9 611 int16_t getRotationY();
Gendy 0:4a55d0a21ea9 612 int16_t getRotationZ();
Gendy 0:4a55d0a21ea9 613
Gendy 0:4a55d0a21ea9 614 // EXT_SENS_DATA_* registers
Gendy 0:4a55d0a21ea9 615 uint8_t getExternalSensorByte(int position);
Gendy 0:4a55d0a21ea9 616 uint16_t getExternalSensorWord(int position);
Gendy 0:4a55d0a21ea9 617 uint32_t getExternalSensorDWord(int position);
Gendy 0:4a55d0a21ea9 618
Gendy 0:4a55d0a21ea9 619 // MOT_DETECT_STATUS register
Gendy 0:4a55d0a21ea9 620 bool getXNegMotionDetected();
Gendy 0:4a55d0a21ea9 621 bool getXPosMotionDetected();
Gendy 0:4a55d0a21ea9 622 bool getYNegMotionDetected();
Gendy 0:4a55d0a21ea9 623 bool getYPosMotionDetected();
Gendy 0:4a55d0a21ea9 624 bool getZNegMotionDetected();
Gendy 0:4a55d0a21ea9 625 bool getZPosMotionDetected();
Gendy 0:4a55d0a21ea9 626 bool getZeroMotionDetected();
Gendy 0:4a55d0a21ea9 627
Gendy 0:4a55d0a21ea9 628 // I2C_SLV*_DO register
Gendy 0:4a55d0a21ea9 629 void setSlaveOutputByte(uint8_t num, uint8_t data);
Gendy 0:4a55d0a21ea9 630
Gendy 0:4a55d0a21ea9 631 // I2C_MST_DELAY_CTRL register
Gendy 0:4a55d0a21ea9 632 bool getExternalShadowDelayEnabled();
Gendy 0:4a55d0a21ea9 633 void setExternalShadowDelayEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 634 bool getSlaveDelayEnabled(uint8_t num);
Gendy 0:4a55d0a21ea9 635 void setSlaveDelayEnabled(uint8_t num, bool enabled);
Gendy 0:4a55d0a21ea9 636
Gendy 0:4a55d0a21ea9 637 // SIGNAL_PATH_RESET register
Gendy 0:4a55d0a21ea9 638 void resetGyroscopePath();
Gendy 0:4a55d0a21ea9 639 void resetAccelerometerPath();
Gendy 0:4a55d0a21ea9 640 void resetTemperaturePath();
Gendy 0:4a55d0a21ea9 641
Gendy 0:4a55d0a21ea9 642 // MOT_DETECT_CTRL register
Gendy 0:4a55d0a21ea9 643 uint8_t getAccelerometerPowerOnDelay();
Gendy 0:4a55d0a21ea9 644 void setAccelerometerPowerOnDelay(uint8_t delay);
Gendy 0:4a55d0a21ea9 645 uint8_t getFreefallDetectionCounterDecrement();
Gendy 0:4a55d0a21ea9 646 void setFreefallDetectionCounterDecrement(uint8_t decrement);
Gendy 0:4a55d0a21ea9 647 uint8_t getMotionDetectionCounterDecrement();
Gendy 0:4a55d0a21ea9 648 void setMotionDetectionCounterDecrement(uint8_t decrement);
Gendy 0:4a55d0a21ea9 649
Gendy 0:4a55d0a21ea9 650 // USER_CTRL register
Gendy 0:4a55d0a21ea9 651 bool getFIFOEnabled();
Gendy 0:4a55d0a21ea9 652 void setFIFOEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 653 bool getI2CMasterModeEnabled();
Gendy 0:4a55d0a21ea9 654 void setI2CMasterModeEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 655 void switchSPIEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 656 void resetFIFO();
Gendy 0:4a55d0a21ea9 657 void resetI2CMaster();
Gendy 0:4a55d0a21ea9 658 void resetSensors();
Gendy 0:4a55d0a21ea9 659
Gendy 0:4a55d0a21ea9 660 // PWR_MGMT_1 register
Gendy 0:4a55d0a21ea9 661 void reset();
Gendy 0:4a55d0a21ea9 662 bool getSleepEnabled();
Gendy 0:4a55d0a21ea9 663 void setSleepEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 664 bool getWakeCycleEnabled();
Gendy 0:4a55d0a21ea9 665 void setWakeCycleEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 666 bool getTempSensorEnabled();
Gendy 0:4a55d0a21ea9 667 void setTempSensorEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 668 uint8_t getClockSource();
Gendy 0:4a55d0a21ea9 669 void setClockSource(uint8_t source);
Gendy 0:4a55d0a21ea9 670
Gendy 0:4a55d0a21ea9 671 // PWR_MGMT_2 register
Gendy 0:4a55d0a21ea9 672 uint8_t getWakeFrequency();
Gendy 0:4a55d0a21ea9 673 void setWakeFrequency(uint8_t frequency);
Gendy 0:4a55d0a21ea9 674 bool getStandbyXAccelEnabled();
Gendy 0:4a55d0a21ea9 675 void setStandbyXAccelEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 676 bool getStandbyYAccelEnabled();
Gendy 0:4a55d0a21ea9 677 void setStandbyYAccelEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 678 bool getStandbyZAccelEnabled();
Gendy 0:4a55d0a21ea9 679 void setStandbyZAccelEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 680 bool getStandbyXGyroEnabled();
Gendy 0:4a55d0a21ea9 681 void setStandbyXGyroEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 682 bool getStandbyYGyroEnabled();
Gendy 0:4a55d0a21ea9 683 void setStandbyYGyroEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 684 bool getStandbyZGyroEnabled();
Gendy 0:4a55d0a21ea9 685 void setStandbyZGyroEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 686
Gendy 0:4a55d0a21ea9 687 // FIFO_COUNT_* registers
Gendy 0:4a55d0a21ea9 688 uint16_t getFIFOCount();
Gendy 0:4a55d0a21ea9 689
Gendy 0:4a55d0a21ea9 690 // FIFO_R_W register
Gendy 0:4a55d0a21ea9 691 uint8_t getFIFOByte();
Gendy 0:4a55d0a21ea9 692 void setFIFOByte(uint8_t data);
Gendy 0:4a55d0a21ea9 693 void getFIFOBytes(uint8_t *data, uint8_t length);
Gendy 0:4a55d0a21ea9 694
Gendy 0:4a55d0a21ea9 695 // WHO_AM_I register
Gendy 0:4a55d0a21ea9 696 uint8_t getDeviceID();
Gendy 0:4a55d0a21ea9 697 void setDeviceID(uint8_t id);
Gendy 0:4a55d0a21ea9 698
Gendy 0:4a55d0a21ea9 699 // ======== UNDOCUMENTED/DMP REGISTERS/METHODS ========
Gendy 0:4a55d0a21ea9 700
Gendy 0:4a55d0a21ea9 701 // XG_OFFS_TC register
Gendy 0:4a55d0a21ea9 702 uint8_t getOTPBankValid();
Gendy 0:4a55d0a21ea9 703 void setOTPBankValid(bool enabled);
Gendy 0:4a55d0a21ea9 704 int8_t getXGyroOffset();
Gendy 0:4a55d0a21ea9 705 void setXGyroOffset(int8_t offset);
Gendy 0:4a55d0a21ea9 706
Gendy 0:4a55d0a21ea9 707 // YG_OFFS_TC register
Gendy 0:4a55d0a21ea9 708 int8_t getYGyroOffset();
Gendy 0:4a55d0a21ea9 709 void setYGyroOffset(int8_t offset);
Gendy 0:4a55d0a21ea9 710
Gendy 0:4a55d0a21ea9 711 // ZG_OFFS_TC register
Gendy 0:4a55d0a21ea9 712 int8_t getZGyroOffset();
Gendy 0:4a55d0a21ea9 713 void setZGyroOffset(int8_t offset);
Gendy 0:4a55d0a21ea9 714
Gendy 0:4a55d0a21ea9 715 // X_FINE_GAIN register
Gendy 0:4a55d0a21ea9 716 int8_t getXFineGain();
Gendy 0:4a55d0a21ea9 717 void setXFineGain(int8_t gain);
Gendy 0:4a55d0a21ea9 718
Gendy 0:4a55d0a21ea9 719 // Y_FINE_GAIN register
Gendy 0:4a55d0a21ea9 720 int8_t getYFineGain();
Gendy 0:4a55d0a21ea9 721 void setYFineGain(int8_t gain);
Gendy 0:4a55d0a21ea9 722
Gendy 0:4a55d0a21ea9 723 // Z_FINE_GAIN register
Gendy 0:4a55d0a21ea9 724 int8_t getZFineGain();
Gendy 0:4a55d0a21ea9 725 void setZFineGain(int8_t gain);
Gendy 0:4a55d0a21ea9 726
Gendy 0:4a55d0a21ea9 727 // XA_OFFS_* registers
Gendy 0:4a55d0a21ea9 728 int16_t getXAccelOffset();
Gendy 0:4a55d0a21ea9 729 void setXAccelOffset(int16_t offset);
Gendy 0:4a55d0a21ea9 730
Gendy 0:4a55d0a21ea9 731 // YA_OFFS_* register
Gendy 0:4a55d0a21ea9 732 int16_t getYAccelOffset();
Gendy 0:4a55d0a21ea9 733 void setYAccelOffset(int16_t offset);
Gendy 0:4a55d0a21ea9 734
Gendy 0:4a55d0a21ea9 735 // ZA_OFFS_* register
Gendy 0:4a55d0a21ea9 736 int16_t getZAccelOffset();
Gendy 0:4a55d0a21ea9 737 void setZAccelOffset(int16_t offset);
Gendy 0:4a55d0a21ea9 738
Gendy 0:4a55d0a21ea9 739 // XG_OFFS_USR* registers
Gendy 0:4a55d0a21ea9 740 int16_t getXGyroOffsetUser();
Gendy 0:4a55d0a21ea9 741 void setXGyroOffsetUser(int16_t offset);
Gendy 0:4a55d0a21ea9 742
Gendy 0:4a55d0a21ea9 743 // YG_OFFS_USR* register
Gendy 0:4a55d0a21ea9 744 int16_t getYGyroOffsetUser();
Gendy 0:4a55d0a21ea9 745 void setYGyroOffsetUser(int16_t offset);
Gendy 0:4a55d0a21ea9 746
Gendy 0:4a55d0a21ea9 747 // ZG_OFFS_USR* register
Gendy 0:4a55d0a21ea9 748 int16_t getZGyroOffsetUser();
Gendy 0:4a55d0a21ea9 749 void setZGyroOffsetUser(int16_t offset);
Gendy 0:4a55d0a21ea9 750
Gendy 0:4a55d0a21ea9 751 // INT_ENABLE register (DMP functions)
Gendy 0:4a55d0a21ea9 752 bool getIntPLLReadyEnabled();
Gendy 0:4a55d0a21ea9 753 void setIntPLLReadyEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 754 bool getIntDMPEnabled();
Gendy 0:4a55d0a21ea9 755 void setIntDMPEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 756
Gendy 0:4a55d0a21ea9 757 // DMP_INT_STATUS
Gendy 0:4a55d0a21ea9 758 bool getDMPInt5Status();
Gendy 0:4a55d0a21ea9 759 bool getDMPInt4Status();
Gendy 0:4a55d0a21ea9 760 bool getDMPInt3Status();
Gendy 0:4a55d0a21ea9 761 bool getDMPInt2Status();
Gendy 0:4a55d0a21ea9 762 bool getDMPInt1Status();
Gendy 0:4a55d0a21ea9 763 bool getDMPInt0Status();
Gendy 0:4a55d0a21ea9 764
Gendy 0:4a55d0a21ea9 765 // INT_STATUS register (DMP functions)
Gendy 0:4a55d0a21ea9 766 bool getIntPLLReadyStatus();
Gendy 0:4a55d0a21ea9 767 bool getIntDMPStatus();
Gendy 0:4a55d0a21ea9 768
Gendy 0:4a55d0a21ea9 769 // USER_CTRL register (DMP functions)
Gendy 0:4a55d0a21ea9 770 bool getDMPEnabled();
Gendy 0:4a55d0a21ea9 771 void setDMPEnabled(bool enabled);
Gendy 0:4a55d0a21ea9 772 void resetDMP();
Gendy 0:4a55d0a21ea9 773
Gendy 0:4a55d0a21ea9 774 // BANK_SEL register
Gendy 0:4a55d0a21ea9 775 void setMemoryBank(uint8_t bank, bool prefetchEnabled=false, bool userBank=false);
Gendy 0:4a55d0a21ea9 776
Gendy 0:4a55d0a21ea9 777 // MEM_START_ADDR register
Gendy 0:4a55d0a21ea9 778 void setMemoryStartAddress(uint8_t address);
Gendy 0:4a55d0a21ea9 779
Gendy 0:4a55d0a21ea9 780 // MEM_R_W register
Gendy 0:4a55d0a21ea9 781 uint8_t readMemoryByte();
Gendy 0:4a55d0a21ea9 782 void writeMemoryByte(uint8_t data);
Gendy 0:4a55d0a21ea9 783 void readMemoryBlock(uint8_t *data, uint16_t dataSize, uint8_t bank=0, uint8_t address=0);
Gendy 0:4a55d0a21ea9 784 bool writeMemoryBlock(const uint8_t *data, uint16_t dataSize, uint8_t bank=0, uint8_t address=0, bool verify=true, bool useProgMem=false);
Gendy 0:4a55d0a21ea9 785 bool writeProgMemoryBlock(const uint8_t *data, uint16_t dataSize, uint8_t bank=0, uint8_t address=0, bool verify=true);
Gendy 0:4a55d0a21ea9 786
Gendy 0:4a55d0a21ea9 787 bool writeDMPConfigurationSet(const uint8_t *data, uint16_t dataSize, bool useProgMem=false);
Gendy 0:4a55d0a21ea9 788 bool writeProgDMPConfigurationSet(const uint8_t *data, uint16_t dataSize);
Gendy 0:4a55d0a21ea9 789
Gendy 0:4a55d0a21ea9 790 // DMP_CFG_1 register
Gendy 0:4a55d0a21ea9 791 uint8_t getDMPConfig1();
Gendy 0:4a55d0a21ea9 792 void setDMPConfig1(uint8_t config);
Gendy 0:4a55d0a21ea9 793
Gendy 0:4a55d0a21ea9 794 // DMP_CFG_2 register
Gendy 0:4a55d0a21ea9 795 uint8_t getDMPConfig2();
Gendy 0:4a55d0a21ea9 796 void setDMPConfig2(uint8_t config);
Gendy 0:4a55d0a21ea9 797
Gendy 0:4a55d0a21ea9 798 // special methods for MotionApps 2.0 implementation
Gendy 0:4a55d0a21ea9 799 #ifdef MPU6050_INCLUDE_DMP_MOTIONAPPS20
Gendy 0:4a55d0a21ea9 800 uint8_t *dmpPacketBuffer;
Gendy 0:4a55d0a21ea9 801 uint16_t dmpPacketSize;
Gendy 0:4a55d0a21ea9 802
Gendy 0:4a55d0a21ea9 803 uint8_t dmpInitialize();
Gendy 0:4a55d0a21ea9 804 bool dmpPacketAvailable();
Gendy 0:4a55d0a21ea9 805
Gendy 0:4a55d0a21ea9 806 uint8_t dmpSetFIFORate(uint8_t fifoRate);
Gendy 0:4a55d0a21ea9 807 uint8_t dmpGetFIFORate();
Gendy 0:4a55d0a21ea9 808 uint8_t dmpGetSampleStepSizeMS();
Gendy 0:4a55d0a21ea9 809 uint8_t dmpGetSampleFrequency();
Gendy 0:4a55d0a21ea9 810 int32_t dmpDecodeTemperature(int8_t tempReg);
Gendy 0:4a55d0a21ea9 811
Gendy 0:4a55d0a21ea9 812 // Register callbacks after a packet of FIFO data is processed
Gendy 0:4a55d0a21ea9 813 //uint8_t dmpRegisterFIFORateProcess(inv_obj_func func, int16_t priority);
Gendy 0:4a55d0a21ea9 814 //uint8_t dmpUnregisterFIFORateProcess(inv_obj_func func);
Gendy 0:4a55d0a21ea9 815 uint8_t dmpRunFIFORateProcesses();
Gendy 0:4a55d0a21ea9 816
Gendy 0:4a55d0a21ea9 817 // Setup FIFO for various output
Gendy 0:4a55d0a21ea9 818 uint8_t dmpSendQuaternion(uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 819 uint8_t dmpSendGyro(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 820 uint8_t dmpSendAccel(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 821 uint8_t dmpSendLinearAccel(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 822 uint8_t dmpSendLinearAccelInWorld(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 823 uint8_t dmpSendControlData(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 824 uint8_t dmpSendSensorData(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 825 uint8_t dmpSendExternalSensorData(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 826 uint8_t dmpSendGravity(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 827 uint8_t dmpSendPacketNumber(uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 828 uint8_t dmpSendQuantizedAccel(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 829 uint8_t dmpSendEIS(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 830
Gendy 0:4a55d0a21ea9 831 // Get Fixed Point data from FIFO
Gendy 0:4a55d0a21ea9 832 uint8_t dmpGetAccel(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 833 uint8_t dmpGetAccel(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 834 uint8_t dmpGetAccel(VectorInt16 *v, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 835 uint8_t dmpGetQuaternion(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 836 uint8_t dmpGetQuaternion(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 837 uint8_t dmpGetQuaternion(Quaternion *q, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 838 uint8_t dmpGet6AxisQuaternion(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 839 uint8_t dmpGet6AxisQuaternion(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 840 uint8_t dmpGet6AxisQuaternion(Quaternion *q, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 841 uint8_t dmpGetRelativeQuaternion(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 842 uint8_t dmpGetRelativeQuaternion(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 843 uint8_t dmpGetRelativeQuaternion(Quaternion *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 844 uint8_t dmpGetGyro(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 845 uint8_t dmpGetGyro(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 846 uint8_t dmpGetGyro(VectorInt16 *v, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 847 uint8_t dmpSetLinearAccelFilterCoefficient(float coef);
Gendy 0:4a55d0a21ea9 848 uint8_t dmpGetLinearAccel(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 849 uint8_t dmpGetLinearAccel(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 850 uint8_t dmpGetLinearAccel(VectorInt16 *v, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 851 uint8_t dmpGetLinearAccel(VectorInt16 *v, VectorInt16 *vRaw, VectorFloat *gravity);
Gendy 0:4a55d0a21ea9 852 uint8_t dmpGetLinearAccelInWorld(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 853 uint8_t dmpGetLinearAccelInWorld(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 854 uint8_t dmpGetLinearAccelInWorld(VectorInt16 *v, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 855 uint8_t dmpGetLinearAccelInWorld(VectorInt16 *v, VectorInt16 *vReal, Quaternion *q);
Gendy 0:4a55d0a21ea9 856 uint8_t dmpGetGyroAndAccelSensor(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 857 uint8_t dmpGetGyroAndAccelSensor(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 858 uint8_t dmpGetGyroAndAccelSensor(VectorInt16 *g, VectorInt16 *a, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 859 uint8_t dmpGetGyroSensor(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 860 uint8_t dmpGetGyroSensor(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 861 uint8_t dmpGetGyroSensor(VectorInt16 *v, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 862 uint8_t dmpGetControlData(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 863 uint8_t dmpGetTemperature(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 864 uint8_t dmpGetGravity(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 865 uint8_t dmpGetGravity(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 866 uint8_t dmpGetGravity(VectorInt16 *v, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 867 uint8_t dmpGetGravity(VectorFloat *v, Quaternion *q);
Gendy 0:4a55d0a21ea9 868 uint8_t dmpGetUnquantizedAccel(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 869 uint8_t dmpGetUnquantizedAccel(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 870 uint8_t dmpGetUnquantizedAccel(VectorInt16 *v, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 871 uint8_t dmpGetQuantizedAccel(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 872 uint8_t dmpGetQuantizedAccel(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 873 uint8_t dmpGetQuantizedAccel(VectorInt16 *v, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 874 uint8_t dmpGetExternalSensorData(int32_t *data, uint16_t size, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 875 uint8_t dmpGetEIS(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 876
Gendy 0:4a55d0a21ea9 877 uint8_t dmpGetEuler(float *data, Quaternion *q);
Gendy 0:4a55d0a21ea9 878 uint8_t dmpGetYawPitchRoll(float *data, Quaternion *q, VectorFloat *gravity);
Gendy 0:4a55d0a21ea9 879
Gendy 0:4a55d0a21ea9 880 // Get Floating Point data from FIFO
Gendy 0:4a55d0a21ea9 881 uint8_t dmpGetAccelFloat(float *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 882 uint8_t dmpGetQuaternionFloat(float *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 883
Gendy 0:4a55d0a21ea9 884 uint8_t dmpProcessFIFOPacket(const unsigned char *dmpData);
Gendy 0:4a55d0a21ea9 885 uint8_t dmpReadAndProcessFIFOPacket(uint8_t numPackets, uint8_t *processed=NULL);
Gendy 0:4a55d0a21ea9 886
Gendy 0:4a55d0a21ea9 887 uint8_t dmpSetFIFOProcessedCallback(void (*func) (void));
Gendy 0:4a55d0a21ea9 888
Gendy 0:4a55d0a21ea9 889 uint8_t dmpInitFIFOParam();
Gendy 0:4a55d0a21ea9 890 uint8_t dmpCloseFIFO();
Gendy 0:4a55d0a21ea9 891 uint8_t dmpSetGyroDataSource(uint8_t source);
Gendy 0:4a55d0a21ea9 892 uint8_t dmpDecodeQuantizedAccel();
Gendy 0:4a55d0a21ea9 893 uint32_t dmpGetGyroSumOfSquare();
Gendy 0:4a55d0a21ea9 894 uint32_t dmpGetAccelSumOfSquare();
Gendy 0:4a55d0a21ea9 895 void dmpOverrideQuaternion(long *q);
Gendy 0:4a55d0a21ea9 896 uint16_t dmpGetFIFOPacketSize();
Gendy 0:4a55d0a21ea9 897 #endif
Gendy 0:4a55d0a21ea9 898
Gendy 0:4a55d0a21ea9 899 // special methods for MotionApps 4.1 implementation
Gendy 0:4a55d0a21ea9 900 #ifdef MPU6050_INCLUDE_DMP_MOTIONAPPS41
Gendy 0:4a55d0a21ea9 901 uint8_t *dmpPacketBuffer;
Gendy 0:4a55d0a21ea9 902 uint16_t dmpPacketSize;
Gendy 0:4a55d0a21ea9 903
Gendy 0:4a55d0a21ea9 904 uint8_t dmpInitialize();
Gendy 0:4a55d0a21ea9 905 bool dmpPacketAvailable();
Gendy 0:4a55d0a21ea9 906
Gendy 0:4a55d0a21ea9 907 uint8_t dmpSetFIFORate(uint8_t fifoRate);
Gendy 0:4a55d0a21ea9 908 uint8_t dmpGetFIFORate();
Gendy 0:4a55d0a21ea9 909 uint8_t dmpGetSampleStepSizeMS();
Gendy 0:4a55d0a21ea9 910 uint8_t dmpGetSampleFrequency();
Gendy 0:4a55d0a21ea9 911 int32_t dmpDecodeTemperature(int8_t tempReg);
Gendy 0:4a55d0a21ea9 912
Gendy 0:4a55d0a21ea9 913 // Register callbacks after a packet of FIFO data is processed
Gendy 0:4a55d0a21ea9 914 //uint8_t dmpRegisterFIFORateProcess(inv_obj_func func, int16_t priority);
Gendy 0:4a55d0a21ea9 915 //uint8_t dmpUnregisterFIFORateProcess(inv_obj_func func);
Gendy 0:4a55d0a21ea9 916 uint8_t dmpRunFIFORateProcesses();
Gendy 0:4a55d0a21ea9 917
Gendy 0:4a55d0a21ea9 918 // Setup FIFO for various output
Gendy 0:4a55d0a21ea9 919 uint8_t dmpSendQuaternion(uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 920 uint8_t dmpSendGyro(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 921 uint8_t dmpSendAccel(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 922 uint8_t dmpSendLinearAccel(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 923 uint8_t dmpSendLinearAccelInWorld(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 924 uint8_t dmpSendControlData(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 925 uint8_t dmpSendSensorData(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 926 uint8_t dmpSendExternalSensorData(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 927 uint8_t dmpSendGravity(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 928 uint8_t dmpSendPacketNumber(uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 929 uint8_t dmpSendQuantizedAccel(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 930 uint8_t dmpSendEIS(uint_fast16_t elements, uint_fast16_t accuracy);
Gendy 0:4a55d0a21ea9 931
Gendy 0:4a55d0a21ea9 932 // Get Fixed Point data from FIFO
Gendy 0:4a55d0a21ea9 933 uint8_t dmpGetAccel(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 934 uint8_t dmpGetAccel(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 935 uint8_t dmpGetAccel(VectorInt16 *v, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 936 uint8_t dmpGetQuaternion(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 937 uint8_t dmpGetQuaternion(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 938 uint8_t dmpGetQuaternion(Quaternion *q, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 939 uint8_t dmpGet6AxisQuaternion(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 940 uint8_t dmpGet6AxisQuaternion(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 941 uint8_t dmpGet6AxisQuaternion(Quaternion *q, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 942 uint8_t dmpGetRelativeQuaternion(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 943 uint8_t dmpGetRelativeQuaternion(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 944 uint8_t dmpGetRelativeQuaternion(Quaternion *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 945 uint8_t dmpGetGyro(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 946 uint8_t dmpGetGyro(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 947 uint8_t dmpGetGyro(VectorInt16 *v, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 948 uint8_t dmpGetMag(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 949 uint8_t dmpSetLinearAccelFilterCoefficient(float coef);
Gendy 0:4a55d0a21ea9 950 uint8_t dmpGetLinearAccel(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 951 uint8_t dmpGetLinearAccel(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 952 uint8_t dmpGetLinearAccel(VectorInt16 *v, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 953 uint8_t dmpGetLinearAccel(VectorInt16 *v, VectorInt16 *vRaw, VectorFloat *gravity);
Gendy 0:4a55d0a21ea9 954 uint8_t dmpGetLinearAccelInWorld(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 955 uint8_t dmpGetLinearAccelInWorld(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 956 uint8_t dmpGetLinearAccelInWorld(VectorInt16 *v, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 957 uint8_t dmpGetLinearAccelInWorld(VectorInt16 *v, VectorInt16 *vReal, Quaternion *q);
Gendy 0:4a55d0a21ea9 958 uint8_t dmpGetGyroAndAccelSensor(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 959 uint8_t dmpGetGyroAndAccelSensor(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 960 uint8_t dmpGetGyroAndAccelSensor(VectorInt16 *g, VectorInt16 *a, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 961 uint8_t dmpGetGyroSensor(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 962 uint8_t dmpGetGyroSensor(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 963 uint8_t dmpGetGyroSensor(VectorInt16 *v, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 964 uint8_t dmpGetControlData(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 965 uint8_t dmpGetTemperature(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 966 uint8_t dmpGetGravity(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 967 uint8_t dmpGetGravity(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 968 uint8_t dmpGetGravity(VectorInt16 *v, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 969 uint8_t dmpGetGravity(VectorFloat *v, Quaternion *q);
Gendy 0:4a55d0a21ea9 970 uint8_t dmpGetUnquantizedAccel(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 971 uint8_t dmpGetUnquantizedAccel(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 972 uint8_t dmpGetUnquantizedAccel(VectorInt16 *v, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 973 uint8_t dmpGetQuantizedAccel(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 974 uint8_t dmpGetQuantizedAccel(int16_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 975 uint8_t dmpGetQuantizedAccel(VectorInt16 *v, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 976 uint8_t dmpGetExternalSensorData(int32_t *data, uint16_t size, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 977 uint8_t dmpGetEIS(int32_t *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 978
Gendy 0:4a55d0a21ea9 979 uint8_t dmpGetEuler(float *data, Quaternion *q);
Gendy 0:4a55d0a21ea9 980 uint8_t dmpGetYawPitchRoll(float *data, Quaternion *q, VectorFloat *gravity);
Gendy 0:4a55d0a21ea9 981
Gendy 0:4a55d0a21ea9 982 // Get Floating Point data from FIFO
Gendy 0:4a55d0a21ea9 983 uint8_t dmpGetAccelFloat(float *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 984 uint8_t dmpGetQuaternionFloat(float *data, const uint8_t* packet=0);
Gendy 0:4a55d0a21ea9 985
Gendy 0:4a55d0a21ea9 986 uint8_t dmpProcessFIFOPacket(const unsigned char *dmpData);
Gendy 0:4a55d0a21ea9 987 uint8_t dmpReadAndProcessFIFOPacket(uint8_t numPackets, uint8_t *processed=NULL);
Gendy 0:4a55d0a21ea9 988
Gendy 0:4a55d0a21ea9 989 uint8_t dmpSetFIFOProcessedCallback(void (*func) (void));
Gendy 0:4a55d0a21ea9 990
Gendy 0:4a55d0a21ea9 991 uint8_t dmpInitFIFOParam();
Gendy 0:4a55d0a21ea9 992 uint8_t dmpCloseFIFO();
Gendy 0:4a55d0a21ea9 993 uint8_t dmpSetGyroDataSource(uint8_t source);
Gendy 0:4a55d0a21ea9 994 uint8_t dmpDecodeQuantizedAccel();
Gendy 0:4a55d0a21ea9 995 uint32_t dmpGetGyroSumOfSquare();
Gendy 0:4a55d0a21ea9 996 uint32_t dmpGetAccelSumOfSquare();
Gendy 0:4a55d0a21ea9 997 void dmpOverrideQuaternion(long *q);
Gendy 0:4a55d0a21ea9 998 uint16_t dmpGetFIFOPacketSize();
Gendy 0:4a55d0a21ea9 999 #endif
Gendy 0:4a55d0a21ea9 1000
Gendy 0:4a55d0a21ea9 1001 private:
Gendy 0:4a55d0a21ea9 1002 uint8_t devAddr;
Gendy 0:4a55d0a21ea9 1003 uint8_t buffer[14];
Gendy 0:4a55d0a21ea9 1004 };
Gendy 0:4a55d0a21ea9 1005
Gendy 0:4a55d0a21ea9 1006 #endif /* _MPU6050_H_ */