Change WHO_AM_I to match datasheet (#13200)
[betaflight.git] / src / main / drivers / accgyro / accgyro_mpu.h
blobaac3826ff96dd505da8d1bb7957fc5741b6915d7
1 /*
2 * This file is part of Cleanflight and Betaflight.
4 * Cleanflight and Betaflight are free software. You can redistribute
5 * this software and/or modify this software under the terms of the
6 * GNU General Public License as published by the Free Software
7 * Foundation, either version 3 of the License, or (at your option)
8 * any later version.
10 * Cleanflight and Betaflight are distributed in the hope that they
11 * will be useful, but WITHOUT ANY WARRANTY; without even the implied
12 * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
13 * See the GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this software.
18 * If not, see <http://www.gnu.org/licenses/>.
21 #pragma once
23 #include "drivers/bus.h"
24 #include "drivers/exti.h"
25 #include "drivers/sensor.h"
27 #if defined(USE_GYRO_SPI_MPU6500) || defined(USE_GYRO_SPI_MPU6000) || defined(USE_GYRO_SPI_MPU9250) || defined(USE_GYRO_SPI_ICM20649) \
28 || defined(USE_GYRO_SPI_ICM20689)
29 #define GYRO_USES_SPI
30 #endif
32 // MPU6050
33 #define MPU_RA_WHO_AM_I 0x75
34 #define MPU_RA_WHO_AM_I_LEGACY 0x00
36 #define MPUx0x0_WHO_AM_I_CONST (0x68) // MPU3050, 6000 and 6050
37 #define MPU6000_WHO_AM_I_CONST (0x68)
38 #define MPU6500_WHO_AM_I_CONST (0x70)
39 #define MPU9250_WHO_AM_I_CONST (0x71)
40 #define MPU9255_WHO_AM_I_CONST (0x73)
41 #define ICM20601_WHO_AM_I_CONST (0xAC)
42 #define ICM20602_WHO_AM_I_CONST (0x12)
43 #define ICM20608G_WHO_AM_I_CONST (0xAF)
44 #define ICM20649_WHO_AM_I_CONST (0xE1)
45 #define ICM20689_WHO_AM_I_CONST (0x98)
46 #define ICM42605_WHO_AM_I_CONST (0x42)
47 #define ICM42688P_WHO_AM_I_CONST (0x47)
48 #define LSM6DSV16X_WHO_AM_I_CONST (0x70)
50 // RA = Register Address
52 #define MPU_RA_XG_OFFS_TC 0x00 //[7] PWR_MODE, [6:1] XG_OFFS_TC, [0] OTP_BNK_VLD
53 #define MPU_RA_YG_OFFS_TC 0x01 //[7] PWR_MODE, [6:1] YG_OFFS_TC, [0] OTP_BNK_VLD
54 #define MPU_RA_ZG_OFFS_TC 0x02 //[7] PWR_MODE, [6:1] ZG_OFFS_TC, [0] OTP_BNK_VLD
55 #define MPU_RA_X_FINE_GAIN 0x03 //[7:0] X_FINE_GAIN
56 #define MPU_RA_Y_FINE_GAIN 0x04 //[7:0] Y_FINE_GAIN
57 #define MPU_RA_Z_FINE_GAIN 0x05 //[7:0] Z_FINE_GAIN
58 #define MPU_RA_XA_OFFS_H 0x06 //[15:0] XA_OFFS
59 #define MPU_RA_XA_OFFS_L_TC 0x07
60 #define MPU_RA_YA_OFFS_H 0x08 //[15:0] YA_OFFS
61 #define MPU_RA_YA_OFFS_L_TC 0x09
62 #define MPU_RA_ZA_OFFS_H 0x0A //[15:0] ZA_OFFS
63 #define MPU_RA_ZA_OFFS_L_TC 0x0B
64 #define MPU_RA_PRODUCT_ID 0x0C // Product ID Register
65 #define MPU_RA_XG_OFFS_USRH 0x13 //[15:0] XG_OFFS_USR
66 #define MPU_RA_XG_OFFS_USRL 0x14
67 #define MPU_RA_YG_OFFS_USRH 0x15 //[15:0] YG_OFFS_USR
68 #define MPU_RA_YG_OFFS_USRL 0x16
69 #define MPU_RA_ZG_OFFS_USRH 0x17 //[15:0] ZG_OFFS_USR
70 #define MPU_RA_ZG_OFFS_USRL 0x18
71 #define MPU_RA_SMPLRT_DIV 0x19
72 #define MPU_RA_CONFIG 0x1A
73 #define MPU_RA_GYRO_CONFIG 0x1B
74 #define MPU_RA_ACCEL_CONFIG 0x1C
75 #define MPU_RA_FF_THR 0x1D
76 #define MPU_RA_FF_DUR 0x1E
77 #define MPU_RA_MOT_THR 0x1F
78 #define MPU_RA_MOT_DUR 0x20
79 #define MPU_RA_ZRMOT_THR 0x21
80 #define MPU_RA_ZRMOT_DUR 0x22
81 #define MPU_RA_FIFO_EN 0x23
82 #define MPU_RA_I2C_MST_CTRL 0x24
83 #define MPU_RA_I2C_SLV0_ADDR 0x25
84 #define MPU_RA_I2C_SLV0_REG 0x26
85 #define MPU_RA_I2C_SLV0_CTRL 0x27
86 #define MPU_RA_I2C_SLV1_ADDR 0x28
87 #define MPU_RA_I2C_SLV1_REG 0x29
88 #define MPU_RA_I2C_SLV1_CTRL 0x2A
89 #define MPU_RA_I2C_SLV2_ADDR 0x2B
90 #define MPU_RA_I2C_SLV2_REG 0x2C
91 #define MPU_RA_I2C_SLV2_CTRL 0x2D
92 #define MPU_RA_I2C_SLV3_ADDR 0x2E
93 #define MPU_RA_I2C_SLV3_REG 0x2F
94 #define MPU_RA_I2C_SLV3_CTRL 0x30
95 #define MPU_RA_I2C_SLV4_ADDR 0x31
96 #define MPU_RA_I2C_SLV4_REG 0x32
97 #define MPU_RA_I2C_SLV4_DO 0x33
98 #define MPU_RA_I2C_SLV4_CTRL 0x34
99 #define MPU_RA_I2C_SLV4_DI 0x35
100 #define MPU_RA_I2C_MST_STATUS 0x36
101 #define MPU_RA_INT_PIN_CFG 0x37
102 #define MPU_RA_INT_ENABLE 0x38
103 #define MPU_RA_DMP_INT_STATUS 0x39
104 #define MPU_RA_INT_STATUS 0x3A
105 #define MPU_RA_ACCEL_XOUT_H 0x3B
106 #define MPU_RA_ACCEL_XOUT_L 0x3C
107 #define MPU_RA_ACCEL_YOUT_H 0x3D
108 #define MPU_RA_ACCEL_YOUT_L 0x3E
109 #define MPU_RA_ACCEL_ZOUT_H 0x3F
110 #define MPU_RA_ACCEL_ZOUT_L 0x40
111 #define MPU_RA_TEMP_OUT_H 0x41
112 #define MPU_RA_TEMP_OUT_L 0x42
113 #define MPU_RA_GYRO_XOUT_H 0x43
114 #define MPU_RA_GYRO_XOUT_L 0x44
115 #define MPU_RA_GYRO_YOUT_H 0x45
116 #define MPU_RA_GYRO_YOUT_L 0x46
117 #define MPU_RA_GYRO_ZOUT_H 0x47
118 #define MPU_RA_GYRO_ZOUT_L 0x48
119 #define MPU_RA_EXT_SENS_DATA_00 0x49
120 #define MPU_RA_MOT_DETECT_STATUS 0x61
121 #define MPU_RA_I2C_SLV0_DO 0x63
122 #define MPU_RA_I2C_SLV1_DO 0x64
123 #define MPU_RA_I2C_SLV2_DO 0x65
124 #define MPU_RA_I2C_SLV3_DO 0x66
125 #define MPU_RA_I2C_MST_DELAY_CTRL 0x67
126 #define MPU_RA_SIGNAL_PATH_RESET 0x68
127 #define MPU_RA_MOT_DETECT_CTRL 0x69
128 #define MPU_RA_USER_CTRL 0x6A
129 #define MPU_RA_PWR_MGMT_1 0x6B
130 #define MPU_RA_PWR_MGMT_2 0x6C
131 #define MPU_RA_BANK_SEL 0x6D
132 #define MPU_RA_MEM_START_ADDR 0x6E
133 #define MPU_RA_MEM_R_W 0x6F
134 #define MPU_RA_DMP_CFG_1 0x70
135 #define MPU_RA_DMP_CFG_2 0x71
136 #define MPU_RA_FIFO_COUNTH 0x72
137 #define MPU_RA_FIFO_COUNTL 0x73
138 #define MPU_RA_FIFO_R_W 0x74
139 #define MPU_RA_WHO_AM_I 0x75
141 // RF = Register Flag
142 #define MPU_RF_DATA_RDY_EN (1 << 0)
144 enum gyro_fsr_e {
145 INV_FSR_250DPS = 0,
146 INV_FSR_500DPS,
147 INV_FSR_1000DPS,
148 INV_FSR_2000DPS,
149 NUM_GYRO_FSR
152 enum icm_high_range_gyro_fsr_e {
153 ICM_HIGH_RANGE_FSR_500DPS = 0,
154 ICM_HIGH_RANGE_FSR_1000DPS,
155 ICM_HIGH_RANGE_FSR_2000DPS,
156 ICM_HIGH_RANGE_FSR_4000DPS,
157 NUM_ICM_HIGH_RANGE_GYRO_FSR
160 enum clock_sel_e {
161 INV_CLK_INTERNAL = 0,
162 INV_CLK_PLL,
163 NUM_CLK
166 enum accel_fsr_e {
167 INV_FSR_2G = 0,
168 INV_FSR_4G,
169 INV_FSR_8G,
170 INV_FSR_16G,
171 NUM_ACCEL_FSR
174 enum icm_high_range_accel_fsr_e {
175 ICM_HIGH_RANGE_FSR_4G = 0,
176 ICM_HIGH_RANGE_FSR_8G,
177 ICM_HIGH_RANGE_FSR_16G,
178 ICM_HIGH_RANGE_FSR_32G,
179 NUM_ICM_HIGH_RANGE_ACCEL_FSR
182 typedef enum {
183 GYRO_OVERFLOW_NONE = 0x00,
184 GYRO_OVERFLOW_X = 0x01,
185 GYRO_OVERFLOW_Y = 0x02,
186 GYRO_OVERFLOW_Z = 0x04
187 } gyroOverflow_e;
189 typedef enum {
190 MPU_NONE,
191 MPU_3050,
192 MPU_60x0,
193 MPU_60x0_SPI,
194 MPU_65xx_I2C,
195 MPU_65xx_SPI,
196 MPU_9250_SPI,
197 ICM_20601_SPI,
198 ICM_20602_SPI,
199 ICM_20608_SPI,
200 ICM_20649_SPI,
201 ICM_20689_SPI,
202 ICM_42605_SPI,
203 ICM_42688P_SPI,
204 BMI_160_SPI,
205 BMI_270_SPI,
206 LSM6DSO_SPI,
207 L3GD20_SPI,
208 LSM6DSV16X_SPI
209 } mpuSensor_e;
211 typedef enum {
212 MPU_HALF_RESOLUTION,
213 MPU_FULL_RESOLUTION
214 } mpu6050Resolution_e;
216 typedef struct mpuDetectionResult_s {
217 mpuSensor_e sensor;
218 mpu6050Resolution_e resolution;
219 } mpuDetectionResult_t;
221 struct gyroDev_s;
222 struct gyroDeviceConfig_s;
223 void mpuGyroInit(struct gyroDev_s *gyro);
224 bool mpuGyroRead(struct gyroDev_s *gyro);
225 bool mpuGyroReadSPI(struct gyroDev_s *gyro);
226 void mpuPreInit(const struct gyroDeviceConfig_s *config);
227 bool mpuDetect(struct gyroDev_s *gyro, const struct gyroDeviceConfig_s *config);
228 uint8_t mpuGyroDLPF(struct gyroDev_s *gyro);
229 uint8_t mpuGyroReadRegister(const extDevice_t *dev, uint8_t reg);
231 struct accDev_s;
232 bool mpuAccRead(struct accDev_s *acc);
233 bool mpuAccReadSPI(struct accDev_s *acc);
235 busStatus_e mpuIntCallback(uint32_t arg);
236 void mpuIntExtiHandler(extiCallbackRec_t *cb);