

# **BMI270**

# 6-axis, smart, low power Inertial Measurement Unit for high-performance applications



## **BMI270 Datasheet**

Document revision 1.5

Document release date March 2023

Document number BST-BMI270-DS000-07

Sales Part Number 0 273 017 008

Notes Data and descriptions in this document are subject to change without notice. Product

photos and pictures are for illustration purposes only and may differ from the real

product appearance.

# **Basic Description**

The device is a highly integrated, low power inertial measurement unit (IMU) that combines precise acceleration and angular rate (gyroscopic) measurement with intelligent on-chip motion-triggered interrupt features.

#### The device integrates

- ▶ 16 bit digital, triaxial accelerometer with ±2g/±4g/±8g/±16g range
- ▶ 16 bit digital, triaxial gyroscope with ±125dps/±250dps/±500dps/±1000dps/±2000dps range in a compact standard size LGA mold package, 14 pins, footprint 2.5x3.0mm², height 0.83mm

#### Key features

- ▶ Output data rates (ODR): 25 Hz ... 6.4 kHz (gyroscope) and 0.78 Hz ... 1.6 kHz (accelerometer)
- ▶ Programmable low-pass filter (accelerometer | gyroscope): bandwidth 5.5 | 11 ... 740 | 751 Hz
- ▶ Wide power supply range: Analog VDD 1.71V ... 3.6V and independent VDDIO 1.2V...3.6V
- ► Low current consumption: typ. 685 µA (in full ODR and aliasing free operation)
- ▶ Performance mode for gyroscope to minimize noise level: typ. < 7 mdps  $/\sqrt{\text{Hz}}$ .
- ▶ Built-in power management unit (PMU) for advanced power management and low power modes
- ▶ Rapid startup time: 2 ms for gyroscope (in fast start mode) and 2 ms for accelerometer
- ▶ Freely configurable secondary digital interface
  - ▶ I<sup>2</sup>C (Fm+) master interface hub for 1 I2C AUX sensor (e.g. ext. magnetometer, pressure)
    - o data synchronized to IMU
  - ▶ 10 MHz slave SPI (4-wire, 3-wire) for high speed, calibration free OIS / Dual OIS (SPI) applications
    - Up to 6.4 kHz ODR, control register access and down to 680 μs group delay
    - Connectible latency optimized low pass-filters with programmable cut-off frequencies
- ▶ 2 KB on-chip FIFO buffer for accelerometer, gyroscope, timestamps, and AUX sensor data
- ▶ Fast offset error compensation for accelerometer and gyroscope
- ► Fast sensitivity error compensation for gyroscope (CRT, reducing the error down to typ. 0.4 %)
- ► HW synchronization of accelerometer, gyroscope, and AUX sensor (< 1 µs)
- ▶ Sensortime stamps for accurate system (host) and sensor (IMU) time synchronization (<40 µs)
- ▶ 2 independent programmable I/O pins for interrupt and synchronization events
- ▶ RoHS compliant, halogen and lead free
- ► BMI270 Features:

Significant motion/Any motion/Motion detect/No motion/Stationary detect/Wrist wear wakeup/Wrist worn step counter and detector/Activity change recognition/Push arm down/Pivot up/Wrist jiggle/Flick in /out

# **Typical Applications**

- ► Wearables
- ► Hearables
- ► Smart clothing
- ► Augmented / virtual reality (AR/VR)
- ► Activity & Context Recognition

# **Target Devices**

- ► Fitness trackers, wristbands, smart watches
- ► Earbuds, ankle bands, neck bands
- ► Smart clothes
- ► Augmented and virtual reality glasses and controllers

# **Table of Contents**

| 1 | Specificati | on                                                           | 11 |
|---|-------------|--------------------------------------------------------------|----|
| 2 | Absolute r  | naximum ratings                                              | 16 |
| 3 | Quick Star  | t Guide                                                      | 17 |
| 4 | Functional  | Description and Features                                     | 23 |
|   | 4.1 Syste   | em Configurations                                            | 23 |
|   | 4.2 Block   | < Diagram                                                    | 24 |
|   |             | ly Voltage and Power Management                              |    |
|   |             | er-On-Reset (POR) and Device Initialization                  |    |
|   | 4.5 Powe    | er Modes                                                     | 26 |
|   |             | or Data                                                      |    |
|   | 4.6 Sens    | Accelerometer Data                                           |    |
|   | 4.6.2       | Accelerometer Filter Settings                                |    |
|   | 4.6.3       | Accelerometer Filter Modes                                   |    |
|   | 4.6.4       | Accelerometer Data Processing in Normal and Performance Mode |    |
|   | 4.6.5       | Accelerometer Data Processing in Low Power Mode              |    |
|   | 4.6.6       | Accelerometer Data Ready Interrupt                           |    |
|   | 4.6.7       | Gyroscope Data                                               |    |
|   | 4.6.8       | Gyroscope Filter Settings                                    |    |
|   | 4.6.9       | Gyroscope Filter Modes                                       |    |
|   | 4.6.10      | •                                                            |    |
|   | 4.6.11      | Gyroscope Data Processing in Normal and Performance Mode     |    |
|   | 4.6.12      | -                                                            |    |
|   | 4.6.13      |                                                              |    |
|   | 4.6.14      | Temperature Sensor                                           | 31 |
|   | 4.6.15      | Sensor Time                                                  | 32 |
|   | 4.6.16      | Configuration Changes                                        | 33 |
|   | 4.7 FIFO    |                                                              | 34 |
|   | 4.7.1       | Frames                                                       | 34 |
|   | 4.7.2       | Conditions and Details                                       | 38 |
|   | 4.7.3       | FIFO data synchronization                                    | 39 |
|   | 4.7.4       | FIFO synchronization with external events                    | 40 |
|   | 4.7.5       | FIFO Interrupts                                              | 40 |
|   | 4.7.6       | FIFO Reset                                                   | 40 |
|   | 4.7.7       | FIFO in Low Power Mode                                       | 40 |
|   | 4.8 Adva    | nced Features                                                | 41 |

| 4.8.1        | Global Configuration                        | 41 |
|--------------|---------------------------------------------|----|
| 4.8.2        | Anymotion Detection                         | 43 |
| 4.8.3        | Nomotion Detection                          | 45 |
| 4.8.4        | Significant Motion Detection                | 47 |
| 4.8.5        | Activity and Activity Change Recognition    | 47 |
| 4.8.6        | Wrist Wear Wakeup                           | 48 |
| 4.8.7        | Wrist Wear Navigation Gesture Detector      | 50 |
| 4.8.8        | Step counter / detector (Wrist-worn)        | 53 |
| 4.9 Gener    | ral Interrupt Pin Configuration             | 54 |
| 4.9.1        | Electrical Interrupt Pin Behavior           | 54 |
| 4.9.2        | Interrupt Pin Mapping                       | 54 |
| 4.10 Auxilia | ary Sensor Interface                        | 55 |
| 4.10.1       | Structure and Concept                       | 55 |
| 4.10.2       | Interface Control                           | 56 |
| 4.10.3       | Interface Configuration                     | 56 |
| 4.10.4       | Setup Mode (AUX_IF_CONF.aux_manual_en =0b1) | 57 |
| 4.10.5       | Data Mode (AUX_IF_CONF.aux_manual_en=0)     | 59 |
| 4.10.6       | Delay (Time Offset)                         | 59 |
| 4.11 OIS Ir  | nterface                                    | 60 |
| 4.11.1       | OIS Register Map                            | 61 |
| 4.11.2       | Register (0x0C0x17) OIS_DATA_011            | 62 |
| 4.11.3       | Register (0x40) OIS_CTRL_S                  | 62 |
| 4.12 Senso   | or Self-Test                                | 63 |
| 4.12.1       | Accelerometer                               | 63 |
| 4.12.2       | Gyroscope                                   | 64 |
| 4.13 Offset  | t Compensation                              | 65 |
| 4.13.1       | Accelerometer                               | 65 |
| 4.13.2       | Gyroscope                                   | 65 |
| 4.14 Sensi   | tivity Error Compensation                   | 67 |
| 4.14.1       | Accelerometer                               | 67 |
| 4.14.2       | Gyroscope                                   | 67 |
| 4.15 Non-V   | /olatile Memory                             | 68 |
| 4.16 Error   | Reporting                                   | 69 |
| 4.17 Soft R  | Reset                                       | 69 |
| Pagister Da  | escription                                  | 70 |
| _            |                                             |    |
|              | ral Remarks                                 |    |
| 5.2 Regis    | ter Map                                     | 71 |

5

| 5.2.1  | Register (0x00) CHIP_ID         | 75  |
|--------|---------------------------------|-----|
| 5.2.2  | Register (0x02) ERR_REG         | 75  |
| 5.2.3  | Register (0x03) STATUS          | 75  |
| 5.2.4  | Register (0x04) DATA_0          | 76  |
| 5.2.5  | Register (0x05) DATA_1          | 76  |
| 5.2.6  | Register (0x06) DATA_2          | 76  |
| 5.2.7  | Register (0x07) DATA_3          | 76  |
| 5.2.8  | Register (0x08) DATA_4          | 77  |
| 5.2.9  | Register (0x09) DATA_5          | 77  |
| 5.2.10 | Register (0x0A) DATA_6          | 77  |
| 5.2.11 | Register (0x0B) DATA_7          | 77  |
| 5.2.12 | Register (0x0C) DATA_8          | 78  |
| 5.2.13 | Register (0x0D) DATA_9          | 78  |
| 5.2.14 | Register (0x0E) DATA_10         | 78  |
| 5.2.15 | Register (0x0F) DATA_11         | 78  |
| 5.2.16 | Register (0x10) DATA_12         | 79  |
| 5.2.17 | Register (0x11) DATA_13         | 79  |
| 5.2.18 | Register (0x12) DATA_14         | 79  |
| 5.2.19 | Register (0x13) DATA_15         | 79  |
| 5.2.20 | Register (0x14) DATA_16         | 80  |
| 5.2.21 | Register (0x15) DATA_17         | 80  |
| 5.2.22 | Register (0x16) DATA_18         | 80  |
| 5.2.23 | Register (0x17) DATA_19         | 80  |
| 5.2.24 | Register (0x18) SENSORTIME_0    | 81  |
| 5.2.25 | Register (0x19) SENSORTIME_1    | 81  |
| 5.2.26 | Register (0x1A) SENSORTIME_2    | 81  |
| 5.2.27 | Register (0x1B) EVENT           | 82  |
| 5.2.28 | Register (0x1C) INT_STATUS_0    | 82  |
| 5.2.29 | Register (0x1D) INT_STATUS_1    | 83  |
| 5.2.30 | Register (0x1E) SC_OUT_0        | 83  |
| 5.2.31 | Register (0x1F) SC_OUT_1        | 83  |
| 5.2.32 | Register (0x20) WR_GEST_ACT     | 84  |
| 5.2.33 | Register (0x21) INTERNAL_STATUS | 85  |
| 5.2.34 | Register (0x22) TEMPERATURE_0   | 86  |
| 5.2.35 | Register (0x23) TEMPERATURE_1   | 86  |
| 5.2.36 | Register (0x24) FIFO_LENGTH_0   | 86  |
| 5.2.37 | Register (0x25) FIFO_LENGTH_1   | 87  |
| 5.2.38 | Register (0x26) FIFO_DATA       | 87  |
| 5.2.39 | Register (0x2F) FEAT_PAGE       | 87  |
| 5.2.40 | Register (0x30) FEATURES[16]    | 88  |
| 5.2.41 | Register (0x40) ACC_CONF        | 100 |

| 5.2.42 | Register (0x41) ACC_RANGE          | 102 |
|--------|------------------------------------|-----|
| 5.2.43 | Register (0x42) GYR_CONF           | 102 |
| 5.2.44 | Register (0x43) GYR_RANGE          | 103 |
| 5.2.45 | Register (0x44) AUX_CONF           | 103 |
| 5.2.46 | Register (0x45) FIFO_DOWNS         | 104 |
| 5.2.47 | Register (0x46) FIFO_WTM_0         | 105 |
| 5.2.48 | Register (0x47) FIFO_WTM_1         | 105 |
| 5.2.49 | Register (0x48) FIFO_CONFIG_0      | 105 |
| 5.2.50 | Register (0x49) FIFO_CONFIG_1      | 106 |
| 5.2.51 | Register (0x4A) SATURATION         | 107 |
| 5.2.52 | Register (0x4B) AUX_DEV_ID         | 107 |
| 5.2.53 | Register (0x4C) AUX_IF_CONF        | 107 |
| 5.2.54 | Register (0x4D) AUX_RD_ADDR        | 108 |
| 5.2.55 | Register (0x4E) AUX_WR_ADDR        | 108 |
| 5.2.56 | Register (0x4F) AUX_WR_DATA        | 108 |
| 5.2.57 | Register (0x52) ERR_REG_MSK        | 109 |
| 5.2.58 | Register (0x53) INT1_IO_CTRL       | 109 |
| 5.2.59 | Register (0x54) INT2_IO_CTRL       | 110 |
| 5.2.60 | Register (0x55) INT_LATCH          | 111 |
| 5.2.61 | Register (0x56) INT1_MAP_FEAT      | 111 |
| 5.2.62 | Register (0x57) INT2_MAP_FEAT      | 111 |
| 5.2.63 | Register (0x58) INT_MAP_DATA       | 112 |
| 5.2.64 | Register (0x59) INIT_CTRL          | 112 |
| 5.2.65 | Register (0x5B) INIT_ADDR_0        | 112 |
| 5.2.66 | Register (0x5C) INIT_ADDR_1        | 113 |
| 5.2.67 | Register (0x5E) INIT_DATA          | 113 |
| 5.2.68 | Register (0x5F) INTERNAL_ERROR     | 113 |
| 5.2.69 | Register (0x68) AUX_IF_TRIM        | 114 |
| 5.2.70 | Register (0x69) GYR_CRT_CONF       | 114 |
| 5.2.71 | Register (0x6A) NVM_CONF           | 114 |
| 5.2.72 | Register (0x6B) IF_CONF            | 115 |
| 5.2.73 | Register (0x6C) DRV                | 115 |
| 5.2.74 | Register (0x6D) ACC_SELF_TEST      | 116 |
| 5.2.75 | Register (0x6E) GYR_SELF_TEST_AXES | 116 |
| 5.2.76 | Register (0x70) NV_CONF            | 117 |
| 5.2.77 | Register (0x71) OFFSET_0           | 117 |
| 5.2.78 | Register (0x72) OFFSET_1           | 117 |
| 5.2.79 | Register (0x73) OFFSET_2           | 118 |
| 5.2.80 | Register (0x74) OFFSET_3           | 118 |
| 5.2.81 | Register (0x75) OFFSET_4           | 118 |
| 5.2.82 | Register (0x76) OFFSET 5           | 118 |

|   | 5.2.83        | Register (0x77) OFFSET 6                                                    | 119 |
|---|---------------|-----------------------------------------------------------------------------|-----|
|   | 5.2.84        | Register (0x7C) PWR_CONF                                                    |     |
|   | 5.2.85        | Register (0x7D) PWR_CTRL                                                    |     |
|   | 5.2.86        | Register (0x7E) CMD                                                         | 120 |
| 6 | Digital Inter | faces                                                                       | 121 |
|   | 6.1 Interfa   | aces                                                                        | 121 |
|   | 6.2 Prima     | ry Interface                                                                | 122 |
|   | 6.3 Prima     | ry Interface Digital Protocol Selection                                     | 123 |
|   | 6.4 Prima     | ry Interface SPI                                                            | 123 |
|   | 6.5 Prima     | ry Interface I <sup>2</sup> C                                               | 128 |
|   | 6.5.1         | I <sup>2</sup> C write access:                                              | 130 |
|   | 6.5.2         | I <sup>2</sup> C read access                                                | 130 |
|   | 6.6 Secor     | ndary Interface                                                             | 132 |
|   | 6.6.1         | Auxiliary Interface                                                         | 132 |
|   | 6.6.2         | OIS Interface                                                               | 133 |
| 7 | Pin-out and   | l Connection Diagram                                                        | 134 |
|   | 7.1 Pin-ou    | ıt                                                                          | 134 |
|   | 7.2 Conne     | ection Diagrams without Secondary Interface                                 | 136 |
|   | 7.2.1         | Primary: 3-wire SPI Secondary: None                                         | 136 |
|   | 7.2.2         | Primary: 4-wire SPI Secondary: None                                         | 136 |
|   | 7.2.3         | Primary: I2C Secondary: None                                                | 137 |
|   | 7.3 Conne     | ection Diagrams with I2C Auxiliary Interface                                | 138 |
|   | 7.3.1         | Primary: 3-wire SPI Secondary: Auxiliary interface I2C (e.g. BMM150 sensor) | 138 |
|   | 7.3.2         | Primary: 4-wire SPI Secondary: Auxiliary interface I2C (e.g. BMM150 sensor) | 138 |
|   | 7.3.3         | Primary: I2C Secondary: Auxiliary interface I2C (e.g. BMM150 sensor)        | 139 |
|   | 7.4 Conne     | ection Diagrams with OIS Interface                                          | 140 |
|   | 7.4.1         | Primary: 3-wire SPI Secondary: 4-wire SPI for OIS interface                 | 140 |
|   | 7.4.2         | Primary: 3-wire SPI Secondary: 3-wire SPI for OIS interface                 | 140 |
|   | 7.4.3         | Primary: 4-wire SPI Secondary: 4-wire SPI for OIS interface                 | 141 |
|   | 7.4.4         | Primary: 4-wire SPI Secondary: 3-wire SPI for OIS interface                 | 141 |
|   | 7.4.5         | Primary: I2C Secondary: 4-wire SPI for OIS interface                        | 142 |
|   | 7.4.6         | Primary: I2C Secondary: 3-wire SPI for OIS interface                        | 142 |
| 8 | Package       |                                                                             | 143 |
|   | 8.1 Packa     | ge outline dimensions                                                       | 143 |
|   | 8.2 Sensi     | ng axis orientation                                                         | 144 |

|    | 8.3 Landii  | ng pattern recommendation  | 145 |
|----|-------------|----------------------------|-----|
|    | 8.4 Markir  | ng                         | 146 |
|    | 8.4.1       | Mass production            | 146 |
|    | 8.4.2       | Engineering samples        | 146 |
|    | 8.5 Solde   | ring guidelines            | 147 |
|    | 8.6 Handl   | ling instructions          | 147 |
|    | 8.7 Enviro  | onmental safety            |     |
|    | 8.7.1       | Halogen content            | 147 |
|    | 8.7.2       | Internal package structure | 147 |
| 9  | Legal discl | aimer                      | 148 |
| 10 | Document l  | history and modification   | 149 |

# List of figures

| Figure 1: Any-motion detection                                                          | 44  |
|-----------------------------------------------------------------------------------------|-----|
| Figure 2: No-motion detection                                                           |     |
| Figure 3: Device co-ordinate system assumed for gesture detection                       |     |
| Figure 4: Flick-in/out movement                                                         |     |
| Figure 5: Push arm-down/pivot up                                                        |     |
| Figure 6: Shake or jiggle movement                                                      |     |
| Figure 7: 9-DOF Solution w/ magnetometer (AUX) connected to the 2 <sup>nd</sup> I/F     |     |
| Figure 8: OIS interface                                                                 |     |
| Figure 9: Digital Interfaces                                                            | 121 |
| Figure 10: SPI timing diagram                                                           | 124 |
| Figure 11: 4-wire basic SPI write sequence (mode '00')                                  | 125 |
| Figure 12: SPI multiple write                                                           | 125 |
| Figure 13: 4-wire basic SPI read sequence (mode '00')                                   | 126 |
| Figure 14: 3-wire basic SPI write sequence (mode '11')                                  | 127 |
| Figure 15: 3-wire basic SPI read sequence (mode '00')                                   | 127 |
| Figure 16: I <sup>2</sup> C timing diagram                                              | 129 |
| List of tables                                                                          |     |
| Table 1: Basic electrical parameter specifications                                      | 11  |
| Table 2: Characteristics of Accelerometer                                               |     |
| Table 3: Gyroscope Characteristics                                                      |     |
| Table 4: Electrical Characteristics of Temperature Sensor                               |     |
| Table 5: Absolute maximum ratings                                                       |     |
| Table 6: Power Modes                                                                    |     |
| Table 7: Cutoff freq. of the accelerometer according to ODR, Normal & Performance Mode  |     |
| Table 8: Accelerometer noise according to ODR, Normal & Performance Mode, ± 8g range    |     |
| Table 9: Accelerometer group delay according to ODR, Normal & Performance Mode          |     |
| Table 10: Cutoff frequency of the gyroscope according to ODR, Normal & Performance Mode |     |
| Table 11: Gyroscope noise according to ODR, Normal Mode, ± 2000 dps range               |     |
| Table 12: Gyroscope noise according to ODR, Performance Mode, ± 2000 dps range          |     |
| Table 14: Positive use-case scenarios for the wrist wear wakeup gestures                |     |
| Table 15: Step counter Configuration                                                    |     |
| Table 16: OIS Register Map                                                              |     |
| Table 17: Mapping for primary interface                                                 |     |
| Table 18: Electrical specifications of the interface pins                               |     |
| Table 19: Timing specifications for SPI                                                 |     |
| Table 20: Timing specifications for I <sup>2</sup> C of the device                      |     |
| Table 21: Mapping of the device pins for secondary interface                            |     |
| Table 22: Pin-out and pin connections                                                   |     |

# 1 Specification

Unless stated otherwise, the given values are over lifetime, operating temperature and voltage ranges. Minimum/maximum values are  $\pm 3\sigma$ .

Table 1: Basic electrical parameter specifications

| Operating Conditions                   |                   |                                                                                              |                      |     |                      |        |
|----------------------------------------|-------------------|----------------------------------------------------------------------------------------------|----------------------|-----|----------------------|--------|
| Parameter                              | Symbol            | Condition                                                                                    | Min                  | Тур | Max                  | Units  |
| Supply Voltage<br>Core Domain          | $V_{DD}$          |                                                                                              | 1.71                 | 1.8 | 3.6                  | ٧      |
| Supply Voltage<br>I/O Domain           | $V_{\text{DDIO}}$ |                                                                                              | 1.2                  | 1.8 | 3.6                  | V      |
| Voltage Input<br>Low Level             | VIL               | SPI & I <sup>2</sup> C                                                                       |                      |     | 0.3V <sub>DDIO</sub> | -      |
| Voltage Input<br>High Level            | VIH               | SPI & I <sup>2</sup> C                                                                       | 0.7VDDIO             |     |                      | -      |
| Voltage Output<br>Low Level            | VOL               | V <sub>DDIO</sub> >=1.62V,<br>I <sub>OL</sub> <=2mA, SPI                                     |                      |     | 0.2V <sub>DDIO</sub> | -      |
|                                        | VOL               | V <sub>DDIO</sub> <1.62V,<br>I <sub>OL</sub> <=1.5mA, SPI                                    |                      |     | 0.2V <sub>DDIO</sub> | -      |
| Voltage Output<br>High Level           | VOL               | V <sub>DDIO</sub> >=1.62V,<br>I <sub>OH</sub> <=2mA, SPI                                     | 0.8V <sub>DDIO</sub> |     |                      | -      |
|                                        | VOH               | V <sub>DDIO</sub> <=1.62V,<br>I <sub>OH</sub> <=1.5mA, SPI                                   | 0.8V <sub>DDIO</sub> |     |                      | -      |
| Current consumption                    |                   | A+G Performance Mode<br>VDD= 1.8 V, T <sub>A</sub> =25°C,<br>ODR <sub>max</sub>              |                      | 970 |                      |        |
|                                        |                   | A+G Normal Mode<br>VDD= 1.8 V, T <sub>A</sub> =25°C,<br>ODR <sub>max</sub>                   |                      | 685 |                      |        |
|                                        |                   | A+G Low Power Mode<br>VDD= 1.8 V, T <sub>A</sub> =25°C,<br>ODR <sub>25Hz</sub>               |                      | 420 |                      |        |
|                                        | I <sub>DD</sub>   | A <sub>only</sub> Normal Mode<br>VDD= 1.8 V, T <sub>A</sub> =25°C,<br>ODR <sub>max</sub>     |                      | 210 |                      | μΑ     |
|                                        |                   | A <sub>only</sub> Low Power Mode<br>VDD= 1.8 V, T <sub>A</sub> =25°C,<br>ODR <sub>25Hz</sub> |                      | 10  |                      |        |
|                                        |                   | A+G Suspend mode,<br>VDD= 1.8 V, T <sub>A</sub> =25°C                                        |                      | 3.5 |                      |        |
|                                        |                   | Advanced features VDD= 1.8 V, TA=25°C, depends on enabled feature set                        |                      | 3   |                      |        |
| Power on time                          | t <sub>PO</sub>   | Time from supply "on" to SPI or I2C I/F operational                                          |                      |     | 2                    | ms     |
| Non-volatile memory (NVM) write-cycles | nNVM              | Using nvm_prog cmd                                                                           |                      |     | 14                   | cycles |
| Operating<br>Temperature               | T <sub>A</sub>    |                                                                                              | -40                  |     | +85                  | °C     |

Table 2: Characteristics of Accelerometer

| Operating Conditions Accelerometer |                |                                   |     |     |     |          |
|------------------------------------|----------------|-----------------------------------|-----|-----|-----|----------|
| Parameter                          | Symbol         | Condition                         | Min | Тур | Max | Units    |
| Acceleration Range                 | <b>g</b> FS2g  | Selectable                        |     | ±2  |     |          |
|                                    | <b>g</b> FS4g  | via serial digital interface      |     | ±4  |     | <u> </u> |
|                                    | <b>g</b> FS8g  |                                   |     | ±8  |     | g        |
|                                    | <b>g</b> FS16g |                                   |     | ±16 |     |          |
| Start-up time                      |                | Suspend to normal mode            |     |     |     |          |
|                                    | $t_{A,SU}$     | VDD= 1.8 V, T <sub>A</sub> =25°C, |     | 2   |     | ms       |
|                                    |                | ODR <sub>max</sub>                |     |     |     |          |

|                    | Output Signal Accelerometer |                                                  |      |        |      |         |  |  |
|--------------------|-----------------------------|--------------------------------------------------|------|--------|------|---------|--|--|
| Parameter          | Symbol                      | Condition                                        | Min  | Тур    | Max  | Units   |  |  |
| Resolution         |                             |                                                  |      | 16     |      | bit     |  |  |
| Sensitivity        | S <sub>2g</sub>             | g <sub>FS2g</sub> , T <sub>A</sub> =25°C         |      | 16384  |      |         |  |  |
|                    | S <sub>4g</sub>             | g <sub>FS4g</sub> , T <sub>A</sub> =25°C         |      | 8192   |      | I SR/g  |  |  |
|                    | S <sub>8g</sub>             | g <sub>FS8g</sub> , T <sub>A</sub> =25°C         |      | 4096   |      | – LSB/g |  |  |
|                    | S <sub>16g</sub>            | g <sub>FS16g</sub> , T <sub>A</sub> =25°C        |      | 2048   |      |         |  |  |
| Sensitivity Error  | S <sub>A_err_8g</sub>       | $T_A=25$ °C, nominal $V_{DD}$                    |      | ±0.4   |      | %       |  |  |
|                    | JA_err_8g                   | soldered, over life time                         |      | 10.4   |      | 70      |  |  |
| Sensitivity        | TCSA                        | full $T_A$ range, nominal $V_{DD}$               |      | 0.004  |      | %/K     |  |  |
| Temperature Drift  | T C SA                      | best fit straight line                           |      | 0.004  |      | 70/10   |  |  |
| Sensitivity        | S <sub>A,VDD</sub>          | $T_A=25$ °C, full $V_{DD}$ range                 |      | 0.0001 |      | %/V     |  |  |
| Supply Volt. Drift | OA, VDD                     | soldered, over life time                         |      | 0.0001 |      | 70/ 4   |  |  |
| Zero-g Offset      | Off <sub>A,life</sub>       | $T_A=25$ °C, nominal $V_{DD}$                    |      | ±20    |      | mg      |  |  |
|                    | OTTA, ille                  | soldered, over life time                         |      |        |      | 8       |  |  |
| Zero-g Offset      | TCOA                        | full $T_A$ range, nominal $V_{DD}$               |      | ±0.25  |      | mg/K    |  |  |
| Temperature Drift  |                             | best fit straight line                           |      |        |      |         |  |  |
| Zero-g Offset      | Off <sub>A,VDD</sub>        | T <sub>A</sub> =25°C, full V <sub>DD</sub> range |      | <0.5   |      | mg/V    |  |  |
| Supply Volt. Drift | 7,,125                      | soldered, over life time                         |      |        |      | J       |  |  |
| Power supply       | Off PSRRA                   | 100Hz – 1 MHz                                    |      | < 8    |      | mg/50mV |  |  |
| rejection ratio    | _                           | sine wave, 50mV                                  |      |        |      |         |  |  |
| Output Noise       |                             | Normal mode                                      |      | 0.40   |      | mg/√Hz  |  |  |
|                    | <b>n</b> A,nd               | $T_A = 25$ °C, nominal $V_{DD}$ ,                |      | 0.16   |      |         |  |  |
|                    |                             | range = 8g                                       |      |        |      |         |  |  |
|                    |                             | Normal mode                                      |      |        |      |         |  |  |
|                    |                             | $T_A=25^{\circ}C$ , nominal $V_{DD}$ ,           |      | 4 54   |      |         |  |  |
|                    | n <sub>A,rms</sub>          | BW = 80 Hz                                       |      | 1.51   |      | mg-rms  |  |  |
|                    |                             | ODR = 200 Hz                                     |      |        |      |         |  |  |
|                    |                             | range = 8g                                       |      |        |      |         |  |  |
| Nonlinearity       | $NL_A$                      | T <sub>A</sub> =25°C, nominal V <sub>DD</sub> ,  |      | 0.5    |      | %FS     |  |  |
| 0                  |                             | best fit straight line gFS2g                     | 40.5 |        | 4000 |         |  |  |
| Output Data Rate   | ODR <sub>A,n</sub>          | Normal mode                                      | 12.5 |        | 1600 | Hz      |  |  |
| 000.4              | ODR <sub>A,lpm</sub>        | Low-power mode                                   | 0.78 |        | 400  |         |  |  |
| ODR Accuracy       |                             | Normal mode, variation                           |      |        |      |         |  |  |
|                    |                             | part to part, T <sub>A</sub> =25°C,              |      | 1      |      |         |  |  |
|                    | OAcy <sub>A,n</sub>         | nominal V <sub>DD</sub> ,                        |      |        |      | %       |  |  |
|                    |                             | Accel only operation                             |      |        |      | _       |  |  |
|                    |                             | Normal mode, variation                           |      | 1.7    |      |         |  |  |
|                    |                             | part to part, T <sub>A</sub> =25°C,              |      |        |      |         |  |  |

| Output Signal Accelerometer |                       |                                                 |     |      |      |       |
|-----------------------------|-----------------------|-------------------------------------------------|-----|------|------|-------|
| Parameter                   | Symbol                | Condition                                       | Min | Тур  | Max  | Units |
|                             |                       | nominal V <sub>DD</sub> ,                       |     |      |      |       |
|                             |                       | IMU operation                                   |     |      |      |       |
|                             |                       | Normal mode, variation                          |     |      |      |       |
|                             |                       | full TA range, same part                        |     | 0.03 |      |       |
|                             |                       | nominal V <sub>DD</sub> ,                       |     |      |      |       |
|                             | OAcy <sub>A,n,T</sub> | Accel only operation                            |     |      |      | %/K   |
|                             | OACYA,n, I            | Normal mode, variation                          |     |      |      | 70/13 |
|                             |                       | full $T_A$ range, same part                     |     |      |      |       |
|                             |                       | nominal V <sub>DD</sub> ,                       |     |      | 0037 |       |
|                             |                       | IMU operation                                   |     |      |      |       |
| Bandwidth (BW)              | ODR <sub>A,12.5</sub> | 3dB cutoff frequency of                         |     | 5.5  |      |       |
| in normal mode              | ODR <sub>A,25</sub>   | the accelerometer                               |     | 11   |      |       |
|                             | ODR <sub>A,50</sub>   | T <sub>A</sub> =25°C, nominal V <sub>DD</sub> , |     | 22   |      |       |
|                             | ODR <sub>A,100</sub>  |                                                 |     | 44   |      | Hz    |
|                             | ODR <sub>A,200</sub>  | Filter setting                                  |     | 89   |      | П     |
|                             | ODR <sub>A,400</sub>  | [acc_bwp] = 0x02                                |     | 178  |      |       |
|                             | ODR <sub>A,800</sub>  |                                                 |     | 343  |      |       |
|                             | ODR <sub>A,1600</sub> |                                                 |     | 740  |      |       |

| Mechanical Characteristics Accelerometer |                      |                                               |     |        |     |            |  |
|------------------------------------------|----------------------|-----------------------------------------------|-----|--------|-----|------------|--|
| Parameter                                | Symbol               | Condition                                     | Min | Тур    | Max | Units      |  |
| Cross Axis Sensitivity                   |                      | Relative contribution                         |     |        |     |            |  |
|                                          | $SX_A$               | between any two of the                        |     | 1      |     | %          |  |
|                                          |                      | three axes                                    |     |        |     |            |  |
| Alignment Error                          | _                    | Relative to package                           |     | 0.5    |     | 0          |  |
|                                          | EA                   | outline                                       |     |        |     |            |  |
| Zero-g offset                            | O#                   | T <sub>A</sub> =25°C, nominal V <sub>DD</sub> |     | 10.010 |     | malustrain |  |
| over PCB strain                          | Off <sub>A,PCB</sub> | soldered, $\varnothing$ 5 parts               |     | ±0.010 |     | mg/µstrain |  |

Table 3: Gyroscope Characteristics

|               |                     | Operating Conditions Gy                                                                      | yroscope |       |     |       |
|---------------|---------------------|----------------------------------------------------------------------------------------------|----------|-------|-----|-------|
| Parameter     | Symbol              | Condition                                                                                    | Min      | Тур   | Max | Units |
| Range         | R <sub>FS125</sub>  | Selectable                                                                                   |          | 125   |     |       |
|               | R <sub>FS250</sub>  | via serial digital interface                                                                 |          | 250   |     |       |
|               | R <sub>FS500</sub>  | ]                                                                                            |          | 500   |     | dps   |
|               | R <sub>FS1000</sub> | ]                                                                                            |          | 1,000 |     |       |
|               | RFS2000             |                                                                                              |          | 2,000 |     |       |
| Start-up time | t <sub>G</sub> ,su  | suspend to normal mode<br>repeated, VDD = 1.8 V,<br>T <sub>A</sub> =25°C, ODR <sub>max</sub> |          | 45    |     |       |
|               | t <sub>G,FSU</sub>  | fast start mode VDD = 1.8 V, $T_A$ =25°C, ODR <sub>max</sub>                                 |          | 2     |     | ms    |

|                    |                                  | Output Signal Gyrosc                             |     |         |       |          |
|--------------------|----------------------------------|--------------------------------------------------|-----|---------|-------|----------|
| Parameter          | Symbol                           | Condition                                        | Min | Тур     | Max   | Units    |
| Resolution         |                                  |                                                  |     | 16      |       | bit      |
| Sensitivity        | R <sub>FS2000</sub>              | Ta=25°C                                          |     | 16.384  |       |          |
|                    | R <sub>FS1000</sub>              | Ta=25°C                                          |     | 32.768  |       |          |
|                    | R <sub>FS500</sub>               | Ta=25°C                                          |     | 65.536  |       | LSB/dps  |
|                    | R <sub>FS250</sub>               | Ta=25°C                                          |     | 131.072 |       |          |
|                    | R <sub>FS125</sub>               | Ta=25°C                                          |     | 262.144 |       |          |
| Sensitivity Error  | $S_{G\_err}$                     | T <sub>A</sub> =25°C, nominal V <sub>DD</sub>    |     | ±2      |       | %        |
|                    |                                  | soldered, over life time                         |     |         |       |          |
|                    | S <sub>G_err_CRT</sub>           | T <sub>A</sub> =25°C, nominal V <sub>DD</sub>    |     | ±0.4    |       |          |
|                    |                                  | soldered, after CRT <sup>1</sup>                 |     |         |       |          |
| Sensitivity        | TCS <sub>G</sub>                 | full TA range, nominal VDD                       |     | 0.02    |       | %/K      |
| Temperature Drift  |                                  | best fit straight line                           |     |         |       |          |
| Sensitivity Supply | 6                                | T <sub>A</sub> =25°C, full V <sub>DD</sub> range |     | 0.0005  |       | %/V      |
| Volt. Drift        | S <sub>G</sub> , v <sub>DD</sub> | soldered, over life time                         |     |         |       |          |
| Zero-rate Offset   | $\Omega$ , oL                    | T <sub>A</sub> =25°C, nominal V <sub>DD</sub>    |     | ±0.5    |       | dps      |
|                    | ,                                | soldered, over life time                         |     |         |       | •        |
| Zero-rate offset   | TCO <sub>G</sub>                 | Nominal V <sub>DD</sub> supplies                 |     | ±0.015  |       | dps/K    |
| change over        |                                  | best fit straight line                           |     |         |       |          |
| temperature        |                                  |                                                  |     |         |       |          |
| Zero-g Offset      | Off <sub>G,VDD</sub>             | T <sub>A</sub> =25°C, full V <sub>DD</sub> range |     | 0.02    |       | dps/V    |
| Supply Volt. Drift |                                  | soldered, over life time                         |     |         |       |          |
| Power supply       | Off_PSRR <sub>G</sub>            | 100 Hz – 1 MHz                                   |     | 0.40    |       | dps/50mV |
| rejection ratio    | _                                | sine wave, 50mV                                  |     |         |       | -        |
| Output Noise       | <b>n</b> G,nd                    | Performance mode                                 |     | 0.007   |       | dps /√Hz |
| ·                  |                                  | T <sub>A</sub> =25°C, nominal V <sub>DD</sub>    |     |         |       |          |
|                    |                                  | Normal mode                                      |     | 0.010   |       | dps /√Hz |
|                    |                                  | T <sub>A</sub> =25°C, nominal V <sub>DD</sub>    |     |         |       | •        |
|                    | n <sub>G,rms</sub>               | Performance mode                                 |     | 0.07    |       | dps-rms  |
|                    | ŕ                                | T <sub>A</sub> =25°C, nominal V <sub>DD</sub> ,  |     |         |       | •        |
|                    |                                  | BW = 74.6 Hz                                     |     |         |       |          |
|                    |                                  | ODR = 200 Hz                                     |     |         |       |          |
|                    |                                  | Normal mode                                      |     | 0.09    |       | dps-rms  |
|                    |                                  | T <sub>A</sub> =25°C, nominal V <sub>DD</sub> ,  |     |         |       | •        |
|                    |                                  | BW = 74.6 Hz                                     |     |         |       |          |
|                    |                                  | ODR = 200 Hz                                     |     |         |       |          |
| Nonlinearity       | NLG                              | T <sub>A</sub> =25°C, nominal V <sub>DD</sub> ,  |     | 0.01    |       | % FS     |
| · ····· ······     |                                  | best fit straight line                           |     |         |       |          |
|                    |                                  | RFS250, RFS2000                                  |     |         |       |          |
| Output Data Rate   | $ODR_{G,n,hp}$                   | Normal and performance                           | 25  | +       | 6400  | Hz       |
| Salpat Data Hate   | O D i (G,ii,iip                  | mode                                             | 20  |         | 0 100 | 112      |
|                    | ODR <sub>G,lpm</sub>             | Low-power mode                                   | 25  |         | 100   | =        |
| ODR Accuracy       | OAcy <sub>G,n</sub>              | Normal and performance                           |     | 1.7     | 100   | %        |
| ODIT Accuracy      | Олсуч,п                          | mode, T <sub>A</sub> =25°C, nominal              |     | '''     |       | /0       |
|                    |                                  | V <sub>DD</sub>                                  |     |         |       |          |
|                    | OAcy <sub>G,n,T</sub>            | Normal mode,                                     |     | 0.0037  |       | %/K      |
|                    | <b>О</b> Д <b>Су</b> (с,п, г     | full T <sub>A</sub> range, same part,            |     | 0.0007  |       | /0/11    |
|                    |                                  | nominal V <sub>DD</sub>                          |     |         |       |          |
|                    |                                  | טט זייטוווומו                                    |     |         |       |          |

\_

<sup>&</sup>lt;sup>1</sup> See section 4.14 for details.

| Bandwidth (BW)   | ODR <sub>G,25</sub>   | 3dB cutoff frequency of                       | 11  | Hz |
|------------------|-----------------------|-----------------------------------------------|-----|----|
| in normal and    | ODR <sub>G,50</sub>   | the gyroscope,                                | 20  |    |
| performance mode | ODR <sub>G,100</sub>  | T <sub>A</sub> =25°C, nominal V <sub>DD</sub> | 39  |    |
|                  | ODR <sub>G,200</sub>  |                                               | 77  |    |
|                  | ODR <sub>G,400</sub>  | Filter setting                                | 152 |    |
|                  | ODR <sub>G,800</sub>  | [gyr_bwp] = 0x02                              | 300 |    |
|                  | ODR <sub>G,1600</sub> |                                               | 557 |    |
|                  | ODR <sub>G,3200</sub> |                                               | 751 |    |
|                  | ODR <sub>G,6400</sub> |                                               | 712 |    |

|                        |                  | <b>Mechanical Characteristics</b>             | Gyroscope | •    |     |          |
|------------------------|------------------|-----------------------------------------------|-----------|------|-----|----------|
| Parameter              | Symbol           | Condition                                     | Min       | Тур  | Max | Units    |
| Cross Axis Sensitivity | SX <sub>G</sub>  | Relative contribution                         |           | 0.2  |     | %        |
|                        |                  | between any two of the                        |           |      |     |          |
|                        |                  | three axes 2                                  |           |      |     |          |
| Alignment Error        | E <sub>G,A</sub> | Relative to package                           |           | 0.5  |     | 0        |
|                        |                  | outline                                       |           |      |     |          |
| Zero-g offset          | Offg, PCB        | T <sub>A</sub> =25°C, nominal V <sub>DD</sub> |           | ±1.5 |     | mdps     |
| over PCB strain        |                  | soldered, $\varnothing$ 5 parts               |           |      |     | /µstrain |
| g-Sensitivity          |                  | Sensitivity to static                         |           |      | 0.1 | dps/g    |
|                        |                  | acceleration stimuli in all                   |           |      |     |          |
|                        |                  | three axis                                    |           |      |     |          |

Table 4: Electrical Characteristics of Temperature Sensor

|                                        | Operating Co       | onditions and Output Signa                                                                     | al of Temper | ature Senso | r    |       |
|----------------------------------------|--------------------|------------------------------------------------------------------------------------------------|--------------|-------------|------|-------|
| Parameter                              | Symbol             | Condition                                                                                      | Min          | Тур         | Max  | Units |
| ADC Resolution                         |                    |                                                                                                |              | 16          |      | bits  |
| Temperature Sensor                     | Ts                 |                                                                                                | -41          |             | 87   | °C    |
| Measurement Range                      |                    |                                                                                                |              |             |      |       |
| Output at 23 °C                        |                    |                                                                                                |              | 0           |      | LSB   |
| Sensitivity                            | St                 |                                                                                                |              | 512         |      | LSB/K |
| Output Data Rate<br>Temperature Sensor | ODR <sub>T,G</sub> | Normal mode and performance mode, T <sub>A</sub> =25°C, nominal V <sub>DD</sub> , Gyroscope on |              |             | 100  | Hz    |
|                                        | ODR <sub>T</sub>   | All other modes incl. low power mode                                                           |              |             | 0.78 | -     |
| ODR Accuracy<br>Temperature Sensor     | ОАсут, а           | Normal mode and performance mode, T <sub>A</sub> =25°C, nominal V <sub>DD</sub> , Gyroscope on |              | <1.5        |      | %     |
|                                        | OAcy⊤              | All other modes incl. low power mode                                                           |              | 1.5         |      |       |

Modifications reserved | Data subject to change without notice

<sup>&</sup>lt;sup>2</sup> For details see section 4.6 Gyroscope DataPost-Processing

# 2 Absolute maximum ratings

Stress above these limits may cause damage to the device. Exceeding the specified electrical limits may affect the device reliability or cause malfunction.

Table 5: Absolute maximum ratings

| Parameter                   | Condition             | Min  | Max                        | Units |
|-----------------------------|-----------------------|------|----------------------------|-------|
| Voltage at Supply Pin       | V <sub>DD</sub> Pin   | -0.3 | 4                          | V     |
|                             | V <sub>DDIO</sub> Pin | -0.3 | 4                          | V     |
| Voltage at any Logic Pin    | Non-Supply Pin        | -0.3 | V <sub>DDIO</sub> +0.3, <4 | V     |
| Passive Storage Temp. Range | ≤ 65% rel. H.         | -50  | +150                       | °C    |
| None-volatile memory (NVM)  | T = 85°C,             | 10   |                            | у     |
| Data Retention              | after 15 cycles       |      |                            |       |
| Mechanical Shock            | Duration ≤ 200 µs     |      | 20,000                     | g     |
|                             | Duration ≤ 1.0 ms     |      | 2,000                      | g     |
|                             | Free fall             |      | 1.8                        | m     |
|                             | onto hard surfaces    |      |                            |       |
| ESD according JESD47        | HBM at any pin        |      | 2                          | kV    |
|                             | CDM                   |      | 500                        | V     |
|                             | MM JESD22A115C        |      | 200                        | V     |

## 3 Quick Start Guide

The purpose of this section is to help developers who want to start working with the device by giving you some very basic hands-on application examples to get started.

#### Note about using the device

The communication between application processor and the device will happen either over I2C or SPI interface. Each register read operation includes dummy bytes:

▶ 12C: 0

► SPI: 1

For simplicity the dummy bytes are not shown in the examples below. For more information about the interfaces, see Section 6.

The device is configured for advance power save mode after POR or soft reset. For details on the interface operation in advanced power save mode, see the description of Register PWR CONF.adv power save in Section 5.

Before starting the test, the device has to be properly connected to the master (AP) and powered up. For more information about it, read the related Section 7.

#### First application setup examples algorithms:

After power up by setting the correct voltage to the appropriate external pins, the device enters automatically into the Power On Reset (POR) sequence. In order to properly make use of the device, certain steps from host processor side are needed. The most typical operations will be explained in the following application examples in form of flow diagrams.

#### 1. Testing communication and initializing the device

a. Reading <u>CHIP\_ID</u> (0x24) (checking correct communication). The interface is coming up configured for I2C, the initial dummy read configures it to SPI.



#### b. Performing initialization sequence <sup>3</sup>



450us is the minimum duration (>= 450us is recommended wait time)

Modifications reserved | Data subject to change without notice

<sup>&</sup>lt;sup>3</sup> bmi270\_config\_file: https://github.com/BoschSensortec/BMI270-Sensor-API/blob/master/bmi270.c

# c. Checking the correct initialization status



## 2. Configuring the device for low power mode

Setting data processing parameters (power, bandwidth, range) and reading sensor data



## 3. Configuring the device for normal power mode

Setting data processing parameters (power, bandwidth, range) and reading sensor data



#### 4. Configuring the device for performance mode

Setting data processing parameters (power, bandwidth, range) and reading sensor data



# Further steps:

The device has many more capabilities that are described in this document and include FIFO, power saving modes, synchronization capabilities with host processor, data synchronization and integration with third party sensors (see Section 4).

# 4 Functional Description and Features

This section contains references to the registers of the device. A detailed description of the registers including addresses, bit fields, and values is given in Section 5.

## 4.1 System Configurations

The device has 14 external I/F pins and supports the SPI and I2C protocols on its primary interface to the host system. The device supports on its secondary interface (I2C master) an auxiliary sensor configuration (e.g. a magnetometer, see Section 4.10) or an external OIS interface (see Section 4.11). Both configurations work independent of the configuration (SPI/I2C) of the primary interface. If the secondary I/F is configured as AUX I/F, the sensor data of the IMU and the AUX sensor are synchronized.



The device includes two sensors, an accelerometer and a gyroscope. The accelerometer measures the direction and magnitude of the force applied to the sensor, reporting zero in a free fall scenario. The gyroscope measures the rotation rate, reporting zero at rest.

# 4.2 Block Diagram



# 4.3 Supply Voltage and Power Management

The device has two distinct power supply pins:

- ▶ VDD is the main power supply.
- ▶ VDDIO is a separate power supply pin used for supplying power for the interface including the auxiliary interface.

There are no limitations with respect to the voltage level applied to the VDD and VDDIO pins, as long as it lies within the respective operating range. Furthermore, the device can be completely switched off (VDD= 0V) while keeping the VDDIO supply within operating range or vice versa. However, if the VDDIO supply is switched off, all interface pins (CSB, SDX, SCX) must be kept close to GNDIO potential. The device is reset when the supply voltage applied to at least one supply pin VDD or VDDIO falls below the specified minimum values. No constraints exist for the minimum slew-rate of the voltage applied to the VDD and VDDIO pins.

## 4.4 Power-On-Reset (POR) and Device Initialization

During POR the voltages VDD/VDDIO are ramped to their respective target values. After reaching the target supply voltages, all registers are accessible after a delay of 450 us.

After every POR or soft reset, the IMU remains in suspend mode. To get ready for operation the device must be initialized through the following procedure:

- ▶ Interface selection (SPI only): Read an arbitrary register of the device, discard the read response
- ▶ Disable advanced power save mode: PWR CONF.adv power save =0b0
- ▶ Wait for at least 450 us (or 12 LSB of SENSORTIME\_0)
- ► Write INIT CTRL.init ctrl=0x00 to prepare config load
- ► Upload configuration file
  - Burst write 8 kB initialization data to Register INIT\_DATA (start with byte 0 of initialization data)<sup>4</sup>. This requires ca. 6.6 ms at 10 MHz SPI I/F frequency. The configuration file bmi270\_config\_file is available on GitHub (https://github.com/BoschSensortec/BMI270-Sensor-API/blob/master/bmi270.c)
  - Optionally: Burst read configuration file from Register <u>INIT\_DATA</u> and check correctness by comparing it to the data written to the register in the previous step.
- ► Write <a href="INIT\_CTRL.init\_ctrl">INIT\_CTRL.init\_ctrl</a> = 0x01 to complete config load.

Note: This operation must not be performed more than once after POR or soft reset.

► Wait until Register <a href="INTERNAL\_STATUS.message">INTERNAL\_STATUS.message</a> contains the value 0b0001. This will happen after at most 20 msec.

After the initialization sequence is completed, the power mode of the device is automatically set to "Configuration mode" (refer to Section 4.5). Now it is possible to switch to other power modes and the device is ready for operation as required and described in the following sections.

Modifications reserved | Data subject to change without notice

<sup>&</sup>lt;sup>4</sup> If the maximum burst write length of the host is less than 8 kB the initialization data can be written in smaller chunks. Between two write operations the Registers <u>INIT\_ADDR\_0</u> and <u>INIT\_ADDR\_1</u> need to be incremented by the length of the first chunk write operation in bytes/2.

#### 4.5 Power Modes

The main power modes of the device are:

- ▶ Suspend mode: Lowest possible power consumption, while still maintaining its configuration
- ► Configuration mode: All IMU features accessible at full interface speed
- ▶ Low power mode: Motion sensing at lowest possible power consumption
- ▶ Normal mode: Aliasing free motion sensing at maximum ODR
- ▶ Performance mode: Motion sensing at maximum sensor performance

The table below shows the required configurations for these power modes

Table 6: Power Modes

|                               |            | PWR_CTRL.acc_en | PWR_CTRL.gyr_en | ACC_CONF.acc_filter_perf | GYR CONF.gyr filter perf | GYR_CONF.gyr_noise_perf | PWR_CONF.adv_power_save | Typ. current consumption * depends on ACC_CONF ** depends on GYR_CONF |
|-------------------------------|------------|-----------------|-----------------|--------------------------|--------------------------|-------------------------|-------------------------|-----------------------------------------------------------------------|
| Suspend (lowest power         | er mode)   | 0               | 0               | Х                        | Χ                        | Х                       | 1                       | 3.5 μΑ                                                                |
| Configuration mode            |            | 0               | 0               | Х                        | Х                        | Х                       | 0                       | 120 μΑ                                                                |
|                               | Accel only | 1               | 0               | 0                        | Х                        | Х                       | 4                       | Down to 4 μA*                                                         |
| Low power mode                | Gyro only  | 0               | 1               | Х                        | 0                        | 0                       | l                       | Down to 400 μA**                                                      |
|                               | IMU        | 1               | 1               | 0                        | 0                        | 0                       |                         | Down to 420 μA* **                                                    |
|                               | Accel only | 1               | 0               | 1                        | Х                        | Х                       |                         | 210 μΑ                                                                |
| Normal mode                   | Gyro only  | 0               | 1               | Х                        | 1                        | 0                       | Х                       | 600 μΑ                                                                |
| IMU                           |            | 1               | 1               | 1                        | 1                        | 0                       |                         | 685 μΑ                                                                |
|                               | Accel only | 1               | 0               | 1                        | Х                        | Х                       |                         | 210 μΑ                                                                |
| Performance mode <sup>5</sup> | Gyro only  | 0               | 1               | Х                        | 1                        | 1                       | Х                       | 900 μΑ                                                                |
|                               | IMU        | 1               | 1               | 1                        | 1                        | 1                       |                         | 970 μΑ                                                                |

The power state of the IMU is controlled through the registers <a href="PWR\_CTRL">PWR\_CTRL</a> and <a href="PWR\_CONF">PWR\_CONF</a>. The Register <a href="PWR\_CTRL">PWR\_CONF</a>. The Register <a href="PWR\_CONF">PWR\_CONF</a> controls which power state the sensors enter if they are enabled or disabled in the Register <a href="PWR\_CTRL">PWR\_CTRL</a>. The power state impacts the behavior of the sensor with respect to start-up time, available functions, etc. but not the sensor data quality.

The sensor data quality (e.g. the noise performance and/or the filter characteristics) is controlled in the Register ACC CONF and Register GYR CONF. In all global power configurations both register contents and FIFO contents are retained.

Modifications reserved | Data subject to change without notice

<sup>&</sup>lt;sup>5</sup> Accelerometer does not differ in normal and performance mode.

Table "Power Modes" above shows how to configure the device for the most relevant power modes. But any other combination of the shown register settings is allowed. These registers are described as follows:

<u>PWR\_CTRL</u>: used to enable and disable sensors (accelerometer, gyroscope, auxiliary, and temperature). Per default, all sensors are disabled.

PWR CTRL.acc\_en: enable or disable the accelerometer in all power modes.

PWR\_CTRL.gyr\_en: enable or disable the gyroscope in all power modes.

ACC CONF.acc filter perf: enable or disable aliasing<sup>6</sup> free acceleration sensing.

GYR\_CONF.gyr\_filter\_perf: enable or disable aliasing<sup>6</sup> free yaw rate sensing.

GYR CONF.gyr noise perf: enable or disable low noise mode for precision yaw rate sensing.

<u>PWR CONF.adv power save</u>: enable or disable the advanced power save configuration. If the device is configured for accelerometer only operation and <u>ACC CONF.acc filter perf</u>=0b0 or all sensors are disabled, there is a potential for additional (maximal) power saving. If the configuration is set by <u>PWR CONF.adv power\_save</u>=0b1, the devices internally reduces the power consumption always to a minimum without compromising data quality defined by the performance parameters set above at the expense of these restrictions which apply:

- ▶ Register writes need an inter-write-delay of at least 450 µs, see Section 6 for details.
- ► The sensors log data into the FIFO in all power modes. The user needs to disable advanced power save mode (<a href="PWR\_CONF.adv\_power\_save">PWR\_CONF.adv\_power\_save</a>=0b0), respect the timing constraints in Sections 6.4 and 6.5 before reading the FIFO.

If <u>PWR\_CONF.adv\_power\_save</u>=0b0 the device is accessible without the restrictions of the advanced power save configuration after 450 μs.

-

<sup>&</sup>lt;sup>6</sup> An effect that causes different signals to become indistinguishable when sampled with low ODR's.

#### 4.6 Sensor Data

#### 4.6.1 Accelerometer Data

The width of acceleration data is 16 bits given in two's complement representation in the registers <u>DATA\_8</u> to <u>DATA\_13</u>. The 16 bits for each axis are split into an MSB upper part and an LSB lower part. Reading the acceleration data registers shall always start with the LSB part. In order to ensure the integrity of the acceleration data, the content of an MSB register is locked by reading the corresponding LSB register (shadowing procedure).

#### 4.6.2 Accelerometer Filter Settings

The accelerometer digital filter is configured through the Register ACC CONF.

## 4.6.3 Accelerometer Filter Modes

The accelerometer filter modes influence the low pass filter characteristics, in particular the 3dB cutoff frequency, noise, and group delay. The accelerometer filter mode is configured through <a href="ACC\_CONF.acc\_bwp">ACC\_CONF.acc\_bwp</a>. This datasheet describes the device in normal filter mode configuration for <a href="ACC\_CONF.acc\_bwp">ACC\_CONF.acc\_bwp</a>.

#### 4.6.4 Accelerometer Data Processing in Normal and Performance Mode

The data processing for this mode is configured using <u>ACC\_CONF.acc\_filter\_perf</u>=0b1. In this power mode, the accelerometer data is sampled at equidistant points in the time, defined by the accelerometer output data rate parameter <u>ACC\_CONF.acc\_odr</u>. The output data rate can be configured in one of eight different valid ODR configurations going from 12.5 Hz up to 1600Hz.

The characteristics of the implemented low pass filter are described in the following 2 tables:

Table 7: Cutoff freq. of the accelerometer according to ODR, Normal & Performance Mode

| Accelerometer ODR [Hz]                                             | 12.5 | 25 | 50 | 100 | 200 | 400 | 800 | 1600 |
|--------------------------------------------------------------------|------|----|----|-----|-----|-----|-----|------|
| 3dB Cutoff frequency [Hz] normal filter mode ACC_CONF.acc_bwp=0x02 | 5.5  | 11 | 22 | 44  | 89  | 178 | 343 | 740  |

Table 8: Accelerometer noise according to ODR, Normal & Performance Mode, ± 8g range

| ODR in Hz                                                      | 12.5 | 25   | 50   | 100  | 200  | 400  | 800  | 1600 |
|----------------------------------------------------------------|------|------|------|------|------|------|------|------|
| RMS-Noise (typ.) [mg] normal filter mode ACC_CONF.acc_bwp=0x02 | 0.38 | 0.53 | 0.75 | 1.06 | 1.51 | 2.13 | 2.96 | 4.35 |

Table 9: Accelerometer group delay according to ODR, Normal & Performance Mode

| ODR in Hz                                                        | 12.5 | 25 | 50   | 100  | 200 | 400 | 800 | 1600 |
|------------------------------------------------------------------|------|----|------|------|-----|-----|-----|------|
| Group Delay (typ.) [ms] normal filter mode ACC_CONF.acc_bwp=0x02 | 80   | 40 | 20.5 | 10.5 | 5.4 | 2   | 1.3 | 0.6  |

#### 4.6.5 Accelerometer Data Processing in Low Power Mode

Low power mode can be enabled by <u>PWR\_CONF.adv\_power\_save</u>=0b1 and <u>ACC\_CONF.acc\_filter\_perf</u>=0b0. In this power mode, the accelerometer regularly changes between an idle phase where no measurement is performed and an active phase, where data is acquired. The period of the duty cycle for changing between active and idle mode will be determined by the output data rate (<u>ACC\_CONF.acc\_odr</u>). In low power mode, the output data rate can be configured in one of 10 different valid ODR configurations going from 0.78Hz up to 400Hz.

The samples acquired during the active phase will be averaged and the result will be the output data. The number of averaged samples can be determined by the parameter ACC CONF.acc bwp through the following formula:

averaged samples = 2<sup>(Val(acc\_bwp))</sup> skipped samples = (1600/ODR)-averaged samples

A higher number of averaged samples will result in a lower noise level of the signal. Since the active phase is increased, the power consumption will also rise.

#### 4.6.6 Accelerometer Data Ready Interrupt

This interrupt fires whenever a new data sample set from accelerometer is available in Registers <u>DATA\_8</u> to <u>DATA\_13</u>. This allows a low latency data readout. In non-latched mode, the interrupt are cleared automatically after 1/(6400Hz). If this automatic clearance is unwanted, please use latched mode (see Section 4.9). The flag <u>INT\_STATUS\_1</u> acc\_drdy\_int is cleared when the register <u>INT\_STATUS\_1</u> is read. The flag <u>STATUS.drdy\_acc</u> is cleared when any of the Registers <u>DATA\_8</u> to <u>DATA\_13</u> is read.

To enable the data ready interrupt please map it on the desired INT pin via INT MAP DATA.

#### 4.6.7 Gyroscope Data

The width of gyroscope data is 16 bits given in two's complement representation in the registers <u>DATA\_14</u> to <u>DATA\_19</u>. The 16 bits for each axis are split into an MSB upper part and an LSB lower part. Reading the gyroscope data registers shall always start with the LSB part. In order to ensure the integrity of the gyroscope data, the content of an MSB register is locked by reading the corresponding LSB register (shadowing procedure).

# 4.6.8 Gyroscope Filter Settings

The gyroscope digital filter can be configured through the Register GYR CONF.

#### 4.6.9 Gyroscope Filter Modes

The gyroscope filter modes influence the low pass filter characteristics, in particular the 3dB cutoff frequency, noise, and group delay. The gyroscope filter mode is configured through <u>GYR\_CONF.gyr\_bwp</u>. This datasheet describes the device in normal filter mode configuration for <u>GYR\_CONF.gyr\_bwp</u>=0x02.

#### 4.6.10 Gyroscope Data Post-Processing

For optimal gyroscope CAS performance the following data post-processing step is necessary:

 $Rate_x = DATA_15 << 8 + DATA_14 - GYR_CAS.factor_zx * (DATA_19 << 8 + DATA_18) / 29$ 

Rate<sub>y</sub> =  $DATA_17 << 8 + DATA_16$ 

Rate<sub>z</sub> = DATA 19 < 8 + DATA 18

Note: <u>GYR\_CAS.factor\_zx</u> is a 7-bit two-complement encoded signed value, if you do not use Bosch Sensortec sensor API, please make sure that you implement sign extension.

#### 4.6.11 Gyroscope Data Processing in Normal and Performance Mode

The data processing for these modes is configured using <u>GYR\_CONF.gyr\_filter\_perf</u>=0b1. In these power modes, the gyroscope data is sampled at equidistant points in the time, defined by the gyroscope output data rate parameter <u>GYR\_CONF.gyr\_odr</u>. The output data rate can be configured in one of eight different valid ODR configurations going from 25 Hz up to 3.2 kHz. For 6.4 kHz operation use FIFO data readout described in section 4.7.

The characteristics of the implemented low pass filter are described in the following tables:

Table 10: Cutoff frequency of the gyroscope according to ODR, Normal & Performance Mode

| Gyroscope ODR [Hz]                                                 | 25 | 50 | 100 | 200 | 400 | 800 | 1.6 k | 3.2 k | 6.4 k |
|--------------------------------------------------------------------|----|----|-----|-----|-----|-----|-------|-------|-------|
| 3dB Cutoff frequency [Hz] normal filter mode GYR CONF.gyr bwp=0x02 | 11 | 20 | 39  | 77  | 152 | 300 | 557   | 751   | 712   |

Table 11: Gyroscope noise according to ODR, Normal Mode, ± 2000 dps range

| ODR in Hz                                                        | 25   | 50   | 100  | 200  | 400 | 800 | 1.6 k | 3.2 k | 6.4 k |
|------------------------------------------------------------------|------|------|------|------|-----|-----|-------|-------|-------|
| RMS-Noise (typ.) [mdps] normal filter mode GYR_CONF.gyr_bwp=0x02 | 31.0 | 43.9 | 62.0 | 87.7 | 124 | 176 | 248   | 431   | 500   |

Table 12: Gyroscope noise according to ODR, Performance Mode, ± 2000 dps range

| ODR in Hz                                 | 25   | 50   | 100  | 200  | 400  | 800 | 1.6 k | 3.2 k | 6.4 k |
|-------------------------------------------|------|------|------|------|------|-----|-------|-------|-------|
| RMS-Noise (typ.) [mdps]                   |      |      |      |      |      |     |       |       |       |
| normal filter mode  GYR_CONF.gyr_bwp=0x02 | 21.7 | 30.7 | 43.4 | 61.4 | 86.9 | 123 | 174   | 302   | 350   |

Table 13: Gyroscope group delay according to ODR, Normal and Performance Modes

| ODR in Hz                                                        | 25 | 50   | 100  | 200  | 400  | 800  | 1.6 k | 3.2 k | 6.4 k |
|------------------------------------------------------------------|----|------|------|------|------|------|-------|-------|-------|
| Group Delay (typ.) [ms] normal filter mode GYR CONF.gyr bwp=0x02 | 40 | 20.5 | 10.8 | 5.97 | 3.55 | 2.34 | 0.97  | 0.82  | 0.68  |

#### 4.6.12 Gyroscope Data Processing in Low Power Mode

Low power mode can be enabled by <u>PWR\_CONF.adv\_power\_save</u>=0b1 and <u>GYR\_CONF.gyr\_filter\_perf</u>=0b0. In this power mode, the gyroscope regularly changes between an idle phase where no measurement is performed and an active phase, where data is acquired. The period of the duty cycle for changing between active and idle mode will be determined by the output data rate (<u>GYR\_CONF.gyr\_odr</u>). The output data rate can be configured in one of 3 different valid ODR configurations 25Hz, 50Hz, and 100Hz.

Four samples are acquired during the active phase and will be averaged and the result will be the output data.

#### 4.6.13 Gyroscope Data Ready Interrupt

This interrupt fires whenever a new data sample set from the gyroscope is available in Registers <u>DATA 14</u> to <u>DATA 19</u>. This allows a low latency data readout. In non-latched mode, the interrupt are cleared automatically after 1/(6400Hz). If this automatic clearance is unwanted, please use latched mode (see Section 4.9). The flag <u>INT\_STATUS\_1.gyr\_drdy\_int</u> is cleared when the register <u>INT\_STATUS\_1</u> is read. The flag <u>STATUS.drdy\_gyr</u> is cleared when any of the Registers <u>DATA\_14</u> to <u>DATA\_19</u> is read.

To enable the data ready interrupt please map it on the desired INT pin via INT MAP DATA.

#### 4.6.14 Temperature Sensor

The temperature sensor has 16 bits defined as:

| Value  | Temperature                |
|--------|----------------------------|
| 0x7FFF | 87 – 1/2 <sup>9</sup> °C   |
|        |                            |
| 0x0000 | 23 °C                      |
|        |                            |
| 0x8001 | -(41-1/2 <sup>9</sup> ) °C |
| 0x8000 | Invalid                    |

The measured temperature is accessible via the Registers <u>TEMPERATURE 0</u> and <u>TEMPERATURE 1</u>. After enabling the temperature sensor, the register contains the invalid value 0x8000 until the first temperature measurement is completed.

If the gyroscope is disabled (i.e. <u>PWR\_CTRL.gyr\_en</u>=0b00, e.g. for accelerometer only operation) the temperature sensor must be manually enabled or disabled using <u>PWR\_CTRL.temp\_en</u>. Disabling the temperature sensor reduces the overall current consumption of the device by approximately 1.8 µA in average. If the temperature sensor is enabled it updates the results aligned with bit 7 of the Register <u>SENSORTIME</u> 1 at an update rate of 0.78 Hz.

If the gyroscope is enabled and <a href="PWR\_CONF.adv">PWR\_CONF.adv</a> power\_save=0b0 and <a href="PWR\_CTRL.gyr">PWR\_CTRL.gyr</a> en=0b1, the temperature in Registers <a href="TEMPERATURE\_0">TEMPERATURE\_0</a> and <a href="TEMPERATURE\_1">TEMPERATURE\_1</a> is updated every 10 ms (±12%), if the gyroscope is in standby mode or fast-power up mode, the temperature is updated every 1.28 s aligned with bit 7 of the Register <a href="SENSORTIME\_1">SENSORTIME\_1</a>.

#### 4.6.15 Sensor Time

The device supports the concept of sensortime. Its core element is a free running counter with a width of 24 bits. It increments with a resolution of 39.0625us. The user can access the current state of the counter by reading registers <a href="SENSORTIME\_0">SENSORTIME\_0</a> to <a href="SENSORTIME\_2">SENSORTIME\_2</a>.

All sensor events e.g. updates of data registers are synchronous to this sensor time register as defined in the table below. With every update of the data register or the FIFO, a bit *m* in the registers <u>SENSORTIME 0</u> to <u>SENSORTIME 2</u> toggles where *m* depends on the output data rate for the data register and the output data rate and the FIFO downsampling rate for the FIFO. The table below shows which bit toggles for which update rate of data register and FIFO:

| Bit m in sensor_time | 23     | 22     | 21    | 20    | 19    | 18    | 17   | 16   |
|----------------------|--------|--------|-------|-------|-------|-------|------|------|
| Resolution [s]       | 327.68 | 163.84 | 81.92 | 40.96 | 20.48 | 10.24 | 5.12 | 2.56 |
| Update rate [Hz]     | 0.0031 | 0.0061 | 0.012 | 0.024 | 0.049 | 0.10  | 0.20 | 0.39 |

| Bit <i>m</i> in sensor_time | 15   | 14   | 13    | 12   | 11   | 10 | 9  | 8   |
|-----------------------------|------|------|-------|------|------|----|----|-----|
| Resolution [ms]             | 1280 | 640  | 320   | 160  | 80   | 40 | 20 | 10  |
| Update rate [Hz]            | 0.78 | 1.56 | 3.125 | 6.25 | 12.5 | 25 | 50 | 100 |

| Bit <i>m</i> in sensor_time | 7   | 6   | 5     | 4     | 3      | 2     | 1     | 0     |
|-----------------------------|-----|-----|-------|-------|--------|-------|-------|-------|
| Resolution [ms]             | 5   | 2.5 | 1.250 | 0.625 | 0.3125 | 0.156 | 0.078 | 0.039 |
| Update rate [Hz]            | 200 | 400 | 800   | 1600  | 3200   |       |       |       |

The sensortime is synchronized with the data capturing in the data register and the FIFO. The sensortime supports multiple seconds of sample counting and a sub-millisecond resolution, see Register SENSORTIME 0 for details.

Burst reads on the registers <u>SENSORTIME\_0</u> to <u>SENSORTIME\_2</u> always deliver consistent values, i.e. the value of the register does not change during the burst read.

#### 4.6.16 Configuration Changes

If device configuration settings in registers <u>ACC\_CONF</u>, <u>ACC\_RANGE</u>, <u>GYR\_CONF</u>, <u>GYR\_RANGE</u>, or <u>AUX\_CONF</u> are changed while the sensors are enabled (accelerometer <u>PWR\_CTRL.acc\_en</u> = 0b1, gyroscope <u>PWR\_CTRL.gyr\_en</u> or auxiliary sensor <u>PWR\_CTRL.aux\_en</u> = 0b1), the configuration changes are not immediately applied. The configuration changes become effective if a sampling event for the currently active ODR coincides with a sampling event for the newly requested ODR on the sensortime sampling grid. In the case where the currently active ODR equals the newly requested ODR, the configuration changes become effective at the next sampling event. See also following figure:



#### **4.7 FIFO**

The device supports the following FIFO operating modes:

- ▶ Streaming mode: overwrites oldest data on FIFO full condition
- ▶ FIFO mode: discards newest data on FIFO full condition

The FIFO size is 2048<sup>7</sup> byte and supports the following interrupts:

- ► FIFO full interrupt
- ► FIFO watermark interrupt

FIFO is enabled for accelerometer data with FIFO CONFIG\_1.fifo acc\_en=0b1, for gyroscope data with FIFO CONFIG\_1.fifo gyr\_en=0b1, and auxiliary interface (e.g. magnetometer) data with FIFO CONFIG\_1.fifo aux\_en=0b1 (0b0=disabled).

The FIFO may be used in all power modes of the device to record data. For readout conditions, see Subsection "FIFO in Low Power Mode".

#### **4.7.1** Frames

The FIFO captures data in frames, which consist in header mode of a header and a payload data, in headerless mode only payload is stored.

In header mode (standard configuration) each regular frame consists of a one byte header describing properties of the frame (e.g. which sensors are included in this frame) and the payload data itself. Beside the regular frames, which contain the sensor data, there are control frames, which contain metadata (e.g. sensortime).

An overview of the possible frame types is show below



\_

<sup>&</sup>lt;sup>7</sup> See Application Note BST-BMI270-AN001 for 6KB FIFO

#### Header mode

The header has a fixed length of 8 bit and the following format:

| Bit     | 7           | 6           | 5            | 4 | 3 | 2 | 1           | 0 |
|---------|-------------|-------------|--------------|---|---|---|-------------|---|
| Content | fh_mode<1:0 | <b>&gt;</b> | fh_parm<3:0: | > |   |   | fh_ext<1:0> |   |

These fh\_mode and fh\_parm and fh\_ext fields are defined below

| fh_mode<1:0>  | Definition    | fh_parm <3:0>   | fh_ext<1:0>          |
|---------------|---------------|-----------------|----------------------|
| 0b10          | Regular frame | Enabled sensors | Tag of INT2 and INT1 |
| 0b01          | Control frame | Control opcode  |                      |
| 0b00 and 0b11 | Reserved      | N/A             |                      |

fh\_parm=0b0000 is invalid for regular mode, a header of 0x80 indicates an uninitialized frame, which is reported if the fifo read operations reads more data, than contained in the fifo. An uninitialized frame contains one byte of payload 0x00.

In a regular frame, fh\_parm parameter defines which sensors are included in the data part of the frame. The format is

| Name    | fh_parm<3:0> |               |               |               |
|---------|--------------|---------------|---------------|---------------|
| Bit     | 3            | 2             | 1             | 0             |
| Content | Reserved     | FIFO_aux_data | FIFO_gyr_data | FIFO_acc_data |

When FIFO\_<sensor x>\_data is 0b1 (0b0) data for sensor x is included (not included) in the data part of the frame.

The fh\_ext<1:0> field are used for external tagging.

The order of the data in the FIFO data frame (see following table) differs from the order defined for the Registers <u>DATA\_0</u> to <u>DATA\_19</u>.

A valid regular frame, contains data of at least one sensor (accelerometer, gyroscope, or auxiliary sensor). Only valid frames will be written into the FIFO. E.g. fh\_parm=0b0111 in the header of a frame will result in the data layout shown below.

| DATA[X] | Acronym           |                                                                      |
|---------|-------------------|----------------------------------------------------------------------|
| X=0     | AUX_0             | copy of register Val(AUX_RD_ADDR) in auxiliary sensor register map   |
| X=1     | AUX_1             | copy of register Val(AUX_RD_ADDR)+1 in auxiliary sensor register map |
| X=2     | AUX_2             | copy of register Val(AUX_RD_ADDR)+2 in auxiliary sensor register map |
| X=3     | AUX_3             | copy of register Val(AUX_RD_ADDR)+3 in auxiliary sensor register map |
| X=4     | AUX_4             | copy of register Val(AUX_RD_ADDR)+4 in auxiliary sensor register map |
| X=5     | AUX_5             | copy of register Val(AUX_RD_ADDR)+5 in auxiliary sensor register map |
| X=6     | AUX_6             | copy of register Val(AUX_RD_ADDR)+6 in auxiliary sensor register map |
| X=7     | AUX_7             | copy of register Val(AUX_RD_ADDR)+7 in auxiliary sensor register map |
| X=8     | GYR_X<7:0> (LSB)  |                                                                      |
| X=9     | GYR_X<15:8> (MSB) |                                                                      |
| X=10    | GYR_Y<7:0> (LSB)  |                                                                      |
| X=11    | GYR_Y<15:8> (MSB) |                                                                      |
| X=12    | GYR_Z<7:0> (LSB)  |                                                                      |
| X=13    | GYR_Z<15:8> (MSB) |                                                                      |
| X=14    | ACC_X<7:0> (LSB)  |                                                                      |
| X=15    | ACC_X<15:8> (MSB) |                                                                      |
| X=16    | ACC_Y<7:0> (LSB)  |                                                                      |
| X=17    | ACC_Y<15:8> (MSB) |                                                                      |
| X=18    | ACC_Z<7:0> (LSB)  |                                                                      |
| X=19    | ACC_Z<15:8> (MSB) |                                                                      |

The length of the auxiliary sensor data block in a FIFO frame depends on the configured burst read length of the auxiliary interface in Register AUX\_IF\_CONF.aux\_rd\_burst:

If the read burst length for the auxiliary sensor is configured to less than 8 byte, the number of data bytes in the regular FIFO frame is reduced accordingly. I.e. in the above example, the gyro data would start before Byte 8.

#### Control frames

Control frames are only supported in header mode. There are a number of control frames defined through the fh\_parm field. These are shown in below.

A skip frame indicates the number of skipped frames after a FIFO overrun occurred. A sensortime frame contains the sensortime when the last sampled frame stored in the FIFO is read. A FIFO input config frames indicates a change in sensor configuration which affects the sensor data.

The FIFO fill level is contained in registers <u>FIFO\_LENGTH\_1.fifo\_byte\_counter\_13\_8</u> and <u>FIFO\_LENGTH\_0.fifo\_byte\_counter\_7\_0</u>. The fifo fill level includes the space needed for the regular and the control frames, with the exception of the sensortime frame.

| fh_mode<3:0> | Definition              | Number of       |
|--------------|-------------------------|-----------------|
| 0x0          | Skip Frame              | 1 byte payload  |
| 0x1          | Sensortime Frame        | 3 bytes payload |
| 0x2          | Fifo_Input_Config Frame | 4 bytes payload |
| 0x3 - 0x7    | Reserved                |                 |

#### Skip Frame (fh parm=0x0)

In the case of FIFO overflows, a skip\_frame is prepended to the FIFO content, when read out next time. The data for the frame consists of one byte and contains the number of skipped frames. When more than 0xFF frames have been skipped, 0xFF is returned. A skip frame is expected always as first frame in a FIFO read burst. A skip frame does not consume memory in the FIFO.

#### Sensortime Frame (fh parm=0x1)

The data for the sensortime frame is a copy of the Register <u>SENSORTIME\_0</u> to <u>SENSORTIME\_2</u> when the last byte of the last sample frame was read. One sensortime frame is always expected as last frame in the FIFO. A sensortime frame is only sent if the FIFO becomes empty during the burst read. A sensortime frame does not consume memory in the FIFO. Sensortime frames are enabled (disabled) by setting <u>FIFO CONFIG\_0.fifo\_time\_en</u> to 0b1 (0b0).

#### Fifo Input Config Frame (fh parm=0x2)

Whenever the filter configuration of the FIFO input data sources changes, a FIFO input config frame is inserted into the FIFO, before the configuration change becomes active. E.g. when the bandwidth for the accelerometer filter is changed in Register ACC\_CONF, a FIFO input config frame is inserted before the first frame with accelerometer data with the new bandwidth configuration. The FIFO input config frame contains four byte of data with the format

| Bit    | 7                                                | 6                                                | 5     | 4       | 3        | 2       | 1        | 0       |  |
|--------|--------------------------------------------------|--------------------------------------------------|-------|---------|----------|---------|----------|---------|--|
| Byte 0 | reserved                                         | reserved                                         | aux_  | aux_    | gyr_     | gyr_    | acc_     | acc_    |  |
|        |                                                  |                                                  | if_ch | conf_ch | range_ch | conf_ch | range_ch | conf_ch |  |
| Byte 1 | Sensortime                                       | Sensortime _0 for next frame (may be drop frame) |       |         |          |         |          |         |  |
| Byte 2 | Sensortime_                                      | Sensortime_1 for next frame (may be drop frame)  |       |         |          |         |          |         |  |
| Byte 3 | Sensortime _2 for next frame (may be drop frame) |                                                  |       |         |          |         |          |         |  |

| aux_if_ch   | A write to Register AUX_IF_CONF, AUX_RD_ADDR, or AUX_WR_ADDR becomes active. |
|-------------|------------------------------------------------------------------------------|
| aux_conf_ch | A write to Register AUX_CONF becomes active.                                 |

| gyr_range_ch | A write to Register GYR_RANGE becomes active.                   |
|--------------|-----------------------------------------------------------------|
| gyr_conf_ch  | A write to Register GYR_CONF or gyr_FIFO_filt_data              |
|              | or gyr_FIFO_downsampling in Register FIFO_DOWNS becomes active. |
| acc_range_ch | A write to Register ACC_RANGE becomes active.                   |
| acc_conf_ch  | A write to Register ACC CONF or acc_FIFO_filt_data              |
|              | or acc_FIFO_downsampling in Register FIFO_DOWNS becomes active. |

If Byte 0 is 0x00, this indicates that this Fifo\_Input\_Config Frame is written, because the fifo or sensor was enabled.

## Headerless mode

When the data rates of all enabled sensor elements are identical, the FIFO header may be disabled in FIFO CONFIG 1.fifo header en.

The headerless mode supports only regular frames. To be able to distinguish frames from each other, all frames must have the same size. For this reason, any change in configuration that have an impact to frame size or order of data within a frame will cause an instant flush of FIFO, restarting capturing of data with the new settings.

If the auxiliary sensor interface is enabled, the number of auxiliary sensor bytes in a FIFO frame is always <u>AUX\_IF\_CONF.aux\_rd\_burst</u> bytes (see section 4.10). If the burst length is less than 4, the device will pad the values read form the auxiliary sensor to 4 bytes. E.g. if <u>AUX\_IF\_CONF.aux\_rd\_burst</u>=0b01 (2 Bytes), a frame with auxiliary sensor, accelerometer, and gyroscope data will look like

| DATA[X] | Acronym           |                                                                            |
|---------|-------------------|----------------------------------------------------------------------------|
| X=0     | AUX_0             | copy of register Val(AUX RD ADDR.read addr) in auxiliary sensor register   |
|         |                   | map                                                                        |
| X=1     | AUX_1             | copy of register Val( <u>AUX_RD_ADDR.read_addr</u> +1) in auxiliary sensor |
|         |                   | register map                                                               |
| X=2     | Padding byte      | Undefined value                                                            |
| X=3     | Padding byte      | Undefined value                                                            |
| X=4     | GYR_X<7:0> (LSB)  |                                                                            |
| X=5     | GYR_X<15:8> (MSB) |                                                                            |
| X=6     | GYR_Y<7:0> (LSB)  |                                                                            |
| X=7     | GYR_Y<15:8> (MSB) |                                                                            |
| X=8     | GYR_Z<7:0> (LSB)  |                                                                            |
| X=9     | GYR_Z<15:8> (MSB) |                                                                            |
| X=10    | ACC_X<7:0> (LSB)  |                                                                            |
| X=11    | ACC_X<15:8> (MSB) |                                                                            |
| X=12    | ACC_Y<7:0> (LSB)  |                                                                            |
| X=13    | ACC_Y<15:8> (MSB) |                                                                            |
| X=14    | ACC_Z<7:0> (LSB)  |                                                                            |
| X=15    | ACC_Z<15:8> (MSB) |                                                                            |

#### 4.7.2 Conditions and Details

#### FIFO frame reads

If a frame is fully read through the Register FIFO\_DATA, it gets deleted from the FIFO of the device. If a frame is only partially read it will be repeated completely with the next access both in headerless and in header mode. In headermode, this includes the header. In the case of a FIFO overflow between the first partial read and the second read attempt, the frame is kept only if FIFO\_CONFIG\_0.fifo\_stop\_on\_full =0b1.

#### FIFO overreads

When more data are read from the FIFO than it contains valid data, 0x8000 is returned in headerless mode. In header mode 0x80 indicates an invalid frame.

#### Frame rates

The frame sampling rate of the FIFO is defined by the maximum output data rate of the sensors enabled for FIFO sampling. The FIFO sampling configuration is set in register <u>FIFO CONFIG 0</u> to <u>FIFO CONFIG 1</u>. It is possible to select filtered or pre-filtered data as an input to the FIFO. If pre-filtered data is selected in register <u>FIFO DOWNS.acc fifo filt data</u> for the accelerometer, the sample rate is 1600 Hz. If pre-filtered data is selected in register <u>FIFO DOWNS.gyr fifo filt data</u> for the gyroscope, the sample rate is 6400 Hz. The range of the pre-filtered gyroscope data is defined by <u>GYR RANGE.ois range</u> and independent of the range configured for the data register and filtered data in the fifo defined by <u>GYR RANGE.gyr range</u>. The input data rate to the FIFO can be reduced by selecting a down-sampling factor 2<sup>k</sup> in registers <u>FIFO DOWNS.acc fifo downs</u> or <u>FIFO DOWNS.gyr fifo downs</u> where k={0..7}.

#### FIFO overflow

In the case of an overflow the FIFO can either stop recording data or overwrite the oldest data. The behavior is controlled by Register FIFO CONFIG 0.fifo stop on full. If FIFO CONFIG 0.fifo stop on full =0b0, the FIFO logic may delete the oldest frames. If header mode is enabled and the free FIFO space falls below the maximum size frame, the skip frame is the prepended at the next FIFO readout.

If FIFO\_CONFIG\_0.fifo\_stop\_on\_full =0b1, the newest frame may be discarded, if the free FIFO space falls below the maximum size frame. If header mode is enabled, a skip frame is prepended at the next FIFO readout (which is **not** the position where the frame(s) have been discarded).

During a FIFO read operation of the host, no data at the FIFO tail may be dropped. If the host reads the FIFO with a slower rate than it is filled, it may happen that the sensor needs to drop new data, even when FIFO CONFIG 0.fifo stop on full =0b0. These events are recorded in the Register ERR\_REG.fifo\_err.

# 4.7.3 FIFO data synchronization

All sensor data are sampled with respect to a common ODR time grid. Even if a different ODR is selected for the acceleration and the auxiliary sensor the data remains synchronized:

If a frame contains a sample from a sensor element with ODR x, then it must contain also samples of all sensor elements with an ODR y>=x. This applies for steady state operation. In transition phases, it is more important not to lose data, therefore exceptions are possible if the sensor elements with ODR y>=x do not have data, e.g. due to a sensor configuration change.

FIFO Data Synchronization Scheme in the following figure illustrates the steady state and transient operating conditions.



# 4.7.4 FIFO synchronization with external events

External events at the INT<x> pin may be synchronized into the FIFO data. For this operation mode the FIFO CONFIG\_1.fifo tag int<x>1 en and INT<x> IO CTRL.input en need to be enabled. The fh\_ext field in FIFO header of a regular frame will then be set according to an event at the INT<x> pin. If FIFO CONFIG\_1.fifo tag int<x> en is configured to int\_level, the value of the INT<x> pin at the time when the FIFO regular frame is written is copied into the fh\_ext field. If FIFO CONFIG\_1.fifo tag int<x> en is configured to int\_edge, the corresponding bit in the fh\_ext field of a regular frame will be set, if a positive edge of a pulse of minimum length 10ns on the INT<x> pin occured in the sampling interval before this frame is written into the FIFO. E.g. if the ODR is set to 100 Hz and the fh\_ext field in FIFO header is set, then in the 10 ms before the regular frame was written into FIFO an positive edge occurred at the INT<x> pins.

## 4.7.5 FIFO Interrupts

The FIFO supports two interrupts, a FIFO full interrupt and a watermark interrupt:

- ► The FIFO full interrupt is issued when the FIFO fill level is above the full threshold. The full threshold is reached just before the last two frames are stored in the FIFO.
- ► The FIFO watermark is issued when the FIFO fill level is equal or above a watermark defined in Register FIFO WTM 1.fifo water mark 12 8.

In order to enable/use the FIFO full or watermark interrupts, map them on the desired interrupt pin via INT MAP DATA.

Latched FIFO interrupts will only be cleared, if the status register gets read and the fill level is below the corresponding FIFO interrupt (full or watermark).

## 4.7.6 FIFO Reset

The user can trigger a FIFO reset by writing the command fifo\_flush (0xB0) in <u>CMD</u>. Automatic resets are only performed in the following cases:

- ▶ A sensor is enabled or disabled in headerless mode
- ▶ A transition between headerless and headermode or vice versa has occurred.
- ▶ Size of auxiliary sensor data in a frame changed in header or headerless mode

#### 4.7.7 FIFO in Low Power Mode

In the low power mode the device supports FIFO usage. The data storage into the FIFO is identical to the normal and performance mode, for the readout the description below applies:

- ► If <u>PWR\_CONF.fifo\_self\_wakeup</u>=0b0 the advanced power save configuration needs to be disabled (<u>PWR\_CONF.adv\_power\_save=0b0</u>) before reading out FIFO data.
- ▶ If <a href="PWR\_CONF.fifo\_self\_wakeup">PWR\_CONF.fifo\_self\_wakeup</a>=0b1 and the FIFO watermark or FIFO full interrupt is triggered, the restriction for <a href="PWR\_CONF.adv">PWR\_CONF.adv</a> power <a href="save">save</a>=0b1 (see Section 4.5) do not apply as long as a single burst read on Register <a href="FIFO\_DATA">FIFO\_DATA</a> completes. This may be used to read the complete FIFO with one single burst read without leaving low power mode. Without a FIFO watermark interrupt or full interrupt, the advanced power save configuration needs to be disabled (PWR\_CONF.adv\_power\_save=0b0) before reading out FIFO data.

## 4.8 Advanced Features

# 4.8.1 Global Configuration

The configuration of the interrupt feature engine is described in the Registers <u>FEATURES</u>. These registers are partitioned into several pages, the page valid for the next read or write to the Registers <u>FEATURES</u> is selected by the Register <u>FEAT\_PAGE.page</u>. Writes to a <u>FEATURES</u> register must be 16-bit word oriented, i.e. writes should start at an even address (2m) and the last byte written should be at an odd address (2n+1), where 0x30<=2m<=2n<0x3F. If the write start address is less than 0x30 the write may start at any address (see example 4 below), if the end address is greater than 0x3F, it may stop at any address (see example 5 below).

- ► For register writes which stop at an even SPI address (2n), the data at the odd SPI address (2n+1) are undefined (see Example 2, 3 below)
- ► For writes which start at an odd SPI address (2m+1), the data at the even address (2m) are undefined. (see Example 3 below)

Ex. 1) Write 4 bytes starting at address 0x30

| Valid Data |
|------------|
| Valid Data |
| Valid Data |
| Valid Data |
|            |

Ex. 2) Write 3 bytes starting at address 0x30

| 0x30 | Valid Data |
|------|------------|
| 0x31 | Valid Data |
| 0x32 | Valid Data |
| 0x33 | Undefined  |

Ex. 3) Write 2 bytes starting at address 0x31

| 0x30 | Undefined  |
|------|------------|
| 0x31 | Valid Data |
| 0x32 | Valid Data |
| 0x33 | Undefined  |

Ex. 4) Write 9 bytes starting at address 0x29

| 0x29 | Valid Data |
|------|------------|
| 0x2A | Valid Data |
|      |            |
| 0x2E | Valid Data |
| 0x2F | Valid Data |
| 0x30 | Valid Data |
| 0x31 | Valid Data |
|      |            |

Ex. 5) Write 5 bytes starting at address 0x3E

| 0x3E | Valid Data |
|------|------------|
| 0x3F | Valid Data |
| 0x40 | Valid Data |
| 0x41 | Valid Data |
| 0x42 | Valid Data |
|      |            |

Make sure the sensor is initialized properly before the feature configuration is performed (see description in section 4.4.)

Some features generate interrupts. <a href="INT1\_MAP\_FEAT">INT1\_MAP\_FEAT</a> and <a href="INT2\_MAP\_FEAT">INT2\_MAP\_FEAT</a> configure these features. <a href="INT\_STATUS\_0">INT\_STATUS\_0</a> reports the interrupt source.

In order to minimize the power consumption or to enable always-on motion sensing, all advanced features (algorithms) rely on accelerometer data samples.

#### Minimum Bandwidth Settings

If the filter performance of the accelerometer is configured to high performance (<u>ACC\_CONF.acc\_filter\_perf</u> is 0b1), the features operate at highest performance independent of the ODR and the bandwidth set by the host.

If the filter performance of the accelerometer is configured to low power (<u>ACC\_CONF.acc\_filter\_perf</u> is 0b0), the feature performance is depending on the ODR and the averaging factor (<u>ACC\_CONF.acc\_bwp</u>) set by the host. The ODR must be set to minimum 50 Hz.

If the device configuration does not meet the minimum requirements, the corresponding flag in the Register <a href="INTERNAL STATUS">INTERNAL STATUS</a> is set, if one of the advanced features is enabled. In this case the features are still evaluated, the same number of samples are evaluated, but they are sampled at the lower rate.

#### **Error Interrupts**

The device supports an error interrupt, which triggers if the device cannot be recovered without a soft reset or a POR. This error interrupt is enabled through <a href="INT\_MAP\_DATA">INT\_MAP\_DATA</a>. The interrupt status is available in <a href="INT\_STATUS\_1.err\_int">INT\_STATUS\_1.err\_int</a>. After restarting a device reinitialization must be done.

#### Axis remapping for interrupt features

If the coordinate system of the end device differs from the sensor coordinate system described in Section 8.2 the sensor axis must be remapped to use the orientation dependent features (e.g. orientation interrupt, flat interrupt) properly.

Axis remapping register allows the host to freely map individual axis to the coordinate system of the used platform. Individual axis can be mapped to any other defined axis. The sign value of the axis can be also configured. For example x axis can be mapped to -x axis, +y axis, -y axis, +z axis or -z axis. Similarly, other axes also have their own combinations.

Invalid remappings are signaled through the register <a href="INTERNAL\_STATUS.axes\_remap\_error">INTERNAL\_STATUS.axes\_remap\_error</a> if an advanced feature is enabled.

#### Note:

The axis remapping applies only to the data fetched into the features. The <u>DATA\_0</u> to <u>DATA\_13</u> registers and FIFO are not affected and should be remapped accordingly on the driver level.

#### Configuration settings:

- 1. <u>GEN\_SET\_1.map\_x\_axis</u> describes which axis shall be mapped to x axis.
- 2. GEN SET 1.map x axis sign describes whether the mapped axis shall be inverted or not to be inverted.
- 3. GEN\_SET\_1.map\_y\_axis describes which axis shall be mapped to y axis.
- 4. GEN\_SET\_1.map\_y\_axis\_sign describes whether the mapped axis shall be inverted or not to be inverted.
- 5. GEN SET 1.map z axis describes which axis shall be mapped to z axis.
- 6. GEN\_SET\_1.map\_z\_axis\_sign describes whether the mapped axis shall be inverted or not to be inverted.

# 4.8.2 Anymotion Detection

The anymotion detection uses the slope between two acceleration signals to detect changes in motion. The interrupt is configured by setting enable flag <u>ANYMO\_2.enable</u> along with at least one of the following flags: <u>ANYMO\_1.select\_x</u>, <u>ANYMO\_1.select\_y</u>, and <u>ANYMO\_1.select\_z</u> respectively for each axis.

It generates an interrupt when the absolute value of the slope (the difference between two accelerations) exceeds the preset <u>ANYMO\_2.threshold</u> for a certain number of consecutive data points <u>ANYMO\_1.duration</u>.

The slope (difference) is being computed between the current acceleration sample and the reference sample. The reference sample is updated while the anymotion is detected; basically this means the reference is the last state when sensor detected anymotion.

The interrupt generated will be reset as soon as the slope value falls below the threshold.

## Configuration settings

- 1. <u>ANYMO\_2.enable</u> enable the feature.
- 2. <u>ANYMO 1.duration</u> the number of consecutive data points for which the threshold condition must be respected, for interrupt assertion.
- 3. ANYMO\_2.threshold the slope threshold.
- 4. ANYMO 1.select x select the feature for x axis
- 5. ANYMO 1.select y select the feature for y axis
- 6. ANYMO 1.select z select the feature for z axis

#### Output

INT\_STATUS\_0.any\_motion\_out - Set to 1 when shake interrupt is generated by the device



Figure 1: Any-motion detection

## 4.8.3 Nomotion Detection

The interrupt is configured by setting enable flag <u>NOMO 2.enable</u> along with at least one of the following flags: <u>NOMO\_1.select\_x</u>, <u>NOMO\_1.select\_y</u>, and <u>NOMO\_1.select\_z</u> respectively for each axis.

Nomotion Detection interrupt is generated when the slope on all selected axis remains smaller than a programmable <a href="NOMO\_2.threshold">NOMO\_2.threshold</a> for a programmable time. The signals and timings relevant to the nomotion interrupt functionality are depicted in the figure below.

Register <u>NOMO 1.duration</u> defines the number of consecutive slope data points of the selected axis which must stay under the threshold for an interrupt to be asserted.

## Configuration settings

- 1. NOMO\_2.enable enable the feature.
- 2. <u>NOMO\_1.duration</u> the number of consecutive data points for which the threshold condition must be respected, for interrupt assertion.
- 3. NOMO 2.threshold the slope threshold.
- 4. NOMO\_1.select\_x select the feature for x axis
- 5. NOMO 1.select y select the feature for y axis
- 6. NOMO 1.select z select the feature for z axis

## Output

INT\_STATUS\_0.no\_motion\_out - Set to 1 when shake interrupt is generated by the device



Figure 2: No-motion detection

# 4.8.4 Significant Motion Detection

The significant motion interrupt implements the interrupt required for motion detection in Android 4.3 and greater: https://source.android.com/devices/sensors/sensor-types.html#significant motion.

A significant motion is a motion due to a change in the user location.

Examples of such significant motions are walking or biking, sitting in a moving car, coach or train, etc. Examples of situations that does typically not trigger significant motion include phone in pocket and person is stationary or phone is at rest on a table which is in normal office use.

#### Configuration settings

- 1. SIGMO 2.enable indicates if this feature is enabled or not.
- 2. <u>SIGMO 1.block size</u> Defines the duration after which the significant motion interrupt is triggered. It is expressed in 50 Hz samples (20 ms). Default value is 0xFA=5sec.

## 4.8.5 Activity and Activity Change Recognition

The device can detect simple user activities (unknown, still, walking, running) and can send an interrupt if those are changed, e.g. from walking to running or vice versus. The interrupt is shared with step detector/step counter watermark interrupts and can be configured independently of all other interrupts to any of the interrupt lines.

- 1. The device reports changes for following activity changes by an interrupt
  - 1) Still 0
  - 2) Walking 1
  - 3) Running -2
  - 4) Unknown 3
- 2. Activity interrupt will be triggered only when there is change in status
- 3. ACT OUT.act out reports the activity status

During power on, activity will be unknown (0x03) and the device receives an activity change interrupt once activity is enabled, and a new activity detected. When activity is disabled, status will be changed to unknown.

#### Configuration settings

1. SC 26.en activity – indicates if the activity feature is enabled or not

# 4.8.6 Wrist Wear Wakeup

Wrist wear wakeup feature is designed to detect any natural way of user moving the hand to see the watch dial when wearing a classical wrist watch. The feature is intended to be used as wakeup gesture (i.e. for triggering screen-on or screen-off) in wrist wearable devices.

This feature has dependency on the device orientation in the user system. Implementation of the feature to detect gesture assumes that the sensor co-ordinate frame is aligned with the device/system co-ordinate frame. The assumed default device/system co-ordinate frame is depicted below. Please refer to section 4.8.1 for details about axis remapping



Figure 3: Device co-ordinate system assumed for gesture detection

The feature can distinguish if the device is in one of the following two positions:

- ► Focus position: In this position, the arm in-front of the body and the user should be able to comfortably look at the watch dial.
- ▶ Non-focus position: In this position, the user is not able to look at the watch dial.

WR WAKEUP 3.min angle nonfocus and WR WAKEUP 2.min angle focus can be used to adjust the angle change needed to detect a wrist wear wakeup gesture. WR WAKEUP 4.max tilt Ir, WR WAKEUP 5.max tilt II, WR WAKEUP 6.max tilt pd and WR WAKEUP 7.max tilt pu can be used to define the maximum tilt angle within which device will still remain in focus position.

Table 14: Positive use-case scenarios for the wrist wear wakeup gestures

| Environment        | Scenario            | Device initial position     | User movement                                  |
|--------------------|---------------------|-----------------------------|------------------------------------------------|
| Outdoor / Indoor / | Walking             | Arm swinging / hand in      | Lifts and brings the arm in-front of the body  |
| train / bus        |                     | pocket                      | to be able to comfortably look at the watch    |
|                    |                     |                             | dial                                           |
| Outdoor / Indoor   | Walking / Running / | Arm swinging                | Lift and bring the arm in-front of the body to |
|                    | Jogging             |                             | be able to comfortably look at the watch dial  |
| Outdoor / Indoor / | Sitting / Standing  | Arm is down on side of      | Lifts and brings the arm in-front of the body  |
| train / bus        |                     | the body / hand in pocket   | to be able to comfortably look at the watch    |
|                    |                     |                             | dial                                           |
|                    |                     | Arm is in-front of the body | Rolls the wrist towards the user to look at    |
|                    |                     |                             | the watch dial                                 |
| Indoor / train     | Working with        | Arm on table or arm rest    | Rolls the wrist towards the user to look at    |
|                    | computer            |                             | the watch dial                                 |

#### Configuration Settings

- ► WR\_WAKEUP\_1.enable Enables the feature.
- ▶ <u>WR\_WAKEUP\_2.min\_angle\_focus</u> Cosine of minimum expected attitude change of the device within 1 second time window when moving within focus position.
- ► <u>WR WAKEUP 3.min angle nonfocus</u> Cosine of minimum expected attitude change of the device within 1 second time window when moving from non-focus to focus position.
- ▶ <u>WR\_WAKEUP\_4.max\_tilt\_Ir</u> Sine of the maximum allowed downward tilt angle in landscape right direction of the device, when it is in focus position (i.e. user is able to comfortably look at the dial of wear device).
- ▶ <u>WR\_WAKEUP\_5.max\_tilt\_II</u> Sine of the maximum allowed downward tilt angle in landscape left direction of the device, when it is in focus position (i.e. user is able to comfortably look at the dial of wear device).
- ▶ <u>WR\_WAKEUP\_6.max\_tilt\_pd</u> Sine of the maximum allowed backward tilt angle in portrait down direction of the device, when it is in focus position (i.e. user is able to comfortably look at the dial of wear device).
- ▶ WR WAKEUP 7.max tilt pu Sine of the maximum allowed forward tilt angle in portrait up direction of the device, when it is in focus position (i.e. user is able to comfortably look at the dial of wear device).

# 4.8.7 Wrist Wear Navigation Gesture Detector

BMI270 is designed for Wear OS by Google™ and features wrist gestures (flick in/out, push arm down/pivot up, wrist jiggle/shake) that help navigate the smartwatch (<a href="https://support.google.com/wearos/answer/6312406?hl=en">https://support.google.com/wearos/answer/6312406?hl=en</a>)

Flick in/out





Flick-in movement

Flick-out movement

Figure 4: Flick-in/out movement

For flick-in detection, the user must slowly turn the wrist away from the body (i.e. roll-out shown with a light-grey arrow) and then quickly bring it back (i.e. roll-in shown with a darker-black arrow) into its original position.

For flick-out detection, the user must quickly turn the wrist away from the body (i.e. roll-out shown with a darker-black arrow in above picture) and then slowly bring it back (i.e. roll-in shown with a light-grey arrow in above picture) to its original position.

The speed of the roll-out and roll-in movements determine if the user performed a flick-in or a flick-out movement. WR\_GEST 3.min\_flick\_samples can be used to control the time difference between the roll-in and roll-out movement. WR\_GEST\_2.min\_flick\_peak can be used to adjust the amount to tilt needed on the device to detect a flick gesture.

# Push arm down/Pivot up





Push-arm-down movement

Pivot-up movement

Figure 5: Push arm-down/pivot up

For push-arm down detection, the user should hold the arm in front of the body and quickly push down and then bring it back normally to the original position.

For pivot-up detection, the user should hold the arm in front of the body and quickly pivot up and then bring it back normally to the original position.

Wrist Jiggle / Shake



Figure 6: Shake or jiggle movement

For a jiggle detection, the user must shake the hand quickly.

The device will detect the above mentioned gestures only when the user completes the movement within the duration defined by WR GEST 4.max duration.

Once feature is disabled, output will hold the previous value.

This feature has dependency on the device orientation in the user system. Please refer to section 4.8.1 for details about axis remapping

# Configuration settings

- ► WR GEST 1.enable Enables the feature.
- ▶ WR GEST 1.wearable arm Configures the device in left (0) or right (1) arm. By default, the wearable device is assumed to be in left arm i.e. default value is 0."
- ▶ WR GEST 2.min flick peak Sine of the minimum tilt angle in portrait down direction of the device when wrist is rolled away (roll-out) from user.
- ► <u>WR\_GEST\_3.min\_flick\_samples</u> Value of minimum time difference between wrist's roll-out and roll-in movement during flick gesture.
- ▶ <u>WR\_GEST\_4.max\_duration</u> Maximum time within which gesture movement has to be completed.

## Output details

► WR\_GEST\_OUT.wr\_gest\_out – 3-bits indicate type of gestures detected:

| Gestures           | Value |
|--------------------|-------|
| No gesture         | 0     |
| Push arm down      | 1     |
| Pivot up           | 2     |
| Wrist shake/jiggle | 3     |
| Flick in           | 4     |
| Flick out          | 5     |

# 4.8.8 Step counter / detector (Wrist-worn)

The wrist worn step counter/detector in BMI270 is optimized for wearable applications including smartwatches/bands/fitness trackers, among others. The step counter algorithm is optimized for high accuracy in wrist use-case applications, while Step Detector is optimized for low latency.

Table 15: Step counter Configuration

| Configuration                   |       |  |  |  |  |
|---------------------------------|-------|--|--|--|--|
| Parameters                      | Wrist |  |  |  |  |
| SC_1.param_1                    | 301   |  |  |  |  |
| SC_2.param_2                    | 31700 |  |  |  |  |
| SC 3.param 3                    | 315   |  |  |  |  |
| SC_4.param_4                    | 31451 |  |  |  |  |
| SC_5.param_5 (STEP_BUFFER_SIZE) | 4     |  |  |  |  |
| SC 6.param 6                    | 31551 |  |  |  |  |
| SC_7.param_7                    | 27853 |  |  |  |  |
| SC 8.param 8                    | 1219  |  |  |  |  |
| SC_9.param_9                    | 2437  |  |  |  |  |
| SC_10.param_10                  | 1219  |  |  |  |  |
| SC 11.param 11                  | -6420 |  |  |  |  |
| SC_12.param_12                  | 17932 |  |  |  |  |
| SC_13.param_13                  | 1     |  |  |  |  |
| SC 14.param 14                  | 39    |  |  |  |  |
| SC_15.param_15                  | 25    |  |  |  |  |
| SC 16.param 16                  | 150   |  |  |  |  |
| SC_17.param_17                  | 160   |  |  |  |  |
| SC_18.param_18                  | 1     |  |  |  |  |
| SC 19.param 19                  | 12    |  |  |  |  |
| SC_20.param_20                  | 15600 |  |  |  |  |
| SC_21.param_21                  | 256   |  |  |  |  |
| SC_22.param_22                  | 1     |  |  |  |  |
| SC_23.param_23                  | 3     |  |  |  |  |
| SC 24.param 24                  | 1     |  |  |  |  |
| SC_25.param_25                  | 14    |  |  |  |  |

- 1. <u>SC\_26.watermark\_level</u> watermark level; the step counter will trigger output every time specific number of steps are counted
- 2. <u>SC 26.reset\_counter</u> flag to reset the counted steps. Step count value can be reset only when any one of features mentioned in this register is enabled.
- 3. <u>SC 26.en counter</u> indicates if the Step Counter feature is enabled or not.
- 4. SC 26.en detector indicates if the Step Detector feature is enabled or not.
- 5. <u>SC\_26.en\_activity</u> indicates if the activity feature is enabled or not
- 6. <u>SC\_1.param\_1</u> to <u>SC\_25.param\_25</u> there are 25 parameters, which can customize the sensitivity of the Step Counter and Detector.

# 4.9 General Interrupt Pin Configuration

# 4.9.1 Electrical Interrupt Pin Behavior

Both interrupt pins INT1 and INT2 can be configured to show the desired electrical behavior. Interrupt pins can be enabled in <a href="INT1\_IO\_CTRL.output\_en">INT1\_IO\_CTRL.output\_en</a> respectively <a href="INT1\_IO\_CTRL.output\_en">INT2\_IO\_CTRL.output\_en</a>. The characteristic of the output driver of the interrupt pins may be configured with bits <a href="INT1\_IO\_CTRL.od">INT1\_IO\_CTRL.od</a> and <a href="INT2\_IO\_CTRL.od">INT2\_IO\_CTRL.od</a>. By setting these bits to 0b1, the output driver shows open-drive characteristic, by setting the configuration bits to 0b0, the output driver shows pushpull characteristic.

The electrical behavior of the Interrupt pins, whenever an interrupt is triggered, can be configured as either "active-high" or "active-low" via <a href="INT1\_IO\_CTRL.lvl">INT1\_IO\_CTRL.lvl</a> respectively <a href="INT2\_IO\_CTRL.lvl">INT2\_IO\_CTRL.lvl</a>.

Both interrupt pins can be configured as input pins via <a href="INT1\_IO\_CTRL.input\_en">INT1\_IO\_CTRL.input\_en</a> respectively <a href="INT2\_IO\_CTRL.input\_en">INT2\_IO\_CTRL.input\_en</a>. This is necessary when FIFO tag feature is used (see Section 4.7.4 "FIFO synchronization with external interrupts"). If both are enabled, the input (e.g. marking FIFO) is driven by the interrupt output.

The device supports edge and level triggered interrupt inputs, this can be configured through FIFO\_CONFIG1.fifo\_tag\_int1\_en and FIFO\_CONFIG1.fifo\_tag\_int2\_en.

The device supports non-latched and latched interrupts modes for data ready, FIFO watermark, FIFO full, error, and the advanced feature interrupts. The mode is selected by <a href="INT\_LATCH.int\_latch">INT\_LATCH.int\_latch</a>. Non-latched interrupts are designed for systems using level-triggered interrupts.

In latched mode an asserted interrupt status in <a href="INT\_STATUS\_0">INT\_STATUS\_1</a> (advanced feature interrupts) or <a href="INT\_STATUS\_1">INT\_STATUS\_1</a> (data ready, FIFO and error interrupts) and the selected pin are reset if the corresponding status register is read. If the interrupt activation condition still holds when the interrupt is reset, the interrupt status and pin are asserted again. If more than one interrupt pin is used in latched mode, all interrupts in <a href="INT\_STATUS\_0">INT\_STATUS\_0</a> should be mapped to one interrupt pin and all interrupts in <a href="INT\_STATUS\_1">INT\_STATUS\_1</a> should be mapped to the other interrupt pin. If just one interrupt pin is used all interrupts may be mapped to this interrupt pin.

In the non-latched mode the selected pin are reset as soon as the activation condition is not valid anymore. The interrupt status bits are active until read by the host.

## 4.9.2 Interrupt Pin Mapping

The data ready, FIFO watermark, FIFO full, error, and the advanced feature interrupts are mapped to the external INT1 or INT2 pins by setting the corresponding bits in the Registers <u>INT\_MAP\_DATA</u>, <u>INT1\_MAP\_FEAT</u> and <u>INT2\_MAP\_FEAT</u>. To unmap these interrupts, the corresponding bits must be reset.

Once an interrupt triggered the output pin, the host can derive the source of the interrupt of the corresponding status bit in the Register: INT STATUS 0 and INT STATUS 1.

# 4.10 Auxiliary Sensor Interface

The auxiliary interface allows to attach one auxiliary sensor (AUX, e.g. magnetometer) on the secondary interface of the device as shown in the figure below.



Figure 7: 9-DOF Solution w/ magnetometer (AUX) connected to the 2<sup>nd</sup> I/F

The auxiliary interface is fully compatible with sensors supporting I2C fast-mode-plus (fm+) and which do not require clock stretching. For operating the device with sensors supporting only I2C fast-mode (fm), please contact your regional Bosch Sensortec sales representative.

## 4.10.1 Structure and Concept

The device controls the data acquisition of the auxiliary sensor and presents the data to the application processor through the primary I2C or SPI interface. No other I2C master or slave devices must be attached to the auxiliary sensor interface.

The device autonomously reads the sensor data from a compatible auxiliary sensor without intervention of the application processor and stores the data in its data registers and FIFO. The initial setup of the auxiliary sensor after power-on is done through indirect addressing, see subsection "Setup Mode" below for details.

The main benefits of the auxiliary sensor interface are

- ▶ Synchronization of sensor data of auxiliary sensor and accelerometer. This results in an improved sensor data fusion quality.
- ▶ Usage of the device FIFO for auxiliary sensor data (BMM150 does not have a FIFO). This is important for monitoring applications.

## 4.10.2 Interface Control

The auxiliary sensor functionality is supported only if an AUX sensor is connected according to Section 7.3 and the auxiliary interface is configured for the auxiliary sensor operation by <a href="PWR\_CTRL.aux\_en">PWR\_CTRL.aux\_en</a>=0b1. If the auxiliary interface is not used for auxiliary sensor operation, then the auxiliary sensor interface must remain disabled by setting PWR\_CTRL.aux\_en=0b0 (default).

To change the power mode of the auxiliary sensor, both the power mode of the auxiliary interface and the auxiliary sensor part needs to be changed, e.g. to set the auxiliary sensor to suspend mode:

- ► The auxiliary sensor part itself must be put into suspend mode by writing the respective configuration bits of the auxiliary sensor part. The power mode of the auxiliary sensor part is controlled by setting the device auxiliary sensor interface into manual mode by <a href="AUX\_IF\_CONF.aux\_manual\_en">AUX\_IF\_CONF.aux\_manual\_en</a>=0b1 and then communicating with the auxiliary sensor part through the device registers <a href="AUX\_RD\_ADDR">AUX\_WR\_ADDR</a>, and <a href="AUX\_WR\_DATA">AUX\_WR\_DATA</a>. For details see subsection "Setup Mode" below.
- ▶ Set the auxiliary sensor interface to suspend in Register <a href="PWR CTRL.aux en">PWR CTRL.aux en</a>=0b0. Changing the auxiliary sensor interface power mode to suspend does not imply any mode change in the auxiliary sensor.

## 4.10.3 Interface Configuration

The I2C address of the auxiliary sensor must be configured in register <u>AUX\_DEV\_ID.i2c\_device\_addr</u>.

The configuration registers that control the auxiliary sensor interface operation, are only affecting the interface to the

auxiliary sensor, not the configuration of the sensor itself (this must be done in setup mode).

There are three basis configurations of the auxiliary sensor interface:

- ► No auxiliary sensor access
- ▶ Setup mode: Auxiliary sensor access in manual mode
- ▶ Data mode: Auxiliary sensor access through hardware readout loop.

The setup of the auxiliary sensor itself must be done through the primary interface using indirect addressing in setup mode. When collecting sensor data, the device autonomously triggers the measurement of the auxiliary sensor using the auxiliary sensor forced mode and the data readout from the auxiliary sensor (data mode).

In setup mode, the auxiliary sensor may be configured and trim data may be read out from the auxiliary sensor. In the data mode the auxiliary sensor data are continuously copied into the device's registers and may be read out from the device directly over the primary interface. For a BMM150 magnetometer, these are the auxiliary sensor data itself and Hall resistance, temperature is not required. The table below shows how to configure these three modes using the registers PWR CONF, PWR CTRL, and AUX IF CONF.aux manual en.

| Mode                       | AUX_IF_CONF.aux   | PWR_CONF.adv | PWR_CTRL.aux_en |
|----------------------------|-------------------|--------------|-----------------|
|                            | <u>_manual_en</u> | _power_save  |                 |
| No auxiliary sensor access | 1                 | 1            | 0               |
| Setup mode                 | 1                 | 0            | 0               |
| Data mode                  | 0                 | Х            | 1               |

<u>IF CONF.aux en</u> enables (disables) the auxiliary sensor interface. The auxiliary sensor interface operates at 400 kHz. This results in an I2C readout delay of about 250 µs for 10 bytes of data.

# 4.10.4 Setup Mode (AUX IF CONF.aux manual en =0b1)

Through the primary interface the auxiliary sensor may be accessed using indirect addressing through the AUX\_\* registers. AUX\_RD\_ADDR and AUX\_WR\_ADDR define the address of the register to read/write in the auxiliary sensor register map and triggers the operation itself, when the auxiliary sensor interface is enabled through PWR\_CTRL.aux\_en. For reads, the number of data bytes defined in AUX\_IF\_CONF.aux\_rd\_burst\_ are read from the auxiliary sensor and written into the device Register DATA\_0 to DATA\_7. For writes only single bytes are written, independent of the settings in AUX\_IF\_CONF.aux\_rd\_burst. The data for the I2C write to auxiliary sensor must be stored in AUX\_WR\_DATA before the auxiliary sensor register address is written into AUX\_WR\_ADDR.

When a read or write operation is triggered by writing to <u>AUX\_RD\_ADDR</u> and <u>AUX\_WR\_ADDR</u>, <u>STATUS.aux\_busy</u> is set and it is reset when the operation is completed. For reads the <u>DATA\_0</u> to <u>DATA\_7</u> contains the read data, for writes <u>AUX\_WR\_DATA</u> may be overwritten again.

Configuration phase of the auxiliary sensor.

Example: Read bytes 5 and 6 of auxiliary sensor



# Example: Write 0xEF into byte 3 of auxiliary sensor



# 4.10.5 Data Mode (AUX IF CONF.aux manual en=0)

<u>AUX\_RD\_ADDR.read\_addr</u> defines the address of the data register from which to read the number of data bytes configured in <u>AUX\_IF\_CONF.aux\_rd\_burst</u> from AUX\_0... AUX\_7 data of the auxiliary sensor. These data are stored in the <u>DATA\_0</u> up to <u>DATA\_7</u> register. the device uses bit 0 of the <u>DATA\_6</u> register to determine the data ready status.

The data ready interrupt fires whenever a new data sample set from the AUX sensor is available in Registers <u>DATA\_0</u> to <u>DATA\_7</u>. This allows a low latency data readout. In non-latched mode, the interrupt are cleared automatically after 1/(6400Hz). If this automatic clearance is unwanted, please use latched mode (see Section 4.9). The flag <u>INT\_STATUS\_1.aux\_drdy\_int</u> is cleared when the register <u>INT\_STATUS\_1 is read.</u> The flag <u>STATUS.drdy\_aux\_is</u> cleared when the Registers <u>DATA\_0</u> to <u>DATA\_7</u> are read.

To enable the data ready interrupt please map it on the desired INT pin via INT MAP DATA.

<u>AUX\_WR\_ADDR.write\_addr</u> defines the register address of auxiliary sensor to start a measurement in forced mode in the auxiliary sensor register map. During read and write operations <u>STATUS.aux\_busy</u> is set and it is reset, when the operation is completed. The delay (time offset) between triggering an auxiliary sensor measurement and reading the measurement data is specified in <u>AUX\_CONF.aux\_offset</u>. Reading of the data is done in a single I2C read operation with a burst length specified in <u>AUX\_IF\_CONF.aux\_rd\_burst</u>. For BMM150 <u>AUX\_IF\_CONF.aux\_rd\_burst</u> should be set to 0b11, i.e. 8 bytes. If <u>AUX\_IF\_CONF.aux\_rd\_burst</u> is set to a value lower than 8 bytes, the remaining auxiliary sensor data in the Register <u>DATA\_0</u> to <u>DATA\_7</u> and the FIFO are undefined.

It is recommended to disable the auxiliary sensor interface (IF\_CONF.aux\_en=0b0) before setting up <u>AUX\_RD\_ADDR.read\_addr</u> and <u>AUX\_WR\_ADDR.write\_addr</u> for the data mode. This does not put the auxiliary sensor itself into suspend mode but avoids gathering unwanted data during this phase. Afterwards the auxiliary sensor interface can be enabled (IF\_CONF.aux\_en =0b1) again.

## 4.10.6 Delay (Time Offset)

The device supports starting the measurement of the sensor at the auxiliary sensor interface between 2.5 and 37.5 ms before the Register DATA are updated. This offset is defined in <u>AUX\_CONF.aux\_offset</u>. If set to 0b0, the measurement is done right after the last Register DATA update, therefore this measurement will be included in the next register DATA update.

## 4.11 OIS Interface

The device includes a secondary interface (see Section 6.6 for further details). This may be configured as a dedicated OIS interface. The OIS interface supports phone architectures which share a IMU for a regular host interface (HMI, activity recognition and gesture recognition, PDR, ...) and for optical image stabilization (OIS) at the same time. The OIS interface is a second SPI slave interface, see Section 7.4 for detailed connection diagrams.

The OIS controller has access to low latency accelerometer and gyroscope data through the OIS interface. This is independent of the settings on the host interface. E.g. any settings in the Registers ACC\_CONF and GYR\_CONF will not influence the OIS interface, it remains always in the minimum group delay configuration. With the exception of GYR\_CONF.gyr\_noise\_perf which trades power and noise performance globally for both interfaces, i.e. noise may be reduced w/o compromising group delay. The range of gyroscope data accessible through the OIS interface is independent of the primary interface setting and is configured through GYR\_RANGE.ois\_range. The range of the accelerometer data accessible through the OIS interface is identical to the range setting for the primary interface and configured through ACC\_RANGE.acc\_range.

The usecase for this data is to stabilize photo and video images by real time motion compensation of the camera lenses.



Figure 8: OIS interface

\*) supported by the marked leading providers of OIS controllers.

By default, the OIS interface is in disabled state. If the system design requires an OIS interface, the host enables it by <a href="IF\_CONF.ois\_en">IF\_CONF.ois\_en</a>=0b1. If the OIS interface is enabled the sensors may be controlled both through the host controller and the OIS controller. The OIS controller has access to a dedicated OIS register map.

The OIS data are controlled through the register <u>OIS\_CTRL\_S</u>. This includes enabling and disabling the accelerometer and gyroscope.

The IMU sensor signals for the OIS use case are provided through the secondary interface (in registers OIS\_DATA, OIS Register Map, see following subsection)

For a more detailed description on how to implement OIS, please contact your regional Bosch Sensortec sales representative.

# 4.11.1 OIS Register Map

Table 16: OIS Register Map

| read/write                                                                              |                  | read only        |        |            | write only |       |        | reserved |   |   |
|-----------------------------------------------------------------------------------------|------------------|------------------|--------|------------|------------|-------|--------|----------|---|---|
| ld: #ai260aa#flow#dig#reg-ipxact#BAl260_AddrMap_Shell.xml,v 1.14 2018-02-02 09:23:38+01 |                  |                  |        |            |            |       |        |          |   |   |
| Register<br>Address                                                                     | Register<br>Name | Default<br>Value | 7      | 6          | 5          | 4     | 3      | 2        | 1 | 0 |
| 0x7F                                                                                    |                  |                  |        | reserved   |            |       |        |          |   |   |
|                                                                                         |                  |                  |        |            |            | rese  | erved  |          |   |   |
| 0x41                                                                                    |                  |                  |        |            |            | rese  | erved  |          |   |   |
| 0x40                                                                                    | OIS_CTRL_S       | 0x00             | acc_en | gyr_en     |            |       | rese   | erved    |   |   |
| 0x3F                                                                                    |                  | 0x00             |        |            |            | rese  | erved  |          |   |   |
|                                                                                         |                  | 0x01             |        |            |            | rese  | erved  |          |   |   |
| 0x18                                                                                    |                  | 0x00             |        |            |            | rese  | erved  |          |   |   |
| 0x17                                                                                    | OIS DATA 11      | 0x00             |        |            |            | gyr_z | _15_8  |          |   |   |
| 0x16                                                                                    | OIS DATA 10      | 0x00             |        | gyr_z_7_0  |            |       |        |          |   |   |
| 0x15                                                                                    | OIS_DATA_9       | 0x00             |        | gyr_y_15_8 |            |       |        |          |   |   |
| 0x14                                                                                    | OIS_DATA_8       | 0x00             |        |            |            | gyr_y | /_7_0  |          |   |   |
| 0x13                                                                                    | OIS_DATA_7       | 0x00             |        |            |            | gyr_x | _15_8  |          |   |   |
| 0x12                                                                                    | OIS_DATA_6       | 0x00             |        | gyr_x_7_0  |            |       |        |          |   |   |
| 0x11                                                                                    | OIS_DATA_5       | 0x00             |        |            |            | acc_z | :_15_8 |          |   |   |
| 0x10                                                                                    | OIS_DATA_4       | 0x00             |        |            |            | acc_: | z_7_0  |          |   |   |
| 0x0F                                                                                    | OIS_DATA_3       | 0x00             |        | acc_y_15_8 |            |       |        |          |   |   |
| 0x0E                                                                                    | OIS_DATA_2       | 0x00             |        | acc_y_7_0  |            |       |        |          |   |   |
| 0x0D                                                                                    | OIS_DATA_1       | 0x00             |        | acc_x_15_8 |            |       |        |          |   |   |
| 0x0C                                                                                    | OIS_DATA_0       | 0x00             |        | acc_x_7_0  |            |       |        |          |   |   |
| 0x0B                                                                                    |                  | 0x00             |        | reserved   |            |       |        |          |   |   |
|                                                                                         |                  | -                |        | reserved   |            |       |        |          |   |   |
| 0x00                                                                                    |                  | 0x27             |        | reserved   |            |       |        |          |   |   |

# 4.11.2 Register (0x0C..0x17) OIS\_DATA\_0..11

DESCRIPTION: These 12 registers publish accelerometer and gyroscope data. The register map layout is identical to the host register map (see Section 5, Registers <u>DATA\_8</u> .. <u>DATA\_19</u>). The registers of both register maps are separate instances and thus their content is not a simple copy of each other. The OIS registers provide output data of a separate low latency datapath.

RESET: 0x00

DEFINITION (Go to register map):

| Address  | Bit | Name         | Description             | Reset | Access |
|----------|-----|--------------|-------------------------|-------|--------|
| 0x0C0x17 |     | OIS_DATA_011 |                         | 0x00  |        |
|          | 70  |              | acc_x_7_0 to gyr_z_15_8 | 0x0   | R      |

# 4.11.3 Register (0x40) OIS\_CTRL\_S

DESCRIPTION: controls the IMU through the OIS interface

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name       | Description                                                                                                           | Reset | Access |
|---------|-----|------------|-----------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x40    |     | OIS_CTRL_S |                                                                                                                       | 0x00  |        |
|         | 7   | acc_en     | Enables accelerometer via OIS interface in registers OIS_DATA_0 till OIS_DATA_5 with minimum group delay @ 1.6KHz ODR | 0x0   | RW     |
|         | 6   | gyr_en     | Enables gyroscope via OIS interface in registers OIS_DATA_6 till OIS_DATA_11 with minimum group delay @ 6.4KHz ODR    | 0x0   | RW     |

## 4.12 Sensor Self-Test

#### 4.12.1 Accelerometer

Activating the self-test results in a static offset of the acceleration data. Any external acceleration or gravitational force applied to the sensor during active self-test will be observed in the output as a superposition of both acceleration and self-test signal.

The recommended self test procedure is as follows:

- Enable accelerometer with register PWR\_CTRL.acc\_en=1b1.
- 2. Set ±16g range in register ACC\_RANGE.acc\_range
- Set self test amplitude to high by setting <u>ACC\_SELF\_TEST.acc\_self\_test\_amp</u> = 1b1
- Set <u>ACC\_CONF.acc\_odr=1600Hz</u>, Continuous sampling mode, <u>ACC\_CONF.acc\_bwp</u>=norm\_avg4, ACC\_CONF.acc\_filter\_perf=1b1.
- 5. Wait for > 2 ms
- 6. Set positive self-test polarity (ACC SELF TEST.acc self test sign= 1b1)
- 7. Enable self-test ACC\_SELF\_TEST.acc\_self\_test\_en = 1b1
- 8. Wait for > 50ms
- 9. Read and store positive acceleration value of each axis from registers DATA 8 to DATA 13
- 10. Set negative self-test polarity ACC\_SELF\_TEST.acc\_self\_test\_sign= 1b0)
- 11. Enable self-test ACC SELF TEST.acc self test en = 1b1
- 12. Wait for > 50ms
- 13. Read and store negative acceleration value of each axis from registers <a href="DATA\_8">DATA\_8</a> to <a href="DATA\_13">DATA\_13</a>
- 14. Calculate difference of positive and negative acceleration values and compare against minimum difference signal values defined in the table below
- 15. Disable self-test ACC\_SELF\_TEST.acc\_self\_test\_en = 1b0

The table below shows the minimum differences for each axis in order for the self test to pass. The actually measured signal differences can be significantly larger.

Self-test: Resulting minimum difference signal

|               | x-axis signal | y-axis signal | z-axis signal |
|---------------|---------------|---------------|---------------|
| Accelerometer | > +16g        | < -15g        | > +10g        |

It is recommended to perform a reset of the device after a self-test has been performed. If the reset cannot be performed, the following sequence must be kept to prevent unwanted interrupt generation: disable interrupts, change parameters of interrupts, wait for at least 50ms, and enable desired interrupts.

## 4.12.2 Gyroscope

The gyroscope self test consists of independent parts, a drive test, a sense test, and a datapath test.

To perform a gyroscope self-test

- 1. Issue a soft reset (see Section 4.17) or a power-on reset (POR) (see Section 4.4)
- 2. Initialize device (see Section 4.4)
- 3. Disable APS PWR\_CONF.adv\_power\_save=0b0 and wait for 450us
- 4. Enable accelerometer PWR\_CTRL.acc\_en=0b1
- 5. Ensure that the device is at rest during self-test execution
- 6. Send g\_trigger command using the register CMD
- 7. Self-test is complete, after the device sets GYR\_SELF\_TEST\_AXES.gyr\_st\_axes\_done=0b1
- 8. GYR GAIN STATUS.g trig status reports a successful self-test or execution errors
- 9. The test passed if all axes report the status "ok" by GYR\_SELF\_TEST\_AXES.gyr\_axis\_[xyz]\_ok=0b1.

During the gyroscope self-test described above and at every gyroscope startup, i.e.:

- ► <u>PWR\_CTRL.gyr\_en</u>: 0b0->0b1 and <u>PWR\_CONF.fup\_en</u>==0b0
- ▶ PWR CONF.fup en: 0b0->0b1 and PWR CTRL.gyr en==0b0

a drive test is automatically performed and if it fails it is reported through <a href="ERR\_REG.fatal\_err">ERR\_REG.fatal\_err</a> latest after 320 ms.

# 4.13 Offset Compensation

#### 4.13.1 Accelerometer

The device offers manual compensation as well as inline calibration.

Offset compensation is performed with pre-filtered data, and the offset is then applied to both, pre-filtered and filtered data. If necessary, the result of this computation is saturated to prevent any overflow errors (the smallest or biggest possible value is set, depending on the sign).

## Manual Offset Compensation

The offset compensation Registers OFFSET 0 to OFFSET 2 are initialized out of the corresponding registers in the NVM during power on or soft reset. These registers can be overwritten by the user at any time. After modifying the Register OFFSET 0 to OFFSET 2 the next data sample is not valid.

The offset compensation registers have a width of 8 bit using two's complement notation. The offset resolution (LSB) is 3.9 mg and the offset range is  $\pm$  0.5 g. Both are independent of the range setting. Offset compensation needs to be enabled through NV\_CONF.acc\_off\_en = 0b1

Fast Offset Compensation FOC (Semi-Automatic Offset Compensation)

For certain applications, it is often desirable to calibrate the offset once and to store the compensation values permanently. This can be achieved by using manual offset compensation to determine the proper compensation values and then storing these values permanently in the NVM.

Each time the device is reset, the compensation values are loaded from the non-volatile memory into the image registers and used for offset compensation.

## 4.13.2 Gyroscope

Offset compensation is performed with pre-filtered data, and the offset is then applied to both, pre-filtered and filtered data. If necessary, the result of this computation is saturated to prevent any overflow errors (the smallest or biggest possible value is set, depending on the sign).

#### Manual Offset Compensation

The offset compensation Registers OFFSET\_3 to OFFSET\_6 are initialized out images of the corresponding registers in the NVM during power on or soft reset. These registers can be overwritten by the user at any time. After modifying the Register OFFSET\_3 to OFFSET\_6 the next data sample is not valid.

The offset compensation field for each axis has a width of 10 bit using two's complement notation. The offset resolution (LSB) is 61 mdps and the offset range is ±31 dps. Both are independent of the range setting. Offset compensation needs to be enabled through OFFSET\_6.gyr\_off\_en.

## Fast Offset Compensation FOC (Semi-Automatic Offset Compensation)

For certain applications, it is often desirable to calibrate the offset once and to store the compensation values permanently. This can be achieved by using manual offset compensation to determine the proper compensation values and then storing these values permanently in the NVM.

Each time the device is reset, the compensation values are loaded from the non-volatile memory into the image registers and used for offset compensation.

In-use Offset Compensation IOC (Full-Automatic Offset Compensation)

MEMS devices typically show offset drifts due to thermomechanical stress effects within the application, the use-case or over lifetime. To compensate such potential drifts the device offers an in-use offset compensation (IOC), which operates fully autonomous without any necessary host interaction and in parallel to the normal device operation.

The host can choose to use either the built-in full automatic IOC feature to compensate the gyroscope offset in registers OFFSET 3 ... OFFSET 6 or control these registers manually. This is controlled by the Register GEN\_SET\_1.gyr\_self\_off.

The device will update the gyroscope offset registers automatically if all of the following conditions are met (host should not update the registers <a href="OFFSET\_6">OFFSET\_6</a> when this feature is enabled):

- ▶ Bit GEN SET 1.gyr self off is 1
- ▶ Bit OFFSET\_6.gyr\_off\_en is 1
- ▶ Accelerometer is enabled from either primary or OIS interface
- ▶ Gyroscope is enabled from primary interface
- ▶ Gyroscope is disabled from OIS interface

If any one of the above conditions are not met, then the feature is disabled. In this case, host can update the gyroscope offset registers. The recommended way to disable this feature is to clear the <u>GEN\_SET\_1.gyr\_self\_off</u> bit to 0.

# 4.14 Sensitivity Error Compensation

#### 4.14.1 Accelerometer

The device supports an ultra low sensitivity (gain) compensation already by design. Refer to Section 1.

## 4.14.2 Gyroscope

The device supports sensitivity (gain) compensation (e.g. to compensate for a soldering drift). This can be done either manually by rotating the device and comparing against a known reference or motionless using CRT (Component ReTrimming).

## Manual SENS Error Compensation

The device supports correcting the sensitivity difference, with respect to the reference system using manual SENS error compensation. Assuming the offset of the gyro is compensated, gain compensation is enabled (OFFSET6.gyr gain\_en=0b1) and the gyroscope reports  $\underline{\omega}_m$ , whereas the reference system reports  $\underline{\omega}_r$ , the host must supply the rate ratios  $\omega_{r[x-z]}/\omega_{m[x-z]}$  in the Registers GYR GAIN UPD [1-3]. The encoding is given by

- a. Bit width = 11 bits (FxP representation is 1.10)
- b. Resolution =  $0.0009765 = 2^{-10}$  (i.e. 0.09765% i.e. < 0.1%)
- c. Range = 0.75 .. 1.25 (i.e.  $1 \pm 25\%$ )

## e.g. 1+25% = 1.25 is represented as

| b10 | b9 | b8 | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 |
|-----|----|----|----|----|----|----|----|----|----|----|
| 1   | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

## e.g. 1+0.09765% = 1.0009765 is represented as

| b10 | b9 | b8 | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 |
|-----|----|----|----|----|----|----|----|----|----|----|
| 1   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  |

#### e.g. 1-0.09765% = 0.9990234 is represented as

|     |    |    |    | •  |    |    |    |    |    |    |
|-----|----|----|----|----|----|----|----|----|----|----|
| b10 | b9 | b8 | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 |
| 0   | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |

## e.g. 1-25% = 0.75 is represented as

| b10 | b9 | b8 | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 |
|-----|----|----|----|----|----|----|----|----|----|----|
| 0   | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

The host must enable the update operation via Register <u>GYR\_GAIN\_UPD\_3.enable</u> =0b1 and disable the gyroscope (<u>PWR\_CTRL.gyr\_en</u>=0b0) before triggering the manual SENS error compensation operation via issuing a command *usr\_gain* to the Register <u>CMD</u>. After <u>GYR\_GAIN\_UPD\_3.enable</u> bit gets cleared, the operation is completed, and the host can reenable the gyroscope (<u>PWR\_CTRL.gyr\_en</u>=0b1)

In case the compensation reaches the compensation range limit, the device reports this through Register GYR\_GAIN\_STATUS.

This compensated sensitivity value may be retained over power cycles by storing it in NVM, see Section 4.15 for details.

# Component ReTrimming Feature CRT (Fast, motionless SENS Error Compensation)

For motionless SENS error compensation (CRT) the following flow needs to be executed:

- 1. Issue a soft reset (see Section 4.17) or a power-on reset (POR) (see Section 4.4)
- 2. Initialize device (see Section 4.4)
- 3. Disable APS PWR CONF.adv power save=0b0 and wait for 450us
- 4. Enable gyroscope gain compensation <a href="OFFSET\_6.gyr\_gain\_en">OFFSET\_6.gyr\_gain\_en</a>=0b1
- 5. Enable accelerometer PWR CTRL.acc en=0b1
- 6. Ensure that the device is at rest during CRT execution
- 7. Set GYR CRT CONF.crt running=0b1
- 8. Set G TRIG 1.select=1
- 9. Set G TRIG 1.block=0
- 10. Send g\_trigger command using the register CMD
- 11. CRT is complete, after the device sets GYR\_CRT\_CONF.crt\_running=0b0
- 12. GYR\_GAIN\_STATUS.g\_trig\_status reports a successful CRT run or execution errors
- 13. Optionally, the new gyroscope gain values can be programmed to NVM. See Section 4.15 for details about NVM programming.
- 14. The new gain values are applied automatically at the next start of the gyroscope.

If the device detects motion during the CRT flow, the operation is aborted and the gain remains unchanged. If CRT is abort, Register GYR GAIN STATUS.g trig status will be set to 0x03.

CRT may run in the full operating temperature range. We recommend to run CRT at the operating temperature of the device. The sensitivity error is typically minimal at the temperature CRT was performed at.

We recommend performing CRT according the description above for one-time CRT calibration. Both one-time and repeated CRT is supported by the device.

## 4.15 Non-Volatile Memory

The registers <u>NV\_CONF</u>, <u>OFFSET\_0</u> to <u>OFFSET\_6</u>, <u>AUX\_IF\_TRIM</u>, and <u>DRV</u> have an NVM backup which are accessible by the user. In addition, the registers for the sensitivity error compensation for the gyroscope are included in the NVM backup (see Section 4.14).

The content of the NVM is loaded to the image registers after a reset (either POR or softreset). As long as the image update is in progress, STATUS.cmd\_rdy is 0b0, otherwise it is 0b1.

The image registers can be read and written like any other register.

Writing to the NVM is a 7-step procedure:

- 1. Set PWR CONF.adv power save = 0b0
- 2. Write the new contents to the image registers.
- 3. Prepare NVM write by setting GEN SET 1.nvm prog prep =0b1
- 4. Wait 40 ms
- 5. Write 0b1 to bit NVM\_CONF.nvm\_prog\_en in order to unlock the NVM.
- 6. Write prog nvm to the CMD register to trigger the write process.
- 7. Power off or restart the device (e.g. by POR, see Section 4.4 or soft-reset, see Section 4.17)

Writing to the NVM always renews the entire NVM contents and is limited in write cycles. It is possible to check the write status by reading STATUS.cmd\_rdy. While <u>STATUS.cmd\_rdy</u>. While <u>STATUS.cmd\_rdy</u> = 0b0, the write process is still in progress; when <u>STATUS.cmd\_rdy</u> = 0b1, writing is completed. An NVM write cycle can only be initiated, if PWR\_CONF.adv\_power\_save = 0b0.

Until boot phase is finished (after POR or softreset), the serial interface is not operational. The NVM shadow registers must not be accessed during an ongoing NVM command (initiated through the Register CMD). In all other cases, register can be read or written.

As long as an NVM read (during sensor boot and soft reset) or an NVM write is ongoing, writes to sensor registers are discarded, reads return the Register <u>STATUS</u> independent of the read address.

# 4.16 Error Reporting

Device errors during operation are reported through the registers <u>ERR\_REG</u> (hardware errors), <u>EVENT</u> (POR and invalid configuration events), <u>INTERNAL\_STATUS</u> (initialization and invalid configuration), and <u>INTERNAL\_ERROR</u> (unexpected behavior). Reserved bits in the error registers are for Bosch Sensortec internal purposes and can be ignored safely.

The register <u>ERR\_REG\_MSK</u> controls which bits in Register <u>ERR\_REG</u> trigger an interrupt. Register <u>INT\_MAP\_DATA.err\_int1</u> and <u>INT\_MAP\_DATA.err\_int2</u> defines on which interrupt pin, the error interrupt is mapped.

Illegal settings in configuration registers <u>ACC\_CONF</u> and <u>GYR\_CONF</u> will result in an error code in Register <u>EVENT</u>. The content of the data register is undefined.

Sensor Self-Test errors are covered in Section 4.12.

#### 4.17 Soft Reset

A softreset can be initiated at any time by writing the command softreset (0xB6) to register <u>CMD</u>. The softreset performs a fundamental reset to the device which is largely equivalent to a power cycle (see section 4.4). Following a delay, all user configuration settings are overwritten with their default state (setting stored in the NVM) wherever applicable. This command is functional in all operation modes but must not be performed while NVM writing operation is in progress. To access the SPI or I2C interface after a soft-reset, the same timing constraints apply as for power on, see Section 1 for details

# 5 Register Description

## 5.1 General Remarks

This section contains register definitions. REG[x]<y> denotes bit y in byte x in register REG. Val(Name) is the value contained in the register interpreted as non-negative binary number. If writing to reserved bits, the reset value should be written if not stated different.

For most of the registers auto address increment applies for, with the exception of the registers below, which trap the address:

- ► FIFO DATA
- ► INIT DATA

Register read from a burst read must remain consistent. In order to ensure this, when a read starts in one register of a group, the registers in this group are shadowed:

- ► STATUS, DATA x, SENSORTIME x, TEMPERATURE x, SC OUT x, FIFO LENGTH x
- **▶** FEATURES

The registers listed below are clear-on-read:

- ► ERR REG
- ► <u>STATUS.drdy\_acc</u> (cleared when <u>DATA\_9.acc\_x\_15\_8</u> is read),
- ► <u>STATUS.drdy\_gyr</u> (cleared when <u>DATA\_15.gyr\_x\_15\_8</u> is read)
- ► <u>STATUS.drdy\_aux</u> (cleared when <u>DATA\_1.aux\_x\_15\_8</u> is read)
- **► EVENT**
- ► INT STATUS 0
- ► <a href="INT\_STATUS\_1">INT\_STATUS\_1</a>

The register clearance happens, when bit 0 of the corresponding register is read.

# 5.2 Register Map

|                     | read/write         |                  | rea               | ıd only                        |             | write     | only              |                  | reserved              |                    |  |
|---------------------|--------------------|------------------|-------------------|--------------------------------|-------------|-----------|-------------------|------------------|-----------------------|--------------------|--|
|                     |                    |                  |                   |                                |             |           |                   |                  |                       |                    |  |
| D. minton           | Do minton          | Defende          |                   |                                | T           | Corre     | sponding to BMI   | 270_main.tbin ve | rsion 4.8, registe    | r map version 4.4  |  |
| Register<br>Address | Register<br>Name   | Default<br>Value | 7                 | 6                              | 5           | 4         | 3                 | 2                | 1                     | 0                  |  |
| 0x7E                | CMD                | 0x00             |                   |                                |             | C         | md                |                  |                       |                    |  |
|                     | PWR CTR            |                  |                   |                                |             |           |                   |                  |                       |                    |  |
| 0x7D                | <u>L</u>           | 0x00             |                   | reserved temp_en acc_en gyr_en |             |           |                   |                  |                       |                    |  |
| 0x7C                | PWR CO<br>NF       | 0x03             |                   |                                | reserved    |           |                   | fup_en           | fifo_self_w<br>ake_up | adv_power<br>_save |  |
| 0x7B                | -                  | -                |                   |                                |             | rese      | erved             |                  |                       |                    |  |
|                     | -                  | -                |                   |                                |             | rese      | erved             |                  |                       |                    |  |
| 0x78                | -                  | -                |                   |                                |             | rese      | erved             |                  |                       |                    |  |
| 0x77                | OFFSET_6           | 0x00             | gyr_gain_e<br>n   | gyr_off_en                     | gyr_usr_    | off_z_9_8 | gyr_usr_          | off_y_9_8        | gyr_usr_              | off_x_9_8          |  |
| 0x76                | OFFSET 5           | 0x00             |                   |                                |             | gyr_usr_  | off_z_7_0         |                  |                       |                    |  |
| 0x75                | OFFSET_4           | 0x00             |                   |                                |             | gyr_usr_  | off_y_7_0         |                  |                       |                    |  |
| 0x74                | OFFSET_3           | 0x00             |                   |                                |             | gyr_usr_  | off_x_7_0         |                  |                       |                    |  |
| 0x73                | OFFSET 2           | 0x00             |                   |                                |             | off_a     | acc_z             |                  |                       |                    |  |
| 0x72                | OFFSET_1           | 0x00             |                   |                                |             | off_a     | acc_y             |                  |                       |                    |  |
| 0x71                | OFFSET_0           | 0x00             |                   | off_acc_x                      |             |           |                   |                  |                       |                    |  |
| 0x70                | NV_CONF            | 0x00             |                   | reserved                       |             |           |                   | i2c_wdt_en       | i2c_wdt_se            | spi_en             |  |
| 0x6F                | -                  | -                |                   |                                |             | rese      | erved             |                  |                       |                    |  |
|                     | GYR_SEL            |                  |                   |                                |             |           | gyr_axis_z        | gyr_axis_y       | gyr_axis_x            | gyr_st_axe         |  |
| 0x6E                | F_TEST_A           | 0x00             |                   | rese                           | rved        |           | _ok               | _ok              | _ok                   | s_done             |  |
|                     | XES                |                  |                   |                                |             |           |                   |                  | _                     |                    |  |
| 0x6D                | ACC_SEL            | 0x00             |                   | rese                           | rved        |           | acc_self_te       | acc_self_te      | reserved              | acc_self_te        |  |
|                     | <u>F_TEST</u>      |                  | io nad iOo        |                                |             |           | st_amp            | st_sign          |                       | st_en              |  |
| 0x6C                | DRV                | 0xAA             | io_pad_i2c<br>_b2 |                                | io_pad_drv2 |           | io_pad_i2c<br>_b1 |                  | io_pad_drv1           |                    |  |
| 0x6B                | IF_CONF            | 0x00             | rese              | rved                           | aux_en      | ois_en    |                   | erved            | spi3_ois              | spi3               |  |
| 00 A                | NVM_CON            | 000              |                   |                                |             |           |                   |                  | nvm_prog_             |                    |  |
| 0x6A                | <u>F</u>           | 0x00             |                   |                                | rese        | erved     |                   |                  | en                    | reserved           |  |
| 0x69                | GYR_CRT<br>CONF    | 0x00             |                   | rese                           | erved       |           | rdy_for_dl        | crt_running      | rese                  | rved               |  |
| 0x68                | AUX IF T           | 0x01             |                   |                                | rese        | erved     |                   |                  | asda_                 | pupsel             |  |
| 0x67                | -                  | -                |                   |                                |             | rese      | erved             |                  |                       |                    |  |
|                     | -                  | -                |                   |                                |             |           | erved             |                  |                       |                    |  |
| 0x60                | -                  | -                |                   |                                |             | rese      | erved             |                  |                       |                    |  |
| 0x5F                | INTERNAL<br>_ERROR | 0x00             |                   | reserved feat_eng_d            |             |           | reserved          | int_err_2        | int_err_1             | reserved           |  |
| 0x5E                | INIT DATA          | 0x00             |                   |                                |             |           | ata               |                  |                       |                    |  |
| 0x5D                | -                  | -                |                   |                                |             |           | erved             |                  |                       |                    |  |
| 0x5C                | INIT_ADD<br>R_1    | 0x00             |                   |                                |             |           | _11_4             |                  |                       |                    |  |

| 0    | INIT_ADD          | 000  |                                         |                      | d                 |                       |                               | haaa              | . 0. 2               |                       |  |
|------|-------------------|------|-----------------------------------------|----------------------|-------------------|-----------------------|-------------------------------|-------------------|----------------------|-----------------------|--|
| 0x5B | <u>R_0</u>        | 0x00 |                                         | rese                 | erved             |                       |                               | Dase              | 0_3                  |                       |  |
| 0x5A | -                 | -    |                                         |                      |                   |                       | rved                          |                   |                      |                       |  |
| 0x59 | INIT_CTRL         | 0x00 |                                         |                      |                   | init <sub>.</sub>     | _ctrl<br>I                    |                   |                      |                       |  |
| 0x58 | INT MAP DATA      | 0x00 | err_int2                                | drdy_int2            | fwm_int2          | ffull_int2            | err_int1                      | drdy_int1         | fwm_int1             | ffull_int1            |  |
| 0x57 | INT2_MAP<br>_FEAT | 0x00 | reserved                                | any_motio<br>n_out   | no_motion<br>_out | wrist_gestu<br>re_out | wrist_wear<br>_wakeup_<br>out | activity_out      | step_count<br>er_out | sig_motion<br>_out    |  |
| 0x56 | INT1_MAP<br>_FEAT | 0x00 | reserved any_motio no_motion n_out _out |                      |                   | wrist_gestu<br>re_out | wrist_wear<br>_wakeup_<br>out | activity_out      | step_count<br>er_out | sig_motion<br>_out    |  |
| 0x55 | INT LATC H        | 0x00 |                                         | reserved             |                   |                       |                               | int_latch         |                      |                       |  |
| 0x54 | INT2 IO C         | 0x00 |                                         | reserved input_e     |                   |                       | output_en                     | od                | lvl                  | reserved              |  |
| 0x53 | INT1 IO C         | 0x00 | reserved i                              |                      |                   | input_en              | output_en                     | od                | lvl                  | reserved              |  |
| 0x52 | ERR REG<br>MSK    | 0x00 | aux_err fifo_err reserved intern        |                      |                   |                       | al_err                        |                   | fatal_err            |                       |  |
| 0x51 | -                 | -    |                                         | reserved             |                   |                       |                               |                   |                      |                       |  |
| 0x50 | =                 | =    | reserved                                |                      |                   |                       |                               |                   |                      |                       |  |
| 0x4F | AUX_WR_<br>DATA   | 0x02 |                                         | write_data           |                   |                       |                               |                   |                      |                       |  |
| 0x4E | AUX_WR<br>ADDR    | 0x4C |                                         | write_addr           |                   |                       |                               |                   |                      |                       |  |
| 0x4D | AUX_RD_<br>ADDR   | 0x42 |                                         |                      |                   | read                  | _addr                         |                   |                      |                       |  |
| 0x4C | AUX_IF_C<br>ONF   | 0x83 | aux_manu<br>al_en                       | aux_fcu_w<br>rite_en | rese              | rved                  | man_r                         | man_rd_burst aux_ |                      |                       |  |
| 0x4B | AUX_DEV<br>_ID    | 0x20 |                                         |                      | i2                | 2c_device_ad          | dr                            |                   |                      | reserved              |  |
| 0x4A | SATURATI<br>ON    | 0x00 | rese                                    | rved                 | gyr_z             | gyr_y                 | gyr_x                         | acc_z             | acc_y                | acc_x                 |  |
| 0x49 | FIG_1             | 0x10 | fifo_gyr_en                             | fifo_acc_e           | fifo_aux_e<br>n   | fifo_header<br>_en    | fifo_tag                      | _int2_en          | fifo_tag             | _int1_en              |  |
| 0x48 | FIFO CON          | 0x02 |                                         |                      |                   | rved                  |                               |                   | fifo_time_e          | fifo_stop_o<br>n_full |  |
| 0x47 | FIFO_WT<br>M_1    | 0x02 |                                         | reserved             |                   |                       | fifo_                         | water_mark_       | 12_8                 |                       |  |
| 0x46 | FIFO_WT M_0       | 0x00 |                                         |                      |                   | fifo_water_           | _mark_7_0                     |                   |                      |                       |  |
| 0x45 | FIFO_DO<br>WNS    | 0x88 | acc_fifo_filt<br>_data                  | а                    | acc_fifo_down     | S                     | gyr_fifo_filt<br>_data        | <b>§</b>          | gyr_fifo_down        | S                     |  |
| 0x44 | AUX CON<br>F      | 0x46 | _                                       | aux_                 | offset            |                       |                               | aux               | _odr                 |                       |  |
| 0x43 | GYR_RAN<br>GE     | 0x00 |                                         | rese                 | erved             |                       | ois_range gyr_range           |                   |                      |                       |  |
| 0x42 | GYR CON<br>E      | 0xA9 | gyr_filter_p<br>erf                     | gyr_noise_<br>perf   | gyr_              | bwp                   | gyr_odr                       |                   |                      |                       |  |

| 0x41 | ACC_RAN<br>GE                  | 0x02 |                       |                    | rese                 | rved                  |                               |              | acc_ı                | range              |
|------|--------------------------------|------|-----------------------|--------------------|----------------------|-----------------------|-------------------------------|--------------|----------------------|--------------------|
| 0x40 | ACC_CON<br>E                   | 0xA8 | acc_filter_           |                    | acc_bwp              | acc_odr               |                               |              |                      |                    |
| 0x3F | <u>FEATURE</u><br><u>S[15]</u> | 0x00 |                       |                    |                      |                       |                               |              |                      |                    |
|      |                                | -    |                       | features_in_out    |                      |                       |                               |              |                      |                    |
| 0x30 | FEATURE<br>S[0]                | 0x00 |                       |                    |                      |                       |                               |              |                      |                    |
| 0x2F | FEAT_PAG<br><u>E</u>           | 0x00 |                       |                    | reserved             |                       |                               |              | page                 |                    |
| 0x2E | -                              | -    |                       |                    |                      | rese                  | rved                          |              |                      |                    |
|      | -                              | -    |                       |                    |                      | rese                  | rved                          |              |                      |                    |
| 0x27 | -                              | -    |                       |                    |                      | rese                  | rved                          |              |                      |                    |
| 0x26 | FIFO_DAT<br>A                  | 0x00 |                       |                    |                      | fifo_                 | data                          |              |                      |                    |
| 0x25 | FIFO_LEN<br>GTH_1              | 0x00 | rese                  | rved               |                      |                       | fifo_byte_co                  | ounter_13_8  |                      |                    |
| 0x24 | FIFO_LEN<br>GTH_0              | 0x00 | fifo_byte_counter_7_0 |                    |                      |                       |                               |              |                      |                    |
| 0x23 | TEMPERA TURE 1                 | 0x80 | tmp_data_15_8         |                    |                      |                       |                               |              |                      |                    |
| 0x22 | TEMPERA TURE 0                 | 0x00 | tmp_data_7_0          |                    |                      |                       |                               |              |                      |                    |
| 0x21 | INTERNAL<br>STATUS             | 0x00 | Reserved              | odr_50hz_<br>error | axes_rema<br>p_error | Reserved              |                               | message      |                      |                    |
| 0x20 | WR_GEST<br>_ACT                | 0x00 |                       | reserved           |                      | act <sub>-</sub>      | _out                          |              | wr_gest_out          |                    |
| 0x1F | <u>SC_OUT</u>                  | 0x00 |                       |                    |                      | byt                   | e_1                           |              |                      |                    |
| 0x1E | <u>SC_OUT</u>                  | 0x00 |                       |                    |                      | byt                   | e_0                           |              |                      |                    |
| 0x1D | INT_STAT<br>US_1               | 0x00 | acc_drdy_i<br>nt      | gyr_drdy_i<br>nt   | aux_drdy_i<br>nt     | rese                  | rved                          | err_int      | fwm_int              | ffull_int          |
| 0x1C | INT_STAT US_0                  | 0x00 | reserved              | any_motio<br>n_out | no_motion<br>_out    | wrist_gestu<br>re_out | wrist_wear<br>_wakeup_<br>out | activity_out | step_count<br>er_out | sig_motion<br>_out |
| 0x1B | <u>EVENT</u>                   | 0x01 |                       | reserved           |                      |                       | error_code                    |              | reserved             | por_detect<br>ed   |
| 0x1A | SENSORT<br>IME_2               | 0x00 |                       |                    |                      | sensor_tir            | me_23_16                      |              |                      |                    |
| 0x19 | SENSORT<br>IME_1               | 0x00 |                       |                    |                      | sensor_ti             | me_15_8                       |              |                      |                    |
| 0x18 | SENSORT<br>IME 0               | 0x00 |                       |                    |                      | sensor_t              | ime_7_0                       |              |                      |                    |
| 0x17 | DATA_19                        | 0x00 |                       |                    |                      | gyr_z                 | _15_8                         |              |                      |                    |
| 0x16 | DATA_18                        | 0x00 |                       |                    |                      |                       | <br>7_0                       |              |                      |                    |
| 0x15 | <u>DATA 17</u>                 | 0x00 |                       |                    |                      |                       | _15_8                         |              |                      |                    |
| 0x14 | <u>DATA_16</u>                 | 0x00 |                       |                    |                      |                       | <mark>/_7_</mark> 0           |              |                      |                    |

| 0x13 | <u>DATA_15</u> | 0x00 |          |           |          | gyr_x_  | _15_8             |          |      |           |
|------|----------------|------|----------|-----------|----------|---------|-------------------|----------|------|-----------|
| 0x12 | <u>DATA_14</u> | 0x00 |          |           |          | gyr_x   | _7_0              |          |      |           |
| 0x11 | <u>DATA_13</u> | 0x00 |          |           |          | acc_z   | _15_8             |          |      |           |
| 0x10 | <u>DATA_12</u> | 0x00 |          | acc_z_7_0 |          |         |                   |          |      |           |
| 0x0F | DATA_11        | 0x00 |          |           |          | acc_y   | _15_8             |          |      |           |
| 0x0E | <u>DATA_10</u> | 0x00 |          |           |          | acc_y   | _7_0              |          |      |           |
| 0x0D | DATA 9         | 0x00 |          |           |          | acc_x   | _15_8             |          |      |           |
| 0x0C | DATA_8         | 0x00 |          |           |          | acc_x   | :_7_0             |          |      |           |
| 0x0B | DATA_7         | 0x00 |          |           |          | aux_r_  | _15_8             |          |      |           |
| 0x0A | DATA_6         | 0x00 |          |           |          | aux_r   | _7_0              |          |      |           |
| 0x09 | DATA_5         | 0x00 |          |           |          | aux_z   | _15_8             |          |      |           |
| 0x08 | DATA_4         | 0x00 |          |           |          | aux_z   | :_7_0             |          |      |           |
| 0x07 | DATA_3         | 0x00 |          |           |          | aux_y   | _15_8             |          |      |           |
| 0x06 | DATA_2         | 0x00 |          |           |          | aux_y   | <mark>-7_0</mark> |          |      |           |
| 0x05 | DATA_1         | 0x00 |          |           |          | aux_x   | _15_8             |          |      |           |
| 0x04 | DATA_0         | 0x00 |          |           |          | aux_x   | <u>.</u> 7_0      |          |      |           |
| 0x03 | <u>STATUS</u>  | 0x10 | drdy_acc | drdy_gyr  | drdy_aux | cmd_rdy | reserved          | aux_busy | rese | rved      |
| 0x02 | ERR_REG        | 0x00 | aux_err  | fifo_err  | reserved |         | intern            | al_err   |      | fatal_err |
| 0x01 | -              | -    |          |           |          | rese    | rved              |          |      |           |
| 0x00 | CHIP_ID        | 0x24 |          | chip_id   |          |         |                   |          |      |           |

**FEATURES Pages** 

| Register<br>Address | Register Name   | Page 0          | Page 1         | Page 2   | Page 3      |
|---------------------|-----------------|-----------------|----------------|----------|-------------|
| 0x30                | FEATURES[0,1]   | SC OUT 0 1      | Reserved       | NOMO_1   | <u>SC_1</u> |
| 0x32                | FEATURES[2,3]   | SC_OUT_2_3      | G_TRIG_1       | NOMO_2   | <u>SC_2</u> |
| 0x34                | FEATURES[4,5]   | ACT_OUT         | GEN_SET_1      | SIGMO_1  | <u>SC_3</u> |
| 0x36                | FEATURES[6,7]   | WR_GEST_OUT     | GYR GAIN UPD 1 | Reserved | <u>SC_4</u> |
| 0x38                | FEATURES[8,9]   | GYR_GAIN_STATUS | GYR_GAIN_UPD_2 | Reserved | <u>SC_5</u> |
| 0x3A                | FEATURES[10,11] | Reserved        | GYR_GAIN_UPD_3 | Reserved | <u>SC_6</u> |
| 0x3C                | FEATURES[12,13] | GYR_CAS         | ANYMO_1        | Reserved | <u>SC_7</u> |
| 0x3E                | FEATURES[14,15] | Reserved        | ANYMO_2        | SIGMO_2  | SC_8        |

FEATURES Pages

| Register<br>Address | Register Name          | Page 4       | Page 5       | Page 6       | Page 7          |
|---------------------|------------------------|--------------|--------------|--------------|-----------------|
| 0x30                | FEATURES[0,1]          | <u>SC_9</u>  | <u>SC_17</u> | <u>SC_25</u> | WR_WAKEUP_1     |
| 0x32                | FEATURES[2,3]          | <u>SC_10</u> | <u>SC_18</u> | <u>SC_26</u> | WR_WAKEUP_2     |
| 0x34                | FEATURES[4,5]          | <u>SC_11</u> | <u>SC 19</u> | <u>SC_27</u> | WR_WAKEUP_3     |
| 0x36                | FEATURES[6,7]          | <u>SC_12</u> | <u>SC_20</u> | WR_GEST_1    | WR_WAKEUP_4     |
| 0x38                | FEATURES[8,9]          | <u>SC_13</u> | <u>SC_21</u> | WR_GEST_2    | WR_WAKEUP_5     |
| 0x3A                | FEATURES[10,11]        | <u>SC_14</u> | <u>SC 22</u> | WR_GEST_3    | WR_WAKEUP_6     |
| 0x3C                | <u>FEATURES[12,13]</u> | <u>SC 15</u> | <u>SC 23</u> | WR GEST 4    | WR WAKEUP 7     |
| 0x3E                | <u>FEATURES[14,15]</u> | <u>SC_16</u> | <u>SC_24</u> | Reserved     | <u>Reserved</u> |

# 5.2.1 Register (0x00) CHIP\_ID

DESCRIPTION: Chip identification code

RESET: 0x24

DEFINITION (Go to register map):

| Address | Bit | Name    | Description              | Reset | Access |
|---------|-----|---------|--------------------------|-------|--------|
| 0x00    |     | CHIP_ID |                          | 0x24  |        |
|         | 70  | chip_id | Chip identification code | 0x24  | R      |

# 5.2.2 Register (0x02) ERR\_REG

**DESCRIPTION:** Reports sensor error conditions

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name         | Description                                                                                                                                                                | Reset | Access |
|---------|-----|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x02    |     | ERR_REG      |                                                                                                                                                                            | 0x00  |        |
|         | 0   | fatal_err    | Fatal Error, chip is not in operational state (Boot-, power-system). This flag will be reset only by power-on-reset or softreset.                                          | 0x0   | R      |
|         | 41  | internal_err | Internal error, please contact your Bosch Sensortec regional support team.                                                                                                 | 0x0   | R      |
|         | 6   | fifo_err     | Error when a frame is read in streaming mode (so skipping is not possible) and fifo is overfilled (with virtual and/or regular frames). This flag will be reset when read. | 0x0   | R      |
|         | 7   | aux_err      | Error in I2C-Master detected. This flag will be reset when read.                                                                                                           | 0x0   | R      |

# 5.2.3 Register (0x03) STATUS

**DESCRIPTION: Sensor status flags** 

RESET: 0x10

| Address | Bit | Name     | Description                                                                                                                  | Reset | Access |
|---------|-----|----------|------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x03    |     | STATUS   |                                                                                                                              | 0x10  |        |
|         | 2   | aux_busy | '1'('0') indicate a (no) Auxiliary sensor interface operation is ongoing triggered via AUX_RD_ADDR, AUX_WR_ADDR or from FCU. | 0x0   | R      |
|         | 4   | cmd_rdy  | CMD decoder status. `0´ -> Command in progress `1´ -> Command decoder is ready to accept a new command                       | 0x1   | R      |
|         | 5   | drdy_aux | Data ready for Auxiliary sensor. It gets reset, when one Auxiliary sensor DATA register is read out                          | 0x0   | R      |
|         | 6   | drdy_gyr | Data ready for Gyroscope. It gets reset, when one Gyroscope DATA register is read out                                        | 0x0   | R      |
|         | 7   | drdy_acc | Data ready for Accelerometer. It gets reset, when one Accelerometer DATA register is read out                                | 0x0   | R      |

### 5.2.4 Register (0x04) DATA\_0

DESCRIPTION: AUX\_X(LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description                                         | Reset | Access |
|---------|-----|-----------|-----------------------------------------------------|-------|--------|
| 0x04    |     | DATA_0    |                                                     | 0x00  |        |
|         | 70  | aux_x_7_0 | copy of register Val(AUX_IF[1]) in Auxiliary sensor | 0x0   | R      |
|         |     |           | register map.                                       |       |        |

### 5.2.5 Register (0x05) DATA\_1

DESCRIPTION: AUX\_X(MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name       | Description                                           | Reset | Access |
|---------|-----|------------|-------------------------------------------------------|-------|--------|
| 0x05    |     | DATA_1     |                                                       | 0x00  |        |
|         | 70  | aux_x_15_8 | copy of register Val(AUX_IF[1])+1 in Auxiliary sensor | 0x0   | R      |
|         |     |            | register map                                          |       |        |

### 5.2.6 Register (0x06) DATA\_2

DESCRIPTION: AUX\_Y(LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description                                                        | Reset | Access |
|---------|-----|-----------|--------------------------------------------------------------------|-------|--------|
| 0x06    |     | DATA_2    |                                                                    | 0x00  |        |
|         | 70  | aux_y_7_0 | copy of register Val(AUX_IF[1])+2 in Auxiliary sensor register map | 0x0   | R      |

### 5.2.7 Register (0x07) DATA\_3

DESCRIPTION: AUX\_Y(MSB)

RESET: 0x00

| Address | Bit | Name       | Description                                           | Reset | Access |
|---------|-----|------------|-------------------------------------------------------|-------|--------|
| 0x07    |     | DATA_3     |                                                       | 0x00  |        |
|         | 70  | aux_y_15_8 | copy of register Val(AUX_IF[1])+3 in Auxiliary sensor | 0x0   | R      |
|         |     |            | register map                                          |       |        |

### 5.2.8 Register (0x08) DATA\_4

DESCRIPTION: AUX\_Z(LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description                                                        | Reset | Access |
|---------|-----|-----------|--------------------------------------------------------------------|-------|--------|
| 0x08    |     | DATA_4    |                                                                    | 0x00  |        |
|         | 70  | aux_z_7_0 | copy of register Val(AUX_IF[1])+4 in Auxiliary sensor register map | 0x0   | R      |

# 5.2.9 Register (0x09) DATA\_5

DESCRIPTION: AUX\_Z(MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name       | Description                                                        | Reset | Access |
|---------|-----|------------|--------------------------------------------------------------------|-------|--------|
| 0x09    |     | DATA_5     |                                                                    | 0x00  |        |
|         | 70  | aux_z_15_8 | copy of register Val(AUX_IF[1])+5 in Auxiliary sensor register map | 0x0   | R      |

### 5.2.10 Register (0x0A) DATA\_6

DESCRIPTION: AUX\_R(LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description                                                        | Reset | Access |
|---------|-----|-----------|--------------------------------------------------------------------|-------|--------|
| 0x0A    |     | DATA_6    |                                                                    | 0x00  |        |
|         | 70  | aux_r_7_0 | copy of register Val(AUX_IF[1])+6 in Auxiliary sensor register map | 0x0   | R      |

### 5.2.11 Register (0x0B) DATA\_7

DESCRIPTION: AUX\_R(MSB)

RESET: 0x00

| Address | Bit | Name       | Description                                           | Reset | Access |
|---------|-----|------------|-------------------------------------------------------|-------|--------|
| 0x0B    |     | DATA_7     |                                                       | 0x00  |        |
|         | 70  | aux_r_15_8 | copy of register Val(AUX_IF[1])+7 in Auxiliary sensor | 0x0   | R      |
|         |     |            | register map                                          |       |        |

### 5.2.12 Register (0x0C) DATA\_8

DESCRIPTION: ACC\_X(LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description | Reset | Access |
|---------|-----|-----------|-------------|-------|--------|
| 0x0C    |     | DATA_8    |             | 0x00  |        |
|         | 70  | acc_x_7_0 |             | 0x0   | R      |

# 5.2.13 Register (0x0D) DATA\_9

DESCRIPTION: ACC\_X(MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name       | Description | Reset | Access |
|---------|-----|------------|-------------|-------|--------|
| 0x0D    |     | DATA_9     |             | 0x00  |        |
|         | 70  | acc_x_15_8 |             | 0x0   | R      |

### 5.2.14 Register (0x0E) DATA\_10

DESCRIPTION: ACC\_Y(LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description | Reset | Access |
|---------|-----|-----------|-------------|-------|--------|
| 0x0E    |     | DATA_10   |             | 0x00  |        |
|         | 70  | acc_y_7_0 |             | 0x0   | R      |

### 5.2.15 Register (0x0F) DATA\_11

DESCRIPTION: ACC\_Y(MSB)

RESET: 0x00

| Address | Bit | Name       | Description | Reset | Access |
|---------|-----|------------|-------------|-------|--------|
| 0x0F    |     | DATA_11    |             | 0x00  |        |
|         | 70  | acc_y_15_8 |             | 0x0   | R      |

5.2.16 Register (0x10) DATA\_12

DESCRIPTION: ACC\_Z(LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description | Reset | Access |
|---------|-----|-----------|-------------|-------|--------|
| 0x10    |     | DATA_12   |             | 0x00  |        |
|         | 70  | acc_z_7_0 |             | 0x0   | R      |

5.2.17 Register (0x11) DATA\_13

DESCRIPTION: ACC\_Z(MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name       | Description | Reset | Access |
|---------|-----|------------|-------------|-------|--------|
| 0x11    |     | DATA_13    |             | 0x00  |        |
|         | 70  | acc_z_15_8 |             | 0x0   | R      |

5.2.18 Register (0x12) DATA\_14

DESCRIPTION: GYR\_X(LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description | Reset | Access |
|---------|-----|-----------|-------------|-------|--------|
| 0x12    |     | DATA_14   |             | 0x00  |        |
|         | 70  | gyr_x_7_0 |             | 0x0   | R      |

5.2.19 Register (0x13) DATA\_15

DESCRIPTION: GYR\_X(MSB)

RESET: 0x00

| Address | Bit | Name       | Description | Reset | Access |
|---------|-----|------------|-------------|-------|--------|
| 0x13    |     | DATA_15    |             | 0x00  |        |
|         | 70  | gyr_x_15_8 |             | 0x0   | R      |

5.2.20 Register (0x14) DATA\_16

DESCRIPTION: GYR\_Y(LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description | Reset | Access |
|---------|-----|-----------|-------------|-------|--------|
| 0x14    |     | DATA_16   |             | 0x00  |        |
|         | 70  | gyr_y_7_0 |             | 0x0   | R      |

5.2.21 Register (0x15) DATA\_17

DESCRIPTION: GYR\_Y(MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name       | Description | Reset | Access |
|---------|-----|------------|-------------|-------|--------|
| 0x15    |     | DATA_17    |             | 0x00  |        |
|         | 70  | gyr_y_15_8 |             | 0x0   | R      |

5.2.22 Register (0x16) DATA\_18

DESCRIPTION: GYR\_Z(LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description | Reset | Access |
|---------|-----|-----------|-------------|-------|--------|
| 0x16    |     | DATA_18   |             | 0x00  |        |
|         | 70  | gyr_z_7_0 |             | 0x0   | R      |

5.2.23 Register (0x17) DATA\_19

DESCRIPTION: GYR\_Z(MSB)

RESET: 0x00

| Address | Bit | Name       | Description | Reset | Access |
|---------|-----|------------|-------------|-------|--------|
| 0x17    |     | DATA_19    |             | 0x00  |        |
|         | 70  | gyr_z_15_8 |             | 0x0   | R      |

### 5.2.24 Register (0x18) SENSORTIME\_0

DESCRIPTION: Sensor time <7:0>

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name            | Description       | Reset | Access |
|---------|-----|-----------------|-------------------|-------|--------|
| 0x18    |     | SENSORTIME_0    |                   | 0x00  |        |
|         | 70  | sensor_time_7_0 | Sensor time <7:0> | 0x0   | R      |

### 5.2.25 Register (0x19) SENSORTIME\_1

DESCRIPTION: Sensor time <15:8>

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name             | Description         | Reset | Access |
|---------|-----|------------------|---------------------|-------|--------|
| 0x19    |     | SENSORTIME_1     |                     | 0x00  |        |
|         | 70  | sensor_time_15_8 | Sensor time <15:8>. | 0x0   | R      |

### 5.2.26 Register (0x1A) SENSORTIME\_2

DESCRIPTION: Sensor time <23:16>

RESET: 0x00

| Address | Bit | Name              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reset | Access |
|---------|-----|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x1A    |     | SENSORTIME_2      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x00  |        |
|         | 70  | sensor_time_23_16 | Sensor time <23:16> The sensor time is a 24 bit counter available in suspend, low power, and normal mode. The value of the SENSORTIME register is shadowed, when it is read in a burst read with the data register at the beginning of the operation and the shadowed value is returned. When the fifo is read the register is shadowed, whenever a new frame is read. The resolution of the sensor_time is 39.0625 us, and it is synchrounous to ODR. The register wraps if it reaches 0xFFFFFF. | 0x0   | R      |

### 5.2.27 Register (0x1B) EVENT

DESCRIPTION: Sensor event flags. Will be cleared on read when bit 0 is sent out over the bus.

RESET: 0x01

DEFINITION (Go to register map):

| Address | Bit | Name         | Descri             | ption                                                       |                      | Reset | Access |
|---------|-----|--------------|--------------------|-------------------------------------------------------------|----------------------|-------|--------|
| 0x1B    |     | EVENT        |                    |                                                             |                      | 0x01  |        |
|         | 0   | por_detected | '1' after<br>read. | ' after device power up or softreset, '0' after status ead. |                      |       | R      |
|         | 42  | error_code   | Error c            | Error codes for persistent errors                           |                      |       | R      |
|         |     |              | Value              | Name                                                        | Description          |       |        |
|         |     |              | 0x00               | no_error                                                    | no error is reported |       |        |
|         |     |              | 0x01               | acc_err                                                     | error in Register    |       |        |
|         |     |              |                    |                                                             | ACC_CONF             |       |        |
|         |     |              | 0x02               | gyr_err                                                     | error in Register    |       |        |
|         |     |              |                    |                                                             | GYR_CONF             |       |        |
|         |     |              | 0x03               | acc_and_gyr_err                                             | error in Registers   |       |        |
|         |     |              |                    |                                                             | ACC_GYR & GYR_CONF   |       |        |

# 5.2.28 Register (0x1C) INT\_STATUS\_0

DESCRIPTION: Interrupt/Feature Status. Will be cleared on read.

RESET: 0x00

| Address | Bit | Name                  | Description                                    | Reset | Access |
|---------|-----|-----------------------|------------------------------------------------|-------|--------|
| 0x1C    |     | INT_STATUS_0          |                                                | 0x00  |        |
|         | 0   | sig_motion_out        | Sigmotion output.                              | 0x0   | R      |
|         | 1   | step_counter_out      | Step-counter watermark or Step-detector output | 0x0   | R      |
|         | 2   | activity_out          | Step activity output                           | 0x0   | R      |
|         | 3   | wrist_wear_wakeup_out | Wrist wear wakeup output                       | 0x0   | R      |
|         | 4   | wrist_gesture_out     | Wrist gesture output                           | 0x0   | R      |
|         | 5   | no_motion_out         | No motion detection output                     | 0x0   | R      |
|         | 6   | any_motion_out        | Any motion detection output                    | 0x0   | R      |
|         | 7   | reserved              | Reserved                                       | 0x0   | R      |

### 5.2.29 Register (0x1D) INT\_STATUS\_1

DESCRIPTION: Interrupt Status 1. Will be cleared on read when bit 0 is sent out over the bus.

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name         | Description                        | Reset | Access |
|---------|-----|--------------|------------------------------------|-------|--------|
| 0x1D    |     | INT_STATUS_1 |                                    | 0x00  |        |
|         | 0   | ffull_int    | FIFO Full Interrupt                | 0x0   | R      |
|         | 1   | fwm_int      | FIFO Watermark Interrupt           | 0x0   | R      |
|         | 2   | err_int      | ERROR Interrupt                    | 0x0   | R      |
|         | 5   | aux_drdy_int | Auxiliary Data Ready Interrupt     | 0x0   | R      |
|         | 6   | gyr_drdy_int | Gyroscope Data Ready Interrupt     | 0x0   | R      |
|         | 7   | acc_drdy_int | Accelerometer Data Ready Interrupt | 0x0   | R      |

# 5.2.30 Register (0x1E) SC\_OUT\_0

DESCRIPTION: Step counting value byte-0

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name     | Description                                         | Reset | Access |
|---------|-----|----------|-----------------------------------------------------|-------|--------|
| 0x1E    |     | SC_OUT_0 |                                                     | 0x00  |        |
|         | 70  | byte_0   | Step counting value byte-0 (least significant byte) | 0x0   | R      |

### 5.2.31 Register (0x1F) SC\_OUT\_1

DESCRIPTION: Step counting value byte-1

RESET: 0x00

| Address | Bit | Name     | Description                | Reset | Access |
|---------|-----|----------|----------------------------|-------|--------|
| 0x1F    |     | SC_OUT_1 |                            | 0x00  |        |
|         | 70  | byte_1   | Step counting value byte-1 | 0x0   | R      |

# 5.2.32 Register (0x20) WR\_GEST\_ACT

DESCRIPTION: Wrist gesture and activity detection output

RESET: 0x00

| Address | Bit | Name        | Description                                                                                                                                                                                                                                                                   | Reset | Access |
|---------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x20    |     | WR_GEST_ACT |                                                                                                                                                                                                                                                                               | 0x00  |        |
|         | 20  | wr_gest_out | Output value of the wrist gesture detection feature. Value after device initialization is 0b00 i.e. unknown gesture                                                                                                                                                           | 0x0   | R      |
|         |     |             | Value Name  0x00 unknown_gesture  0x01 push_arm_down  0x02 pivot_up  0x03 wrist_shake_jiggle  0x04 flick_in  0x05 flick_out  Description  Unknown gesture  Push arm down  gesture  Pivot up gesture  Wrist shake/jiggle  gesture  Arm flick in gesture  Arm flick out gesture |       |        |
|         | 43  | act_out     | Output value of the activity detection feature. Value after device initialization is 0b11 i.e. unknown activity  Value Name Description  0x00 still User stationary  0x01 walking User walking  0x02 running User running  0x03 unknown Unknown state                         | 0x0   | R      |

# 5.2.33 Register (0x21) INTERNAL\_STATUS

DESCRIPTION: Error bits and message indicating internal status

RESET: 0x00

| Address | Bit | Name             | Description                                 | Reset | Access |
|---------|-----|------------------|---------------------------------------------|-------|--------|
| 0x21    |     | INTERNAL_STATUS  |                                             | 0x00  |        |
|         | 30  | message          | Internal Status Message                     | 0x0   | R      |
|         |     |                  | Value Name Description                      |       |        |
|         |     |                  | 0x00 not_init ASIC is not initialized       |       |        |
|         |     |                  | 0x01 init_ok ASIC initialized               |       |        |
|         |     |                  | 0x02 init_err Initialization error          |       |        |
|         |     |                  | 0x03 drv_err Invalid driver                 |       |        |
|         |     |                  | 0x04 sns_stop Sensor stopped                |       |        |
|         |     |                  | 0x05 nvm_error Internal error while         |       |        |
|         |     |                  | accessing NVM                               |       |        |
|         |     |                  | 0x06 start_up_error Internal error while    |       |        |
|         |     |                  | accessing NVM and                           |       |        |
|         |     |                  | Initialization error                        |       |        |
|         |     |                  | 0x07 compat_error Compatibility error       |       |        |
|         | 4   | Reserved         | Reserved                                    | 0x0   | R      |
|         | 5   | axes_remap_error | Incorrect axes remapping. X,Y,Z axes must   | 0x0   | R      |
|         |     |                  | be mapped to exclusively separate axes i.e. |       |        |
|         |     |                  | they cannot be mapped to same axes.         |       |        |
|         | 6   | odr_50hz_error   | The minimum bandwidth conditions are not    | 0x0   | R      |
|         |     |                  | respected for the features which require 50 |       |        |
|         |     |                  | Hz data.                                    |       |        |
|         | 7   | Reserved         | Reserved                                    | 0x0   | R      |

#### 5.2.34 Register (0x22) TEMPERATURE\_0

DESCRIPTION: Temperature LSB; The temperature is disabled when all sensors are in suspend. The output word of the 16-bit temperature sensor is valid if the Gyroscope is in normal mode, i.e. gyr\_pmu\_status=1. The resolution is 1/2^9 K/LSB. The absolute accuracy of the temperature is in the order of:

0x7FFF -> 87-1/2^9 °C

0x0000 -> 23°C

0x8001 -> -41+1/2^9 °C

0x8000 -> invalid

If the Gyroscope is in normal mode (see register PMU\_STATUS), the temperature is updated every 10 ms (+-12%), if the gyroscope is in standby mode or fast-power up mode, the temperature is updated ever 1.28 s aligned with bit 15 of the register SENSORTIME.

RESET: 0x00

**DEFINITION** (Go to register map):

| Address | Bit | Name          | Description        | Reset | Access |
|---------|-----|---------------|--------------------|-------|--------|
| 0x22    |     | TEMPERATURE_0 |                    | 0x00  |        |
|         | 70  | tmp_data_7_0  | Temperature value. | 0x0   | R      |

#### 5.2.35 Register (0x23) TEMPERATURE\_1

DESCRIPTION: Contains the MSBs of temperature sensor value

RESET: 0x80

DEFINITION (Go to register map):

| Address | Bit | Name          | Description       | Reset | Access |
|---------|-----|---------------|-------------------|-------|--------|
| 0x23    |     | TEMPERATURE_1 |                   | 0x80  |        |
|         | 70  | tmp_data_15_8 | Temperature LSBs. | 0x80  | R      |

#### 5.2.36 Register (0x24) FIFO LENGTH 0

DESCRIPTION: FIFO byte count register (LSB)

RESET: 0x00

| Address | Bit | Name                  | Description                                      | Reset | Access |
|---------|-----|-----------------------|--------------------------------------------------|-------|--------|
| 0x24    |     | FIFO_LENGTH_0         |                                                  | 0x00  |        |
|         | 70  | fifo_byte_counter_7_0 | Current fill level of FIFO buffer                | 0x0   | R      |
|         |     |                       | This includes the skip frame for a full fifo. An |       |        |
|         |     |                       | empty FIFO corresponds to 0x000. The byte        |       |        |
|         |     |                       | counter may be reset by reading out all          |       |        |
|         |     |                       | frames from the FIFO buffer or when the          |       |        |
|         |     |                       | FIFO is reset through the register CMD. The      |       |        |
|         |     |                       | byte counter is updated each time a              |       |        |
|         |     |                       | complete frame was read or written.              |       |        |

### 5.2.37 Register (0x25) FIFO\_LENGTH\_1

DESCRIPTION: FIFO byte count register (MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name                   | Description                | Reset | Access |
|---------|-----|------------------------|----------------------------|-------|--------|
| 0x25    |     | FIFO_LENGTH_1          |                            | 0x00  |        |
|         | 50  | fifo_byte_counter_13_8 | FIFO byte counter bits 138 | 0x0   | R      |

# 5.2.38 Register (0x26) FIFO\_DATA

DESCRIPTION: FIFO data output register

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                             | Reset | Access |
|---------|-----|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x26    |     | FIFO_DATA |                                                                                                                                                                                                                                                                                                                                                                                                         | 0x00  |        |
|         | 70  | fifo_data | FIFO read data, for burst read (8 bits). Data format depends on the setting of register FIFO_CONFIG. The FIFO data are organized in frames. The new data flag is preserved. Read burst access must be used, the address will not increment when the read burst reads at the address of FIFO_DATA. When a frame is only partially read out it is retransmitted including the header at the next readout. | 0x0   | R      |

### 5.2.39 Register (0x2F) FEAT\_PAGE

DESCRIPTION: Page number for feature configuration and output registers

RESET: 0x00

| Address | Bit | Name      | Description                                            | Reset | Access |
|---------|-----|-----------|--------------------------------------------------------|-------|--------|
| 0x2F    |     | FEAT_PAGE |                                                        | 0x00  |        |
|         | 20  | page      | Map 16 feature registers to one of the 8 feature pages | 0x0   | RW     |

# 5.2.40 Register (0x30) FEATURES[16]

DESCRIPTION: Input registers for feature configuration. Output registers for feature results.

RESET: 0x00

DEFINITION (Go to register map):

| Address     | Bit     | Name        | Descri  | ption                  |                        | Reset  | Access |
|-------------|---------|-------------|---------|------------------------|------------------------|--------|--------|
| step_coun   | ter_out | out         |         |                        |                        |        |        |
| 0x30        |         | SC_OUT_0_1  | Describ | es lower word of ste   | ep counter             | 0x0000 |        |
|             | 70      | byte_0      | Value o | f step counter byte (  | )                      | 0x0    | R      |
|             | 158     | byte_1      | Value o | f step counter byte 1  | 1                      | 0x0    | R      |
|             |         |             |         |                        |                        |        |        |
| 0x32        |         | SC_OUT_2_3  | Describ | es higher word of st   | ep counter             | 0x0000 |        |
|             | 70      | byte_2      | Value c | f step counter byte 2  | 2                      | 0x0    | R      |
|             | 158     | byte_3      | Value c | f step counter byte 3  | 3                      | 0x0    | R      |
| activity_ou | ıtput   |             |         |                        |                        |        |        |
| 0x34        |         | ACT_OUT     | Describ | es activity output     |                        | 0x0000 |        |
|             | 10      | act_out     | Output  | value of the activity  | detection              | 0x0    | R      |
|             |         |             | feature | . Value after device i | nitialization is       |        |        |
|             |         |             |         | e. unknown activity    |                        |        |        |
|             |         |             |         | Name Descript          |                        |        |        |
|             |         |             | 0x00    |                        | •                      |        |        |
|             |         |             | 0x01    | walking User wal       | _                      |        |        |
|             |         |             | 0x02    | running User run       |                        |        |        |
|             |         |             | 0x03    | unknown Unknowr        | n state                |        |        |
|             |         |             |         |                        |                        |        |        |
| wrist_gest  | ure_out |             | l       |                        |                        |        |        |
| 0x36        |         | WR_GEST_OUT |         | es wrist gesture out   |                        | 0x0000 | _      |
|             | 20      | wr_gest_out |         | value of the wrist ge  |                        | 0x0    | R      |
|             |         |             |         | . Value after device i | nitialization is       |        |        |
|             |         |             |         | e. unknown gesture     | D                      |        |        |
|             |         |             |         | Name                   | Description            |        |        |
|             |         |             | UXUU    | unknown_gesture        | Unknown                |        |        |
|             |         |             | 0.01    | nuch arm dawn          | gesture                |        |        |
|             |         |             | 0x01    | push_arm_down          | Push arms down gesture |        |        |
|             |         |             | 0×02    | pivot_up               | Pivot up               |        |        |
|             |         |             | 0.02    | pivot_up               | gesture                |        |        |
|             |         |             | 0x03    | wrist_shake_jiggle     | Wrist                  |        |        |
|             |         |             | OXOG    | WIIST_SHAKE_JIBBIC     | shake/jiggle           |        |        |
|             |         |             |         |                        | gesture                |        |        |
|             |         |             | 0x04    | flick_in               | Arm flick in           |        |        |
|             |         |             |         |                        | gesture                |        |        |
|             |         |             | 0x05    | flick_out              | Arm flick out          |        |        |
|             |         |             |         |                        | gesture                |        |        |
|             |         |             |         |                        |                        |        |        |
| gyr_gain_s  | status  |             |         |                        |                        |        |        |
| O) D ~      |         |             |         |                        |                        |        |        |

| 0x38               |     | GYR_GAIN_STATUS      | Describes the saturation status for the gyroscope gain update and G_TRIGGER command status                                       | 0x0000 |   |
|--------------------|-----|----------------------|----------------------------------------------------------------------------------------------------------------------------------|--------|---|
|                    | 0   | sat_x                | This bit will be 1 if the updated gain results to saturated value based on the ratio provided for x axis, otherwise it will be 0 | 0x0    | R |
|                    | 1   | sat_y                | This bit will be 1 if the updated gain results to saturated value based on the ratio provided for y axis, otherwise it will be 0 | 0x0    | R |
|                    | 2   | sat_z                | This bit will be 1 if the updated gain results to saturated value based on the ratio provided for z axis, otherwise it will be 0 | 0x0    | R |
|                    | 53  | g_trig_status        | Status of gyroscope trigger G_TRIGGER command. These bits are updated at the end of feature execution.                           | 0x0    | R |
|                    |     |                      | Value Name  0x00 no_err  Command is valid. Selected feature has been executed and output of feature has                          |        |   |
|                    |     |                      | been updated.  0x01 precon_err Command is aborted. Precondition to start the feature was not completed.                          |        |   |
|                    |     |                      | 0x02 dl_err Command is aborted. Unsuccessful download of 2kB configuration stream.                                               |        |   |
|                    |     |                      | 0x03 abort_err Command is aborted either by host via the block bit or due to motion detection.                                   |        |   |
| Reserved           |     |                      |                                                                                                                                  |        |   |
| 0x3A               |     | Reserved             | Reserved                                                                                                                         | 0x0000 |   |
|                    | 150 | Reserved             | Reserved                                                                                                                         | 0x0    | R |
| mur no soft        |     |                      |                                                                                                                                  |        |   |
| gyr_postpr<br>0x3C | TOC | GYR_CAS              | Register for gyroscope data post                                                                                                 | 0x0000 |   |
| UASC               | 6.0 |                      | processing                                                                                                                       |        | D |
|                    | 60  | factor_zx            | Factor to further optimize the gyroscope performance                                                                             | 0x0    | R |
| Reserved           |     |                      |                                                                                                                                  |        |   |
|                    |     |                      | December                                                                                                                         | 0x0000 |   |
| UX3E               |     | Reserved             | Reserved                                                                                                                         | UXUUUU |   |
| 0x3E               | 8   | Reserved<br>Reserved | Reserved Reserved                                                                                                                | 0x0000 | R |

| 10 | Reserved | Reserved | 0x0 | R |
|----|----------|----------|-----|---|
| 11 | Reserved | Reserved | 0x0 | R |
| 12 | Reserved | Reserved | 0x0 | R |
| 13 | Reserved | Reserved | 0x0 | R |
| 14 | Reserved | Reserved | 0x0 | R |
| 15 | Reserved | Reserved | 0x0 | R |

| Address   | Bit     | Name                 | Description                                                                                                                                                                                                                                                                                 | Reset         | Access |
|-----------|---------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--------|
| general_s | ettings |                      |                                                                                                                                                                                                                                                                                             |               |        |
| 0x30      |         | Reserved             | Reserved                                                                                                                                                                                                                                                                                    | 0x0000        |        |
|           | 150     | Reserved             | Reserved                                                                                                                                                                                                                                                                                    | 0x0           | R      |
| 0x32      |         | G_TRIG_1             | Configuration for features triggered by G_TRIGGER command.                                                                                                                                                                                                                                  | 0x0000        |        |
|           | 70      | max_burst_len        | Maximum burst-write length in 16-bits words to download 2kB configuration stream of G_TRIGGER feature. Range is 0 to 255. E.g. value = 20 means that maximum burst-write length is set to 20 words or 40 bytes.                                                                             | 0x0           | RW     |
|           | 8       | select               | Select feature that should be executed  Value Name Description  0x00 gyr_bist Gyroscope built-in selftest will be executed  0x01 crt CRT will be executed                                                                                                                                   | 0x0           | RW     |
|           | 9       | block                | Block feature with next G_TRIGGER command  Value Name Description  0x00 unblock Do not block further G_TRIGGER commands  0x01 block With the next G_TRIGGER command, the ongoing selected feature will be aborted OR if a feature is not ongoing then the G_TRIGGER command will be ignored | 0x0           | RW     |
| 0x34      | 10      | GEN_SET_1 map_x_axis | Describes configuration of general features  Map the x axis to desired axis  Value Name Description  0x00 x_axis Map to x-axis 0x01 y_axis Map to y-axis 0x02 z_axis Map to z-axis 0x03 reserved Map to x-axis                                                                              | 0x0088<br>0x0 | RW     |

|           | 2      | map_x_axis_sign | Map the x axis sign to the desired one.  Value Name Description  0x00 not_invert Clear this bit to not invert the x axis                                                                                                                                                                                                          | 0x0    | RW |
|-----------|--------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----|
|           |        |                 | 0x01 invert Set this bit to invert the x axis                                                                                                                                                                                                                                                                                     |        |    |
|           | 43     | map_y_axis      | Map the y axis to desired axis  Value Name Description  0x00 x_axis Map to x-axis  0x01 y_axis Map to y-axis  0x02 z_axis Map to z-axis  0x03 reserved Map to y-axis                                                                                                                                                              | 0x1    | RW |
|           | 5      | map_y_axis_sign | Map the y axis sign to the desired one  Value Name Description  0x00 not_invert Clear this bit to not invert the y axis  0x01 invert Set this bit to invert the y axis                                                                                                                                                            | 0x0    | RW |
|           | 76     | map_z_axis      | Map the z axis to desired axis  Value Name Description  0x00 x_axis Map to x-axis  0x01 y_axis Map to y-axis  0x02 z_axis Map to z-axis  0x03 reserved Map to z-axis                                                                                                                                                              | 0x2    | RW |
|           | 8      | map_z_axis_sign | Map the z axis sign to the desired one  Value Name Description  0x00 not_invert Clear this bit to not invert the z axis  0x01 invert Set this bit to invert the z axis                                                                                                                                                            | 0x0    | RW |
|           | 9      | gyr_self_off    | Describes the self offset correction behavior  Value Name Description  0x00 disable Disable self offset correction. Host should update the gyroscope offset register.  0x01 enable Enable self offset correction. Gyroscope offset register will be updated by the device. Host should not update the gyroscope offset registers. | 0x0    | RW |
|           | 10     | nvm_prog_prep   | Prepares the system for NVM programming                                                                                                                                                                                                                                                                                           | 0x0    | RW |
| gyr_gain_ | update |                 |                                                                                                                                                                                                                                                                                                                                   |        |    |
| 0x36      |        | GYR_GAIN_UPD_1  | $\omega$ rx/ $\omega$ mx for which the gain needs to be updated.                                                                                                                                                                                                                                                                  | 0x0000 |    |

|           | 40.0 |                | l                                                                                                                                                                                                                     |        | DV |
|-----------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----|
|           | 100  | ratio_x        | gain update value for x-axis. Fixed point representation is Q(1,10) with range from 1±0.25. For example, value of 0.75 shall be represented in 11bits as 0x300 and 1.25 shall be represented in 11bits as 0x500       | 0x0    | RW |
| 0x38      |      | GYR_GAIN_UPD_2 | ωry/ωmy for which the gain needs to be updated.                                                                                                                                                                       | 0x0000 |    |
|           | 100  | ratio_y        | gain update value for y-axis. Fixed point representation is Q(1,10) with range from 1±0.25. For example, value of 0.75 shall be represented in 11bits as 0x300 and 1.25 shall be represented in 11bits as 0x500       | 0x0    | RW |
| 0x3A      |      | GYR_GAIN_UPD_3 | ωrz/ωmz for which the gain needs to be updated.                                                                                                                                                                       | 0x0000 |    |
|           | 100  | ratio_z        | gain update value for z-axis. Fixed point representation is Q(1,10) with range from 1±0.25. For example, value of 0.75 shall be represented in 11bits as 0x300 and 1.25 shall be represented in 11bits as 0x500       | 0x0    | RW |
|           | 11   | enable         | Enable the gyroscope gain update by writing a value 1 to it. Once the gain update is completed, the device will clear the bit.                                                                                        | 0x0    | RW |
| any_motio | n    |                |                                                                                                                                                                                                                       |        |    |
| 0x3C      |      | ANYMO_1        | Any-motion detection general configuration flags - part 1                                                                                                                                                             | 0xE005 |    |
|           | 120  | duration       | Defines the number of consecutive data points for which the threshold condition must be respected, for interrupt assertion. It is expressed in 50 Hz samples (20 ms). Range is 0 to 163sec. Default value is 5=100ms. | 0x5    | RW |
|           | 13   | select_x       | Selects the feature on a per-axis basis                                                                                                                                                                               | 0x1    | RW |
|           | 14   | select_y       | Selects the feature on a per-axis basis                                                                                                                                                                               | 0x1    | RW |
|           | 15   | select_z       | Selects the feature on a per-axis basis                                                                                                                                                                               | 0x1    | RW |
| 0x3E      |      | ANYMO_2        | Any-motion detection general configuration flags - part 2                                                                                                                                                             | 0x38AA |    |
|           | 100  | threshold      | Slope threshold value for any-motion detection. Range is 0 to 1g. Default value is 0xAA = 83mg.                                                                                                                       | 0xAA   | RW |
|           | 1411 | out_conf       | Enable bits for enabling output into the register status bits and, if desired, onto the interrupt pin  Value Name Description                                                                                         | 0x7    | RW |

|    |        | 0x00   |            | Output of feature not<br>assigned to any interrupt<br>bits 07 of<br>INT_STATUS_0 and<br>INT1/2_MAP_FEAT |     |    |
|----|--------|--------|------------|---------------------------------------------------------------------------------------------------------|-----|----|
|    |        | 0x01   | BIT_0      | Output assigned to bit-0                                                                                |     |    |
|    |        | 0x02   | BIT_1      | Output assigned to bit-1                                                                                |     |    |
|    |        | 0x03   | BIT_2      | Output assigned to bit-2                                                                                |     |    |
|    |        | 0x04   | BIT_3      | Output assigned to bit-3                                                                                |     |    |
|    |        | 0x05   | BIT_4      | Output assigned to bit-4                                                                                |     |    |
|    |        | 0x06   | BIT_5      | Output assigned to bit-5                                                                                |     |    |
|    |        | 0x07   | BIT_6      | Output assigned to bit-6                                                                                |     |    |
|    |        | 0x08   | BIT_7      | Output assigned to bit-7                                                                                |     |    |
| 15 | enable | Enable | s the feat | ture                                                                                                    | 0x0 | RW |

Page 2

| Address   | Bit  | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Reset  | Access |
|-----------|------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|
| no_motion | 1    |           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |        |        |
| 0x30      |      | NOMO_1    | No-motion detection general configuration flags -<br>part 1                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0xE005 |        |
|           | 120  | duration  | Defines the number of consecutive data points for which the threshold condition must be respected, for interrupt assertion. It is expressed in 50 Hz samples (20 ms). Range is 0 to 163sec. Default value is 5=100ms.                                                                                                                                                                                                                                                                                      | 0x5    | RW     |
|           | 13   | select_x  | Selects the feature on a per-axis basis                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x1    | RW     |
|           | 14   | select_y  | Selects the feature on a per-axis basis                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x1    | RW     |
|           | 15   | select_z  | Selects the feature on a per-axis basis                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x1    | RW     |
| 0x32      |      | NOMO_2    | No-motion detection general configuration flags - part 2                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x3090 |        |
|           | 100  | threshold | Slope threshold value for no-motion detection. Range is 0 to 1g. Default value is 0x90 = 70mg.                                                                                                                                                                                                                                                                                                                                                                                                             | 0x90   | RW     |
|           | 1411 | out_conf  | Enable bits for enabling output into the register status bits and, if desired, onto the interrupt pin  Value Name Description  0x00 disable Output of feature not assigned to any interrupt bits 07 of INT_STATUS_0 and INT1/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-2  0x04 BIT_3 Output assigned to bit-3  0x05 BIT_4 Output assigned to bit-4  0x06 BIT_5 Output assigned to bit-5  0x07 BIT_6 Output assigned to bit-6 | 0x6    | RW     |

|          |     |            | 0x08 BIT_7 Output assigned to bit-7                                     |        |    |
|----------|-----|------------|-------------------------------------------------------------------------|--------|----|
|          | 15  | enable     | Enables the feature                                                     | 0x0    | RW |
|          |     |            |                                                                         |        |    |
| sig_moti | on  |            |                                                                         |        |    |
| 0x34     |     | SIGMO_1    | Block size                                                              | 0x00FA |    |
|          | 150 | block_size | Defines the duration after which the significant                        | 0xFA   | RW |
|          |     |            | motion interrupt is triggered. It is expressed in 50 Hz                 |        |    |
|          |     |            | samples (20 ms). Default value is 0xFA=5sec.                            |        |    |
| 0x36     |     | Reserved   | Reserved                                                                | 0x0096 |    |
|          | 150 | Reserved   | Reserved                                                                | 0x96   | RW |
| 0x38     |     | Reserved   | Reserved                                                                | 0x094B |    |
|          | 150 | Reserved   | Reserved                                                                | 0x94B  | RW |
| 0x3A     |     | Reserved   | Reserved                                                                | 0x0011 |    |
|          | 150 | Reserved   | Reserved                                                                | 0x11   | RW |
| 0x3C     |     | Reserved   | Reserved                                                                | 0x0011 |    |
|          | 150 | Reserved   | Reserved                                                                | 0x11   | RW |
| 0x3E     |     | SIGMO_2    | Significant motion setting                                              | 0x0002 |    |
|          | 0   | enable     | Enables the feature                                                     | 0x0    | RW |
|          | 41  | out_conf   | Enable bits for enabling output into the register                       | 0x1    | RW |
|          |     |            | status bits and, if desired, onto the interrupt pin                     |        |    |
|          |     |            | Value Name Description                                                  |        |    |
|          |     |            | 0x00 disable Output of feature not assigned to                          |        |    |
|          |     |            | any interrupt bits 07 of                                                |        |    |
|          |     |            | INT_STATUS_0 and                                                        |        |    |
|          |     |            | INT1/2_MAP_FEAT                                                         |        |    |
|          |     |            | 0x01 BIT_0 Output assigned to bit-0                                     |        |    |
|          |     |            | 0x02 BIT_1 Output assigned to bit-1                                     |        |    |
|          |     |            | 0x03 BIT_2 Output assigned to bit-2                                     |        |    |
|          |     |            | 0x04 BIT_3 Output assigned to bit-3                                     |        |    |
|          |     |            | 0x05 BIT_4 Output assigned to bit-4                                     |        |    |
|          |     |            | 0x06 BIT_5 Output assigned to bit-5 0x07 BIT 6 Output assigned to bit-6 |        |    |
|          |     |            | _ ' 9                                                                   |        |    |
|          |     |            | 0x08 BIT_7 Output assigned to bit-7                                     |        |    |

Page 3

| Address   | Bit            | Name    | Description          | Reset  | Access |  |  |  |  |
|-----------|----------------|---------|----------------------|--------|--------|--|--|--|--|
| step_cour | step_counter_1 |         |                      |        |        |  |  |  |  |
| 0x30      |                | SC_1    | Step Counter setting | 0x012D |        |  |  |  |  |
|           | 150            | param_1 | Step Counter param 1 | 0x12D  | RW     |  |  |  |  |
| 0x32      |                | SC_2    | Step Counter setting | 0x7BD4 |        |  |  |  |  |
|           | 150            | param_2 | Step Counter param 2 | 0x7BD4 | RW     |  |  |  |  |
| 0x34      |                | SC_3    | Step Counter setting | 0x013B |        |  |  |  |  |
|           | 150            | param_3 | Step Counter param 3 | 0x13B  | RW     |  |  |  |  |
| 0x36      |                | SC_4    | Step Counter setting | 0x7ADB |        |  |  |  |  |
|           | 150            | param_4 | Step Counter param 4 | 0x7ADB | RW     |  |  |  |  |
| 0x38      |                | SC_5    | Step Counter setting | 0x0004 |        |  |  |  |  |

|      | 150  | param_5 | Step Counter param 5 | 0x4    | RW |
|------|------|---------|----------------------|--------|----|
| 0x3A | SC_6 |         | Step Counter setting | 0x7B3F |    |
|      | 150  | param_6 | Step Counter param 6 | 0x7B3F | RW |
| 0x3C |      | SC_7    | Step Counter setting | 0x6CCD |    |
|      | 150  | param_7 | Step Counter param 7 | 0x6CCD | RW |
| 0x3E |      | SC_8    | Step Counter setting | 0x04C3 |    |
|      | 150  | param_8 | Step Counter param 8 | 0x4C3  | RW |

Page 4

| Address   | Bit    | Name     | Description           | Reset  | Access |
|-----------|--------|----------|-----------------------|--------|--------|
| step_cour | iter_2 |          |                       |        |        |
| 0x30      |        | SC_9     | Step Counter setting  | 0x0985 |        |
|           | 150    | param_9  | Step Counter param 9  | 0x985  | RW     |
| 0x32      |        | SC_10    | Step Counter setting  | 0x04C3 |        |
|           | 150    | param_10 | Step Counter param 10 | 0x4C3  | RW     |
| 0x34      |        | SC_11    | Step Counter setting  | 0xE6EC |        |
|           | 150    | param_11 | Step Counter param 11 | 0xE6EC | RW     |
| 0x36      |        | SC_12    | Step Counter setting  | 0x460C |        |
|           | 150    | param_12 | Step Counter param 12 | 0x460C | RW     |
| 0x38      |        | SC_13    | Step Counter setting  | 0x0001 |        |
|           | 150    | param_13 | Step Counter param 13 | 0x1    | RW     |
| 0x3A      |        | SC_14    | Step Counter setting  | 0x0027 |        |
|           | 150    | param_14 | Step Counter param 14 | 0x27   | RW     |
| 0x3C      |        | SC_15    | Step Counter setting  | 0x0019 |        |
|           | 150    | param_15 | Step Counter param 15 | 0x19   | RW     |
| 0x3E      |        | SC_16    | Step Counter setting  | 0x0096 |        |
|           | 150    | param_16 | Step Counter param 16 | 0x96   | RW     |

| Address   | Bit            | Name     | Description           | Reset  | Access |  |  |  |  |
|-----------|----------------|----------|-----------------------|--------|--------|--|--|--|--|
| step_coun | step_counter_3 |          |                       |        |        |  |  |  |  |
| 0x30      |                | SC_17    | Step Counter setting  | 0x00A0 |        |  |  |  |  |
|           | 150            | param_17 | Step Counter param 17 | 0xA0   | RW     |  |  |  |  |
| 0x32      |                | SC_18    | Step Counter setting  | 0x0001 |        |  |  |  |  |
|           | 150            | param_18 | Step Counter param 18 | 0x1    | RW     |  |  |  |  |
| 0x34      |                | SC_19    | Step Counter setting  | 0x000C |        |  |  |  |  |
|           | 150            | param_19 | Step Counter param 19 | 0xC    | RW     |  |  |  |  |
| 0x36      |                | SC_20    | Step Counter setting  | 0x3CF0 |        |  |  |  |  |
|           | 150            | param_20 | Step Counter param 20 | 0x3CF0 | RW     |  |  |  |  |
| 0x38      |                | SC_21    | Step Counter setting  | 0x0100 |        |  |  |  |  |
|           | 150            | param_21 | Step Counter param 21 | 0x100  | RW     |  |  |  |  |
| 0x3A      |                | SC_22    | Step Counter setting  | 0x0001 |        |  |  |  |  |
|           | 150            | param_22 | Step Counter param 22 | 0x1    | RW     |  |  |  |  |

| 0x3C |     | SC_23    | Step Counter setting  | 0x0003 |    |
|------|-----|----------|-----------------------|--------|----|
|      | 150 | param_23 | Step Counter param 23 | 0x3    | RW |
| 0x3E |     | SC_24    | Step Counter setting  | 0x0001 |    |
|      | 150 | param_24 | Step Counter param 24 | 0x1    | RW |

| Address   | Bit    | Name                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                        | Reset  | Access |  |
|-----------|--------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|--|
| step_cour | nter_4 |                        |                                                                                                                                                                                                                                                                                                                                                                                                                                    |        |        |  |
| 0x30      |        | SC_25                  | Step Counter setting                                                                                                                                                                                                                                                                                                                                                                                                               | 0x000E |        |  |
|           | 150    | param_25               | Step Counter param 25                                                                                                                                                                                                                                                                                                                                                                                                              | 0xE    | RW     |  |
| 0x32      |        | SC_26                  | Step Counter and Step Detector<br>Settings                                                                                                                                                                                                                                                                                                                                                                                         | 0x0000 |        |  |
|           | 90     | watermark_level        | Watermark level; the Step-counter will trigger output every time this number of steps are counted. Holds implicitly a 20x factor, so the range is 0 to 20460, with resolution of 20 steps. If 0, the output is disabled.                                                                                                                                                                                                           | 0x0    | RW     |  |
|           | 10     | reset_counter          | 20x factor, so the range is 0 to 20460, with resolution of 20 steps. If 0, the output is disabled.  Step count value can be reset only when any one of features mentioned in this register is enabled.  Enables the Step Detector.  Enables the Step Counter.  Enables the activity detection(Running, Walking, Stationary, Unknown)  Step Counter and Step Detector Settings  ector Enable bits for enabling output into the  0x0 |        |        |  |
|           | 11     | en_detector            | Enables the Step Detector.                                                                                                                                                                                                                                                                                                                                                                                                         | 0x0    | RW     |  |
|           | 12     | en_counter             | Enables the Step Counter.                                                                                                                                                                                                                                                                                                                                                                                                          | 0x0    | RW     |  |
|           | 13     | en_activity            | •                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0    | RW     |  |
| 0x34      |        | SC_27                  | ·                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0032 |        |  |
|           | 30     | out_conf_step_detector | Enable bits for enabling output into the register status bits and, if desired, onto the interrupt pin  Value Name Description  0x00 disable Output of feature not assigned to any interrupt bits 07 of INT_STATUS_0 and INT1/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-2  0x04 BIT_3 Output assigned to bit-3  0x05 BIT_4 Output assigned to bit-4   | 0x2    | RW     |  |

| Ox06 BIT_5 Output assigned to bit-5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      | •   |                   | •     |         |                       |     |     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|-------------------|-------|---------|-----------------------|-----|-----|
| 0x07 BIT_6 Output assigned to bit-6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |     |                   | 0x06  | BIT_5   |                       |     |     |
| 74 out_conf_activity  Enable bits for enabling output into the register status bits and, if desired, onto the interrupt pin  Value Name 0x00 disable  Description 0x00 disable 0x00 disa    |      |     |                   | 0x07  | BIT_6   | Output assigned to    |     |     |
| 74 out_conf_activity    Enable bits for enabling output into the register status bits and, if desired, onto the interrupt pin   Value Name   Ox00   disable   Output of feature not assigned to any interrupt bits 07 of INT_STATUS_0 and INT1/2_MAP_FEAT   Ox01   BIT_0   Output assigned to bit-0   Ox02   BIT_1   Output assigned to bit-1   Ox03   BIT_2   Output assigned to bit-1   Ox04   BIT_3   Output assigned to bit-3   Ox05   BIT_4   Output assigned to bit-3   Ox06   BIT_5   Output assigned to bit-6   Ox07   BIT_6   Output assigned to bit-6   Ox08   BIT_7   Output assigned to bit-6   Ox08   BIT_7   Output assigned to bit-7   Ox08   BIT_7   Output assigned to bit-7   Output assigned to any interrupt bits 07 of INT_STATUS_0 and INT1/2_MAP_FEAT   Ox01   BIT_0 Output assigned to bit-1   Ox02   BIT_1 Output assigned to bit-1   Ox03   BIT_2 Output assigned to bit-1   Ox03   BIT_2 Output assigned to bit-1   Ox04   BIT_3 Output assigned to bit-2   Ox04   BIT_3 Output assigned to bit-2   Ox04   BIT_3 Output assigned to output assigned to bit-2   Ox04   BIT_3 Output assigned to output assigned to output assigned to output assigned to bit-2   Ox04   BIT_3 Output assigned to bit-2   Ox04   BIT_3 Output assigned to output assigned to output assigned to bit-2   Ox04   BIT_3 Output assigned to output assigned to bit-2   Ox04   BIT_3 Output assigned to bit-2   Ox04   BIT_3 Output assigned to bit-2   Ox04   BIT_3 Output assigned to bit-2   Ox04            |      |     |                   | 0208  | RIT 7   |                       |     |     |
| register status bits and, if desired, onto the interrupt pin Value Name Ox00 disable Output of feature not assigned to any interrupt bits 0.7 of INT_STATUS_0 and INTT/2_MAP_FEAT  Ox01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-3  0x05 BIT_4 Output assigned to bit-3  0x05 BIT_5 Output assigned to bit-4  0x06 BIT_5 Output assigned to bit-6  0x08 BIT_7 Output assigned to bit-7  0x08 BIT_7 Output assigned to bit-7  0x09 BIT_1 Output assigned to bit-8  0x10 BIT_2 Output assigned to bit-6  0x08 BIT_5 Output assigned to bit-7  0x10 BIT_6 Output assigned to bit-7  0x10 BIT_7 Output assigned to bit-7  0x10 BIT_7 Output assigned to bit-7  0x10 BIT_7 Output assigned to disable Output of feature not assigned to any interrupt bits 0.7 of INT_STATUS_0 and INTT/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-1  0x04 BIT_3 Output assigned to bit-1  0x05 BIT_3 Output assigned to bit-1  0x06 BIT_3 Output assigned to bit-1  0x07 BIT_3 Output assigned to bit-1  0x08 BIT_3 Output assigned to bit-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |      |     |                   | 0,000 | DI1_1   |                       |     |     |
| the interrupt pin  Value Name  0x00 disable  Ox00 disable  Over the third of  |      | 74  | out_conf_activity |       |         |                       | 0x3 | RW  |
| Value Name   Ox00   disable   Output of feature not assigned to any interrupt bits 07 of INT_STATUS_0 and INTI_2_MAP_FEAT   Ox01   BIT_0   Output assigned to bit-0   Ox02   BIT_1   Output assigned to bit-1   Ox03   BIT_2   Output assigned to bit-2   Ox04   BIT_3   Output assigned to bit-3   Ox05   BIT_4   Output assigned to bit-5   Ox06   BIT_5   Output assigned to bit-5   Ox07   BIT_6   Output assigned to bit-5   Ox08   BIT_7   Output assigned to bit-6   Ox08   BIT_7   Output assigned to bit-6   Ox08   BIT_7   Output assigned to bit-7   Ox09   Ox09   Ox09   Ox09   Ox000   Ox09       |      |     |                   | _     |         |                       |     |     |
| Ox00 disable Output of feature not assigned to any interrupt bits 0.7 of INT_STATUS_0 and INTI/2_MAP_FEAT Ox01 BIT_0 Output assigned to bit-0 Ox02 BIT_1 Output assigned to bit-0 Ox03 BIT_2 Output assigned to bit-3 Ox04 BIT_3 Output assigned to bit-3 Ox05 BIT_4 Output assigned to bit-3 Ox06 BIT_5 Output assigned to bit-5 Ox07 BIT_6 Output assigned to bit-6 Ox08 BIT_7 Output assigned to bit-7 Ox19 Ox19 Ox19 Ox19 Ox19 Ox19 Ox19 Ox19                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |     |                   |       |         |                       |     |     |
| assigned to any interrupt bits 0.7 of INT_STATUS_0 and INTT/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-1  0x04 BIT_3 Output assigned to bit-3  0x05 BIT_4 Output assigned to bit-4  0x06 BIT_5 Output assigned to bit-6  0x08 BIT_5 Output assigned to bit-6  0x08 BIT_7 Output assigned to bit-7  wrist_gesture  0x36 WR_GEST_1 Wrist_gesture configuration settings 0x0005  30 out_conf Enable bits for enabling output into the register status bits and, if desired, onto the interrupt pin  Value Name Description  0x00 disable Output of feature not assigned to any interrupt bits 0.7 of INT_STATUS_0 and INT1/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-1  0x04 BIT_3 Output assigned to bit-1  0x04 BIT_3 Output assigned to bit-1  0x05 BIT_3 Output assigned to bit-1  0x07 BIT_6 Output assigned to bit-1  0x08 BIT_7 Output assigned to bit-1  0x09 BIT_1 Output assigned to bit-1  0x09 BIT_3 Output assigned to bit-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |     |                   |       |         |                       |     |     |
| interrupt bits 07 of INT_STATUS_0 and INT1/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-1  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-3  0x05 BIT_4 Output assigned to bit-3  0x05 BIT_5 Output assigned to bit-3  0x06 BIT_5 Output assigned to bit-6  0x08 BIT_7 Output assigned to bit-6  0x08 BIT_7 Output assigned to bit-7  wrist_gesture  0x36 WR_GEST_1 Wrist_gesture configuration settings  0x0005  Enable bits for enabling output into the register status bits and, if desired, onto the interrupt pin  Value Name Description  0x00 disable Output of feature not assigned to any interrupt bits 07 of INT_STATUS_0 and INT1/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-1  0x04 BIT_3 Output assigned to bit-2  0x04 BIT_3 Output assigned to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |     |                   |       | aloubio |                       |     |     |
| NT1/2_MAP_FEAT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |     |                   |       |         | _                     |     |     |
| 0x01 BIT_0 Output assigned to bit-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |     |                   |       |         |                       |     |     |
| Dit-O   Ox02   BIT_1   Output assigned to bit-1   Ox03   BIT_2   Output assigned to bit-1   Ox04   BIT_3   Output assigned to bit-3   Over the same of the same    |      |     |                   |       |         |                       |     |     |
| wrist_gesture  0x36   WR_GEST_1   Wrist gesture configuration settings   0x0005    1x-2   0x04   BIT_3   0x05   BIT_4   0x05   BIT_5    0x06   BIT_5   0x05   BIT_6   0x05   0x05    0x07   BIT_6   0x05   0x05   0x05    0x08   BIT_7   0x05   0x05   0x05    0x09   BIT_7   0x05   0x05   0x05    0x16   WR_GEST_1   Wrist gesture configuration settings   0x0005    0x16   0x16   0x16   0x16   0x16   0x16    0x17   0x16   0x16   0x16   0x16   0x16    0x18   0x16   0x16   0x16   0x16    0x29   0x16   0x16   0x16   0x16    0x20   0x20   0x20   0x20   0x20    0x20   0x20   0x20   0x20    0x20   0x20   0x20   0x20    0x20   0x20   0x20   0x20    0x20   0x20   0x20   0x20    0x20   0x20   0x20   0x20    0x20   0x20   0x20   0x20    0x20   0x20   0x20   0x20    0x20   0x20   0x20   0x20    0x20   0x20   0x20   0x20    0x20   0x20   0x20   0x20    0x20   0x20   0x20   0x20    0x20   0x20   0x20   0x20    0x20   0x20   0x20   0x20    0x20   0x20   0x20   0x20    0x20   0x20   0x20   0x20    0x20   0x20   0x20   0x20    0x20   0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x20   0x20   0x20    0x2 |      |     |                   | 0x01  | BIT_0   |                       |     |     |
| bit-2  0x04 BIT_3 Output assigned to bit-3  0x05 BIT_4 Output assigned to bit-4  0x06 BIT_5 Output assigned to bit-5  0x07 BIT_6 Output assigned to bit-6  0x08 BIT_7 Output assigned to bit-7  wrist_gesture  0x36 WR_GEST_1 Wrist gesture configuration settings 0x0005  30 out_conf Enable bits for enabling output into the register status bits and, if desired, onto the interrupt pin  Value Name Description  0x00 disable Output of feature not assigned to any interrupt bits 07 of INT_STATUS_0 and INT1/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-2  0x04 BIT_3 Output assigned to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |     |                   | 0x02  | BIT_1   |                       |     |     |
| bit-3  0x05 BIT_4 Output assigned to bit-4  0x06 BIT_5 Output assigned to bit-5  0x07 BIT_6 Output assigned to bit-6  0x08 BIT_7 Output assigned to bit-7  wrist_gesture  0x36 WR_GEST_1 Wrist gesture configuration settings 0x0005  30 out_conf Enable bits for enabling output into the register status bits and, if desired, onto the interrupt pin  Value Name Description  0x00 disable Output of feature not assigned to any interrupt bits 07 of INT_STATUS_0 and INT1/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-2  0x04 BIT_3 Output assigned to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |      |     |                   | 0x03  | BIT_2   |                       |     |     |
| wrist_gesture  0x36  WR_GEST_1  Output assigned to bit-5  0x08 BIT_7  Output assigned to bit-7  Wrist_gesture  0x36  WR_GEST_1  Wrist gesture configuration settings  30  out_conf  Enable bits for enabling output into the register status bits and, if desired, onto the interrupt pin  Value Name  0x00 disable  0x00 disable  Description  Output of feature not assigned to any interrupt bits 07 of INT_STATUS_0 and INT1/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-0  0x03 BIT_2 Output assigned to bit-2  0x04 BIT_3 Output assigned to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |     |                   | 0x04  | BIT_3   |                       |     |     |
| wrist_gesture  Ox36                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |     |                   | 0x05  | BIT_4   |                       |     |     |
| wrist_gesture  0x36                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |     |                   | 0x06  | BIT_5   |                       |     |     |
| wrist_gesture    WR_GEST_1   Wrist gesture configuration settings   0x0005     30   out_conf   Enable bits for enabling output into the register status bits and, if desired, onto the interrupt pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |     |                   | 0x07  | BIT_6   |                       |     |     |
| wrist_gesture  0x36  WR_GEST_1  Wrist gesture configuration settings  30  out_conf  Enable bits for enabling output into the register status bits and, if desired, onto the interrupt pin  Value Name Description  0x00 disable Output of feature not assigned to any interrupt bits 07 of INT_STATUS_0 and INT1/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-2  0x04 BIT_3 Output assigned to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |     |                   | 0x08  | BIT_7   | Output assigned to    |     |     |
| Ox36  WR_GEST_1 Wrist gesture configuration settings Ox0005  Enable bits for enabling output into the register status bits and, if desired, onto the interrupt pin  Value Name Description Ox00 disable Output of feature not assigned to any interrupt bits 07 of INT_STATUS_0 and INT1/2_MAP_FEAT Ox01 BIT_0 Output assigned to bit-0  Ox02 BIT_1 Output assigned to bit-1 Ox03 BIT_2 Output assigned to bit-2 Ox04 BIT_3 Output assigned to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |     |                   |       |         | bit-7                 |     |     |
| 30 out_conf  Enable bits for enabling output into the register status bits and, if desired, onto the interrupt pin  Value Name Description  0x00 disable Output of feature not assigned to any interrupt bits 07 of INT_STATUS_0 and INT1/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-2  0x04 BIT_3 Output assigned to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      | ure | Luip 0507 4       | l     |         | <b>6</b>              |     |     |
| register status bits and, if desired, onto the interrupt pin  Value Name Description  0x00 disable Output of feature not assigned to any interrupt bits 07 of INT_STATUS_0 and INT1/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-2  0x04 BIT_3 Output assigned to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x36 | 2 0 |                   |       |         |                       |     | DW  |
| the interrupt pin  Value Name Description  0x00 disable Output of feature not assigned to any interrupt bits 07 of INT_STATUS_0 and INT1/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-2  0x04 BIT_3 Output assigned to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      | 30  | out_com           |       |         |                       | UXS | HVV |
| Value Name Description  0x00 disable Output of feature not assigned to any interrupt bits 07 of INT_STATUS_0 and INT1/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-2  0x04 BIT_3 Output assigned to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |     |                   | _     |         |                       |     |     |
| assigned to any interrupt bits 07 of INT_STATUS_0 and INT1/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-2  0x04 BIT_3 Output assigned to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |     |                   |       |         |                       |     |     |
| interrupt bits 07 of INT_STATUS_0 and INT1/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-2  0x04 BIT_3 Output assigned to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |     |                   | 0x00  | disable | Output of feature not |     |     |
| INT_STATUS_0 and INT1/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-2  0x04 BIT_3 Output assigned to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |     |                   |       |         |                       |     |     |
| INT1/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-2  0x04 BIT_3 Output assigned to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |     |                   |       |         | •                     |     |     |
| 0x01 BIT_0 Output assigned to bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-2  0x04 BIT_3 Output assigned to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |      |     |                   |       |         |                       |     |     |
| bit-0  0x02 BIT_1 Output assigned to bit-1  0x03 BIT_2 Output assigned to bit-2  0x04 BIT_3 Output assigned to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |     |                   | 0x01  | BIT 0   |                       |     |     |
| 0x02 BIT_1 Output assigned to bit-1 0x03 BIT_2 Output assigned to bit-2 0x04 BIT_3 Output assigned to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |     |                   |       |         |                       |     |     |
| bit-2 0x04 BIT_3 Output assigned to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |     |                   | 0x02  | BIT_1   |                       |     |     |
| 0x04 BIT_3 Output assigned to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |     |                   | 0x03  | BIT_2   | •                     |     |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |     |                   | 0x04  | BIT_3   |                       |     |     |

|          |      |                   | 0x05                                    | BIT_4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                              |          |     |
|----------|------|-------------------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|----------|-----|
|          |      |                   |                                         | D.T                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | bit-4                                                                                                                        |          |     |
|          |      |                   | 0x06                                    | BIT_5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Output assigned to bit-5                                                                                                     |          |     |
|          |      |                   | 0x07                                    | BIT_6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Output assigned to bit-6                                                                                                     |          |     |
|          |      |                   | 0x08                                    | BIT_7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Output assigned to bit-7                                                                                                     |          |     |
|          | 4    | wearable_arm      | default                                 | , the wea<br>ed to be                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ) or right (1) arm. By<br>arable device is<br>in left arm i.e. default                                                       | 0x0      | RW  |
|          | 5    | enable            | Enable                                  | s the fea                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ture                                                                                                                         | 0x0      | RW  |
| 0x38     |      | WR_GEST_2         | Wrist g                                 | esture s                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | etting                                                                                                                       | 0x06EE   |     |
|          | 150  | min_flick_peak    | down of is rolled configuration 2048 i. | the minidirection displays (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in a section parties of the controller) the controller (in | 0x6EE                                                                                                                        | RW       |     |
| 0x3A     |      | WR_GEST_3         | Wrist g                                 | esture s                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | etting                                                                                                                       | 0x0004   |     |
|          | 150  | min_flick_samples | between movem is 3 to 0.1 sec           | en wrist r<br>nent durii<br>5 sample                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | um time difference<br>oll-out and roll-in<br>ng flick gesture. Range<br>es at 50Hz (i.e. 0.06 to<br>Default value is 4 (i.e. | 0x4      | RW  |
| 0x3C     |      | WR_GEST_4         | Wrist g                                 | esture s                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | etting                                                                                                                       | 0x00C8   |     |
|          | 150  | max_duration      | movem<br>is 150                         | nent has<br>to 250 sa<br>nds). De                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | within which gesture<br>to be completed. Range<br>amples at 50Hz (i.e. 3 to<br>fualt value is 200 (i.e. 4                    | 0xC8     | RW  |
| D .      |      |                   |                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                              | <u> </u> |     |
| Reserved |      | Decembed          |                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                              | L 00000  |     |
| 0x3E     | 15 0 | Reserved          | Reserv                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                              | 0x0000   | DVA |
|          | 150  | Reserved          | Reserv                                  | ed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                              | 0x0      | RW  |

Page 7

| Address   | Bit     | Name            | Description                                                                                                                                                                                                                                                                                                     | Reset  | Access |
|-----------|---------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|
| wrist_wea | r_wakeı | ıp              |                                                                                                                                                                                                                                                                                                                 |        |        |
| 0x30      |         | WR_WAKEUP_1     | Wrist wear wakeup configuration settings                                                                                                                                                                                                                                                                        | 0x0004 |        |
|           | 30      | out_conf        | Enable bits for enabling output into the register status bits and, if desired, onto the interrupt pin  Value Name Description  0x00 disable Output of feature not assigned to any interrupt bits 07 of  INT_STATUS_0 and  INT1/2_MAP_FEAT  0x01 BIT_0 Output assigned to bit-0                                  | 0x4    | RW     |
|           |         |                 | 0x02 BIT_1 Output assigned to bit-1 0x03 BIT_2 Output assigned to bit-2 0x04 BIT_3 Output assigned to bit-3 0x05 BIT_4 Output assigned to bit-4 0x06 BIT_5 Output assigned to bit-5 0x07 BIT_6 Output assigned to bit-6 0x08 BIT_7 Output assigned to bit-7                                                     |        |        |
|           | 4       | enable          | Enables the feature                                                                                                                                                                                                                                                                                             | 0x0    | RW     |
| 0x32      |         | WR_WAKEUP_2     | Wrist wear wakeup setting                                                                                                                                                                                                                                                                                       | 0x05A8 |        |
|           | 150     | min_angle_focus | Cosine of minimum expected attitude change of the device within 1 second time window when moving within focus position. The parameter is scaled by 2048 i.e. 2048 * cos(angle). Range is 1024 to 1774. Default is 1448.                                                                                         | 0x5A8  | RW     |
| 0x34      |         | WR_WAKEUP_3     | Wrist wear wakeup setting                                                                                                                                                                                                                                                                                       | 0x06EE |        |
|           | 150     |                 | Cosine of minimum expected attitude change of the device within 1 second time window when moving from non-focus to focus position. The parameter is scaled by 2048 i.e. 2048 * cos(angle). Range is 1448 to 1856. Default value is 1774.                                                                        | 0x6EE  | RW     |
| 0x36      |         | WR_WAKEUP_4     | Wrist wear wakeup setting                                                                                                                                                                                                                                                                                       | 0x0400 |        |
|           | 150     | max_tilt_lr     | Sine of the maximum allowed downward tilt angle in landscape right direction of the device, when it is in focus position (i.e. user is able to comfortably look at the dial of wear device). The configuration parameter is scaled by 2048 i.e. 2048 * sin(angle). Range is 700 to 1024. Default value is 1024. | 0x400  | RW     |
| 0x38      |         | WR_WAKEUP_5     | Wrist wear wakeup setting                                                                                                                                                                                                                                                                                       | 0x02BC |        |
|           | 150     | max_tilt_ll     | Sine of the maximum allowed downward tilt angle in landscape left direction of the                                                                                                                                                                                                                              | 0x2BC  | RW     |

|          |     |             | device, when it is in focus position (i.e. user is able to comfortably look at the dial of wear device). The configuration parameter is scaled by 2048 i.e. 2048 * sin(angle). Range is 700 to 1024. Default value is 700.                                                                                  |        |    |
|----------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----|
| 0x3A     |     | WR_WAKEUP_6 | Wrist wear wakeup setting                                                                                                                                                                                                                                                                                   | 0x00B3 |    |
|          | 150 | max_tilt_pd | Sine of the maximum allowed backward tilt angle in portrait down direction of the device, when it is in focus position (i.e. user is able to comfortably look at the dial of wear device). The configuration parameter is scaled by 2048 i.e. 2048 * sin(angle). Range is 0 to179. Default value is 179.    | 0xB3   | RW |
| 0x3C     |     | WR_WAKEUP_7 | Wrist wear wakeup setting                                                                                                                                                                                                                                                                                   | 0x0785 |    |
|          | 150 | max_tilt_pu | Sine of the maximum allowed forward tilt angle in portrait up direction of the device, when it is in focus position (i.e. user is able to comfortably look at the dial of wear device). The configuration parameter is scaled by 2048 i.e. 2048 * sin(angle). Range is 1774 to 1978. Default value is 1925. | 0x785  | RW |
|          |     |             |                                                                                                                                                                                                                                                                                                             |        |    |
| Reserved |     |             |                                                                                                                                                                                                                                                                                                             |        |    |
| 0x3E     |     | Reserved    | Reserved                                                                                                                                                                                                                                                                                                    | 0x0000 |    |
|          | 150 | Reserved    | Reserved                                                                                                                                                                                                                                                                                                    | 0x0    | RW |

# 5.2.41 Register (0x40) ACC\_CONF

DESCRIPTION: Sets the output data rate, the bandwidth, and the read mode of the acceleration sensor RESET: 0xA8

| Address | Bit | Name     | Descri  | ption                                                               |                                            | Reset | Access |
|---------|-----|----------|---------|---------------------------------------------------------------------|--------------------------------------------|-------|--------|
| 0x40    |     | ACC_CONF |         |                                                                     |                                            | 0xA8  |        |
|         | 30  | acc_odr  | the pov | ver mode s Name reserved odr_0p78 odr_1p5 odr_3p1 odr_6p25 odr_12p5 | Reserved<br>25/32<br>25/16<br>25/8<br>25/4 | 0x8   | RW     |

|   | ı  |                 |          |             |                                      | 1   | ı    |
|---|----|-----------------|----------|-------------|--------------------------------------|-----|------|
|   |    |                 | 0x07     | odr_50      | 50                                   |     |      |
|   |    |                 | 0x08     | odr_100     | 100                                  |     |      |
|   |    |                 | 0x09     | odr_200     | 200                                  |     |      |
|   |    |                 | 0x0a     | odr_400     | 400                                  |     |      |
|   |    |                 | 0x0b     | odr_800     | 800                                  |     |      |
|   |    |                 | 0x0c     | odr_1k6     | 1600                                 |     |      |
|   |    |                 | 0x0d     | odr_3k2     | Reserved                             |     |      |
|   |    |                 | 0x0e     | odr_6k4     | Reserved                             |     |      |
|   |    |                 | 0x0f     | odr_12k8    | Reserved                             |     |      |
| 6 | 64 | acc_bwp         | Bandwi   | idth parame | eter determines filter configuration | 0x2 | RW   |
|   |    |                 | (acc_fil | t_perf=1) a | nd averaging for undersampling       |     |      |
|   |    |                 | _        | acc_filt_pe |                                      |     |      |
|   |    |                 |          | Name        | Description                          |     |      |
|   |    |                 | 0x00     | osr4_avg1   | -                                    |     |      |
|   |    |                 |          |             | mode; acc_filt_perf = 0 -> no        |     |      |
|   |    |                 |          |             | averaging                            |     |      |
|   |    |                 | 0x01     | osr2_avg2   | 5 5                                  |     |      |
|   |    |                 |          |             | mode; acc filt perf = 0 ->           |     |      |
|   |    |                 |          |             | average 2 samples                    |     |      |
|   |    |                 | 0x02     | norm_avg    |                                      |     |      |
|   |    |                 |          |             | mode; acc_filt_perf = 0 ->           |     |      |
|   |    |                 |          |             | average 4 samples                    |     |      |
|   |    |                 | 0x03     | cic_avg8    | acc_filt_perf = 1 -> CIC mode;       |     |      |
|   |    |                 | σχοσ     | 0.0_0.00    | acc_filt_perf = 0 -> average 8       |     |      |
|   |    |                 |          |             | samples                              |     |      |
|   |    |                 | 0x04     | res_avg16   | •                                    |     |      |
|   |    |                 | 0,04     | ics_avgic   | acc_filt_perf = 0 -> average         |     |      |
|   |    |                 |          |             | 16 samples                           |     |      |
|   |    |                 | 0x05     | res_avg32   | ·                                    |     |      |
|   |    |                 | 0,00     | 103_avg02   | acc_filt_perf = 0 -> average         |     |      |
|   |    |                 |          |             | 32 samples                           |     |      |
|   |    |                 | 0x06     | res_avg64   |                                      |     |      |
|   |    |                 | 0,00     | 163_avg04   | acc_filt_perf = 0 -> average         |     |      |
|   |    |                 |          |             | 64 samples                           |     |      |
|   |    |                 | 0x07     | res avala   | 28 acc_filt_perf = 1 -> Reserved;    |     |      |
|   |    |                 | 0.07     | ies_avg12   | acc_filt_perf = 0 -> average         |     |      |
|   |    |                 |          |             | 128 samples                          |     |      |
| 7 | 7  | acc filter part | Coloot   | 20000000000 | •                                    | 0.4 | D\A/ |
|   | '  | acc_filter_perf |          |             | eter filter performance mode:        | 0x1 | RW   |
|   |    |                 |          | Name De     | -                                    |     |      |
|   |    |                 | 0x00     |             | wer optimized                        |     |      |
|   |    |                 | 0x01     | hp pe       | rformance opt.                       |     |      |

### 5.2.42 Register (0x41) ACC\_RANGE

DESCRIPTION: Selection of the Accelerometer g-range

RESET: 0x02

DEFINITION (Go to register map):

| Address | Bit | Name      | Descri  | ption       |             | Reset | Access |
|---------|-----|-----------|---------|-------------|-------------|-------|--------|
| 0x41    |     | ACC_RANGE |         |             |             | 0x02  |        |
|         | 10  | acc_range | Accelei | ometer g-ra | nge         | 0x2   | RW     |
|         |     |           | Value   | Name        | Description |       |        |
|         |     |           | 0x00    | range_2g    | +/-2g       |       |        |
|         |     |           | 0x01    | range_4g    | +/-4g       |       |        |
|         |     |           | 0x02    | range_8g    | +/-8g       |       |        |
|         |     |           | 0x03    | range_16g   | +/-16g      |       |        |

#### 5.2.43 Register (0x42) GYR\_CONF

DESCRIPTION: Sets the output data rate and the bandwidth of the Gyroscope in the sensor

RESET: 0xA9

| Address | Bit | Name     | Description                                        | Reset | Access |
|---------|-----|----------|----------------------------------------------------|-------|--------|
| 0x42    |     | GYR_CONF |                                                    | 0xA9  |        |
|         | 30  | gyr_odr  | ODR in Hz                                          | 0x9   | RW     |
|         |     |          | Value Name Description                             |       |        |
|         |     |          | 0x00 reserved Reserved                             |       |        |
|         |     |          | 0x01 odr_0p78 Reserved                             |       |        |
|         |     |          | 0x02 odr_1p5 Reserved                              |       |        |
|         |     |          | 0x03 odr_3p1 Reserved                              |       |        |
|         |     |          | 0x04 odr_6p25 Reserved                             |       |        |
|         |     |          | 0x05 odr_12p5 Reserved                             |       |        |
|         |     |          | 0x06 odr_25 25                                     |       |        |
|         |     |          | 0x07 odr_50 50                                     |       |        |
|         |     |          | 0x08 odr_100 100                                   |       |        |
|         |     |          | 0x09 odr_200 200                                   |       |        |
|         |     |          | 0x0a odr_400 400                                   |       |        |
|         |     |          | 0x0b odr_800 800                                   |       |        |
|         |     |          | 0x0c odr_1k6 1600                                  |       |        |
|         |     |          | 0x0d odr_3k2 3200                                  |       |        |
|         |     |          | 0x0e odr_6k4 Reserved                              |       |        |
|         |     |          | 0x0f odr_12k8 Reserved                             |       |        |
|         | 54  | gyr_bwp  | The Gyroscope bandwidth coefficient defines the 3  | 0x2   | RW     |
|         |     |          | dB cutoff frequency of the low pass filter for the |       |        |
|         |     |          | sensor data                                        |       |        |
|         |     |          | Value Name Description                             |       |        |
|         |     |          | 0x00 osr4 OSR4 mode                                |       |        |
|         |     |          | 0x01 osr2 OSR2 mode                                |       |        |

|   |                 | 0x02   | norm     | normal mode                 |     |    |
|---|-----------------|--------|----------|-----------------------------|-----|----|
|   |                 | 0x03   | res      | reserved                    |     |    |
| 6 | gyr_noise_perf  | Select | noise pe | erformance:                 | 0x0 | RW |
|   |                 | Value  | Name     | Description                 |     |    |
|   |                 | 0x00   | ulp      | power optimized             |     |    |
|   |                 | 0x01   | hp       | performance opt.            |     |    |
| 7 | gyr_filter_perf | Select | gyrosco  | pe filter performance mode: | 0x1 | RW |
|   |                 | Value  | Name     | Description                 |     |    |
|   |                 | 0x00   | ulp      | power optimized             |     |    |
|   |                 | 0x01   | hp       | performance opt.            |     |    |

# 5.2.44 Register (0x43) GYR\_RANGE

DESCRIPTION: Defines the Gyroscope angular rate measurement range

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description                                                               | Reset | Access |
|---------|-----|-----------|---------------------------------------------------------------------------|-------|--------|
| 0x43    |     | GYR_RANGE |                                                                           | 0x00  |        |
|         | 20  | gyr_range | Full scale, Resolution: applies to filtered FIFO data and DATA registers. | 0x0   | RW     |
|         |     |           | Value Name Description                                                    |       |        |
|         |     |           | 0x00 range_2000 +/-2000dps, 16.4 LSB/dps                                  |       |        |
|         |     |           | 0x01 range_1000 +/-1000dps, 32.8 LSB/dps                                  |       |        |
|         |     |           | 0x02 range_500 +/-500dps, 65.6 LSB/dps                                    |       |        |
|         |     |           | 0x03 range_250 +/-250dps, 131.2 LSB/dps                                   |       |        |
|         |     |           | 0x04 range_125 +/-125dps, 262.4 LSB/dps                                   |       |        |
|         | 3   | ois_range | Full scale, Resolution: applies to pre-filtered FIFO                      | 0x0   | RW     |
|         |     |           | data and OIS data.                                                        |       |        |
|         |     |           | Value Name Description                                                    |       |        |
|         |     |           | 0x00 range_250 +/-250dps, 131.2 LSB/dps                                   |       |        |
|         |     |           | 0x01 range_2000 +/-2000dps, 16.4 LSB/dps                                  |       |        |

### 5.2.45 Register (0x44) AUX\_CONF

DESCRIPTION: Sets the output data rate of the Auxiliary sensor interface

RESET: 0x46

| Address | Bit | Name     | Description                                                                                                                                                                                                                                                                                                                              | Reset | Access |
|---------|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x44    |     | AUX_CONF |                                                                                                                                                                                                                                                                                                                                          | 0x46  |        |
|         | 30  | aux_odr  | define the poll rate for the magnetormeter attached to the Auxiliary sensor interface. This is independent of the power mode setting for the sensor. The output data rate in Hz. In addition to setting the poll rate, it is required to configure the Auxiliary sensor properly using the AUX_IF_CONF register.  Value Name Description | 0x6   | RW     |

| RW  |
|-----|
|     |
|     |
| T . |

# 5.2.46 Register (0x45) FIFO\_DOWNS

DESCRIPTION: Configure Gyroscope and Accelerometer downsampling rates for FIFO

RESET: 0x88

| Address | Bit | Name               | Description                                                | Reset | Access |
|---------|-----|--------------------|------------------------------------------------------------|-------|--------|
| 0x45    |     | FIFO_DOWNS         |                                                            | 0x88  |        |
|         | 20  | gyr_fifo_downs     | Downsampling for Gyroscope (2**downs_gyro)                 | 0x0   | RW     |
|         | 3   | gyr_fifo_filt_data | selects filtered or unfiltered Gyroscope data for fifo     | 0x1   | RW     |
|         |     |                    | Value Name Description                                     |       |        |
|         |     |                    | 0x00 unfiltered Unfiltered data                            |       |        |
|         |     |                    | 0x01 filtered Filtered data                                |       |        |
|         | 64  | acc_fifo_downs     | Downsampling for Accelerometer (2**downs_accel)            | 0x0   | RW     |
|         | 7   | acc_fifo_filt_data | selects filtered or unfiltered Accelerometer data for fifo | 0x1   | RW     |
|         |     |                    | Value Name Description                                     |       |        |
|         |     |                    | 0x00 unfiltered Unfiltered data                            |       |        |
|         |     |                    | 0x01 filtered Filtered data                                |       |        |

5.2.47 Register (0x46) FIFO\_WTM\_0

DESCRIPTION: FIFO Watermark level LSB

RESET: 0x00

DEFINITION (Go to register map):

| Addres | Bit | Name               | Description                                | Rese | Acces |
|--------|-----|--------------------|--------------------------------------------|------|-------|
| S      |     |                    |                                            | t    | S     |
| 0x46   |     | FIFO_WTM_0         |                                            | 0x00 |       |
|        | 7   | fifo_water_mark_7_ | Trigger an interrupt when FIFO contains    | 0x0  | RW    |
|        | 0   | 0                  | fifo_water_mark_7_0+fifo_water_mark_12_8*2 |      |       |
|        |     |                    | 56 bytes                                   |      |       |

5.2.48 Register (0x47) FIFO\_WTM\_1

DESCRIPTION: FIFO Watermark level MSB and frame content configuration

RESET: 0x02

DEFINITION (Go to register map):

| Addres | Bit    | Name                     | Description                                                                                 | Rese | Acces |
|--------|--------|--------------------------|---------------------------------------------------------------------------------------------|------|-------|
| S      |        |                          |                                                                                             | t    | S     |
| 0x47   |        | FIFO_WTM_1               |                                                                                             | 0x02 |       |
|        | 4<br>0 | fifo_water_mark_12_<br>8 | Trigger an interrupt when FIFO contains fifo_water_mark_7_0+fifo_water_mark_12_8* 256 bytes | 0x2  | RW    |

5.2.49 Register (0x48) FIFO\_CONFIG\_0

DESCRIPTION: FIFO frame content configuration

RESET: 0x02

| Address | Bit | Name              | Description                                       | Reset | Access |
|---------|-----|-------------------|---------------------------------------------------|-------|--------|
| 0x48    |     | FIFO_CONFIG_0     |                                                   | 0x02  |        |
|         | 0   | fifo_stop_on_full | Stop writing samples into FIFO when FIFO is full. | 0x0   | RW     |
|         |     |                   | Value Name Description                            |       |        |
|         |     |                   | 0x00 disable do not stop writing to FIFO when     |       |        |
|         |     |                   | full                                              |       |        |
|         |     |                   | 0x01 enable Stop writing into FIFO when full.     |       |        |
|         | 1   | fifo_time_en      | Return sensortime frame after the last valid data | 0x1   | RW     |
|         |     |                   | frame.                                            |       |        |
|         |     |                   | Value Name Description                            |       |        |
|         |     |                   | 0x00 disable do not return sensortime frame       |       |        |
|         |     |                   | 0x01 enable return sensortime frame               |       |        |

5.2.50 Register (0x49) FIFO\_CONFIG\_1

DESCRIPTION: FIFO frame content configuration

RESET: 0x10

| Address | Bit | Name             | Descri  | ption       |                                                                 | Reset | Access |
|---------|-----|------------------|---------|-------------|-----------------------------------------------------------------|-------|--------|
| 0x49    |     | FIFO_CONFIG_1    |         |             |                                                                 | 0x10  |        |
|         | 10  | fifo_tag_int1_en | FIFO ir | terrupt 1 t | ag enable                                                       | 0x0   | RW     |
|         |     |                  |         | Name        | Description                                                     |       |        |
|         |     |                  | 0x00    | int_edge    | enable tag on rising edge of                                    |       |        |
|         |     |                  |         |             | int pin                                                         |       |        |
|         |     |                  | 0x01    | int_level   | enable tag on level value of                                    |       |        |
|         |     |                  | 0.00    |             | int pin                                                         |       |        |
|         |     |                  | 0x02    | acc_sat     | _                                                               |       |        |
|         |     |                  | 0,02    | aur oot     | accelerometer data                                              |       |        |
|         |     |                  | 0x03    | gyr_sat     | enable tag on saturation of gyroscope data                      |       |        |
|         | 32  | fifo_tag_int2_en | FIFO ir | tarrunt 2 t | ag enable                                                       | 0x0   | RW     |
|         | 02  | mo_tag_mtz_en    |         | Name        | _                                                               |       | 1144   |
|         |     |                  | 0x00    |             | enable tag on rising edge of                                    |       |        |
|         |     |                  |         |             | int pin                                                         |       |        |
|         |     |                  | 0x01    | int_level   | •                                                               |       |        |
|         |     |                  |         |             | int pin                                                         |       |        |
|         |     |                  | 0x02    | acc_sat     | _                                                               |       |        |
|         |     |                  |         |             | accelerometer data                                              |       |        |
|         |     |                  | 0x03    | gyr_sat     | _                                                               |       |        |
|         | _   |                  |         |             | gyroscope data                                                  |       |        |
|         | 4   | fifo_header_en   |         | ame head    |                                                                 | 0x1   | RW     |
|         |     |                  | 0x00    |             | Description                                                     |       |        |
|         |     |                  | UXUU    |             | no header is stored (output<br>data rate of all enabled sensors |       |        |
|         |     |                  |         |             | need to be identical)                                           |       |        |
|         |     |                  | 0x01    |             | header is stored                                                |       |        |
|         | 5   | fifo_aux_en      |         |             | ensor data in FIFO (all 3 axes)                                 | 0x0   | RW     |
|         |     | - · · - ·        |         | _           | Description                                                     |       |        |
|         |     |                  | 0x00    |             | no Auxiliary sensor data is                                     |       |        |
|         |     |                  |         | 9           | stored                                                          |       |        |
|         |     |                  | 0x01    | enable /    | Auxiliary sensor data is stored                                 |       |        |
|         | 6   | fifo_acc_en      |         |             | eter data in FIFO (all 3 axes)                                  | 0x0   | RW     |
|         |     |                  |         |             | Description                                                     |       |        |
|         |     |                  | 0x00    |             | no Accelerometer data is                                        |       |        |
|         |     |                  | 001     |             | stored                                                          |       |        |
|         | 7   | £;£              | 0x01    |             | Accelerometer data is stored                                    | 00    | D\A/   |
|         | 7   | fifo_gyr_en      |         | •           | data in FIFO (all 3 axes)                                       | 0x0   | RW     |
|         |     |                  | 0x00    |             | <b>Description</b><br>no Gyroscope data is stored               |       |        |
|         |     |                  | 0x00    |             | Gyroscope data is stored                                        |       |        |
|         |     |                  | 0.01    | CHADIC V    | dyroscope data is stored                                        |       |        |

#### 5.2.51 Register (0x4A) SATURATION

DESCRIPTION: Contains the information if one of the raw data samples used to generate current filtered data sample has been saturated (reached 0x8001 or 0x7FFF). The register is updated synchronous to the corresponding data registers in DATA\_0..19.

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name       | Description                          | Reset | Access |
|---------|-----|------------|--------------------------------------|-------|--------|
| 0x4A    |     | SATURATION |                                      | 0x00  |        |
|         | 0   | acc_x      | ACC X-axis raw data saturation flag. | 0x0   | R      |
|         | 1   | acc_y      | ACC Y-axis raw data saturation flag. | 0x0   | R      |
|         | 2   | acc_z      | ACC Z-axis raw data saturation flag. | 0x0   | R      |
|         | 3   | gyr_x      | GYR X-axis raw data saturation flag. | 0x0   | R      |
|         | 4   | gyr_y      | GYR Y-axis raw data saturation flag. | 0x0   | R      |
|         | 5   | gyr_z      | GYR Z-axis raw data saturation flag. | 0x0   | R      |

#### 5.2.52 Register (0x4B) AUX\_DEV\_ID

DESCRIPTION: Auxiliary interface device\_id

RESET: 0x20

DEFINITION (Go to register map):

| Address | Bit | Name            | Description                            | Reset | Access |
|---------|-----|-----------------|----------------------------------------|-------|--------|
| 0x4B    |     | AUX_DEV_ID      |                                        | 0x20  |        |
|         | 71  | i2c_device_addr | I2C device address of Auxiliary sensor | 0x10  | RW     |

### 5.2.53 Register (0x4C) AUX\_IF\_CONF

DESCRIPTION: Auxiliary interface configuration register

RESET: 0x83

| Address | Bit | Name             | Description                             | Reset | Access |
|---------|-----|------------------|-----------------------------------------|-------|--------|
| 0x4C    |     | AUX_IF_CONF      |                                         | 0x83  |        |
|         | 10  | aux_rd_burst     | Burst data length (1,2,6,8 byte)        | 0x3   | RW     |
|         |     |                  | Value Name Description                  |       |        |
|         |     |                  | 0x00 BL1 Burst length 1                 |       |        |
|         |     |                  | 0x01 BL2 Burst length 2                 |       |        |
|         |     |                  | 0x02 BL6 Burst length 6                 |       |        |
|         |     |                  | 0x03 BL8 Burst length 8                 |       |        |
|         | 32  | man_rd_burst     | Manual burst data length (1,2,6,8 byte) | 0x0   | RW     |
|         |     |                  | Value Name Description                  |       |        |
|         |     |                  | 0x00 BL1 Burst length 1                 |       |        |
|         |     |                  | 0x01 BL2 Burst length 2                 |       |        |
|         |     |                  | 0x02 BL6 Burst length 6                 |       |        |
|         |     |                  | 0x03 BL8 Burst length 8                 |       |        |
|         | 6   | aux_fcu_write_en | enables FCU write command on AUX IF for | 0x0   | RW     |
|         |     |                  | auxiliary sensors that need a trigger.  |       |        |

| 7 | aux_manual_en | switches auxiliary interface between automatic and manual mode. In manual mode all read and write operations on auxiliary interface must be triggered manually; in automatic mode (aux_manual_en = "0") FCU triggers read and write operations periodically (as programmed by user). | 0x1 | RW |
|---|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----|
|---|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----|

5.2.54 Register (0x4D) AUX\_RD\_ADDR

DESCRIPTION: Auxiliary interface read address

RESET: 0x42

DEFINITION (Go to register map):

| Address | Bit | Name        | Description                                                     | Reset | Access |
|---------|-----|-------------|-----------------------------------------------------------------|-------|--------|
| 0x4D    |     | AUX_RD_ADDR |                                                                 | 0x42  |        |
|         | 70  | read_addr   | Address to read. In manual mode it triggers the read operation. | 0x42  | RW     |

5.2.55 Register (0x4E) AUX\_WR\_ADDR

DESCRIPTION: Auxiliary interface write address

RESET: 0x4C

DEFINITION (Go to register map):

| Address | Bit | Name        | Description                                                       | Reset | Access |
|---------|-----|-------------|-------------------------------------------------------------------|-------|--------|
| 0x4E    |     | AUX_WR_ADDR |                                                                   | 0x4C  |        |
|         | 70  | write_addr  | Address to write. In manual mode it triggers the write operation. | 0x4C  | RW     |

5.2.56 Register (0x4F) AUX\_WR\_DATA

DESCRIPTION: Auxiliary interface write data

RESET: 0x02

| Address | Bit | Name        | Description   | Reset | Access |
|---------|-----|-------------|---------------|-------|--------|
| 0x4F    |     | AUX_WR_DATA |               | 0x02  |        |
|         | 70  | write_data  | Data to write | 0x2   | RW     |

## 5.2.57 Register (0x52) ERR\_REG\_MSK

DESCRIPTION: Defines which error flag will trigger the error interrupt once enabled

'1' - use to generate the error interrupt

'0' - do not use to generate error interrupt

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name                                                     | Description                                      | Reset | Access |
|---------|-----|----------------------------------------------------------|--------------------------------------------------|-------|--------|
| 0x52    |     | ERR_REG_MSK                                              | EG_MSK                                           |       |        |
|         | 0   | fatal_err                                                | Use fatal error to generate the error interrupt. | 0x0   | RW     |
|         | 41  | 1 internal_err                                           |                                                  | 0x0   | RW     |
|         | 6   | fifo_err Use fifo error to generate the error interrupt. |                                                  | 0x0   | RW     |
|         | 7   | aux_err                                                  | Use aux interface error to generate the error    | 0x0   | RW     |
|         |     |                                                          | interrupt.                                       |       |        |

## 5.2.58 Register (0x53) INT1\_IO\_CTRL

DESCRIPTION: Configure the electrical behavior of the interrupt pin INT1

RESET: 0x00

| Address | Bit | Name         | Description                            | Reset | Access |
|---------|-----|--------------|----------------------------------------|-------|--------|
| 0x53    |     | INT1_IO_CTRL |                                        | 0x00  |        |
|         | 1   | lvl          | Configure output level of INT1 pin     | 0x0   | RW     |
|         |     |              | Value Name Description                 |       |        |
|         |     |              | 0x00 active_low active low             |       |        |
|         |     |              | 0x01 active_high active high           |       |        |
|         | 2   | od           | Configure output behaviour of INT1 pin | 0x0   | RW     |
|         |     |              | Value Name Description                 |       |        |
|         |     |              | 0x00 push_pull push-pull               |       |        |
|         |     |              | 0x01 open_drain open drain             |       |        |
|         | 3   | output_en    | Output enable for INT1 pin             | 0x0   | RW     |
|         |     |              | Value Name Description                 |       |        |
|         |     |              | 0x00 off Output disabled               |       |        |
|         |     |              | 0x01 on Output enabled                 |       |        |
|         | 4   | input_en     | Input enable for INT1 pin              | 0x0   | RW     |
|         |     |              | Value Name Description                 |       |        |
|         |     |              | 0x00 off Input disabled                |       |        |
|         |     |              | 0x01 on Input enabled                  |       |        |

# 5.2.59 Register (0x54) INT2\_IO\_CTRL

DESCRIPTION: Configure the electrical behavior of the interrupt pin INT2

RESET: 0x00

| Address | Bit | Name         | Description                            | Reset | Access |
|---------|-----|--------------|----------------------------------------|-------|--------|
| 0x54    |     | INT2_IO_CTRL |                                        | 0x00  |        |
|         | 1   | lvl          | Configure level of INT2 pin            | 0x0   | RW     |
|         |     |              | Value Name Description                 |       |        |
|         |     |              | 0x00 active_low active low             |       |        |
|         |     |              | 0x01 active_high active high           |       |        |
|         | 2   | od           | Configure output behaviour of INT2 pin | 0x0   | RW     |
|         |     |              | Value Name Description                 |       |        |
|         |     |              | 0x00 push_pull push-pull               |       |        |
|         |     |              | 0x01 open_drain open drain             |       |        |
|         | 3   | output_en    | Output enable for INT2 pin             | 0x0   | RW     |
|         |     |              | Value Name Description                 |       |        |
|         |     |              | 0x00 off Output disabled               |       |        |
|         |     |              | 0x01 on Output enabled                 |       |        |
|         | 4   | input_en     | Input enable for INT2 pin              | 0x0   | RW     |
|         |     |              | Value Name Description                 |       |        |
|         |     |              | 0x00 off Input disabled                |       |        |
|         |     |              | 0x01 on Input enabled                  |       |        |

# 5.2.60 Register (0x55) INT\_LATCH

**DESCRIPTION:** Configure interrupt latch modes

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description                         | Reset | Access |
|---------|-----|-----------|-------------------------------------|-------|--------|
| 0x55    |     | INT_LATCH |                                     | 0x00  |        |
|         | 0   | int_latch | Latched/non-latched interrupt modes | 0x0   | RW     |
|         |     |           | Value Name Description              |       |        |
|         |     |           | 0x00 none non latched               |       |        |
|         |     |           | 0x01 permanent permanent latched    |       |        |

# 5.2.61 Register (0x56) INT1\_MAP\_FEAT

DESCRIPTION: Interrupt/Feature mapping on INT1

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name                  | Description                             | Reset | Access |
|---------|-----|-----------------------|-----------------------------------------|-------|--------|
| 0x56    |     | INT1_MAP_FEAT         |                                         | 0x00  |        |
|         | 0   | sig_motion_out        | Sigmotion output.                       | 0x0   | RW     |
|         | 1   | step_counter_out      | Step-counter watermark or Step-detector | 0x0   | RW     |
|         |     |                       | output                                  |       |        |
|         | 2   | activity_out          | Step activity output                    | 0x0   | RW     |
|         | 3   | wrist_wear_wakeup_out | Wrist wear wakeup output                | 0x0   | RW     |
|         | 4   | wrist_gesture_out     | Wrist gesture output                    | 0x0   | RW     |
|         | 5   | no_motion_out         | No motion detection output              | 0x0   | RW     |
|         | 6   | any_motion_out        | Any motion detection output             | 0x0   | RW     |
|         | 7   | reserved              | Reserved                                | 0x0   | RW     |

## 5.2.62 Register (0x57) INT2\_MAP\_FEAT

DESCRIPTION: Interrupt/Feature mapping on INT2

RESET: 0x00

| Address | Bit | Name                  | Description                                    | Reset | Access |
|---------|-----|-----------------------|------------------------------------------------|-------|--------|
| 0x57    |     | INT2_MAP_FEAT         |                                                | 0x00  |        |
|         | 0   | sig_motion_out        | Sigmotion output.                              | 0x0   | RW     |
|         | 1   | step_counter_out      | Step-counter watermark or Step-detector output | 0x0   | RW     |
|         | 2   | activity_out          | Step activity output                           | 0x0   | RW     |
|         | 3   | wrist_wear_wakeup_out | Wrist wear wakeup output                       | 0x0   | RW     |
|         | 4   | wrist_gesture_out     | Wrist gesture output                           | 0x0   | RW     |
|         | 5   | no_motion_out         | No motion detection output                     | 0x0   | RW     |
|         | 6   | any_motion_out        | Any motion detection output                    | 0x0   | RW     |
|         | 7   | reserved              | Reserved                                       | 0x0   | RW     |

#### 5.2.63 Register (0x58) INT\_MAP\_DATA

DESCRIPTION: Data Interrupt mapping for both INT pins

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name         | Description                             | Reset | Access |
|---------|-----|--------------|-----------------------------------------|-------|--------|
| 0x58    |     | INT_MAP_DATA |                                         | 0x00  |        |
|         | 0   | ffull_int1   | FIFO Full interrupt mapped to INT1      | 0x0   | RW     |
|         | 1   | fwm_int1     | FIFO Watermark interrupt mapped to INT1 | 0x0   | RW     |
|         | 2   | drdy_int1    | Data Ready interrupt mapped to INT1     | 0x0   | RW     |
|         | 3   | err_int1     | Error interrupt mapped to INT1          | 0x0   | RW     |
|         | 4   | ffull_int2   | FIFO Full interrupt mapped to INT2      | 0x0   | RW     |
|         | 5   | fwm_int2     | FIFO Watermark interrupt mapped to INT2 | 0x0   | RW     |
|         | 6   | drdy_int2    | Data Ready interrupt mapped to INT2     | 0x0   | RW     |
|         | 7   | err_int2     | Error interrupt mapped to INT2          | 0x0   | RW     |

#### 5.2.64 Register (0x59) INIT\_CTRL

**DESCRIPTION: Start initialization** 

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description          | Reset | Access |
|---------|-----|-----------|----------------------|-------|--------|
| 0x59    |     | INIT_CTRL |                      | 0x00  |        |
|         | 70  | init_ctrl | Start initialization | 0x0   | RW     |

## 5.2.65 Register (0x5B) INIT\_ADDR\_0

DESCRIPTION: Base address of the initialization data. Increment by burst write length in bytes/2 after each burst write operation. Please ignore, if your host supports to load the initialization data in a single 8kB burst write operation.

RESET: 0x00

| Address | Bit | Name        | Description                                              | Reset | Access |
|---------|-----|-------------|----------------------------------------------------------|-------|--------|
| 0x5B    |     | INIT_ADDR_0 |                                                          | 0x00  |        |
|         | 30  | base_0_3    | Bits 0 to 3 of the base address for initialization data. | 0x0   | RW     |

#### 5.2.66 Register (0x5C) INIT\_ADDR\_1

DESCRIPTION: Base address of the initialization data. Increment by burst write length in bytes/2 after each burst write operation. Please ignore, if your host supports to load the initialization data in a single 8kB burst write operation.

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name        | Description                                               | Reset | Access |
|---------|-----|-------------|-----------------------------------------------------------|-------|--------|
| 0x5C    |     | INIT_ADDR_1 |                                                           | 0x00  |        |
|         | 70  | base_11_4   | Bits 4 to 11 of the base address for initialization data. | 0x0   | RW     |

## 5.2.67 Register (0x5E) INIT\_DATA

**DESCRIPTION: Initialization register** 

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description                      | Reset | Access |
|---------|-----|-----------|----------------------------------|-------|--------|
| 0x5E    |     | INIT_DATA |                                  | 0x00  |        |
|         | 70  | data      | Register for initialization data | 0x0   | RW     |

#### 5.2.68 Register (0x5F) INTERNAL\_ERROR

DESCRIPTION: Internal error flags. Value of all reserved bits should be ignored.

RESET: 0x00

| Address | Bit | Name              | Description                                                      | Reset | Access |
|---------|-----|-------------------|------------------------------------------------------------------|-------|--------|
| 0x5F    |     | INTERNAL_ERROR    |                                                                  | 0x00  |        |
|         | 1   | int_err_1         | Internal error flag - long processing time, processing halted    | 0x0   | R      |
|         | 2   | int_err_2         | Internal error flag - fatal error, processing halted             | 0x0   | R      |
|         | 4   | feat_eng_disabled | Feature engine has been disabled by host during sensor operation | 0x0   | R      |

## 5.2.69 Register (0x68) AUX\_IF\_TRIM

DESCRIPTION: Auxiliary interface trim register (NVM backed)

RESET: 0x01

DEFINITION (Go to register map):

| Address | Bit | Name        | Description                   | Reset | Access |
|---------|-----|-------------|-------------------------------|-------|--------|
| 0x68    |     | AUX_IF_TRIM |                               | 0x01  |        |
|         | 10  | asda_pupsel | Pullup configuration for ASDA | 0x1   | RW     |
|         |     |             | Value Name Description        |       |        |
|         |     |             | 0x00 pup_res_off Pullup off   |       |        |
|         |     |             | 0x01 pup_res_40k Pullup 40k   |       |        |
|         |     |             | 0x02 pup_res_10k Pullup 10k   |       |        |
|         |     |             | 0x03 pup_res_2k Pullup 2k     |       |        |

# 5.2.70 Register (0x69) GYR\_CRT\_CONF

**DESCRIPTION: Component Retrimming for Gyroscope** 

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name         | Description                                                                                                                                                                          | Reset | Access |
|---------|-----|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x69    |     | GYR_CRT_CONF |                                                                                                                                                                                      | 0x00  |        |
|         | 2   | crt_running  | Indicates that CRT is currently running. If CRT completed, check CRT_STATUS register for the completion status  Value Name Description  0x00 disabled disabled  0x01 enabled enabled | 0x0   | RW     |
|         | 3   | rdy_for_dl   | pacemaker bit for downloading the CRT data  Value Name Description  0x00 ongoing ongoing or not started  0x01 complete complete                                                      | 0x0   | R      |

## 5.2.71 Register (0x6A) NVM\_CONF

**DESCRIPTION: NVM Configuration** 

RESET: 0x00

| Address | Bit | Name        | Description             | Reset | Access |
|---------|-----|-------------|-------------------------|-------|--------|
| 0x6A    |     | NVM_CONF    |                         | 0x00  |        |
|         | 1   | nvm_prog_en | Enable NVM programming. | 0x0   | RW     |
|         |     |             | Value Name Description  |       |        |
|         |     |             | 0x00 disable disable    |       |        |
|         |     |             | 0x01 enable enable      |       |        |

# 5.2.72 Register (0x6B) IF\_CONF

**DESCRIPTION: Serial interface settings** 

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name     | Description                                                                                                                               | Reset | Access |
|---------|-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x6B    |     | IF_CONF  |                                                                                                                                           | 0x00  |        |
|         | 0   | spi3     | Configure SPI Interface Mode for primary interface  Value Name Description  0x00 spi4 SPI 4-wire mode  0x01 spi3 SPI 3-wire mode          | 0x0   | RW     |
|         | 1   | spi3_ois | Configure SPI Interface Mode for OIS interface (if enabled)  Value Name Description  0x00 spi4 SPI 4-wire mode  0x01 spi3 SPI 3-wire mode | 0x0   | RW     |
|         | 4   | ois_en   | Interface configuration - OIS enable bit. It has lower priority than aux_en.                                                              | 0x0   | RW     |
|         | 5   | aux_en   | Interface configuration - AUX enable bit. It has higher priority than ois_en.                                                             | 0x0   | RW     |

# 5.2.73 Register (0x6C) DRV

DESCRIPTION: Drive strength control register (NVM backed)

RESET: 0xAA

| Address | Bit | Name          | Description                                                                                                                                                                     | Reset | Access |
|---------|-----|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x6C    |     | DRV           |                                                                                                                                                                                 | 0xAA  |        |
|         | 20  | io_pad_drv1   | Output pad drive strength setting for the SDO and SDx pins: 0b111 is approx. 10x stronger driver than 0b000                                                                     | 0x2   | RW     |
|         | 3   | io_pad_i2c_b1 | Output pad drive strength setting to disable the additional increase in pull down strength of the SDx pin in I2C mode (in case of strong external pull-up resistor).            | 0x1   | RW     |
|         | 64  | io_pad_drv2   | Output pad drive strength setting the OSDO, ASCx, and ASDx pins: 0b111 is approx. 10x stronger driver than 0b000.                                                               | 0x2   | RW     |
|         | 7   | io_pad_i2c_b2 | Output pad drive strength setting to disable the additional increase in pull down strength of the ASCx and ASDx pins in i2c mode (in case of strong external pull-up resistor). | 0x1   | RW     |

## 5.2.74 Register (0x6D) ACC\_SELF\_TEST

DESCRIPTION: Settings for the accelerometer self-test configuration and trigger

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name               | Description                                  | Reset | Access |
|---------|-----|--------------------|----------------------------------------------|-------|--------|
| 0x6D    |     | ACC_SELF_TEST      |                                              | 0x00  |        |
|         | 0   | acc_self_test_en   | Enable accelerometer self-test               | 0x0   | RW     |
|         |     |                    | Value Name Description                       |       |        |
|         |     |                    | 0x00 disabled disabled                       |       |        |
|         |     |                    | 0x01 enabled enabled                         |       |        |
|         | 2   | acc_self_test_sign | select sign of self-test excitation as       | 0x0   | RW     |
|         |     |                    | Value Name Description                       |       |        |
|         |     |                    | 0x00 negative negative                       |       |        |
|         |     |                    | 0x01 positive positive                       |       |        |
|         | 3   | acc_self_test_amp  | select amplitude of the selftest deflection: | 0x0   | RW     |
|         |     |                    | Value Name Description                       |       |        |
|         |     |                    | 0x00 low low                                 |       |        |
|         |     |                    | 0x01 high high                               |       |        |

5.2.75 Register (0x6E) GYR\_SELF\_TEST\_AXES

DESCRIPTION: Settings for the gyroscope AXES self-test configuration and trigger

RESET: 0x00

| Address | Bit | Name               | Description                                             | Reset | Access |
|---------|-----|--------------------|---------------------------------------------------------|-------|--------|
| 0x6E    |     | GYR_SELF_TEST_AXES |                                                         | 0x00  |        |
|         | 0   | gyr_st_axes_done   | STATUS: functional test of detection channels finished. | 0x0   | R      |
|         | 1   | gyr_axis_x_ok      | status of gyro X-axis self test                         | 0x0   | R      |
|         | 2   | gyr_axis_y_ok      | status of gyro Y-axis self test                         | 0x0   | R      |
|         | 3   | gyr_axis_z_ok      | status of gyro Z-axis self test                         | 0x0   | R      |

## 5.2.76 Register (0x70) NV\_CONF

DESCRIPTION: NVM backed configuration bits.

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name        | Description                                            | Reset | Access |
|---------|-----|-------------|--------------------------------------------------------|-------|--------|
| 0x70    |     | NV_CONF     |                                                        | 0x00  |        |
|         | 0   | spi_en      | disable the I2C and enable SPI for the primary         | 0x0   | RW     |
|         |     |             | interface, when it is in autoconfig mode               |       |        |
|         |     |             | Value Name Description                                 |       |        |
|         |     |             | 0x00 disabled I2C enabled                              |       |        |
|         |     |             | 0x01 enabled I2C disabled                              |       |        |
|         | 1   | i2c_wdt_sel | Select timer period for I2C Watchdog                   | 0x0   | RW     |
|         |     |             | Value Name Description                                 |       |        |
|         |     |             | 0x00 short I2C watchdog timeout after 1.25 ms          |       |        |
|         |     |             | 0x01 long I2C watchdog timeout after 40 ms             |       |        |
|         | 2   | i2c_wdt_en  | I2C Watchdog at the SDA pin in I2C interface mode      | 0x0   | RW     |
|         |     |             | Value Name Description                                 |       |        |
|         |     |             | 0x00 Disable Disable I2C watchdog                      |       |        |
|         |     |             | 0x01 Enable Enable I2C watchdog                        |       |        |
|         | 3   | acc_off_en  | Add the offset defined in the off_acc_[xyz] OFFSET     | 0x0   | RW     |
|         |     |             | register to filtered and unfiltered Accelerometer data |       |        |
|         |     |             | Value Name Description                                 |       |        |
|         |     |             | 0x00 disabled Disabled                                 |       |        |
|         |     |             | 0x01 enabled Enabled                                   |       |        |

## 5.2.77 Register (0x71) OFFSET\_0

DESCRIPTION: Offset compensation for Accelerometer X-axis (NVM backed)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description                                 | Reset | Access |
|---------|-----|-----------|---------------------------------------------|-------|--------|
| 0x71    |     | OFFSET_0  |                                             | 0x00  |        |
|         | 70  | off_acc_x | Accelerometer offset compensation (X-axis). | 0x0   | RW     |

# 5.2.78 Register (0x72) OFFSET\_1

DESCRIPTION: Offset compensation for Accelerometer Y-axis (NVM backed)

RESET: 0x00

| ĺ | Address | Bit | Name      | Description                                 | Reset | Access |
|---|---------|-----|-----------|---------------------------------------------|-------|--------|
| ĺ | 0x72    |     | OFFSET_1  |                                             | 0x00  |        |
| ı |         | 70  | off_acc_y | Accelerometer offset compensation (Y-axis). | 0x0   | RW     |

## 5.2.79 Register (0x73) OFFSET\_2

DESCRIPTION: Offset compensation for Accelerometer Z-axis (NVM backed)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description                                 | Reset | Access |
|---------|-----|-----------|---------------------------------------------|-------|--------|
| 0x73    |     | OFFSET_2  |                                             | 0x00  |        |
|         | 70  | off_acc_z | Accelerometer offset compensation (Z-axis). | 0x0   | RW     |

#### 5.2.80 Register (0x74) OFFSET\_3

DESCRIPTION: Offset compensation for Gyroscope X-axis (NVM backed)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name              | Description                             | Reset | Access |
|---------|-----|-------------------|-----------------------------------------|-------|--------|
| 0x74    |     | OFFSET_3          |                                         | 0x00  |        |
|         | 70  | gyr_usr_off_x_7_0 | Gyroscope offset compensation (X-axis). | 0x0   | RW     |

#### 5.2.81 Register (0x75) OFFSET\_4

DESCRIPTION: Offset compensation for Gyroscope Y-axis (NVM backed)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name              | Description                             | Reset | Access |
|---------|-----|-------------------|-----------------------------------------|-------|--------|
| 0x75    |     | OFFSET_4          |                                         | 0x00  |        |
|         | 70  | gyr_usr_off_y_7_0 | Gyroscope offset compensation (Y-axis). | 0x0   | RW     |

#### 5.2.82 Register (0x76) OFFSET\_5

DESCRIPTION: Offset compensation for Gyroscope Z-axis (NVM backed)

RESET: 0x00

| Address | Bit | Name              | Description                             | Reset | Access |
|---------|-----|-------------------|-----------------------------------------|-------|--------|
| 0x76    |     | OFFSET_5          |                                         | 0x00  |        |
|         | 70  | gyr_usr_off_z_7_0 | Gyroscope offset compensation (Z-axis). | 0x0   | RW     |

## 5.2.83 Register (0x77) OFFSET\_6

DESCRIPTION: Offset compensation (MSBs gyroscope, enables) (NVM backed)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name              | Description                                                                                                                                                                  | Reset | Access |
|---------|-----|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x77    |     | OFFSET_6          |                                                                                                                                                                              | 0x00  |        |
|         | 10  | gyr_usr_off_x_9_8 | Gyroscope offset compensation (X-axis).                                                                                                                                      | 0x0   | RW     |
|         | 32  | gyr_usr_off_y_9_8 | Gyroscope offset compensation (Y-axis).                                                                                                                                      | 0x0   | RW     |
|         | 54  | gyr_usr_off_z_9_8 | Gyroscope offset compensation (Z-axis).                                                                                                                                      | 0x0   | RW     |
|         | 6   | gyr_off_en        | Add the offset defined in the gyr_usr_off_[xyz] OFFSET register to filtered and unfiltered Gyroscope data Value Name Description 0x00 disabled Disabled 0x01 enabled Enabled | 0x0   | RW     |
|         | 7   | gyr_gain_en       | Compensate the gain as described in section "Sensitivity Error Compensation".  Value Name Description  0x00 disabled Disabled 0x01 enabled Enabled                           |       | RW     |

## 5.2.84 Register (0x7C) PWR\_CONF

DESCRIPTION: Power mode configuration register

RESET: 0x03

| Address | Bit | Name              | Description                                  | Reset | Access |
|---------|-----|-------------------|----------------------------------------------|-------|--------|
| 0x7C    |     | PWR_CONF          |                                              | 0x03  |        |
|         | 0   | adv_power_save    | Advanced power save disabled.                | 0x1   | RW     |
|         |     |                   | Value Name Description                       |       |        |
|         |     |                   | 0x00 aps_off Advanced power save disabled.   |       |        |
|         |     |                   | 0x01 aps_on Advanced power mode              |       |        |
|         |     |                   | enabled.                                     |       |        |
|         | 1   | fifo_self_wake_up | FIFO read disabled in low power mode         | 0x1   | RW     |
|         |     |                   | Value Name Description                       |       |        |
|         |     |                   | 0x00 fsw_off FIFO read disabled in low power |       |        |
|         |     |                   | mode                                         |       |        |
|         |     |                   | 0x01 fsw_on FIFO read enabled in low power   |       |        |
|         |     |                   | mode after FIFO interrupt is                 |       |        |
|         |     |                   | fired                                        |       |        |
|         | 2   | fup_en            | Fast power up enable                         | 0x0   | RW     |
|         |     |                   | Value Name Description                       |       |        |
|         |     |                   | 0x00 fup_off Fast power up disabled          |       |        |
|         |     |                   | 0x01 fup_on Fast power up enabled            |       |        |

5.2.85 Register (0x7D) PWR\_CTRL

DESCRIPTION: Power mode control register

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name     | Description                                    | Reset | Access |
|---------|-----|----------|------------------------------------------------|-------|--------|
| 0x7D    |     | PWR_CTRL |                                                | 0x00  |        |
|         | 0   | aux_en   |                                                | 0x0   | RW     |
|         |     |          | Value Name Description                         |       |        |
|         |     |          | 0x00 aux_off Disables the Auxiliary sensor.    |       |        |
|         |     |          | 0x01 aux_on Enables the Auxiliary sensor.      |       |        |
|         | 1   | gyr_en   |                                                | 0x0   | RW     |
|         |     |          | Value Name Description                         |       |        |
|         |     |          | 0x00 gyr_off Disables the Gyroscope.           |       |        |
|         |     |          | 0x01 gyr_on Enables the Gyroscope.             |       |        |
|         | 2   | acc_en   |                                                | 0x0   | RW     |
|         |     |          | Value Name Description                         |       |        |
|         |     |          | 0x00 acc_off Disables the Accelerometer.       |       |        |
|         |     |          | 0x01 acc_on Enables the Accelerometer.         |       |        |
|         | 3   | temp_en  |                                                | 0x0   | RW     |
|         |     |          | Value Name Description                         |       |        |
|         |     |          | 0x00 temp_off Disables the Temperature sensor. |       |        |
|         |     |          | 0x01 temp_on Enables the Temperature sensor.   |       |        |

5.2.86 Register (0x7E) CMD

**DESCRIPTION: Command Register** 

RESET: 0x00

| Address | Bit | Name | Descri  | ption                                                   |                                            | Reset | Access |
|---------|-----|------|---------|---------------------------------------------------------|--------------------------------------------|-------|--------|
| 0x7E    |     | CMD  |         |                                                         |                                            |       |        |
|         | 70  | cmd  | Availab | le command                                              | ds (Note: Register will always return 0x00 | 0x0   | W      |
|         |     |      | as read | result):                                                |                                            |       |        |
|         |     |      | Value   | Name                                                    | Description                                |       |        |
|         |     |      | 0x02    | g_trigger                                               | Trigger special gyro operations.           |       |        |
|         |     |      | 0x03    | usr_gain                                                | Applies new gyro gain value.               |       |        |
|         |     |      | 0xa0    | nvm_prog                                                | Writes the NVM backed registers into       |       |        |
|         |     |      |         |                                                         | NVM                                        |       |        |
|         |     |      | 0xb0    | fifo_flush                                              | Clears FIFO content                        |       |        |
|         |     |      | 0xb6    | 0xb6 softreset Triggers a reset, all user configuration |                                            |       |        |
|         |     |      |         |                                                         | settings are overwritten with their        |       |        |
|         |     |      |         |                                                         | default state                              |       |        |

# 6 Digital Interfaces

#### 6.1 Interfaces

Beside the standard primary interface (I2C and SPI configurable), where sensor acts as a slave to the application processor the IMU device supports a secondary interface. The secondary interface can be configured as either auxiliary interface (I2C master) or OIS interface (SPI slave). See picture below. Both secondary configurations work independent of the primary interface configuration, i.e. I2C or SPI between the device and application processor.

If the secondary interface configured as auxiliary interface, the device can be connected to an external sensor (e.g. a magnetometer) in order to build a 9-DoF solution. Then the device will act as a master to the external sensor, reading the sensor data automatically and providing it to the application processor via the primary interface.

Alternatively, the secondary interface can be used as OIS interface to connect to an external OIS control unit. The OIS control unit acts as a master and device as slave.



Figure 9: Digital Interfaces

## 6.2 Primary Interface

By default, the device operates in I2C mode. The device interface can also be configured to operate in a SPI 4-wire configuration. It can also be re-configured by software to work in 3-wire mode instead of 4-wire mode.

All three possible digital interfaces share partly the same pins. The mapping for the primary interface of device is given in the following table:

Table 17: Mapping for primary interface

| Pin# | Name | I/O Type     | Description                             | Connect to | Primary Inter | face        |
|------|------|--------------|-----------------------------------------|------------|---------------|-------------|
|      |      |              |                                         | in SPI4W   | in SPI3W      | in I2C      |
| 1    | SDO  | Digital I/O  | SDO Serial data output in SPI 4W        | SDO        | DNC           | GND for     |
|      |      |              | I2C Address bit-0 select in I2C mode    |            |               | default I2C |
|      |      |              |                                         |            |               | addr.       |
| 4    | INT1 | Digital I/O* | Interrupt pin 1                         | INT1       | INT1          | INT1        |
| 9    | INT2 | Digital I/O* | Interrupt pin 2                         | INT2       | INT2          | INT2        |
| 12   | CSB  | Digital in   | Chip select for SPI mode                | CSB        | CSB           | VDDIO**     |
| 13   | SCx  | Digital in   | SCK for SPI serial clock                | SCK        | SCK           | SCL         |
|      |      |              | SCL for I <sup>2</sup> C serial clock   |            |               |             |
| 14   | SDx  | Digital I/O  | SDA serial data I/O in I <sup>2</sup> C | SDI        | SDA           | SDA         |
|      |      |              | SDI serial data input in SPI 4W         |            |               |             |
|      |      |              | SDA serial data I/O in SPI 3W           |            |               |             |

<sup>\*</sup> INT1 and/or INT2 can also be configured as an input in case the external data synchronization in FIFO is used. If INT1 and/or INT2 are not used, please do not connect them (DNC).

The following table shows the electrical specifications of the interface pins:

Table 18: Electrical specifications of the interface pins

| Parameter                             | Symbol                | Condition                   | Min | Тур | Max | Units |
|---------------------------------------|-----------------------|-----------------------------|-----|-----|-----|-------|
| Pull-up Resistance, CSB               | Rup                   | Internal Pull-up Resistance | 75  | 100 | 140 | kΩ    |
| pin                                   |                       | to VDDIO                    |     |     |     |       |
| Input Capacitance                     | Cin                   |                             |     |     | 5   | pF    |
| I <sup>2</sup> C Bus Load Capacitance | C <sub>I2C_Load</sub> |                             |     |     | 400 | pF    |
| (max. drive capability)               |                       |                             |     |     |     |       |

<sup>\*\*</sup> DNC is also possible due to an internal pull-up, as long as the voltage never drops below VIH.

#### 6.3 Primary Interface Digital Protocol Selection

The protocol is automatically selected based on the chip select CSB pin behavior after power-up.

After reset / power-up, device's primary interface is in I2C mode. If CSB is connected to VDDIO during power-up and not changed, the primary interface works in I2C mode. For using I2C, it is recommended to hard-wire the CSB line to VDDIO. Since power-on-reset is only executed when, both VDD and VDDIO are established, there is no risk of incorrect protocol detection due to power-up sequence.

If CSB sees a rising edge after power-up, the device interface switches to SPI after 200 µs until a reset or the next power-up occurs. Therefore, a CSB rising edge is needed before starting the SPI communication. Hence, it is recommended to perform a SPI single read of register <a href="CHIP ID">CHIP ID</a> (the obtained value will be invalid) before the actual communication start, in order to use the SPI interface.

If toggling of the CSB bit is not possible without data communication, there is an addition the spi\_en bit in register <a href="NV\_CONF">NV\_CONF</a>, which can be used to permanently set the primary interface to SPI without the need to toggle the CSB pin at every power-up or reset.

#### 6.4 Primary Interface SPI

The timing specification for SPI of the device is given in the following table:

SPI timing, valid at V<sub>DDIO</sub> ≥ 1.62V

Table 19: Timing specifications for SPI

| Parameter                          | Symbol                 | Condition                              | Min | Max | Units |
|------------------------------------|------------------------|----------------------------------------|-----|-----|-------|
| Clock Frequency                    | f <sub>SPI</sub>       | Max. Load on SDI or SDO =              |     | 10  | MHz   |
|                                    |                        | 30pF, V <sub>DDIO</sub> ≥ 1.62 V       |     |     |       |
|                                    |                        | V <sub>DDIO</sub> < 1.62V              |     | 7   | MHz   |
| SCK Low Pulse                      | tsckl                  | V <sub>DDIO</sub> ≥1.62V               | 45  |     | ns    |
| SCK High Pulse                     | tscкн                  | V <sub>DDIO</sub> ≥1.62V               | 45  |     | ns    |
| SCK Low Pulse                      | <b>t</b> sckl          | V <sub>DDIO</sub> <1.62V               | 66  |     | ns    |
| SCK High Pulse                     | tscкн                  | V <sub>DDIO</sub> <1.62V               | 66  |     | ns    |
| SDI Setup Time                     | t <sub>SDI_setup</sub> |                                        | 20  |     | ns    |
| SDI Hold Time                      | tsDI_hold              |                                        | 20  |     | ns    |
| SDO Output Delay                   | t <sub>SDO_OD</sub>    | Load = 30pF, V <sub>DDIO</sub> ≥ 1.62V |     | 30  | ns    |
| CSB Setup Time                     | t <sub>CSB_setup</sub> |                                        | 40  |     | ns    |
| CSB Hold Time                      | tcsB_hold              |                                        | 40  |     | ns    |
| Idle time after read access in any | t <sub>IDLE_rd</sub>   |                                        | 2   |     | μs    |
| mode                               |                        |                                        |     |     |       |
| Idle time after write access in    | tIDLE_wr_act           |                                        | 2   |     | μs    |
| normal mode or fast startup mode   |                        |                                        |     |     |       |
| Idle time after a write access in  | tIDLE_wacc_sum         |                                        | 450 |     | μs    |
| suspend mode, low-power mode       |                        |                                        |     |     |       |

The following figure shows the definition of the SPI timings:



Figure 10: SPI timing diagram

The SPI interface of the device is compatible with two modes, '00' [CPOL = '0' and CPHA = '0'] and '11' [CPOL = '1' and CPHA = '1']. The automatic selection between '00' and '11' is controlled based on the value of SCK after a falling edge of CSB.

Two configurations of the SPI interface are supported by device: 4-wire and 3-wire. The same protocol is used by both configurations. The device operates in 4-wire configuration by default. It can be switched to 3-wire configuration by writing IF CONF.spi3 = 0b1. Pin SDX is used as the common data pin in 3-wire configuration.

For single byte read as well as write operations, 16-bit protocols are used. device also supports multiple-byte read and write operations.

In SPI 4-wire configuration CSB (chip select low active), SCX (as SCK for serial clock), SDX (as SDI for serial data input), and SDO (serial data output) pins are used. The communication starts when the CSB is pulled low by the SPI master and stops when CSB is pulled high. SCK is also controlled by SPI master. SDI and SDO are driven at the falling edge of SCK and should be captured at the rising edge of SCK.

The basic write operation waveform for 4-wire configuration is depicted in the following figure. During the entire write cycle SDO remains in high-impedance state.



Figure 11: 4-wire basic SPI write sequence (mode '00')

Multiple write operations are possible by keeping CSB low and continuing the data transfer. Only the first register's address has to be placed in SDX. Addresses are automatically incremented after each write access as long as CSB stays active low. The principle of multiple write is shown in figure below:



Figure 12: SPI multiple write

The basic read operation waveform for 4-wire configuration is depicted in the figure below. Please note that the first byte received from the device via the SDO line correspond to a dummy byte and the 2<sup>nd</sup> byte correspond to the value read out of the specified register address. That means, for a basic read operation two bytes have to be read and the first has to be dropped and the second byte must be interpreted.



Figure 13: 4-wire basic SPI read sequence (mode '00')

The data bits are used as follows:

R/W: Read/Write bit. When 0, the data SDI is written into the chip. When 1, the data SDO from the chip is read.

AD6-AD0: Register address

DI7-DI0: When in write mode, these are the data SDI, which will be written into the address. DO7-DO0: When in read mode, these are the data SDO, which are read from the address.

Multiple read operations are possible by keeping CSB low and continuing the data transfer. Only the first register address has to be written. Addresses are automatically incremented after each read access as long as CSB stays active low. Please note that the first byte received from the device via the SDO line corresponds to a dummy byte and the 2<sup>nd</sup> byte corresponds to the value read out of the specified register address. The successive bytes read out correspond to values of incremented register addresses. That means, for a multiple read operation of n bytes, n+1 bytes have to be read, the first has to be dropped and the successive bytes must be interpreted.

In SPI 3-wire configuration CSB (chip select low active), SCX (as SCK for serial clock), and SDX (as SDA for serial data input and output) pins are used. While SCK is high, the communication starts when the CSB is pulled low by the SPI master and stops when CSB is pulled high. SCK is controlled by SPI master. SDI is driven (when used as input of the device) at the falling edge of SCK and should be captured (when used as the output of the device) at the rising edge of SCK.

The protocol as such is the same in 3-wire configuration as it is in 4-wire configuration. The basic operation for read and write access for 3-wire configuration is depicted in the figure below:



Figure 14: 3-wire basic SPI write sequence (mode '11')



Figure 15: 3-wire basic SPI read sequence (mode '00')

#### 6.5 Primary Interface I<sup>2</sup>C

The I<sup>2</sup>C bus uses SCX (as SCL for serial clock) and SDX (as SDA for serial data input and output) signal lines. Both lines are connected to  $V_{DDIO}$  externally via pull-up resistors so that they are pulled high when the bus is free.

The default I<sup>2</sup>C address of the device is 0b1101000 (0x68). It is used if the SDO pin is pulled to 'GND'. The alternative address 0b1101001 (0x69) is selected by pulling the SDO pin to 'VDDIO'.

The I<sup>2</sup>C interface of device is compatible with the I<sup>2</sup>C Specification UM10204 Rev. 03 (19 June 2007), available at <a href="http://www.nxp.com">http://www.nxp.com</a>. The device supports I<sup>2</sup>C standard mode (100kHz), fast mode (400kHz) and fast mode plus (1000kHz). Only 7-bit address mode is supported. <a href="http://www.nxp.com">http://www.nxp.com</a>. The device supports I<sup>2</sup>C standard mode (100kHz), fast mode (400kHz) and fast mode plus (1000kHz). Only 7-bit address mode is supported.

The device supports **fast mode plus I<sup>2</sup>C mode** that allows using clock frequencies up to 1 MHz. In this mode all timings of the fast mode apply and it additionally supports clock frequencies up to 1MHz.

The timing specification for I<sup>2</sup>C of the device is given in the following table:

Table 20: Timing specifications for I<sup>2</sup>C of the device

| PARAMETER                                                        | SYMBOL             | CONDITION      | MIN                    | MAX                    | UNITS |
|------------------------------------------------------------------|--------------------|----------------|------------------------|------------------------|-------|
| Clock Frequency                                                  | f <sub>SCL</sub>   |                |                        | 400 (FM)<br>1000 (FM+) | kHz   |
| SCL Low Period                                                   | t <sub>LOW</sub>   |                | 1.3 (FM)<br>0.5 (FM+)  |                        |       |
| SCL High Period                                                  | tнідн              |                | 0.6 (FM)<br>0.26 (FM+) |                        |       |
| SDA Setup Time                                                   | tsudat             |                | 0.1 (FM)<br>0.05 (FM+) |                        |       |
| SDA Hold Time                                                    | t <sub>HDDAT</sub> |                | 0.0                    |                        |       |
| Setup Time for a repeated Start Condition                        | <b>t</b> susta     |                | 0.6 (FM)<br>0.26 (FM+) |                        |       |
| Hold Time for a Start Condition                                  | t <sub>HDSTA</sub> |                | 0.6 (FM)<br>0.26 (FM+) |                        | μs    |
| Setup Time for a Stop<br>Condition                               | t <sub>susто</sub> |                | 0.6 (FM)<br>0.26 (FM+) |                        | μ3    |
| Time before a new                                                |                    | low power mode | 400                    |                        |       |
| Transmission can start                                           | <b>t</b> BUF       | normal mode    | 1.3 (FM)<br>0.5 (FM+)  |                        |       |
| Idle time after write accesses in normal mode, fast startup mode | tIDLE_wacc_nm      |                | 2                      |                        |       |
| Idle time after write accesses in suspend mode, low-power mode   | tIDLE_wacc_sum     |                | 450                    |                        |       |

The figure below shows the definition of the I<sup>2</sup>C timings given in the above table:



Figure 16: I2C timing diagram

The I2C protocol works as follows:

**START:** Data transmission on the bus begins with a high to low transition on the SDA line while SCL is held high (start condition (S) indicated by I<sup>2</sup>C bus master). Once the START signal is transferred by the master, the bus is considered busy.

**STOP:** Each data transfer should be terminated by a Stop signal (P) generated by master. The STOP condition is a low to high transition on SDA line while SCL is held high.

**ACKS:** Each byte of data transferred must be acknowledged. It is indicated by an acknowledge bit sent by the receiver. The transmitter must release the SDA line (no pull down) during the acknowledge pulse while the receiver must then pull the SDA line low so that it remains stable low during the high period of the acknowledge clock cycle.

In the following diagrams these abbreviations are used:

S Start P Stop

ACKS Acknowledge by slave
ACKM Acknowledge by master
NACKM Not acknowledge by master

RW Read / Write

A START immediately followed by a STOP (without SCL toggling from 'VDDIO' to 'GND') is not supported. If such a combination occurs, the STOP is not recognized by the device.

#### 6.5.1 I2C write access:

I<sup>2</sup>C write access can be used to write a data byte in one sequence.

The sequence begins with start condition generated by the master, followed by 7 bits slave address and a write bit (RW = 0). The slave sends an acknowledge bit (ACKS = 0) and releases the bus. Then the master sends the one byte register address. The slave again acknowledges the transmission and waits for the 8 bits of data which shall be written to the specified register address. After the slave acknowledges the data byte, the master generates a stop signal and terminates the writing protocol.

#### Example of an I2C write access:

| Start | Slave Adress  | R/W ACK |   | Register address (0x41) ACK | Register data (0x01) | ACK Stop |
|-------|---------------|---------|---|-----------------------------|----------------------|----------|
| S     | 1 1 0 1 0 0 0 | 0 0     | х | 1 0 0 0 0 0 1 0             | 0 0 0 0 0 0 0 1      | 0 P      |



I2C write

Multi-byte writes are supported without restriction on normal registers with auto-increment as well as on special registers with address trap.

#### 6.5.2 I2C read access

I<sup>2</sup>C read access can be used to read one or multiple data bytes in one sequence.

A read sequence consists of a one-byte  $I^2C$  write phase followed by the  $I^2C$  read phase. The two parts of the transmission must be separated by a repeated start condition (S). The  $I^2C$  write phase addresses the slave and sends the register address to be read. After slave acknowledges the transmission, the master generates again a start condition and sends the slave address together with a read bit (RW = 1). Then the master releases the bus and waits for the data bytes to be read out from slave. After each data byte the master has to generate an acknowledge bit (ACKM = 0) to enable further data transfer. A NACKM (ACKM = 1) from the master stops the data being transferred from the slave. The slave releases the bus so that the master can generate a STOP condition and terminate the transmission.

The register address is automatically incremented and, therefore, more than one byte can be sequentially read out. Once a new data read transmission starts, the start address will be set to the register address specified since the latest I<sup>2</sup>C write command. By default the start address is set at 0x00. In this way repetitive multi-bytes reads from the same starting address are possible.



In order to prevent the I²C slave of the device to lock-up the I²C bus, a watchdog timer (WDT) is implemented. The WDT observes internal I²C signals and resets the I²C interface if the bus is locked-up by the device. Whenever the sensor device starts to drive the SDA pin of the primary interface low, the timer is started. If the timer expires, the serial interface logic of device is reset and the transaction is aborted. This allows the host to restart a new operation or to initiate a soft-reset of device, for a full recovery. Please ensure that the watchdog is not triggered unintentionally by running with a I²C clock frequency. This could trigger the watchdog, if a low SDA line for the watchdog timer expiration period is a valid communication (e.g. for NV CONF.i2c wdt sel=0b0 the clock frequency should be greater than 100 kHz to avoid triggering the watchdog unintentionally). The activity and the timer period of the WDT can be configured through the bits NV CONF.i2c wdt en and NV CONF.i2c wdt sel.

#### SPI and I2C Access Restrictions

In order to allow for the correct internal synchronization of data written to the device, certain access restrictions apply for consecutive write accesses or a write/read sequence through the SPI as well as I<sup>2</sup>C interface. The required waiting period depends on whether the device is operating in normal mode or other modes.

As illustrated in the figure below, an interface idle time of at least 2 µs is required following a write operation when the device operates in normal mode. In suspend mode an interface idle time of at least 450 µs is required.



Post-Write Access Timing Constraints

#### 6.6 Secondary Interface

The secondary interface can be used in either of the following two configurations:

- ▶ Auxiliary interface (I2C master) for connecting an external sensor:
  In this case, the secondary interface is used as a two-wire I2C interface (ASDX and ASCX pins) where an external sensor like a magnetometer can be connected as a slave to the device. Typical application is connecting a Bosch Sensortec geomagnetic sensor like BMM150.
- ► OIS interface (SPI slave) for connecting to OIS control unit
  In this case, the secondary interface is used as an SPI interface where an external controller can be connected as a master to the device. External controller can be an OIS control unit.

The mapping of the device pins for secondary interface usage is given in following table:

Table 21: Mapping of the device pins for secondary interface

| Pin# | Name | I/O Type    | Description                   | Connect to Secondary Interface |            |               |
|------|------|-------------|-------------------------------|--------------------------------|------------|---------------|
|      |      |             |                               | OIS SPI 4W                     | OIS SPI 3W | AUXILIARY I2C |
| 2    | ASDX | Digital I/O | Aux interface / OIS interface | SDI                            | SDA        | SDA           |
| 3    | ASCX | Digital I/O | Aux interface / OIS interface | SCK                            | SCK        | SCL           |
| 10   | OCSB | Digital in  | OIS interface                 | CSB                            | CSB        | DNC           |
| 11   | OSDO | Digital out | OIS interface                 | SDO                            | DNC        | DNC           |

#### 6.6.1 Auxiliary Interface

The device allows attaching an external sensor (e.g. magnetometer) to the secondary interface. The connection diagrams for the auxiliary interface are depicted in the section 7.3. The timings of the secondary I2C interface follow the I2C fast-mode plus (fm+) specification, see section 6.5. For operating AUX I/F in I2C fast-mode (fm), please contact your regional Bosch Sensortec sales representative.

The device acts as a master of the secondary interface, controls the data acquisition of the external sensor (slave of the secondary interface) and presents the data to the application processor (AP) in the user registers of the device through the primary interface. No external pull-up resistors need to be connected, since an internal pull-up register can be configured through <a href="Mailto:AUX\_IF\_TRIM.asda\_pupsel">AUX\_IF\_TRIM.asda\_pupsel</a>. No additional I2C master or slave devices can be attached to the magnetometer interfaces.

The device autonomously reads out the sensor data from the external sensor without intervention of the application processor and stores the data in its data registers (per default) and FIFO (see Register <u>FIFO\_CONFIG\_1.fifo\_aux\_en</u>). The initial setup of the external sensor after power-on is done through indirect addressing in the device.

For more information about the usage of auxiliary interface see Section 4.10.

#### 6.6.2 OIS Interface

The device can support optical image stabilization (OIS) applications with the secondary interface (SPI only). The OIS controller has direct access to pre-filtered gyroscope and accelerometer data with minimum latency. Pre-filter gyroscope data is available at ODR of 6.4kHz and accelerometer data with ODR 1.6kHz. OIS SPI interface supports 3-wire and 4-wire modes. The timing of OIS SPI interface is identical to the primary SPI interface described in section 6.4

For more information about the usage of the OIS data see Section 4.11.

# 7 Pin-out and Connection Diagram

## 7.1 Pin-out



Pin-out top view



Pin-out bottom view

Table 22: Pin-out and pin connections

| Pin# | Name  | I/O            | Interface | Description                                                                                          | Connect to                                  |                                                |                                                |
|------|-------|----------------|-----------|------------------------------------------------------------------------------------------------------|---------------------------------------------|------------------------------------------------|------------------------------------------------|
|      |       | Туре           |           |                                                                                                      | in SPI4W                                    | In SPI3W                                       | in I <sup>2</sup> C                            |
| 1    | SDO   | Digital<br>I/O | Primary   | SDO Serial data output in<br>SPI 4W<br>I2C Address bit-0 select in<br>I2C mode                       | SDO                                         | DNC                                            | GND for<br>default I2C<br>address              |
| 2    | ASDx  | Digital<br>I/O | Secondary | Aux interface / OIS<br>interface**                                                                   | VDDIO or<br>DNC or<br>Aux SDA or<br>OIS SDI | VDDIO or<br>DNC or<br>Aux SDA or<br>OIS SDI    | VDDIO or<br>DNC<br>or<br>Aux SDA or<br>OIS SDI |
| 3    | ASCx  | Digital<br>I/O | Secondary | Aux interface / OIS<br>interface**                                                                   | VDDIO or<br>DNC or<br>Aux SCL or<br>OIS SCK | VDDIO or<br>DNC<br>or<br>Aux SCL or<br>OIS SCK | VDDIO or<br>DNC<br>or<br>Aux SCL or<br>OIS SCK |
| 4    | INT1  | Digital<br>I/O | -         | Interrupt pin 1*                                                                                     | INT1                                        | INT1                                           | INT1                                           |
| 5    | VDDIO | Supply         | -         | Digital I/O supply voltage<br>(1.2 3.6V)                                                             | VDDIO                                       | VDDIO                                          | VDDIO                                          |
| 6    | GNDIO | Ground         | -         | Ground for I/O                                                                                       | GNDIO                                       | GNDIO                                          | GNDIO                                          |
| 7    | GND   | Ground         | -         | Ground for digital & analog                                                                          | GND                                         | GND                                            | GND                                            |
| 8    | VDD   | Supply         | -         | Power supply analog & digital domain (1.71V – 3.6V)                                                  | VDD                                         | VDD                                            | VDD                                            |
| 9    | INT2  | Digital<br>I/O | -         | Interrupt pin 2 *                                                                                    | INT2                                        | INT2                                           | INT2                                           |
| 10   | OCSB  | Digital in     | Secondary | OIS interface                                                                                        | DNC*** or<br>OIS CSB                        | DNC*** or<br>OIS CSB                           | DNC*** or<br>OIS CSB                           |
| 11   | OSDO  | Digital<br>out | Secondary | OIS interface                                                                                        | DNC*** or<br>OIS SDO                        | DNC*** or<br>OIS SDO                           | DNC*** or<br>OIS SDO                           |
| 12   | CSB   | Digital in     | Primary   | Chip select for SPI mode                                                                             | CSB                                         | CSB                                            | VDDIO****                                      |
| 13   | SCx   | Digital in     | Primary   | SCK for SPI serial clock<br>SCL for I <sup>2</sup> C serial clock                                    | SCK                                         | SCK                                            | SCL                                            |
| 14   | SDx   | Digital<br>I/O | Primary   | SDA serial data I/O in I2C<br>SDI serial data input in SPI<br>4W<br>SDA serial data I/O in SPI<br>3W | SDI                                         | SDIO                                           | SDA                                            |

<sup>\*)</sup> If INT1 and/or INT2 are not used, please do not connect them (DNC). INT1 and/or INT2 can also be configured as input in case the external data synchronization of FIFO is used.

<sup>\*\*)</sup> If secondary interface is unused, ASDx and ASCx can be connected to VDDIO or left unconnected. Do not connect to GND. If configured as AUX I/F to connect and I2C slave sensor device, ASCx operates in push/pull-mode, ASDA operates in open-drain-mode. The internal pull-up resistor of the device is configured in Register AUX\_IF\_TRIM.asda\_pupsel.

<sup>\*\*\*)</sup> Can be tied to GND only if register <a href="IF\_CONF.ois\_en">IF\_CONF.ois\_en</a> = 0

<sup>\*\*\*\*)</sup> DNC is not recommended, but possible, if the system design ensures that the voltage never drops below VIH (internal pull-up available).

# 7.2 Connection Diagrams without Secondary Interface

It is recommended to use 100nF decoupling capacitors at pin 5 (VDDIO) and pin 8 (VDD).

## 7.2.1 Primary: 3-wire SPI Secondary: None



## 7.2.2 Primary: 4-wire SPI Secondary: None



# 7.2.3 Primary: I2C Secondary: None



Here SA0 = I2C slave address bit-0 select

# 7.3 Connection Diagrams with I2C Auxiliary Interface

It is recommended to use 100nF decoupling capacitors at pin 5 (VDDIO) and pin 8 (VDD).

## 7.3.1 Primary: 3-wire SPI Secondary: Auxiliary interface I2C (e.g. BMM150 sensor)



## 7.3.2 Primary: 4-wire SPI Secondary: Auxiliary interface I2C (e.g. BMM150 sensor)



# 7.3.3 Primary: I2C Secondary: Auxiliary interface I2C (e.g. BMM150 sensor)



# 7.4 Connection Diagrams with OIS Interface

It is recommended to use 100nF decoupling capacitors at pin 5 (VDDIO) and pin 8 (VDD).

## 7.4.1 Primary: 3-wire SPI Secondary: 4-wire SPI for OIS interface



#### 7.4.2 Primary: 3-wire SPI Secondary: 3-wire SPI for OIS interface



## 7.4.3 Primary: 4-wire SPI Secondary: 4-wire SPI for OIS interface



## 7.4.4 Primary: 4-wire SPI Secondary: 3-wire SPI for OIS interface



## 7.4.5 Primary: I2C Secondary: 4-wire SPI for OIS interface



# 7.4.6 Primary: I2C Secondary: 3-wire SPI for OIS interface



# **Package**

# Package outline dimensions



| DIMENSIONA | L REFERE           | unit: nn |      |  |
|------------|--------------------|----------|------|--|
| REF.       | Min.               | Nom.     | Max. |  |
| Α          | 0.79               | 0.83     | 0.87 |  |
| A1         | 0.11               | 0.13     | 0.15 |  |
| A2         | 0.68               | 0.70     | 0.72 |  |
| b          | Refer to metallize |          |      |  |
| L          | pad detail         |          |      |  |
| D          | 2.95               | 3.00     | 3.05 |  |
| E          | 2.45               | 2.50     | 2.55 |  |
| D1         | 1.00 BSC           |          |      |  |
| ZD         | 1.00 BSC           |          |      |  |
| ZE         | 0.50 BSC           |          |      |  |
| е          | 0.50 BSC           |          |      |  |
| L1         | 0.074              | 0.100    | -    |  |

| DIMENSIONA | L KEFEKENCES UNIT: MM |
|------------|-----------------------|
| REF.       | TOLERANCE OF FORM     |
|            | AND POSITION          |
| aaa        | 0.050                 |
| bbb        | 0.050                 |
| CCC        | 0.100                 |
| ddd        | 0.020                 |
| eee        | 0,056                 |
| xxx        | -                     |
|            |                       |

- Notes :

  ① 'e' REPRESENTS THE BASIC TERMINAL PITCH.

  SPECIFIES THE TRUE GEOMETRIC POSITION OF THE TERMINAL AXIS.
- Ø DIMENSION 'b' APPLIES TO METALLIZED TERMINAL PAD.
- 3 DIMENSION 'A' INCLUDES PACKAGE WARPAGE.
- EXPOSED METALLIZED PADS ARE CU PADS WITH SURFACE FINISH PROTECTION.
- 5 TOP PACKAGE SURFACE ROUGHNESS IS Ra 1~3um.

#### 8.2 Sensing axis orientation

If the sensor is accelerated and/or rotated in the indicated directions, the corresponding channels of the device will deliver a positive acceleration and/or yaw rate signal (dynamic acceleration). If the sensor is at rest without any rotation and the force of gravity is acting contrary to the indicated directions, the output of the corresponding acceleration channel will be positive and the corresponding gyroscope channel will be "zero" (static acceleration).

Example: If the sensor is at rest or at uniform motion in a gravity field according to the figure given below, the output signals are:

▶  $\pm$  0g for the X ACC channel and  $\pm$  0°/sec for the  $\Omega_X$  GYR channel

▶  $\pm$  0g for the Y ACC channel and  $\pm$  0°/sec for the  $\Omega_Y$  GYR channel

▶ + 1g for the Z ACC channel and  $\pm$  0°/sec for the  $\Omega_Z$  GYR channel



Definition of sensing axes orientation

The following table lists all corresponding output signals on X, Y, and Z while the sensor is at rest or at uniform motion in a gravity field under assumption of a ±4g range setting, a 16 bit resolution, and a top down gravity vector as shown above.

| Sensor<br>Orientation<br>(gravity vector ↓) | •             | •             | •                    | •             | upright     | उत्तेश्वायूग  |
|---------------------------------------------|---------------|---------------|----------------------|---------------|-------------|---------------|
| Output Signal X                             | 0g/0LSB       | 1g / 8192 LSB | 0g/0LSB              | -1g/-8192 LSB | 0g/0LSB     | 0g/0LSB       |
| Output Signal Y                             | -1g/-8192 LSB | 0g / 0 LSB    | 1g/8192 LSB 0g/0 LSB |               | 0g/0LSB     | 0g / 0 LSB    |
| Output Signal Z                             | 0g/0LSB       | 0g/0LSB       | 0g/0LSB              | 0g/0LSB       | 1g/8192 LSB | -1g/-8192 LSB |

If the sensor axes coordinates do not match the platforms axes coordinates, then axis remapping is required. For the accelerometer and gyroscope data, the axes remapping needs to be implemented in the applications processor's driver. For the interrupt features to work properly, axes remapping information must be written to configuration registers of the device. Axes remapping is supported via most interrupt features in a configuration registers, which applies to the feature algorithms.

# 8.3 Landing pattern recommendation

The following landing pad recommendation is given for maximum stability of the solder connections.



Pad tolerance: ±50 µm (L, W)

# 8.4 Marking

# 8.4.1 Mass production

| Labeling    | Name                      | Symbol | Remark                                                                             |
|-------------|---------------------------|--------|------------------------------------------------------------------------------------|
|             | Internal Code             | L      | 1 alphanumeric digit, fixed, L ≠ "E"<br>L = "P" or "L" or "W" or "N", internal use |
| ● VL        | Product Identifier        | V      | 1 alphanumeric digit, fixed, V = "5"<br>to identify BMI2xy product family          |
| ● VL<br>CCC | Counter ID                | ccc    | 3 alphanumeric digits, variable to generate trace-code.                            |
|             | Pin 1 identifier top side | •      |                                                                                    |

# 8.4.2 Engineering samples

| Labeling | Name                         | Symbol | Remark                                                                                       |
|----------|------------------------------|--------|----------------------------------------------------------------------------------------------|
|          | Eng. sample ID               | L, N   | 2 alphanumeric digit, fixed, L = "E" to identify engineering sample, N = "L" or "C"          |
| ● VL     | Product Identifier           | V      | 1 alphanumeric digit, fixed,<br>V = "P" or "L" or "W" or "N"                                 |
| NCC      | Counter ID                   | СС     | 2 alphanumeric digits, variable<br>Internal revision ID<br>to identify BMI2xy product family |
|          | Pin 1 identifier<br>top side | •      |                                                                                              |

#### 8.5 Soldering guidelines

The moisture sensitivity level of the device corresponds to JEDEC Level 1, see also

- ► IPC/JEDEC J-STD-020E "Joint Industry Standard: Moisture/Reflow Sensitivity Classification for non-hermetic Solid State Surface Mount Devices"
- ► IPC/JEDEC J-STD-033D "Joint Industry Standard: Handling, Packing, Shipping and Use of Moisture/Reflow Sensitive Surface Mount Devices"

Both documents are available on JEDEC's Website

The sensor fulfils the lead-free soldering requirements of the above-mentioned IPC/JEDEC standard, i.e. reflow soldering with a peak temperature  $T_p$  up to 260°C.

#### 8.6 Handling instructions

Micromechanical sensors are designed to sense acceleration with high accuracy even at low amplitudes and contain highly sensitive structures inside the sensor element. The MEMS sensor can tolerate mechanical shocks up to several thousand g's. However, these limits might be exceeded in conditions with extreme shock loads such as e.g. hammer blow on or next to the sensor, dropping of the sensor onto hard surfaces etc.

We recommend to avoid g-forces beyond the specified limits during transport, handling and mounting of the sensors in a defined and qualified installation process.

This device has built-in protections against high electrostatic discharges or electric fields (e.g. 2kV HBM); however, antistatic precautions should be taken as for any other CMOS component. Unless otherwise specified, proper operation can only occur when all terminal voltages are kept within the supply voltage range. Unused inputs must always be tied to a defined logic voltage level.

#### 8.7 Environmental safety

The device meets the requirements of the EC restriction of hazardous substances (RoHS) directive, see also:

ROHS-Directive 2011/65/EU and its amendments, including the amendment 2015/863/EU on the restriction of the use of certain hazardous substances in electrical and electronic equipment.

#### 8.7.1 Halogen content

The device is halogen-free. For more details on the corresponding analysis results please contact your Bosch Sensortec representative.

#### 8.7.2 Internal package structure

Within the scope of Bosch Sensortec's ambition to improve its products and secure the mass product supply, Bosch Sensortec qualifies additional sources (e.g. 2<sup>nd</sup> source) for the LGA package of the device.

While Bosch Sensortec took care that all of the package parameters as described above are 100% identical for all sources, there can be differences in the chemical content and the internal structure between the different package sources.

However, as secured by the extensive product qualification process of Bosch Sensortec, this has no impact to the usage or to the quality of the device.

## 9 Legal disclaimer

#### i. Engineering samples

Engineering Samples are marked with an asterisk (\*), (E) or (e). Samples may vary from the valid technical specifications of the product series contained in this data sheet. They are therefore not intended or fit for resale to third parties or for use in end products. Their sole purpose is internal client testing. The testing of an engineering sample may in no way replace the testing of a product series. Bosch Sensortec assumes no liability for the use of engineering samples. The Purchaser shall indemnify Bosch Sensortec from all claims arising from the use of engineering samples.

#### ii. Product use

Bosch Sensortec products are developed for the consumer goods industry. They may only be used within the parameters of this product data sheet. They are not fit for use in life-sustaining or safety-critical systems. Safety-critical systems are those for which a malfunction is expected to lead to bodily harm, death or severe property damage. In addition, they shall not be used directly or indirectly for military purposes (including but not limited to nuclear, chemical or biological proliferation of weapons or development of missile technology), nuclear power, deep sea or space applications (including but not limited to satellite technology).

Bosch Sensortec products are released on the basis of the legal and normative requirements relevant to the Bosch Sensortec product for use in the following geographical target market: BE, BG, DK, DE, EE, FI, FR, GR, IE, IT, HR, LV, LT, LU, MT, NL, AT, PL, PT, RO, SE, SK, SI, ES, CZ, HU, CY, US, CN, JP, KR, TW. If you need further information or have further requirements, please contact your local sales contact.

The resale and/or use of Bosch Sensortec products are at the purchaser's own risk and his own responsibility. The examination of fitness for the intended use is the sole responsibility of the purchaser.

The purchaser shall indemnify Bosch Sensortec from all third party claims arising from any product use not covered by the parameters of this product data sheet or not approved by Bosch Sensortec and reimburse Bosch Sensortec for all costs in connection with such claims.

The purchaser accepts the responsibility to monitor the market for the purchased products, particularly with regard to product safety, and to inform Bosch Sensortec without delay of all safety-critical incidents.

#### iii. Application examples and hints

With respect to any examples or hints given herein, any typical values stated herein and/or any information regarding the application of the device, Bosch Sensortec hereby disclaims any and all warranties and liabilities of any kind, including without limitation warranties of non-infringement of intellectual property rights or copyrights of any third party. The information given in this document shall in no event be regarded as a guarantee of conditions or characteristics. They are provided for illustrative purposes only and no evaluation regarding infringement of intellectual property rights or copyrights or regarding functionality, performance or error has been made.

# 10 Document history and modification

| Rev. No Section |                     | Description of modification/changes                       | Date          |  |
|-----------------|---------------------|-----------------------------------------------------------|---------------|--|
| 0.9             | -                   | Preliminary version                                       | 29-Feb-2019   |  |
| 1.0             | 6.5                 | Туро                                                      | 17-May-2019   |  |
| 1.1             | Basic Description   | Updated description                                       | 04-May-2020   |  |
|                 | 1                   | Updated Accel only normal mode current consumption, power |               |  |
|                 |                     | on time, Gyro PSR                                         |               |  |
|                 | 3.1.b               | Updated initialization sequence wait time                 |               |  |
|                 | 4.4                 | Corrected typos in wait time                              |               |  |
|                 | 4.5                 | Updated Power Modes table                                 |               |  |
|                 | 4.6                 | Updated Gyro CAS data post processing description         |               |  |
|                 | 4.7                 | Updated frame rates description (FIFO)                    |               |  |
|                 | 4.12                | Updated accelerometer self-test range                     |               |  |
|                 | 4.13                | Updated offset resolution for gyro                        |               |  |
|                 | 4.17                | Updated soft-reset timing constraints                     |               |  |
|                 | 5.1                 | Updated clear-on-read registers                           |               |  |
|                 | 6.2, 7.1            | Pin 12 description (table 17, 22)                         |               |  |
|                 | 6.4                 | Updated timing specifications for SPI (table 19)          |               |  |
|                 | 8.1                 | Updated package dimensions drawing (detailed)             |               |  |
|                 | 8.4                 | Updated MP Marking (internal code)                        |               |  |
|                 | 8.5, 8.7            | Updated references                                        |               |  |
|                 | 9                   | Updated legal disclaimer                                  |               |  |
| 1.2             | 2                   | Updated absolute max. rating for MM                       | 25-June-2020  |  |
|                 | 8.1                 | Erased redundant information                              |               |  |
| 1.3             | 9 Disclaimer Update |                                                           | 25-Nov-2020   |  |
| 1.4             | 6.6, 7.1            | Updated AUX I/F description                               | 13-Oct-2021   |  |
|                 | 4.4                 | Enhanced initialization description                       |               |  |
|                 | 4.7                 | FIFO synchronization                                      |               |  |
|                 | 6                   | Enhanced watchdog description                             |               |  |
|                 | 6.5                 | Updated timing specifications of I2C FM+                  |               |  |
|                 | 8.3                 | Updated pad tolerance (L, W: 50 µm)                       |               |  |
|                 | 2                   | Updated max shock limit                                   |               |  |
| 1.5             | 3                   | Updated wait time during initialisation                   | 13-March-2023 |  |
|                 | 4.7.1               | Corrected typo in Headerless mode frame size              |               |  |



#### **Bosch Sensortec GmbH**

Gerhard-Kindler-Straße 9 72770 Reutlingen / Germany

contact@bosch-sensortec.com www.bosch-sensortec.com

Modifications reserved Specifications subject to change without notice Document number: BST-BMI270-DS000-07