

# **BMA580**

Advanced, ultra-small, triaxial high performance low-g accelerometer with digital interfaces



## **BMA580 Datasheet**

Document revision 1.1

Document release date Feb 6th 2025

Document number BST-BMA580-DS000-05

Sales part number(s) 0 273 017 046

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 BMA580 is an advanced,ultra-small, triaxial high performance low-g accelerometer with digital interfaces. The sensor is suitable for low-power and demanding consumer electronics applications. The BMA580 integrates

- a 16 bit digital, triaxial accelerometer with range configurable to  $\pm 2\,\mathrm{g}$ ,  $\pm 4\,\mathrm{g}$ ,  $\pm 8\,\mathrm{g}$ ,  $\pm 16\,\mathrm{g}$
- lacktriangle a 8 bit digital temperature sensor for an operating temperature range  $-40\,^{\circ}\mathrm{C}$  ... 85  $^{\circ}\mathrm{C}$

#### **Key Features**

- Compact size 1.2 × 0.8 mm² Wafer Level Chip Scale Package (WLCSP), 6 pins, height 0.55 mm
- Primary digital interface with 10 MHz slave SPI (4-wire, 3-wire), 12.5 MHz I3C and up to 1 MHz I2C (Fm+)
- Sample rates (output data rates ODR): 1.5625 Hz . . . 6.4 kHz (nominal)
- Programmable low-pass filtering
- Wide power supply range: analog VDD 1.62 V ... 3.63 V
- Ultra low current consumption: typ.  $125\mu A$  (in full ODR and aliasing free operation)
- Built-in power management unit (PMU) for advanced power management and low power modes
- Power on time: 1.8ms for communication readiness
- up to 1 KB on-chip FIFO buffer for accelerometer, temperature sensor and sensor time stamps
- Fast offset error compensation for accelerometer
- Sensor time stamps for accurate system (host) and sensor time synchronization
- Two independent programmable I/O pins for interrupt and synchronization events
- On-chip interrupt engine and integrated smart features for always-on applications (e.g., activity, action, and gesture recognition) using the sensor ultra-low power domain:
  - single tap, double tap, and triple tap detection
  - Audio feature for hearables: "Voice Activity Detection"
  - generic interrupts (three parallel instances of a highly configurable flexible interrupt)
- RoHS compliant, halogen and lead free

# **Table of contents**

| Ba | sic D | escription                                                                                                                                                                                                                |                                                     | 2  |
|----|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|----|
| 1  | Spe   | cification                                                                                                                                                                                                                |                                                     | 9  |
| 2  | Abs   | olute Max                                                                                                                                                                                                                 | imum Ratings                                        | 12 |
| 3  | Quid  | 4.4.1 Temperature sensor and external voltage measurement  4.5 Interrupt Pin Configuration  4.5.1 Electrical Interrupt Pin Behavior  4.5.2 Interrupt Pin Mapping  4.5.3 Measurement of external signals on Interrupt Pins | 13                                                  |    |
| 4  | Fun   | ctional De                                                                                                                                                                                                                | scription and Advanced Features                     | 22 |
|    | 4.1   | Power Mo                                                                                                                                                                                                                  | ode States                                          | 22 |
|    |       | 4.1.1                                                                                                                                                                                                                     | ACTIVE State                                        | 22 |
|    |       | 4.1.2                                                                                                                                                                                                                     | SUSPEND State                                       | 22 |
|    |       | 4.1.3                                                                                                                                                                                                                     | Power on Time                                       | 22 |
|    | 4.2   | Acceleror                                                                                                                                                                                                                 | neter                                               | 23 |
|    |       | 4.2.1                                                                                                                                                                                                                     | Accelerometer Data                                  | 23 |
|    |       | 4.2.2                                                                                                                                                                                                                     | Accelerometer Data Processing                       | 23 |
|    |       | 4.2.3                                                                                                                                                                                                                     | Accelerometer Configuration                         | 24 |
|    |       | 4.2.4                                                                                                                                                                                                                     | Accelerometer Performance Mode                      | 24 |
|    |       | 4.2.5                                                                                                                                                                                                                     | Accelerometer Effective Bandwidth                   | 24 |
|    |       | 4.2.6                                                                                                                                                                                                                     | Accelerometer Change Configuration                  | 24 |
|    |       | 4.2.7                                                                                                                                                                                                                     | Accelerometer Self-Test                             | 25 |
|    |       | 4.2.8                                                                                                                                                                                                                     | Accelerometer Data Ready Interrupt                  | 26 |
|    |       | 4.2.9                                                                                                                                                                                                                     | Accelerometer Startup Time (Time to valid data)     | 26 |
|    |       | 4.2.10                                                                                                                                                                                                                    | Accelerometer Offset Compensation                   | 26 |
|    | 4.3   | Sensor tir                                                                                                                                                                                                                | ne                                                  | 27 |
|    | 4.4   | Temperat                                                                                                                                                                                                                  | ure Sensor                                          | 27 |
|    |       | 4.4.1                                                                                                                                                                                                                     | Temperature sensor and external voltage measurement | 27 |
|    | 4.5   | Interrupt I                                                                                                                                                                                                               | Pin Configuration                                   | 28 |
|    |       | •                                                                                                                                                                                                                         |                                                     |    |
|    |       | 4.5.2                                                                                                                                                                                                                     | Interrupt Pin Mapping                               | 28 |
|    |       | 4.5.3                                                                                                                                                                                                                     |                                                     |    |
|    |       | 4.5.4                                                                                                                                                                                                                     | Clear Interrupt Status                              | 29 |
|    |       | 4.5.5                                                                                                                                                                                                                     | Interrupt Behavior Example                          | 29 |
|    | 4.6   | FIFO                                                                                                                                                                                                                      |                                                     | 30 |
|    |       | 4.6.1                                                                                                                                                                                                                     | FIFO Configuration                                  |    |
|    |       | 4.6.2                                                                                                                                                                                                                     | FIFO Frames                                         |    |
|    |       | 4.6.3                                                                                                                                                                                                                     | FIFO Interrupts                                     |    |
|    |       | 4.6.4                                                                                                                                                                                                                     | FIFO Reset/Flush                                    |    |
|    | 4.7   | Soft-Rese                                                                                                                                                                                                                 | et                                                  | 34 |
|    | 4.8   |                                                                                                                                                                                                                           | ealth Status                                        |    |
|    | 4.9   | Advanced                                                                                                                                                                                                                  | d Features                                          | 34 |
|    |       | 4.9.1                                                                                                                                                                                                                     | General Configuration                               |    |
|    |       | 4.9.2                                                                                                                                                                                                                     | Generic Interrupt                                   |    |
|    |       |                                                                                                                                                                                                                           |                                                     |    |

|   |      | 4.9.3       | Any-Motion Detector                               | 39  |
|---|------|-------------|---------------------------------------------------|-----|
|   |      | 4.9.4       | No-Motion Detector                                | 39  |
|   |      | 4.9.5       | Tap Detection                                     |     |
|   |      | 4.9.6       | Self Wake-up                                      |     |
|   |      | 4.9.7       | In-Ear/Out-Ear Detection                          |     |
|   |      | 4.9.8       | Voice Activity Detection                          |     |
|   |      | 4.9.9       | Fast Offset Compensation (FOC)                    | 44  |
| 5 | Digi | tal Interfa | ces                                               | 45  |
|   | 5.1  | Electrical  | Specification                                     | 45  |
|   | 5.2  | Digital Int | erface Protocols                                  | 45  |
|   |      | 5.2.1       | Protocol Selection                                | 45  |
|   |      | 5.2.2       | SPI Protocol                                      | 46  |
|   |      | 5.2.3       | I <sup>2</sup> C Protocol                         | 50  |
|   |      | 5.2.4       | I3C Protocol                                      | 53  |
|   |      | 5.2.5       | Automatic Address Increment for Burst Access      | 61  |
| 6 | Men  | nory Map    |                                                   | 62  |
|   | 6.1  | Register I  | Map Description                                   | 62  |
|   |      | 6.1.1       | Register Map Overview                             | 63  |
|   |      | 6.1.2       | Register Map Details                              | 66  |
|   | 6.2  | Extended    | Register Map Description                          | 135 |
|   |      | 6.2.1       | Extended Register Map Overview                    | 136 |
|   |      | 6.2.2       | Extended Register Map Details                     | 138 |
| 7 | Pin  | Out and C   | onnection Diagrams                                | 182 |
|   | 7.1  | Pin Out .   |                                                   | 182 |
|   | 7 2  | Connectio   | on Diagrams                                       | 184 |
|   | 1.2  |             | Connection Diagrams with I <sup>2</sup> C and I3C |     |
|   |      | 7.2.2       | Connection Diagrams with SPI (3-Wire)             |     |
|   |      | 7.2.3       | Connection Diagrams with SPI (4-Wire)             |     |
| 8 | Pac  | kage        |                                                   | 188 |
|   | 8.1  | _           | ns                                                | 188 |
|   | 8.2  |             | Axis Orientation                                  |     |
|   | 8.3  | _           | Pattern Recommendation                            |     |
|   | 8.4  | _           |                                                   |     |
|   | 8.5  | _           | Reel Information                                  |     |
|   |      |             |                                                   |     |
|   | 8.6  | _           | Guidelines                                        |     |
|   | 8.7  | _           | Instructions                                      |     |
|   | 8.8  | Environm    | ental Safety                                      | 193 |
| 9 | Lega | al Disclain | ner                                               | 194 |

10 Document History and Modifications

195

# List of figures

| Figure 1:  | Device communication test                                                         | 14 |
|------------|-----------------------------------------------------------------------------------|----|
| Figure 2:  | Configure the SPI 3-wire interface                                                | 15 |
| Figure 3:  | Configure the I3C interface                                                       | 15 |
| Figure 4:  | Configure the device power mode                                                   | 16 |
| Figure 5:  | Configure the device suspend mode                                                 | 16 |
| Figure 6:  | Configure the sensor parameters and read sensor data                              | 17 |
| Figure 7:  | Mapping hardware interrupt                                                        | 18 |
| Figure 8:  | Change FIFO size                                                                  | 18 |
| Figure 9:  | Read registers in the extended register map                                       | 19 |
| Figure 10: | Write registers in the extended register map                                      | 19 |
| Figure 11: | Enable generic interrupt 1                                                        | 20 |
| Figure 12: | Enable FOC feature in combination with INT1                                       | 21 |
| Figure 13: | Sensor power mode state diagram                                                   | 22 |
| Figure 14: | Power on Time                                                                     | 23 |
| Figure 15: | Accelerometer Startup Time                                                        | 26 |
| Figure 16: | Power on Time and Accelerometer Startup Time                                      | 26 |
| Figure 17: | Interrupt output in latch mode                                                    | 29 |
| Figure 18: | Interrupt output in pulses mode                                                   | 30 |
| Figure 19: | Interrupt output when auto clear mechanism of the data ready interrupt is enabled | 30 |
| Figure 20: | Data Path of generic interrupt                                                    | 35 |
| Figure 21: | Data path of tap detection                                                        | 35 |
| Figure 22: | Data path of VAD                                                                  | 36 |
| Figure 23: | Axis remapping of datapath                                                        | 36 |
| Figure 24: | Functional behavior of generic interrupt                                          | 38 |
| Figure 25: | Reporting of tap gesture when TAP_DETECTOR_1.wait_for_timeout = 0b0               | 41 |
| Figure 26: | Reporting of tap gesture when settings_1.wait_for_timeout = 0b1                   | 42 |
| Figure 27: | SPI timing diagram                                                                | 47 |
| Figure 28: | SPI idle read timing                                                              | 47 |
| Figure 29: | SPI idle write timing                                                             | 47 |
| Figure 30: | Single-byte write operation of 4-wire SPI with mode 0                             | 48 |
| Figure 31: | Multiple-byte write operation of 4-wire SPI with mode 0                           | 48 |
| Figure 32: | Single-byte read operation of 4-wire SPI with mode 0                              | 48 |
| Figure 33: | Multiple-byte read operation of 4-wire SPI with mode 0                            | 49 |
| Figure 34: | Single-byte write operation of 4-wire SPI with mode 3                             | 49 |
| Figure 35: | Single-byte read operation of 3-wire SPI with mode 0                              | 49 |
| Figure 36: | Definition of rise- and fall-time of I <sup>2</sup> C interface signals           | 50 |
| Figure 37: | I <sup>2</sup> C timing diagram                                                   | 51 |
| Figure 38: | Single-byte write operation of I <sup>2</sup> C                                   | 51 |
| Figure 39: | Multiple-byte write operation of I <sup>2</sup> C                                 | 52 |
| Figure 40: | Multiple-byte read operation of I <sup>2</sup> C                                  | 52 |
| Figure 41: | Multiple read transmissions of I <sup>2</sup> C from the same start address       | 53 |
| Figure 42: | Single-byte write protocol of I3C                                                 | 58 |
| Figure 43: | Multi-Byte write protocol of I3C                                                  | 59 |
| Figure 44: | Multi-byte read protocol of I3C with repeated start                               | 60 |
|            |                                                                                   |    |

| Figure 45: | Multi-byte read protocol of I3C with stop-start                                                                         | . 60 |
|------------|-------------------------------------------------------------------------------------------------------------------------|------|
| Figure 46: | Multi-byte read protocol of I3C from the same start address with stop-start                                             | . 61 |
| Figure 47: | Pin-out: top view                                                                                                       | 182  |
| Figure 48: | Pin-out: bottom view                                                                                                    | 183  |
| Figure 49: | Connection Diagram with I <sup>2</sup> C and I3C                                                                        | 184  |
| Figure 50: | Connection that is not allowed in I <sup>2</sup> C and I3C before the pin 3 is configured to the output characteristics | 185  |
| •          | Connection that is not allowed in I <sup>2</sup> C and I3C before the pin 3 is configured to the output characteristics |      |
| Figure 52: | Connection Diagram with SPI 3-Wire                                                                                      | 186  |
| Figure 53: | Connection Diagram with SPI 4-Wire                                                                                      | 187  |
| •          | Dimensions from top (in mm)                                                                                             |      |
|            | Dimensions from bottom view (in mm)                                                                                     |      |
| Figure 56: | Dimensions from side view (in mm)                                                                                       | 189  |
| Figure 57: | Definition of the sensing axes orientation for the raw device                                                           | 189  |
| _          | Definition of the sensing axes orientation within a device                                                              |      |
|            | Landing pattern recommendation                                                                                          |      |
| Figure 60: | Tape and Reel information                                                                                               | 192  |
|            |                                                                                                                         |      |
|            |                                                                                                                         |      |
| List of t  | ables                                                                                                                   |      |
| Table 1:   | Basic electrical parameter specification                                                                                | 9    |
| Table 2:   | Operating conditions for the accelerometer                                                                              |      |
| Table 3:   | Performance characteristics of the accelerometer                                                                        |      |
| Table 4:   | Mechanical characteristics of the accelerometer                                                                         | . 10 |
| Table 5:   | Characteristics of the temperature sensor                                                                               | . 11 |
| Table 6:   | Absolute maximum ratings                                                                                                |      |
| Table 7:   | Sensitivity under different acceleration ranges                                                                         | . 23 |
| Table 8:   | Current Consumption (typical values) depending on ODR and number of averaged samples in LPM at                          |      |
|            | $V_{DD} = 1.8 \text{ V}, T_{A} = 25^{\circ}\text{C}.$                                                                   | . 24 |
| Table 9:   | Minimum threshold value of self-test                                                                                    | . 25 |
| Table 10:  | Pulse duration in the short and long pulses mode                                                                        | . 28 |
| Table 12:  | Register Map Overview                                                                                                   | . 31 |
| Table 14:  | Register Map Overview                                                                                                   | . 32 |
| Table 16:  | Register Map Overview                                                                                                   | . 32 |
|            | Register Map Overview                                                                                                   | . 32 |
| Table 19:  | Overview of supported ODRs in generic interrupts, any-motion/motion detector and no-motion/stationary detector.         | . 37 |
| Table 20:  | Supported ODRs in tap detection.                                                                                        | . 37 |
|            | Pin mapping of the digital interface                                                                                    |      |
|            | Electrical specification of the digital interface                                                                       |      |
|            | SPI mode 0 and mode 3 configuration                                                                                     |      |
|            | SPI interface timing specifications                                                                                     |      |
|            | I <sup>2</sup> C timing requirements (standard mode, fast mode snf fast mode plus)                                      |      |
|            | I3C Bus Identifier                                                                                                      |      |
|            | IBI Payload Format                                                                                                      |      |
|            | Mapping of I3C interrupts status bits to IBI payload                                                                    |      |
|            | • • •                                                                                                                   |      |

| Table 29: | GETCAPS returning value                    | 55  |
|-----------|--------------------------------------------|-----|
| Table 30: | GETSTATUS returning value                  | 55  |
| Table 31: | GETMXDS returning value                    | 56  |
| Table 32: | GETMWL returning value                     | 56  |
| Table 33: | GETMRL returning value                     | 56  |
| Table 34: | GETXTIME returning value                   | 57  |
| Table 35: | Open drain timing parameters of I3C        | 57  |
| Table 36: | Push-pull timing parameters for SDR of I3C | 58  |
| Table 37: | Register map overview                      | 63  |
| Table 38: | Extended register map overview             | 136 |
| Table 39: | Pin-out and pin connections                | 183 |
| Table 40: | Marking – Mass Production                  | 191 |
| Table 41: | Marking – Engineering Samples              | 191 |
| Table 42: | Change log                                 | 195 |

## 1 Specification

This chapter provides the specifications for the BMA580. Minimum values and maximum values are provided for standard distributed quantities as  $\mu \pm 3\sigma$ , typical values as  $\mu \pm \sigma$ . Unless stated otherwise, the specifications provide the characteristics for a nominal supply voltage of  $V_{\rm DD} = V_{\rm DDIO} = 1.8 \rm V$  either at an ambient temperature of  $T_{\rm A} = 25^{\circ} \rm C$ . This definition for minimum (Min), maximum (Max) and typical (Typ) values is also used throughout the other following chapters. Table 1 provides the electrical characteristics for the device.

Condition **Parameter Symbol** Min Max Unit Тур Supply voltage core 1.62 1.8 3.63 V  $V_{
m DD}$ (and I/O) domain  $V_{\rm DDIO}$ SPI, I<sup>2</sup>C & I3C V Voltage input low  $0.3 \cdot V_{\rm DDIO}$  $V_{\rm IL}$ level SPI, I<sup>2</sup>C & I3C 0.7 · V<sub>DDIO</sub> V Voltage input high  $V_{\rm IH}$ level Voltage output low SPI  $0.2 \cdot V_{\rm DDIO}$ V  $V_{\rm IL}$ level Voltage output high SPI 0.8 · V<sub>DDIO</sub> V  $V_{\rm IH}$ level 4.75 Suspend mode Current 18 Low power mode, μΑ  $I_{\rm DD}$ consumption  $f_{A,lp} = 100$ Hz High performance mode, 125  $f_{A,\cdot} = \max$ Time from supply "on" to 1.8 Power on time  $\Delta t_{\rm PO}$ ms serial I/F operational (and stable register access) °C Operating  $T_{\rm A}$ -40 +85 temperature  $\Delta f_{\rm A}$ Any mode enabled 3.0 % Accuracy of the @  $T_{\rm A} = 25^{\circ} C$ output data rate  $\Delta f_{\rm T}$ (accelerometer and temperature sensor)

Table 1: Basic electrical parameter specification

The Tables 2, 3 and 4 provide the operating conditions for the accelerometer and the related performance and mechanical characteristics.

**Parameter** Symbol Condition Min Тур Max **Units**  $\pm 2$ Selectable via serial digital ±4 Acceleration range  $a_{FS}$ g ±8 interface  $\pm 16$ From suspend mode to first data Start-up time - Time to valid data sample (in high performance 3.15 ms  $t_{A,SU}$ mode  $f_{A,.} = 1600 Hz$ )

Table 2: Operating conditions for the accelerometer

Table 3: Performance characteristics of the accelerometer

| Parameter              | Symbol                 | Condition                                                              | Min    | Тур   | Max  | Units                            |  |
|------------------------|------------------------|------------------------------------------------------------------------|--------|-------|------|----------------------------------|--|
| Resolution             |                        |                                                                        |        | 16    |      | bit                              |  |
|                        | S <sub>A,2g</sub>      | $a_{\rm FS}$ = 2 $g$                                                   |        | 16384 |      |                                  |  |
| Concitivity            | $S_{A,4g}$             | $a_{\rm FS}$ = 4 $g$                                                   |        | 8192  |      | LSB                              |  |
| Sensitivity            | $S_{A,8g}$             | $a_{\rm FS}$ = 8 $g$                                                   |        | 4096  |      |                                  |  |
|                        | S <sub>A,16g</sub>     | $a_{\rm FS}$ = $16g$                                                   |        | 2048  |      |                                  |  |
| Sensitivity error      | $S_{A,err}$            | Soldered, over life time,                                              |        |       | 0.5  | %                                |  |
|                        |                        | $a_{\rm FS}$ = 8 $g$                                                   |        |       |      |                                  |  |
| Sensitivity error      | TCS                    | Full $T_{\rm A}$ range, best fit                                       |        | 0.005 |      | %<br>K                           |  |
| temperature drift      |                        | straight line                                                          |        |       |      |                                  |  |
| Zero-g offset          | O <sub>A</sub>         | Soldered                                                               |        | ±35   |      | mg                               |  |
| Zero-g onset           | $O_{ m A,life}$        | Soldered, over life time                                               |        | ±50   |      | mg                               |  |
| Zero-g offset          | TCO                    | Full $T_{\rm A}$ range, best fit                                       |        | ±0.2  |      | mg<br>K                          |  |
| temperature drift      |                        | straight line                                                          |        |       |      | K                                |  |
| Noise density          | n <sub>A,density</sub> | High performance mode,                                                 |        | 120   |      | $\frac{\mu g}{\sqrt{\text{Hz}}}$ |  |
|                        |                        | $a_{\rm FS}$ = 8 $g$                                                   |        |       |      | VIIZ                             |  |
| Nonlinearity error     | $S_{ m A,NL}$          | Best fit straight line,                                                |        | 0.2   |      | %FS                              |  |
|                        |                        | $a_{\rm FS}$ = 2 $g$                                                   |        |       |      |                                  |  |
| Output data rata (ODD) | $f_{A,\mathrm{hpm}}$ , | High performance mode                                                  | 12.5   |       | 6400 | Hz                               |  |
| Output data rate (ODR) | $f_{A,n}$              |                                                                        |        |       |      | HZ                               |  |
|                        | $f_{ m A,lpm}$         | Low-power mode                                                         | 1.5625 |       | 400  |                                  |  |
|                        | B <sub>A=12.5Hz</sub>  |                                                                        |        | 6.3   |      |                                  |  |
|                        | $B_{A=25Hz}$           |                                                                        |        | 12.5  |      |                                  |  |
|                        | $B_{A=50Hz}$           |                                                                        |        | 25    |      |                                  |  |
|                        | B <sub>A=100Hz</sub>   | $0Hz \le f \le f_{3dB-cutoff} \text{ of the }$                         |        | 50    |      |                                  |  |
| Bandwidth (BW) in high | $B_{\text{A=200Hz}}$   | accelerometer, $B_A = \frac{1}{2}f_A$                                  |        | 100   |      | Hz                               |  |
| performance            | $B_{A=400\mathrm{Hz}}$ | $-\frac{\text{accelerometer, } D_{A} - \frac{1}{2}I_{A}}{\text{[Hz]}}$ |        | 200   |      | 112                              |  |
|                        | $B_{\rm A=800Hz}$      | [ [114]                                                                |        | 400   |      |                                  |  |
|                        | B <sub>A=1600Hz</sub>  |                                                                        |        | 800   |      |                                  |  |
|                        | B <sub>A=3200Hz</sub>  |                                                                        |        | 850   |      |                                  |  |
|                        | B <sub>A=6400Hz</sub>  |                                                                        |        | 1675  |      |                                  |  |

Table 4: Mechanical characteristics of the accelerometer

| Parameter              | Symbol              | Condition              | Min | Тур | Max | Units |
|------------------------|---------------------|------------------------|-----|-----|-----|-------|
| Cross axis sensitivity | $S_{A,X}$           | Relative contribution  |     | 0.3 |     | %     |
|                        |                     | between any two of the |     |     |     |       |
|                        |                     | three axes             |     |     |     |       |
| Alignment error        | $\Delta \xi_{ m A}$ | Relative to package    |     | 0   |     | 0     |
|                        |                     | outline                |     |     |     |       |

Table 5 provides the temperature sensor related characteristics.

Table 5: Characteristics of the temperature sensor

| Parameter                     | Symbol           | Condition                    | Min    | Тур             | Max | Units    |
|-------------------------------|------------------|------------------------------|--------|-----------------|-----|----------|
| Resolution                    |                  |                              |        | 8               |     | bits     |
| Measurement Range             | $T_{\mathrm{S}}$ |                              | -41    |                 | 87  | °C       |
| Output at 23°C                |                  |                              |        | 0               |     | LSB      |
| Sensitivity                   | $S_{\mathrm{T}}$ |                              |        | 1               |     | LSB<br>K |
| Temperature offset            | O <sub>T</sub>   | After soldering              |        | ±1.5            |     | K        |
|                               |                  | @ $T_{\rm A} = 25^{\circ} C$ |        |                 |     |          |
| Temperature sensitivity error |                  | After soldering, $T_{ m P}$  |        |                 | ±18 | %        |
| Output Data Rate              | $f_{ m T,LPM}$   | Accelerometer in low         |        | $f_{\rm A,lpm}$ |     | Hz       |
| Output Data Nate              |                  | power mode                   |        | _               |     | пх       |
|                               | $f_{ m T,HPM}$   | Accelerometer in high        | 1.5625 |                 | 200 |          |
|                               |                  | performance mode             |        |                 |     |          |

## 2 Absolute Maximum Ratings

**Important:** Stress above limits stated in Table 6 may cause damage to the device. Exceeding the specified limits may affect the reliability of the device or can cause malfunction.

Table 6: Absolute maximum ratings

| Parameter                | Condition                         | Min  | Max               | Units |
|--------------------------|-----------------------------------|------|-------------------|-------|
| Voltage at Supply Pin    | $V_{\rm DD}$ = $V_{\rm DDIO}$ Pin | -0.3 | 4                 | V     |
| Voltage at any Logic Pin | Non-Supply Pin-out                | -0.3 | VDD + 0.3 and < 4 | V     |
| Passive Storage          | ≤ <b>6</b> 5                      | -50  | 150               | °C    |
| Temperature Range        |                                   |      |                   |       |
| OTP Non-Volatile         | <i>T</i> ≤ 85°C                   | 10   |                   | a     |
| Memory Data Retention    |                                   |      |                   |       |
| Mechanical Shock         | Duration $\leq 200 \mu s$         |      | 20000             | g     |
| ESD                      | HBM at any pin                    |      | 2000              | V     |
| 130                      | CDM                               |      | 500               | V     |

## 3 Quick Start Guide

The purpose of this chapter is to help developers to start working with the device by giving basic hands-on application examples. Before starting, the device has to be properly connected to the host and powered up.

## Notes on the Serial Interface Support

The communication between host processor and the device happens over one of the interfaces: I<sup>2</sup>C, I3C or SPI (4-wire and 3-wire). Each register read operation includes the following number of inserted dummy bytes before the payload:

- I<sup>2</sup>C: 0
- I3C: 1
- SPI: 1

For simplicity, the dummy bytes are not shown in the examples within this chapter. For more information about the interfaces and the protocol selection, please see Chapter 5. After power on reset or soft reset, the device is automatically configured in suspend mode.

## First Application Setup Example Procedures

After the proper power-up by applying the stable supply voltage to the corresponding device pins, the device enters automatically into the Power On Reset (POR) sequence. To ensure proper use of the device, certain configuration steps from the host are a mandatory prerequisite. The most typical operations will be explained in the following application examples by flow diagrams:

#### ■ Test communication and initialize the device in I<sup>2</sup>C or SPI 4-wire

Read the CHIP\_ID.chip\_id to ensure the correct communication. Before reading the CHIP\_ID.chip\_id, one initial transaction is required, while the returning value is invalid. This initial transaction determines the serial interface in either I<sup>2</sup>C or SPI 4-wire for later communication. Notably, the initial transaction through the I<sup>2</sup>C interface is not acknowledged by the sensor (NACK). Since the default power mode state of BMA580 is SUSPEND power mode state, the host must disable it for further operations. Also, it is recommended to read the health status of the sensor to ensure the proper power-on.



Figure 1: Device communication test

#### ■ Enable the SPI 3-wire interface:



Figure 2: Configure the SPI 3-wire interface

## ■ Enable the I3C interface:



Figure 3: Configure the I3C interface

Configure the power mode state:



Figure 4: Configure the device power mode

Configure the device in suspend mode:



Figure 5: Configure the device suspend mode

• Set the sensor parameters followed by reading the sensor data:



Figure 6: Configure the sensor parameters and read sensor data

Map the data ready hardware interrupt:



Figure 7: Mapping hardware interrupt

## Change the FIFO size:



Figure 8: Change FIFO size

• Read the registers in the extended register map:



Figure 9: Read registers in the extended register map

Write the registers in the extended register map:



Figure 10: Write registers in the extended register map

■ Enable advanced feature, e.g., generic interrupt 1:



Figure 11: Enable generic interrupt 1

■ Enable the Fast Offset Compensation (FOC) feature on Z-axis in combination with INT1. For a complete FOC procedure, it is recommended to perform the feature on all axes as explained in detail in chapter 4.9.9.



Figure 12: Enable FOC feature in combination with INT1

## 4 Functional Description and Advanced Features

#### 4.1 Power Mode States

The BMA580 supports ACTIVE and SUSPEND power mode states, which can be switched in CMD\_SUSPEND. After power on or soft-reset, the default power mode state of BMA580 is SUSPEND. Conclusively, the switch process is illustrated in Figure 13.



Figure 13: Sensor power mode state diagram

#### 4.1.1 ACTIVE State

In ACTIVE state, the accelerometer is active and there is no restriction in accessing the register map. The device can enter two further performance modes, namely low power mode (LPM) and high performance mode (HPM), and switch between them while in the ACTIVE state. The main difference between the two modes is the data sampling behavior of the acceleration signal.

## High Performance Mode (HPM)

In HPM, data is sampled continuously and fed to the filter that is configured by the host.

## Low Power Mode (LPM)

In LPM, only the necessary number of data is sampled for the average purpose, so that one can optimize the power consumption. However, since the acceleration signal is undersampled, the duty-cycling mode is prone to aliasing effects.

#### 4.1.2 SUSPEND State

In the SUSPEND state, the accelerometer is inactive and the internal oscillator is also shut down. In this mode, the register content prior to entering this power mode will be retained. Also, the host is limited to access the CHIP\_ID, CMD\_SUSPEND and CMD.cmd registers. Notably, executing soft-reset is possible in the SUSPEND mode.

Please also note that, once in the SUSPEND state, both INT1 and INT2 pins are configured in high-impedance state. To prevent the error interrupt detection by the host due to signal cross-talk, it is suggested to pull-up or pull-down the interrupt pins from the host side.

#### 4.1.3 Power on Time

The power on time of the BMA580 is typically 1.8ms (see also specification table 1). The power on time describes the time between powering the device ( $V_{\rm DD} \ge 1.62$ V) and the interface being ready to respond with stable register access. During the powering phase, the device will not be able to respond to any command sent on the serial interface.

Note that the power on time may vary if the ramp of VDD between 0V and 1.62V, which is controlled by the host, takes a longer time.



Figure 14: Power on Time

The power on time does not include the processing of the first acceleration value. See chapter 4.2.9 for more information about the time for the first valid data.

#### 4.2 Accelerometer

#### 4.2.1 Accelerometer Data

The three-dimensional acceleration data are provided with 16 bits width in two's complement representation, which are available in registers from ACC\_DATA\_0 to ACC\_DATA\_5. The 16 bits acceleration data for each axis contain a high byte and a low byte. To ensure the data integrity, the content in ACC\_DATA\_0 to ACC\_DATA\_5 must be read in a single burst read.

The output acceleration data are in LSB unit. They can be converted to a g unit using the following formula:

$$ACC [g] = 2's(ACC_{High} [LSB] \ll 8 + ACC_{Low} [LSB]) \times \frac{a_{FS}}{2^{15}}, \tag{4.1}$$

where  $a_{FS}$  is the acceleration range. The selection of the acceleration range leads to different sensitivity, as concluded in table 7;  $ACC_{High}$  and  $ACC_{Low}$  are the high byte and low byte of the acceleration data, respectively; "2's()" is the calculation of two's complement.

| Acceleration range | Sensitivity (t  | ypical value)      |
|--------------------|-----------------|--------------------|
| 2 g                | 1 g = 16384 LSB | 1 LSB = 61.035 µg  |
| 4 g                | 1 g = 8192 LSB  | 1 LSB = 122.070 μg |
| 8 g                | 1 g = 4096 LSB  | 1 LSB = 244.141 μg |
| 16 g               | 1 g = 2048 LSB  | 1 LSB = 488.281 μg |

Table 7: Sensitivity under different acceleration ranges

For example, if  $a_{\rm FS}$ = 8 g is selected, the acceleration data of 0x7FFF represents 8 g, while 0x8001 represents -8 g. Please note that, the the acceleration data of 0x8000 represents an invalid value, which occurs e.g., when the host sets an invalid configuration, or when the acceleration data is not yet ready after the power-on or during the configuration change.

## 4.2.2 Accelerometer Data Processing

The acceleration signals and the temperature data are processed according to the configured settings from corresponding registers (ACC\_CONF\_0 - ACC\_CONF\_2 and TEMP\_CONF). Additionally, the acceleration signals of the device can be compensated through the registers from ACC\_OFFSET\_0 to ACC\_OFFSET\_5. Please note that values in these registers are not persistent and must be written each time after the power-up or reset of the device.

## 4.2.3 Accelerometer Configuration

The host can configure the accelerometer via registers from ACC\_CONF\_0 - ACC\_CONF\_2. In detail:

- ACC\_CONF\_0 is used to enable or disable the accelerometer. Please note that, in BMA580, the accelerometer is disabled by default after power on, since the default power mode state is SUSPEND.
- ACC\_CONF\_1 is used to select the output data rate (ODR), the bandwidth parameter (BWP) for the filter configuration and the performance mode.
- ACC\_CONF\_2 is used to select the dynamic range, the filter roll-off, the measurement preference and clear mechanism
  of the acceleration data ready interrupt.
- CONFIG\_STATUS.acc\_conf\_err indicates invalid or valid accelerometer configurations.

## 4.2.4 Accelerometer Performance Mode

The device has two performance modes, namely low power mode (LPM) and high performance mode (HPM). The mode switching is controlled by the register field ACC\_CONF\_1.power\_mode. Only in LPM the overall power consumption depends strongly on the chosen ODR and the amount of averaged samples. Typical values can be seen in table 8.

Table 8: Current Consumption (typical values) depending on ODR and number of averaged samples in LPM at  $V_{DD}$  = 1.8 V,  $T_A$  = 25°C.

|         | current consumption - typical (μΑ) |       |       |  |  |  |
|---------|------------------------------------|-------|-------|--|--|--|
| ODR(Hz) | No Avg                             | Avg 2 | Avg 4 |  |  |  |
| 1.5625  | 7.1                                | 7.1*  | 7.1*  |  |  |  |
| 12.5    | 8.3                                | 8.4*  | 8.8*  |  |  |  |
| 25      | 9.6*                               | 10.0* | 10.9* |  |  |  |
| 50      | 12.4                               | 13.2* | 15.0* |  |  |  |
| 100     | 18.0                               | 19.7  | 23.3  |  |  |  |
| 200     | 28.9                               | 32.7* | 39.9* |  |  |  |
| 400     | 51.1                               | 58.6* | 73.1* |  |  |  |

(\*) estimated values.

## 4.2.5 Accelerometer Effective Bandwidth

The effective bandwidth of the accelerometer depends on the selection of ODR and BWP in register ??. For the HPM the effective bandwidth is nearly half of ODR for BWP=2 ("normal mode") or BWP=3 ("CIC mode") and ODR smaller than 1.6 kHz. The effective bandwidth is ODR/4 for BWP=1 ("OSR2 mode") and ODR/8 for BWP=0 ("OSR4 mode"). The effective bandwidth for ODR bigger than 1.6 kHz is limited to a value of 1.675 kHz.

For the LPM the effective bandwidth is only determined by the ODR and is always equal to ODR/2. With the help of the BW value the number of averaged samples for each ODR data sample can be selected: higher number of averaged samples lead to less noise but higher current consumption.

## 4.2.6 Accelerometer Change Configuration

Before the host changes the accelerometer configuration, it is recommended to disable the accelerometer first. The host can again enable the accelerometer after the configuration is finished. Any change of the accelerometer configuration is applied immediately.

After the configuration change, the host needs to wait for a certain time until the first valid sample is available. This waiting time depends on the changed configuration and the timing of the change. Please note that, in HPM, all samples after the first valid sample are given at the expected ODR. In LPM, it can sometimes occur that the time interval between the first and second samples is not as expected. This is meant for a quick data delivery in the LPM mode. The host can skip the first and second samples if an accurate ODR is necessary.

#### 4.2.7 Accelerometer Self-Test

The BMA580 has a comprehensive self-test function for the MEMS element by applying electrostatic forces to the sensor core instead of external accelerations. By actually deflecting the seismic mass, the entire signal path of the sensor can be tested. The activation of 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 self-test is activated and deactivated for all axes via ACC\_SELF\_TEST.self\_test. It is also possible to control the direction of the deflection through ACC\_SELF\_TEST.self\_test\_sign. The excitation occurs in positive (negative) direction if ACC\_SELF\_TEST.self\_test\_sign = 0b1 (0b0).

In below, the recommended procedure to use the self-test is given:

- 1. Disable all advanced features and interrupts, if any of them are enabled.
- 2. Activate the self-test
  - a. Disable the accelerometer in ACC\_CONF\_0.sensor\_ctrl
  - **b.** Apply the following configurations:
    - ACC\_CONF\_1.acc\_odr = 10
    - ACC\_CONF\_1.acc\_bwp = 2
    - ACC\_CONF\_1.power\_mode = 1
    - ACC\_CONF\_2.acc\_range = 2
    - ACC\_CONF\_2.acc\_iir\_ro = 1
    - ACC\_CONF\_2.noise\_mode = 0
    - ACC\_CONF\_2.acc\_drdy\_int\_auto\_clear = 0
  - c. Enable the accelerometer in ACC\_CONF\_0.sensor\_ctrl
  - d. Wait for at least 10 ms
  - e. Enable self-test and set the negative self-test polarity by setting
    - ACC\_SELF\_TEST.self\_test\_sign = 0
    - ACC\_SELF\_TEST.self\_test = 1
  - f. Wait for at least 10 ms
  - **g.** Read and store valid data of each axis from registers ACC\_DATA\_0 to ACC\_DATA\_5. Please check in SENSOR\_STATUS. acc\_data\_rdy before reading, if the valid data is ready.
  - h. Enable self-test and set the positive self-test polarity by setting
    - ACC\_SELF\_TEST.self\_test\_sign = 1
    - ACC\_SELF\_TEST.self\_test = 1
  - i. Wait for at least 10 ms
  - j. Read and store valid data of each axis from registers ACC\_DATA\_0 to ACC\_DATA\_5. Please check in SENSOR\_STATUS. acc\_data\_rdy before reading, if the valid data is ready.
  - k. Check self-test results:
    - i. Convert values from steps 2g and 2j for each axis. Please note that those values are signed values, so the host has to apply the two's complement calculation to the raw data.
    - ii. Calculate the difference between the values from step 2g and 2j
    - **iii.** Compare the difference against the minimum threshold values in Table 9. To pass the self-test, the measured difference has to exceed the minimum threshold value.

Table 9: Minimum threshold value of self-test

| x-axis (LSB) | y-axis (LSB) | z-axis (LSB) |
|--------------|--------------|--------------|
| 17500        | 17500        | 8000         |

- I. Disable the self-test by setting
  - ACC\_SELF\_TEST.self\_test = 0

- **3.** It is recommended to perform a soft-reset of the device after the self-test. Please note that, after the soft-reset, all user configuration settings are overwritten with their default state. If the soft-reset cannot be performed, the following sequence is required to reset the signal path:
  - a. Disable the accelerometer in ACC\_CONF\_0.sensor\_ctrl
  - **b.** Wait for at least 1 ms
  - c. Enable the accelerometer in ACC\_CONF\_0.sensor\_ctrl
- **4.** Now the host can apply user configuration to the accelerometer and again enable the advanced features and interrupts.

## 4.2.8 Accelerometer Data Ready Interrupt

This interrupt fires whenever a new data sample set from accelerometer. This allows a low latency data readout.

## 4.2.9 Accelerometer Startup Time (Time to valid data)

The accelerometer startup time of the BMA580 is typically 3.15ms (see also specification table 2). The accelerometer startup time describes the time between leaving the suspend mode and the availability of the first valid acceleration data, if the selected power mode is HPM and the selected ODR is 1600Hz. The BMA580 can indicate this time point with an interrupt, if the data ready trigger is selected. See chapter 4.5 for more details. During the powering phase the device will not be able to respond to any command sent on the serial interface.

Please note, that the accelerometer startup time may vary, if a different power mode is selected or a different ODR.



Figure 15: Accelerometer Startup Time

The accelerometer startup time is also related to the power on time, but not overlapping. For more information on the power on time, see chapter 4.1.3. The following picture shows both times in an example illustration:



Figure 16: Power on Time and Accelerometer Startup Time

## 4.2.10 Accelerometer Offset Compensation

The BMA580 offers manual compensation. The offset compensation is effective for data in ACC\_DATA\_0 - ACC\_DATA\_5 and FIFO, and signals for the advanced features. 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).

The offset compensation uses of the registers ACC\_OFFSET\_0 to ACC\_OFFSET\_5, providing a compensation value for each accelerometer axis x, y, z, respectively. The contents of the compensation register ACC\_OFFSET\_0 to ACC\_OFFSET\_5

may be set manually via the digital interface. It is recommended to restart the accelerometer after writing new values to the compensation register or write to the compensation register, while the accelerometer is disabled (see register ACC\_CONF\_0).

To disable the offset compensation, a value of 0x0 has to be written to all the compensation register ACC\_0FFSET\_0 to ACC\_0FFSET\_5.

The offset compensation registers have a width of 9 bit using two's-complement binary notation. The offset resolution is 0.98 mg (1024 LSB/g) with an offset range of +/-0.25 g. Please note that the resolution of the offset register is independent of the range setting (see register ACC\_CONF\_2.acc\_range). The compensation offset values are not persistent and must be written each time after power-up or reset of the device.

The BMA580 offers also the "Fast Offset Compensation" (FOC) feature, which is described in chapter 4.9.9.

## 4.3 Sensor time

The device supports the concept of sensor time. Its core element is a free running counter with a width of 24 bits. It runs at the frequency of 3.2 kHz, while the time resolution is 312.5 µs. The host can access the current state of the counter by reading registers from SENSOR\_TIME\_0 to SENSOR\_TIME\_2. The sensor time counter is synchronized with the data capturing event in the register from ACC\_DATA\_0 to ACC\_DATA\_5 and FIFO.

Please note that a burst read on register from SENSOR\_TIME\_0 to SENSOR\_TIME\_2 delivers always consistent values. Once the device enters the SUSPEND power mode state, the sensor time counter stops.

## 4.4 Temperature Sensor

The BMA580 provides a temperature sensor, sensing the internal temperature of the device. The temperature sensor is always on, when the accelerometer sensor is active.

The temperature sensor has 8 bits, the data can be read from register field TEMP\_DATA.temp\_data. The data register output is of the unit K. A data value of 0x0 means 23°C. The sensor can be configured via the register TEMP\_CONF: The output data rate for the temperature sensor can be set in the field TEMP\_CONF.temp\_rate

When there is no valid temperature information available, the temperature indicates an invalid value (0x80) and the register field SENSOR\_STATUS.temperature\_rdy shows a 0x0.

## 4.4.1 Temperature sensor and external voltage measurement

By using the temperature sensor, the BMA580 can also measure the external voltages via interrupt pins in the I<sup>2</sup>C mode. In below, the recommended procedure to use the external measurement feature is given:

- Enable accelerometer by setting ACC\_CONF\_0.sensor\_ctrl = 0x0F.
- 2. Configure the temperature sensor via TEMP\_CONF
  - a. Choose 200 Hz as the sample rate by setting TEMP\_CONF.temp\_rate = 0b111
  - Select the external voltage as the input source for the temperature sensor by setting TEMP\_CONF.temp\_meas\_src= 0b0
  - c. Select the interrupt pin for the voltage measurement via TEMP\_CONF.temp\_ext\_sel
  - **d.** Be sure to set the reserved bits (bits 5 to 7) in TEMP\_CONF to 0b000.
- 3. Apply the external voltage on the selected interrupt pin
- 4. Clear the temperature ready flag SENSOR\_STATUS.temperature\_rdy
- 5. Wait until SENSOR\_STATUS.temperature\_rdy becomes 0b1
- **6.** Burst-read measurement data from  $AUX_{Low}$  [LSB] = AUX\_DATA\_0 and  $AUX_{High}$  [LSB] = AUX\_DATA\_1
- **7.** Combine  $AUX_{Low}$  and  $AUX_{High}$  to 16-bit value AUX:

$$AUX[LSB] = AUX_{High}[LSB] \ll 8 + AUX_{Low}[LSB]$$
 (4.2)

**8.** Calculate the external voltage  $V_{ext}$  using the following equation:

$$V_{ext}[V] = \frac{AUX[LSB] - 2^{15}}{2^{15}} \times 1.6$$
 (4.3)

After the measurement of the external voltage is finished, the host needs to configure TEMP\_CONF so that the temperature sensor can be again used.

## 4.5 Interrupt Pin Configuration

The BMA580 has two external pins to provide the status of feature events. For certain digital interface settings, these pins are not available for this interrupt behavior but used by the digital interface. In I<sup>2</sup>C and I3C mode the two external pins are available for the feature events. In SPI 3-Wire mode, one pin is still available and in SPI 4-Wire mode no external pin is available to provide feature events. See table 39 and chapter 5 for more details.

## 4.5.1 Electrical Interrupt Pin Behavior

The electrical behavior of interrupt pins INT1 and INT2 can be configured in the register INT1\_CONF and INT2\_CONF, respectively.

## 4.5.1.1 Output Mode

In the register fields INT1\_CONF.mode and INT2\_CONF.mode, the output on the pins can be enabled/disabled, and the output mode can be configured between latch, short pulses and long pulses mode. Please note that, if the output pin is disabled, the interrupt status will not be updated.

- In the latch mode, the interrupt output is active when the status bit of any mapped interrupt source is set. It will remain active until cleared.
- In the short and long pulses mode, the interrupt output is active when the status bit of any mapped interrupt source is set. Then, after a certain pulse duration, the the interrupt output becomes automatically inactive, while the corresponding status bit of any mapped interrupt source remains uncleared. In other words, the host needs to clear the interrupt status bit if necessary. Table 10 provides the typical pulse duration in the short and long pulses mode.

Table 10: Pulse duration in the short and long pulses mode

|                     | Short pulses mode | Long pulses mode |
|---------------------|-------------------|------------------|
| Typ. pulse duration | 625 ns            | 10 us            |

Especially, in addition to the common output mode setting, the auto clear mechanism of the data ready interrupt can be configured in ACC\_CONF\_2.acc\_drdy\_int\_auto\_clear. When this option is enabled, the status flag of acc\_drdy\_int is cleared automatically after the half of the ODR duration. This saves the need for the host to clear each data ready interrupt status. Please note that, it is recommended to enable the auto clear mechanism in latch mode, but not in pulses mode, since the pulses mode behaves already similarly to the auto clearing with small difference.

#### 4.5.1.2 Output Characteristics

The characteristic of the output driver of the interrupt pins may be configured with fields INT1\_CONF.od and INT2\_CONF. od. By setting these bits to 0b1, the output driver shows open-drain characteristic. By setting the configuration bits to 0b0, the output driver shows push-pull characteristic. The electrical behavior of the interrupt pins, whenever an interrupt is triggered, can be configured as either "active-high" or "active-low" via INT1\_CONF.1v1 respectively INT2\_CONF.1v1.

Please note the high impedance state of interrupt pins when the BMA580 is in the SUSPEND state, as already mentioned in chapter 4.1.2.

## 4.5.2 Interrupt Pin Mapping

In order for the host to react to the features output, they can be mapped to the external pin INT1 or pin INT2, by setting the corresponding bits from the registers INT\_MAP\_0, INT\_MAP\_1 and INT\_MAP\_3. To disconnect the features outputs to the

external pins, the same corresponding bits must be reset, from those registers. Once a feature triggers the output pin, the host can read out the corresponding bit from the register INT\_STATUS\_INT1\_0, INT\_STATUS\_INT1\_1,INT\_STATUS\_INT2\_0 or INT\_STATUS\_INT2\_1.

Besides to the two external pins, the interrupts can also be mapped to the I3C in band interrupts (IBI), if the BMA580 is in I3C mode. In this case, the status can be handled in the register INT\_STATUS\_I3C\_0 and INT\_STATUS\_I3C\_1.

BMA580 allows the host to map multiple interrupt sources to the same destinations, e.g. INT1, INT2, I3C IBI. In this case, to clear the status of that destination, each single mapped source needs to be cleared individually. On the other hand, BMA580 does not support mapping a interrupt source to several destinations in parallel.

## 4.5.3 Measurement of external signals on Interrupt Pins

Instead of using the external pins INT1 and INT2 as destination for internal triggers, the pins can be configured to be an input for an external voltage in the range of 0.1V to 0.9V. If this feature is enabled via the register field TEMP\_CONF. temp\_meas\_src and TEMP\_CONF.temp\_ext\_sel, no temperature value is available anymore. The data of the external voltage is digitalized and can be read in the register field AUX\_DATA\_0.aux\_data\_7\_0 and AUX\_DATA\_1.aux\_data\_15\_8.

## 4.5.4 Clear Interrupt Status

In BMA580, the interrupt status is cleared upon writing 1'b1 to the corresponding interrupt status bit.

## 4.5.5 Interrupt Behavior Example

For a better understanding of the interrupt pin behavior of BMA580, the following examples under various configurations are provided. For simplicity, the "INT pin" represents both INT1 and INT2 pins, and the electrical behavior of the interrupt pins is configured as "active-high".

**Latch Mode** Figure 17 shows the timing diagram when the latch mode is configured. FEATURE\_A and FEATURE\_B can represent any interrupt source, and are mapped to the same INT pin target. Detailed explanations of the timing diagram are provided in below:

- When the interrupt event "1" of FEATURE\_A comes, the corresponding FEATURE\_A\_int\_status is set immediately high. FEATURE\_A\_int\_status is cleared after the host executes the clear operation at "2".
- When the interrupt event "3" of FEATURE\_B comes, the corresponding FEATURE\_B\_int\_status is set immediately high. While the interrupt event "3" of FEATURE\_B remains active, a clear operation such as "4" will fail to clear the FEATURE\_B\_int\_status. This describes the case of e.g., FIFO full interrupt. FEATURE\_B\_int\_status can be cleared at "5", when FEATURE\_B is no more active.
- The INT pin is set to high as long as one of the interrupt status is active.



Figure 17: Interrupt output in latch mode

**Pulses Mode** Figure 18 shows the timing diagram when the pulses mode is configured. FEATURE\_A and FEATURE\_B can represent any interrupt source, and are mapped to the same INT pin target. Detailed explanations of the timing diagram are provided in below:

- When the interrupt event "1" of FEATURE\_A comes, the corresponding FEATURE\_A\_int\_status is set immediately high, so is the INT pin. Since the pulses mode is configured, the INT pin turns to low after the duration defined in table 10. Then, when another interrupt event "2" of FEATURE\_A comes, a pulse signal is again generated on the INT pin without the FEATURE\_A\_int\_status to be cleared. At the end, FEATURE\_A\_int\_status is cleared after the host executes the clear operation at "3".
- When the interrupt event "4" of FEATURE\_B comes, the corresponding FEATURE\_B\_int\_status is set immediately high, so is the INT pin. Since the pulses mode is configured, the INT pin turns to low after the duration defined in table 10. While the interrupt event "4" of FEATURE\_B remains active, a clear operation such as "5" will fail to clear the FEATURE\_B\_int\_status. This describes the case of e.g., FIFO full interrupt. FEATURE\_B\_int\_status can be cleared at "6", when the FEATURE\_B is no more active.



Figure 18: Interrupt output in pulses mode

**Auto Clear Mechanism of the Data Ready Interrupt** Figure 19 shows the timing diagram when the auto clear mechanism of the data ready interrupt is enabled. Both the acc\_drdy\_int and INT pin is cleared automatically after the half of the ODR duration.



Figure 19: Interrupt output when auto clear mechanism of the data ready interrupt is enabled

#### **4.6 FIFO**

The BMA580 provides a first-in first-out (FIFO) data buffer for the accelerometer data as well as optionally the sensor time. The size of this FIFO is configurable with a maximum of 1024 bytes.

## 4.6.1 FIFO Configuration

The FIFO can be configured by the user registers FIFO\_CONF\_0 and FIFO\_CONF\_1.

#### 4.6.1.1 Enabling FIFO

The register FIFO\_CONF\_0 is used to enable or disable the complete FIFO functionality or to sample only individual axis.

#### 4.6.1.2 FIFO Compression

The field FIFO\_CONF\_0.fifo\_compression can be configured to store only 8 bit of acceleration data. If the compression is enabled, only the high byte of the acceleration data is stored, e.g., ACC\_DATA\_1.acc\_x\_15\_8.

#### 4.6.1.3 Sensor Time in FIFO

The field FIFO\_CONF\_1.fifo\_sensor\_time can be configured to disable the sensor time, to send dedicated sensor time frame, or to append sensor time to each frame. For more information of the dedicated sensor time frame, please refer to section 4.6.2.4.

## 4.6.1.4 FIFO Stop-on-full Mode

The FIFO stop-on-full mode can be configured in the field FIFO\_CONF\_1.fifo\_stop\_on\_full, and the full level is defined as the FIFO size minus two times the payload size.

#### 4.6.1.5 FIFO Size

The size of this FIFO is configurable with a maximum of 1024 bytes. The default is 512 bytes, which allows the feature engine to work in parallel to the FIFO. The FIFO size can be configured with the help of the register field FIFO\_CONF\_1. fifo\_size. Since FIFO and the feature engine share a common memory, the size configuration is locked when the feature engine is enabled. Then this register is controlled by the feature engine and the value might change depending on the chosen features with their possible configuration.

The register field FIFO\_CONF\_1.fifo\_size can only be changed, once the feature engine is disabled. With the feature engine disabled, a FIFO size up to 1024 bytes is possible, while with the feature engine enabled, a FIFO size of 512 bytes or less is possible.

## 4.6.2 FIFO Frames

#### 4.6.2.1 FIFO Header

The FIFO header has the following structure in below:

Table 12: Register Map Overview

| Legend |        | Read  | Read-only Read/Wri |            | /Write | Vrite Write-only |          | Reserved |          |          |
|--------|--------|-------|--------------------|------------|--------|------------------|----------|----------|----------|----------|
| Index  | Name   | Value | bit7               | bit6       | bit5   | bit4             | bit3     | bit2     | bit1     | bit0     |
| 0x0    | HEADER | 0x80  | const_1            | frame_type |        | compr_en         | acc_z_en | acc_y_en | acc_x_en | acc_t_en |

Please note that the FIFO header is not stored in the memory while generated during the FIFO read-out process. This needs to be considered cautiously, when the host calculates the correct number of data frames in the FIFO.

**Field frame\_type** Field frame\_type encodes the type of payload data:

- 2'b00: empty frame
- 2'b10: acceleration data frame
- 2'b01: dedicated sensor time frame

**Field acc\_x/y/z\_en** Field acc\_x/y/z\_en displays the selection of accelerometer axis in the FIFO. If the acc\_x/y/z\_en field of the header equals 1'b1, the corresponding axis data is contained in the FIFO frame. Otherwise, the axis data is not part of the FIFO frame. The order of the payload bytes is x, y and z.

**Field compr\_en** Field compr\_en displays the enabling state of FIFO data compression. If data compression is enabled (FIFO\_CONF\_0.fifo\_compression = 1'b1), each enabled axis contributes one byte (the MSB) to the payload. Otherwise, each enabled axis contributes two bytes to the payload.

**Field acc\_t\_en** Field acc\_t\_en displays the enabling state of sensor time in each FIFO frame. The host can choose the way to display sensor time by configuring FIFO\_CONF\_1.fifo\_sensor\_time, which can change the header format. This is explained in 4.6.2.3 and 4.6.2.4.

## 4.6.2.2 Empty Frame

An empty frame has no payload and only consists of a single byte as header.

Table 14: Register Map Overview

| Legend |        | Read-only Rea |         | Read       | /Write | Write-only |          | Reserved |          |          |
|--------|--------|---------------|---------|------------|--------|------------|----------|----------|----------|----------|
| Index  | Name   | Value         | bit7    | bit6       | bit5   | bit4       | bit3     | bit2     | bit1     | bit0     |
| 0x0    | HEADER | 0x80          | const_1 | frame_type |        | compr_en   | acc_z_en | acc_y_en | acc_x_en | acc_t_en |

#### 4.6.2.3 Acceleration Data Frame

The number of payload bytes depends on the configuration of FIFO\_CONF\_0 and FIFO\_CONF\_1. If the FIFO is configured in such a way that the payload would be 0 (i.e. no axis enabled, no sensor time), no data will be stored in the FIFO memory and only empty frames will be read.

The minimum data frame size is 2 byte, when only a single axis and data compression is enabled.

If FIFO\_CONF\_1.fifo\_sensor\_time is configured as 2'b10, the sensor time is appended to each data frame. Please note that the sensor time data in each data frame occupies the FIFO space.

For an acceleration data frame the maximum frame size looks as follows:

Table 16: Register Map Overview

| Legend |           | Read-only |                    | Read/Write |          | Write-only |          | Reserved |          |      |
|--------|-----------|-----------|--------------------|------------|----------|------------|----------|----------|----------|------|
| Index  | Name      | Value     | bit7               | bit6       | bit5     | bit4       | bit3     | bit2     | bit1     | bit0 |
| 0x0    | HEADER    | 0xCF      | const_1 frame_type |            | compr_en | acc_z_en   | acc_y_en | acc_x_en | acc_t_en |      |
| 0x1    | PAYLOAD_0 | 0x00      |                    | acc_x_7_0  |          |            |          |          |          |      |
| 0x2    | PAYLOAD_1 | 0x00      |                    | acc_x_15_8 |          |            |          |          |          |      |
| 0x3    | PAYLOAD_2 | 0x00      | acc_y_7_0          |            |          |            |          |          |          |      |
| 0x4    | PAYLOAD_3 | 0x00      | acc_y_15_8         |            |          |            |          |          |          |      |
| 0x5    | PAYLOAD_4 | 0x00      | acc_z_7_0          |            |          |            |          |          |          |      |
| 0x6    | PAYLOAD_5 | 0x00      |                    | acc_z_15_8 |          |            |          |          |          |      |
| 0x7    | PAYLOAD_6 | 0x00      | sensor_time_7_0    |            |          |            |          |          |          |      |
| 0x8    | PAYLOAD_7 | 0x00      | sensor_time_15_8   |            |          |            |          |          |          |      |
| 0x9    | PAYLOAD_8 | 0x00      | sensor_time_23_16  |            |          |            |          |          |          |      |

## 4.6.2.4 Dedicated Sensor Time Frame

If FIFO\_CONF\_1.fifo\_sensor\_time is configured as 2'b01, the FIFO sends a dedicated sensor time frame when the FIFO runs empty during a read burst. It has the following format:

Table 18: Register Map Overview

| Legend |           |       | Read-only         |            | Read/Write |          | Write-only |          | Reserved |          |
|--------|-----------|-------|-------------------|------------|------------|----------|------------|----------|----------|----------|
| Index  | Name      | Value | bit7              | bit6       | bit5       | bit4     | bit3       | bit2     | bit1     | bit0     |
| 0x0    | HEADER    | 0xA1  | const_1           | frame_type |            | compr_en | acc_z_en   | acc_y_en | acc_x_en | acc_t_en |
| 0x1    | PAYLOAD_0 | 0x00  | sensor_time_7_0   |            |            |          |            |          |          |          |
| 0x2    | PAYLOAD_1 | 0x00  | sensor_time_15_8  |            |            |          |            |          |          |          |
| 0x3    | PAYLOAD_2 | 0x00  | sensor_time_23_16 |            |            |          |            |          |          |          |

The dedicated sensor time frame will be transmitted after the last sensor data frame has been read. This means that the dedicated sensor time frame is always preceded by sensor data frames and followed by empty frames. No sensor time frame will be transmitted if a read burst starts when the FIFO is already empty. The content of the dedicated sensor time frame is sampled when the header byte of the sensor time is read.

Please note that, the dedicated sensor time frame is not stored in the FIFO memory.

## 4.6.2.5 FIFO Frame Read Out

It is recommended to burst read the FIFO frame to ensure the proper read out of dedicated sensor time frame, if it is enabled. Also, once FIFO frames are read out, it will be discarded in the FIFO memory, while the unread ones remains there. Therefore, it is strongly recommended to read out all available frames once the FIFO content is ready. Otherwise, the remaining unread data will corrupt the next run of the FIFO.

**Read Out in Stop-on-full Mode** Please pay special attention to the FIFO read out process when the FIFO stop-on-full is enabled. In this case, the FIFO stops buffering data once the full condition is met. Then, the host can perform the burst-read operation to read out data. However, during the burst read process, once old samples are read out, they are discarded from the FIFO. Therefore, the FIFO full condition becomes no more valid, thus allowing new samples to be buffered in the FIFO.

This design helps to ensure the data continuity. However, this also leads to the situation that the host needs to read out more frames than what the FIFO can store in a full condition. At higher ODR, there are more additional frames. If the dedicated sensor time frame is enabled, this situation needs to be especially considered because the dedicated sensor time frame will be only transmitted after the last sensor data frame, as mentioned in section 4.6.2.4.

If the data continuity is not important, the host can disable the accelerometer before burst-read the FIFO. In this way, no additional frames during the read out process are required.

**Read Out Sensor Time in FIFO** The BMA580 provides various methods to read out acceleration data in association with sensor time data.

- The host can enable the sensor time data in each frame as described in section 4.6.2.3. In this way, each frame is labeled with a sensor time.
- The host can enable the dedicated sensor time frame as described in section 4.6.2.4. In this way, the BMA580 provides the sensor time at the moment when the host finishes reading the FIFO.
- Without enabling the dedicated sensor time frame, the host can perform a burst read starting from SENSOR\_TIME\_0.
  In this way, the BMA580 provides the sensor time at the moment when the host starts to read the FIFO.

## 4.6.3 FIFO Interrupts

The BMA580 offers two kinds of interrupt events, which can be mapped to the interrupt pins like any other interrupt sources. General information about interrupt pin configuration is described in chapter 4.5. Once the FIFO is enabled, the interrupt can be mapped directly to any destination. They do not have to be enabled separately. Please note, that for both interrupts, only the acceleration and sensor time data counts. The headers are not stored in the FIFO memory and not considered when determining the FIFO fill level.

## 4.6.3.1 FIFO Watermark Interrupt

The FIFO watermark interrupt will be asserted as long as the fill level is equal to or larger than the watermark level. Before the FIFO has reached the watermark level, any attempts to manually clear the FIFO watermark interrupt status will fail.

The watermark level can be set in the register FIFO\_WM\_1.fifo\_watermark\_level\_10\_8 and in the register FIFO\_WM\_0. fifo\_watermark\_level\_7\_0. The unit is bytes. If the level is set to a higher value than the FIFO size, the watermark interrupt will never be triggered.

## 4.6.3.2 FIFO Full Interrupt

The full level is defined as the FIFO size minus two times the payload size, as already mentioned in section 4.6.1.4. The FIFO full interrupt will be asserted as long as the fill level is equal to or larger than the full level. While the FIFO remains at the full level, any attempts to manually clear the FIFO full interrupt status will fail.

## 4.6.4 FIFO Reset/Flush

The FIFO may be explicitly flushed by writing FIFO\_CTRL.fifo\_rst = 1'b1. The FIFO is flushed automatically, if the FIFO configuration registers FIFO\_CONF\_0 and FIFO\_CONF\_1 are written or the device wakes up from suspend power state. Also, the FIFO is flushed automatically, if the accelerometer configuration is changed and the accelerometer signal path is reset. Conclusively, any writing operation to the register ACC\_CONF\_0, ACC\_CONF\_1 or ACC\_CONF\_2 will trigger the flushing.

## 4.7 Soft-Reset

In order to reset the BMA580 without removing the supply voltage, the offers a Soft-Reset. A Soft-Reset can be initiated at any time by writing the command softreset (0xB6) to register CMD.cmd. The softreset performs a fundamental reset to the device which is largely equivalent to a power cycle. Following a delay, all user configuration settings are overwritten with their default state. This command is functional in all operation modes.

#### 4.8 Sensor Health Status

The register field HEALTH\_STATUS.sensor\_health\_status indicates the internal health state of the device. A value of 0x0F indicates a good internal health state. The reserved bits in the same register HEALTH\_STATUS should be ignored. Any other values in the field HEALTH\_STATUS.sensor\_health\_status indicate an internal error. If the value remains on error state after reset and the external supply is stable and in correct range, the device should be checked.

#### 4.9 Advanced Features

## 4.9.1 General Configuration

#### 4.9.1.1 Enable and Disable Advanced Feature

To enable/disable the advanced features of the device, please follow the step in below:

- 1. Set/clear the corresponding feature enable bit. E.g., for the generic interrupt 1, write FEAT\_ENG\_GPR\_0.gen\_int1\_en= 1/0.
- 2. Set FEAT\_ENG\_GPR\_CTRL.update\_gprs= 1.

Please note that the second step needs to be performed every time when the corresponding feature enable bit is changed, so that the change becomes effective.

## 4.9.1.2 Data Path of Advanced Features

Depending on the advanced features, the datapath that feeds acceleration data to the feature engine is constructed in different ways.

**Data Path of Generic Interrupt** In the generic interrupt, the host can choose one of the following data sources via FEAT\_ENG\_GPR\_1.gen\_int1\_data\_src, FEAT\_ENG\_GPR\_1.gen\_int2\_data\_src, FEAT\_ENG\_GPR\_1.gen\_int3\_data\_src:

- 50 Hz filter data: the acceleration data that is directly down-sampled from the temperature compensated raw data. The ODR of this data source is locked at 50 Hz. This setting is the default and recommended value in case the generic interrupts are configured to the motion detection feature behavior (like Any-Motion Detector, see chapters 4.9.3 or 4.9.4).
- 200 Hz filter data: the acceleration data that is directly down-sampled from the temperature compensated raw data.
   The ODR of this data source is locked at 200 Hz.
- User filter data: the acceleration data that is available in registers ACC\_DATA\_0 ACC\_DATA\_5, which is configurable
  for the host via ACC\_CONF\_0 ACC\_CONF\_2.

Please note that, when different data path sources for the advanced features are used, there are limitations on the accelerometer ODR in LPM. Please refer to section 4.9.1.3.



Figure 20: Data Path of generic interrupt

Data Path of Tap detection The tap detection has the following data source:

200 Hz filter data: the acceleration data that is directly down-sampled from the temperature compensated raw data. The ODR of this data source is locked at 200 Hz.

The user filter data, which is available in ACC\_DATA\_0 - ACC\_DATA\_5, remains configurable for the host via ACC\_CONF\_0 - ACC\_CONF\_2.



Figure 21: Data path of tap detection

**Data Path of VAD** The VAD has the following data source:

User filter data that is fixed to a high-pass setting in HPM with an ODR of 1.6 kHz, when VAD is enabled.

Please note that, this configuration is locked and becomes in-configurable for the host. Any other user setting is by-passed. On the other hand, the host can choose one of the following data via GENERAL\_SETTINGS\_0.vad\_acc\_data\_src as the data source in ACC\_DATA\_0 - ACC\_DATA\_5:

- 50 Hz filter data: the acceleration data that is directly down-sampled from the temperature compensated raw data. The ODR of this data source is locked at 50 Hz.
- 200 Hz filter data: the acceleration data that is directly down-sampled from the temperature compensated raw data. The ODR of this data source is locked at 200 Hz.



Figure 22: Data path of VAD

**Axis remapping of datapath** The host can remap the accelerometer axes in GENERAL\_SETTINGS\_0.feat\_axis\_ex and change their polarity in GENERAL\_SETTINGS\_0.feat\_x\_inv, GENERAL\_SETTINGS\_0.feat\_y\_inv and GENERAL\_SETTINGS\_0.feat\_z\_inv, as illustrated in figure 23. Please note that the axis remapping feature does not influence the values in ACC\_DATA\_0 to ACC\_DATA\_5. It affects only the datapath that is fed to advanced features.



Figure 23: Axis remapping of datapath

## 4.9.1.3 Supported ODR in Advanced Features

The advanced features support various accelerometer ODRs.

For the following advanced features:

- generic interrupts
- any-motion/motion detector
- no-motion/stationary detector

in HPM, all available accelerometer ODRs are supported. In LPM, depending on the selection of the data path, the generic interrupts support only limited ODRs. Table 19 lists the supported ODRs.

Table 19: Overview of supported ODRs in generic interrupts, any-motion/motion detector and no-motion/stationary detector

| Power Mode State | Data path <sup>1</sup>                          | Supported accelerometer ODR               |
|------------------|-------------------------------------------------|-------------------------------------------|
|                  | FEAT_ENG_GPR_1.gen_int1_data_src = 1            |                                           |
| HPM              | FEAT_ENG_GPR_1.gen_int1_data_src = 2            | All available ODRs                        |
|                  | FEAT_ENG_GPR_1.gen_int1_data_src = 3            |                                           |
|                  | FEAT_ENG_GPR_1.gen_int1_data_src = 1            | ≥ 50 Hz                                   |
| LPM              | FEAT_ENG_GPR_1.gen_int1_data_src = 2            | ≥ 200 Hz                                  |
|                  | <pre>FEAT_ENG_GPR_1.gen_int1_data_src = 3</pre> | $6.25~\text{Hz} \geq \text{ODR} \geq 400$ |

For tap detection, in HPM, all available accelerometer ODR is supported. In LPM, the tap detection only supports ODR  $\geq$  200 Hz. Table 20 lists the supported ODRs.

Table 20: Supported ODRs in tap detection.

| Power Mode State | ODR                |
|------------------|--------------------|
| HPM              | All available ODRs |
| LPM              | ≥ 200 Hz           |

#### 4.9.1.4 Invalid Feature Configuration

If the host sets an invalid ODR that is not mentioned in Table 19 and Table 20, the device will automatically set FEAT\_ENG\_GPR\_5.feat\_conf\_err = 1 as an error signal. The detailed information about the features with invalid configuration can be looked up in FEAT\_CONF\_ERR.

Please note that the VAD feature cannot be enabled in parallel with the other features.

#### 4.9.1.5 Enable Advanced Features in Parallel

Advanced features, except for the self wake-up and VAD features, can be enabled and work in parallel. For the self wake-up feature, all other enabled features will be suspended when entering the LPM. For the VAD feature, once other features are enabled in parallel, the device will set FEAT\_ENG\_GPR\_5.feat\_conf\_err = 1.

It is recommended to deactivate all other features, when using the Fast Offset Compensation (FOC), described in chapter 4.9.9.

#### 4.9.2 Generic Interrupt

The generic interrupt feature of the device is designed to detect device's movements (activity) or device's static state (in-activity).

## 4.9.2.1 General Functional Behavior of Generic Interrupt

The functional behavior of the generic interrupt is presented in Figure 24. Generally, the change in the acceleration signal with respect to a defined reference value is monitored by the feature. Then, this change in the acceleration signal is compared against a configurable threshold value. Additionally, to avoid unwanted rapid interrupts, a hysteresis value can also be configured. Finally, to trigger the generic interrupt, the acceleration change must be either greater or lower than the configured threshold for a configured duration. The interrupt can be again cleared, when the condition remains false for a configured wait time.

The device provides the generic interrupts 1, 2 and 3, which can be enabled and disabled respectively via:

- FEAT\_ENG\_GPR\_0.gen\_int1\_en
- FEAT\_ENG\_GPR\_0.gen\_int2\_en
- FEAT\_ENG\_GPR\_0.gen\_int3\_en

<sup>&</sup>lt;sup>1</sup>The generic interrupt 1 is taken as an example. The rule is also applied to the generic interrupt 2 and 3.



<sup>\*</sup> Quiet time not depicted

Figure 24: Functional behavior of generic interrupt

All generic interrupts have the same implementation. Therefore, in the following description, only the generic interrupt 1 is used as an example.

- 1. GENERIC\_INTERRUPT1\_1.comb\_sel selects the combination logic of the chosen axis:
  - GENERIC\_INTERRUPT1\_1.comb\_sel = 0: combination of axes is set to logic OR.
  - GENERIC\_INTERRUPT1\_1.comb\_sel = 1: combination of axes is set to logic AND.
- 2. GENERIC\_INTERRUPT1\_2.criterion\_sel selects, whether the interrupt is triggered based on activity or in-activity:
  - GENERIC\_INTERRUPT1\_2.criterion\_sel = 0: interrupt triggers based on in-activity
  - GENERIC\_INTERRUPT1\_2.criterion\_sel = 1: interrupt triggers based on activity
- **3.** GENERIC\_INTERRUPT1\_2.acc\_ref\_up selects the approach, with which the acceleration reference signal is updated:
  - GENERIC\_INTERRUPT1\_2.acc\_ref\_up = 0: on-event. The reference acceleration is updated whenever there is an
    event (interrupt) being triggered by the feature.
  - GENERIC\_INTERRUPT1\_2.acc\_ref\_up = 1: always. An update of the reference acceleration is done with each new
    available acceleration sample.
  - GENERIC\_INTERRUPT1\_2.acc\_ref\_up = 2: manual. The reference acceleration is set manually by the host in:
    - GENERIC\_INTERRUPT1\_5.ref\_acc\_x
    - GENERIC\_INTERRUPT1\_6.ref\_acc\_y
    - GENERIC\_INTERRUPT1\_7.ref\_acc\_z
- 4. GENERIC\_INTERRUPT1\_1.axis\_sel selects the acceleration axes used for the generic interrupt feature:
  - GENERIC\_INTERRUPT1\_1.axis\_sel = 1: x-axis is used for the evaluation.
  - GENERIC\_INTERRUPT1\_1.axis\_sel = 2: y-axis is used for the evaluation.
  - GENERIC\_INTERRUPT1\_1.axis\_sel = 3: x-axis and y-axis are used for the evaluation.
  - GENERIC\_INTERRUPT1\_1.axis\_sel = 4: z-axis is used for the evaluation.
  - GENERIC\_INTERRUPT1\_1.axis\_sel = 5: x-axis and z-axis are used for the evaluation.
  - GENERIC\_INTERRUPT1\_1.axis\_sel = 6: y-axis and z-axis are used for the evaluation.
  - GENERIC\_INTERRUPT1\_1.axis\_sel = 7: x-axis, y-axis and z-axis are used for the evaluation.
- **5.** GENERIC\_INTERRUPT1\_1.slope\_thres configures threshold value that is compared to the change in the acceleration signal.
- 6. GENERIC\_INTERRUPT1\_2.hysteresis configures the hysteresis value to avoid unwanted rapid interrupts.
- **7.** GENERIC\_INTERRUPT1\_3.duration configures the duration parameter, in which the condition needs to remain true, so that the interrupt can be triggered.
- **8.** GENERIC\_INTERRUPT1\_3.wait\_time configures the wait time parameter, in which the condition needs to remain false, so that the interrupt can be cleared.
- **9.** GENERIC\_INTERRUPT1\_4.quiet\_time configures the quiet time behavior of the generic interrupt, which is not depicted in figure 24. It defines the minimum quiet time between two consecutive interrupt detection. This means that, after

an interrupt was triggered, no new interrupt will be triggered before the configured quiet time is expired.

## 4.9.3 Any-Motion Detector

The any-motion detector triggers an interrupt, when the slope between adjacent acceleration samples exceeds a threshold for a duration. It is realized using the generic interrupt. For that purpose, the following parameters have fixed values:

- 1. The axis combination selection is configured as logic OR (e.g. GENERIC\_INTERRUPT1\_1.comb\_sel = 0)
- 2. The criterion is configured as activity (e.g. GENERIC\_INTERRUPT1\_2.criterion\_sel = 1)
- 3. The acceleration reference update is configured as always (e.g. GENERIC\_INTERRUPT1\_2.acc\_ref\_up = 1).

By configuring the remaining parameters in the generic interrupt, the behavior of the any-motion detector can be influenced. In detail:

- **4.** The axis selection (e.g. GENERIC\_INTERRUPT1\_1.axis\_sel) defines, which axis or combination of axis is used to for the evaluation. (Change to single axis only if a the use case really demands it, in general the any motion detector works with all axis.)
- **5.** The slope threshold (e.g. GENERIC\_INTERRUPT1\_1.slope\_thres) influences the sensitivity of the detection.
- **6.** The hysteresis (e.g. GENERIC\_INTERRUPT1\_2.hysteresis) influences the sensitivity of the detection.
- 7. The duration (e.g. GENERIC\_INTERRUPT1\_3.duration) defines how long a motion beyond the threshold needs to be present before triggering an interrupt.
- **8.** The wait time (e.g. GENERIC\_INTERRUPT1\_3.wait\_time) defines, after an any-motion interrupt, how long a motion below the threshold needs to be present, before an interrupt is again cleared.
- **9.** The quiet time (e.g. GENERIC\_INTERRUPT1\_4.quiet\_time) defines the time of the no-interrupt state after an interrupt is triggered.

By default, the generic interrupt 1 is already configured as an any-motion detector. If necessary, other generic interrupts can also be configured as a an any-motion detector by the host.

#### 4.9.4 No-Motion Detector

The no-motion detector triggers an interrupt, when the slope between adjacent acceleration samples remains below a threshold for a duration. It is realized using the generic interrupt. For that purpose, the following parameters have fixed values:

- 1. The axis combination selection is configured as logic AND (e.g. GENERIC\_INTERRUPT2\_1.comb\_sel = 1).
- 2. The criterion is configured as in-activity (e.g. GENERIC\_INTERRUPT2\_2.criterion\_sel = 0).
- The acceleration reference update is configured as always (e.g. GENERIC\_INTERRUPT2\_2.acc\_ref\_up = 1).

By configuring the remaining parameters in the generic interrupt, the behavior of the any-motion detector can be influenced. In detail:

- 4. The axis selection (e.g. GENERIC\_INTERRUPT2\_1.axis\_sel) defines, which axis or combination of axis is used to for the evaluation. (Change to single axis only if a the use case really demands it, in general the no motion detector works with all axis.)
- 5. The slope threshold (e.g. GENERIC\_INTERRUPT2\_1.slope\_thres) influences the sensitivity of the detection.
- The hysteresis (e.g. GENERIC\_INTERRUPT2\_2.hysteresis) influences the sensitivity of the detection.
- 7. The duration (e.g. GENERIC\_INTERRUPT2\_3.duration) defines how long a motion blow the threshold needs to be present before triggering an interrupt.
- **8.** The wait time (e.g. GENERIC\_INTERRUPT2\_3.wait\_time) defines, after an no-motion interrupt, how long a motion beyond the threshold needs to be present, before an interrupt is again cleared.
- **9.** The quiet time (e.g. GENERIC\_INTERRUPT2\_4.quiet\_time) defines the time of the no-interrupt state after an interrupt is triggered.

By default, the generic interrupt 2 is already configured as a no-motion detector. If necessary, other generic interrupts can also be configured as a no-motion detector by the host.

#### 4.9.5 Tap Detection

The device allows the detection of different tap gestures. Supported tap gestures include the single-tap, double-tap and triple-tap.

**Enable and disable** Each gesture can be individually enabled and disabled via following fields:

- TAP\_DETECTOR\_1.s\_tap\_en
- TAP\_DETECTOR\_1.d\_tap\_en
- TAP\_DETECTOR\_1.t\_tap\_en.

**Interrupt status** When a tap gesture is detected, the event is reported in interrupt status registers, if the interrupt source is mapped. Each kind of gesture is reported individually. For example, if mapped to INT1, the interrupt status is available in:

- INT\_STATUS\_INT1\_0.stap\_int\_status
- INT\_STATUS\_INT1\_1.dtap\_int\_status
- INT\_STATUS\_INT1\_1.ttap\_int\_status

The status of the detected tap gesture is retained until the next gesture detection.

**Sensing axis** The dominant sensing axis can be configured using TAP\_DETECTOR\_1.axis\_sel. By default, TAP\_DETECTOR\_1.axis\_sel is selected to be the z-axis. Depending on the tap impact and direction, it is also possible to detect tap gestures which is not strictly aligned with the selected axis.

**Tap detection principle** A tap event is defined as subsequent crossings of a threshold within a configured maximum time limit between the crossings. The absolute value of the threshold for a tap detection is programmable via TAP\_DETECTOR\_2.tap\_peak\_thres. The maximum time window between the threshold crossings is defined by the parameter TAP\_DETECTOR\_3.max\_dur\_between\_peaks. To enable tap detection under noisy operating conditions, for a single tap movement, the limit on the number of threshold-crossing can be configured using TAP\_DETECTOR\_1. max\_peaks\_for\_tap.

Classification of a tap gesture The classification of a tap gesture as a double-tap or triple-tap gesture is dependent on the time window in which the 2nd or 3rd tap occurs after the first tap. The time window is set by TAP\_DETECTOR\_2. max\_gesture\_dur. For example, in case of a double-tap to be detected, the 2nd tap event have to occur within this limit after the first tap. In case of a triple-tap to be detected, the 2nd and 3rd tap events has to occur within this limit after the first tap.

**Reporting behavior of a tap gesture** On detection of a tap gesture, the reporting behavior of the event is determined by the value configured in TAP\_DETECTOR\_1.wait\_for\_timeout:

- TAP\_DETECTOR\_1.wait\_for\_timeout set to 0b0: each detected tap event is reported. E.g., to detect the triple-tap gesture, the 1st, 2nd and 3rd tap events are reported as single-tap, double-tap and triple-tap respectively, if they are enabled.
- TAP\_DETECTOR\_1.wait\_for\_timeout set to 0b1: the corresponding tap gesture is reported after the duration of TAP\_DETECTOR\_2.max\_gesture\_dur. E.g., to detect the triple-tap gesture, only the 3rd tap events is reported. No event is reported, if the number of detected taps is less or greater than three.

**Quiet time** Once a tap gesture is reported, the detection of a further gesture is suspended for a quiet time as defined by the parameter TAP\_DETECTOR\_3.quite\_time\_after\_gesture.

**Detection sensitivity mode** The tap detector offers the mode selection of the detection sensitivity for a tap event by configuring TAP\_DETECTOR\_1.mode. The detection modes affects the high-pass filter behavior, and enable a simple selection of sensitivity levels for tap detection, while keeping the values of other configuration parameters unchanged. Details are given in the memory map at TAP\_DETECTOR\_1.mode.

**Example** To illustrate the working principle of the tap detector, following diagrams are provided. figure 25 shows the behavior of the tap detector with all supported tap gestures enabled and with TAP\_DETECTOR\_1.wait\_for\_timeout set to 0b0. For every detected tap, the corresponding interrupt is reported if the taps occur within TAP\_DETECTOR\_2. max\_gesture\_dur since the first tap.





Figure 25: Reporting of tap gesture when TAP\_DETECTOR\_1.wait\_for\_timeout = 0b0

The tap detector behavior in case of enabling all supported tap gestures and with TAP\_DETECTOR\_1.wait\_for\_timeout set to 0b1 is depicted in the graphs in figure 26. As can be seen, only the 3rd tap detected within TAP\_DETECTOR\_2. max\_gesture\_dur after the first tap is reported.





Figure 26: Reporting of tap gesture when settings\_1.wait\_for\_timeout = 0b1

#### 4.9.6 Self Wake-up

The self wake-up feature is a built-in feature to support the smart power management of the device. To utilize the feature, the host stores two kinds of power mode settings in the device:

- The setting of HPM in ACC\_CONF\_1
- The setting of LPM in ACC\_CONF\_LOW\_POWER.

Depending on whether the any-motion or no-motion is detected, the device will switch automatically between the preconfigured HPM and LPM.

The prerequisite for the self wake-up feature are:

- The generic interrupt 1 is configured as the any-motion detector. Please refer to chapter 4.9.3 for the description of the any-motion detector.
- The generic interrupt 2 is configured as the no-motion detector. Please refer to chapter 4.9.4 for the description of the no-motion detector.
- The data source for generic interrupt 1 must be set to user filtered data. (FEAT\_ENG\_GPR\_1.gen\_int1\_data\_src = 0x03)
- ACC\_CONF\_LOW\_POWER.acc\_odr should be selected within 6.25 Hz to 50 Hz.
- The self wake-up feature and both generic interrupt features are enabled. Please refer to chapter 3 for the procedure
  of enabling advanced features.

The working principle of the self wake-up feature is explained in below:

- 1. When the no-motion is detected, ACC\_CONF\_1 is over-written with the value in ACC\_CONF\_LOW\_POWER, while the original setting in ACC\_CONF\_1 is retained internally. This switches the device from HPM to LPM. From now on, only the anymotion detection is active, while all other enabled features will be suspended. If the setting in ACC\_CONF\_LOW\_POWER. acc\_odr is invalid, an error will be reported in feat\_conf\_err.self\_wake\_up\_err. Now the device is in the predefined LPM.
- 2. Then, once the any-motion is detected, the internally retained setting is again restored in ACC\_CONF\_1, switching the device from LPM back to the internally retained HPM. Now, all enabled features are again processed. In case that the tap detection feature is enabled in parrallel, the first tap movement is processed as the trigger to enter HPM mode by the self wake-up feature, while the second tap movement is processed by the tap detection feature.
- **3.** If the self wake-up feature remains enabled, the step 1 is repeated.

When the switching event is triggered by the self wake-up feature, a corresponding interrupt can be raised if it is mapped in INT\_MAP\_2.self\_wake\_up\_int\_map, which can be used as a notification of the switch event.

Please note that, if the host disables the self wake-up feature, the setting in ACC\_CONF\_1 will not be recovered and is retained with the existing value. Therefore, the host might need to set a valid configuration to proceed with other features.

#### 4.9.7 In-Ear/Out-Ear Detection

The in-ear/out-ear detection requires the software support, and BMA580 is ready for the operation. Please contact your local sales contact for further detail.

The in-ear/out-ear detection uses the acceleration signal of a three axis accelerometer along with the signal of a proximity sensor. The goal is to reliably detect any in-ear scenario while on the other hand detecting if the device is out-ear. This can support the smart power management of the device, and therefore a longer batter life per charge.

#### 4.9.8 Voice Activity Detection

The device has the built-in voice activity detection (VAD). The host, such as a hearable device, can use the VAD to detect voice activity of the user wearing the hearable at ultra-low power consumption. To detect the voice activity, the device senses skull bone vibrations. Therefore, the VAD is insensitive to the environmental sound, and voices of other persons not wearing the hearable.

If the voice of the user is detected, a VAD interrupt is issued and the host can enable the communication interface and start reading sensor data.

After the VAD activated, the measurement range is automatically changed to +/-4 g, and the data path is configured in HPM with ODR = 1.6 kHz and a high-pass filter setting, as described in 22. During the time VAD is enabled, these registers must not be modified:

- ACC\_CONF\_0
- ACC\_CONF\_1
- ACC\_CONF\_2

Please note that, as described in chapter 4.9.1.4, the VAD feature cannot be enabled in parallel with the other features.

## 4.9.8.1 Activation

If needed, the VAD interrupted can be mapped as described in chapter 4.5. The VAD feature is activated or deactivated by setting FEAT\_ENG\_GPR\_0.vad\_en. Please also update FEAT\_ENG\_GPR\_CTRL.update\_gprs to make the configuration valid.

To optimize power consumption, in most cases it is sufficient to use only one sensor axis for VAD. The best axis needs to be determined through mechanical simulations of the hearable device or analysis of data recorded by the sensor in the hearable. The chosen sensing axis can be configured in VAD\_CTRL.

#### 4.9.9 Fast Offset Compensation (FOC)

The BMA580 offers the advanced feature "Fast Offset Compensation" (FOC). In principle, the FOC uses the same registers as the manual compensation as described in chapter 4.2.10, but offers an easier seeking of the dedicated compensation values.

**Prerequisites** There are prerequisites to use the FOC feature:

- It is recommended to place the sensor in a stable and noiseless environment.
- Additionally, one of the accelerometer axes must be aligned in parallel to the gravity vector during the compensation process.
- The accelerometer range has to be set to 16 g. (Write 0xf to register ACC\_CONF\_2)

**Configuration** To configure the FOC, the following parameters are available:

- FOC\_3.foc\_apply\_corr: this option decides, if the feature updates the ACC\_OFFSET\_0 ACC\_OFFSET\_5 with estimated
  offset values after feature completion automatically.
- FOC\_3.foc\_filter\_coeff: number of 200 Hz accelerometer samples that are averaged to estimate the offset.
- FOC\_3.foc\_axis\_1g: alignment information of the accelerometer axis to the gravity vector. Please note that BMA580 does not warn the user if the device is not static or an axis is not parallel to the gravitational vector.

**Execution** While the FOC feature is being executed, FEAT\_ENG\_GP\_FLAGS.foc\_running is set to 0b1. It will be cleared at the end of the compensation. Then, the FOC interrupts is raised, if it is mapped to any destination. Checking the interrupt is the recommended way to get the notification of FOC progress. After the FOC process is completed, it is recommended that the host disables the FOC feature in FEAT\_ENG\_GPR\_0.acc\_foc\_en, so that the feature can be restarted again. Also, please note that, if FOC\_3.foc\_apply\_corr is enabled, it is recommended to restart the accelerometer after the FOC completion, as was also suggested for the manual compensation in chapter 4.2.10.

As an example, Chapter 3 provides the recommend execution flow to perform FOC on one axis in combination with INT 1.

# 5 Digital Interfaces

The device provides one serial interface to the host. It acts as a slave to the host. The serial interface is configurable to the interface protocols SPI, I3C and I2C. Please note that, in the following chapter, only VDD is used to notate the power supply of the device, since VDD = VDDIO. The communication between host processor and the device happens over one of the interfaces: I2C, I3C or SPI (4-wire and 3-wire). Each register read operation includes the following number of inserted dummy bytes before the payload:

- I2C: 0
- I3C: 1
- SPI: 1

## 5.1 Electrical Specification

By default, the device operates in I<sup>2</sup>C mode or SPI 4-wire. The interface of the device can be configured to operate in a I3C or SPI 3-wire configuration as well. All digital interfaces share partly the same pins. The mapping for the primary interface of device is given in Table 21. The full pin mapping can be found in table 39.

I/O Type Pin# Name **Description** in SPI 4-wire in SPI 3-wire in I<sup>2</sup>C/I3C 2 INT1 Digital I/O Interrupt pin 1 (or Serial SDO/MISO INT1 INT1 Data) 3 Digital I/O CSB **CSB** INT2 Interrupt pin 2 (or Chip INT2\* Select for SPI) Digital I/O SDI/MOSI 4 SDA Serial Data SDX SDA 5 SCL Digital I/O Serial Clock SCK SCK SCL

Table 21: Pin mapping of the digital interface

In Table 22, the electrical specifications of the interface pins are given.

Symbol Condition **Parameter** Min Max Units Typ Pull-up resistance, CSB pin Internal Pull-up 75 100 125 kΩ  $R_{\rm up}$ Resistance to VDD Input capacitance  $C_{in}$ 5 рF I2C bus load capacitance (max. drive capability) 400  $C_{\text{load},I2C}$ pF I3C bus load capacitance (max. drive capability) 10 50 pF  $C_{\text{load,I3C}}$ 

Table 22: Electrical specification of the digital interface

## 5.2 Digital Interface Protocols

## 5.2.1 Protocol Selection

#### 5.2.1.1 Automatic Protocol Selection of I<sup>2</sup>C or 4-wire SPI

After the power on or soft-reset, the sensor automatically selects protocol after the host sends an initial transaction, while the returning value is invalid. This initial transaction determines the serial interface in either I<sup>2</sup>C or 4-wire SPI for the later communication.

Additionally, if I<sup>2</sup>C is selected as the communication protocol, there are certain limitations on the electrical connections on pin 3, especially during the power-up when INT 2 is configured as input. In detail:

<sup>\*</sup> Since pin 3 is used as CSB in SPI mode, it should not be driven low; see the chapter 7.2.1 for more details.

- When I<sup>2</sup>C/I3C is used, configure pin 3 to be output.
- When the output characteristics of pin 3 is disabled (or not yet enabled), please do not connect pin 3 to the ground.
- When the output characteristics of pin 3 is disabled (or not yet enabled), please do not connect pin 3 to a GPIO pin configured in the pull-down state.

Please find illustrations of the connection diagrams in chapter 7.2.1.

In practice, when I<sup>2</sup>C is selected as the primary protocol, it is strongly suggested to configure INT 2 as output via INT2\_CONF.mode. This helps to prevent an unexpected erroneous detection of SPI and therefore improve the stability of I<sup>2</sup>C communication.

#### 5.2.1.2 Protocol Selection of I3C

The host can switch to I3C from I2C protocol. Before accessing the registers of the device via I3C private transfers, the I3C must be enabled in the following way:

- The host has to set register IF\_CONF\_1.if\_i3c\_en = 1 via I2C write.
- The host has to apply the DAA (Dynamic Address Assignment) procedure via I3C CCC (Common Command Code) sequences according to the BCR (Bus Characteristics), the PID (Provisioned ID) and the static I²C slave address known by the host.
- After a successful DAA, the host can access registers via I3C private read and write.

#### 5.2.1.3 Protocol Selection of 3-wire SPI

The device supports both 4-wire and 3-wire SPI interfaces. The device operates in the 4-wire configuration by default. It can be switched to 3-wire configuration by setting register IF\_CONF\_1.if\_spi3\_en = 1. In the 3-wire configuration, the pin SDX is used as the common data input and output pin. Notably, although the change of SPI interface configuration is executed immediately, the SPI 3-wire configuration is effective only at the first read operation following the change to SPI 3-wire configuration and vice versa.

#### 5.2.2 SPI Protocol

The SPI interface of the device encompasses two orthogonal aspects, namely 3-wire or 4-wire interface and mode 0 or mode 3 configuration. The signaling conventions applicable to the supported SPI modes are defined in Table 23.

Table 23: SPI mode 0 and mode 3 configuration

| SPI mode | Description           |  |
|----------|-----------------------|--|
| 0        | CPOL = 0 and CPHA = 0 |  |
| 3        | CPOL = 1 and CPHA = 1 |  |

#### Specifically:

- 3-wire and 4-wire configurations: SPI 3-wire mode can be configured through bit IF\_CONF\_1.if\_spi3\_en, as described in the previous chapter.
- Mode 0 and mode 3 configurations: The selection between SPI mode 0 and 3 is performed automatically by detecting the value of the SCK signal at the first falling edge of the CSB signal.

The following chapters describe the protocol properties for each SPI configuration and mode.

## 5.2.2.1 SPI Timing specification

The timing specifications are stated in Table 24 for the SPI interface of the device. Additionally, figures 27 to 29 show the definition of the SPI timings. Here, the 4-wire SPI protocol with mode 0 is presented as an example.

| and a man and a man go promound and |               |                |     |     |     |       |  |
|-------------------------------------|---------------|----------------|-----|-----|-----|-------|--|
| Parameter                           | Comment       | Symbol         | Min | Тур | Max | Units |  |
| CSB lead time                       |               | T_setup_csb    | 40  |     |     | ns    |  |
| CSB lag time                        |               | T_hold_csb     | 40  |     |     | ns    |  |
| SDI setup time                      |               | T_setup_sdi    | 20  |     |     | ns    |  |
| SDI hold time                       |               | T_hold_sdi     | 20  |     |     | ns    |  |
| SDO output delay time               | Load = 30pF   | T_delay_sdo    |     |     | 30  | ns    |  |
| SDO release delay time              | Load = 30pF   | T_release_sdo  |     |     | 30  | ns    |  |
| SDO drive delay time                | Load = 30pF   | T_drive_sdo    |     |     | 30  | ns    |  |
| SCX frequency                       |               | F_sck          |     |     | 10  | MHz   |  |
| SCX pulse high time                 |               | T_high_scx     | 45  |     |     | ns    |  |
| SCX pulse low time                  |               | T_low_scx      | 45  |     |     | ns    |  |
| Idle time after write access        | Active state  | T_wr_idle_act  | 2   |     |     | μs    |  |
| idic time arter write access        | Suspend state | T_wr_idle_susp | 450 |     |     | μs    |  |
| Idle time after read access         |               | T_rd_idle      | 2   |     |     | μs    |  |

Table 24: SPI interface timing specifications



Figure 27: SPI timing diagram



Figure 28: SPI idle read timing



Figure 29: SPI idle write timing

#### 5.2.2.2 4-wire SPI

The 4-wire SPI interface is based on the following pins:

- CSB (chip select low active)
- SCX (serial clock)
- SDI (serial data input)
- SDO (serial data output)

The communication starts (stops), when the CSB is pulled low (high) by the host. The SDX input receiver is enabled (disabled), when the CSB is pulled low (high) by the host. In figures 30 to 34, the basic operation waveform is presented with respect to the 4-wire SPI. The 4-wire SPI mode 3 and mode 0 configurations are equivalent in terms of multiple-byte write, single byte read and multiple-byte read operations using the respective SCX signaling properties. Hence these modes are omitted here.



Figure 30: Single-byte write operation of 4-wire SPI with mode 0



Figure 31: Multiple-byte write operation of 4-wire SPI with mode 0



Figure 32: Single-byte read operation of 4-wire SPI with mode 0



Figure 33: Multiple-byte read operation of 4-wire SPI with mode 0



Figure 34: Single-byte write operation of 4-wire SPI with mode 3

#### 5.2.2.3 3-wire SPI

The 3-wire SPI interface is based on the following pins:

- CSB (chip select low active)
- SCX (serial clock)
- SDX (serial data input and output)

The 3-wire SPI interface mode uses the SDX pin for both data input and output. The write command for the 3-wire SPI is identical to the 4-wire SPI write command. When a read command is performed, output data appear at the SDX pin once the last address bit AD0 has been latched. Output data are synchronized at falling edge of SCX. Both input and output data shall be captured at rising edge of SCX. The SDX input receiver is enabled when the CSB is pulled low by the host, and disabled when CSB is pulled high (write access) or output data is driven (read access). In figure 35, the basic operation waveform is presented with respect to the 3-wire SPI, where the single-byte read operation with mode is given as an example.



Figure 35: Single-byte read operation of 3-wire SPI with mode 0

## 5.2.3 I2C Protocol

The device supports the following I2C modes:

- Normal mode (100 kHz)
- Fast mode (400 kHz)
- Fast mode plus (Fm+) (1 MHz)

The default 7 bits I2C address is 0x18.

I<sup>2</sup>C Timing specification The I<sup>2</sup>C timing specification of the device is given in Table 25, figure 36 and figure 37.

| Table 25: I <sup>2</sup> C timing require | ments (standard | l mode, fast mod | de snf fast mode | : plus) |
|-------------------------------------------|-----------------|------------------|------------------|---------|
|                                           |                 |                  |                  |         |

| Parameter                 | Comment       | Symbol              | Min  | Тур   | Max  | Unit |
|---------------------------|---------------|---------------------|------|-------|------|------|
| SCL frequency             |               | F_scl               | 0    |       | 1000 | kHz  |
| Fall time                 |               | T_F                 | 0    |       | 300  | ns   |
| Rise time <sup>1</sup>    | Load = 400 pF | T_R                 | 20   |       | 300  | ns   |
| SCL low period            |               | T_LOW               | 0.5  |       |      | μs   |
| SCL high period           |               | T_HIGH              | 0.26 |       |      | μs   |
| Hold time (repeated start |               | T_HD, STA           | 0.26 |       |      | μs   |
| condition)                |               |                     |      |       |      |      |
| Set-Up time (repeated     |               | T_SU, STA           | 0.26 |       |      | μs   |
| start condition)          |               |                     |      |       |      |      |
| Data hold time, data      |               | T_HD, DAT, slv      | 0    |       |      | μs   |
| written to slave          |               |                     |      |       |      |      |
| Data hold time, data      |               | T_VD, DAT           | 120  |       | 450  | ns   |
| written to host           |               |                     |      |       |      |      |
| Data set-up time          |               | T_SU, DAT           | 50   |       |      | ns   |
| Set-up time stop          |               | T_SU, STO           | 0.26 |       |      | μs   |
| condition                 |               |                     |      |       |      |      |
| Bus free time             |               | T_BUF               | 0.5  |       |      | μs   |
| Spike suppression         |               | T_SP                | 50   |       |      | ns   |
| Noise margin at low input |               | V <sub>nL</sub>     |      | 0.1 * |      | V    |
| level                     |               |                     |      | VDD   |      |      |
| Noise margin at high      |               | V <sub>nH</sub>     |      | 0.2 * |      | V    |
| input level               |               |                     |      | VDD   |      |      |
| Idle time after write     | Suspend state | T_wr_idle_susp, I2C | 450  |       |      | μs   |
| access                    |               |                     |      |       |      |      |



Figure 36: Definition of rise- and fall-time of I<sup>2</sup>C interface signals

 $<sup>^{1}\</sup>mbox{Determined}$  by the external pull-up resistor.



Figure 37: I2C timing diagram

#### 5.2.3.1 I2C Write Operation

Figure 38 depicts the I<sup>2</sup>C write telegram for a single-byte write operation. The telegram begins with a start condition generated by the host, followed by 7 bits slave address and a write bit (R/W = 0). The slave sends an acknowledge bit (ACK = 0) and releases the bus. Subsequently, the host is expected to send the one-byte register address. Please note that only the first 7 bits (right aligned) are the valid address bits, while the MSB is ignored. The slave shall again acknowledge the transmission and wait for the 8 bits data which shall be written to the specified register address. After the slave acknowledges the data byte, the host generates a stop signal and terminates the writing protocol.



Figure 38: Single-byte write operation of I2C

The device also supports multi-byte write operation when operating in I<sup>2</sup>C mode. The multi-byte write telegram is depicted in Fig. . The telegram begins with a start condition generated by the host, followed by 7bits slave address and a write bit (R/W = 0). The slave sends an acknowledge bit (ACK = 0) and releases the bus. Subsequently, the host sends the one-byte register address. Agian, please note that only the first 7 bits (right aligned) are the valid address bits, while the MSB is ignored. The slave shall again acknowledge the transmission and wait for several 8-bit wide data words. The first data word is written to the specified register address. The register address pointer is automatically incremented for each data word (please see chapter 5.2.5 for details). Each received data word is written to the register referenced by the current register address pointer. The slave acknowledges each data byte. When no more data words need to be written, the host generates a stop signal and terminates the writing protocol.



Figure 39: Multiple-byte write operation of I2C

#### 5.2.3.2 I2C Read Operation

The I<sup>2</sup>C read operation supports multiple bytes reading. A read command consists of a 1-byte I<sup>2</sup>C write phase followed by I<sup>2</sup>C read phase. The two I<sup>2</sup>C transmissions must be separated by a repeated start condition (Sr). The I<sup>2</sup>C write phase addresses the slave and sends the register address to be read. After the slave acknowledges the transmission, the host is expected to generate a start condition and then to send the slave address together with a read bit (R/W = 1). Then the host releases the bus and waits for the data bytes to be read out from slave. After each data byte, the host has to generate an acknowledge bit (ACK = 0) to enable further data transfer. A NACK (ACK = 1) from the host stops the data transferring from slave. The slave releases the bus so that the host can generate a STOP condition and terminate the transmission.



Figure 40: Multiple-byte read operation of I2C

Multiple-byte read transmissions within one read command are also possible. Once a new read transmission starts, the start address is set to the register address specified in the latest I<sup>2</sup>C write command. In this way, repetitive multi-bytes reads from the same starting address are possible. The default start address is 0x00.



Figure 41: Multiple read transmissions of I2C from the same start address

#### 5.2.4 I3C Protocol

The device supports the I3C protocol with the features:

- I3C single data rate (SDR) mode with up to 12.5 MHz data rate
- I<sup>2</sup>C compatibility
- In-Band Interrupt (IBI)
- Timing control (TC) synchronous mode
- Timing control asynchronous (TC Async) 0 and 1 mode

To select the I3C protocol, please refer to chapter 5.2.1.2.

The I3C interface of the device is compatible with the Specification for I3C® Improved Inter Integrated Circuit Version 1.1.1 - 11 June 2021 (hereinafter called "MIPI specification") available at http://www.mipi.org/specifications/i3 c-sensor-specification.

## 5.2.4.1 Bus Identifier

The I3C protocol provides the following identifiers in Table 26 for the I3C communication:

Table 26: I3C Bus Identifier

| Bus identifier                              | Value                   |
|---------------------------------------------|-------------------------|
| I3C Provisioned ID (PID) [47:0]             | 0x077000011001          |
| Device Characteristics Register (DCR) [7:0] | 0x41 <sup>1</sup>       |
| Bus Characteristics Register (BCR) [7:0]    | 0x27 <sup>2, 3, 4</sup> |

<sup>1:</sup> This register describes the I3C compliant Device type as defined in MIPI specification.

<sup>&</sup>lt;sup>2</sup>: BCR[5] is set to 0b1, meaning that device supports solely SDR.

<sup>3:</sup> BCR[2] is set to 0b1, meaning that an accepted IBI is followed by the mandatory byte (MDB).

 $<sup>^4</sup>$ : BCR[0] is set to 0b1 according to MIPI specification, Table 5. However, the device supports the typical clock frequency of 12.5 MHz. See Table 36.

## 5.2.4.2 In-Band Interrupt (IBI)

The IBI is enabled by default after power-up and the Dynamic Address Assignment (DAA). If DAA is reset via RSTDAA CCC, IBI will be disabled automatically. As long as no new dynamic address has been assigned, IBI will stay disabled and must be enabled explicitly by ENEC CCC in contrast to the situation after power-up.

IBI Payload Format The IBI payload is defined in Table 27 and Table 28 in dependency of TC.

Table 27: IBI Payload Format

| TC configuration | Byte No. | Name            | Bit   | Description                                      |
|------------------|----------|-----------------|-------|--------------------------------------------------|
|                  | 1        | MDB             | [7:5] | Interrupt Group Identifier fixed to 0x0          |
| No TC            | 1        | INIDB           | [4:0] | Interrupt status bits provided by I3C interrupts |
|                  |          |                 |       | status <sup>1</sup>                              |
|                  | 2        | Additional Byte | [7:0] | Interrupt status bits provided by I3C interrupts |
|                  |          |                 |       | status <sup>1</sup>                              |
|                  | 1        | MDB             | [7:5] | Interrupt Group Identifier fixed to 0x4          |
|                  |          | INIDD           | [4:0] | Interrupt status bits provided by I3C interrupts |
| TC Async 0       |          |                 |       | status <sup>1</sup>                              |
| 1 C Asylic 0     | 2        | T_C1_LSByte     | [7:0] | LSByte of Target C1 counter value                |
|                  | 3        | T_C1_MSByte     | [7:0] | MSByte of Target C1 counter value                |
|                  | 4        | T_C2            | [7:0] | Target C2 counter value                          |
|                  | 5        | Additional Byte | [7:0] | Interrupt status bits provided by I3C interrupts |
|                  |          |                 |       | status                                           |
|                  | 1        | MDB             | [7:5] | Interrupt Group Identifier fixed to 0x4          |
|                  |          | INIDB           | [4:0] | Interrupt status bits provided by I3C interrupts |
|                  |          |                 |       | status <sup>1</sup>                              |
| TC Async 1       | 2        | T_C1_LSByte     | [7:0] | LSByte of Target C1 counter value                |
|                  | 3        | T_C1_MSByte     | [7:0] | MSByte of Target C1 counter value                |
|                  | 4        | T_C2            | [7:0] | Target C2 counter value                          |
|                  | 5        | T_AME           | [7:0] | Target AME counter value                         |
|                  | 6        | Additional Byte | [7:0] | Interrupt status bits provided by I3C interrupts |
|                  |          |                 |       | status                                           |

<sup>1:</sup> Please refer to Table 28 for the mapping of I3C interrupts status bits to IBI payload.

Table 28: Mapping of I3C interrupts status bits to IBI payload

| Name            | Bit | I3C interrupts status bit                           |  |  |
|-----------------|-----|-----------------------------------------------------|--|--|
|                 | [0] | INT_STATUS_I3C_0.acc_drdy_int_status                |  |  |
|                 | [1] | INT_STATUS_I3C_0.fifo_wm_int_status                 |  |  |
| MDB             | [2] | INT_STATUS_I3C_0.fifo_full_int_status               |  |  |
|                 | [3] | INT_STATUS_I3C_0.gen_int1_int_status                |  |  |
|                 | [4] | INT_STATUS_I3C_0.gen_int2_int_status                |  |  |
|                 | [0] | <pre>INT_STATUS_I3C_0.gen_int3_int_status</pre>     |  |  |
|                 | [1] | INT_STATUS_I3C_0.acc_foc_int_status                 |  |  |
|                 | [2] | INT_STATUS_I3C_0.stap_int_status                    |  |  |
| Additional Byte | [3] | INT_STATUS_I3C_1.dtap_int_status                    |  |  |
| Additional Dyte | [4] | <pre>INT_STATUS_I3C_1.ttap_int_status</pre>         |  |  |
|                 | [5] | INT_STATUS_I3C_1.vad_int_status                     |  |  |
|                 | [6] | INT_STATUS_I3C_1.self_wake_up_int_status            |  |  |
|                 | [7] | <pre>INT_STATUS_I3C_1.feat_eng_err_int_status</pre> |  |  |

**IBI Payload Abortion** When a I3C controller reads the IBI payload from BMA580, it is controller's responsibility to end the message. The controller can either determine the number of payload byte through Table 27 and Table 28, or by using GETMRL.

## 5.2.4.3 Common Command Code (CCC)

**Support for Defining Bytes** Defining Bytes formats for the following CCCs are not supported and will always respond with format 1:

- GETSTATUS with format 1 (defined by GETCAP3[4] = 0b0) returning 2 bytes
- GETCAPS with format 1 (defined by GETCAP3[3] = 0b0) returning 4 bytes
- GETMXDS with format 1: Bytes MaxWr and MaxRd will be returned.

**GETCAPS** GETCAPS (Get Optional Feature Capabilities) format 1 returns the following four bytes in Table 29.

Byte No. **Bvte** Bit **Description GETCAP1** [7:0] High Data Rate (HDR) Mode No HDR supported [7:6] = 0b0**Defining Byte Support** Not supported 2 [5:4] = 0b0Group Address Capabilities GETCAP2 Not supported I3C 1.x Specification Version Minor version number of the MIPI [5:4] = 0x1**I3C Specification** [7] = 0b0Reserved [6] = 0b0Pending Read Notification No Pending Read Notification for 3 **GETCAP3** [5] = 0b0HDR-BT CRC32 Support Not supported [4:3] = 0b0**Defining Byte Support** No Defining Byte support for **GETCAPS and GETSTATUS** [2:1] = 0b0 Device to Device Transfer Not supported [0] = 0b0Multi-Lane for Speed Support Not supported [7:0]=0x00 4 **GETCAP4** Reserved

Table 29: GETCAPS returning value

**GETSTATUS** GETSTATUS (Get Device Status) format 1 returns the following two bytes in Table 30.

| Bits          | Name              | Description                                                                                                                                                                                                                                        |
|---------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:8] = 0x00 | Reserved          |                                                                                                                                                                                                                                                    |
| [7:6] = 0b00  | Activity mode     | Not used.                                                                                                                                                                                                                                          |
| [5]           | Protocol Error    | If 1'b1: The device detected a protocol error since the last status read. The device might or might not be able to check for such errors. Note that this value self-clears upon every successful completion of a host read of the device's status. |
| [4] = 0b0     | Reserved          |                                                                                                                                                                                                                                                    |
| [3:0]         | Pending Interrupt | Contains the interrupt number of any pending interrupt, or 0 if no interrupts are pending. This encoding allows for up to 15 numbered interrupts. If more than one interrupt is set, then the highest priority interrupt shall be returned.        |

Table 30: GETSTATUS returning value

**GETMXDS** The GETMXDS (Get Max Data Speed) format 1 returns the following five bytes in Table 31.

Table 31: GETMXDS returning value

| Byte No. | Byte      | Bit           | Name                               | Description                       |
|----------|-----------|---------------|------------------------------------|-----------------------------------|
|          |           | [7:4]         | Reserved                           |                                   |
| 1        | MaxWr     | [3] = 0b0     | Defining Byte Support              | No Defining Byte format supported |
|          |           | [2:0] = 0b000 | Maximum Sustained Data Rate for    | f <sub>SCL</sub> Max              |
|          |           |               | non-CCC Messages sent by           |                                   |
|          |           |               | Controller Device to Target Device |                                   |
|          |           | [6] = 0b0     | Write-to-Read Permits Stop         | STOP would cancel the Read        |
| 2        | MaxRd     |               | Between                            |                                   |
|          |           | [5:3] = 0b111 | Clock to Data Turnaround Time      | t <sub>SCO</sub> is > 12 ns       |
|          |           |               | (t <sub>SCO</sub> )                |                                   |
|          |           | [2:0] = 0b000 | Maximum Sustained Data Rate for    | fSCL Max                          |
|          |           |               | non-CCC Messages sent by Target    |                                   |
|          |           |               | Device to Controller Device        |                                   |
| 3        |           | [7:0]=0x00    |                                    |                                   |
| 4        | maxRdTurn | [15:8]=0x00   | Maximum Read Turnaround Time       | fSCL Max                          |
| 5        |           | [23:16]=0x00  |                                    |                                   |

**GETMWL** The GETMWL (Get Max Write Length) returns the following two bytes in Table 32. Please note that SETMWL (Set Max Write Length) is not supported.

Table 32: GETMWL returning value

| Byte No. | Byte    | Bit          | Name                       | Description |
|----------|---------|--------------|----------------------------|-------------|
| 1        | MWL MSB | [8:0] = 0xFF | MSByte of Max Write length | No limit    |
| 2        | MWL LSB | [8:0] = 0xFF | LSByte of Max Write length | IVO III III |

**GETMRL** The GETMRL (Get Max Read Length) returns the following three bytes in 32. Please note that SETMRL is not supported.

Table 33: GETMRL returning value

| Byte No. | Byte    | Bit          | Name                       | Description                         |
|----------|---------|--------------|----------------------------|-------------------------------------|
| 1        | MWL MSB | [8:0] = 0xFF | MSByte of Max Write length | No limit                            |
| 2        | MWL LSB | [8:0] = 0xFF | LSByte of Max Write length | - NO IIIIII                         |
| 3        | IBI PL  | [8:0]        | IBI Payload Size           | Values:                             |
|          |         |              |                            | 0x02: When No TC is activated. IBI  |
|          |         |              |                            | payload size is 3 bytes, including  |
|          |         |              |                            | MDB + 1 additional byte.            |
|          |         |              |                            | 0x05: When TC Async 0 is            |
|          |         |              |                            | activated. IBI payload size is 5    |
|          |         |              |                            | bytes, including MDB + 4 additional |
|          |         |              |                            | byte.                               |
|          |         |              |                            | 0x06: When TC Async 1 is            |
|          |         |              |                            | activated. IBI payload size is 6    |
|          |         |              |                            | bytes, including MDB + 5 additional |
|          |         |              |                            | byte.                               |

**GETXTIME** The GETXTIME (Get Exchange Timing Support Information) returns the following four bytes in Table 32.

Byte No. Name **Description** Supported Modes Byte TC Async 0 and TC Async 1 are supported. 2 State Byte TC Async 0 and TC Async 1 enabling state is shown. Overflow bit is related to Async Mode 0 and 3 Frequency Byte Fixed to 0x0D: 6.5 MHz. 4 Inaccuracy Byte Fixed to 0x14: 2%.

Table 34: GETXTIME returning value

The overflow bit in Byte No. 2 will be set in case of any TC Async counter overflow, and will be cleared automatically in the following way:

- TC Async 0: a new IBI is requested by hardware interrupt.
- TC Async 1: an I3C start has been found after a drdy event.

Note that the overflow bit will not be cleared by the GETXTIME.

## 5.2.4.4 I3C Timing Specification

The device supports I3C single data rate (SDR) mode according to the MIPI specification. The I3C timing specification of the device is given in Table 35 and Table 36.

| Parameter               | Diagram in MIPI | Symbol                 | Min                                             | Max            | Unit |
|-------------------------|-----------------|------------------------|-------------------------------------------------|----------------|------|
|                         | specification   |                        |                                                 |                |      |
| SCL clock low period    | Figure 233      | t <sub>LOW_OD</sub>    | 200                                             |                | ns   |
| SOL CIOCK IOW PERIOD    | Figure 234      | t <sub>DIG_OD_L</sub>  | t <sub>LOW_ODmin</sub> + t <sub>fDA_ODmin</sub> |                | ns   |
| SCL clock high period   |                 | t <sub>HIGH_INIT</sub> | 200                                             |                | ns   |
| (for Broadcast Address) |                 |                        |                                                 |                |      |
| SCL clock high period   | Figure 230      | t <sub>HIGH</sub>      |                                                 | 41             | ns   |
| (for Mixed Bus)         | Figure 230      | t <sub>DIG_H</sub>     |                                                 | tHIGH + tCF    | ns   |
| SCL clock high period   | Figure 230      | t <sub>HIGH</sub>      | 24                                              |                | ns   |
| (for Pure Bus)          | Figure 230      | t <sub>DIG_H</sub>     | 32                                              |                | ns   |
| SDA fall time           | Figure 233      | t <sub>fDA_OD</sub>    |                                                 | 12             | ns   |
| SDA setup time          | Figure 233      | t <sub>SU_OD</sub>     | 3                                               |                | ns   |
|                         |                 |                        |                                                 | ENTAS0: 1e-6   | S    |
| Clock after Start       | Figure 222      |                        | 38.4e-9                                         | ENTAS1: 100e-6 | s    |
| CIUCK AILEI SLAIL       | Figure 233      | t <sub>CAS</sub>       | 30.46-9                                         | ENTAS2: 2e-3   | S    |
|                         |                 |                        |                                                 | ENTAS3: 50e-3  | S    |
| Clock before Stop       | Figure 233      | t <sub>CBP</sub>       | t <sub>CASmin</sub> /2                          |                | ns   |
| Bus available condition |                 | τωνΔΙΙ                 | 1                                               |                | μs   |

200

Table 35: Open drain timing parameters of I3C

t<sub>IDLE</sub>

μs

Bus idle condition

| Parameter             | Diagram in MIPI | Symbol                   | Min                    | Тур  | Max                | Unit |
|-----------------------|-----------------|--------------------------|------------------------|------|--------------------|------|
|                       | specification   |                          |                        |      |                    |      |
| SCL clock frequency   |                 | f <sub>SCL</sub>         | 0.01                   | 12.5 | 12.9               | MHz  |
| SCL clock low period  | Figure 230      | t <sub>LOW</sub>         | 24                     |      |                    | ns   |
| SCL Clock low period  | rigure 250      | t <sub>DIG_L</sub>       | 32                     |      |                    | ns   |
| SCL clock high period | Figure 230      | t <sub>HIGH_MIXED</sub>  | 24                     |      |                    | ns   |
| (for Mixed Bus)       | rigure 250      | t <sub>DIG_H_MIXED</sub> | 32                     |      | 45                 | ns   |
| SCL clock high period | Figure 230      | t <sub>HIGH</sub>        | 24                     |      |                    | ns   |
| (for Pure Bus)        | rigure 250      | t <sub>DIG_H</sub>       | 32                     |      |                    | ns   |
| Clock-in to data-out  | Figure 236      | t <sub>sco</sub>         |                        |      | 12                 | ns   |
| SCL clock rise time   | Figure 230      | t <sub>CR</sub>          |                        |      | 150e06 *           | ns   |
|                       |                 |                          |                        |      | 1/f <sub>SCL</sub> |      |
| SCL clock fall time   | Figure 230      | t <sub>CF</sub>          |                        |      | 150e06 *           | ns   |
|                       |                 |                          |                        |      | 1/f <sub>SCL</sub> |      |
| SDA signal hold time  | Figure 235      | t <sub>HD_PP</sub>       | t <sub>CR/F</sub> + 3  |      |                    | ns   |
| SDA signal setup time | Figure 235 and  | t <sub>SU_PP</sub>       | 3                      |      |                    | ns   |
|                       | Figure 236      |                          |                        |      |                    |      |
| Clock after SR        | Figure 239      | t <sub>CASr</sub>        | t <sub>CASmin</sub> /2 |      |                    | ns   |
| Clock before SR       | Figure 239      | t <sub>CABr</sub>        | t <sub>CASmin</sub> /2 |      |                    | ns   |
| Capacitive bus load   |                 | Св                       |                        |      | 50                 | pF   |

Table 36: Push-pull timing parameters for SDR of I3C

#### 5.2.4.5 I3C Private Write Operation

The I3C write operation supports single-byte as well as multi-byte (burst) writing. figure 42 depicts the I3C write transfer for single-byte write operation. The transfer begins with a start condition generated by the host, followed by 7-bit I3C dynamic slave address and a write bit (R/W = 0). Then, the slave sends an acknowledge bit (ACK = 0) and releases the bus. Subsequently, the host is expected to send the register address (only the first 7-bit (right aligned) are the valid address bits, the MSB shall be ignored). Compared to I<sup>2</sup>C, the slave will not acknowledge the data bytes after the transmission. Instead, the I3C master is transmitting a parity bit during the T-bit phase. The next 8-bit data shall be written to the specified register address. After the final T-bit, the host generates a stop signal and terminates the writing protocol.



Figure 42: Single-byte write protocol of I3C

The device also supports multi-byte (burst) write operation in I3C mode. The multi-byte write telegram is depicted in Fig. 43. The telegram begins with a start condition generated by the host, followed by 7-bit dynamic slave address and a write bit (R/W = 0). The slave sends an acknowledge bit (ACK = 0) and releases the bus. Subsequently the host sends the one byte register address (only the first 7-bit (right aligned) are the valid address bits, the MSB shall be ignored). The I3C master is transmitting a parity bit during the T-bit phase. The first data word is written to the specified register address. The register address pointer is automatically incremented for each data word. Each received data word is written to the register referenced by the current register address pointer. When no more data words need to be written, after the final T-bit, the host generates a stop signal and terminates the writing protocol.



Figure 43: Multi-Byte write protocol of I3C

## 5.2.4.6 I3C Private Read Operation

The I3C read operation supports single-byte as well as multi-byte (burst) reading. Please note that, burst accesses are not permitted when sensor is in suspend mode. A read command consists of a 1-byte I3C write phase followed by an I3C read phase. The two I3C transmissions must be separated by a repeated start condition (Sr) as shown in figure 44 or a stop followed by start condition (P followed by S) as shown in figure 45. The I3C write phase addresses the slave and sends the register address to be read. After the slave acknowledges the transmission, the host is expected to generate a start condition and then to send the dynamic slave address together with a read bit (R/W = 1). Then, the host releases the bus and waits for the data bytes to be read out from slave. After each data byte, the slave can continue the burst by driving the T-Bit high until the rising edge of SCL and release its driver right after SCL rising edged the to give the master the possibility to create a STOP or RESTART condition to terminate the transmission. If both the slave and master are keeping the T-Bit high, the burst will continue. The register address is automatically incremented and more than one byte can be sequentially read out (please refer to chapter 5.2.5 for address handling). Once a new data read transmission starts, the start address is set to the register address specified in the latest I3C write command. By default, the start address is set at 8h'00. In this way, repetitive multi-bytes reads from the same starting address are possible, as shown in figure 46.



Figure 44: Multi-byte read protocol of I3C with repeated start



Figure 45: Multi-byte read protocol of I3C with stop-start



Figure 46: Multi-byte read protocol of I3C from the same start address with stop-start

#### **Automatic Address Increment for Burst Access** 5.2.5

Whenever a host accesses the device with a burst transfer, the register address is incremented upon each data byte, independent of the access type (read or write). When the highest address (0x7F) is reached, it wraps around to the start address (0x00). On dedicated addresses, the auto-incrementing is stalled, and all succeeding bytes are transferred with this stalled address. Auto-incrementing is stalled, even when the address is not the first one within a burst access. These stalling addresses are:

- FIFO\_DATA\_OUT (read access only)
- FEATURE\_DATA\_TX (write and read access)

# 6 Memory Map

The device can be operated for all standard features directly through registers. The registers are described in the register map in Section 6.1. The configuration and extended outputs of the advanced features provided by the feature engine can be accessed through the extended register map. The layout of the extended registers is described in Section 6.2.

In case a bit field of a register is marked as "reserved", the value read from it cannot be assumed to be "0x0" in every case. To reserved bit fields only "0x0" should be written to. Please be aware, that the BMA580 starts in suspend mode and not all registers are directly accessible. Please refer to the section section §4.1 for more details.

## 6.1 Register Map Description

The description of the register map is split into the overview of the register map and a detailed description for each register. The access to the extended register map through the registers FEATURE\_DATA\_ADDR and FEATURE\_DATA\_TX is explained in Section 6.2.

# 6.1.1 Register Map Overview

The Table 37 provides an overview of the register map of the device.

Table 37: Register map overview

|      | Legend            |             | Rea                           | d-only   | Read     | l/Write     | Write        | -only    | Rese                 | erved  |
|------|-------------------|-------------|-------------------------------|----------|----------|-------------|--------------|----------|----------------------|--------|
| Addr | Name              | Reset value | bit7                          | bit6     | bit5     | bit4        | bit3         | bit2     | bit1                 | bit0   |
| 0x00 | CHIP_ID           | 0xC4        |                               |          |          | chi         | p_id         |          |                      |        |
|      | -                 | -           |                               | reserved |          |             |              |          |                      |        |
| 0x02 | HEALTH_STATUS     | 0x00        | reserved sensor_health_status |          |          |             |              |          |                      |        |
|      | -                 | -           | reserved                      |          |          |             |              |          |                      |        |
| 0x04 | CMD_SUSPEND       | 0x01        | reserved                      |          |          |             |              |          | suspend              |        |
|      | <u>-</u>          | -           |                               |          |          | rese        | erved        |          |                      |        |
| 0x10 | CONFIG_STATUS     | 0x00        | reserved acc_co.              |          |          |             |              |          | acc_co               | feat_e |
| 0x11 | SENSOR_STATUS     | 0x04        |                               |          | reserved |             |              | sensor:. | tempera              | acc_da |
| 0x12 | INT_STATUS_INT1_0 | 0x00        | stap_i                        | acc_fo   | gen_in   | gen_in      | gen_in       | fifo_f   | fifo_w               | acc_dr |
| 0x13 | INT_STATUS_INT1_1 | 0x00        |                               | reserved |          | feat_e      | self_w       | vad_in   | ttap_i               | dtap_i |
| 0x14 | INT_STATUS_INT2_0 | 0x00        | stap_i                        | acc_fo   | gen_in   | gen_in      | gen_in       | fifo_f   | fifo_w               | acc_dr |
| 0x15 | INT_STATUS_INT2_1 | 0x00        |                               | reserved |          | feat_e      | self_w       | vad_in   | ttap_i               | dtap_i |
| 0x16 | INT_STATUS_I3C_0  | 0x00        | stap_i                        | acc_fo   | gen_in   | gen_in      | gen_in       | fifo_f   | fifo_w               | acc_dr |
| 0x17 | INT_STATUS_I3C_1  | 0x00        |                               | reserved |          | feat_e      | self_w       | vad_in   | ttap_i               | dtap_i |
| 0x18 | ACC_DATA_0        | 0x00        |                               |          |          | acc_:       | x_7_0        |          |                      |        |
| 0x19 | ACC_DATA_1        | 0x80        |                               |          |          | acc_x       | <u></u>      |          |                      |        |
| 0x1A | ACC_DATA_2        | 0x00        |                               |          |          | acc_        | y_7_0        |          |                      |        |
| 0x1B | ACC_DATA_3        | 0x80        |                               |          |          | acc_y       | <u>15_</u> 8 |          |                      |        |
| 0x1C | ACC_DATA_4        | 0x00        |                               |          |          | acc_:       | z_7_0        |          |                      |        |
| 0x1D | ACC_DATA_5        | 0x80        |                               |          |          | acc_z       | ·_15_8       |          |                      |        |
| 0x1E | TEMP_DATA         | 0x00        |                               |          |          | temp        | _data        |          |                      |        |
| 0x1F | SENSOR_TIME_0     | 0x00        |                               |          |          | sensor_     | time_7_0     |          |                      |        |
| 0x20 | SENSOR_TIME_1     | 0x00        |                               |          |          | sensor_t    | ime_15_8     |          |                      |        |
| 0x21 | SENSOR_TIME_2     | 0x00        |                               |          |          | sensor_tii  | me_23_16     |          |                      |        |
| 0x22 | FIFO_LEVEL_0      | 0x00        |                               |          |          | fifo_fill_l | evel_7_0     |          |                      |        |
| 0x23 | FIFO_LEVEL_1      | 0x00        |                               |          | reserved |             |              |          | fifo_fill_level_10_8 |        |
| 0x24 | FIFO_DATA_OUT     | 0x80        | fifo_data_out                 |          |          |             |              |          |                      |        |
|      | -                 | -           |                               |          |          | rese        | erved        |          |                      |        |
| 0x2B | AUX_DATA_0        | 0x00        | aux_data_7_0                  |          |          |             |              |          |                      |        |
| 0x2C | AUX_DATA_1        | 0x00        |                               |          |          | aux_da      | ta_15_8      |          |                      |        |
|      | -                 | -           |                               |          |          | rese        | erved        |          |                      |        |

Table 37: Register map overview (continued)

|      | Legend            |             | Read     | d-only   | Read       | /Write       | Write             | e-only    | Res                | erved     |
|------|-------------------|-------------|----------|----------|------------|--------------|-------------------|-----------|--------------------|-----------|
| Addr | Name              | Reset value | bit7     | bit6     | bit5       | bit4         | bit3              | bit2      | bit1               | bit0      |
| 0x30 | ACC_CONF_0        | 0x0F        |          | rese     | erved      |              |                   | sens      | or_ctrl            |           |
| 0x31 | ACC_CONF_1        | 0xA7        | power    |          | acc_bwp    |              | acc_odr           |           |                    |           |
| 0x32 | ACC_CONF_2        | 0x0E        | acc_dr   | rese     | erved      | noise        | acc_              | _iir_ro   | acc_               | range     |
| 0x33 | TEMP_CONF         | 0x60        |          | reserved |            | temp_e       | temp_m            |           | temp_rate          |           |
| 0x34 | INT1_CONF         | 0x00        |          | rese     | erved      |              | lvl               | od        | m                  | ode       |
| 0x35 | INT2_CONF         | 0x00        |          | rese     | erved      |              | lvl               | od        | m                  | ode       |
| 0x36 | INT_MAP_0         | 0x00        | gen_int1 | _int_map | fifo_full_ | _int_map     | fifo_wm           | _int_map  | acc_drdy           | _int_map  |
| 0x37 | INT_MAP_1         | 0x00        | stap_i   | nt_map   | acc_foc    | _int_map     | gen_int3          | _int_map  | gen_int2           | !_int_map |
| 0x38 | INT_MAP_2         | 0x00        | self_wal | re_up_i  | vad_ir     | nt_map       | ttap_i            | nt_map    | dtap_i             | nt_map    |
| 0x39 | INT_MAP_3         | 0x00        | reserved |          |            |              |                   |           | feat_en            | g_err_i   |
| 0x3A | IF_CONF_0         | 0x18        | reserved |          |            |              | if_i2c_slv_addr   |           |                    |           |
| 0x3B | IF_CONF_1         | 0x38        | reserved | if_i2c   |            | if_pad_drv   |                   | if_csb    | if_spi             | if_i3c    |
|      | -                 | -           | reserv   |          |            |              | erved             |           |                    |           |
| 0x40 | FIFO_CTRL         | 0x00        | reserved |          |            |              |                   |           | fifo_f             | fifo_rst  |
| 0x41 | FIFO_CONF_0       | 0x0E        |          | reserved |            | fifo_c       | fifo_a            | fifo_a    | fifo_a             | fifo_cfg  |
| 0x42 | FIFO_CONF_1       | 0x06        |          | reserved |            | fifo_s       | fifo_ser          | sor_time  | fifo               | _size     |
| 0x43 | FIFO_WM_0         | 0x00        |          |          |            | fifo_waterma | ark_level_7_0     |           |                    |           |
| 0x44 | FIFO_WM_1         | 0x04        |          |          | reserved   |              |                   | fifo      | _watermark_level_: | 10_8      |
|      | -                 | -           |          |          |            | rese         | erved             |           |                    |           |
| 0x50 | FEAT_ENG_CONF     | 0x01        |          |          |            | reserved     |                   |           |                    | feat_e    |
| 0x51 | FEAT_ENG_STATUS   | 0x00        |          | rese     | erved      |              | feat_e            | host_g    | feat_e             | feat_e    |
| 0x52 | FEAT_ENG_GP_FLAGS | 0x00        |          |          | reserved   |              |                   | foc_ru    | feat_i             | nit_stat  |
| 0x53 | FEAT_ENG_GPR_CONF | 0x00        | reserved | feat_e   | feat_e     | feat_e       | feat_e            | feat_e    | feat_e             | feat_e    |
| 0x54 | FEAT_ENG_GPR_CTRL | 0x00        |          |          | rese       | erved        |                   |           | unlock:.           | update:.  |
| 0x55 | FEAT_ENG_GPR_0    | 0x00        | reserved | self_w   | vad_en     | tap_en       | acc_fo            | gen_in    | gen_in             | gen_in    |
| 0x56 | FEAT_ENG_GPR_1    | 0x00        | rese     | erved    | gen_int3   | _data_src    | gen_int2          | _data_src | gen_int1           | _data_src |
| 0x57 | FEAT_ENG_GPR_2    | 0x00        |          | reserved |            | vad_stat     | self_w            | gen_in    | gen_in             | gen_in    |
|      | -                 | -           |          |          |            | rese         | erved             | •         |                    | •         |
| 0x5E | FEATURE_DATA_ADDR | 0x00        | reserved |          |            |              | feature_data_addi |           |                    |           |
| 0x5F | FEATURE_DATA_TX   | 0x00        |          |          |            | featur       | e_data            |           |                    |           |
|      | -                 | -           |          |          |            | rese         | erved             |           |                    |           |
| 0x70 | ACC_OFFSET_0      | 0x00        |          |          |            | acc_do       | ff_x_7_0          |           |                    |           |
| 0x71 | ACC_OFFSET_1      | 0x00        |          |          |            | reserved     |                   |           |                    | acc_do    |
| 0x72 | ACC_OFFSET_2      | 0x00        |          |          |            | acc_do       | ff_y_7_0          |           |                    |           |
| 0x73 | ACC_OFFSET_3      | 0x00        |          |          |            | reserved     |                   |           |                    | acc_do    |

Table 37: Register map overview (continued)

| Legend |               |                | Read-only                         |  | Read/Write |          | Write-only |      | Reserved |           |
|--------|---------------|----------------|-----------------------------------|--|------------|----------|------------|------|----------|-----------|
| Addr   | Name          | Reset<br>value | bit7 bit6 bit5 bit4 bit3 bit2 bit |  |            |          |            | bit1 | bit0     |           |
| 0x74   | ACC_OFFSET_4  | 0x00           | acc_doff_z_7_0                    |  |            |          |            |      |          |           |
| 0x75   | ACC_OFFSET_5  | 0x00           |                                   |  |            | reserved |            |      |          | acc_do    |
| 0x76   | ACC_SELF_TEST | 0x00           |                                   |  | rese       | erved    |            |      | self_t   | self_test |
|        | -             | -              | reserved                          |  |            |          |            |      |          |           |
| 0x7E   | CMD           | 0x00           | cmd                               |  |            |          |            |      |          |           |
| •••    | -             | -              |                                   |  |            | rese     | erved      |      |          |           |

## 6.1.2 Register Map Details

# Register (0x00) CHIP\_ID

**Description:** The product chip\_id. This register can be used to identify the product and perform a first simple communication test while reading out the chip id after boot up.

| Bit            | 7 | 6       | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|----------------|---|---------|---|---|---|---|---|---|--|--|
| Read/Write     | R | R       | R | R | R | R | R | R |  |  |
| Reset<br>Value | 1 | 1       | 0 | 0 | 0 | 1 | 0 | 0 |  |  |
| Content        |   | chip_id |   |   |   |   |   |   |  |  |

CHIP\_ID.chip\_id: (bit offset: 0, bit width: 8, access: read-only) Chip ID: a constant number to identify the product. Following values can be read from the field chip\_id:

| Value | Description                   |
|-------|-------------------------------|
| 0xC4  | product identifier for BMA580 |

Use this link to go back to the overview table: CHIP\_ID.

# Register (0x02) **HEALTH\_STATUS**

Description: This register contains internal health status information

| Bit            | 7 | 6    | 5    | 4 | 3                    | 2 | 1 | 0 |
|----------------|---|------|------|---|----------------------|---|---|---|
| Read/Write     | R | R    | R    | R | R                    | R | R | R |
| Reset<br>Value | 0 | 0    | 0    | 0 | 0                    | 0 | 0 | 0 |
| Content        |   | rese | rved |   | sensor_health_status |   |   |   |

■ reserved: write 0x0.

• HEALTH\_STATUS.sensor\_health\_status: (bit offset: 0, bit width: 4, access: read-only) The value 0xF indicate a good internal health state.

Use this link to go back to the overview table: HEALTH\_STATUS.

# Register (0x04) CMD\_SUSPEND

**Description:** Command register to activate suspend mode.

| Bit            | 7 | 6        | 5 | 4 | 3 | 2 | 1 | 0   |  |
|----------------|---|----------|---|---|---|---|---|-----|--|
| Read/Write     | R | R        | R | R | R | R | R | R/W |  |
| Reset<br>Value | 0 | 0        | 0 | 0 | 0 | 0 | 0 | 1   |  |
| Content        |   | reserved |   |   |   |   |   |     |  |

- reserved: write 0x0.
- CMD\_SUSPEND.suspend: (bit offset: 0, bit width: 1, access: read-write) Write '1' to activate suspend mode. The register content prior to entering this power mode will NOT be lost.
  Following values can be set to or read from the field suspend:

| Value     | Description                                                          |
|-----------|----------------------------------------------------------------------|
| 0b0 (0x0) | Suspend mode is disabled. Sensor in normal operation mode.           |
| 0b1 (0x1) | Suspend mode is enabled. Only Register CHIP_ID and this register are |
| ODI (OXI) | accessible.                                                          |

Use this link to go back to the overview table: CMD\_SUSPEND.

# Register (0x10) CONFIG\_STATUS

**Description:** Global error flags

| Bit            | 7 | 6 | 5      | 4      | 3 | 2 | 1 | 0   |
|----------------|---|---|--------|--------|---|---|---|-----|
| Read/Write     | R | R | R      | R      | R | R | R | R/W |
| Reset<br>Value | 0 | 0 | 0      | 0      | 0 | 0 | 0 | 0   |
| Content        |   |   | acc_co | feat_e |   |   |   |     |

■ reserved: write 0x0.

■ CONFIG\_STATUS.feat\_eng\_err: (bit offset: 0, bit width: 1, access: read-write) Set by feature engine in case of feature engine error condition. Needs to be reseted by the host. For more details there are further status register in the feature engine section and inside the DMA region.

Following values can be set to or read from the field feat\_eng\_err:

| Value     | Description                    |
|-----------|--------------------------------|
| 0b0 (0x0) | feature engine is okay         |
| 0b1 (0x1) | feature engine indicates error |

CONFIG\_STATUS.acc\_conf\_err: (bit offset: 1, bit width: 1, access: read-only) This flag is set if the ACC configuration in ACC\_CONF\_0, ACC\_CONF\_1, and ACC\_CONF\_2 is an invalid combination.
 Following values can be read from the field acc\_conf\_err:

| Value     | Description                  |
|-----------|------------------------------|
| 0b0 (0x0) | sensor configuration okay    |
| 0b1 (0x1) | sensor configuration invalid |

Use this link to go back to the overview table: CONFIG\_STATUS.

# Register (0x11) SENSOR\_STATUS

**Description:** Global status flags

| Bit            | 7        | 6 | 5 | 4 | 3 | 2        | 1       | 0      |
|----------------|----------|---|---|---|---|----------|---------|--------|
| Read/Write     | R        | R | R | R | R | R        | R/W     | R/W    |
| Reset<br>Value | 0        | 0 | 0 | 0 | 0 | 1        | 0       | 0      |
| Content        | reserved |   |   |   |   | sensor:. | tempera | acc_da |

- reserved: write 0x0.
- SENSOR\_STATUS.acc\_data\_rdy: (bit offset: 0, bit width: 1, access: read-write) Set when new ACC data is available. This flag can be cleared by writing '1' to it.
- SENSOR\_STATUS.temperature\_rdy: (bit offset: 1, bit width: 1, access: read-write) Set when new temperature data is available. This flag can be cleared by writing '1' to it.
- SENSOR\_STATUS.sensor\_rdy: (bit offset: 2, bit width: 1, access: read-only) Sensor is ready for operation.

Use this link to go back to the overview table: SENSOR\_STATUS.

## Register (0x12) INT\_STATUS\_INT1\_0

**Description:** INT1 interrupt status register 0

| Bit            | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------------|--------|--------|--------|--------|--------|--------|--------|--------|
| Read/Write     | R/W    |
| Reset<br>Value | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
| Content        | stap_i | acc_fo | gen_in | gen_in | gen_in | fifo_f | fifo_w | acc_dr |

- INT\_STATUS\_INT1\_0.acc\_drdy\_int\_status: (bit offset: 0, bit width: 1, access: read-write) Accelerometer data ready interrupt status.
- INT\_STATUS\_INT1\_0.fifo\_wm\_int\_status: (bit offset: 1, bit width: 1, access: read-write) FIFO watermark interrupt status.
- INT\_STATUS\_INT1\_0.fifo\_full\_int\_status: (bit offset: 2, bit width: 1, access: read-write) FIFO full interrupt status.
- INT\_STATUS\_INT1\_0.gen\_int1\_int\_status: (bit offset: 3, bit width: 1, access: read-write) Generic interrupt 1 interrupt status.
- INT\_STATUS\_INT1\_0.gen\_int2\_int\_status: (bit offset: 4, bit width: 1, access: read-write) Generic interrupt 2 interrupt status.
- INT\_STATUS\_INT1\_0.gen\_int3\_int\_status: (bit offset: 5, bit width: 1, access: read-write) Generic interrupt 3 interrupt status.
- INT\_STATUS\_INT1\_0.acc\_foc\_int\_status: (bit offset: 6, bit width: 1, access: read-write) Accelerometer fast offset compensation interrupt status.
- INT\_STATUS\_INT1\_0.stap\_int\_status: (bit offset: 7, bit width: 1, access: read-write) Single tap interrupt status.

Use this link to go back to the overview table: INT\_STATUS\_INT1\_0.

# Register (0x13) INT\_STATUS\_INT1\_1

**Description:** INT1 interrupt status register 1

| Bit            | 7        | 6 | 5 | 4      | 3      | 2      | 1      | 0      |
|----------------|----------|---|---|--------|--------|--------|--------|--------|
| Read/Write     | R        | R | R | R/W    | R/W    | R/W    | R/W    | R/W    |
| Reset<br>Value | 0        | 0 | 0 | 0      | 0      | 0      | 0      | 0      |
| Content        | reserved |   |   | feat_e | self_w | vad_in | ttap_i | dtap_i |

- reserved: write 0x0.
- INT\_STATUS\_INT1\_1.dtap\_int\_status: (bit offset: 0, bit width: 1, access: read-write) Double tap interrupt status.
- INT\_STATUS\_INT1\_1.ttap\_int\_status: (bit offset: 1, bit width: 1, access: read-write) Triple tap interrupt status.
- INT\_STATUS\_INT1\_1.vad\_int\_status: (bit offset: 2, bit width: 1, access: read-write) Voice activity detection interrupt status.
- INT\_STATUS\_INT1\_1.self\_wake\_up\_int\_status: (bit offset: 3, bit width: 1, access: read-write) Self wake-up interrupt status.
- INT\_STATUS\_INT1\_1.feat\_eng\_err\_int\_status: (bit offset: 4, bit width: 1, access: read-write) Feature engine error interrupt status.

Use this link to go back to the overview table: INT\_STATUS\_INT1\_1.

### Register (0x14) INT\_STATUS\_INT2\_0

Description: INT2 interrupt status register 0

| Bit            | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------------|--------|--------|--------|--------|--------|--------|--------|--------|
| Read/Write     | R/W    |
| Reset<br>Value | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
| Content        | stap_i | acc_fo | gen_in | gen_in | gen_in | fifo_f | fifo_w | acc_dr |

- INT\_STATUS\_INT2\_0.acc\_drdy\_int\_status: (bit offset: 0, bit width: 1, access: read-write) Accelerometer data ready interrupt status.
- INT\_STATUS\_INT2\_0.fifo\_wm\_int\_status: (bit offset: 1, bit width: 1, access: read-write) FIFO watermark interrupt status.
- INT\_STATUS\_INT2\_0.fifo\_full\_int\_status: (bit offset: 2, bit width: 1, access: read-write) FIFO full interrupt status.
- INT\_STATUS\_INT2\_0.gen\_int1\_int\_status: (bit offset: 3, bit width: 1, access: read-write) Generic interrupt 1 interrupt status.
- INT\_STATUS\_INT2\_0.gen\_int2\_int\_status: (bit offset: 4, bit width: 1, access: read-write) Generic interrupt 2 interrupt status.
- INT\_STATUS\_INT2\_0.gen\_int3\_int\_status: (bit offset: 5, bit width: 1, access: read-write) Generic interrupt 3 interrupt status.
- INT\_STATUS\_INT2\_0.acc\_foc\_int\_status: (bit offset: 6, bit width: 1, access: read-write) Accelerometer fast offset compensation interrupt status.
- INT\_STATUS\_INT2\_0.stap\_int\_status: (bit offset: 7, bit width: 1, access: read-write) Single tap interrupt status.

Use this link to go back to the overview table: INT\_STATUS\_INT2\_0.

## Register (0x15) INT\_STATUS\_INT2\_1

Description: INT2 interrupt status register 1

| Bit            | 7 | 6        | 5 | 4      | 3      | 2      | 1      | 0      |
|----------------|---|----------|---|--------|--------|--------|--------|--------|
| Read/Write     | R | R        | R | R/W    | R/W    | R/W    | R/W    | R/W    |
| Reset<br>Value | 0 | 0        | 0 | 0      | 0      | 0      | 0      | 0      |
| Content        |   | reserved |   | feat_e | self_w | vad_in | ttap_i | dtap_i |

- reserved: write 0x0.
- INT\_STATUS\_INT2\_1.dtap\_int\_status: (bit offset: 0, bit width: 1, access: read-write) Double tap interrupt status.
- INT\_STATUS\_INT2\_1.ttap\_int\_status: (bit offset: 1, bit width: 1, access: read-write) Triple tap interrupt status.
- INT\_STATUS\_INT2\_1.vad\_int\_status: (bit offset: 2, bit width: 1, access: read-write) Voice activity detection interrupt status.
- INT\_STATUS\_INT2\_1.self\_wake\_up\_int\_status: (bit offset: 3, bit width: 1, access: read-write) Self wake-up interrupt status.
- INT\_STATUS\_INT2\_1.feat\_eng\_err\_int\_status: (bit offset: 4, bit width: 1, access: read-write) Feature engine error interrupt status.

Use this link to go back to the overview table: INT\_STATUS\_INT2\_1.

#### Register (0x16) INT\_STATUS\_I3C\_0

**Description:** I3C interrupt status register 0

| Bit            | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------------|--------|--------|--------|--------|--------|--------|--------|--------|
| Read/Write     | R/W    |
| Reset<br>Value | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
| Content        | stap_i | acc_fo | gen_in | gen_in | gen_in | fifo_f | fifo_w | acc_dr |

- INT\_STATUS\_I3C\_0.acc\_drdy\_int\_status: (bit offset: 0, bit width: 1, access: read-write) Accelerometer data ready interrupt status.
- INT\_STATUS\_I3C\_0.fifo\_wm\_int\_status: (bit offset: 1, bit width: 1, access: read-write) FIFO watermark interrupt status.
- INT\_STATUS\_I3C\_0.fifo\_full\_int\_status: (bit offset: 2, bit width: 1, access: read-write) FIFO full interrupt status.
- INT\_STATUS\_I3C\_0.gen\_int1\_int\_status: (bit offset: 3, bit width: 1, access: read-write) Generic interrupt 1 interrupt status.
- INT\_STATUS\_I3C\_0.gen\_int2\_int\_status: (bit offset: 4, bit width: 1, access: read-write) Generic interrupt 2 interrupt status.
- INT\_STATUS\_I3C\_0.gen\_int3\_int\_status: (bit offset: 5, bit width: 1, access: read-write) Generic interrupt 3 interrupt status.
- INT\_STATUS\_I3C\_0.acc\_foc\_int\_status: (bit offset: 6, bit width: 1, access: read-write) Accelerometer fast offset compensation interrupt status.
- INT\_STATUS\_I3C\_0.stap\_int\_status: (bit offset: 7, bit width: 1, access: read-write) Single tap interrupt status.

Use this link to go back to the overview table: INT\_STATUS\_I3C\_0.

## Register (0x17) INT\_STATUS\_I3C\_1

**Description:** I3C interrupt status register 1

| Bit            | 7 | 6        | 5 | 4      | 3      | 2      | 1      | 0      |
|----------------|---|----------|---|--------|--------|--------|--------|--------|
| Read/Write     | R | R        | R | R/W    | R/W    | R/W    | R/W    | R/W    |
| Reset<br>Value | 0 | 0        | 0 | 0      | 0      | 0      | 0      | 0      |
| Content        |   | reserved |   | feat_e | self_w | vad_in | ttap_i | dtap_i |

- reserved: write 0x0.
- INT\_STATUS\_I3C\_1.dtap\_int\_status: (bit offset: 0, bit width: 1, access: read-write) Double tap interrupt status.
- INT\_STATUS\_I3C\_1.ttap\_int\_status: (bit offset: 1, bit width: 1, access: read-write) Triple tap interrupt status.
- INT\_STATUS\_I3C\_1.vad\_int\_status: (bit offset: 2, bit width: 1, access: read-write) Voice activity detection interrupt status.
- INT\_STATUS\_I3C\_1.self\_wake\_up\_int\_status: (bit offset: 3, bit width: 1, access: read-write) Self wake-up interrupt status.
- INT\_STATUS\_I3C\_1.feat\_eng\_err\_int\_status: (bit offset: 4, bit width: 1, access: read-write) Feature engine error interrupt status.

Use this link to go back to the overview table: INT\_STATUS\_I3C\_1.

## Register (0x18) ACC\_DATA\_0

Description: ACC data register 0

| Bit        | 7         | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------|-----------|---|---|---|---|---|---|---|
| Read/Write | R         | R | R | R | R | R | R | R |
| Reset      | 0         | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Value      | U         | U | U | U | U | U | U | U |
| Content    | acc_x_7_0 |   |   |   |   |   |   |   |

ACC\_DATA\_0.acc\_x\_7\_0: (bit offset: 0, bit width: 8, access: read-only) Accelerometer data for x-axis. (LSB). The full 16bit range cover the selected g-range. (e.g. 8G-range: 1LSB = 16/65536=0.244 mg).

Use this link to go back to the overview table: ACC\_DATA\_0.

## Register (0x19) ACC\_DATA\_1

Description: ACC data register 1

| Bit            | 7          | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|------------|---|---|---|---|---|---|---|
| Read/Write     | R          | R | R | R | R | R | R | R |
| Reset<br>Value | 1          | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Content        | acc_x_15_8 |   |   |   |   |   |   |   |

■ ACC\_DATA\_1.acc\_x\_15\_8: (bit offset: 0, bit width: 8, access: read-only) Accelerometer data for x-axis. (MSB). The full 16bit range cover the selected g-range. (e.g. 8G-range: 1LSB = 16/65536=0.244 mg).

Use this link to go back to the overview table: ACC\_DATA\_1.

## Register (0x1A) ACC\_DATA\_2

Description: ACC data register 2

| Bit        | 7         | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------|-----------|---|---|---|---|---|---|---|
| Read/Write | R         | R | R | R | R | R | R | R |
| Reset      | 0         | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Value      | U         | U | U | U | U | U | U | U |
| Content    | acc_y_7_0 |   |   |   |   |   |   |   |

■ ACC\_DATA\_2.acc\_y\_7\_0: (bit offset: 0, bit width: 8, access: read-only) Accelerometer data for y-axis. (LSB). The full 16bit range cover the selected g-range. (e.g. 8G-range: 1LSB = 16/65536=0.244 mg).

Use this link to go back to the overview table: ACC\_DATA\_2.

## Register (0x1B) ACC\_DATA\_3

Description: ACC data register 3

| Bit            | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|---|------------|---|---|---|---|---|---|
| Read/Write     | R | R          | R | R | R | R | R | R |
| Reset<br>Value | 1 | 0          | 0 | 0 | 0 | 0 | 0 | 0 |
| Content        |   | acc_y_15_8 |   |   |   |   |   |   |

■ ACC\_DATA\_3.acc\_y\_15\_8: (bit offset: 0, bit width: 8, access: read-only) Accelerometer data for y-axis. (MSB). The full 16bit range cover the selected g-range. (e.g. 8G-range: 1LSB = 16/65536=0.244 mg).

Use this link to go back to the overview table: ACC\_DATA\_3.

## Register (0x1C) ACC\_DATA\_4

Description: ACC data register 4

| Bit        | 7         | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------|-----------|---|---|---|---|---|---|---|
| Read/Write | R         | R | R | R | R | R | R | R |
| Reset      | 0         | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Value      | U         | U | U | U | U | U | U | U |
| Content    | acc_z_7_0 |   |   |   |   |   |   |   |

■ ACC\_DATA\_4.acc\_z\_7\_0: (bit offset: 0, bit width: 8, access: read-only) Accelerometer data for z-axis. (LSB). The full 16bit range cover the selected g-range. (e.g. 8G-range: 1LSB = 16/65536=0.244 mg).

Use this link to go back to the overview table: ACC\_DATA\_4.

## Register (0x1D) ACC\_DATA\_5

Description: ACC data register 5

| Bit            | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|---|------------|---|---|---|---|---|---|
| Read/Write     | R | R          | R | R | R | R | R | R |
| Reset<br>Value | 1 | 0          | 0 | 0 | 0 | 0 | 0 | 0 |
| Content        |   | acc_z_15_8 |   |   |   |   |   |   |

■ ACC\_DATA\_5.acc\_z\_15\_8: (bit offset: 0, bit width: 8, access: read-only) Accelerometer data for z-axis. (MSB). The full 16bit range cover the selected g-range. (e.g. 8G-range: 1LSB = 16/65536=0.244 mg).

Use this link to go back to the overview table: ACC\_DATA\_5.

## Register (0x1E) TEMP\_DATA

**Description:** Temperature data register

| Bit            | 7 | 6         | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|---|-----------|---|---|---|---|---|---|
| Read/Write     | R | R         | R | R | R | R | R | R |
| Reset<br>Value | 0 | 0         | 0 | 0 | 0 | 0 | 0 | 0 |
| Content        |   | temp_data |   |   |   |   |   |   |

■ TEMP\_DATA.temp\_data: (bit offset: 0, bit width: 8, access: read-only) Calculated temperature. Resolution: 1 K/LSB. The value 0 represents 23degC.

Use this link to go back to the overview table: TEMP\_DATA.

# Register (0x1F) **SENSOR\_TIME\_0**

**Description:** Sensor time register 0

| Bit            | 7 | 6               | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|---|-----------------|---|---|---|---|---|---|
| Read/Write     | R | R               | R | R | R | R | R | R |
| Reset<br>Value | 0 | 0               | 0 | 0 | 0 | 0 | 0 | 0 |
| Content        |   | sensor_time_7_0 |   |   |   |   |   |   |

SENSOR\_TIME\_0.sensor\_time\_7\_0: (bit offset: 0, bit width: 8, access: read-only) Sensor time in units 1 LSB = 312.5us.

Use this link to go back to the overview table: SENSOR\_TIME\_0.

# Register (0x20) SENSOR\_TIME\_1

**Description:** Sensor time register 1

| Bit            | 7                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|------------------|---|---|---|---|---|---|---|
| Read/Write     | R                | R | R | R | R | R | R | R |
| Reset<br>Value | 0                | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Content        | sensor_time_15_8 |   |   |   |   |   |   |   |

SENSOR\_TIME\_1.sensor\_time\_15\_8: (bit offset: 0, bit width: 8, access: read-only) Sensor time in units 1 LSB = 312.5us.

Use this link to go back to the overview table: SENSOR\_TIME\_1.

# Register (0x21) SENSOR\_TIME\_2

**Description:** Sensor time register 2

| Bit        | 7 | 6                 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------|---|-------------------|---|---|---|---|---|---|
| Read/Write | R | R                 | R | R | R | R | R | R |
| Reset      | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 |
| Value      | 0 | U                 | U | U | U | U | U | 0 |
| Content    |   | sensor_time_23_16 |   |   |   |   |   |   |

■ SENSOR\_TIME\_2.sensor\_time\_23\_16: (bit offset: 0, bit width: 8, access: read-only) Sensor time in units 1 LSB = 312.5us.

Use this link to go back to the overview table: SENSOR\_TIME\_2.

## Register (0x22) FIFO\_LEVEL\_0

Description: FIFO fill level register (LSB)

| Bit            | 7                   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|---------------------|---|---|---|---|---|---|---|
| Read/Write     | R                   | R | R | R | R | R | R | R |
| Reset<br>Value | 0                   | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Content        | fifo_fill_level_7_0 |   |   |   |   |   |   |   |

■ FIFO\_LEVEL\_0.fifo\_fill\_level\_7\_0: (bit offset: 0, bit width: 8, access: read-only) The fill level of the fifo only reflects the stored data. The frame header are not stored and not part of the FIFO fill level. To read out complete FIFO, the best way is to read as long as valid frames are read. LSB of the FIFO fill level. Should be read before the MSB register.

Use this link to go back to the overview table: FIFO\_LEVEL\_0.

## Register (0x23) FIFO\_LEVEL\_1

Description: FIFO fill level register (MSB)

| Bit            | 7        | 6 | 5 | 4 | 3 | 2                    | 1 | 0 |
|----------------|----------|---|---|---|---|----------------------|---|---|
| Read/Write     | R        | R | R | R | R | R                    | R | R |
| Reset<br>Value | 0        | 0 | 0 | 0 | 0 | 0                    | 0 | 0 |
| Content        | reserved |   |   |   |   | fifo_fill_level_10_8 |   |   |

■ reserved: write 0x0.

• FIFO\_LEVEL\_1.fifo\_fill\_level\_10\_8: (bit offset: 0, bit width: 3, access: read-only) MSB of the FIFO fill level. Should be read after the LSB register.

Use this link to go back to the overview table: FIFO\_LEVEL\_1.

## Register (0x24) FIFO\_DATA\_OUT

Description: FIFO data register

| Bit            | 7 | 6             | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|---|---------------|---|---|---|---|---|---|
| Read/Write     | R | R             | R | R | R | R | R | R |
| Reset<br>Value | 1 | 0             | 0 | 0 | 0 | 0 | 0 | 0 |
| Content        |   | fifo_data_out |   |   |   |   |   |   |

• FIFO\_DATA\_OUT.fifo\_data\_out: (bit offset: 0, bit width: 8, access: read-only) Output of the FIFO. During burst reads on this address the address increment stops and the FIFO can be read out with help of the burst read. The type of data stored in the FIFO depends on configuration stored in FIFO\_CONF\_\* registers.

Use this link to go back to the overview table: FIFO\_DATA\_OUT.

# Register (0x2B) AUX\_DATA\_0

**Description:** Auxiliary data

| Bit            | 7 | 6 | 5 | 4      | 3      | 2 | 1 | 0 |
|----------------|---|---|---|--------|--------|---|---|---|
| Read/Write     | R | R | R | R      | R      | R | R | R |
| Reset<br>Value | 0 | 0 | 0 | 0      | 0      | 0 | 0 | 0 |
| Content        |   |   |   | aux_da | ta_7_0 |   |   |   |

■ AUX\_DATA\_0.aux\_data\_7\_0: (bit offset: 0, bit width: 8, access: read-only) Auxiliary data [7:0]. Value from measurement voltage on INT1/2 pin.

Use this link to go back to the overview table: AUX\_DATA\_0.

# Register (0x2C) AUX\_DATA\_1

**Description:** Auxiliary data

| Bit            | 7             | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|---------------|---|---|---|---|---|---|---|
| Read/Write     | R             | R | R | R | R | R | R | R |
| Reset<br>Value | 0             | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Content        | aux_data_15_8 |   |   |   |   |   |   |   |

■ AUX\_DATA\_1.aux\_data\_15\_8: (bit offset: 0, bit width: 8, access: read-only) Auxilary data [15:8]. Value from measurement voltage on INT1/2 pin.

Use this link to go back to the overview table: AUX\_DATA\_1.

## Register (0x30) ACC\_CONF\_0

**Description:** Accelerometer configuration register 0

| Bit            | 7        | 6 | 5 | 4           | 3   | 2   | 1   | 0   |
|----------------|----------|---|---|-------------|-----|-----|-----|-----|
| Read/Write     | R        | R | R | R           | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0        | 0 | 0 | 0           | 1   | 1   | 1   | 1   |
| Content        | reserved |   |   | sensor_ctrl |     |     |     |     |

write 0x0. reserved:

• ACC\_CONF\_0.sensor\_ctrl: (bit offset: 0, bit width: 4, access: read-write) This bit enables/disables the accelerometer and the temperature sensor.

Following values can be set to or read from the field sensor\_ctrl:

| Value        | Description                                                            |
|--------------|------------------------------------------------------------------------|
| 0b0000 (0x0) | The accelerometer and the temperature sensor are disabled.             |
| 0b1111 (0xF) | The accelerometer and the temperature sensor are enabled.              |
| 0b1110 (0xE) | A wrong configuration was found: The accelerometer and the temperature |
| ODITIO (OXE) | sensor are disabled.                                                   |

Use this link to go back to the overview table: ACC\_CONF\_0.

### Register (0x31) ACC\_CONF\_1

**Description:** Accelerometer configuration register 1

| Bit            | 7     | 6   | 5       | 4   | 3       | 2   | 1   | 0   |
|----------------|-------|-----|---------|-----|---------|-----|-----|-----|
| Read/Write     | R/W   | R/W | R/W     | R/W | R/W     | R/W | R/W | R/W |
| Reset<br>Value | 1     | 0   | 1       | 0   | 0       | 1   | 1   | 1   |
| Content        | power |     | acc_bwp |     | acc_odr |     |     |     |

■ ACC\_CONF\_1.acc\_odr: (bit offset: 0, bit width: 4, access: read-write) The ODR (Output Data Rate) in Hz. Not all settings are available in all power modes.

Following values can be set to or read from the field acc\_odr:

| Value        | Description                                           |
|--------------|-------------------------------------------------------|
| 0b0000 (0x0) | 1.5625 Hz. Only available in duty cycling mode (LPM). |
| 0b0001 (0x1) | 3.125 Hz. Only available in duty cycling mode (LPM).  |
| 0b0010 (0x2) | 6.25 Hz.Only available in duty cycling mode (LPM).    |
| 0b0011 (0x3) | 12.5 Hz.                                              |
| 0b0100 (0x4) | 25 Hz.                                                |
| 0b0101 (0x5) | 50 Hz.                                                |
| 0b0110 (0x6) | 100 Hz.                                               |
| 0b0111 (0x7) | 200 Hz.                                               |
| 0b1000 (0x8) | 400 Hz.                                               |
| 0b1001 (0x9) | 800 Hz. Only available in continuous mode (HPM).      |
| 0b1010 (0xA) | 1.6 kHz. Only available in continuous mode (HPM).     |
| 0b1011 (0xB) | 3.2 kHz. Only available in continuous mode (HPM).     |
| 0b1100 (0xC) | 6.4 kHz. Only available in continuous mode (HPM).     |

• ACC\_CONF\_1.acc\_bwp: (bit offset: 4, bit width: 3, access: read-write) Accelerometer bandwith parameter. This parameter determines the filter configuration. The different settings have a different impact depending on the setting of the power\_mode bit. The name of the settings are therefore (HPM-setting)\_(LPM-setting). (e.g. norm\_avg4 means norm mode for HPM and avg4 for LPM).

Following values can be set to or read from the field acc\_bwp:

| Value       | Description                                   |
|-------------|-----------------------------------------------|
| 0b000 (0x0) | HPM -> OSR4 mode; LPM -> no averaging.        |
| 0b001 (0x1) | HPM -> OSR2 mode; LPM -> average 2 samples.   |
| 0b010 (0x2) | HPM -> normal mode; LPM -> average 4 samples. |
| 0b011 (0x3) | HPM -> CIC mode; LPM -> average 8 samples.    |
| 0b100 (0x4) | HPM -> reserved; LPM -> average 16 samples.   |
| 0b101 (0x5) | HPM -> reserved; LPM -> average 32 samples.   |
| 0b110 (0x6) | HPM -> reserved; LPM -> average 64 samples.   |
| 0b111 (0x7) | HPM -> reserved; LPM -> reserved.             |

■ ACC\_CONF\_1.power\_mode: (bit offset: 7, bit width: 1, access: read-write) With this config bit, it is possible to set the basic measurement power mode. There are two possible settings:LPM (Low Power Mode) with duty cycling or HPM (High Performance Mode) with continous measurement. This setting has an influence on the signal path and the filter settings, too.

Following values can be set to or read from the field power\_mode:

| Value     | Description                                  |
|-----------|----------------------------------------------|
| 0b0 (0x0) | LPM: Low power mode (Duty Cycling mode)      |
| 0b1 (0x1) | HPM: High Performance Mode (Continuous mode) |

Use this link to go back to the overview table: ACC\_CONF\_1.

#### Register (0x32) ACC\_CONF\_2

**Description:** Accelerometer configuration register 2

| Bit            | 7      | 6    | 5        | 4   | 3    | 2      | 1     | 0     |
|----------------|--------|------|----------|-----|------|--------|-------|-------|
| Read/Write     | R/W    | R    | R        | R/W | R/W  | R/W    | R/W   | R/W   |
| Reset<br>Value | 0      | 0    | 0        | 0   | 1    | 1      | 1     | 0     |
| Content        | acc_dr | rese | reserved |     | acc_ | iir_ro | acc_ı | range |

- reserved: write 0x0.
- ACC\_CONF\_2.acc\_range: (bit offset: 0, bit width: 2, access: read-write) The measurement range of the accelerometer. This setting has influence on the scaling of the ACC\_DATA registers.
   Following values can be set to or read from the field acc\_range:

| Value      | Description                |
|------------|----------------------------|
| 0b00 (0x0) | measurement range: +/-2g.  |
| 0b01 (0x1) | measurement range: +/-4g.  |
| 0b10 (0x2) | measurement range: +/-8g.  |
| 0b11 (0x3) | measurement range: +/-16g. |

ACC\_CONF\_2.acc\_iir\_ro: (bit offset: 2, bit width: 2, access: read-write) Select roll-off of IIR filter in continuous mode.

Following values can be set to or read from the field acc iir ro:

| Value      | Description    |
|------------|----------------|
| 0b00 (0x0) | reserved       |
| 0b01 (0x1) | -20dB roll-off |
| 0b10 (0x2) | -40dB roll-off |
| 0b11 (0x3) | -60dB roll-off |

■ ACC\_CONF\_2.noise\_mode: (bit offset: 4, bit width: 1, access: read-write) Select the performance mode of the sensor. The choice is between high performance with lower noise or reduce the power consumption but with an increased noise level. The default is the high performance (lower noise). Changing this setting from default migh also influence the sensor behaviour like offset. This configuration should only be used in HPM. .

| Fol | llowing v | alues | can be | e set to | or reac | trom | the fie | ld noise | mode: |
|-----|-----------|-------|--------|----------|---------|------|---------|----------|-------|
|     |           |       |        |          |         |      |         | -        | _     |
|     |           |       |        |          |         |      |         |          |       |
|     |           |       |        |          |         |      |         |          |       |

| Value     | Description                                                              |  |  |  |  |  |
|-----------|--------------------------------------------------------------------------|--|--|--|--|--|
| 0b0 (0x0) | Default config. Lower noise level.                                       |  |  |  |  |  |
| 0b1 (0x1) | Lower power consumption. Higher noise level. This setting should only be |  |  |  |  |  |
| ODI (OXI) | used in HPM mode!                                                        |  |  |  |  |  |

• ACC\_CONF\_2.acc\_drdy\_int\_auto\_clear: (bit offset: 7, bit width: 1, access: read-write) Configuration bit to enable/disable the auto clear mechanism of the data ready interrupt. If enabled, a clock like with freq=odr can be

enabled on the external interrupt pin.

Following values can be set to or read from the field acc\_drdy\_int\_auto\_clear:

| Value     | Description                                                                             |  |  |  |  |  |  |
|-----------|-----------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 0b0 (0x0) | The status flag of acc_drdy_int is not cleared automatically.                           |  |  |  |  |  |  |
| 0b1 (0x1) | The status flag of acc_drdy_int is cleared automatically after approximately 1/(2*ODR). |  |  |  |  |  |  |

Use this link to go back to the overview table: ACC\_CONF\_2.

### Register (0x33) TEMP\_CONF

**Description:** Temperature Sensor configuration register

| Bit        | 7        | 6   | 5   | 4      | 3      | 2   | 1         | 0   |
|------------|----------|-----|-----|--------|--------|-----|-----------|-----|
| Read/Write | R/W      | R/W | R/W | R/W    | R/W    | R/W | R/W       | R/W |
| Reset      | 0        | 1   | 1   | 0      | 0      | 0   | 0         | 0   |
| Value      | U        | 1   | 1   | U      | U      | U   | U         | 0   |
| Content    | reserved |     |     | temp_e | temp_m |     | temp_rate |     |

■ TEMP\_CONF.temp\_rate: (bit offset: 0, bit width: 3, access: read-write) Select rate in Hz at which the temperature is sampled.

Following values can be set to or read from the field temp\_rate:

| Value       | Description                      |
|-------------|----------------------------------|
| 0b000 (0x0) | Sample temperature at 1.5625 Hz. |
| 0b001 (0x1) | Sample temperature at 3.125 Hz.  |
| 0b010 (0x2) | Sample temperature at 6.25 Hz.   |
| 0b011 (0x3) | Sample temperature at 12.5 Hz.   |
| 0b100 (0x4) | Sample temperature at 25 Hz.     |
| 0b101 (0x5) | Sample temperature at 50 Hz.     |
| 0b110 (0x6) | Sample temperature at 100 Hz.    |
| 0b111 (0x7) | Sample temperature at 200 Hz.    |

TEMP\_CONF.temp\_meas\_src: (bit offset: 3, bit width: 1, access: read-write) Select the input source for the temperature ADC.

Following values can be set to or read from the field temp\_meas\_src:

| Value     | Description                                  |
|-----------|----------------------------------------------|
| 0b0 (0x0) | internal temperature diode                   |
| 0b1 (0x1) | external input as configured by temp_ext_sel |

■ TEMP\_CONF.temp\_ext\_sel: (bit offset: 4, bit width: 1, access: read-write) Select the external pin as source for temperature ADC.

Following values can be set to or read from the field temp\_ext\_sel:

| Value     | Description        |
|-----------|--------------------|
| 0b0 (0x0) | interrupt pin INT1 |
| 0b1 (0x1) | interrupt pin INT2 |

■ TEMP\_CONF. reserved: (bit offset: 5, bit width: 3, access: read-write) write 0x3.

Use this link to go back to the overview table: TEMP\_CONF.

## Register (0x34) INT1\_CONF

**Description:** Configuration register for INT1

| 7        | 6           | 5                | 4                       | 3                                                                                                                              | 2       | 1         | 0           |
|----------|-------------|------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------|---------|-----------|-------------|
| R        | R           | R                | R                       | R/W                                                                                                                            | R/W     | R/W       | R/W         |
| 0        | 0           | 0                | 0                       | 0                                                                                                                              | 0       | 0         | 0           |
| reserved |             |                  | lyl                     | od                                                                                                                             | mc      | l         |             |
|          | 7<br>R<br>0 | 7 6 R R 0 0 rese | 7 6 5<br>R R R<br>0 0 0 | 7         6         5         4           R         R         R         R           0         0         0         0   reserved | 0 0 0 0 | 0 0 0 0 0 | 0 0 0 0 0 0 |

■ reserved: write 0x0.

■ INT1\_CONF.mode: (bit offset: 0, bit width: 2, access: read-write) Output enable for INT1 pin. Following values can be set to or read from the field mode:

| Value      | Description                                           |
|------------|-------------------------------------------------------|
| 0b00 (0x0) | Output disabled.                                      |
| 0b01 (0x1) | Latched (level triggered) interrupts.                 |
| 0b10 (0x2) | Pulsed (edge triggered) interrupts with short pulses. |
| 0b11 (0x3) | Pulsed (edge triggered) interrupts with long pulses.  |

■ INT1\_CONF.od: (bit offset: 2, bit width: 1, access: read-write) Configure behaviour of INT1 pin to open drain. Following values can be set to or read from the field od:

| Value     | Description |
|-----------|-------------|
| 0b0 (0x0) | push-pull   |
| 0b1 (0x1) | open drain  |

■ INT1\_CONF.lvl: (bit offset: 3, bit width: 1, access: read-write) Configure level of INT1 pin. Following values can be set to or read from the field lvl:

| Value     | Description |
|-----------|-------------|
| 0b0 (0x0) | active low  |
| 0b1 (0x1) | active high |

Use this link to go back to the overview table: INT1\_CONF.

## Register (0x35) INT2\_CONF

**Description:** Configuration register for INT2

| Bit        | 7        | 6 | 5 | 4   | 3   | 2   | 1   | 0   |
|------------|----------|---|---|-----|-----|-----|-----|-----|
| Read/Write | R        | R | R | R   | R/W | R/W | R/W | R/W |
| Reset      | 0        | 0 | 0 | 0   | 0   | 0   | 0   | 0   |
| Value      | -        | - | - |     |     |     | -   | -   |
| Content    | reserved |   |   | lvl | od  | mo  | de  |     |

■ reserved: write 0x0.

■ INT2\_CONF.mode: (bit offset: 0, bit width: 2, access: read-write) Mode for INT2 pin. Following values can be set to or read from the field mode:

| Value      | Description                                           |
|------------|-------------------------------------------------------|
| 0b00 (0x0) | Output disabled.                                      |
| 0b01 (0x1) | Latched (level triggered) interrupts.                 |
| 0b10 (0x2) | Pulsed (edge triggered) interrupts with short pulses. |
| 0b11 (0x3) | Pulsed (edge triggered) interrupts with long pulses.  |

■ INT2\_CONF. od: (bit offset: 2, bit width: 1, access: read-write) Configure behaviour of INT2 pin to open drain. Following values can be set to or read from the field od:

| Value     | Description |
|-----------|-------------|
| 0b0 (0x0) | push-pull   |
| 0b1 (0x1) | open drain  |

■ INT2\_CONF.lvl: (bit offset: 3, bit width: 1, access: read-write) Configure level of INT2 pin. Following values can be set to or read from the field lvl:

| Value     | Description |
|-----------|-------------|
| 0b0 (0x0) | active low  |
| 0b1 (0x1) | active high |

Use this link to go back to the overview table: INT2\_CONF.

## Register (0x36) INT\_MAP\_0

**Description:** Interrupt mapping register 0

| Bit            | 7        | 6        | 5          | 4       | 3        | 2        | 1        | 0        |
|----------------|----------|----------|------------|---------|----------|----------|----------|----------|
| Read/Write     | R/W      | R/W      | R/W        | R/W     | R/W      | R/W      | R/W      | R/W      |
| Reset<br>Value | 0        | 0        | 0          | 0       | 0        | 0        | 0        | 0        |
| Content        | gen_int1 | _int_map | fifo_full_ | int_map | fifo_wm_ | _int_map | acc_drdy | _int_map |

■ INT\_MAP\_0.acc\_drdy\_int\_map: (bit offset: 0, bit width: 2, access: read-write) Data ready interrupt mapping. Following values can be set to or read from the field acc\_drdy\_int\_map:

| Value      | Description                                   |
|------------|-----------------------------------------------|
| 0b00 (0x0) | Interrupt is not mapped to any destination    |
| 0b01 (0x1) | Interrupt is mapped to INT1 pin               |
| 0b10 (0x2) | Interrupt is mapped to INT2 pin               |
| 0b11 (0x3) | Interrupt is mapped to I3C in-band interrupts |

■ INT\_MAP\_0.fifo\_wm\_int\_map: (bit offset: 2, bit width: 2, access: read-write) FIFO watermark interrupt mapping. Following values can be set to or read from the field fifo\_wm\_int\_map:

| Value      | Description                                   |
|------------|-----------------------------------------------|
| 0b00 (0x0) | Interrupt is not mapped to any destination    |
| 0b01 (0x1) | Interrupt is mapped to INT1 pin               |
| 0b10 (0x2) | Interrupt is mapped to INT2 pin               |
| 0b11 (0x3) | Interrupt is mapped to I3C in-band interrupts |

INT\_MAP\_0.fifo\_full\_int\_map: (bit offset: 4, bit width: 2, access: read-write) FIFO full interrupt mapping. Following values can be set to or read from the field fifo\_full\_int\_map:

| Value      | Description                                   |
|------------|-----------------------------------------------|
| 0b00 (0x0) | Interrupt is not mapped to any destination    |
| 0b01 (0x1) | Interrupt is mapped to INT1 pin               |
| 0b10 (0x2) | Interrupt is mapped to INT2 pin               |
| 0b11 (0x3) | Interrupt is mapped to I3C in-band interrupts |

INT\_MAP\_0.gen\_int1\_int\_map: (bit offset: 6, bit width: 2, access: read-write) Generic interrupt 1 interrupt mapping. Following values can be set to or read from the field gen\_int1\_int\_map:

| Value      | Description                                   |
|------------|-----------------------------------------------|
| 0b00 (0x0) | Interrupt is not mapped to any destination    |
| 0b01 (0x1) | Interrupt is mapped to INT1 pin               |
| 0b10 (0x2) | Interrupt is mapped to INT2 pin               |
| 0b11 (0x3) | Interrupt is mapped to I3C in-band interrupts |

Use this link to go back to the overview table: INT\_MAP\_0.

### Register (0x37) INT\_MAP\_1

**Description:** Interrupt mapping register 1

| Bit            | 7            | 6   | 5        | 4        | 3        | 2        | 1        | 0        |
|----------------|--------------|-----|----------|----------|----------|----------|----------|----------|
| Read/Write     | R/W          | R/W | R/W      | R/W      | R/W      | R/W      | R/W      | R/W      |
| Reset<br>Value | 0            | 0   | 0        | 0        | 0        | 0        | 0        | 0        |
| Content        | stap_int_map |     | acc_foc_ | _int_map | gen_int3 | _int_map | gen_int2 | _int_map |

INT\_MAP\_1.gen\_int2\_int\_map: (bit offset: 0, bit width: 2, access: read-write) Generic interrupt 2 interrupt mapping. Following values can be set to or read from the field gen\_int2\_int\_map:

| Value      | Description                                   |
|------------|-----------------------------------------------|
| 0b00 (0x0) | Interrupt is not mapped to any destination    |
| 0b01 (0x1) | Interrupt is mapped to INT1 pin               |
| 0b10 (0x2) | Interrupt is mapped to INT2 pin               |
| 0b11 (0x3) | Interrupt is mapped to I3C in-band interrupts |

■ INT\_MAP\_1.gen\_int3\_int\_map: (bit offset: 2, bit width: 2, access: read-write) Generic interrupt 3 interrupt mapping. Following values can be set to or read from the field gen\_int3\_int\_map:

| Value      | Description                                   |
|------------|-----------------------------------------------|
| 0b00 (0x0) | Interrupt is not mapped to any destination    |
| 0b01 (0x1) | Interrupt is mapped to INT1 pin               |
| 0b10 (0x2) | Interrupt is mapped to INT2 pin               |
| 0b11 (0x3) | Interrupt is mapped to I3C in-band interrupts |

■ INT\_MAP\_1.acc\_foc\_int\_map: (bit offset: 4, bit width: 2, access: read-write) Accelerometer fast offset compensation interrupt mapping.

Following values can be set to or read from the field acc\_foc\_int\_map:

| Value      | Description                                   |
|------------|-----------------------------------------------|
| 0b00 (0x0) | Interrupt is not mapped to any destination    |
| 0b01 (0x1) | Interrupt is mapped to INT1 pin               |
| 0b10 (0x2) | Interrupt is mapped to INT2 pin               |
| 0b11 (0x3) | Interrupt is mapped to I3C in-band interrupts |

■ INT\_MAP\_1.stap\_int\_map: (bit offset: 6, bit width: 2, access: read-write) Single tap interrupt mapping. Following values can be set to or read from the field stap\_int\_map:

| Value      | Description                                   |
|------------|-----------------------------------------------|
| 0b00 (0x0) | Interrupt is not mapped to any destination    |
| 0b01 (0x1) | Interrupt is mapped to INT1 pin               |
| 0b10 (0x2) | Interrupt is mapped to INT2 pin               |
| 0b11 (0x3) | Interrupt is mapped to I3C in-band interrupts |

Use this link to go back to the overview table: INT\_MAP\_1.

### Register (0x38) INT\_MAP\_2

**Description:** Interrupt mapping register 2

| Bit            | 7              | 6   | 5      | 4      | 3       | 2      | 1       | 0      |
|----------------|----------------|-----|--------|--------|---------|--------|---------|--------|
| Read/Write     | R/W            | R/W | R/W    | R/W    | R/W     | R/W    | R/W     | R/W    |
| Reset<br>Value | 0              | 0   | 0      | 0      | 0       | 0      | 0       | 0      |
| Content        | self_wake_up_i |     | vad_in | it_map | ttap_ir | nt_map | dtap_ir | nt_map |

■ INT\_MAP\_2.dtap\_int\_map: (bit offset: 0, bit width: 2, access: read-write) Double tap interrupt mapping. Following values can be set to or read from the field dtap\_int\_map:

| Value      | Description                                   |
|------------|-----------------------------------------------|
| 0b00 (0x0) | Interrupt is not mapped to any destination    |
| 0b01 (0x1) | Interrupt is mapped to INT1 pin               |
| 0b10 (0x2) | Interrupt is mapped to INT2 pin               |
| 0b11 (0x3) | Interrupt is mapped to I3C in-band interrupts |

■ INT\_MAP\_2.ttap\_int\_map: (bit offset: 2, bit width: 2, access: read-write) Triple tap interrupt mapping. Following values can be set to or read from the field ttap\_int\_map:

| Value      | Description                                   |
|------------|-----------------------------------------------|
| 0b00 (0x0) | Interrupt is not mapped to any destination    |
| 0b01 (0x1) | Interrupt is mapped to INT1 pin               |
| 0b10 (0x2) | Interrupt is mapped to INT2 pin               |
| 0b11 (0x3) | Interrupt is mapped to I3C in-band interrupts |

■ INT\_MAP\_2.vad\_int\_map: (bit offset: 4, bit width: 2, access: read-write) Voice activity detection interrupt mapping. Following values can be set to or read from the field vad\_int\_map:

| Value      | Description                                   |
|------------|-----------------------------------------------|
| 0b00 (0x0) | Interrupt is not mapped to any destination    |
| 0b01 (0x1) | Interrupt is mapped to INT1 pin               |
| 0b10 (0x2) | Interrupt is mapped to INT2 pin               |
| 0b11 (0x3) | Interrupt is mapped to I3C in-band interrupts |

INT\_MAP\_2.self\_wake\_up\_int\_map: (bit offset: 6, bit width: 2, access: read-write) Self wake-up interrupt mapping. Following values can be set to or read from the field self\_wake\_up\_int\_map:

| Value      | Description                                   |
|------------|-----------------------------------------------|
| 0b00 (0x0) | Interrupt is not mapped to any destination    |
| 0b01 (0x1) | Interrupt is mapped to INT1 pin               |
| 0b10 (0x2) | Interrupt is mapped to INT2 pin               |
| 0b11 (0x3) | Interrupt is mapped to I3C in-band interrupts |

Use this link to go back to the overview table: INT\_MAP\_2.

## Register (0x39) INT\_MAP\_3

**Description:** Interrupt mapping register 3

| Bit        | 7                       | 6 | 5 | 4 | 3 | 2       | 1   | 0   |
|------------|-------------------------|---|---|---|---|---------|-----|-----|
| Read/Write | R                       | R | R | R | R | R       | R/W | R/W |
| Reset      | 0                       | 0 | 0 | 0 | 0 | 0       | 0   | 0   |
| Value      | •                       |   |   |   |   |         | •   |     |
| Content    | reserved feat_eng_err_i |   |   |   |   | g_err_i |     |     |

write 0x0. reserved:

■ INT\_MAP\_3.feat\_eng\_err\_int\_map: (bit offset: 0, bit width: 2, access: read-write) Feature engine error interrupt mapping.

Following values can be set to or read from the field feat\_eng\_err\_int\_map:

| Value      | Description                                   |
|------------|-----------------------------------------------|
| 0b00 (0x0) | Interrupt is not mapped to any destination    |
| 0b01 (0x1) | Interrupt is mapped to INT1 pin               |
| 0b10 (0x2) | Interrupt is mapped to INT2 pin               |
| 0b11 (0x3) | Interrupt is mapped to I3C in-band interrupts |

Use this link to go back to the overview table: INT\_MAP\_3.

# Register (0x3A) IF\_CONF\_0

**Description:** Serial interface settings

| Bit            | 7        | 6 | 5 | 4  | 3            | 2 | 1 | 0 |
|----------------|----------|---|---|----|--------------|---|---|---|
| Read/Write     | R        | R | R | R  | R            | R | R | R |
| Reset<br>Value | 0        | 0 | 0 | 1  | 1            | 0 | 0 | 0 |
| Content        | reserved |   |   | it | _i2c_slv_add | r |   |   |

- reserved: write 0x0.
- IF\_CONF\_0.if\_i2c\_slv\_addr: (bit offset: 0, bit width: 7, access: read-only) I2C slave address of this device. Following values can be read from the field if\_i2c\_slv\_addr:

| Value | Description                                  |
|-------|----------------------------------------------|
| 0x18  | the default i2c slave address of this device |

Use this link to go back to the overview table: IF\_CONF\_0.

### Register (0x3B) IF\_CONF\_1

**Description:** Serial interface settings

| Bit            | 7        | 6      | 5   | 4          | 3   | 2      | 1      | 0      |
|----------------|----------|--------|-----|------------|-----|--------|--------|--------|
| Read/Write     | R        | R/W    | R/W | R/W        | R/W | R/W    | R/W    | R/W    |
| Reset<br>Value | 0        | 0      | 1   | 1          | 1   | 0      | 0      | 0      |
| Content        | reserved | if_i2c |     | if_pad_drv |     | if_csb | if_spi | if_i3c |

- reserved: write 0x0.
- IF\_CONF\_1.if\_i3c\_cfg: (bit offset: 0, bit width: 1, access: read-write) Configuration of I3C mode. Following values can be set to or read from the field if\_i3c\_cfg:

| Value     | Description               |
|-----------|---------------------------|
| 0b0 (0x0) | The I3C mode is disabled. |
| 0b1 (0x1) | The I3C mode is enabled.  |

■ IF\_CONF\_1.if\_spi3\_cfg: (bit offset: 1, bit width: 1, access: read-write) Configuration of SPI3 mode(SPI 3 wire protocol).

Following values can be set to or read from the field if\_spi3\_cfg:

| Value     | Description                |
|-----------|----------------------------|
| 0b0 (0x0) | The SPI3 mode is disabled. |
| 0b1 (0x1) | The SPI3 mode is enabled.  |

■ IF\_CONF\_1.if\_csb\_pullup: (bit offset: 2, bit width: 1, access: read-write) Configuration of CSB pullup in SPI mode. Following values can be set to or read from the field if\_csb\_pullup:

| Value     | Description             |
|-----------|-------------------------|
| 0b0 (0x0) | The pullup is disabled. |
| 0b1 (0x1) | The pullup is enabled.  |

- IF\_CONF\_1.if\_pad\_drv: (bit offset: 3, bit width: 3, access: read-write) Pad drive strength in I2C mode.
- IF\_CONF\_1.if\_i2c\_drv\_sel: (bit offset: 6, bit width: 1, access: read-write) select drive strength in I2C mode. Following values can be set to or read from the field if\_i2c\_drv\_sel:

| Value     | Description                               |
|-----------|-------------------------------------------|
| 0b0 (0x0) | use maximum pad drive strength            |
| 0b1 (0x1) | use drive strength settings of if_pad_drv |

Use this link to go back to the overview table: IF\_CONF\_1.

## Register (0x40) FIFO\_CTRL

**Description:** FIFO control register

| Bit            | 7        | 6 | 5 | 4 | 3 | 2      | 1        | 0 |
|----------------|----------|---|---|---|---|--------|----------|---|
| Read/Write     | R        | R | R | R | R | R      | W        | W |
| Reset<br>Value | 0        | 0 | 0 | 0 | 0 | 0      | 0        | 0 |
| Content        | reserved |   |   |   |   | fifo_f | fifo_rst |   |

- reserved: write 0x0.
- FIFO\_CTRL.fifo\_rst: (bit offset: 0, bit width: 1, access: write-only) FIFO reset trigger. Writing '1' to this field synchronously resets the FIFO.
- FIFO\_CTRL.fifo\_frame\_sync: (bit offset: 1, bit width: 1, access: write-only) FIFO frame synchronization trigger. Writing '1' to this field tells the FIFO that another frame is about to be written to FIFO\_DATA\_IN.

Use this link to go back to the overview table: FIFO\_CTRL.

Register (0x41) FIFO\_CONF\_0

**Description:** FIFO configuration register 0

| Bit        | 7 | 6        | 5 | 4      | 3      | 2      | 1      | 0        |
|------------|---|----------|---|--------|--------|--------|--------|----------|
| Read/Write | R | R        | R | R/W    | R/W    | R/W    | R/W    | R/W      |
| Reset      | 0 | 0        | 0 | 0      | 1      | 1      | 1      | 0        |
| Value      | U | U        | U | U      | 1      | 1      | 1      | U        |
| Content    |   | reserved |   | fifo_c | fifo_a | fifo_a | fifo_a | fifo_cfg |

■ reserved: write 0x0.

• FIFO\_CONF\_0.fifo\_cfg: (bit offset: 0, bit width: 1, access: read-write) Enable bit for the FIFO. Cannot be set to 1 if fifo\_size equals 0.

Following values can be set to or read from the field fifo\_cfg:

| Value     | Description           |
|-----------|-----------------------|
| 0b0 (0x0) | The FIFO is disabled. |
| 0b1 (0x1) | The FIFO is enabled.  |

• FIFO\_CONF\_0.fifo\_acc\_x: (bit offset: 1, bit width: 1, access: read-write) Configuration bit to enable the storage of the x-axis acceleration data in the FIFO.

Following values can be set to or read from the field fifo\_acc\_x:

| Value     | Description                                       |
|-----------|---------------------------------------------------|
| 0b0 (0x0) | The FIFO x-axis acceleration channel is disabled. |
| 0b1 (0x1) | The FIFO x-axis acceleration channel is enabled.  |

• FIFO\_CONF\_0.fifo\_acc\_y: (bit offset: 2, bit width: 1, access: read-write) Configuration bit to enable the storage of the y-axis acceleration data in the FIFO.

Following values can be set to or read from the field fifo\_acc\_y:

| Value     | Description                                       |
|-----------|---------------------------------------------------|
| 0b0 (0x0) | The FIFO y-axis acceleration channel is disabled. |
| 0b1 (0x1) | The FIFO y-axis acceleration channel is enabled.  |

• FIFO\_CONF\_0.fifo\_acc\_z: (bit offset: 3, bit width: 1, access: read-write) Configuration bit to enable the storage of the z-axis acceleration data in the FIFO.

Following values can be set to or read from the field fifo\_acc\_z:

| Value     | Description                                       |
|-----------|---------------------------------------------------|
| 0b0 (0x0) | The FIFO z-axis acceleration channel is disabled. |
| 0b1 (0x1) | The FIFO z-axis acceleration channel is enabled.  |

• FIFO\_CONF\_0.fifo\_compression: (bit offset: 4, bit width: 1, access: read-write) Enable bit for FIFO data compression.

Following values can be set to or read from the field fifo\_compression:

| Value     | Description                                             |
|-----------|---------------------------------------------------------|
| 0b0 (0x0) | compression disbaled. full 16bit acceleration data.     |
| 0b1 (0x1) | compression enabled. 8bit compressed acceleration data. |

Use this link to go back to the overview table: FIFO\_CONF\_0.

#### Register (0x42) FIFO\_CONF\_1

**Description:** FIFO configuration register 1

| Bit            | 7        | 6 | 5      | 4        | 3        | 2     | 1    | 0   |
|----------------|----------|---|--------|----------|----------|-------|------|-----|
| Read/Write     | R        | R | R      | R/W      | R/W      | R/W   | R/W  | R/W |
| Reset<br>Value | 0        | 0 | 0      | 0        | 0        | 1     | 1    | 0   |
| Content        | reserved |   | fifo_s | fifo_sen | sor_time | fifo_ | size |     |

- reserved: write 0x0.
- FIFO\_CONF\_1.fifo\_size: (bit offset: 0, bit width: 2, access: read-write) FIFO size. Since FIFO and feature engine share a common RAM, the size for the FIFO share has to be adjusted. Cannot be changed if locked by the feature engine. In order to change this value, first disable the feature engine. If the feature engine is turned on again, a minimum share might be needed and this setting might be changed by the feature engine. Following values can be set to or read from the field fifo\_size:

| Value      | Description                                                                                                                                            |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b00 (0x0) | The FIFO has a size of 0 bytes. The feature engine ('feat_eng') has a RAM size of 1024 bytes. This setting forces fifo_en to 0.                        |
| 0b01 (0x1) | The FIFO has a size of 256 bytes. The feature engine ('feat_eng') has a RAM size of 768 bytes.                                                         |
| 0b10 (0x2) | The FIFO has a size of 512 bytes. The feature engine ('feat_eng') has a RAM size of 512 bytes.                                                         |
| 0b11 (0x3) | The FIFO has a size of 1024 bytes. The feature engine ('feat_eng') has a RAM size of 0 bytes. This setting forces feature engine ('feat_eng')_en to 0. |

• FIFO\_CONF\_1.fifo\_sensor\_time: (bit offset: 2, bit width: 2, access: read-write) FIFO sensor time configuration. Following values can be set to or read from the field fifo\_sensor\_time:

| Value      | Description                                                                                |
|------------|--------------------------------------------------------------------------------------------|
| 0b00 (0x0) | The FIFO does not transmit the sensor time.                                                |
| 0b01 (0x1) | The FIFO sends a dedicated sensor time frame when the FIFO runs empty during a read burst. |
| 0b10 (0x2) | The FIFO has appends the sensor time to each frame.                                        |

• FIFO\_CONF\_1.fifo\_stop\_on\_full: (bit offset: 4, bit width: 1, access: read-write) If set, the FIFO stops storing new data if it is full. Otherwise the oldest frame is dropped in order to make room for a new frame. Following values can be set to or read from the field fifo\_stop\_on\_full:

| Value     | Description                                                                                   |
|-----------|-----------------------------------------------------------------------------------------------|
| 0b0 (0x0) | feature disbaled.The FIFO will be filled continously with new data, old data will be dropped. |
| 0b1 (0x1) | feature enabled. The FIFO will stop, when it is full.                                         |

Use this link to go back to the overview table: FIFO\_CONF\_1.

## Register (0x43) FIFO\_WM\_0

**Description:** FIFO watermark level register (LSB)

| Bit            | 7                        | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------------|--------------------------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write     | R/W                      | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0                        | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Content        | fifo_watermark_level_7_0 |     |     |     |     |     |     |     |

• FIFO\_WM\_0.fifo\_watermark\_level\_7\_0: (bit offset: 0, bit width: 8, access: read-write) LSB of the FIFO watermark level.

Use this link to go back to the overview table: FIFO\_WM\_0.

## Register (0x44) FIFO\_WM\_1

Description: FIFO watermark level register (MSB)

| Bit            | 7 | 6 | 5        | 4       | 3            | 2      | 1   | 0   |
|----------------|---|---|----------|---------|--------------|--------|-----|-----|
| Read/Write     | R | R | R        | R       | R            | R/W    | R/W | R/W |
| Reset<br>Value | 0 | 0 | 0        | 0       | 0            | 1      | 0   | 0   |
| Content        |   |   | reserved | fifo_wa | termark_leve | l_10_8 |     |     |

■ reserved: write 0x0.

■ FIFO\_WM\_1.fifo\_watermark\_level\_10\_8: (bit offset: 0, bit width: 3, access: read-write) LSB of the FIFO watermark level.

Use this link to go back to the overview table: FIFO\_WM\_1.

## Register (0x50) FEAT\_ENG\_CONF

Description: feature engine ('feat\_eng') configuration register

| Bit        | 7        | 6 | 5 | 4 | 3 | 2 | 1      | 0   |
|------------|----------|---|---|---|---|---|--------|-----|
| Read/Write | R        | R | R | R | R | R | R      | R/W |
| Reset      | 0        | 0 | 0 | 0 | 0 | 0 | 0      | 1   |
| Value      |          |   |   |   |   |   |        |     |
| Content    | reserved |   |   |   |   |   | feat_e |     |

- reserved: write 0x0.
- FEAT\_ENG\_CONF.feat\_eng\_ctrl: (bit offset: 0, bit width: 1, access: read-write) An enable/disable switch for the feature engine. The feature engine is internally reseted, once the engine is disabled and the enabled again. Following values can be set to or read from the field feat\_eng\_ctrl:

| Value     | Description                                |
|-----------|--------------------------------------------|
| 0b0 (0x0) | the feature engine is disabled (and reset) |
| 0b1 (0x1) | the feature engine is enabled.             |

Use this link to go back to the overview table: FEAT\_ENG\_CONF.

#### Register (0x51) FEAT\_ENG\_STATUS

**Description:** feature engine ('feat\_eng') status register

| Bit            | 7        | 6 | 5 | 4 | 3      | 2      | 1      | 0      |
|----------------|----------|---|---|---|--------|--------|--------|--------|
| Read/Write     | R        | R | R | R | R      | R      | R      | R      |
| Reset<br>Value | 0        | 0 | 0 | 0 | 0      | 0      | 0      | 0      |
| Content        | reserved |   |   |   | feat_e | host_g | feat_e | feat_e |

- reserved: write 0x0.
- FEAT\_ENG\_STATUS.feat\_eng\_halted: (bit offset: 0, bit width: 1, access: read-only) When this field equals 1, the feature engine is currently halted. This means that the "halt" instruction has been executed and that the processor waits for a wakeup trigger.
- FEAT\_ENG\_STATUS.feat\_eng\_running: (bit offset: 1, bit width: 1, access: read-only) When this field equals 1, the feature engine is currently executing code.
- FEAT\_ENG\_STATUS.host\_gpr\_update\_pending: (bit offset: 2, bit width: 1, access: read-only) This field reads 1'b1 as long as an update of the host-owned GPRs is pending. .
- FEAT\_ENG\_STATUS.feat\_eng\_gpr\_update\_pending: (bit offset: 3, bit width: 1, access: read-only) This field reads 1'b1 as long as an update of the feature engine-owned GPRs is pending.

Use this link to go back to the overview table: FEAT\_ENG\_STATUS.

## Register (0x52) FEAT\_ENG\_GP\_FLAGS

Description: feature engine ('feat\_eng') general purpose flags

| Bit            | 7 | 6 | 5        | 4      | 3       | 2        | 1 | 0 |
|----------------|---|---|----------|--------|---------|----------|---|---|
| Read/Write     | R | R | R        | R      | R       | R        | R | R |
| Reset<br>Value | 0 | 0 | 0        | 0      | 0       | 0        | 0 | 0 |
| Content        |   |   | reserved | foc_ru | feat_ir | nit_stat |   |   |

- write 0x0. reserved:
- FEAT\_ENG\_GP\_FLAGS.feat\_init\_stat: (bit offset: 0, bit width: 2, access: read-only) Feature engine initialization status.

Following values can be read from the field feat\_init\_stat:

| Value      | Description                       |
|------------|-----------------------------------|
| 0b00 (0x0) | Feature engine is not initialized |
| 0b01 (0x1) | Feature engine is initialized     |
| 0b10 (0x2) | Reserved                          |
| 0b11 (0x3) | Reserved                          |

■ FEAT\_ENG\_GP\_FLAGS.foc\_running: (bit offset: 2, bit width: 1, access: read-only) Bit is set to '1' if fast-offset compensation feature is being executed. Bit is cleared to '0' at the end of feature compensation. User should not change the accelerometer configuration while the feature is running. .

Use this link to go back to the overview table: FEAT\_ENG\_GP\_FLAGS.

#### Register (0x53) FEAT\_ENG\_GPR\_CONF

Description: feature engine ('feat eng') general purpose register configuration register

| Bit            | 7        | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------------|----------|--------|--------|--------|--------|--------|--------|--------|
| Read/Write     | R        | R/W    |
| Reset<br>Value | 0        | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
| Content        | reserved | feat_e |

- reserved: write 0x0.
- FEAT\_ENG\_GPR\_CONF.feat\_eng\_gpr\_0\_dir: (bit offset: 0, bit width: 1, access: read-write) host Direction for GP register 0 ('0': feature engine has write access, '1': host has write access). This field is only writeable by the feature engine.
- FEAT\_ENG\_GPR\_CONF.feat\_eng\_gpr\_1\_dir: (bit offset: 1, bit width: 1, access: read-write) host Direction for GP register 1 ('0': feature engine has write access, '1': host has write access). This field is only writeable by the feature engine.
- FEAT\_ENG\_GPR\_CONF.feat\_eng\_gpr\_2\_dir: (bit offset: 2, bit width: 1, access: read-write) host Direction for GP register 2 ('0': feature engine has write access, '1': host has write access). This field is only writeable by the feature engine.
- FEAT\_ENG\_GPR\_CONF.feat\_eng\_gpr\_3\_dir: (bit offset: 3, bit width: 1, access: read-write) host direction for GP register 3 ('0': feature engine has write access, '1': host has write access). This field is only writeable by the feature engine.
- FEAT\_ENG\_GPR\_CONF.feat\_eng\_gpr\_4\_dir: (bit offset: 4, bit width: 1, access: read-write) host direction for GP register 4 ('0': feature engine has write access, '1': host has write access). This field is only writeable by the feature engine.
- FEAT\_ENG\_GPR\_CONF.feat\_eng\_gpr\_5\_dir: (bit offset: 5, bit width: 1, access: read-write) host direction for GP register 5 ('0': feature engine has write access, '1': host has write access). This field is only writeable by the feature engine.
- FEAT\_ENG\_GPR\_CONF.feat\_eng\_gpr\_6\_dir: (bit offset: 6, bit width: 1, access: read-write) host direction for GP register 6 ('0': feature engine has write access, '1': host has write access). This field is only writeable by the feature engine.

Use this link to go back to the overview table: FEAT\_ENG\_GPR\_CONF.

#### Register (0x54) FEAT\_ENG\_GPR\_CTRL

**Description:** feature engine ('feat\_eng') general purpose register control register

| Bit            | 7 | 6        | 5 | 4 | 3 | 2 | 1 | 0        |
|----------------|---|----------|---|---|---|---|---|----------|
| Read/Write     | R | R        | R | R | R | R | W | W        |
| Reset<br>Value | 0 | 0        | 0 | 0 | 0 | 0 | 0 | 0        |
| Content        |   | reserved |   |   |   |   |   | update:. |

- reserved: write 0x0.
- FEAT\_ENG\_GPR\_CTRL.update\_gprs: (bit offset: 0, bit width: 1, access: write-only) If the host writes 1'b1 to this field, it requests that the host-owned first stage registers are copied to the host-owned second stage registers. If the feature engine writes 1'b1 to this field, it requests that the feature engine-owned first stage registers are copied to the feature engine-owned second stage registers.
- FEAT\_ENG\_GPR\_CTRL.unlock\_gprs: (bit offset: 1, bit width: 1, access: write-only) If the host writes 1'b1 to this field, it releases the lock of the feature engine-owned GPRs and thus allows for an update of the feature engine-owned second stage registers. If the feature engine writes 1'b1 to this field, it releases the lock of the host-owned GPRs and thus allows for an update of the host-owned second stage registers. .

Use this link to go back to the overview table: FEAT\_ENG\_GPR\_CTRL.

#### Register (0x55) FEAT\_ENG\_GPR\_0

**Description:** feature engine ('feat\_eng') general purpose register 0

| Bit            | 7        | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------------|----------|--------|--------|--------|--------|--------|--------|--------|
| Read/Write     | R        | R/W    |
| Reset<br>Value | 0        | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
| Content        | reserved | self_w | vad_en | tap_en | acc_fo | gen_in | gen_in | gen_in |

- reserved: write 0x0.
- FEAT\_ENG\_GPR\_0.gen\_int1\_en: (bit offset: 0, bit width: 1, access: read-write) Enables generic interrupt 1 feature.
- FEAT\_ENG\_GPR\_0.gen\_int2\_en: (bit offset: 1, bit width: 1, access: read-write) Enables generic interrupt 2 feature.
- FEAT\_ENG\_GPR\_0.gen\_int3\_en: (bit offset: 2, bit width: 1, access: read-write) Enables generic interrupt 3 feature.
- FEAT\_ENG\_GPR\_0.acc\_foc\_en: (bit offset: 3, bit width: 1, access: read-write) Enables accelerometer fast offset compensation feature.
- FEAT\_ENG\_GPR\_0.tap\_en: (bit offset: 4, bit width: 1, access: read-write) Enables tap feature.
- FEAT\_ENG\_GPR\_0.vad\_en: (bit offset: 5, bit width: 1, access: read-write) Enables voice activity detection feature.
- FEAT\_ENG\_GPR\_0.self\_wake\_up\_en: (bit offset: 6, bit width: 1, access: read-write) Enables self wake-up feature.

Use this link to go back to the overview table: FEAT\_ENG\_GPR\_0.

## Register (0x56) FEAT\_ENG\_GPR\_1

**Description:** feature engine ('feat\_eng') general purpose register 1

| Bit        | 7    | 6    | 5         | 4         | 3         | 2         | 1        | 0         |
|------------|------|------|-----------|-----------|-----------|-----------|----------|-----------|
| Read/Write | R    | R    | R/W       | R/W       | R/W       | R/W       | R/W      | R/W       |
| Reset      | 0    | 0    | 0         | 0         | 0         | 0         | 0        | 0         |
| Value      |      |      |           |           |           |           |          |           |
| Content    | rese | rved | gen_int3_ | _data_src | gen_int2_ | _data_src | gen_int1 | _data_src |

- reserved: write 0x0.
- FEAT\_ENG\_GPR\_1.gen\_int1\_data\_src: (bit offset: 0, bit width: 2, access: read-write) Data source selection for gen\_int1 feature.

Following values can be set to or read from the field gen\_int1\_data\_src:

| Value      | Description                               |
|------------|-------------------------------------------|
| 0b00 (0x0) | Uses 50Hz filter data                     |
| 0b01 (0x1) | Uses 200Hz filter data                    |
| 0b10 (0x2) | Uses user filter data                     |
| 0b11 (0x3) | Uses 50Hz filter data. Same as data_src_1 |

■ FEAT\_ENG\_GPR\_1.gen\_int2\_data\_src: (bit offset: 2, bit width: 2, access: read-write) Data source selection for gen int2 feature.

Following values can be set to or read from the field gen\_int2\_data\_src:

| Value      | Description                               |
|------------|-------------------------------------------|
| 0b00 (0x0) | Uses 50Hz filter data                     |
| 0b01 (0x1) | Uses 200Hz filter data                    |
| 0b10 (0x2) | Uses user filter data                     |
| 0b11 (0x3) | Uses 50Hz filter data. Same as data_src_1 |

■ FEAT\_ENG\_GPR\_1.gen\_int3\_data\_src: (bit offset: 4, bit width: 2, access: read-write) Data source selection for gen int3 feature.

Following values can be set to or read from the field gen\_int3\_data\_src:

| Value      | Description                               |  |  |  |  |
|------------|-------------------------------------------|--|--|--|--|
| 0b00 (0x0) | Uses 50Hz filter data                     |  |  |  |  |
| 0b01 (0x1) | Uses 200Hz filter data                    |  |  |  |  |
| 0b10 (0x2) | Uses user filter data                     |  |  |  |  |
| 0b11 (0x3) | Uses 50Hz filter data. Same as data_src_1 |  |  |  |  |

Use this link to go back to the overview table: FEAT\_ENG\_GPR\_1.

#### Register (0x57) FEAT\_ENG\_GPR\_2

Description: feature engine ('feat\_eng') general purpose register 2

| Bit            | 7 | 6        | 5 | 4        | 3      | 2      | 1      | 0      |
|----------------|---|----------|---|----------|--------|--------|--------|--------|
| Read/Write     | R | R        | R | R        | R      | R      | R      | R      |
| Reset<br>Value | 0 | 0        | 0 | 0        | 0      | 0      | 0      | 0      |
| Content        |   | reserved |   | vad_stat | self_w | gen_in | gen_in | gen_in |

- write 0x0. reserved:
- FEAT\_ENG\_GPR\_2.gen\_int1\_stat: (bit offset: 0, bit width: 1, access: read-only) Status of generic interrupt 1 feature.
- FEAT\_ENG\_GPR\_2.gen\_int2\_stat: (bit offset: 1, bit width: 1, access: read-only) Status of generic interrupt 2 feature.
- FEAT\_ENG\_GPR\_2.gen\_int3\_stat: (bit offset: 2, bit width: 1, access: read-only) Status of generic interrupt 3 feature.
- FEAT\_ENG\_GPR\_2.self\_wake\_up\_stat: (bit offset: 3, bit width: 1, access: read-only) Status of self wake-up feature. Following values can be read from the field self\_wake\_up\_stat:

| Value     | Description       |
|-----------|-------------------|
| 0b0 (0x0) | Normal power mode |
| 0b1 (0x1) | low power mode    |

• FEAT\_ENG\_GPR\_2.vad\_stat: (bit offset: 4, bit width: 1, access: read-only) Status of vad feature.

Use this link to go back to the overview table: FEAT\_ENG\_GPR\_2.

## Register (0x5E) FEATURE\_DATA\_ADDR

Description: feature engine ('feat\_eng') feature data start address

| Bit            | 7        | 6   | 5                 | 4   | 3   | 2   | 1   | 0   |  |  |
|----------------|----------|-----|-------------------|-----|-----|-----|-----|-----|--|--|
| Read/Write     | R        | R/W | R/W               | R/W | R/W | R/W | R/W | R/W |  |  |
| Reset<br>Value | 0        | 0   | 0                 | 0   | 0   | 0   | 0   | 0   |  |  |
| Content        | reserved |     | feature_data_addr |     |     |     |     |     |  |  |

- reserved: write 0x0.
- FEATURE\_DATA\_ADDR.feature\_data\_addr: (bit offset: 0, bit width: 7, access: read-write) Feature data address. For the address values see the extended memory map.

  Following values can be set to or read from the field feature\_data\_addr:

| Value | Description                                            |
|-------|--------------------------------------------------------|
| 0x2   | address(0x2) to access register: feat_conf_err         |
| 0x3   | address(0x3) to access register: GENERAL_SETTINGS_0    |
| 0x4   | address(0x4) to access register: GENERIC_INTERRUPT1_1  |
| 0x5   | address(0x5) to access register: GENERIC_INTERRUPT1_2  |
| 0x6   | address(0x6) to access register: GENERIC_INTERRUPT1_3  |
| 0x7   | address(0x7) to access register: GENERIC_INTERRUPT1_4  |
| 0x8   | address(0x8) to access register: GENERIC_INTERRUPT1_5  |
| 0x9   | address(0x9) to access register: GENERIC_INTERRUPT1_6  |
| 0xA   | address(0xa) to access register: GENERIC_INTERRUPT1_7  |
| 0xB   | address(0xb) to access register: GENERIC_INTERRUPT2_1  |
| 0xC   | address(0xc) to access register: GENERIC_INTERRUPT2_2  |
| 0xD   | address(0xd) to access register: GENERIC_INTERRUPT2_3  |
| 0xE   | address(0xe) to access register: GENERIC_INTERRUPT2_4  |
| 0xF   | address(0xf) to access register: GENERIC_INTERRUPT2_5  |
| 0x10  | address(0x10) to access register: GENERIC_INTERRUPT2_6 |
| 0x11  | address(0x11) to access register: GENERIC_INTERRUPT2_7 |
| 0x12  | address(0x12) to access register: GENERIC_INTERRUPT3_1 |
| 0x13  | address(0x13) to access register: GENERIC_INTERRUPT3_2 |
| 0x14  | address(0x14) to access register: GENERIC_INTERRUPT3_3 |
| 0x15  | address(0x15) to access register: GENERIC_INTERRUPT3_4 |
| 0x16  | address(0x16) to access register: GENERIC_INTERRUPT3_5 |
| 0x17  | address(0x17) to access register: GENERIC_INTERRUPT3_6 |
| 0x18  | address(0x18) to access register: GENERIC_INTERRUPT3_7 |
| 0x19  | address(0x19) to access register: TAP_DETECTOR_1       |
| 0x1A  | address(0x1a) to access register: TAP_DETECTOR_2       |
| 0x1B  | address(0x1b) to access register: TAP_DETECTOR_3       |
| 0x1C  | address(0x1c) to access register: VAD_CTRL             |
| 0x24  | address(0x24) to access register: ACC_CONF_LOW_POWER   |
| 0x25  | address(0x25) to access register: FOC_0                |
| 0x26  | address(0x26) to access register: FOC_1                |
| 0x27  | address(0x27) to access register: FOC_2                |
| 0x28  | address(0x28) to access register: FOC_3                |

Use this link to go back to the overview table: FEATURE\_DATA\_ADDR.

## Register (0x5F) FEATURE\_DATA\_TX

Description: feature engine ('feat\_eng') feature data

| Bit            | 7            | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |
|----------------|--------------|-----|-----|-----|-----|-----|-----|-----|--|
| Read/Write     | R/W          | R/W | R/W | R/W | R/W | R/W | R/W | R/W |  |
| Reset<br>Value | 0            | 0   | 0   | 0   | 0   | 0   | 0   | 0   |  |
| Content        | feature_data |     |     |     |     |     |     |     |  |

■ FEATURE\_DATA\_TX.feature\_data: (bit offset: 0, bit width: 8, access: read-write) The data port associated with feature\_data\_addr. During burst read/write operations on this address the address increment stops and the burst operation can be used to read/write multiple feature\_data words. See the extendend memory map for details.

Use this link to go back to the overview table: FEATURE\_DATA\_TX.

## Register (0x70) ACC\_OFFSET\_0

Description: Offset compensation value (x-axis) LSB

| Bit            | 7              | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |
|----------------|----------------|-----|-----|-----|-----|-----|-----|-----|--|
| Read/Write     | R/W            | R/W | R/W | R/W | R/W | R/W | R/W | R/W |  |
| Reset<br>Value | 0              | 0   | 0   | 0   | 0   | 0   | 0   | 0   |  |
| Content        | acc_doff_x_7_0 |     |     |     |     |     |     |     |  |

■ ACC\_OFFSET\_0.acc\_doff\_x\_7\_0: (bit offset: 0, bit width: 8, access: read-write) Accelerometer compensation value for x-axis. 9 bit signed, resolution is 0.98 mg/LSB. Range is [-0.25 g .. 0.25 g]. The resolution of the compensation value is independent of the range setting. To disable the offset compensation, a value of 0x0 has to be written to this field. The compensation offset values are not persistent and must be written each time after power-up or reset of the device.

Use this link to go back to the overview table: ACC\_OFFSET\_0.

## Register (0x71) ACC\_OFFSET\_1

Description: Offset compensation value (x-axis) MSB

| Bit            | 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|----------------|----------|---|---|---|---|---|---|-----|
| Read/Write     | R        | R | R | R | R | R | R | R/W |
| Reset<br>Value | 0        | 0 | 0 | 0 | 0 | 0 | 0 | 0   |
| Content        | reserved |   |   |   |   |   |   |     |

■ reserved: write 0x0.

ACC\_OFFSET\_1.acc\_doff\_x\_8: (bit offset: 0, bit width: 1, access: read-write) Highest bit of the acc\_doff\_x field. See details at description of previous register field acc\_doff\_x\_7\_0.

Use this link to go back to the overview table: ACC\_OFFSET\_1.

## Register (0x72) ACC\_OFFSET\_2

Description: Offset compensation value (y-axis) LSB

| Bit        | 7              | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------------|----------------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write | R/W            | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset      | 0              | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Value      | U              | U   | 0   | U   | U   | U   | U   | U   |
| Content    | acc_doff_y_7_0 |     |     |     |     |     |     |     |

 ACC\_0FFSET\_2.acc\_doff\_y\_7\_0: (bit offset: 0, bit width: 8, access: read-write) Accelerometer compensation value for y-axis. 9 bit signed, resolution is 0.98 mg/LSB. Range is [-0.25 g .. 0.25 g]. The resolution of the compensation value is independent of the range setting. To disable the offset compensation, a value of 0x0 has to be written to this field. The compensation offset values are not persistent and must be written each time after power-up or reset of the device.

Use this link to go back to the overview table: ACC\_OFFSET\_2.

## Register (0x73) ACC\_OFFSET\_3

Description: Offset compensation value (y-axis) MSB

| Bit            | 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|----------------|----------|---|---|---|---|---|---|-----|
| Read/Write     | R        | R | R | R | R | R | R | R/W |
| Reset<br>Value | 0        | 0 | 0 | 0 | 0 | 0 | 0 | 0   |
| Content        | reserved |   |   |   |   |   |   |     |

■ reserved: write 0x0.

ACC\_OFFSET\_3.acc\_doff\_y\_8: (bit offset: 0, bit width: 1, access: read-write) Highest bit of the acc\_doff\_y field. See
details at description of previous register field acc\_doff\_y\_7\_0.

Use this link to go back to the overview table: ACC\_OFFSET\_3.

## Register (0x74) ACC\_OFFSET\_4

Description: Offset compensation value (z-axis) LSB

| Bit            | 7              | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |
|----------------|----------------|-----|-----|-----|-----|-----|-----|-----|--|
| Read/Write     | R/W            | R/W | R/W | R/W | R/W | R/W | R/W | R/W |  |
| Reset<br>Value | 0              | 0   | 0   | 0   | 0   | 0   | 0   | 0   |  |
| Content        | acc_doff_z_7_0 |     |     |     |     |     |     |     |  |

■ ACC\_OFFSET\_4.acc\_doff\_z\_7\_0: (bit offset: 0, bit width: 8, access: read-write) Accelerometer compensation value for z-axis. 9 bit signed, resolution is 0.98 mg/LSB. Range is [-0.25 g .. 0.25 g]. The resolution of the compensation value is independent of the range setting. To disable the offset compensation, a value of 0x0 has to be written to this field. The compensation offset values are not persistent and must be written each time after power-up or reset of the device.

Use this link to go back to the overview table: ACC\_OFFSET\_4.

## Register (0x75) ACC\_OFFSET\_5

Description: Offset compensation value (z-axis) MSB

| Bit            | 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|----------------|----------|---|---|---|---|---|---|-----|
| Read/Write     | R        | R | R | R | R | R | R | R/W |
| Reset<br>Value | 0        | 0 | 0 | 0 | 0 | 0 | 0 | 0   |
| Content        | reserved |   |   |   |   |   |   |     |

write 0x0. reserved:

■ ACC\_OFFSET\_5.acc\_doff\_z\_8: (bit offset: 0, bit width: 1, access: read-write) Highest bit of the acc\_doff\_z field. See details at description of previous register field acc\_doff\_z\_7\_0.

Use this link to go back to the overview table: ACC\_OFFSET\_5.

## Register (0x76) ACC\_SELF\_TEST

**Description:** Select NORMAL/SELF\_TEST mode and test data. If you write to this register, the ACC data path is reset.

| Bit            | 7 | 6                       | 5 | 4 | 3 | 2 | 1   | 0   |  |  |
|----------------|---|-------------------------|---|---|---|---|-----|-----|--|--|
| Read/Write     | R | R                       | R | R | R | R | R/W | R/W |  |  |
| Reset<br>Value | 0 | 0                       | 0 | 0 | 0 | 0 | 0   | 0   |  |  |
| Content        |   | reserved self_t self_te |   |   |   |   |     |     |  |  |

- reserved: write 0x0.
- ACC\_SELF\_TEST.self\_test: (bit offset: 0, bit width: 1, access: read-write) Enable flag for the self test mode. Following values can be set to or read from the field self\_test:

| Value     | Description                   |
|-----------|-------------------------------|
| 0b0 (0x0) | normal operation mode         |
| 0b1 (0x1) | built-in test excitation mode |

• ACC\_SELF\_TEST.self\_test\_sign: (bit offset: 1, bit width: 1, access: read-write) Select sign of self test excitation. Following values can be set to or read from the field self\_test\_sign:

| Value     | Description |
|-----------|-------------|
| 0b0 (0x0) | negative    |
| 0b1 (0x1) | positive    |

Use this link to go back to the overview table: ACC\_SELF\_TEST.

## Register (0x7E) CMD

**Description:** Command Register

| Bit        | 7 | 6   | 5 | 4 | 3 | 2 | 1 | 0 |  |
|------------|---|-----|---|---|---|---|---|---|--|
| Read/Write | W | W   | W | W | W | W | W | W |  |
| Reset      | 0 | 0   | 0 | 0 | 0 | 0 | 0 | 0 |  |
| Value      | U | U   | U | U | U | U | U | U |  |
| Content    |   | cmd |   |   |   |   |   |   |  |

■ CMD.cmd: (bit offset: 0, bit width: 8, access: write-only) Available commands (Note: Register will always read as 0x00):.

Following values can be set to the field cmd:

| Value | Description                                                                                                                                                   |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x0   | reserved. No command.                                                                                                                                         |
| 0xB6  | Triggers a reset, all user configuration settings are overwritten with their default state. If this register is set using I2C, an ACK will NOT be transmitted |
|       | to the host                                                                                                                                                   |

Use this link to go back to the overview table: CMD.

#### 6.2 Extended Register Map Description

The extended configuration and input/output of the feature engine has to be done through the feature engine data interface. The data can be read from or written through FEATURE\_DATA\_TX.feature\_data to an address in the extended register map configured in FEATURE\_DATA\_ADDR.feature\_data\_addr by a data exchange transaction. For more details on how to access the extended register map, please refer to the example no3 in the quick start guide section chapter 3.

# 6.2.1 Extended Register Map Overview

The Table 38 provides an overview of the extended register map of the device.

Table 38: Extended register map overview

|      | Legend               |             |       | Read                                   | -only        |          |          | Read                       | /Write   |          |        | Write      | e-only        |             |        | Rese             | erved      |          |
|------|----------------------|-------------|-------|----------------------------------------|--------------|----------|----------|----------------------------|----------|----------|--------|------------|---------------|-------------|--------|------------------|------------|----------|
| Addr | Name                 | Reset value | bit15 | bit14                                  | bit13        | bit12    | bit11    | bit10                      | bit9     | bit8     | bit7   | bit6       | bit5          | bit4        | bit3   | bit2             | bit1       | bit0     |
|      | -                    | -           |       |                                        |              |          |          |                            |          | rese     | erved  |            |               |             |        |                  |            |          |
| 0x02 | FEAT_CONF_ERR        | 0x0000      |       |                                        |              |          | reserved |                            |          |          |        | self_w     | vad_co        | tap_co      | acc_fo | gen_in           | gen_in     | gen_in   |
| 0x03 | GENERAL_SETTINGS_0   | 0x0000      |       |                                        |              | reserved |          |                            |          | vad_     | _ac    | feat_z     | feat_y        | feat_x      | 1      | feat_axis_e      | (          | reserved |
| 0x04 | GENERIC_INTERRUPT1_1 | 0xE00C      | a     | axis_sel                               |              | comb_sel |          |                            |          |          |        | slope      | _thres        |             |        |                  |            |          |
| 0x05 | GENERIC_INTERRUPT1_2 | 0x0C04      | re    | eserved                                |              | acc_r    | ef_up    | criteri                    |          |          |        |            | hyste         | eresis      |        |                  |            |          |
| 0x06 | GENERIC_INTERRUPT1_3 | 0x600A      | w     | /ait_time                              |              |          |          |                            |          |          |        | duration   |               |             |        |                  |            |          |
| 0x07 | GENERIC_INTERRUPT1_4 | 0x0040      | re    | eserved                                |              |          |          |                            |          |          |        | quiet_time |               |             |        |                  |            |          |
| 0x08 | GENERIC_INTERRUPT1_5 | 0x0000      |       |                                        |              |          |          |                            |          | ref_a    | acc_x  |            |               |             |        |                  |            |          |
| 0x09 | GENERIC_INTERRUPT1_6 | 0x0000      |       |                                        |              |          |          |                            |          | ref_a    | acc_y  |            |               |             |        |                  |            |          |
| 0x0A | GENERIC_INTERRUPT1_7 | 0x0800      |       |                                        |              |          |          |                            |          | ref_a    | acc_z  |            |               |             |        |                  |            |          |
| 0x0B | GENERIC_INTERRUPT2_1 | 0xF008      | a     | axis_sel comb_sel slope_thres          |              |          |          |                            |          |          |        |            |               |             |        |                  |            |          |
| 0x0C | GENERIC_INTERRUPT2_2 | 0x0801      | re    | reserved acc_ref_up criteri hysteresis |              |          |          |                            |          |          |        |            |               |             |        |                  |            |          |
| 0x0D | GENERIC_INTERRUPT2_3 | 0x600A      | w     | wait_time duration                     |              |          |          |                            |          |          |        |            |               |             |        |                  |            |          |
| 0x0E | GENERIC_INTERRUPT2_4 | 0x0040      | re    | reserved quiet_time                    |              |          |          |                            |          |          |        |            |               |             |        |                  |            |          |
| 0x0F | GENERIC_INTERRUPT2_5 | 0x0000      |       |                                        |              |          |          |                            |          | ref_a    | acc_x  |            |               |             |        |                  |            |          |
| 0x10 | GENERIC_INTERRUPT2_6 | 0x0000      |       |                                        |              |          |          |                            |          | ref_a    | acc_y  |            |               |             |        |                  |            |          |
| 0x11 | GENERIC_INTERRUPT2_7 | 0x0800      |       |                                        |              |          |          |                            |          | ref_a    | acc_z  |            |               |             |        |                  |            |          |
| 0x12 | GENERIC_INTERRUPT3_1 | 0xF082      | а     | axis_sel                               |              | comb_sel |          |                            |          |          |        | slope      | _thres        |             |        |                  |            |          |
| 0x13 | GENERIC_INTERRUPT3_2 | 0x1008      | re    | eserved                                |              | acc_r    | ef_up    | criteri                    |          |          |        |            | hyste         | eresis      |        |                  |            |          |
| 0x14 | GENERIC_INTERRUPT3_3 | 0x4003      | w     | /ait_time                              |              |          |          |                            |          |          |        | duration   |               |             |        |                  |            |          |
| 0x15 | GENERIC_INTERRUPT3_4 | 0x0040      | re    | eserved                                |              |          |          |                            |          |          |        | quiet_time |               |             |        |                  |            |          |
| 0x16 | GENERIC_INTERRUPT3_5 | 0x0000      |       |                                        |              |          |          |                            |          | ref_a    | acc_x  |            |               |             |        |                  |            |          |
| 0x17 | GENERIC_INTERRUPT3_6 | 0x0000      |       |                                        |              |          |          |                            |          | ref_a    | acc_y  |            |               |             |        |                  |            |          |
| 0x18 | GENERIC_INTERRUPT3_7 | 0x0000      |       |                                        |              |          |          |                            |          | ref_a    | acc_z  |            |               |             |        |                  |            |          |
| 0x19 | TAP_DETECTOR_1       | 0x0776      |       |                                        | reserved     |          |          | t_tap_en                   | d_tap_en | s_tap_en | me     | ode        | max           | x_peaks_for | _tap   | wait_f           | axis       | s_sel    |
| 0x1A | TAP_DETECTOR_2       | 0x66EE      |       | max_gesture_dur tap_peak_thres         |              |          |          |                            |          |          |        |            |               |             |        |                  |            |          |
| 0x1B | TAP_DETECTOR_3       | 0x6864      | quit  | te_time_a                              | fter_gesture | е        | mi       | min_quite_dur_between_taps |          |          |        | tap_shock_ | _settling_dur |             | n      | nax_dur_be       | tween_peak | is       |
| 0x1C | VAD_CTRL             | 0x011F      |       |                                        |              |          |          |                            | reserved |          |        |            |               |             |        | en_vad_z         | en_vad_y   | en_vad_x |
|      | -                    | -           |       |                                        |              |          |          |                            |          | rese     | erved  |            |               |             |        |                  |            |          |
| 0x24 | ACC_CONF_LOW_POWER   | 0x0025      |       |                                        |              | rese     | rved     |                            |          |          | acc_pe |            | acc_bwp       |             |        | acc <sub>.</sub> | _odr       |          |
| 0x25 | FOC_0                | 0x0000      |       |                                        |              | reserved |          |                            |          |          |        |            |               | foc_of      |        |                  |            |          |

Table 38: Extended register map overview (continued)

|      | Legend | gend Read-only |       | Read/Write                         |          |          |          | Write-only |          |      | Reserved |             |      |      |                  |      |      |        |
|------|--------|----------------|-------|------------------------------------|----------|----------|----------|------------|----------|------|----------|-------------|------|------|------------------|------|------|--------|
| Addr | Name   | Reset value    | bit15 | it15 bit14 bit13 bit12 bit11 bit10 |          |          | bit10    | bit9       | bit8     | bit7 | bit6     | bit5        | bit4 | bit3 | bit2             | bit1 | bit0 |        |
| 0x26 | FOC_1  | 0x0000         |       |                                    | <u> </u> | reserved |          | <u>'</u>   | <u>'</u> |      | foc_of   |             |      |      |                  |      |      |        |
| 0x27 | FOC_2  | 0x0000         |       | reserved                           |          |          |          |            | foc_of   |      |          |             |      |      |                  |      |      |        |
| 0x28 | FOC_3  | 0x0000         |       |                                    |          |          | reserved |            |          |      |          | foc_axis_1g |      |      | foc_filter_coeff |      |      | foc_ap |

#### 6.2.2 Extended Register Map Details

#### Register (0x02) FEAT\_CONF\_ERR

**Description:** Bits reflects the error status of accel config for features

| Bit            | 15 | 14       | 13 | 12 | 11 | 10 | 9 | 8 |  |
|----------------|----|----------|----|----|----|----|---|---|--|
| Read/Write     | R  | R        | R  | R  | R  | R  | R | R |  |
| Reset<br>Value | 0  | 0        | 0  | 0  | 0  | 0  | 0 | 0 |  |
| Content        |    | reserved |    |    |    |    |   |   |  |

| Bit            | 7        | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------------|----------|--------|--------|--------|--------|--------|--------|--------|
| Read/Write     | R        | R/W    |
| Reset<br>Value | 0        | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
| Content        | reserved | self_w | vad_co | tap_co | acc_fo | gen_in | gen_in | gen_in |

- reserved: write 0x0.
- FEAT\_CONF\_ERR.gen\_int1\_conf\_err: (bit offset: 0, bit width: 1, access: read-write) Internal filter cannot produce enough samples for generic interrupt 1 feature, or this feature is enabled in parallel to VAD feature. Following values can be set to or read from the field gen\_int1\_conf\_err:

| Value     | Description |
|-----------|-------------|
| 0b0 (0x0) | no error    |
| 0b1 (0x1) | error       |

• FEAT\_CONF\_ERR.gen\_int2\_conf\_err: (bit offset: 1, bit width: 1, access: read-write) Internal filter cannot produce enough samples for generic interrupt 2 feature, or this feature is enabled in parallel to VAD feature. Following values can be set to or read from the field gen\_int2\_conf\_err:

| Value     | Description |
|-----------|-------------|
| 0b0 (0x0) | no error    |
| 0b1 (0x1) | error       |

• FEAT\_CONF\_ERR.gen\_int3\_conf\_err: (bit offset: 2, bit width: 1, access: read-write) Internal filter cannot produce enough samples for generic interrupt 3 feature, or this feature is enabled in parallel to VAD feature.

Following values can be set to or read from the field gen\_int3\_conf\_err:

| Value     | Description |
|-----------|-------------|
| 0b0 (0x0) | no error    |
| 0b1 (0x1) | error       |

■ FEAT\_CONF\_ERR.acc\_foc\_conf\_err: (bit offset: 3, bit width: 1, access: read-write) Internal filter cannot produce enough samples for accelerometer fast-offset compensation feature.

Following values can be set to or read from the field acc\_foc\_conf\_err:

| Value Description |          |  |  |
|-------------------|----------|--|--|
| 0b0 (0x0)         | no error |  |  |
| 0b1 (0x1)         | error    |  |  |

• FEAT\_CONF\_ERR.tap\_conf\_err: (bit offset: 4, bit width: 1, access: read-write) Internal filter cannot produce enough samples for tap detection feature, or this feature is enabled in parallel to VAD feature.

Following values can be set to or read from the field tap\_conf\_err:

| Value     | Description |  |  |  |
|-----------|-------------|--|--|--|
| 0b0 (0x0) | no error    |  |  |  |
| 0b1 (0x1) | error       |  |  |  |

• FEAT\_CONF\_ERR.vad\_conf\_err: (bit offset: 5, bit width: 1, access: read-write) VAD feature is enabled in parallel to generic interrupt or tap feature.

Following values can be set to or read from the field vad\_conf\_err:

| Value     | Description |
|-----------|-------------|
| 0b0 (0x0) | no error    |
| 0b1 (0x1) | error       |

• FEAT\_CONF\_ERR.self\_wake\_up\_err: (bit offset: 6, bit width: 1, access: read-write) Self wake-up configuration is invalid.

Following values can be set to or read from the field self\_wake\_up\_err:

| Value     | Description |
|-----------|-------------|
| 0b0 (0x0) | no error    |
| 0b1 (0x1) | error       |

Use this link to go back to the overview table: FEAT\_CONF\_ERR.

## Register (0x03) GENERAL\_SETTINGS\_0

**Description:** Configuration parameters common across all features

| Bit        | 15       | 14 | 13 | 12 | 11 | 10 | 9      | 8   |
|------------|----------|----|----|----|----|----|--------|-----|
| Read/Write | R        | R  | R  | R  | R  | R  | R      | R/W |
| Reset      | 0        | 0  | 0  | 0  | 0  | 0  | 0      | 0   |
| Value      | U        | U  | 0  | U  | U  | U  | U      | U   |
| Content    | reserved |    |    |    |    |    | vad_ac |     |

| Bit        | 7      | 6      | 5      | 4      | 3            | 2   | 1   | 0        |
|------------|--------|--------|--------|--------|--------------|-----|-----|----------|
| Read/Write | R/W    | R/W    | R/W    | R/W    | R/W          | R/W | R/W | R/W      |
| Reset      | 0      | 0      | 0      | 0      | 0            | 0   | 0   | 0        |
| Value      | U      | U      | U      | U      | U            | U   | U   | 0        |
| Content    | vad_ac | feat_z | feat_y | feat_x | feat_axis_ex |     |     | reserved |

- reserved: write 0x0.
- GENERAL\_SETTINGS\_0.reserved: (bit offset: 0, bit width: 1, access: read-write) Reserved.
- GENERAL\_SETTINGS\_0.feat\_axis\_ex: (bit offset: 1, bit width: 3, access: read-write) Axes exchange scheme that is applied in host software.

Following values can be set to or read from the field feat\_axis\_ex:

| Value       | Description                                                   |
|-------------|---------------------------------------------------------------|
| 0b000 (0x0) | X(feat)=x(datapath),Y(feat)=y(datapath),Z(feat)=z(datapath)   |
| 0b001 (0x1) | X(feat)=y(datapath), Y(feat)=x(datapath), Z(feat)=z(datapath) |
| 0b010 (0x2) | X(feat)=x(datapath),Y(feat)=z(datapath),Z(feat)=y(datapath)   |
| 0b011 (0x3) | X(feat)=z(datapath),Y(feat)=x(datapath),Z(feat)=y(datapath)   |
| 0b100 (0x4) | X(feat)=y(datapath),Y(feat)=z(datapath),Z(feat)=x(datapath)   |
| 0b101 (0x5) | X(feat)=z(datapath),Y(feat)=y(datapath),Z(feat)=x(datapath)   |
| 0b110 (0x6) | Same as default_0                                             |
| 0b111 (0x7) | Same as default_0                                             |

■ GENERAL\_SETTINGS\_0.feat\_x\_inv: (bit offset: 4, bit width: 1, access: read-write) Invert polarity of X-axis data after axis exchange.

Following values can be set to or read from the field feat\_x\_inv:

| Value     | Description               |
|-----------|---------------------------|
| 0b0 (0x0) | X(feat) remains unchanged |
| 0b1 (0x1) | X(feat) = -X(feat)        |

• GENERAL\_SETTINGS\_0.feat\_y\_inv: (bit offset: 5, bit width: 1, access: read-write) Invert polarity of Y-axis data after axis exchange.

Following values can be set to or read from the field feat\_y\_inv:

| Value     | Description               |
|-----------|---------------------------|
| 0b0 (0x0) | Y(feat) remains unchanged |
| 0b1 (0x1) | Y(feat) = -Y(feat)        |

■ GENERAL\_SETTINGS\_0.feat\_z\_inv: (bit offset: 6, bit width: 1, access: read-write) Invert polarity of Z-axis data after axis exchange.

Following values can be set to or read from the field feat\_z\_inv:

| Value Description |                           |  |  |
|-------------------|---------------------------|--|--|
| 0b0 (0x0)         | Z(feat) remains unchanged |  |  |
| 0b1 (0x1)         | Z(feat) = -Z(feat)        |  |  |

■ GENERAL\_SETTINGS\_0.vad\_acc\_data\_src: (bit offset: 7, bit width: 2, access: read-write) This setting should only be set, if VAD feature is used. It should be set before enabling VAD. This setting defines, what will be the source for the ACC\_DATA\_0-5 registers during VAD. Since VAD feature reconfigures the signal path, for ACC\_DATA registers the ACC CONF is not valid anymore.

Following values can be set to or read from the field vad\_acc\_data\_src:

| Value      | Description                                                                                   |
|------------|-----------------------------------------------------------------------------------------------|
| 0b00 (0x0) | ACC Data with 1.6kHz ODR and filtered for VAD. (Not recommended)                              |
| 0b01 (0x1) | ACC Data with 1.6kHz ODR and filtered for VAD. (Not recommended). Same as value '0'=hipass_1. |
| 0b10 (0x2) | ACC Data with 50Hz. Data is averaged for downsampling.                                        |
| 0b11 (0x3) | ACC Data with 200Hz. Data is averaged for downsampling.                                       |

Use this link to go back to the overview table: GENERAL\_SETTINGS\_0.

## Register (0x04) **GENERIC\_INTERRUPT1\_1**

Description: Configuration of acceleration slope threshold, axis enabling and evaluation condition between axis

| Bit            | 15       | 14  | 13  | 12       | 11          | 10  | 9   | 8   |
|----------------|----------|-----|-----|----------|-------------|-----|-----|-----|
| Read/Write     | R/W      | R/W | R/W | R/W      | R/W         | R/W | R/W | R/W |
| Reset<br>Value | 1        | 1   | 1   | 0        | 0           | 0   | 0   | 0   |
| Content        | axis_sel |     |     | comb_sel | slope_thres |     |     |     |

| Bit            | 7           | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------------|-------------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write     | R/W         | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0           | 0   | 0   | 0   | 1   | 1   | 0   | 0   |
| Content        | slope_thres |     |     |     |     |     |     |     |

GENERIC\_INTERRUPT1\_1.slope\_thres: (bit offset: 0, bit width: 12, access: read-write) Minimum/maximum slope of acceleration signal for interrupt detection based on selected motion criterion. The field slope\_thres has the following properties:

| Property      | Value                    |  |  |
|---------------|--------------------------|--|--|
| Bitwidth      | 12                       |  |  |
| Sign          | unsigned                 |  |  |
| Unit          | g                        |  |  |
| Scaling       | 512.0                    |  |  |
| Default value | 12/512                   |  |  |
| Range         | Min=0.0, Max=7.998046875 |  |  |

■ GENERIC\_INTERRUPT1\_1.comb\_sel: (bit offset: 12, bit width: 1, access: read-write) Logical evaluation condition between enabled axis status.

Following values can be set to or read from the field comb\_sel:

| Value     | Description                                           |  |  |
|-----------|-------------------------------------------------------|--|--|
| 0b0 (0x0) | One of the enabled axis should meet the set condition |  |  |
| 0b1 (0x1) | All of the enabled axis should meet the set condition |  |  |

The field comb\_sel has the following properties:

| Property      | Value        |
|---------------|--------------|
| Bitwidth      | 1            |
| Default value | 0            |
| Range         | Min=0, Max=1 |

■ GENERIC\_INTERRUPT1\_1.axis\_sel: (bit offset: 13, bit width: 3, access: read-write) Enabling of axis for generic

interrupt detection. The field axis\_sel has the following properties:

| Property      | Value        |
|---------------|--------------|
| Bitwidth      | 3            |
| Default value | 7            |
| Range         | Min=0, Max=7 |

Use this link to go back to the overview table: GENERIC\_INTERRUPT1\_1.

## Register (0x05) **GENERIC\_INTERRUPT1\_2**

Description: Configuration for hysteresis of acceleration slope, motion criterion selection and reference update mode selection.

| Bit            | 15       | 14 | 13    | 12    | 11      | 10    | 9      | 8   |
|----------------|----------|----|-------|-------|---------|-------|--------|-----|
| Read/Write     | R        | R  | R     | R/W   | R/W     | R/W   | R/W    | R/W |
| Reset<br>Value | 0        | 0  | 0     | 0     | 1       | 1     | 0      | 0   |
| Content        | reserved |    | acc_r | ef_up | criteri | hyste | eresis |     |

| Bit            | 7          | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------------|------------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write     | R/W        | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0          | 0   | 0   | 0   | 0   | 1   | 0   | 0   |
| Content        | hysteresis |     |     |     |     |     |     |     |

- write 0x0. reserved:
- GENERIC\_INTERRUPT1\_2.hysteresis: (bit offset: 0, bit width: 10, access: read-write) Hysteresis for the slope of the acceleration signal. The field hysteresis has the following properties:

| Property      | Value                    |  |  |
|---------------|--------------------------|--|--|
| Bitwidth      | 10                       |  |  |
| Sign          | unsigned                 |  |  |
| Unit          | g                        |  |  |
| Scaling       | 512.0                    |  |  |
| Default value | 4/512                    |  |  |
| Range         | Min=0.0, Max=1.998046875 |  |  |

• GENERIC\_INTERRUPT1\_2.criterion\_sel: (bit offset: 10, bit width: 1, access: read-write) Selection of motion criterion Following values can be set to or read from the field criterion\_sel:

| Value     | Description                                               |
|-----------|-----------------------------------------------------------|
| 0b0 (0x0) | Evaluate the condition for stationary state of the device |
| 0b1 (0x1) | Evaluate the condition for motion state of the device     |

The field criterion\_sel has the following properties:

| Property      | Value        |
|---------------|--------------|
| Bitwidth      | 1            |
| Default value | 1            |
| Range         | Min=0, Max=1 |

■ GENERIC\_INTERRUPT1\_2.acc\_ref\_up: (bit offset: 11, bit width: 2, access: read-write) Mode of the acceleration reference update. .

Following values can be set to or read from the field acc\_ref\_up:

| Value      | Description                      |
|------------|----------------------------------|
| 0b00 (0x0) | On detection of the event        |
| 0b01 (0x1) | On update of acceleration signal |
| 0b10 (0x2) | Manually update by host          |

The field acc\_ref\_up has the following properties:

| Property      | Value        |
|---------------|--------------|
| Bitwidth      | 2            |
| Default value | 1            |
| Range         | Min=0, Max=2 |

Use this link to go back to the overview table: GENERIC\_INTERRUPT1\_2.

#### Register (0x06) GENERIC\_INTERRUPT1\_3

**Description:** Configuration of timing related parameters for generic interrupt detection

| Bit            | 15        | 14  | 13  | 12       | 11  | 10  | 9   | 8   |
|----------------|-----------|-----|-----|----------|-----|-----|-----|-----|
| Read/Write     | R/W       | R/W | R/W | R/W      | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0         | 1   | 1   | 0        | 0   | 0   | 0   | 0   |
| Content        | wait_time |     |     | duration |     |     |     |     |

| Bit        | 7        | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------------|----------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write | R/W      | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset      | 0        | 0   | 0   | 0   | 1   | 0   | 1   | 0   |
| Value      | · ·      | •   | •   |     | _   |     | -   |     |
| Content    | duration |     |     |     |     |     |     |     |

• GENERIC\_INTERRUPT1\_3.duration: (bit offset: 0, bit width: 13, access: read-write) Minimum duration for which the selected criterion is true for interrupt detection. . The field duration has the following properties:

| Property      | Value               |  |  |  |
|---------------|---------------------|--|--|--|
| Bitwidth      | 13                  |  |  |  |
| Sign          | unsigned            |  |  |  |
| Unit          | S                   |  |  |  |
| Scaling       | 50.0                |  |  |  |
| Default value | 0.2                 |  |  |  |
| Range         | Min=0.0, Max=163.82 |  |  |  |

■ GENERIC\_INTERRUPT1\_3.wait\_time: (bit offset: 13, bit width: 3, access: read-write) Wait time for clearing the event after condition evaluates false. The field wait\_time has the following properties:

| Property      | Value             |
|---------------|-------------------|
| Bitwidth      | 3                 |
| Sign          | unsigned          |
| Unit          | S                 |
| Scaling       | 50.0              |
| Default value | 0.1               |
| Range         | Min=0.0, Max=0.14 |

Use this link to go back to the overview table: GENERIC\_INTERRUPT1\_3.

#### Register (0x07) GENERIC\_INTERRUPT1\_4

**Description:** Configuration for quiet time between interrupts

| Bit            | 15       | 14 | 13         | 12  | 11  | 10  | 9   | 8   |
|----------------|----------|----|------------|-----|-----|-----|-----|-----|
| Read/Write     | R        | R  | R          | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0        | 0  | 0          | 0   | 0   | 0   | 0   | 0   |
| Content        | reserved |    | quiet_time |     |     |     |     |     |

| Bit              | 7          | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------------------|------------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write       | R/W        | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset            | 0          | 1   | 0   | 0   | 0   | 0   | 0   | 0   |
| Value<br>Content | quiet_time |     |     |     |     |     |     |     |

- reserved: write 0x0.
- GENERIC\_INTERRUPT1\_4.quiet\_time: (bit offset: 0, bit width: 13, access: read-write) Quiet time after an interrupt where no additional interrupts are detected. The field quiet\_time has the following properties:

| Property      | Value               |  |  |  |
|---------------|---------------------|--|--|--|
| Bitwidth      | 13                  |  |  |  |
| Sign          | unsigned            |  |  |  |
| Unit          | S                   |  |  |  |
| Scaling       | 50.0                |  |  |  |
| Default value | 1.28                |  |  |  |
| Range         | Min=0.0, Max=163.82 |  |  |  |

Use this link to go back to the overview table: GENERIC\_INTERRUPT1\_4.

## Register (0x08) **GENERIC\_INTERRUPT1\_5**

**Description:** Manually set acceleration signal reference for x-axis

| Bit            | 15        | 14  | 13  | 12  | 11  | 10  | 9   | 8   |
|----------------|-----------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write     | R/W       | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0         | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Content        | ref_acc_x |     |     |     |     |     |     |     |

| Bit            | 7         | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------------|-----------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write     | R/W       | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0         | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Content        | ref_acc_x |     |     |     |     |     |     |     |

• GENERIC\_INTERRUPT1\_5.ref\_acc\_x: (bit offset: 0, bit width: 16, access: read-write) Reference acceleration signal for x-axis . The field  $ref\_acc\_x$  has the following properties:

| Property      | Value                         |  |  |  |  |
|---------------|-------------------------------|--|--|--|--|
| Bitwidth      | 16                            |  |  |  |  |
| Sign          | signed                        |  |  |  |  |
| Unit          | g                             |  |  |  |  |
| Scaling       | 2048.0                        |  |  |  |  |
| Default value | 0.0                           |  |  |  |  |
| Range         | Min=-16.0, Max=15.99951171875 |  |  |  |  |

Use this link to go back to the overview table: GENERIC\_INTERRUPT1\_5.

#### Register (0x09) GENERIC\_INTERRUPT1\_6

**Description:** Manually set acceleration signal reference for y-axis

| Bit            | 15        | 14  | 13  | 12  | 11  | 10  | 9   | 8   |
|----------------|-----------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write     | R/W       | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0         | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Content        | ref_acc_y |     |     |     |     |     |     |     |

| Bit        | 7         | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------------|-----------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write | R/W       | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset      | 0         | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Value      | 0         | U   | 0   | U   | U   | 0   | 0   | U   |
| Content    | ref_acc_y |     |     |     |     |     |     |     |

■ GENERIC\_INTERRUPT1\_6.ref\_acc\_y: (bit offset: 0, bit width: 16, access: read-write) Reference acceleration signal for y-axis . The field ref\_acc\_y has the following properties:

| Property      | Value                         |  |  |
|---------------|-------------------------------|--|--|
| Bitwidth      | 16                            |  |  |
| Sign          | signed                        |  |  |
| Unit          | g                             |  |  |
| Scaling       | 2048.0                        |  |  |
| Default value | 0.0                           |  |  |
| Range         | Min=-16.0, Max=15.99951171875 |  |  |

Use this link to go back to the overview table: GENERIC\_INTERRUPT1\_6.

#### Register (0x0A) GENERIC\_INTERRUPT1\_7

Description: Manually set acceleration signal reference for z-axis

| Bit            | 15        | 14  | 13  | 12  | 11  | 10  | 9   | 8   |
|----------------|-----------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write     | R/W       | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0         | 0   | 0   | 0   | 1   | 0   | 0   | 0   |
| Content        | ref_acc_z |     |     |     |     |     |     |     |

| Bit            | 7         | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------------|-----------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write     | R/W       | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0         | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Content        | ref_acc_z |     |     |     |     |     |     |     |

• GENERIC\_INTERRUPT1\_7.ref\_acc\_z: (bit offset: 0, bit width: 16, access: read-write) Reference acceleration signal for z-axis . The field ref\_acc\_z has the following properties:

| Property      | Value                         |  |  |  |
|---------------|-------------------------------|--|--|--|
| Bitwidth      | 16                            |  |  |  |
| Sign          | signed                        |  |  |  |
| Unit          | g                             |  |  |  |
| Scaling       | 2048.0                        |  |  |  |
| Default value | 1.0                           |  |  |  |
| Range         | Min=-16.0, Max=15.99951171875 |  |  |  |

Use this link to go back to the overview table: GENERIC\_INTERRUPT1\_7.

#### Register (0x0B) GENERIC\_INTERRUPT2\_1

Description: Configuration of acceleration slope threshold, axis enabling and evaluation condition between axis

| Bit            | 15       | 14  | 13       | 12          | 11  | 10  | 9   | 8   |
|----------------|----------|-----|----------|-------------|-----|-----|-----|-----|
| Read/Write     | R/W      | R/W | R/W      | R/W         | R/W | R/W | R/W | R/W |
| Reset<br>Value | 1        | 1   | 1        | 1           | 0   | 0   | 0   | 0   |
| Content        | axis_sel |     | comb_sel | slope_thres |     |     |     |     |

| Bit            | 7           | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------------|-------------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write     | R/W         | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0           | 0   | 0   | 0   | 1   | 0   | 0   | 0   |
| Content        | slope_thres |     |     |     |     |     |     |     |

GENERIC\_INTERRUPT2\_1.slope\_thres: (bit offset: 0, bit width: 12, access: read-write) Minimum/maximum slope of acceleration signal for interrupt detection based on selected motion criterion. . The field slope\_thres has the following properties:

| Property      | Value                    |  |  |
|---------------|--------------------------|--|--|
| Bitwidth      | 12                       |  |  |
| Sign          | unsigned                 |  |  |
| Unit          | g                        |  |  |
| Scaling       | 512.0                    |  |  |
| Default value | 8/512                    |  |  |
| Range         | Min=0.0, Max=7.998046875 |  |  |

■ GENERIC\_INTERRUPT2\_1.comb\_sel: (bit offset: 12, bit width: 1, access: read-write) Logical evaluation condition between enabled axis status.

Following values can be set to or read from the field comb\_sel:

| Value     | Description                                           |
|-----------|-------------------------------------------------------|
| 0b0 (0x0) | One of the enabled axis should meet the set condition |
| 0b1 (0x1) | All of the enabled axis should meet the set condition |

The field comb\_sel has the following properties:

| Property      | Value        |
|---------------|--------------|
| Bitwidth      | 1            |
| Default value | 1            |
| Range         | Min=0, Max=1 |

■ GENERIC\_INTERRUPT2\_1.axis\_sel: (bit offset: 13, bit width: 3, access: read-write) Enabling of axis for generic

interrupt detection. The field axis\_sel has the following properties:

| Property      | Value        |
|---------------|--------------|
| Bitwidth      | 3            |
| Default value | 7            |
| Range         | Min=0, Max=7 |

Use this link to go back to the overview table: GENERIC\_INTERRUPT2\_1.

#### Register (0x0C) **GENERIC\_INTERRUPT2\_2**

Description: Configuration for hysteresis of acceleration slope, motion criterion selection and reference update mode selection.

| Bit            | 15       | 14 | 13    | 12    | 11      | 10    | 9      | 8   |
|----------------|----------|----|-------|-------|---------|-------|--------|-----|
| Read/Write     | R        | R  | R     | R/W   | R/W     | R/W   | R/W    | R/W |
| Reset<br>Value | 0        | 0  | 0     | 0     | 1       | 0     | 0      | 0   |
| Content        | reserved |    | acc_r | ef_up | criteri | hyste | eresis |     |

| Bit            | 7          | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------------|------------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write     | R/W        | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0          | 0   | 0   | 0   | 0   | 0   | 0   | 1   |
| Content        | hysteresis |     |     |     |     |     |     |     |

- write 0x0. reserved:
- GENERIC\_INTERRUPT2\_2.hysteresis: (bit offset: 0, bit width: 10, access: read-write) Hysteresis for the slope of the acceleration signal. The field hysteresis has the following properties:

| Property      | Value                    |
|---------------|--------------------------|
| Bitwidth      | 10                       |
| Sign          | unsigned                 |
| Unit          | g                        |
| Scaling       | 512.0                    |
| Default value | 1/512                    |
| Range         | Min=0.0, Max=1.998046875 |

• GENERIC\_INTERRUPT2\_2.criterion\_sel: (bit offset: 10, bit width: 1, access: read-write) Selection of motion criterion Following values can be set to or read from the field criterion\_sel:

| Value     | Description                                               |
|-----------|-----------------------------------------------------------|
| 0b0 (0x0) | Evaluate the condition for stationary state of the device |
| 0b1 (0x1) | Evaluate the condition for motion state of the device     |

The field criterion\_sel has the following properties:

| Property      | Value        |
|---------------|--------------|
| Bitwidth      | 1            |
| Default value | 0            |
| Range         | Min=0, Max=1 |

■ GENERIC\_INTERRUPT2\_2.acc\_ref\_up: (bit offset: 11, bit width: 2, access: read-write) Mode of the acceleration reference update. .

Following values can be set to or read from the field acc\_ref\_up:

| Value      | Description                      |
|------------|----------------------------------|
| 0b00 (0x0) | On detection of the event        |
| 0b01 (0x1) | On update of acceleration signal |
| 0b10 (0x2) | Manually update by host          |

The field acc\_ref\_up has the following properties:

| Property      | Value        |
|---------------|--------------|
| Bitwidth      | 2            |
| Default value | 1            |
| Range         | Min=0, Max=2 |

Use this link to go back to the overview table: GENERIC\_INTERRUPT2\_2.

#### Register (0x0D) GENERIC\_INTERRUPT2\_3

**Description:** Configuration of timing related parameters for generic interrupt detection

| Bit            | 15        | 14  | 13  | 12       | 11  | 10  | 9   | 8   |
|----------------|-----------|-----|-----|----------|-----|-----|-----|-----|
| Read/Write     | R/W       | R/W | R/W | R/W      | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0         | 1   | 1   | 0        | 0   | 0   | 0   | 0   |
| Content        | wait_time |     |     | duration |     |     |     |     |

| Bit        | 7        | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------------|----------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write | R/W      | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset      | 0        | 0   | 0   | 0   | 1   | 0   | 1   | 0   |
| Value      | · ·      | •   | •   |     | _   |     | -   |     |
| Content    | duration |     |     |     |     |     |     |     |

• GENERIC\_INTERRUPT2\_3.duration: (bit offset: 0, bit width: 13, access: read-write) Minimum duration for which the selected criterion is true for interrupt detection. . The field duration has the following properties:

| Property      | Value               |
|---------------|---------------------|
| Bitwidth      | 13                  |
| Sign          | unsigned            |
| Unit          | S                   |
| Scaling       | 50.0                |
| Default value | 0.2                 |
| Range         | Min=0.0, Max=163.82 |

■ GENERIC\_INTERRUPT2\_3.wait\_time: (bit offset: 13, bit width: 3, access: read-write) Wait time for clearing the event after condition evaluates false. The field wait\_time has the following properties:

| Property      | Value             |  |  |  |
|---------------|-------------------|--|--|--|
| Bitwidth      | 3                 |  |  |  |
| Sign          | unsigned          |  |  |  |
| Unit          | S                 |  |  |  |
| Scaling       | 50.0              |  |  |  |
| Default value | 0.1               |  |  |  |
| Range         | Min=0.0, Max=0.14 |  |  |  |

Use this link to go back to the overview table: GENERIC\_INTERRUPT2\_3.

#### Register (0x0E) GENERIC\_INTERRUPT2\_4

**Description:** Configuration for quiet time between interrupts

| Bit            | 15       | 14 | 13         | 12  | 11  | 10  | 9   | 8   |
|----------------|----------|----|------------|-----|-----|-----|-----|-----|
| Read/Write     | R        | R  | R          | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0        | 0  | 0          | 0   | 0   | 0   | 0   | 0   |
| Content        | reserved |    | quiet_time |     |     |     |     |     |

| Bit              | 7   | 6          | 5   | 4   | 3   | 2   | 1   | 0   |
|------------------|-----|------------|-----|-----|-----|-----|-----|-----|
| Read/Write       | R/W | R/W        | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset            | 0   | 1          | 0   | 0   | 0   | 0   | 0   | 0   |
| Value<br>Content |     | quiet_time |     |     |     |     |     |     |

- reserved: write 0x0.
- GENERIC\_INTERRUPT2\_4.quiet\_time: (bit offset: 0, bit width: 13, access: read-write) Quiet time after an interrupt where no additional interrupts are detected. The field quiet\_time has the following properties:

| Property      | Value               |
|---------------|---------------------|
| Bitwidth      | 13                  |
| Sign          | unsigned            |
| Unit          | S                   |
| Scaling       | 50.0                |
| Default value | 1.28                |
| Range         | Min=0.0, Max=163.82 |

Use this link to go back to the overview table: GENERIC\_INTERRUPT2\_4.

## Register (0x0F) **GENERIC\_INTERRUPT2\_5**

**Description:** Manually set acceleration signal reference for x-axis

| Bit            | 15  | 14        | 13  | 12  | 11  | 10  | 9   | 8   |  |
|----------------|-----|-----------|-----|-----|-----|-----|-----|-----|--|
| Read/Write     | R/W | R/W       | R/W | R/W | R/W | R/W | R/W | R/W |  |
| Reset<br>Value | 0   | 0         | 0   | 0   | 0   | 0   | 0   | 0   |  |
| Content        |     | ref_acc_x |     |     |     |     |     |     |  |

| Bit        | 7   | 6         | 5   | 4   | 3   | 2   | 1   | 0   |
|------------|-----|-----------|-----|-----|-----|-----|-----|-----|
| Read/Write | R/W | R/W       | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset      | 0   | 0         | 0   | 0   | 0   | 0   | 0   | 0   |
| Value      | 0   | U         | 0   | U   | U   | 0   | 0   | U   |
| Content    |     | ref_acc_x |     |     |     |     |     |     |

• GENERIC\_INTERRUPT2\_5.ref\_acc\_x: (bit offset: 0, bit width: 16, access: read-write) Reference acceleration signal for x-axis . The field ref\_acc\_x has the following properties:

| Property      | Value                         |
|---------------|-------------------------------|
| Bitwidth      | 16                            |
| Sign          | signed                        |
| Unit          | g                             |
| Scaling       | 2048.0                        |
| Default value | 0.0                           |
| Range         | Min=-16.0, Max=15.99951171875 |

Use this link to go back to the overview table: GENERIC\_INTERRUPT2\_5.

## Register (0x10) **GENERIC\_INTERRUPT2\_6**

**Description:** Manually set acceleration signal reference for y-axis

| Bit            | 15  | 14        | 13  | 12  | 11  | 10  | 9   | 8   |  |
|----------------|-----|-----------|-----|-----|-----|-----|-----|-----|--|
| Read/Write     | R/W | R/W       | R/W | R/W | R/W | R/W | R/W | R/W |  |
| Reset<br>Value | 0   | 0         | 0   | 0   | 0   | 0   | 0   | 0   |  |
| Content        |     | ref_acc_y |     |     |     |     |     |     |  |

| Bit            | 7   | 6         | 5   | 4   | 3   | 2   | 1   | 0   |
|----------------|-----|-----------|-----|-----|-----|-----|-----|-----|
| Read/Write     | R/W | R/W       | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0   | 0         | 0   | 0   | 0   | 0   | 0   | 0   |
| Content        |     | ref_acc_y |     |     |     |     |     |     |

■ GENERIC\_INTERRUPT2\_6.ref\_acc\_y: (bit offset: 0, bit width: 16, access: read-write) Reference acceleration signal for y-axis . The field ref\_acc\_y has the following properties:

| Property      | Value                         |
|---------------|-------------------------------|
| Bitwidth      | 16                            |
| Sign          | signed                        |
| Unit          | g                             |
| Scaling       | 2048.0                        |
| Default value | 0.0                           |
| Range         | Min=-16.0, Max=15.99951171875 |

Use this link to go back to the overview table: GENERIC\_INTERRUPT2\_6.

## Register (0x11) **GENERIC\_INTERRUPT2\_7**

**Description:** Manually set acceleration signal reference for z-axis

| Bit            | 15  | 14        | 13  | 12  | 11  | 10  | 9   | 8   |  |
|----------------|-----|-----------|-----|-----|-----|-----|-----|-----|--|
| Read/Write     | R/W | R/W       | R/W | R/W | R/W | R/W | R/W | R/W |  |
| Reset<br>Value | 0   | 0         | 0   | 0   | 1   | 0   | 0   | 0   |  |
| Content        |     | ref_acc_z |     |     |     |     |     |     |  |

| Bit            | 7   | 6         | 5   | 4   | 3   | 2   | 1   | 0   |
|----------------|-----|-----------|-----|-----|-----|-----|-----|-----|
| Read/Write     | R/W | R/W       | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0   | 0         | 0   | 0   | 0   | 0   | 0   | 0   |
| Content        |     | ref_acc_z |     |     |     |     |     |     |

■ GENERIC\_INTERRUPT2\_7.ref\_acc\_z: (bit offset: 0, bit width: 16, access: read-write) Reference acceleration signal for z-axis . The field ref\_acc\_z has the following properties:

| Property      | Value                         |
|---------------|-------------------------------|
| Bitwidth      | 16                            |
| Sign          | signed                        |
| Unit          | g                             |
| Scaling       | 2048.0                        |
| Default value | 1.0                           |
| Range         | Min=-16.0, Max=15.99951171875 |

Use this link to go back to the overview table: GENERIC\_INTERRUPT2\_7.

#### Register (0x12) GENERIC\_INTERRUPT3\_1

Description: Configuration of acceleration slope threshold, axis enabling and evaluation condition between axis

| Bit            | 15       | 14  | 13  | 12       | 11          | 10  | 9   | 8   |
|----------------|----------|-----|-----|----------|-------------|-----|-----|-----|
| Read/Write     | R/W      | R/W | R/W | R/W      | R/W         | R/W | R/W | R/W |
| Reset<br>Value | 1        | 1   | 1   | 1        | 0           | 0   | 0   | 0   |
| Content        | axis_sel |     |     | comb_sel | slope_thres |     |     |     |

| Bit        | 7           | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------------|-------------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write | R/W         | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset      | 1           | 0   | 0   | 0   | 0   | 0   | 1   | 0   |
| Value      |             | _   |     | _   | -   | -   |     | -   |
| Content    | slope_thres |     |     |     |     |     |     |     |

GENERIC\_INTERRUPT3\_1.slope\_thres: (bit offset: 0, bit width: 12, access: read-write) Minimum/maximum slope of acceleration signal for interrupt detection based on selected motion criterion. . The field slope\_thres has the following properties:

| Property      | Value                    |
|---------------|--------------------------|
| Bitwidth      | 12                       |
| Sign          | unsigned                 |
| Unit          | g                        |
| Scaling       | 512.0                    |
| Default value | 130/512                  |
| Range         | Min=0.0, Max=7.998046875 |

■ GENERIC\_INTERRUPT3\_1.comb\_sel: (bit offset: 12, bit width: 1, access: read-write) Logical evaluation condition between enabled axis status.

Following values can be set to or read from the field comb\_sel:

| Value     | Description                                           |
|-----------|-------------------------------------------------------|
| 0b0 (0x0) | One of the enabled axis should meet the set condition |
| 0b1 (0x1) | All of the enabled axis should meet the set condition |

The field comb\_sel has the following properties:

| Property      | Value        |
|---------------|--------------|
| Bitwidth      | 1            |
| Default value | 1            |
| Range         | Min=0, Max=1 |

■ GENERIC\_INTERRUPT3\_1.axis\_sel: (bit offset: 13, bit width: 3, access: read-write) Enabling of axis for generic

interrupt detection. The field axis\_sel has the following properties:

| Property      | Value        |
|---------------|--------------|
| Bitwidth      | 3            |
| Default value | 7            |
| Range         | Min=0, Max=7 |

Use this link to go back to the overview table: GENERIC\_INTERRUPT3\_1.

#### Register (0x13) **GENERIC\_INTERRUPT3\_2**

Description: Configuration for hysteresis of acceleration slope, motion criterion selection and reference update mode selection.

| Bit            | 15 | 14       | 13 | 12    | 11    | 10      | 9     | 8      |
|----------------|----|----------|----|-------|-------|---------|-------|--------|
| Read/Write     | R  | R        | R  | R/W   | R/W   | R/W     | R/W   | R/W    |
| Reset<br>Value | 0  | 0        | 0  | 1     | 0     | 0       | 0     | 0      |
| Content        |    | reserved |    | acc_r | ef_up | criteri | hyste | eresis |

| Bit            | 7          | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------------|------------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write     | R/W        | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0          | 0   | 0   | 0   | 1   | 0   | 0   | 0   |
| Content        | hysteresis |     |     |     |     |     |     |     |

- write 0x0. reserved:
- GENERIC\_INTERRUPT3\_2.hysteresis: (bit offset: 0, bit width: 10, access: read-write) Hysteresis for the slope of the acceleration signal. The field hysteresis has the following properties:

| Property      | Value                    |
|---------------|--------------------------|
| Bitwidth      | 10                       |
| Sign          | unsigned                 |
| Unit          | g                        |
| Scaling       | 512.0                    |
| Default value | 8/512                    |
| Range         | Min=0.0, Max=1.998046875 |

• GENERIC\_INTERRUPT3\_2.criterion\_sel: (bit offset: 10, bit width: 1, access: read-write) Selection of motion criterion Following values can be set to or read from the field criterion\_sel:

| Value     | Description                                               |
|-----------|-----------------------------------------------------------|
| 0b0 (0x0) | Evaluate the condition for stationary state of the device |
| 0b1 (0x1) | Evaluate the condition for motion state of the device     |

The field criterion\_sel has the following properties:

| Property      | Value        |
|---------------|--------------|
| Bitwidth      | 1            |
| Default value | 0            |
| Range         | Min=0, Max=1 |

■ GENERIC\_INTERRUPT3\_2.acc\_ref\_up: (bit offset: 11, bit width: 2, access: read-write) Mode of the acceleration reference update. .

Following values can be set to or read from the field acc\_ref\_up:

| Value      | Description                      |
|------------|----------------------------------|
| 0b00 (0x0) | On detection of the event        |
| 0b01 (0x1) | On update of acceleration signal |
| 0b10 (0x2) | Manually update by host          |

The field acc\_ref\_up has the following properties:

| Property      | Value        |
|---------------|--------------|
| Bitwidth      | 2            |
| Default value | 2            |
| Range         | Min=0, Max=2 |

Use this link to go back to the overview table: GENERIC\_INTERRUPT3\_2.

#### Register (0x14) GENERIC\_INTERRUPT3\_3

**Description:** Configuration of timing related parameters for generic interrupt detection

| Bit            | 15  | 14        | 13  | 12  | 11  | 10       | 9   | 8   |
|----------------|-----|-----------|-----|-----|-----|----------|-----|-----|
| Read/Write     | R/W | R/W       | R/W | R/W | R/W | R/W      | R/W | R/W |
| Reset<br>Value | 0   | 1         | 0   | 0   | 0   | 0        | 0   | 0   |
| Content        |     | wait_time |     |     |     | duration |     |     |

| Bit            | 7   | 6   | 5   | 4    | 3     | 2   | 1   | 0   |
|----------------|-----|-----|-----|------|-------|-----|-----|-----|
| Read/Write     | R/W | R/W | R/W | R/W  | R/W   | R/W | R/W | R/W |
| Reset<br>Value | 0   | 0   | 0   | 0    | 0     | 0   | 1   | 1   |
| Content        |     |     |     | dura | ation |     |     |     |

• GENERIC\_INTERRUPT3\_3.duration: (bit offset: 0, bit width: 13, access: read-write) Minimum duration for which the selected criterion is true for interrupt detection. . The field duration has the following properties:

| Property      | Value               |  |  |
|---------------|---------------------|--|--|
| Bitwidth      | 13                  |  |  |
| Sign          | unsigned            |  |  |
| Unit          | S                   |  |  |
| Scaling       | 50.0                |  |  |
| Default value | 0.06                |  |  |
| Range         | Min=0.0, Max=163.82 |  |  |

■ GENERIC\_INTERRUPT3\_3.wait\_time: (bit offset: 13, bit width: 3, access: read-write) Wait time for clearing the event after condition evaluates false. The field wait\_time has the following properties:

| Property      | Value             |
|---------------|-------------------|
| Bitwidth      | 3                 |
| Sign          | unsigned          |
| Unit          | S                 |
| Scaling       | 50.0              |
| Default value | 0.04              |
| Range         | Min=0.0, Max=0.14 |

Use this link to go back to the overview table: GENERIC\_INTERRUPT3\_3.

#### Register (0x15) GENERIC\_INTERRUPT3\_4

**Description:** Configuration for quiet time between interrupts

| Bit        | 15 | 14       | 13 | 12  | 11  | 10         | 9   | 8   |
|------------|----|----------|----|-----|-----|------------|-----|-----|
| Read/Write | R  | R        | R  | R/W | R/W | R/W        | R/W | R/W |
| Reset      | 0  | 0        | 0  | 0   | 0   | 0          | 0   | 0   |
| Value      | U  | U        | U  | U   | U   | U          | U   | 0   |
| Content    |    | reserved |    |     |     | quiet_time |     |     |

| Bit              | 7   | 6          | 5   | 4   | 3   | 2   | 1   | 0   |
|------------------|-----|------------|-----|-----|-----|-----|-----|-----|
| Read/Write       | R/W | R/W        | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset            | 0   | 1          | 0   | 0   | 0   | 0   | 0   | 0   |
| Value<br>Content |     | quiet_time |     |     |     |     |     |     |

- reserved: write 0x0.
- GENERIC\_INTERRUPT3\_4.quiet\_time: (bit offset: 0, bit width: 13, access: read-write) Quiet time after an interrupt where no additional interrupts are detected. The field quiet\_time has the following properties:

| Property      | Value               |
|---------------|---------------------|
| Bitwidth      | 13                  |
| Sign          | unsigned            |
| Unit          | S                   |
| Scaling       | 50.0                |
| Default value | 1.28                |
| Range         | Min=0.0, Max=163.82 |

Use this link to go back to the overview table: GENERIC\_INTERRUPT3\_4.

## Register (0x16) **GENERIC\_INTERRUPT3\_5**

**Description:** Manually set acceleration signal reference for x-axis

| Bit            | 15  | 14        | 13  | 12  | 11  | 10  | 9   | 8   |
|----------------|-----|-----------|-----|-----|-----|-----|-----|-----|
| Read/Write     | R/W | R/W       | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0   | 0         | 0   | 0   | 0   | 0   | 0   | 0   |
| Content        |     | ref_acc_x |     |     |     |     |     |     |

| Bit        | 7   | 6   | 5   | 4     | 3    | 2   | 1   | 0   |
|------------|-----|-----|-----|-------|------|-----|-----|-----|
| Read/Write | R/W | R/W | R/W | R/W   | R/W  | R/W | R/W | R/W |
| Reset      | 0   | 0   | 0   | 0     | 0    | 0   | 0   | 0   |
| Value      | 0   | U   | 0   | U     | U    | 0   | 0   | U   |
| Content    |     |     |     | ref_a | cc_x |     |     |     |

• GENERIC\_INTERRUPT3\_5.ref\_acc\_x: (bit offset: 0, bit width: 16, access: read-write) Reference acceleration signal for x-axis . The field ref\_acc\_x has the following properties:

| Property      | Value                         |
|---------------|-------------------------------|
| Bitwidth      | 16                            |
| Sign          | signed                        |
| Unit          | g                             |
| Scaling       | 2048.0                        |
| Default value | 0.0                           |
| Range         | Min=-16.0, Max=15.99951171875 |

Use this link to go back to the overview table: GENERIC\_INTERRUPT3\_5.

# Register (0x17) **GENERIC\_INTERRUPT3\_6**

**Description:** Manually set acceleration signal reference for y-axis

| Bit            | 15  | 14        | 13  | 12  | 11  | 10  | 9   | 8   |
|----------------|-----|-----------|-----|-----|-----|-----|-----|-----|
| Read/Write     | R/W | R/W       | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0   | 0         | 0   | 0   | 0   | 0   | 0   | 0   |
| Content        |     | ref_acc_y |     |     |     |     |     |     |

| Bit        | 7   | 6         | 5   | 4   | 3   | 2   | 1   | 0   |
|------------|-----|-----------|-----|-----|-----|-----|-----|-----|
| Read/Write | R/W | R/W       | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset      | 0   | 0         | 0   | 0   | 0   | 0   | 0   | 0   |
| Value      |     |           |     |     |     |     |     |     |
| Content    |     | ref_acc_y |     |     |     |     |     |     |

• GENERIC\_INTERRUPT3\_6.ref\_acc\_y: (bit offset: 0, bit width: 16, access: read-write) Reference acceleration signal for y-axis . The field ref\_acc\_y has the following properties:

| Property      | Value                         |  |
|---------------|-------------------------------|--|
| Bitwidth      | 16                            |  |
| Sign          | signed                        |  |
| Unit          | g                             |  |
| Scaling       | 2048.0                        |  |
| Default value | 0.0                           |  |
| Range         | Min=-16.0, Max=15.99951171875 |  |

Use this link to go back to the overview table: GENERIC\_INTERRUPT3\_6.

## Register (0x18) **GENERIC\_INTERRUPT3\_7**

Description: Manually set acceleration signal reference for z-axis

| Bit            | 15        | 14  | 13  | 12  | 11  | 10  | 9   | 8   |
|----------------|-----------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write     | R/W       | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0         | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Content        | ref_acc_z |     |     |     |     |     |     |     |

| Bit            | 7         | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------------|-----------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write     | R/W       | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0         | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Content        | ref_acc_z |     |     |     |     |     |     |     |

• GENERIC\_INTERRUPT3\_7.ref\_acc\_z: (bit offset: 0, bit width: 16, access: read-write) Reference acceleration signal for z-axis . The field ref\_acc\_z has the following properties:

| Property      | Value                         |  |
|---------------|-------------------------------|--|
| Bitwidth      | 16                            |  |
| Sign          | signed                        |  |
| Unit          | g                             |  |
| Scaling       | 2048.0                        |  |
| Default value | 0.0                           |  |
| Range         | Min=-16.0, Max=15.99951171875 |  |

Use this link to go back to the overview table: GENERIC\_INTERRUPT3\_7.

#### Register (0x19) TAP\_DETECTOR\_1

Description: Selection of the tap detection axis, gesture reporting approach, detection mode

| Bit        | 15 | 14       | 13 | 12 | 11 | 10       | 9        | 8        |
|------------|----|----------|----|----|----|----------|----------|----------|
| Read/Write | R  | R        | R  | R  | R  | R/W      | R/W      | R/W      |
| Reset      | 0  | 0        | 0  | 0  | 0  | 1        | 1        | 1        |
| Value      | U  | U        | 0  | U  | U  | 1        | 1        | 1        |
| Content    |    | reserved |    |    |    | t_tap_en | d_tap_en | s_tap_en |

| Bit        | 7   | 6   | 5                 | 4   | 3   | 2      | 1    | 0    |
|------------|-----|-----|-------------------|-----|-----|--------|------|------|
| Read/Write | R/W | R/W | R/W               | R/W | R/W | R/W    | R/W  | R/W  |
| Reset      | 0   | 1   | 1                 | 1   | 0   | 1      | 1    | 0    |
| Value      | U   | 1   | <b>T</b>          | 1   | O   | 1      | Ι Ι  | 0    |
| Content    | mo  | ode | max_peaks_for_tap |     | tap | wait_f | axis | _sel |

- reserved: write 0x0.
- TAP\_DETECTOR\_1.axis\_sel: (bit offset: 0, bit width: 2, access: read-write) Dominant sensing axis of accelerometer along which tap gesture is performed.

Following values can be set to or read from the field axis\_sel:

| Value      | Description                  |
|------------|------------------------------|
| 0b00 (0x0) | Use x-axis for tap detection |
| 0b01 (0x1) | Use y-axis for tap detection |
| 0b10 (0x2) | Use z-axis for tap detection |
| 0b11 (0x3) | Use z-axis for tap detection |

The field axis\_sel has the following properties:

| Property      | Value        |
|---------------|--------------|
| Bitwidth      | 2            |
| Default value | 2            |
| Range         | Min=0, Max=2 |

■ TAP\_DETECTOR\_1.wait\_for\_timeout: (bit offset: 2, bit width: 1, access: read-write) Perform gesture confirmation with wait time set by max\_gesture\_dur.

Following values can be set to or read from the field wait\_for\_timeout:

| Value     | Description                           |
|-----------|---------------------------------------|
| 0b0 (0x0) | Report the gesture when detected      |
| 0b1 (0x1) | Report the gesture after confirmation |

The field wait\_for\_timeout has the following properties:

| Property      | Value        |
|---------------|--------------|
| Bitwidth      | 1            |
| Default value | 1            |
| Range         | Min=0, Max=1 |

■ TAP\_DETECTOR\_1.max\_peaks\_for\_tap: (bit offset: 3, bit width: 3, access: read-write) Maximum number of threshold crossing expected around a tap. The field max\_peaks\_for\_tap has the following properties:

| Property      | Value        |
|---------------|--------------|
| Bitwidth      | 3            |
| Default value | 6            |
| Range         | Min=0, Max=7 |

■ TAP\_DETECTOR\_1.mode: (bit offset: 6, bit width: 2, access: read-write) Mode for detection of tap gesture. Default value = Normal. In stable position of device, to improve detection accuracy, sensitive mode can be used. Under noisy scenarios, the false detection can be suppressed with Robust mode . Following values can be set to or read from the field mode:

| Value      | Description              |
|------------|--------------------------|
| 0b00 (0x0) | Sensitive detection mode |
| 0b01 (0x1) | Normal detection mode    |
| 0b10 (0x2) | Robust detection mode    |

The field mode has the following properties:

| Property      | Value        |
|---------------|--------------|
| Bitwidth      | 2            |
| Default value | 1            |
| Range         | Min=0, Max=2 |

- TAP\_DETECTOR\_1.s\_tap\_en: (bit offset: 8, bit width: 1, access: read-write) Enable single tap feature.
- TAP\_DETECTOR\_1.d\_tap\_en: (bit offset: 9, bit width: 1, access: read-write) Enable double tap feature.
- TAP\_DETECTOR\_1.t\_tap\_en: (bit offset: 10, bit width: 1, access: read-write) Enable triple tap feature.

Use this link to go back to the overview table: TAP\_DETECTOR\_1.

### Register (0x1A) TAP\_DETECTOR\_2

**Description:** Tap detector setting

| Bit        | 15              | 14  | 13  | 12  | 11  | 10  | 9       | 8       |
|------------|-----------------|-----|-----|-----|-----|-----|---------|---------|
| Read/Write | R/W             | R/W | R/W | R/W | R/W | R/W | R/W     | R/W     |
| Reset      | 0               | 1   | 1   | 0   | 0   | 1   | 1       | 0       |
| Value      | U               | 1   | 1   | U   | U   | 1   | 1       | 0       |
| Content    | max_gesture_dur |     |     |     |     |     | tap_pea | k_thres |

| Bit            | 7              | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |
|----------------|----------------|-----|-----|-----|-----|-----|-----|-----|--|
| Read/Write     | R/W            | R/W | R/W | R/W | R/W | R/W | R/W | R/W |  |
| Reset<br>Value | 1              | 1   | 1   | 0   | 1   | 1   | 1   | 0   |  |
| Content        | tap_peak_thres |     |     |     |     |     |     |     |  |

■ TAP\_DETECTOR\_2.tap\_peak\_thres: (bit offset: 0, bit width: 10, access: read-write) Minimum threshold for peak resulting from the tap. The field tap\_peak\_thres has the following properties:

| Property      | Value                    |  |  |  |  |
|---------------|--------------------------|--|--|--|--|
| Bitwidth      | 10                       |  |  |  |  |
| Sign          | unsigned                 |  |  |  |  |
| Unit          | g                        |  |  |  |  |
| Scaling       | 512                      |  |  |  |  |
| Default value | 740/512                  |  |  |  |  |
| Range         | Min=0.0, Max=1.998046875 |  |  |  |  |

■ TAP\_DETECTOR\_2.max\_gesture\_dur: (bit offset: 10, bit width: 6, access: read-write) Maximum duration from first tap within the second and/or third tap is expected to happen. The field max\_gesture\_dur has the following properties:

| Property      | Value             |  |  |  |
|---------------|-------------------|--|--|--|
| Bitwidth      | 6                 |  |  |  |
| Sign          | unsigned          |  |  |  |
| Unit          | S                 |  |  |  |
| Scaling       | 25                |  |  |  |
| Default value | 1.0               |  |  |  |
| Range         | Min=0.0, Max=2.52 |  |  |  |

Use this link to go back to the overview table: TAP\_DETECTOR\_2.

#### Register (0x1B) TAP\_DETECTOR\_3

**Description:** Tap detector setting

| Bit            | 15                       | 14  | 13  | 12  | 11  | 10           | 9            | 8   |
|----------------|--------------------------|-----|-----|-----|-----|--------------|--------------|-----|
| Read/Write     | R/W                      | R/W | R/W | R/W | R/W | R/W          | R/W          | R/W |
| Reset<br>Value | 0                        | 1   | 1   | 0   | 1   | 0            | 0            | 0   |
| Content        | quite_time_after_gesture |     |     |     | m   | in_quite_dur | _between_tap | os  |

| Bit            | 7                      | 6   | 5   | 4   | 3   | 2           | 1          | 0   |
|----------------|------------------------|-----|-----|-----|-----|-------------|------------|-----|
| Read/Write     | R/W                    | R/W | R/W | R/W | R/W | R/W         | R/W        | R/W |
| Reset<br>Value | 0                      | 1   | 1   | 0   | 0   | 1           | 0          | 0   |
| Content        | tap_shock_settling_dur |     |     |     |     | max_dur_bet | ween_peaks |     |

■ TAP\_DETECTOR\_3.max\_dur\_between\_peaks: (bit offset: 0, bit width: 4, access: read-write) Maximum duration between positive and negative peaks to tap. The field max\_dur\_between\_peaks has the following properties:

| Property      | Value              |  |  |  |
|---------------|--------------------|--|--|--|
| Bitwidth      | 4                  |  |  |  |
| Sign          | unsigned           |  |  |  |
| Unit          | S                  |  |  |  |
| Scaling       | 200                |  |  |  |
| Default value | 0.02               |  |  |  |
| Range         | Min=0.0, Max=0.075 |  |  |  |

■ TAP\_DETECTOR\_3.tap\_shock\_settling\_dur: (bit offset: 4, bit width: 4, access: read-write) Maximum duration for which tap impact is observed. The field tap\_shock\_settling\_dur has the following properties:

| Property      | Value              |  |  |  |
|---------------|--------------------|--|--|--|
| Bitwidth      | 4                  |  |  |  |
| Sign          | unsigned           |  |  |  |
| Unit          | S                  |  |  |  |
| Scaling       | 200                |  |  |  |
| Default value | 0.03               |  |  |  |
| Range         | Min=0.0, Max=0.075 |  |  |  |

■ TAP\_DETECTOR\_3.min\_quite\_dur\_between\_taps: (bit offset: 8, bit width: 4, access: read-write) Mimimum duration between two consecutive tap impact. The field min\_quite\_dur\_between\_taps has the following properties:

| Property      | Value              |  |  |  |
|---------------|--------------------|--|--|--|
| Bitwidth      | 4                  |  |  |  |
| Sign          | unsigned           |  |  |  |
| Unit          | S                  |  |  |  |
| Scaling       | 200                |  |  |  |
| Default value | 0.04               |  |  |  |
| Range         | Min=0.0, Max=0.075 |  |  |  |

■ TAP\_DETECTOR\_3.quite\_time\_after\_gesture: (bit offset: 12, bit width: 4, access: read-write) Minimum quite duration between two gestures. The field quite\_time\_after\_gesture has the following properties:

| Property      | Value            |  |  |  |
|---------------|------------------|--|--|--|
| Bitwidth      | 4                |  |  |  |
| Sign          | unsigned         |  |  |  |
| Unit          | S                |  |  |  |
| Scaling       | 25               |  |  |  |
| Default value | 0.24             |  |  |  |
| Range         | Min=0.0, Max=0.6 |  |  |  |

Use this link to go back to the overview table: TAP\_DETECTOR\_3.

## Register (0x1C) VAD\_CTRL

**Description:** Settings for segment size for feature analysis, post-processor buffer size and operating sample rate selection for voice activity detection

| Bit        | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
|------------|----------|----|----|----|----|----|---|---|
| Read/Write | R        | R  | R  | R  | R  | R  | R | R |
| Reset      | 0        | 0  | 0  | 0  | 0  | 0  | 0 | 0 |
| Value      | U        | U  | O  | U  | O  | O  | O | 0 |
| Content    | reserved |    |    |    |    |    |   |   |

| Bit        | 7 | 6        | 5 | 4 | 3        | 2        | 1        | 0   |
|------------|---|----------|---|---|----------|----------|----------|-----|
| Read/Write | R | R        | R | R | R        | R/W      | R/W      | R/W |
| Reset      | 0 | 0        | 0 | 0 | 0        | 1        | 1        | 1   |
| Value      | 0 | U        | 0 | 0 | 0        | 1        | ±        | 1   |
| Content    |   | reserved |   |   | en_vad_z | en_vad_y | en_vad_x |     |

- reserved: write 0x0.
- VAD\_CTRL.en\_vad\_x: (bit offset: 0, bit width: 1, access: read-write) Enable detection of voice activity for x axis . Following values can be set to or read from the field en\_vad\_x:

| Value     | Description                             |
|-----------|-----------------------------------------|
| 0b0 (0x0) | Detection of voice activity is disabled |
| 0b1 (0x1) | Detection of voice activity is enabled  |

The field en\_vad\_x has the following properties:

| Property      | Value        |
|---------------|--------------|
| Bitwidth      | 1            |
| Sign          | unsigned     |
| Default value | 1            |
| Range         | Min=0, Max=1 |

VAD\_CTRL.en\_vad\_y: (bit offset: 1, bit width: 1, access: read-write) Enable detection of voice activity for y axis . Following values can be set to or read from the field en\_vad\_y:

| Value     | Description                             |
|-----------|-----------------------------------------|
| 0b0 (0x0) | Detection of voice activity is disabled |
| 0b1 (0x1) | Detection of voice activity is enabled  |

The field en\_vad\_y has the following properties:

| Property      | Value        |
|---------------|--------------|
| Bitwidth      | 1            |
| Sign          | unsigned     |
| Default value | 1            |
| Range         | Min=0, Max=1 |

■ VAD\_CTRL.en\_vad\_z: (bit offset: 2, bit width: 1, access: read-write) Enable detection of voice activity for z axis . Following values can be set to or read from the field en\_vad\_z:

| Value     | Description                             |
|-----------|-----------------------------------------|
| 0b0 (0x0) | Detection of voice activity is disabled |
| 0b1 (0x1) | Detection of voice activity is enabled  |

The field en\_vad\_z has the following properties:

| Property      | Value        |
|---------------|--------------|
| Bitwidth      | 1            |
| Sign          | unsigned     |
| Default value | 1            |
| Range         | Min=0, Max=1 |

Use this link to go back to the overview table: VAD\_CTRL.

#### Register (0x24) ACC\_CONF\_LOW\_POWER

Description: Accelerometer configuration register when the user chooses low power mode

| Bit            | 15       | 14  | 13  | 12  | 11  | 10  | 9   | 8   |
|----------------|----------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write     | R/W      | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0        | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Content        | reserved |     |     |     |     |     |     |     |

| Bit        | 7      | 6   | 5       | 4   | 3       | 2   | 1   | 0   |
|------------|--------|-----|---------|-----|---------|-----|-----|-----|
| Read/Write | R/W    | R/W | R/W     | R/W | R/W     | R/W | R/W | R/W |
| Reset      | 0      | 0   | 1       | 0   | 0       | 1   | 0   | 1   |
| Value      |        |     |         |     |         |     |     |     |
| Content    | acc_pe |     | acc_bwp |     | acc_odr |     |     |     |

• ACC\_CONF\_LOW\_POWER.acc\_odr: (bit offset: 0, bit width: 4, access: read-write) The ODR (Output Data Rate) in Hz. Not all settings are available in all power modes.

Following values can be set to or read from the field acc\_odr:

| Value        | Description                                           |
|--------------|-------------------------------------------------------|
| 0b0000 (0x0) | 1.5625 Hz. Only available in duty cycling mode (LPM). |
| 0b0001 (0x1) | 3.125 Hz. Only available in duty cycling mode (LPM).  |
| 0b0010 (0x2) | 6.25 Hz.Only available in duty cycling mode (LPM).    |
| 0b0011 (0x3) | 12.5 Hz.                                              |
| 0b0100 (0x4) | 25 Hz.                                                |
| 0b0101 (0x5) | 50 Hz.                                                |
| 0b0110 (0x6) | 100 Hz.                                               |
| 0b0111 (0x7) | 200 Hz.                                               |
| 0b1000 (0x8) | 400 Hz.                                               |
| 0b1001 (0x9) | 800 Hz. Only available in continuous mode (HPM).      |
| 0b1010 (0xA) | 1.6 kHz. Only available in continuous mode (HPM).     |
| 0b1011 (0xB) | 3.2 kHz. Only available in continuous mode (HPM).     |
| 0b1100 (0xC) | 6.4 kHz. Only available in continuous mode (HPM).     |

■ ACC\_CONF\_LOW\_POWER.acc\_bwp: (bit offset: 4, bit width: 3, access: read-write) Bandwidth parameter, determines filter configuration.

Following values can be set to or read from the field acc\_bwp:

| Value       | Description                                                               |
|-------------|---------------------------------------------------------------------------|
| 0b000 (0x0) | acc_perf_mode = 1 -> OSR4 mode; acc_perf_mode = 0 -> no averaging.        |
| 0b001 (0x1) | acc_perf_mode = 1 -> OSR2 mode; acc_perf_mode = 0 -> average 2 samples.   |
| 0b010 (0x2) | acc_perf_mode = 1 -> normal mode; acc_perf_mode = 0 -> average 4 samples. |
| 0b011 (0x3) | acc_perf_mode = 1 -> CIC mode; acc_perf_mode = 0 -> average 8 samples.    |
| 0b100 (0x4) | acc_perf_mode = 1 -> reserved; acc_perf_mode = 0 -> average 16 samples.   |
| 0b101 (0x5) | acc_perf_mode = 1 -> reserved; acc_perf_mode = 0 -> average 32 samples.   |
| 0b110 (0x6) | acc_perf_mode = 1 -> reserved; acc_perf_mode = 0 -> average 64 samples.   |
| 0b111 (0x7) | acc_perf_mode = 1 -> reserved; acc_perf_mode = 0 -> reserved.             |

ACC\_CONF\_LOW\_POWER.acc\_perf\_mode: (bit offset: 7, bit width: 1, access: read-write) Bandwidth parameter, determines filter configuration.

Following values can be set to or read from the field acc\_perf\_mode:

| Value     | Description                        |
|-----------|------------------------------------|
| 0b0 (0x0) | Duty Cycling mode (CIC averaging). |
| 0b1 (0x1) | Continuous mode (IIR filtering).   |

• ACC\_CONF\_LOW\_POWER.reserved: (bit offset: 8, bit width: 8, access: read-write) Reserved.

Use this link to go back to the overview table: ACC\_CONF\_LOW\_POWER.

#### Register (0x25) FOC\_0

**Description:** Accelerometer fast-offset compensation feature

| Bit        | 15       | 14 | 13 | 12 | 11 | 10 | 9      | 8   |
|------------|----------|----|----|----|----|----|--------|-----|
| Read/Write | R        | R  | R  | R  | R  | R  | R      | R/W |
| Reset      | 0        | 0  | 0  | 0  | 0  | 0  | 0      | 0   |
| Value      | U        | U  | U  | U  | U  | U  | U      | U   |
| Content    | reserved |    |    |    |    |    | foc_of |     |

| Bit        | 7         | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------------|-----------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write | R/W       | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset      | 0         | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Value      | 0         | U   | 0   | U   | U   | U   | 0   | U   |
| Content    | foc_off_x |     |     |     |     |     |     |     |

- reserved: write 0x0.
- FOC\_0.foc\_off\_x: (bit offset: 0, bit width: 9, access: read-write) Offset estimated for accelerometer X-axis using fast-offset compensation feature. Value has same range and resolution as the user offset registers. . The field foc\_off\_x has the following properties:

| Property      | Value             |  |  |
|---------------|-------------------|--|--|
| Bitwidth      | 9                 |  |  |
| Sign          | signed            |  |  |
| Scaling       | 1024              |  |  |
| Default value | 0                 |  |  |
| Range         | Min=-256, Max=255 |  |  |

Use this link to go back to the overview table: FOC\_0.

#### Register (0x26) FOC\_1

**Description:** Accelerometer fast-offset compensation feature

| Bit        | 15       | 14 | 13 | 12 | 11 | 10     | 9 | 8   |
|------------|----------|----|----|----|----|--------|---|-----|
| Read/Write | R        | R  | R  | R  | R  | R      | R | R/W |
| Reset      | 0        | 0  | 0  | 0  | 0  | 0      | 0 | 0   |
| Value      | U        | U  | U  | U  | U  | U      | U | U   |
| Content    | reserved |    |    |    |    | foc_of |   |     |

| Bit        | 7         | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------------|-----------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write | R/W       | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset      | 0         | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Value      | 0         | U   | 0   | U   | U   | 0   | U   | 0   |
| Content    | foc_off_y |     |     |     |     |     |     |     |

- reserved: write 0x0.
- FOC\_1.foc\_off\_y: (bit offset: 0, bit width: 9, access: read-write) Offset estimated for accelerometer Y-axis using fast-offset compensation feature. Value has same range and resolution as the user offset registers. . The field foc\_off\_y has the following properties:

| Property      | Value             |  |  |
|---------------|-------------------|--|--|
| Bitwidth      | 9                 |  |  |
| Sign          | signed            |  |  |
| Scaling       | 1024              |  |  |
| Default value | 0                 |  |  |
| Range         | Min=-256, Max=255 |  |  |

Use this link to go back to the overview table: FOC\_1.

#### Register (0x27) FOC\_2

**Description:** Accelerometer fast-offset compensation feature

| Bit        | 15       | 14 | 13 | 12 | 11 | 10 | 9      | 8   |
|------------|----------|----|----|----|----|----|--------|-----|
| Read/Write | R        | R  | R  | R  | R  | R  | R      | R/W |
| Reset      | 0        | 0  | 0  | 0  | 0  | 0  | 0      | 0   |
| Value      | 0        | U  | 0  | U  | U  | U  | U      | U   |
| Content    | reserved |    |    |    |    |    | foc_of |     |

| Bit            | 7         | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------------|-----------|-----|-----|-----|-----|-----|-----|-----|
| Read/Write     | R/W       | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset<br>Value | 0         | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Content        | foc_off_z |     |     |     |     |     |     |     |

- reserved: write 0x0.
- FOC\_2.foc\_off\_z: (bit offset: 0, bit width: 9, access: read-write) Offset estimated for accelerometer Z-axis using fast-offset compensation feature. Value has same range and resolution as the user offset registers. . The field foc\_off\_z has the following properties:

| Property      | Value             |  |  |
|---------------|-------------------|--|--|
| Bitwidth      | 9                 |  |  |
| Sign          | signed            |  |  |
| Scaling       | 1024              |  |  |
| Default value | 0                 |  |  |
| Range         | Min=-256, Max=255 |  |  |

Use this link to go back to the overview table: FOC\_2.

# Register (0x28) FOC\_3

**Description:** Accelerometer fast-offset compensation feature

| Bit        | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
|------------|----------|----|----|----|----|----|---|---|
| Read/Write | R        | R  | R  | R  | R  | R  | R | R |
| Reset      | 0        | 0  | 0  | 0  | 0  | 0  | 0 | 0 |
| Value      | U        | U  | U  | U  | U  | U  | O | U |
| Content    | reserved |    |    |    |    |    |   |   |

| Bit            | 7        | 6           | 5   | 4                | 3   | 2   | 1      | 0   |
|----------------|----------|-------------|-----|------------------|-----|-----|--------|-----|
| Read/Write     | R        | R/W         | R/W | R/W              | R/W | R/W | R/W    | R/W |
| Reset<br>Value | 0        | 0           | 0   | 0                | 0   | 0   | 0      | 0   |
| Content        | reserved | foc_axis_1g |     | foc_filter_coeff |     |     | foc_ap |     |

- write 0x0. reserved:
- FOC\_3.foc\_apply\_corr: (bit offset: 0, bit width: 1, access: read-write) Update user offset registers with estimated offset values after feature completion.
- FOC\_3.foc\_filter\_coeff: (bit offset: 1, bit width: 3, access: read-write) Number of 200Hz accelerometer samples that are averaged to estimate the offset. Number of samples = 2^(foc\_filter\_coeff + 3). Default value of field is 0 which means 8 samples will be averaged. .
- FOC\_3.foc\_axis\_1g: (bit offset: 4, bit width: 3, access: read-write) Fast-offset compensation must be executed only when the device is still and one axis is parallel to the gravitation vector. This axis can be either aligned with gravitational vector or in the opposite direction of the gravitational vector. Device will not warn the user if the device is not static or an axis is not parallel to the gravitational vector. .

Following values can be set to or read from the field foc\_axis\_1g:

| Value       | Description        |
|-------------|--------------------|
| 0b000 (0x0) | Z-axis shows 1G    |
| 0b001 (0x1) | Z-axis shows -1G   |
| 0b010 (0x2) | Y-axis shows 1G    |
| 0b011 (0x3) | Y-axis shows -1G   |
| 0b100 (0x4) | X-axis shows 1G    |
| 0b101 (0x5) | X-axis shows -1G   |
| 0b110 (0x6) | Same as x_plus_1g  |
| 0b111 (0x7) | Same as x_minus_1g |

Use this link to go back to the overview table: FOC\_3.

# **Pin Out and Connection Diagrams**

# 7.1 Pin Out

The figures 47 and 48 shows the pin-out of the device from top and bottom view, respectively.



Figure 47: Pin-out: top view



Figure 48: Pin-out: bottom view

The table 39 details the pin out and the connections of the individual pins of the device.

Table 39: Pin-out and pin connections

|       |      |             |                                                                              | Connect to    |               |                                 |  |
|-------|------|-------------|------------------------------------------------------------------------------|---------------|---------------|---------------------------------|--|
| Pin # | Name | I/O Type    | Description                                                                  | in SPI 4-wire | in SPI 3-Wire | in I <sup>2</sup> C/I3C         |  |
| 1     | VSS  | Ground      | Ground<br>(VSS=GND=GNDIO)                                                    | GND           | GND           | GND                             |  |
| 2     | INT1 | Digital I/O | Interrupt pin 1 (or Serial Data)                                             | SDO/MISO      | INT1          | INT1                            |  |
| 3     | INT2 | Digital I/O | Interrupt pin 2 (or Chip<br>Select for SPI)                                  | CSB           | CSB           | INT2*<br>(or VDD, if<br>unused) |  |
| 4     | SDA  | Digital I/O | Serial Data                                                                  | SDI/MOSI      | SDX           | SDA                             |  |
| 5     | SCL  | Digital I/O | Serial Clock                                                                 | SCK           | SCK           | SCL                             |  |
| 6     | VDD  | Supply      | Power supply analog & digital domain and digital I/O 1.62V 3.63V (VDD=VDDIO) | VDD (= VDDIO) | VDD (= VDDIO) | VDD (= VDDIO)                   |  |

<sup>\*</sup>Do not drive INT2 low during startup, see the following chapter 7.2.1 for more details.

# 7.2 Connection Diagrams

# 7.2.1 Connection Diagrams with I2C and I3C



Figure 49: Connection Diagram with I2C and I3C

It is recommended to use 100nF decoupling capacitors at pin 6 (VDD).

Please note for the I2C/I3C mode, as already mentioned in chapter 5.2.1.1:

- Configure the pin 3 to be an output.
- When the output characteristics of pin 3 is disabled (or not yet enabled), please do not connect pin 3 to ground, as shown in figure 50.
- If the pin 3 is not used, connected it to VDD.

### When the output characteristics of pin 3 is disabled



Figure 50: Connection that is not allowed in I<sup>2</sup>C and I3C before the pin 3 is configured to the output characteristics

■ When the output characteristics of pin 3 is disabled (or not yet enabled), please do not connect pin 3 to a GPIO pin configured in the pull-down state, as shown in figure 51. Please consider this behavior especially during the startup of the device, since pin 3 is used in SPI Mode as CSB and therefore a connection to ground will trigger the SPI mode.

# When the output characteristics of pin 3 is disabled



Figure 51: Connection that is not allowed in I2C and I3C before the pin 3 is configured to the output characteristics

# 7.2.2 Connection Diagrams with SPI (3-Wire)



Figure 52: Connection Diagram with SPI 3-Wire

It is recommended to use 100nF decoupling capacitors at pin 6 (VDD).

# 7.2.3 Connection Diagrams with SPI (4-Wire)



Figure 53: Connection Diagram with SPI 4-Wire

It is recommended to use 100nF decoupling capacitors at pin 6 (VDD).

# 8 Package

### 8.1 Dimensions

The BMA580 has a very compact Wafer Level Chip Scale Package (WLCSP). Figures 54, 55 and 56 show the dimensions of the package, the unit for all dimension specifications in the figures is mm.



# TOP VIEW

Figure 54: Dimensions from top (in mm)



NOTE:
DIEMENSION OF BUMP REFER TO BALL DIAMETER AFTER REFLOW

Figure 55: Dimensions from bottom view (in mm)



Figure 56: Dimensions from side view (in mm)

#### 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.

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 accelerometer channel
- $\pm 0g$  for the y accelerometer channel
- +1g for the z accelerometer channel



Figure 57: Definition of the sensing axes orientation for the raw device

For reference, Figure 58 below shows the smartphone device orientation with an integrated device.



Figure 58: Definition of the sensing axes orientation within a device

#### Landing Pattern Recommendation 8.3

Figure 59 provides the recommendation for the landing pad to ensure maximum stability of the solder connections.



Figure 59: Landing pattern recommendation

IPC recommends shrinking of PCB-pads to nominal ball diameter:

■ PCB-pad size = 0.18 mm

■ Nominal ball diameter = 0.21 mm

#### Marking 8.4

Mass Production

Table 40: Marking - Mass Production

| Labeling | Symbol | Name               | Remark                                                       |
|----------|--------|--------------------|--------------------------------------------------------------|
|          | F      | Product Identifier | One alphanumeric digit, fixed to "F" to identify the product |
| FCCC +   | 6      | Internal Code      | 1 alphanumeric digit, fixed to "6", internal use only        |
| 6CCCCC   | CCC    | Counter ID         | Tracing identification by eight alphanumeric digits          |
|          | •      | Pin 1              | Identifier on top side                                       |

# **Engineering Samples**

Table 41: Marking - Engineering Samples

| Labeling | Symbol | Name               | Remark                                                       |
|----------|--------|--------------------|--------------------------------------------------------------|
|          | F      | Product Identifier | One alphanumeric digit, fixed to "F" to identify the product |
| ECCC +   | E      | Internal Code      | 1 alphanumeric digit, fixed to "E", internal use only        |
| FCCCC    | CCC    | Counter ID         | Tracing identification by eight alphanumeric digits          |
|          | •      | Pin 1              | Identifier on top side                                       |

# 8.5 Tape and Reel Information



Figure 60: Tape and Reel information

## 8.6 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-020F "Joint Industry Standard: Moisture/Reflow Sensitivity Classification for non-hermetic Solid State Surface Mount Devices"

Both documents are available on the JEDEC website https://www.jedec.org/.

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

### 8.7 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*. 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 accelerations 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.8 Environmental Safety

The BMA580 WLCSP sensor 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.

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

Corresponding chemical analysis certificates are available as separate documents from Bosch Sensortec.

# 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 Modifications

Table 42: Change log

| Rev No | Chapter  | Description of modification/changes                                                                                                                                     | Date          |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 1.0    | all      | public release                                                                                                                                                          | May 14th 2024 |
| 1.1    | 2 4      | <ul> <li>update of description only (no update of specification values)</li> <li>update of FOC description: more details on recommended</li> </ul>                      | Feb 6th 2025  |
|        |          | sequence - reduced waiting time for self test - add details on LPM and filter settings - update of self wake-up description: more details on recommended configurations |               |
|        | 6<br>all | <ul> <li>external voltage measurement: update of evaluation formula</li> <li>update register map description</li> </ul>                                                 |               |
|        | all      | - editorial changes                                                                                                                                                     |               |

### **Bosch Sensortec GmbH**

Gerhard-Kindler-Strasse 9 72770 Reutlingen / Germany

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

Modifications reserved

Document number: BST-BMA580-DS000-05