mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-15 17:12:45 +01:00
104 lines
3.2 KiB
C
104 lines
3.2 KiB
C
/*
|
|
* Copyright (C) 2015 Freie Universität Berlin
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
* directory for more details.
|
|
*/
|
|
|
|
/**
|
|
* @ingroup drivers_mpu9150
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Register and bit definitions for the MPU-9150 9-Axis Motion Sensor
|
|
*
|
|
* @author Fabian Nack <nack@inf.fu-berlin.de>
|
|
*/
|
|
|
|
#ifndef MPU9150_REGS_H_
|
|
#define MPU9150_REGS_H_
|
|
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @name MPU-9150 register definitions
|
|
* @{
|
|
*/
|
|
#define MPU9150_YG_OFFS_TC_REG (0x01)
|
|
#define MPU9150_RATE_DIV_REG (0x19)
|
|
#define MPU9150_LPF_REG (0x1A)
|
|
#define MPU9150_GYRO_CFG_REG (0x1B)
|
|
#define MPU9150_ACCEL_CFG_REG (0x1C)
|
|
#define MPU9150_FIFO_EN_REG (0x23)
|
|
#define MPU9150_I2C_MST_REG (0x24)
|
|
#define MPU9150_SLAVE0_ADDR_REG (0x25)
|
|
#define MPU9150_SLAVE0_REG_REG (0x26)
|
|
#define MPU9150_SLAVE0_CTRL_REG (0x27)
|
|
#define MPU9150_SLAVE1_ADDR_REG (0x28)
|
|
#define MPU9150_SLAVE1_REG_REG (0x29)
|
|
#define MPU9150_SLAVE1_CTRL_REG (0x2A)
|
|
#define MPU9150_SLAVE4_CTRL_REG (0x34)
|
|
#define MPU9150_INT_PIN_CFG_REG (0x37)
|
|
#define MPU9150_INT_ENABLE_REG (0x38)
|
|
#define MPU9150_DMP_INT_STATUS (0x39)
|
|
#define MPU9150_INT_STATUS (0x3A)
|
|
#define MPU9150_ACCEL_START_REG (0x3B)
|
|
#define MPU9150_TEMP_START_REG (0x41)
|
|
#define MPU9150_GYRO_START_REG (0x43)
|
|
#define MPU9150_EXT_SENS_DATA_START_REG (0x49)
|
|
#define MPU9150_COMPASS_DATA_START_REG (0x4A)
|
|
#define MPU9150_SLAVE0_DATA_OUT_REG (0x63)
|
|
#define MPU9150_SLAVE1_DATA_OUT_REG (0x64)
|
|
#define MPU9150_SLAVE2_DATA_OUT_REG (0x65)
|
|
#define MPU9150_SLAVE3_DATA_OUT_REG (0x66)
|
|
#define MPU9150_I2C_DELAY_CTRL_REG (0x67)
|
|
#define MPU9150_USER_CTRL_REG (0x6A)
|
|
#define MPU9150_PWR_MGMT_1_REG (0x6B)
|
|
#define MPU9150_PWR_MGMT_2_REG (0x6C)
|
|
#define MPU9150_FIFO_COUNT_START_REG (0x72)
|
|
#define MPU9150_FIFO_RW_REG (0x74)
|
|
#define MPU9150_WHO_AM_I_REG (0x75)
|
|
/** @} */
|
|
|
|
/**
|
|
* @name Compass register definitions
|
|
* @{
|
|
*/
|
|
#define COMPASS_WHOAMI_REG (0x00)
|
|
#define COMPASS_ST1_REG (0x02)
|
|
#define COMPASS_DATA_START_REG (0x03)
|
|
#define COMPASS_ST2_REG (0x09)
|
|
#define COMPASS_CNTL_REG (0x0A)
|
|
#define COMPASS_ASTC_REG (0x0C)
|
|
#define COMPASS_ASAX_REG (0x10)
|
|
#define COMPASS_ASAY_REG (0x11)
|
|
#define COMPASS_ASAZ_REG (0x12)
|
|
/** @} */
|
|
|
|
/**
|
|
* @name MPU9150 bitfield definitions
|
|
* @{
|
|
*/
|
|
#define BIT_SLV0_DELAY_EN (0x01)
|
|
#define BIT_SLV1_DELAY_EN (0x02)
|
|
#define BIT_I2C_BYPASS_EN (0x02)
|
|
#define BIT_I2C_MST_EN (0x20)
|
|
#define BIT_PWR_MGMT1_SLEEP (0x40)
|
|
#define BIT_WAIT_FOR_ES (0x40)
|
|
#define BIT_I2C_MST_VDDIO (0x80)
|
|
#define BIT_SLAVE_RW (0x80)
|
|
#define BIT_SLAVE_EN (0x80)
|
|
#define BIT_DMP_EN (0x80)
|
|
/** @} */
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* MPU9150_REGS_H_ */
|
|
/** @} */
|