ICM428688硬件spi通讯异常

This commit is contained in:
2024-03-08 16:50:42 +08:00
parent fa1cc826f1
commit 6e701f3ae8
3 changed files with 817 additions and 822 deletions

View File

@ -11,8 +11,8 @@ void mymain()
led_init();
adc_init();
tle5012b_init();
// Init_ICM42688();
// imu_rest();
Init_ICM42688();
imu_rest();
moto_Init();
PID_Iint();
setvbuf(stdout, NULL, _IONBF, 0); //<2F><><EFBFBD><EFBFBD>printfû<66><C3BB>\n<><6E><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
@ -51,7 +51,6 @@ void mymain()
// printf("%d\n",i);
// }
// i++;
//
// Data_send(x,y);
// HAL_Delay(3);
}

File diff suppressed because it is too large Load Diff

View File

@ -1,212 +1,10 @@
//#ifndef _DMX_ICM42688_H_
//#define _DMX_ICM42688_H_
//#include "stm32h7xx_hal.h"
//#include "mymain.h"
//#define ICM42688_DELAY_MS(time) (HAL_Delay(time))
//
//
//enum icm42688_afs
//{
// ICM42688_AFS_16G,// default
// ICM42688_AFS_8G,
// ICM42688_AFS_4G,
// ICM42688_AFS_2G,
// NUM_ICM42688__AFS
//};
//
//enum icm42688_aodr
//{
// ICM42688_AODR_32000HZ,
// ICM42688_AODR_16000HZ,
// ICM42688_AODR_8000HZ,
// ICM42688_AODR_4000HZ,
// ICM42688_AODR_2000HZ,
// ICM42688_AODR_1000HZ,// default
// ICM42688_AODR_200HZ,
// ICM42688_AODR_100HZ,
// ICM42688_AODR_50HZ,
// ICM42688_AODR_25HZ,
// ICM42688_AODR_12_5HZ,
// ICM42688_AODR_6_25HZ,
// ICM42688_AODR_3_125HZ,
// ICM42688_AODR_1_5625HZ,
// ICM42688_AODR_500HZ,
// NUM_ICM42688_AODR
//};
//
//enum icm42688_gfs
//{
// ICM42688_GFS_2000DPS,// default
// ICM42688_GFS_1000DPS,
// ICM42688_GFS_500DPS,
// ICM42688_GFS_250DPS,
// ICM42688_GFS_125DPS,
// ICM42688_GFS_62_5DPS,
// ICM42688_GFS_31_25DPS,
// ICM42688_GFS_15_625DPS,
// NUM_ICM42688_GFS
//};
//enum icm42688_godr
//{
// ICM42688_GODR_32000HZ,
// ICM42688_GODR_16000HZ,
// ICM42688_GODR_8000HZ,
// ICM42688_GODR_4000HZ,
// ICM42688_GODR_2000HZ,
// ICM42688_GODR_1000HZ,// default
// ICM42688_GODR_200HZ,
// ICM42688_GODR_100HZ,
// ICM42688_GODR_50HZ,
// ICM42688_GODR_25HZ,
// ICM42688_GODR_12_5HZ,
// ICM42688_GODR_X0HZ,
// ICM42688_GODR_X1HZ,
// ICM42688_GODR_X2HZ,
// ICM42688_GODR_500HZ,
// NUM_ICM42688_GODR
//};
//
//
//// ICM42688Bank0<6B>ڲ<EFBFBD><DAB2><EFBFBD>ַ
//#define ICM42688_DEVICE_CONFIG 0x11
//#define ICM42688_DRIVE_CONFIG 0x13
//#define ICM42688_INT_CONFIG 0x14
//#define ICM42688_FIFO_CONFIG 0x16
//#define ICM42688_TEMP_DATA1 0x1D
//#define ICM42688_TEMP_DATA0 0x1E
//#define ICM42688_ACCEL_DATA_X1 0x1F
//#define ICM42688_ACCEL_DATA_X0 0x20
//#define ICM42688_ACCEL_DATA_Y1 0x21
//#define ICM42688_ACCEL_DATA_Y0 0x22
//#define ICM42688_ACCEL_DATA_Z1 0x23
//#define ICM42688_ACCEL_DATA_Z0 0x24
//#define ICM42688_GYRO_DATA_X1 0x25
//#define ICM42688_GYRO_DATA_X0 0x26
//#define ICM42688_GYRO_DATA_Y1 0x27
//#define ICM42688_GYRO_DATA_Y0 0x28
//#define ICM42688_GYRO_DATA_Z1 0x29
//#define ICM42688_GYRO_DATA_Z0 0x2A
//#define ICM42688_TMST_FSYNCH 0x2B
//#define ICM42688_TMST_FSYNCL 0x2C
//#define ICM42688_INT_STATUS 0x2D
//#define ICM42688_FIFO_COUNTH 0x2E
//#define ICM42688_FIFO_COUNTL 0x2F
//#define ICM42688_FIFO_DATA 0x30
//#define ICM42688_APEX_DATA0 0x31
//#define ICM42688_APEX_DATA1 0x32
//#define ICM42688_APEX_DATA2 0x33
//#define ICM42688_APEX_DATA3 0x34
//#define ICM42688_APEX_DATA4 0x35
//#define ICM42688_APEX_DATA5 0x36
//#define ICM42688_INT_STATUS2 0x37
//#define ICM42688_INT_STATUS3 0x38
//#define ICM42688_SIGNAL_PATH_RESET 0x4B
//#define ICM42688_INTF_CONFIG0 0x4C
//#define ICM42688_INTF_CONFIG1 0x4D
//#define ICM42688_PWR_MGMT0 0x4E
//#define ICM42688_GYRO_CONFIG0 0x4F
//#define ICM42688_ACCEL_CONFIG0 0x50
//#define ICM42688_GYRO_CONFIG1 0x51
//#define ICM42688_GYRO_ACCEL_CONFIG0 0x52
//#define ICM42688_ACCEL_CONFIG1 0x53
//#define ICM42688_TMST_CONFIG 0x54
//#define ICM42688_APEX_CONFIG0 0x56
//#define ICM42688_SMD_CONFIG 0x57
//#define ICM42688_FIFO_CONFIG1 0x5F
//#define ICM42688_FIFO_CONFIG2 0x60
//#define ICM42688_FIFO_CONFIG3 0x61
//#define ICM42688_FSYNC_CONFIG 0x62
//#define ICM42688_INT_CONFIG0 0x63
//#define ICM42688_INT_CONFIG1 0x64
//#define ICM42688_INT_SOURCE0 0x65
//#define ICM42688_INT_SOURCE1 0x66
//#define ICM42688_INT_SOURCE3 0x68
//#define ICM42688_INT_SOURCE4 0x69
//#define ICM42688_FIFO_LOST_PKT0 0x6C
//#define ICM42688_FIFO_LOST_PKT1 0x6D
//#define ICM42688_SELF_TEST_CONFIG 0x70
//#define ICM42688_WHO_AM_I 0x75
//#define ICM42688_REG_BANK_SEL 0x76 // Banks
//#define ICM42688_SENSOR_CONFIG0 0x03
//#define ICM42688_GYRO_CONFIG_STATIC2 0x0B
//#define ICM42688_GYRO_CONFIG_STATIC3 0x0C
//#define ICM42688_GYRO_CONFIG_STATIC4 0x0D
//#define ICM42688_GYRO_CONFIG_STATIC5 0x0E
//#define ICM42688_GYRO_CONFIG_STATIC6 0x0F
//#define ICM42688_GYRO_CONFIG_STATIC7 0x10
//#define ICM42688_GYRO_CONFIG_STATIC8 0x11
//#define ICM42688_GYRO_CONFIG_STATIC9 0x12
//#define ICM42688_GYRO_CONFIG_STATIC10 0x13
//#define ICM42688_XG_ST_DATA 0x5F
//#define ICM42688_YG_ST_DATA 0x60
//#define ICM42688_ZG_ST_DATA 0x61
//#define ICM42688_TMSTVAL0 0x62
//#define ICM42688_TMSTVAL1 0x63
//#define ICM42688_TMSTVAL2 0x64
//#define ICM42688_INTF_CONFIG4 0x7A
//#define ICM42688_INTF_CONFIG5 0x7B
//#define ICM42688_INTF_CONFIG6 0x7C
//
//
//static void Read_Datas_ICM42688(unsigned char reg, unsigned char *dat, unsigned int num);
//static void Write_Data_ICM42688(unsigned char reg, unsigned char dat);
//void Init_ICM42688(void);
////void sys_gpio_pin_set(GPIO_TypeDef *p_gpiox, uint16_t pinx, uint8_t status);
//void Set_LowpassFilter_Range_ICM42688(enum icm42688_afs afs, enum icm42688_aodr aodr, enum icm42688_gfs gfs, enum icm42688_godr godr);
//uint8_t MpuGetData(void);
//
//
//#endif
//
#ifndef _DMX_ICM42688_H_
#define _DMX_ICM42688_H_
#include "stm32h7xx_hal.h"
#include "mymain.h"
#define ICM42688_DELAY_MS(time) (HAL_Delay(time))
extern float icm42688_acc_x, icm42688_acc_y, icm42688_acc_z ; // <20><><EFBFBD><EFBFBD>ICM42688<38><38><EFBFBD>ٶȼ<D9B6><C8BC><EFBFBD><EFBFBD><EFBFBD>
extern float icm42688_gyro_x, icm42688_gyro_y, icm42688_gyro_z ; // <20><><EFBFBD><EFBFBD>ICM42688<38>Ǽ<EFBFBD><C7BC>ٶ<EFBFBD><D9B6><EFBFBD><EFBFBD><EFBFBD>
static void Read_Datas_ICM42688(unsigned char reg, unsigned char *dat, unsigned int num);
static void Write_Data_ICM42688(unsigned char reg, unsigned char dat);
enum icm42688_afs
{
ICM42688_AFS_16G,// default
@ -268,58 +66,7 @@ enum icm42688_godr
NUM_ICM42688_GODR
};
void gpio_init(void);
/**
*
* @brief ICM42688<38><38><EFBFBD><EFBFBD><EFBFBD>dz<EFBFBD>ʼ<EFBFBD><CABC>
* @param
* @return void
* @notes <20>û<EFBFBD><C3BB><EFBFBD><EFBFBD><EFBFBD>
* Example: Init_ICM42688();
*
**/
void Init_ICM42688(void);
//void get_IMU(float accx,float accy,float accz,float *pitch,float *roll);
void get_IMU(float *pitch,float *roll);
uint8_t sys_gpio_pin_get(GPIO_TypeDef *p_gpiox, uint16_t pinx);
void sys_gpio_pin_set(GPIO_TypeDef *p_gpiox, uint16_t pinx, uint8_t status);
/**
*
* @brief <20><><EFBFBD>ICM42688<38><38><EFBFBD><EFBFBD><EFBFBD>Ǽ<EFBFBD><C7BC>ٶ<EFBFBD>
* @param
* @return void
* @notes <20><>λ:g(m/s^2),<2C>û<EFBFBD><C3BB><EFBFBD><EFBFBD><EFBFBD>
* Example: Get_Acc_ICM42688();
*
**/
void Get_Acc_ICM42688(void);
/**
*
* @brief <20><><EFBFBD>ICM42688<38><38><EFBFBD><EFBFBD><EFBFBD>ǽǼ<C7BD><C7BC>ٶ<EFBFBD>
* @param
* @return void
* @notes <20><>λΪ:<3A><>/s,<2C>û<EFBFBD><C3BB><EFBFBD><EFBFBD><EFBFBD>
* Example: Get_Gyro_ICM42688();
*
**/
void Get_Gyro_ICM42688(void);
/**
*
* @brief <20><><EFBFBD><EFBFBD>ICM42688<38><38><EFBFBD><EFBFBD><EFBFBD>ǵ<EFBFBD>ͨ<EFBFBD>˲<EFBFBD><CBB2><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
* @param afs // <20><><EFBFBD>ٶȼ<D9B6><C8BC><EFBFBD><EFBFBD><EFBFBD>,<2C><><EFBFBD><EFBFBD>dmx_icm42688.h<>ļ<EFBFBD><C4BC><EFBFBD>ö<EFBFBD>ٶ<EFBFBD><D9B6><EFBFBD><EFBFBD>в鿴
* @param aodr // <20><><EFBFBD>ٶȼ<D9B6><C8BC><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>,<2C><><EFBFBD><EFBFBD>dmx_icm42688.h<>ļ<EFBFBD><C4BC><EFBFBD>ö<EFBFBD>ٶ<EFBFBD><D9B6><EFBFBD><EFBFBD>в鿴
* @param gfs // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>,<2C><><EFBFBD><EFBFBD>dmx_icm42688.h<>ļ<EFBFBD><C4BC><EFBFBD>ö<EFBFBD>ٶ<EFBFBD><D9B6><EFBFBD><EFBFBD>в鿴
* @param godr // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>,<2C><><EFBFBD><EFBFBD>dmx_icm42688.h<>ļ<EFBFBD><C4BC><EFBFBD>ö<EFBFBD>ٶ<EFBFBD><D9B6><EFBFBD><EFBFBD>в鿴
* @return void
* @notes ICM42688.c<>ļ<EFBFBD><C4BC>ڲ<EFBFBD><DAB2><EFBFBD><EFBFBD><EFBFBD>,<2C>û<EFBFBD><C3BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ó<EFBFBD><C3B3><EFBFBD>
* Example: Set_LowpassFilter_Range_ICM42688(ICM42688_AFS_16G,ICM42688_AODR_32000HZ,ICM42688_GFS_2000DPS,ICM42688_GODR_32000HZ);
*
**/
void Set_LowpassFilter_Range_ICM42688(enum icm42688_afs afs, enum icm42688_aodr aodr, enum icm42688_gfs gfs, enum icm42688_godr godr);
uint8_t MpuGetData(void);
// ICM42688Bank0<6B>ڲ<EFBFBD><DAB2><EFBFBD>ַ
#define ICM42688_DEVICE_CONFIG 0x11
#define ICM42688_DRIVE_CONFIG 0x13
@ -400,5 +147,258 @@ uint8_t MpuGetData(void);
#define ICM42688_INTF_CONFIG5 0x7B
#define ICM42688_INTF_CONFIG6 0x7C
static void Read_Datas_ICM42688(unsigned char reg, unsigned char *dat, unsigned int num);
static void Write_Data_ICM42688(unsigned char reg, unsigned char dat);
void Init_ICM42688(void);
//void sys_gpio_pin_set(GPIO_TypeDef *p_gpiox, uint16_t pinx, uint8_t status);
void Set_LowpassFilter_Range_ICM42688(enum icm42688_afs afs, enum icm42688_aodr aodr, enum icm42688_gfs gfs, enum icm42688_godr godr);
uint8_t MpuGetData(void);
#endif
//
//#ifndef _DMX_ICM42688_H_
//#define _DMX_ICM42688_H_
//#include "stm32h7xx_hal.h"
//#include "mymain.h"
//#define ICM42688_DELAY_MS(time) (HAL_Delay(time))
//
//extern float icm42688_acc_x, icm42688_acc_y, icm42688_acc_z ; // <20><><EFBFBD><EFBFBD>ICM42688<38><38><EFBFBD>ٶȼ<D9B6><C8BC><EFBFBD><EFBFBD><EFBFBD>
//extern float icm42688_gyro_x, icm42688_gyro_y, icm42688_gyro_z ; // <20><><EFBFBD><EFBFBD>ICM42688<38>Ǽ<EFBFBD><C7BC>ٶ<EFBFBD><D9B6><EFBFBD><EFBFBD><EFBFBD>
//static void Read_Datas_ICM42688(unsigned char reg, unsigned char *dat, unsigned int num);
//static void Write_Data_ICM42688(unsigned char reg, unsigned char dat);
//enum icm42688_afs
//{
// ICM42688_AFS_16G,// default
// ICM42688_AFS_8G,
// ICM42688_AFS_4G,
// ICM42688_AFS_2G,
// NUM_ICM42688__AFS
//};
//
//enum icm42688_aodr
//{
// ICM42688_AODR_32000HZ,
// ICM42688_AODR_16000HZ,
// ICM42688_AODR_8000HZ,
// ICM42688_AODR_4000HZ,
// ICM42688_AODR_2000HZ,
// ICM42688_AODR_1000HZ,// default
// ICM42688_AODR_200HZ,
// ICM42688_AODR_100HZ,
// ICM42688_AODR_50HZ,
// ICM42688_AODR_25HZ,
// ICM42688_AODR_12_5HZ,
// ICM42688_AODR_6_25HZ,
// ICM42688_AODR_3_125HZ,
// ICM42688_AODR_1_5625HZ,
// ICM42688_AODR_500HZ,
// NUM_ICM42688_AODR
//};
//
//enum icm42688_gfs
//{
// ICM42688_GFS_2000DPS,// default
// ICM42688_GFS_1000DPS,
// ICM42688_GFS_500DPS,
// ICM42688_GFS_250DPS,
// ICM42688_GFS_125DPS,
// ICM42688_GFS_62_5DPS,
// ICM42688_GFS_31_25DPS,
// ICM42688_GFS_15_625DPS,
// NUM_ICM42688_GFS
//};
//enum icm42688_godr
//{
// ICM42688_GODR_32000HZ,
// ICM42688_GODR_16000HZ,
// ICM42688_GODR_8000HZ,
// ICM42688_GODR_4000HZ,
// ICM42688_GODR_2000HZ,
// ICM42688_GODR_1000HZ,// default
// ICM42688_GODR_200HZ,
// ICM42688_GODR_100HZ,
// ICM42688_GODR_50HZ,
// ICM42688_GODR_25HZ,
// ICM42688_GODR_12_5HZ,
// ICM42688_GODR_X0HZ,
// ICM42688_GODR_X1HZ,
// ICM42688_GODR_X2HZ,
// ICM42688_GODR_500HZ,
// NUM_ICM42688_GODR
//};
//
//void gpio_init(void);
//
///**
//*
//* @brief ICM42688<38><38><EFBFBD><EFBFBD><EFBFBD>dz<EFBFBD>ʼ<EFBFBD><CABC>
//* @param
//* @return void
//* @notes <20>û<EFBFBD><C3BB><EFBFBD><EFBFBD><EFBFBD>
//* Example: Init_ICM42688();
//*
//**/
//void Init_ICM42688(void);
////void get_IMU(float accx,float accy,float accz,float *pitch,float *roll);
//void get_IMU(float *pitch,float *roll);
//uint8_t sys_gpio_pin_get(GPIO_TypeDef *p_gpiox, uint16_t pinx);
//void sys_gpio_pin_set(GPIO_TypeDef *p_gpiox, uint16_t pinx, uint8_t status);
///**
//*
//* @brief <20><><EFBFBD>ICM42688<38><38><EFBFBD><EFBFBD><EFBFBD>Ǽ<EFBFBD><C7BC>ٶ<EFBFBD>
//* @param
//* @return void
//* @notes <20><>λ:g(m/s^2),<2C>û<EFBFBD><C3BB><EFBFBD><EFBFBD><EFBFBD>
//* Example: Get_Acc_ICM42688();
//*
//**/
//void Get_Acc_ICM42688(void);
//
///**
//*
//* @brief <20><><EFBFBD>ICM42688<38><38><EFBFBD><EFBFBD><EFBFBD>ǽǼ<C7BD><C7BC>ٶ<EFBFBD>
//* @param
//* @return void
//* @notes <20><>λΪ:<3A><>/s,<2C>û<EFBFBD><C3BB><EFBFBD><EFBFBD><EFBFBD>
//* Example: Get_Gyro_ICM42688();
//*
//**/
//void Get_Gyro_ICM42688(void);
//
///**
//*
//* @brief <20><><EFBFBD><EFBFBD>ICM42688<38><38><EFBFBD><EFBFBD><EFBFBD>ǵ<EFBFBD>ͨ<EFBFBD>˲<EFBFBD><CBB2><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
//* @param afs // <20><><EFBFBD>ٶȼ<D9B6><C8BC><EFBFBD><EFBFBD><EFBFBD>,<2C><><EFBFBD><EFBFBD>dmx_icm42688.h<>ļ<EFBFBD><C4BC><EFBFBD>ö<EFBFBD>ٶ<EFBFBD><D9B6><EFBFBD><EFBFBD>в鿴
//* @param aodr // <20><><EFBFBD>ٶȼ<D9B6><C8BC><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>,<2C><><EFBFBD><EFBFBD>dmx_icm42688.h<>ļ<EFBFBD><C4BC><EFBFBD>ö<EFBFBD>ٶ<EFBFBD><D9B6><EFBFBD><EFBFBD>в鿴
//* @param gfs // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>,<2C><><EFBFBD><EFBFBD>dmx_icm42688.h<>ļ<EFBFBD><C4BC><EFBFBD>ö<EFBFBD>ٶ<EFBFBD><D9B6><EFBFBD><EFBFBD>в鿴
//* @param godr // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>,<2C><><EFBFBD><EFBFBD>dmx_icm42688.h<>ļ<EFBFBD><C4BC><EFBFBD>ö<EFBFBD>ٶ<EFBFBD><D9B6><EFBFBD><EFBFBD>в鿴
//* @return void
//* @notes ICM42688.c<>ļ<EFBFBD><C4BC>ڲ<EFBFBD><DAB2><EFBFBD><EFBFBD><EFBFBD>,<2C>û<EFBFBD><C3BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ó<EFBFBD><C3B3><EFBFBD>
//* Example: Set_LowpassFilter_Range_ICM42688(ICM42688_AFS_16G,ICM42688_AODR_32000HZ,ICM42688_GFS_2000DPS,ICM42688_GODR_32000HZ);
//*
//**/
//void Set_LowpassFilter_Range_ICM42688(enum icm42688_afs afs, enum icm42688_aodr aodr, enum icm42688_gfs gfs, enum icm42688_godr godr);
//uint8_t MpuGetData(void);
//// ICM42688Bank0<6B>ڲ<EFBFBD><DAB2><EFBFBD>ַ
//#define ICM42688_DEVICE_CONFIG 0x11
//#define ICM42688_DRIVE_CONFIG 0x13
//#define ICM42688_INT_CONFIG 0x14
//#define ICM42688_FIFO_CONFIG 0x16
//#define ICM42688_TEMP_DATA1 0x1D
//#define ICM42688_TEMP_DATA0 0x1E
//#define ICM42688_ACCEL_DATA_X1 0x1F
//#define ICM42688_ACCEL_DATA_X0 0x20
//#define ICM42688_ACCEL_DATA_Y1 0x21
//#define ICM42688_ACCEL_DATA_Y0 0x22
//#define ICM42688_ACCEL_DATA_Z1 0x23
//#define ICM42688_ACCEL_DATA_Z0 0x24
//#define ICM42688_GYRO_DATA_X1 0x25
//#define ICM42688_GYRO_DATA_X0 0x26
//#define ICM42688_GYRO_DATA_Y1 0x27
//#define ICM42688_GYRO_DATA_Y0 0x28
//#define ICM42688_GYRO_DATA_Z1 0x29
//#define ICM42688_GYRO_DATA_Z0 0x2A
//#define ICM42688_TMST_FSYNCH 0x2B
//#define ICM42688_TMST_FSYNCL 0x2C
//#define ICM42688_INT_STATUS 0x2D
//#define ICM42688_FIFO_COUNTH 0x2E
//#define ICM42688_FIFO_COUNTL 0x2F
//#define ICM42688_FIFO_DATA 0x30
//#define ICM42688_APEX_DATA0 0x31
//#define ICM42688_APEX_DATA1 0x32
//#define ICM42688_APEX_DATA2 0x33
//#define ICM42688_APEX_DATA3 0x34
//#define ICM42688_APEX_DATA4 0x35
//#define ICM42688_APEX_DATA5 0x36
//#define ICM42688_INT_STATUS2 0x37
//#define ICM42688_INT_STATUS3 0x38
//#define ICM42688_SIGNAL_PATH_RESET 0x4B
//#define ICM42688_INTF_CONFIG0 0x4C
//#define ICM42688_INTF_CONFIG1 0x4D
//#define ICM42688_PWR_MGMT0 0x4E
//#define ICM42688_GYRO_CONFIG0 0x4F
//#define ICM42688_ACCEL_CONFIG0 0x50
//#define ICM42688_GYRO_CONFIG1 0x51
//#define ICM42688_GYRO_ACCEL_CONFIG0 0x52
//#define ICM42688_ACCEL_CONFIG1 0x53
//#define ICM42688_TMST_CONFIG 0x54
//#define ICM42688_APEX_CONFIG0 0x56
//#define ICM42688_SMD_CONFIG 0x57
//#define ICM42688_FIFO_CONFIG1 0x5F
//#define ICM42688_FIFO_CONFIG2 0x60
//#define ICM42688_FIFO_CONFIG3 0x61
//#define ICM42688_FSYNC_CONFIG 0x62
//#define ICM42688_INT_CONFIG0 0x63
//#define ICM42688_INT_CONFIG1 0x64
//#define ICM42688_INT_SOURCE0 0x65
//#define ICM42688_INT_SOURCE1 0x66
//#define ICM42688_INT_SOURCE3 0x68
//#define ICM42688_INT_SOURCE4 0x69
//#define ICM42688_FIFO_LOST_PKT0 0x6C
//#define ICM42688_FIFO_LOST_PKT1 0x6D
//#define ICM42688_SELF_TEST_CONFIG 0x70
//#define ICM42688_WHO_AM_I 0x75
//#define ICM42688_REG_BANK_SEL 0x76 // Banks
//#define ICM42688_SENSOR_CONFIG0 0x03
//#define ICM42688_GYRO_CONFIG_STATIC2 0x0B
//#define ICM42688_GYRO_CONFIG_STATIC3 0x0C
//#define ICM42688_GYRO_CONFIG_STATIC4 0x0D
//#define ICM42688_GYRO_CONFIG_STATIC5 0x0E
//#define ICM42688_GYRO_CONFIG_STATIC6 0x0F
//#define ICM42688_GYRO_CONFIG_STATIC7 0x10
//#define ICM42688_GYRO_CONFIG_STATIC8 0x11
//#define ICM42688_GYRO_CONFIG_STATIC9 0x12
//#define ICM42688_GYRO_CONFIG_STATIC10 0x13
//#define ICM42688_XG_ST_DATA 0x5F
//#define ICM42688_YG_ST_DATA 0x60
//#define ICM42688_ZG_ST_DATA 0x61
//#define ICM42688_TMSTVAL0 0x62
//#define ICM42688_TMSTVAL1 0x63
//#define ICM42688_TMSTVAL2 0x64
//#define ICM42688_INTF_CONFIG4 0x7A
//#define ICM42688_INTF_CONFIG5 0x7B
//#define ICM42688_INTF_CONFIG6 0x7C
//
//#endif
//