# MAX21100 USER GUIDE

**Revision 1.0** 

July 2015



©2015 Maxim Integrated Products, Inc. All rights reserved.

No part of this documentation may be reproduced nor distributed in any form or by any means, graphic, electronic, or mechanical, including but not limited to photocopying, scanning, recording, taping, e-mailing, or storing in information storage and retrieval systems without the written permission of Maxim Integrated Products, Inc. (hereafter, "Maxim"). Products that are referenced in this document such as Microsoft Windows® may be trademarks and/or registered trademarks of their respective owners. Maxim makes no claim to these trademarks. While every precaution has been taken in the preparation of this document, individually, as a series, in whole, or in part, Maxim, the publisher, and the author assume no responsibility for errors or omissions, including any damages resulting from the express or implied application of information contained in this document or from the use of products, services, or programs that may accompany it. In no event shall Maxim, publishers, authors, or editors of this guide be liable for any loss of profit or any other commercial damage caused or alleged to have been caused directly or indirectly by this document.

Rev. 1.0, Jul 2015

# CONTENTS

| 1                                                                                                                                    | Introduction                                                                                                                                                                                                                                                                                                                               | 6                                                                                                                             |
|--------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 2                                                                                                                                    | Nomenclature                                                                                                                                                                                                                                                                                                                               | 7                                                                                                                             |
| 3                                                                                                                                    | MAX21100 Description                                                                                                                                                                                                                                                                                                                       | 8                                                                                                                             |
| 4                                                                                                                                    | Pin Description                                                                                                                                                                                                                                                                                                                            | 9                                                                                                                             |
| 5                                                                                                                                    | I2C Interface                                                                                                                                                                                                                                                                                                                              | 10                                                                                                                            |
| 1.1                                                                                                                                  | I <sup>2</sup> C Protocol                                                                                                                                                                                                                                                                                                                  | 11                                                                                                                            |
| 1.2                                                                                                                                  | Slave Address                                                                                                                                                                                                                                                                                                                              | 11                                                                                                                            |
| 1.3                                                                                                                                  | Acknowledge                                                                                                                                                                                                                                                                                                                                | 11                                                                                                                            |
| 1.4                                                                                                                                  | Register Address                                                                                                                                                                                                                                                                                                                           | 12                                                                                                                            |
| 1.5                                                                                                                                  | I <sup>2</sup> C Operations                                                                                                                                                                                                                                                                                                                | 12                                                                                                                            |
| 5.1.1                                                                                                                                | Write One Register                                                                                                                                                                                                                                                                                                                         | 12                                                                                                                            |
| 5.1.2                                                                                                                                | Write Multiple Registers                                                                                                                                                                                                                                                                                                                   |                                                                                                                               |
| 5.1.3                                                                                                                                | Read One Register                                                                                                                                                                                                                                                                                                                          |                                                                                                                               |
| 5.1.4                                                                                                                                | Read Multiple Registers                                                                                                                                                                                                                                                                                                                    |                                                                                                                               |
| 5.2                                                                                                                                  | Configuration Registers                                                                                                                                                                                                                                                                                                                    | 15                                                                                                                            |
| 6                                                                                                                                    | SPI Interface                                                                                                                                                                                                                                                                                                                              | 16                                                                                                                            |
| 6.1                                                                                                                                  | SPI Protocol                                                                                                                                                                                                                                                                                                                               | 17                                                                                                                            |
| 6.2                                                                                                                                  | Register Address                                                                                                                                                                                                                                                                                                                           | 17                                                                                                                            |
| 6.3                                                                                                                                  | Configuration Registers                                                                                                                                                                                                                                                                                                                    | 18                                                                                                                            |
|                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                            |                                                                                                                               |
| 7                                                                                                                                    | Interrupts                                                                                                                                                                                                                                                                                                                                 | 19                                                                                                                            |
| <b>7</b><br>7.1                                                                                                                      | Interrupts                                                                                                                                                                                                                                                                                                                                 |                                                                                                                               |
| -                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                            | 19                                                                                                                            |
| 7.1                                                                                                                                  | Interrupt Flags                                                                                                                                                                                                                                                                                                                            | 19<br>19                                                                                                                      |
| 7.1<br>7.2                                                                                                                           | Interrupt Flags<br>Interrupt Lines                                                                                                                                                                                                                                                                                                         | 19<br>19<br>20                                                                                                                |
| 7.1<br>7.2<br>7.3                                                                                                                    | Interrupt Flags<br>Interrupt Lines<br>Rate Interrupts                                                                                                                                                                                                                                                                                      | 19<br>19<br>20<br>22                                                                                                          |
| 7.1<br>7.2<br>7.3<br>7.4                                                                                                             | Interrupt Flags<br>Interrupt Lines<br>Rate Interrupts<br>Configuration Registers                                                                                                                                                                                                                                                           | 19<br>19<br>20<br>22<br><b>23</b>                                                                                             |
| 7.1<br>7.2<br>7.3<br>7.4<br><b>8</b>                                                                                                 | Interrupt Flags<br>Interrupt Lines<br>Rate Interrupts<br>Configuration Registers<br>Reading Data from MAX21100                                                                                                                                                                                                                             | 19<br>19<br>20<br>22<br><b>23</b><br>23                                                                                       |
| 7.1<br>7.2<br>7.3<br>7.4<br><b>8</b><br>8.1                                                                                          | Interrupt Flags<br>Interrupt Lines<br>Rate Interrupts<br>Configuration Registers<br>Reading Data from MAX21100<br>Synchronous Reading                                                                                                                                                                                                      | 19<br>20<br>22<br><b>23</b><br>23<br>23                                                                                       |
| 7.1<br>7.2<br>7.3<br>7.4<br><b>8</b><br>8.1<br>8.2                                                                                   | Interrupt Flags<br>Interrupt Lines<br>Rate Interrupts<br>Configuration Registers<br>Reading Data from MAX21100<br>Synchronous Reading<br>Asynchronous Reading                                                                                                                                                                              | 19<br>20<br>22<br><b>23</b><br>23<br>23                                                                                       |
| 7.1<br>7.2<br>7.3<br>7.4<br>8<br>8.1<br>8.2<br>9                                                                                     | Interrupt Flags<br>Interrupt Lines<br>Rate Interrupts<br>Configuration Registers<br>Reading Data from MAX21100<br>Synchronous Reading<br>Asynchronous Reading<br>FIFO                                                                                                                                                                      | 19<br>20<br>22<br><b>23</b><br>23<br>23<br><b>24</b><br>24                                                                    |
| 7.1<br>7.2<br>7.3<br>7.4<br><b>8</b><br>8.1<br>8.2<br><b>9</b><br>9.1                                                                | Interrupt Flags<br>Interrupt Lines<br>Rate Interrupts<br>Configuration Registers<br>Reading Data from MAX21100<br>Synchronous Reading<br>Asynchronous Reading<br>FIFO<br>FIFO Modes Description                                                                                                                                            | 19<br>19<br>20<br>22<br><b>23</b><br>23<br><b>24</b><br>24                                                                    |
| 7.1<br>7.2<br>7.3<br>7.4<br><b>8</b><br>8.1<br>8.2<br><b>9</b><br>9.1<br>9.1.1                                                       | Interrupt Flags<br>Interrupt Lines<br>Rate Interrupts<br>Configuration Registers<br>Reading Data from MAX21100<br>Synchronous Reading<br>Asynchronous Reading<br>FIFO<br>FIFO Modes Description<br>FIFO OFF Mode                                                                                                                           | 19<br>20<br>22<br><b>23</b><br>23<br><b>24</b><br>24<br>24                                                                    |
| 7.1<br>7.2<br>7.3<br>7.4<br><b>8</b><br>8.1<br>8.2<br><b>9</b><br>9.1<br>9.1.1<br>9.1.2                                              | Interrupt Flags<br>Interrupt Lines<br>Rate Interrupts<br>Configuration Registers<br>Reading Data from MAX21100<br>Synchronous Reading<br>Asynchronous Reading<br>FIFO<br>FIFO Modes Description<br>FIFO OFF Mode<br>Normal Mode                                                                                                            | 19<br>20<br>22<br><b>23</b><br>23<br>23<br>23<br><b>24</b><br>24<br>24<br>24<br>24                                            |
| 7.1<br>7.2<br>7.3<br>7.4<br><b>8</b><br>8.1<br>8.2<br><b>9</b><br>9.1<br>9.1.1<br>9.1.2<br>9.1.3                                     | Interrupt Flags<br>Interrupt Lines                                                                                                                                                                                                                                                                                                         | 19<br>20<br>22<br><b>23</b><br>23<br>23<br><b>24</b><br>24<br>24<br>24<br>24<br>26<br>28                                      |
| 7.1<br>7.2<br>7.3<br>7.4<br><b>8</b><br>8.1<br>8.2<br><b>9</b><br>9.1<br>9.1.1<br>9.1.2<br>9.1.3<br>9.1.4                            | Interrupt Flags<br>Interrupt Lines<br>Rate Interrupts<br>Configuration Registers<br><b>Reading Data from MAX21100</b><br>Synchronous Reading<br>Asynchronous Reading<br>FIFO<br>FIFO<br>FIFO Modes Description<br>FIFO OFF Mode<br>Normal Mode<br>Interrupt Mode<br>Snapshot Mode                                                          | 19<br>20<br>22<br><b>23</b><br>23<br>23<br><b>24</b><br>24<br>24<br>24<br>24<br>24<br>28<br>30                                |
| 7.1<br>7.2<br>7.3<br>7.4<br><b>8</b><br>8.1<br>8.2<br><b>9</b><br>9.1<br>9.1.1<br>9.1.2<br>9.1.3<br>9.1.4<br>9.2                     | Interrupt Flags<br>Interrupt Lines<br>Rate Interrupts<br>Configuration Registers<br>Reading Data from MAX21100<br>Synchronous Reading<br>Synchronous Reading<br>Asynchronous Reading<br>FIFO<br>FIFO Modes Description<br>FIFO OFF Mode<br>Normal Mode<br>Interrupt Mode<br>Snapshot Mode<br>Example of FIFO Read/Write Pointers Evolution | 19<br>20<br>22<br><b>23</b><br>23<br>23<br>23<br><b>24</b><br>24<br>24<br>24<br>24<br>24<br>28<br>30<br>31                    |
| 7.1<br>7.2<br>7.3<br>7.4<br><b>8</b><br>8.1<br>8.2<br><b>9</b><br>9.1<br>9.1.1<br>9.1.2<br>9.1.3<br>9.1.4<br>9.2<br>9.3              | Interrupt Flags<br>Interrupt Lines                                                                                                                                                                                                                                                                                                         | 19<br>20<br>22<br><b>23</b><br>23<br>23<br><b>24</b><br>24<br>24<br>24<br>24<br>24<br>24<br>23<br>30<br>31<br><b>32</b>       |
| 7.1<br>7.2<br>7.3<br>7.4<br><b>8</b><br>8.1<br>8.2<br><b>9</b><br>9.1<br>9.1.1<br>9.1.2<br>9.1.3<br>9.1.4<br>9.2<br>9.3<br><b>10</b> | Interrupt Flags<br>Interrupt Lines                                                                                                                                                                                                                                                                                                         | 19<br>20<br>22<br><b>23</b><br>23<br>23<br><b>24</b><br>24<br>24<br>24<br>24<br>24<br>26<br>30<br>31<br><b>32</b><br>33<br>33 |

| 11     | Motion Merging Engine                   |     |
|--------|-----------------------------------------|-----|
| 11.1   | Sensor Fusion Algorithm                 | 36  |
| 11.2   | Rationale for the Motion Merging Engine |     |
| 11.3   | Motion Merging Engine Architecture      |     |
| 11.4   | Benefits                                |     |
| 11.5   | Operating Modes                         |     |
| 11.6   | Configuration Registers                 |     |
| 12     | Register Map                            | 40  |
| 12.1   | Register Overview                       | 40  |
| 12.1.1 | 1 Common                                | 40  |
| 12.1.2 | 2 Bank 00                               | 42  |
| 12.1.3 | 3 Bank 01                               | 43  |
| 12.1.4 | 4 Bank 02                               | 44  |
| 12.2   | Registers Description                   | 45  |
| 12.2.1 | 1 Common                                | 45  |
| 12.2.2 | 2 Bank 00                               | 73  |
| 12.2.3 | 3 Bank 01                               | 107 |
| 12.2.4 | 4 Bank 02                               | 130 |

# TABLES

| Table 1: Pin Description                                | 9  |
|---------------------------------------------------------|----|
| Table 2: I <sup>2</sup> C External Component Properties |    |
| Table 3: I <sup>2</sup> C Device Addresses              |    |
| Table 4: SPI External Component Properties              | 16 |
| Table 5: Figure 19: Motion Merging Engine Benefits      |    |
| Table 6: Motion Merging Engine Operating Modes          |    |

# **FIGURES**

| Figure 1: Block Diagram                                           | 8  |
|-------------------------------------------------------------------|----|
| Figure 2: I2C Interface Connection to an Application Processor    | 10 |
| Figure 3: START (S), STOP (P), and Repeated START (Sr) Conditions | 11 |
| Figure 4: I2C Write One Byte                                      | 12 |
| Figure 5: I <sup>2</sup> C Write a Burst of Data                  | 13 |
| Figure 6: I2C Read One Byte                                       | 14 |
| Figure 7: I <sup>2</sup> C Read a Burst of Data                   | 15 |
| Figure 8: SPI Interface Connection to an Application Processor    | 16 |
| Figure 9: SPI Protocol                                            | 17 |
| Figure 10: Rate Interrupt ranges                                  | 20 |
| Figure 11: FIFO Normal Mode, Stop on Full                         | 25 |
| Figure 12: FIFO Normal Mode, Overwrite                            | 26 |
| Figure 13: FIFO Interrupt Mode, Stop on Full                      | 27 |

| Figure 14: FIFO Interrupt Mode, Overwrite                                              | 28 |
|----------------------------------------------------------------------------------------|----|
| Figure 15: FIFO Snapshot Mode                                                          | 29 |
| Figure 16: FIFO Read/Write Pointer Evolution                                           | 30 |
| Figure 17: Simple Read-Out Sequence, No FIFO, No Interrupts                            | 33 |
| Figure 18: Simple Read-Out Sequence, FIFO Normal, No Interrupts                        | 34 |
| Figure 19: Simple Read-Out Sequence, Normal Mode, w/ Data Ready Interrupts and No FIFO | 35 |
| Figure 20: Motion Merging Engine Architecture                                          | 36 |

### **1** Introduction

MEMS sensors are revolutionizing the way people interact with everyday technology, making it easier and more user-friendly. Maxim can leverage its analog integration expertise to develop and manufacture new breakthrough MEMS sensors to decrease, operate at lower power, and perform more accurately than ever.

Owning the entire supply chain, Maxim brings its customers complete, reliable, and cost-effective solutions, ensuring prompt time-to-volume and time-to-market to effectively address high-volume applications in consumer and industrial market segments.

Thanks to its leadership in analog integration and its manufacturing experience in MEMS, Maxim is capable of high-volume production to meet the market's demands. Maxim's manufacturing expertise and highest quality standards also guarantee high performance and product reliability.

Every MEMS sensor is tested and trimmed in factory so that for most consumer applications, no additional sensor calibrations are required. The end user can quickly verify the sensor's operation without physically tilting or rotating the sensor thanks to the built-in self-test feature that accelerates the time to market for mass production.

This User Guide provides a clear picture of the guidelines for its use in consumer applications and a comprehensive description of his unique features. The final section of this guide presents the structure of the register file and the purpose of each field or every register.

### **2** Nomenclature

- **ODR** Output data rate
- BW Bandwidth
- FS Full scale
- UI User interface
- **OIS** Optical image stabilization
- MSB Most significant byte
- MSb Most significant bit
- LSB Least significant byte
- LSb Least significant bit
- HPF Highpass filter
- LPF Lowpass filter
- **dps** Degrees per seconds
- **RFU** Reserved for future use

### 3 MAX21100 Description

The MAX21100 is a monolithic 3-axis gyroscope plus 3-axis accelerometer Inertial Measurement Unit (IMU) with integrated 9-axis sensor fusion using proprietary Motion Merging Engine (MME) for handset and tablet applications, game controllers, motion remote controls, and other consumer devices. The MAX21100 is the industry's most accurate 6+3 DoF inertial measurement unit available in a 3mm x 3mm x 0.83mm package and capable of working with a supply voltage as low as 1.71V. The MAX21100 can interface an external magnetometer through a dedicated I<sup>2</sup>C master. The internal Motion Merging Engine can be flexibly configured to get the most suitable accuracy power trade-off. The MAX21100 is available in a 16-lead plastic land grid array (LGA) package and can operate within a temperature range of -40°C to +85°C.



Figure 1: Block Diagram

# **4** Pin Description

| Pin | Name              | Function                                                                                                                                                                                        |
|-----|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | V <sub>DDIO</sub> | Interface and Interrupt Pad Supply Voltage.                                                                                                                                                     |
| 2   | MST_SCL           | $I^2C$ Master Serial Clock. User-selectable $6k\Omega$ internal pullup.                                                                                                                         |
| 3   | MST_SDA           | $I^2C$ Master Serial Data. User selectable $6k\Omega$ internal pullup.                                                                                                                          |
| 4   | SCL_CLK           | SPI and I <sup>2</sup> C Slave Clock. When in I <sup>2</sup> C mode, the IO has selectable antispike filter and delay to ensure correct hold time.                                              |
| 5   | GND               | Power-Supply Ground.                                                                                                                                                                            |
| 6   | SDA_SDI_O         | SPI In/Out Pin and I <sup>2</sup> C Slave Serial Data. When in I <sup>2</sup> C mode, the IO has selectable antispike filter and delay to ensure correct hold time.                             |
| 7   | SA0_SDO           | SPI Serial Data Out and I <sup>2</sup> C Slave Address LSB.                                                                                                                                     |
| 8   | CS                | SPI Chip Select/Serial Interface Selection.                                                                                                                                                     |
| 9   | INT2              | Second Interrupt Line.                                                                                                                                                                          |
| 10  | RSV1              | Reserved. Must be connected to GND.                                                                                                                                                             |
| 11  | INT1              | First Interrupt Line.                                                                                                                                                                           |
| 12  | DSYNC             | Data Synchronization Pin. Dynamically changes the MAX21100 power mode. Synchronizes data with external clock (e.g., GPS/camera) with various options. Synchronizes data with an external event. |
| 13  | REGD              | Internal Regulator Output (2.2V max). Connect a 100nF capacitor to this pin to ensure proper device operation.                                                                                  |
| 14  | V <sub>DD</sub>   | Analog Power Supply. Bypass to GND with a $0.1\mu\text{F}$ capacitor and one $10\mu\text{F}.$                                                                                                   |
| 15  | RSV2              | Reserved. Must be tied to $V_{\text{DD}}$ in the application.                                                                                                                                   |
| 16  | RSV3              | Reserved. Leave unconnected.                                                                                                                                                                    |

# **5** I<sup>2</sup>C Interface

The MAX21100 can operate as an  $I^2C$  slave device when communicating to the system processor, which thus acts as the master. The maximum bus speed is 3.4MHz ( $I^2C$  HS); this reduces the amount of time the system processor is kept busy in supporting the exchange of data.

To connect a MAX21100 device to an I<sup>2</sup>C master, the SDA\_SDI\_O pin of the MAX21100 device must be connected to the SDA pin of the I<sup>2</sup>C master and the SCL\_CLK pin of the MAX21100 device must be connected to the SCL pin of the I<sup>2</sup>C master. Both SDA and SCL lines must be connected to a pull-up resistor. The SA0\_SDO pin must be connected to V<sub>DD</sub> or GND to configure the MAX21100 I<sup>2</sup>C slave address (see *Table 3: I2C Device Addresses*).



Figure 2: I<sup>2</sup>C Interface Connection to an Application Processor

#### Table 2: I<sup>2</sup>C External Component Properties

| Component                          | Label           | Specification                     | Quantity |
|------------------------------------|-----------------|-----------------------------------|----------|
| $V_{DD}/V_{DDIO}$ Bypass Capacitor | C1              | Ceramic, X7R, 100nF ±10%, 4V      | 2        |
| REGD Capacitor                     | C2              | Ceramic, X7R, 100nF ±10%, 2V      | 1        |
| Pullup Resistor                    | R <sub>PU</sub> | 1.1k $\Omega/10k\Omega$ (min/max) | 2        |

# **1.1** I<sup>2</sup>C Protocol

To start an  $I^2C$  request, the master sends a START condition (S), followed by the MAX21100's  $I^2C$  address. Then, the master sends the address of the register to be programmed. Finally, the master terminates the communication by issuing a STOP condition (P) to relinquish the control of the bus, or a repeated START condition (Sr) to keep controlling it.



Figure 3: START (S), STOP (P), and Repeated START (Sr) Conditions

### 1.2 Slave Address

The slave address is used to identify the MAX21100 device in  $I^2C$  communications. The address is defined as the seven most significant bits followed by the read/write bit. Set the read/write bit to 1 to request a read operation, or 0 to request a write operation (see the table below).

| I <sup>2</sup> C Base Address | SA0_SDO pin | R/W bit | Resulting Address |
|-------------------------------|-------------|---------|-------------------|
| 0x2C (6bit)                   | 0           | 0       | 0xB0              |
| 0x2C                          | 0           | 1       | 0xB1              |
| 0x2C                          | 1           | 0       | 0xB2              |
| 0x2C                          | 1           | 1       | 0xB3              |

Table 3: I<sup>2</sup>C Device Addresses

### 1.3 Acknowledge

The acknowledge bit is sent after each byte. This bit allows the receiver to notify the transmitter that the byte has been received correctly and another byte can be sent. The master generates all clock pulses, including the ninth clock pulse of the acknowledge bit (8 bits of data + acknowledge bit). To allow the receiver to send the acknowledge, the transmitter releases the SDA line during the acknowledge pulse, so that the receiver can pull the SDA line low during the ninth clock pulse to signal an acknowledge (ACK), or release the SDA line (high) to signal a not acknowledge (NACK). The NACK is sent if the device is busy or a system fault occurs. It is also used by the master to signal the end of the transfer during a read operation.

### **1.4 Register Address**

The I<sup>2</sup>C register address for the MAX21100 is composed by 6 address bits and 1 bit whose meaning can be configured as:

- **Autoincrement:** If 0, in case of burst operation the initial register address is autoincremented after every data byte; if 1, the operation is executed always on the same register.
- Even parity: This bit represents the even parity computed on the 6 bits of the register address.
- **Odd parity:** This bit represents the odd parity computed on the 6 bits of the register address.

| Bit 7 | Bit 6     | Bit 5 | Bit 4        | Bit 3          | Bit 2        | Bit 1        | Bit 0 |
|-------|-----------|-------|--------------|----------------|--------------|--------------|-------|
| N/A   | MS/parity |       | Address of t | he register yo | ou want to r | ead or write |       |

# **1.5** I<sup>2</sup>C Operations

#### 5.1.1 Write One Register

To write one register, the following steps must be executed:

- **1.** The master sends a START condition.
- 2. The master sends the slave address (7 bits) plus a write bit (low).
- **3.** If the slave address matches, the MAX21100 asserts an ACK on the data line.
- 4. The master sends the address (8 bits) of the register to be written.
- 5. The MAX21100 asserts an ACK on the data line *only if the address is valid (NACK if not)*.
- 6. The master sends 8 bits of data.
- 7. The MAX21100 asserts an ACK on the data line.
- **8.** The master generates a STOP condition.



*Figure 4: I<sup>2</sup>C Write One Byte* 

#### 5.1.2 Write Multiple Registers

To execute a write of *n* consecutive registers, the following steps must be executed:

- **1.** The master sends a START condition.
- 2. The master sends the slave address (7 bits) plus a write bit (low).
- **3.** If the slave address matches, the MAX21100 asserts an ACK on the data line.
- **4.** The master sends the register address of the first register to be written, setting the MS/parity bit to 0 if it is configured as autoincrement bit (see the <u>Register Address</u> section).
- 5. The MAX21100 asserts an ACK on the data line only if the address is valid (NACK if not).
- 6. The master sends 8 bits of data.
- 7. The MAX21100 asserts an ACK on the data line.
- 8. Repeat 6 and 7 *n* times.
- **9.** The master generates a STOP condition.



Figure 5:  $l^2 C$  Write a Burst of Data

#### 5.1.3 Read One Register

To read one register, the following steps must be executed:

- **1.** The master sends a START condition.
- 2. The master sends the slave address (7 bits) plus a write bit (low).
- **3.** If the slave address matches, the MAX21100 asserts an ACK on the data line.
- 4. The master sends the address (8 bits) of the register to be read.
- 5. The MAX21100 asserts an ACK on the data line *only if the address is valid (NACK if not)*.
- **6.** The master sends a restart condition.
- 7. The master sends the slave address (7 bits) plus a read bit (high).
- 8. If the slave address matches, the MAX21100 asserts an ACK on the data line.
- 9. The MAX21100 sends the content of the requested register (8 bits).
- **10.** The master asserts a NACK on the data line.
- **11.** The master generates a STOP condition.



Figure 6: I<sup>2</sup>C Read One Byte

#### 5.1.4 Read Multiple Registers

To execute a read of *n* consecutive registers, the following steps must be executed:

- **1.** The master sends a START condition.
- 2. The master sends the slave address (7 bits) plus a write bit (low).
- **3.** If the slave address matches, the MAX21100 asserts an ACK on the data line.
- **4.** The master sends the register address of the first register to be read, setting the MS/Parity bit to 0 if it is configured as autoincrement bit (see the *Register Address* section).
- 5. The MAX21100 asserts an ACK on the data line only if the address is valid (NACK if not).
- 6. The master sends a restart condition.
- 7. The master sends the slave address (7 bits) plus a read bit (high).
- 8. If the slave address matches, the MAX21100 asserts an ACK on the data line.
- 9. The MAX21100 sends the content of the requested register (8 bits).
- **10.** The master asserts a ACK on the data line.
- **11.** Repeat 9 and 10 *n*-1 times.
- 12. The MAX21100 sends the content of the requested register (8 bits);
- **13.** The master asserts a NACK on the data line;
- **14.** The master generates a STOP condition.



Figure 7: I<sup>2</sup>C Read a Burst of Data

# 5.2 Configuration Registers

| Field               | Description                                                                                         |
|---------------------|-----------------------------------------------------------------------------------------------------|
| <u>slv_pu_dis</u>   | Enables/disables the internal pullups of the slave pads.                                            |
| <u>strong_slave</u> | Increases the I <sup>2</sup> C slave pads speed.                                                    |
| <u>i2c_setting</u>  | Selects the master interface type.                                                                  |
| <u>i2c_off</u>      | Turns on/off the I <sup>2</sup> C interface.                                                        |
| i <u>f_parity</u>   | Sets the meaning of the bit 6 of the address during the communication from the master to the slave. |
| parity_error        | Indicates if parity error occurred                                                                  |
| parity_rst          | Triggers a reset of the parity.                                                                     |

### **6** SPI Interface

The MAX21100 SPI interface can operate up to 10MHz, in both 3-wires (half duplex) and 4-wires mode (full duplex). It is recommended to set the I2C\_OFF bit at address 0x16 if the MAX21100 is used together with other SPI devices to avoid the possibility to switch inadvertently into I<sup>2</sup>C mode when traffic is detected with the CS unasserted.

To connect a MAX21100 device to an SPI master, the CS pin of the MAX21100 device must be connected to the CSn pin of the SPI master, the SDA\_SDI\_O pin of the MAX21100 device must be connected to the MOSI pin of the SPI master, the SA0\_SDO pin of the MAX21100 device must be connected to the MISO pin of the SPI master and the SCL\_CLK pin of the MAX21100 device must be connected to the SCLK pin of the SPI master.



Figure 8: SPI Interface Connection to an Application Processor

#### Table 4: SPI External Component Properties

| Component                          | Label | Specification                | Quantity |
|------------------------------------|-------|------------------------------|----------|
| $V_{DD}/V_{DDIO}$ Bypass Capacitor | C1    | Ceramic, X7R, 100nF ±10%, 4V | 2        |
| <b>REGD</b> Capacitor              | C2    | Ceramic, X7R, 100nF ±10%, 2V | 1        |

### 6.1 SPI Protocol

CSn is the serial port enable pin and is controlled by the SPI master. It goes low at the start of the transmission and returns high at the end.

SCLK is the serial port clock and is controlled by the SPI master. It is kept high when CSn is high (no transmission). MISO and MOSI are, respectively, the serial port master data input and output. These lines are driven at the falling edge of SCLK and are sampled at the rising edge of SCLK.

Both the read register and write register commands are completed in 16 clock pulses, or in multiples of 8 in case of multiple read/write bytes.



### 6.2 Register Address

The SPI register address for the MAX21100 is composed by 6 bits of address, 1 bit to select the direction of the operation ('1' to perform a read operation, '0' to perform a write operation) and 1 bit whose meaning can be configured as:

- **Autoincrement:** If 0, in case of burst operation the initial register address is autoincremented after every data byte; if 1, the operation is executed always on the same register.
- Even parity: This bit represents the even parity computed on the 6 bits of the register address.
- Odd parity: This bit represents the odd parity computed on the 6 bits of the register address.

| Bit 7 | Bit 6     | Bit 5                                             | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-----------|---------------------------------------------------|-------|-------|-------|-------|-------|
| R/W   | MS/parity | Address of the register you want to read or write |       |       |       |       |       |

Here are shown some examples:

| Address       | Count of 1 bit | 8 bits including parity |          |  |
|---------------|----------------|-------------------------|----------|--|
|               |                | Even                    | Odd      |  |
| 000000 (0x00) | 0              | x0000000                | x1000000 |  |
| 100000 (0x20) | 1              | x1100000                | x0100000 |  |
| 100011 (0x23) | 3              | x1100011                | x0100011 |  |
| 111111 (0x3F) | 6              | x0111111                | x1111111 |  |

Bit 7, indicated with *x*, can be 0 or 1, depending on if you want to write or read the correspondent register. For further explanation:

- To write register **0x00**, using **odd parity**, send byte **01000000** (0x40) from the MCU.
- To read register 0x20, using even parity, send byte 11100000 (0xE0) from the MCU.
- To read register 0x23, using odd parity, send byte 10100011 (0xA3) from the MCU.
- To read register **0x3F**, using even parity, send byte **10111111** (0xBF) from the MCU.

If the parity mode is enabled, when the device receives the above bytes from the MCU, it tries to calculate the parity bit. The result of this computation is then reported to the user through a register field of the register map.

| Field               | Description                                                                                         |  |
|---------------------|-----------------------------------------------------------------------------------------------------|--|
| <u>slv pu dis</u>   | Enables/disables the internal pullups of the slave pads.                                            |  |
| <u>strong</u> slave | Increases the I <sup>2</sup> C slave pads speed.                                                    |  |
| i2c setting         | Selects the master interface type.                                                                  |  |
| <u>spi 3 wire</u>   | Sets the interface type of the SPI.                                                                 |  |
| <u>if parity</u>    | Sets the meaning of the bit 6 of the address during the communication from the master to the slave. |  |
| parity error        | Indicates if parity error occurred.                                                                 |  |
| parity rst          | Triggers a reset of the parity.                                                                     |  |

### 6.3 Configuration Registers

### 7 Interrupts

The MAX21100 is equipped with an interrupt module to control a set of interrupt flags and two interrupt lines (INT1 and INT2).

This module allows to:

- 1. Configure the behavior of the interrupt lines (INT1 and INT2).
- 2. Map each interrupt flag to one of both the interrupt lines.
- **3.** Create a conditional interrupt (rate interrupt) based on four thresholds.

#### 7.1 Interrupt Flags

The interrupt module provides several interrupt flags:

- **DATA\_READY:** It is triggered when a new data on the active channels is available. It can be configured to work in one of the following modalities:
  - **ALL**: It is cleared after all the active channels are read. Data are not updated until the clear operation is accomplished.
  - **ANY**: It is cleared when at least a byte of one of the active channels is read. Data are updated independently from the clear operation.
  - **STATUS**: It is cleared when status register is read. Data are not updated until the clear operation is accomplished.
- **FIFO\_EMPTY:** It is triggered when no new data on the FIFO queue is available.
- **FIFO\_OVERRUN:** It is triggered when older unread FIFO data are lost.
- **FIFO\_THRESHOLD:** It is triggered when the number of available data in FIFO exceeds a configured threshold (see the *FIFO* section).
- INT\_AND: See the <u>*Rate Interrupts*</u> section.
- INT\_OR: See the <u>*Rate Interrupts*</u> section.
- **OTP\_DOWNLOADING:** It is triggered when the OTP is being downloaded.

### 7.2 Interrupt Lines

An interrupt line is a dedicated pin where a notification to an external application processor can be provided. The MAX21100 is equipped with two interrupt lines that can be configured independently. For each interrupt line, it is possible to:

- Enable/disable them.
- Set the active level to low.
- Set the output type to push-pull or open-drain configuration.

To map an interrupt flag to an interrupt line, it is necessary to enable it through the mask registers: by setting its corresponding bit to 1 on the bit-mask, the interrupt flag is mapped to the related interrupt line. The output of the two INT1 and INT2 interrupt lines is then computed by applying the OR operator to all the enabled interrupt flags contained in latched interrupt status register. Note that the enable is not applied to the register, so it contains also the value of the interrupt flags that are not enabled.

An interrupt line can be configured to keep the status until the master requests to clear it by reading or writing the flag (latched). The lines can be also configured to autoclear its status after a period of time where the duration to clear the interrupt is programmable (timeout). The only exception is the **DATA\_READY** flag that is always unlatched regardless of the selected clearing mode.

### 7.3 Rate Interrupts

The rate interrupt allows an interrupt event to be generated when the gyroscope/accelerometer data falls inside a range of values defined by a set of thresholds. By setting the absolute value of the threshold (|TH|) for each axis, four ranges are defined:



Figure 10: Rate Interrupt ranges

For each range, it is possible to select if it contributes to the generation of the rate interrupt for each axis. Then, the rate interrupts are computed as follow:

- INT\_AND: Active if the defined conditions are satisfied for all the axes at the same time.
- **INT\_OR:** Active if the defined conditions are satisfied for at least one of the axes.

The threshold absolute value can be set by writing to the <u>INT REF X</u>, <u>INT REF Y</u>, and <u>INT REF Z</u> registers. Those registers represent the most significant byte of the real threshold; so, to compute the actual absolute value of the threshold, the register value must be multiplied by 256. If the application requires a better resolution, it is possible to specify a 16-bit threshold by setting the <u>int single ref</u> register field; in this case, all the axes share the same threshold that is defined as the combination of <u>INT REF X</u> and <u>INT REF Y</u> where the first one is the most significant byte and the last one is the least significant byte of the threshold.

Once the thresholds are defined, the <u>INT\_MSK\_X</u>, <u>INT\_MSK\_Y</u>, and <u>INT\_MSK\_Z</u> permits to select which range contributes to the generation of the rate interrupts for each *axis* as follow:

- int\_axis\_high\_pos\_en: If enabled, the condition is satisfied if the data of the axis falls in the high pos range.
- int\_axis\_high\_neg\_en: If enabled, the condition is satisfied if the data of the axis falls in the high\_neg range.
- int\_axis\_low\_pos\_en: If enabled, the condition is satisfied if the data of the axis falls in the low\_pos range.

• **int\_axis\_low\_neg\_en:** If enabled, the condition is satisfied if the data of the axis falls in the low\_neg range.

Then, the desired axes must be enabled by setting to 1 the corresponding bit of the <u>int mask xyz and</u> for the **INT\_AND** and <u>int mask xyz or</u> for the **INT\_OR**.

Through the <u>INT MSK X</u>, <u>INT MSK Y</u>, and <u>INT MSK Z</u> registers, it is also possible to read the current value of the conditions, regardless of the content of the <u>int mask xyz or</u> and <u>int mask xyz and</u> register fields. Each of these values can be configured as latched by setting the <u>int freeze</u> register field. For the rate interrupts, it is possible also to define a debounce value by defining the number of samples the axis data has to satisfy the condition before asserting the corresponding interrupt. Those values can be set in the <u>INT DEB X</u>, <u>INT DEB Y</u>, and <u>INT DEB Z</u> registers. If the required value is greater than 255, it is possible to define a 16-bit debounce value by setting <u>int single deb</u> register field; in this case, all the conditions share the same debounce value that is defined as the combination of <u>INT DEB X</u> and <u>INT DEB Y</u>, where the first one is the most significant byte and the last one is the least significant byte of the debounce value.

# 7.4 Configuration Registers

| Function       | Register/Field                                        | Description                                                                          |  |
|----------------|-------------------------------------------------------|--------------------------------------------------------------------------------------|--|
| Pads           | <u>int1 pd en, int1 pu en</u>                         | Enable/disable the internal pullup/down of the INT1 pad.                             |  |
|                | <u>int2 pd en, int2 pu en</u>                         | Enable/disable the internal pullup/down of the INT2 pad.                             |  |
|                | strong_int_aux                                        | Increases the interrupt pads speed.                                                  |  |
|                | <u>dr_rst_mode</u>                                    | Sets the DATA_READY interrupt reset and data-out update mode.                        |  |
|                | INT CFG 2                                             | INT1/INT2 generic configuration register                                             |  |
| Functional     | INT_TMO                                               | Interrupts latch mode and duration (timeout) configuration                           |  |
| Functional     | INT_STS_UL, INT_STS                                   | Interrupt status (unlatched and latched)                                             |  |
|                | INT MSK                                               | Interrupt enables                                                                    |  |
|                | <u>msk acc int d rdy,</u><br><u>msk gyr int d rdy</u> | Enable the gyroscope/accelerometer contribution to<br>DATA_READY interrupt assertion |  |
|                | <u>INT_REF_X, INT_REF_Y,</u><br>I <u>NT_REF_Z</u>     | Rate interrupt thresholds for each axis                                              |  |
|                | INT_DEB_X, INT_DEB_Y,<br>INT_DEB_Z                    | Rate interrupt debounce value for each axis                                          |  |
| Rate Interrupt | <u>INT MSK X,</u><br>INT MSK Y, INT MSK Z             | Rate interrupt thresholds ranges enables and status registers for each axis          |  |
|                | <u>int_freeze</u>                                     | Rate interrupt latch configuration                                                   |  |
|                | <u>int_mask_xyz_and,</u><br>int_mask_xyz_or           | Axis enables for INT_AND and INT_OR, respectively                                    |  |
|                | <u>sns intp_fsc</u>                                   | Gyroscope full-scale used by the rate interrupt                                      |  |
|                | <u>sns_intp_hpf</u>                                   | Gyroscope HPF used by the rate interrupt                                             |  |
|                | int_single_ref                                        | Enable a single, 16-bit rate interrupt threshold for all the axes                    |  |
|                | int_single_deb                                        | Enable a single, 16-bit rate interrupt debounce value for all the axes               |  |
|                | <u>int src cfq</u>                                    | Select the rate interrupt source                                                     |  |

# 8 Reading Data from MAX21100

The MAX21100 sensor output data can be read by the host processor in two different mechanisms: synchronous (polling) and asynchronous (interrupt) reading methods.

### 8.1 Synchronous Reading

In synchronous reading, the host actively samples the status of the <u>gyro</u> <u>dr</u> and <u>acc</u> <u>dr</u> flags to check the status of the data output. When one (or both) of them is set, a new data is ready to be read, so the host can read the new data related to the asserted flag from the output registers.

### 8.2 Asynchronous Reading

In asynchronous reading, the host does not need to continuously monitor the status of the data output, because the data availability is notified through the interrupt line.

Only after the **DATA\_READY** interrupt is asserted, the host can read the <u>*ayro dr*</u> and <u>*acc dr*</u> flags to verify which data are available and then read the corresponding output registers.

It is possible to configure which sensor (gyroscope or accelerometer) contributes to the **DATA\_READY** interrupt assertion. If both the gyroscope and accelerometer are mapped to the **DATA\_READY** signal, the interrupt is asserted when a new data of at least one sensor is available.

# 9 FIFO

The MAX21100 embeds a 128-byte data FIFO. This allows a consistent power saving for the system since the host processor does not need to continuously extract the data from the sensor, but it can wake up only when needed and burst the data out from the FIFO. The data order in the FIFO depends on the endian setting:

ne data order in the FIFO depends on the endian setting.

- **Big Endian:** *GYRO\_X\_H, GYRO\_X\_L, GYRO\_Y\_H, GYRO\_Y\_L, GYRO\_Z\_H, GYRO\_Z\_L, ACC\_X\_H, ACC\_X\_L, ACC\_Y\_H, ACC\_Y\_L, ACC\_Z\_H, ACC\_Z\_L*
- Little Endian: *GYRO\_X\_L, GYRO\_X\_H, GYRO\_Y\_L, GYRO\_Y\_H, GYRO\_Z\_L, GYRO\_Z\_H ACC\_X\_L, ACC\_X\_H, ACC\_Y\_L, ACC\_Y\_H, ACC\_Z\_L, ACC\_Z\_H*

### 9.1 FIFO Modes Description

The FIFO buffer can work according to four main different modes: off, normal, interrupt, and snapshot. When configured in snapshot mode, it offers the ideal mechanism to capture the data following a rate interrupt event.

Both normal and Interrupt modes can be optionally configured to operate in overrun mode, depending on whether, in case of buffer underrun, newer or older data are lost.

Various FIFO status flags can be enabled to generate interrupt events on INT1/INT2 pins.

#### 9.1.1 FIFO Off Mode

In this mode, the FIFO is turned off; data are stored only in the data registers. No data are available from the FIFO if read. When the FIFO is turned off, there are two options to use the device: synchronous or asynchronous reading.

#### 9.1.2 Normal Mode

The behavior of the FIFO in normal mode varies depending on the **Overrun** setting.

The following paragraphs show a description of the behavior for both settings of the overrun. For the subsequent sections, the following descriptions are useful for the user's understanding of the FIFO:

- Write Pointer (WP): The write pointer is the address number where the next data is written in the FIFO. Whenever there is a new data is written, the write pointer is incremented by 1.
- **Read Pointer (RP):** The read pointer is the address number from where the first data in the FIFO is read. Whenever there is a new data is read, the read pointer is incremented by 1.
- **Level:** Level tells the difference between the write and read pointers, which also provides the total number of data available in the FIFO.

#### 9.1.2.1 Stop On Full

- **1.** The FIFO is turned on.
- 2. The FIFO is filled with the data at the selected output data rate (ODR).
- **3.** When the FIFO is full, an interrupt can be generated.

- **4.** When the FIFO is full, all the new incoming data is discharged. Reading only a subset of the data already stored into the FIFO keeps locked the possibility for new data to be written.
- 5. Only if all the data are read, the FIFO restarts saving data. If the communication speed is high, data loss can be prevented.
- 6. In order to prevent a FIFO full condition, the required condition is to complete the reading of the data set before the next DATA\_READY occurs.



7. If this condition is not guaranteed, data can be lost.

Figure 11: FIFO Normal Mode, Stop on Full

#### 9.1.2.2 Overwrite

- **1.** The FIFO is turned on.
- **2.** The FIFO is filled with the data at the selected ODR.
- **3.** When the FIFO is full, an interrupt can be generated.
- 4. When the FIFO is full, the oldest data will be overwritten with the new ones.
- 5. If communication speed is high, data integrity can be preserved.
- 6. To prevent a data lost condition, the requirement is to complete the reading of the data set before the next DATA\_READY occurs.
- 7. If this condition is not guaranteed, data can be overwritten.
- **8.** When an overrun condition occurs, the reading pointer is forced to the writing pointer -1 to ensure only older data are discarded and newer data have a chance to be read.



Figure 12: FIFO Normal Mode, Overwrite

#### 9.1.3 Interrupt Mode

The behavior of the FIFO in interrupt mode varies depending on the **Overrun** setting. The following paragraphs show a description of the behavior for both settings of the overrun.

#### 9.1.3.1 Stop on Full

- **1.** FIFO is initially disabled. Data is stored only in the data registers.
- 2. When a rate interrupt (either INT\_OR or INT\_AND) is generated, the FIFO is turned on automatically. It stores the data at the selected ODR.
- **3.** When the FIFO is full, all the new incoming data is discharged. Reading only a subset of the data already stored into the FIFO keeps locked the possibility for new data to be written.
- **4.** The FIFO restarts saving data only if all the data are read.
- 5. If communication speed is high, data loss can be prevented.
- **6.** To prevent a FIFO full condition, the required condition is to complete the reading of the data set before the next **DATA\_READY** occurs.
- 7. If this condition is not guaranteed, data can be lost.



Figure 13: FIFO Interrupt Mode, Stop on Full

#### 9.1.3.2 Overwrite

- **1.** The FIFO is initially disabled. Data is stored only in the data registers.
- 2. When a rate interrupt (either INT\_OR or INT\_AND) is generated, the FIFO is turned on automatically. It stores the data at the selected ODR.
- **3.** When the FIFO is full, an interrupt can be generated.
- 4. When the FIFO is full, the oldest data is overwritten with the new ones.
- 5. If communication speed is high, data integrity can be preserved.
- 6. In order to prevent a data lost condition, the required condition is to complete the reading of the data set before the next DATA\_READY occurs.
- 7. If this condition is not guaranteed, data can be overwritten.
- **8.** When an overrun condition occurs the reading pointer is forced to the writing pointer -1 to ensure only older data are discarded and newer data have a chance to be read.



Figure 14: FIFO Interrupt Mode, Overwrite

#### 9.1.4 Snapshot Mode

- **1.** The FIFO is initially in normal mode with overrun enabled.
- 2. When a rate interrupt (either INT\_OR or INT\_AND) is generated, the FIFO switches automatically to not-overrun mode. It stores the data at the selected ODR until the FIFO becomes full.
- **3.** When FIFO is full, an interrupt can be generated.
- **4.** When FIFO is full, all the new incoming data will be discharged. Reading only a subset of the data already stored into the FIFO keeps locked the possibility for new data to be written.
- 5. The FIFO restarts saving data only if all the data are read.
- **6.** If communication speed is high, data loss can be prevented.
- **7.** To prevent a FIFO full condition, the required condition is to complete the reading of the data set before the next **DATA\_READY** occurs.
- **8.** If this condition is not guaranteed, data can be lost.



Figure 15: FIFO Snapshot Mode

# 9.2 Example of FIFO Read/Write Pointers Evolution

Figure 6 assumes:

- A reading frequency roughly twice the writing frequency (ODR)
- A FIFO threshold = 126
- FIFO is in normal mode



*Figure 16: FIFO Read/Write Pointer Evolution* 

# 9.3 Configuration Registers

| Register/Field                                                                                                                                                            | Description                                                                                |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--|
| <u>fifo store qyr,</u><br><u>fifo store acc,</u><br><u>fifo store maq,</u><br><u>fifo store quat</u>                                                                      | Enable the data storage of<br>gyroscope/accelerometer/magnetometer/quaternion data in FIFO |  |
| <u>FIFO_THS</u>                                                                                                                                                           | FIFO threshold                                                                             |  |
| FIFO CFG                                                                                                                                                                  | FIFO configuration                                                                         |  |
| <u>sts ul fifo empty,</u><br><u>sts ul fifo overrun,</u><br><u>sts ul fifo ths,</u><br><u>sts i1 fifo empty,</u><br><u>sts i1 fifo overrun,</u><br><u>sts_i1 fifo_ths</u> | FIFO status interrupt                                                                      |  |
| <u>msk_i1_fifo_empty,</u><br><u>msk_i1_fifo_overrun,</u><br><u>msk_i1_fifo_ths</u>                                                                                        | FIFO interrupt enables                                                                     |  |
| <u>FIFO_COUNT</u>                                                                                                                                                         | Number of FIFO words available on FIFO                                                     |  |
| FIFO_STATUS                                                                                                                                                               | FIFO status register                                                                       |  |
| FIFO_DATA                                                                                                                                                                 | FIFO data register                                                                         |  |

# **10** Programming Example

This section includes examples for executing various operations on the device. Three functions are defined to abstract the  $SPI/I^2C$  communication:

- Write (<Register Address>, <Value>):
  Writes the <Value> to the register at the <Register Address>.
- Read (<Register Address>): Returns the value of the register at the <*Register Address>*.
- ReadBurstNoInc (<Register Address>, <count>): Returns an array of *count* elements with the result of a burst read with no autoincrement on <Register Address> register.
- ReadBurstInc (<Start Address>, <count>): Returns an array of *count* elements with the result of a burst read with autoincrement, starting from <Start Address> register address.

### 10.1 Simple Read-Out Sequence, No FIFO, No Interrupts



Figure 17: Simple Read-Out Sequence, No FIFO, No Interrupts

### **10.2** Simple Read-Out Sequence, FIFO Normal Mode, No Interrupts



Figure 18: Simple Read-Out Sequence, FIFO Normal, No Interrupts

### 10.3 Simple Readout Sequence, Normal Mode, Data Ready Interrupts



Figure 19: Simple Read-Out Sequence, Normal Mode, with Data Ready Interrupts and No FIFO

# **11** Motion Merging Engine

The MAX21100 IMU includes a Motion Merging Engine (MME) that can be used to fuse together the embedded 3-axis gyroscope and the 3-axis accelerometer, as well as for an external magnetometer that can be optionally connected to the embedded  $I^2C$  master. Using the MME reduces the host  $\mu C$  processing overhead and increases the accuracy in the angle estimation, thanks to the internal calibrated and low-jitter timing reference.

### **11.1 Sensor Fusion Algorithm**

The Sensor Fusion algorithm running in the MME is a Maxim proprietary algorithm based on the well-known complementary filter, evolved to make it as good, in most practical cases, as a Kalman Filter, typically being 1 order of magnitude more complex. Sometimes, the Maxim Adaptive Complementary filter has been proved to exceed the performances of a Kalman filter.

### 11.2 Rationale for the Motion Merging Engine

The underlying assumption for the Motion Merging Engine (MME) is that the sensor calibration (including bias compensation value calculation) typically occurs once every tenth of a second. At the opposite the evaluation of the angular information (quaternion) has be performed continuously.

As such, it makes sense that the recurring operation (fusing together accelerometer, gyroscope and magnetometer) is performed in an application specific hardware block to save processing load to the system Host, whereas the actual Bias estimation can still performed in SW once in a while, with negligible impact on the power consumption of the whole system.

This appears to be of particular relevance for embedded applications, in which the system host processing capabilities can be limited and every saved  $\mu A$  counts.

### **11.3 Motion Merging Engine Architecture**

The functional connections between the Motion Merging Engine and the other blocks in the architecture can be shown as follows:



Figure 20: Motion Merging Engine Architecture
The system host is responsible for:

- **1.** Detecting the conditions when a new calibration is needed and subsequently triggering the execution of bias calibrations algorithms.
- 2. Calculating the bias compensation values of the gyroscope and the accelerometer using various calibrations algorithms (outside the IMUs).
- 3. Writing back the bias compensation values into the Maxim IMUs.
- **4.** Implementing a SW interpolation of the bias correction to prevent the occurrence of a step correction when the bias correction change can determine an observable discontinuity on the output bias-compensated raw data signal.
- 5. Applying the appropriate bias compensation configuration to select the desired behavior (e.g., whether the bias correction should be applied only data going to the MME or to the raw data as well).
- 6. Configuring the sensors and turning them ON with the required power mode.
- 7. Configuring the MME operating mode (G, G+A, A+M, G+A+M).
- 8. Configuring the MME parameters (ODR, alphas, etc.).
- **9.** Enable the MME.

The Maxim IMUs would be accordingly responsible for:

- 1. Applying the bias compensation values to the data going to the data registers and to the FIFO, if configured to do so.
- 2. Applying the bias compensation values to the data going to the MME, if configured to do so.
- 3. Applying the bias compensation values to the data going to the MCS, if configured to do so.
- 4. Calculating the quaternion output or, in alternative, the equivalent (gravity; heading) pair.

### 11.4 Benefits

Using the MME is beneficial is terms of:

| Benefit                                | Description                                                                                                                                                                                                                                                                                                                                                 |
|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Low Power                              | The calculation of the quaternion carrying the information about the angular<br>orientation is performed on a small and specifically designed power optimized DSP.<br>The power advantage of the embedded DSP becomes even more evident when the<br>gyroscope output data rate increases, as necessary to increase the quaternion<br>calculation accuracy.  |
| Higher Timing<br>Accuracy              | The transformation of the rate (rotational speed) into an angle requires integration over time. For this operation to be done in SW without loss of accuracy, a number of conditions have to be met, including the accurate measurement of the ODR made in SW and the need to not miss any data.                                                            |
| Higher Integration<br>Accuracy         | It can be proved that to achieve higher accuracy in the quaternion calculation, the gyroscope ODR has to be preferably increased up to 1kHz for optimum performances. At such an ODR, the power consumption necessary to perform the calculation increases dramatically (tenths on mA), whilst in the MME it keeps in the tenths on $\mu$ A range.          |
| Embedded Low<br>Power PDR<br>Precursor | Having the capability to calculate the angular information inside the sensor means<br>that the application processor and the sensor hub can be turned off completely for<br>an extended amount of time, as the IMUs would keep calculating the quaternion<br>and would save it in the FIFO whenever appropriate (i.e., in correspondence of a<br>new step). |

### **11.5 Operating Modes**

Depending on a number of factors, the MME can be configured for a given application in a different mode, as summarized in Table 6:

Table 6: Motion Merging Engine Operating Modes

| Mode                                      | Description                                                                                                                                                                                                                                       | Benefits                                                                         | Downsides                                                                                                                                                                                                                                                                    |
|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Gyro Only                                 | The MME is used to integrate the gyro signal only                                                                                                                                                                                                 | Inherent immunity<br>to magnetic<br>disturbances and<br>linear<br>accelerations. | Can require additional<br>processing in SW to<br>compensate the gyro errors<br>as well as integration errors<br>over x, y, and z.                                                                                                                                            |
| Gyro +<br>Accelerometer                   | The MME uses the<br>accelerometer to compensate<br>for the gyro bias over x and y.<br>This corresponds to the Rotation<br>Vector sensor in Android.                                                                                               | Inherent immunity<br>to magnetic<br>disturbances.                                | Can require additional<br>processing in SW to<br>compensate the gyro errors<br>as well as integration errors<br>z.<br>Some sensitivity to linear<br>accelerations left.                                                                                                      |
| Gyro +<br>Accelerometer +<br>Magnetometer | The MME uses the<br>accelerometer to compensate<br>for the gyro bias over x and y.<br>The MME uses the<br>magnetometer to compensate<br>for the gyro bias over z.<br>This corresponds to the<br>Geomagnetic Rotation Vector<br>sensor in Android. | Highest accuracy                                                                 | Does not account for soft<br>iron effects.<br>Can be subject to magnetic<br>disturbances, if present.                                                                                                                                                                        |
| Accelerometer +<br>Magnetometer           | The MME generates at ultra-low<br>power levels the quaternions<br>using only the accelerometer<br>and the magnetometer (so-<br>called Virtual Gyroscope)                                                                                          | Lowest power                                                                     | Noisy, lag noticeable,<br>artifacts may be present.<br>Does not account for soft<br>iron effects.<br>May be subject to magnetic<br>disturbances, if present.<br>Suitable only for movements<br>with limited bandwidth in an<br>environment without<br>magnetic disturbances. |

### **11.6 Configuration Registers**

| Register/Field     | Description                 |
|--------------------|-----------------------------|
| FUS CFG0, FUS CFG1 | MME configuration registers |

### **12** Register Map

The following sections illustrate the register map of the device. When not specified differently, register/field values are expressed in binary format.

### **12.1 Register Overview**

### 12.1.1Common

| Name                 | Address | Access | Default  | Description                                    |
|----------------------|---------|--------|----------|------------------------------------------------|
| WHO AM I             | 0x20    | R      | 10110010 | Device ID                                      |
| <u>REVISION ID</u>   | 0x21    | R      | 00000000 | Revision ID register                           |
| <u>BANK_SELECT</u>   | 0x22    | R/W    | 00000000 | Register bank selection                        |
| <u>SYSTEM_STATUS</u> | 0x23    | R      | 00000000 | System Status register                         |
| <u>GYRO X H</u>      | 0x24    | R      | 00000000 | Bits [15:8] of the gyroscope X measurement     |
| <u>GYRO X L</u>      | 0x25    | R      | 00000000 | Bits [7:0] of the gyroscope X measurement      |
| <u>GYRO Y H</u>      | 0x26    | R      | 00000000 | Bits [15:8] of the gyroscope Y<br>measurement  |
| <u>GYRO Y L</u>      | 0x27    | R      | 00000000 | Bits [7:0] of the gyroscope Y measurement      |
| <u>GYRO_Z_H</u>      | 0x28    | R      | 00000000 | Bits [15:8] of the gyroscope Z measurement     |
| <u>GYRO_Z_L</u>      | 0x29    | R      | 00000000 | Bits [7:0] of the gyroscope Z measurement      |
| <u>АСС_Х_Н</u>       | 0x2A    | R      | 00000000 | Bits [15:8] of the accelerometer X measurement |
| <u>ACC X L</u>       | 0x2B    | R      | 00000000 | Bits [7:0] of the accelerometer X measurement  |
| <u>ACC_Y_H</u>       | 0x2C    | R      | 00000000 | Bits [15:8] of the accelerometer Y measurement |
| <u>ACC Y L</u>       | 0x2D    | R      | 00000000 | Bits [7:0] of the accelerometer Y measurement  |
| <u>ACC_Z_H</u>       | 0x2E    | R      | 00000000 | Bits [15:8] of the accelerometer Z measurement |
| <u>ACC Z L</u>       | 0x2F    | R      | 00000000 | Bits [7:0] of the accelerometer Z measurement  |
| <u>MAG X H</u>       | 0x30    | R      | 00000000 | Bits [15:8] of the magnetometer X measurement  |
| <u>MAG_X_L</u>       | 0x31    | R      | 00000000 | Bits [7:0] of the magnetometer X measurement   |
| <u>MAG Y H</u>       | 0x32    | R      | 00000000 | Bits [15:8] of the magnetometer Y measurement  |

| <u>MAG_Y_L</u>     | 0x33 | R   | 00000000 | Bits [7:0] of the magnetometer Y measurement  |
|--------------------|------|-----|----------|-----------------------------------------------|
| <u>MAG Z H</u>     | 0x34 | R   | 00000000 | Bits [15:8] of the magnetometer Z measurement |
| <u>MAG Z L</u>     | 0x35 | R   | 00000000 | Bits [7:0] of the magnetometer Z measurement  |
| <u>TEMP_H</u>      | 0x36 | R   | 00000000 | Bits [15:8] of the temperature measurement    |
| <u>TEMP L</u>      | 0x37 | R   | 00000000 | Bits [7:0] of the temperature measurement     |
| <u>FIFO_COUNT</u>  | 0x3C | R   | 00000000 | Available number of FIFO samples for data set |
| <u>FIFO_STATUS</u> | 0x3D | R   | 00000000 | FIFO status flags                             |
| <u>FIFO_DATA</u>   | 0x3E | R/W | 00000000 | FIFO data, to be read in burst mode           |
| <u>RST_REG</u>     | 0x3F | R/W | 00000000 | Reset register                                |

### 12.1.2Bank 00

| Name                 | Address | Access | Default  | Description                              |
|----------------------|---------|--------|----------|------------------------------------------|
| POWER CFG            | 0x00    | R/W    | 00000111 | Power mode configuration                 |
| <u>GYRO CFG1</u>     | 0x01    | R/W    | 00101000 | Gyroscope configuration register 1       |
| <u>GYRO CFG2</u>     | 0x02    | R/W    | 00000100 | Gyroscope configuration register 2       |
| <u>GYRO_CFG3</u>     | 0x03    | R/W    | 00000000 | Gyroscope configuration register 3       |
| PWR ACC CFG          | 0x04    | R/W    | 11000111 | Accelerometer power configuration.       |
| ACC_CFG_1            | 0x05    | R/W    | 00000010 | Accelerometer configuration register 1   |
| ACC_CFG_2            | 0x06    | R/W    | 00000000 | Accelerometer configuration register 2   |
| MAG SLV CFG          | 0x07    | R/W    | 00000110 | Magnetometer slave configuration         |
| MAG SLV ADD          | 0x08    | R/W    | 00000000 | Magnetometer slave address               |
| MAG SLV REG          | 0x09    | R/W    | 00000000 | Magnetometer slave register              |
| MAG MAP REG          | 0x0A    | R/W    | 00000000 | Magnetometer mapping register            |
| <u>I2C MST ADD</u>   | 0x0B    | R/W    | 00000000 | I <sup>2</sup> C master register address |
| <u>I2C MST RW</u>    | 0x0C    | R/W    | 00000000 | I <sup>2</sup> C master register data.   |
| MAG_OFS_X_MSB        | 0x0D    | R/W    | 00000000 | Magnetometer offset X, MSB               |
| <u>MAG_OFS_X_LSB</u> | 0x0E    | R/W    | 00000000 | Magnetometer offset X, LSB               |
| MAG_OFS_Y_MSB        | 0x0F    | R/W    | 00000000 | Magnetometer offset Y, MSB               |
| MAG OFS Y LSB        | 0x10    | R/W    | 00000000 | Magnetometer offset Y, LSB               |
| MAG OFS Z MSB        | 0x11    | R/W    | 00000000 | Magnetometer offset Z, MSB               |
| MAG OFS Z LSB        | 0x12    | R/W    | 00000000 | Magnetometer offset Z, LSB               |
| <u>DR CFG</u>        | 0x13    | R/W    | 00000001 | Data ready configuration                 |
| <u>IO CFG</u>        | 0x14    | R/W    | 00000000 | Input/output configuration               |
| <u>I2C_PAD</u>       | 0x15    | R/W    | 00000100 | PADs configuration                       |
| <u>12C_CFG</u>       | 0x16    | R/W    | 00000000 | Serial interfaces configuration          |
| <u>FIFO_THS</u>      | 0x17    | R/W    | 00000000 | FIFO threshold configuration             |
| <u>FIFO_CFG</u>      | 0x18    | R/W    | 00000000 | FIFO mode configuration                  |
| DSYNC CFG            | 0x1A    | R/W    | 00000000 | DSYNC configuration                      |
| DSYNC CNT            | Ox1B    | R/W    | 00000000 | DSYNC counter                            |
| <u>ITF OTP</u>       | 0x1C    | R/W    | 00000000 | Serial interfaces and OTP control        |

### 12.1.3Bank 01

| Name              | Address | Access | Default  | Description                        |
|-------------------|---------|--------|----------|------------------------------------|
| <u>INT REF X</u>  | 0x00    | R/W    | 00000000 | Interrupt reference for X axis     |
| <u>INT REF Y</u>  | 0x01    | R/W    | 00000000 | Interrupt reference for Y axis     |
| <u>INT REF Z</u>  | 0x02    | R/W    | 00000000 | Interrupt reference for Z axis     |
| <u>INT_DEB_X</u>  | 0x03    | R/W    | 00000000 | Interrupt debounce, X axis         |
| <u>INT DEB Y</u>  | 0x04    | R/W    | 00000000 | Interrupt debounce, Y axis         |
| <u>INT_DEB_Z</u>  | 0x05    | R/W    | 00000000 | Interrupt debounce, Z axis         |
| <u>INT_MSK_X</u>  | 0x06    | R/W    | 00000000 | Interrupt mask, X axis zones       |
| <u>INT MSK Y</u>  | 0x07    | R/W    | 00000000 | Interrupt mask, Y axis zones       |
| <u>INT MSK Z</u>  | 0x08    | R/W    | 00000000 | Interrupt mask, Z axis zones       |
| INT MASK AO       | 0x09    | R/W    | 00000000 | Interrupt masks, and/or            |
| INT CFG 1         | 0x0A    | R/W    | 00000000 | Interrupt Configuration register 1 |
| INT CFG 2         | 0x0B    | R/W    | 00100100 | Interrupt Configuration register 2 |
| <u>INT TMO</u>    | 0x0C    | R/W    | 00000000 | Interrupt timeout                  |
| <u>INT_STS_UL</u> | 0x0D    | R      | 00000000 | Interrupt sources, unlatched       |
| <u>INT_STS</u>    | 0x0E    | R      | 00000000 | Interrupt Status register          |
| <u>INT_MSK</u>    | 0x0F    | R/W    | 10000010 | Interrupt Mask register            |
| INT SRC SEL       | 0x17    | R/W    | 00111100 | Interrupt source selection         |
| <u>SERIAL 5</u>   | 0x1A    | R      | 00000000 | Unique serial number, byte 5       |
| <u>SERIAL 4</u>   | 0x1B    | R      | 00000000 | Unique serial number, byte 4       |
| <u>SERIAL 3</u>   | 0x1C    | R      | 00000000 | Unique serial number, byte 3       |
| <u>SERIAL 2</u>   | 0x1D    | R      | 00000000 | Unique serial number, byte 2       |
| <u>SERIAL_1</u>   | 0x1E    | R      | 00000000 | Unique serial number, byte 1       |
| <u>SERIAL_0</u>   | 0x1F    | R      | 00000000 | Unique serial number, byte 0       |

### 12.1.4Bank 02

| Name                 | Address | Access | Default  | Description                                  |
|----------------------|---------|--------|----------|----------------------------------------------|
| <u>QUATO_H</u>       | 0x00    | R      | 00000000 | Bits [15:8] of the quaternion 0 measurement. |
| <u>QUATO L</u>       | 0x01    | R      | 00000000 | Bits [7:0] of the quaternion 0 measurement.  |
| <u>QUAT1 H</u>       | 0x02    | R      | 00000000 | Bits [15:8] of the quaternion 1 measurement. |
| <u>QUAT1_L</u>       | 0x03    | R      | 00000000 | Bits [7:0] of the quaternion 1 measurement.  |
| <u>QUAT2 H</u>       | 0x04    | R      | 00000000 | Bits [15:8] of the quaternion 2 measurement. |
| <u>QUAT2 L</u>       | 0x05    | R      | 00000000 | Bits [7:0] of the quaternion 2 measurement.  |
| <u>QUAT3 H</u>       | 0x06    | R      | 00000000 | Bits [15:8] of the quaternion 3 measurement. |
| <u>QUAT3_L</u>       | 0x07    | R      | 00000000 | Bits [7:0] of the quaternion 3 measurement.  |
| <u>BIAS_GYRO_X_H</u> | 0x13    | R/W    | 00000000 | Gyroscope bias compensation, X axis, MSB     |
| BIAS GYRO X L        | 0x14    | R/W    | 00000000 | Gyroscope bias compensation, X axis, LSB     |
| <u>BIAS_GYRO_Y_H</u> | 0x15    | R/W    | 00000000 | Gyroscope bias compensation, Y axis, MSB     |
| <u>BIAS GYRO Y L</u> | 0x16    | R/W    | 00000000 | Gyroscope bias compensation, Y axis, LSB     |
| <u>BIAS GYRO Z H</u> | 0x17    | R/W    | 00000000 | Gyroscope bias compensation, Z axis, MSB     |
| <u>BIAS GYRO Z L</u> | 0x18    | R/W    | 00000000 | Gyroscope bias compensation, Z axis, LSB     |
| <u>BIAS ACC X</u>    | 0x19    | R/W    | 00000000 | Accelerometer bias compensation, X axis      |
| <u>BIAS ACC Y</u>    | 0x1A    | R/W    | 00000000 | Accelerometer bias compensation, Y axis      |
| <u>BIAS_ACC_Z</u>    | Ox1B    | R/W    | 00000000 | Accelerometer bias compensation, Z axis      |
| <u>FUS_CFG0</u>      | 0x1C    | R/W    | 00000000 | MME configuration register 1                 |
| FUS_CFG1             | 0x1D    | R/W    | 01011000 | MME configuration register 2                 |
| <u>GYR ODR TRIM</u>  | 0x1F    | R      | 01110000 | Gyroscope ODR correction factor register     |

### **12.2** Registers Description

### 12.2.1 Common

### WHO\_AM\_I

| Address | Common - 0x20 (Hex) - 32 (Dec) |  |  |      |      |  |  |  |  |  |
|---------|--------------------------------|--|--|------|------|--|--|--|--|--|
| Bit     | 7 6 5 4 3 2 1 0                |  |  |      |      |  |  |  |  |  |
| Fields  | —                              |  |  |      |      |  |  |  |  |  |
| Access  | R                              |  |  |      |      |  |  |  |  |  |
| Default |                                |  |  | 1011 | 0010 |  |  |  |  |  |

#### Description

*Device ID.* Identifier of the product family.

# **REVISION\_ID**

| Address | Common - 0x21 (Hex) - 33 (Dec) |  |  |  |  |  |  |  |  |
|---------|--------------------------------|--|--|--|--|--|--|--|--|
| Bit     | 7 6 5 4 3 2 1 0                |  |  |  |  |  |  |  |  |
| Fields  | _                              |  |  |  |  |  |  |  |  |
| Access  | R                              |  |  |  |  |  |  |  |  |
| Default | 0000000                        |  |  |  |  |  |  |  |  |

### Description

*Revision ID register.* Identifier of the silicon revision.

### BANK\_SELECT

| Address |              | Common - 0x22 (Hex) - 34 (Dec) |    |   |          |   |   |   |  |  |  |
|---------|--------------|--------------------------------|----|---|----------|---|---|---|--|--|--|
| Bit     | 7            | 6                              | 5  | 4 | 3        | 2 | 1 | 0 |  |  |  |
| Fields  | trim_bank_en | RFU                            | RF | U | bank_sel |   |   |   |  |  |  |
| Access  | R            | R                              | R  |   | R/W      |   |   |   |  |  |  |
| Default | 0            | -                              | _  | - | 0000     |   |   |   |  |  |  |

#### Description

Register bank selection.

#### **Fields**

trim\_bank\_en: Enables test banks read/write operations.

0: Disabled 1: Enabled

*bank\_sel:* Allows addressing 3 pages of registers, other than the common bank. Pages are 32 bytes sized.

0000: Bank 0 0001: Bank 1 0010: Bank 2

Back to Register Overview

### SYSTEM\_STATUS

| Address |          | Common - 0x23 (Hex) - 35 (Dec) |          |         |         |        |          |         |  |  |  |
|---------|----------|--------------------------------|----------|---------|---------|--------|----------|---------|--|--|--|
| Bit     | 7        | 6                              | 5        | 4       | 3       | 2      | 1        | 0       |  |  |  |
| Fields  | quat_err | quat_dr                        | magn_err | magn_dr | acc_err | acc_dr | gyro_err | gyro_dr |  |  |  |
| Access  | R        | R                              | R        | R       | R       | R      | R        | R       |  |  |  |
| Default | 0        | 0                              | 0        | 0       | 0       | 0      | 0        | 0       |  |  |  |

#### Description

System Status Register.

#### **Fields**

- *quat\_err:* Quaternion output error: It goes high when a new quaternion data is generated before or during data reading.
- quat\_dr: Quaternion output available: It goes high when a new set of quaternion data is available.
- *magn\_err:* Magnetometer output error: It goes high when a new accelerometer data is generated before or during data reading.
- *magn\_dr:* Magnetometer output available: It goes high when a new set of accelerometer data is available.
  - *acc\_err:* Accelerometer output error: It goes high when a new accelerometer data is generated before or during data reading.
  - acc\_dr: Accelerometer output available: It goes high when a new set of accelerometer data is available.
- gyro\_err: Gyroscope output error: It goes high when a new gyroscope data is generated before or during data reading.
- gyro\_dr: Gyroscope output available: It goes high when a new set of gyroscope data is available.

## GYRO\_X\_H

| Address | Common - 0x24 (Hex) - 36 (Dec) |                 |  |      |      |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|------|------|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |      |      |  |  |  |  |  |
| Fields  | —                              |                 |  |      |      |  |  |  |  |  |
| Access  |                                |                 |  | F    | R    |  |  |  |  |  |
| Default |                                |                 |  | 0000 | 0000 |  |  |  |  |  |

### Description

Bits [15:8] of the gyroscope X measurement. Most significant byte of the X axis gyroscope data.

# GYRO\_X\_L

| Address | Common - 0x25 (Hex) - 37 (Dec) |                 |  |      |      |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|------|------|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |      |      |  |  |  |  |  |
| Fields  | —                              |                 |  |      |      |  |  |  |  |  |
| Access  |                                |                 |  | F    | R    |  |  |  |  |  |
| Default |                                |                 |  | 0000 | 0000 |  |  |  |  |  |

### Description

Bits [7:0] of the gyroscope X measurement. Least significant byte of the X axis gyroscope data.

## GYRO\_Y\_H

| Address | Common - 0x26 (Hex) - 38 (Dec) |                 |  |       |      |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|-------|------|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |       |      |  |  |  |  |  |
| Fields  |                                | —               |  |       |      |  |  |  |  |  |
| Access  |                                |                 |  | R     | ł    |  |  |  |  |  |
| Default |                                |                 |  | 00000 | 0000 |  |  |  |  |  |

#### Description

*Bits [15:8] of the gyroscope Y measurement.* Most significant byte of the Y axis gyroscope data.

# GYRO\_Y\_L

| Address | Common - 0x27 (Hex) - 39 (Dec) |                 |  |      |      |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|------|------|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |      |      |  |  |  |  |  |  |
| Fields  | —                              |                 |  |      |      |  |  |  |  |  |  |
| Access  |                                |                 |  | F    | 2    |  |  |  |  |  |  |
| Default |                                |                 |  | 0000 | 0000 |  |  |  |  |  |  |

### Description

*Bits* [7:0] of the gyroscope Y measurement. Least significant byte of the Y axis gyroscope data.

# GYRO\_Z\_H

| Address |   | Common - 0x28 (Hex) - 40 (Dec) |  |       |      |  |  |  |  |  |  |
|---------|---|--------------------------------|--|-------|------|--|--|--|--|--|--|
| Bit     | 7 | 7 6 5 4 3 2 1 0                |  |       |      |  |  |  |  |  |  |
| Fields  | — |                                |  |       |      |  |  |  |  |  |  |
| Access  |   |                                |  | R     | ł    |  |  |  |  |  |  |
| Default |   |                                |  | 00000 | 0000 |  |  |  |  |  |  |

#### Description

*Bits [15:8] of the gyroscope Z measurement.* Most significant byte of the Z axis gyroscope data.

# GYRO\_Z\_L

| Address | Common - 0x29 (Hex) - 41 (Dec) |                 |  |      |      |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|------|------|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |      |      |  |  |  |  |  |  |
| Fields  | —                              |                 |  |      |      |  |  |  |  |  |  |
| Access  |                                |                 |  | F    | 2    |  |  |  |  |  |  |
| Default |                                |                 |  | 0000 | 0000 |  |  |  |  |  |  |

### Description

*Bits* [7:0] of the gyroscope Z measurement. Least significant byte of the Z axis gyroscope data.

# $\mathsf{ACC}\_\mathsf{X}\_\mathsf{H}$

| Address | Common - 0x2A (Hex) - 42 (Dec) |                 |  |      |      |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|------|------|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |      |      |  |  |  |  |  |
| Fields  |                                | —               |  |      |      |  |  |  |  |  |
| Access  |                                |                 |  | F    | R    |  |  |  |  |  |
| Default |                                |                 |  | 0000 | 0000 |  |  |  |  |  |

### Description

*Bits [15:8] of the accelerometer X measurement.* Most significant byte of the X axis accelerometer data.

# $\mathsf{ACC}\_\mathsf{X}\_\mathsf{L}$

| Address | Common - 0x2B (Hex) - 43 (Dec) |                 |  |      |      |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|------|------|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |      |      |  |  |  |  |  |  |
| Fields  |                                | —               |  |      |      |  |  |  |  |  |  |
| Access  |                                |                 |  | F    | 2    |  |  |  |  |  |  |
| Default |                                |                 |  | 0000 | 0000 |  |  |  |  |  |  |

### Description

Bits [7:0] of the accelerometer X measurement. Least significant byte of the X axis accelerometer data.

# $\mathsf{ACC}_Y_\mathsf{H}$

| Address | Common - 0x2C (Hex) - 44 (Dec) |                 |  |      |      |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|------|------|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |      |      |  |  |  |  |  |
| Fields  |                                | —               |  |      |      |  |  |  |  |  |
| Access  |                                |                 |  | F    | R    |  |  |  |  |  |
| Default |                                |                 |  | 0000 | 0000 |  |  |  |  |  |

### Description

*Bits [15:8] of the accelerometer Y measurement.* Most significant byte of the Y axis accelerometer data.

# $\mathsf{ACC}\_\mathsf{Y}\_\mathsf{L}$

| Address | Common - 0x2D (Hex) - 45 (Dec) |                 |  |      |      |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|------|------|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |      |      |  |  |  |  |  |  |
| Fields  |                                | —               |  |      |      |  |  |  |  |  |  |
| Access  |                                |                 |  | F    | 2    |  |  |  |  |  |  |
| Default |                                |                 |  | 0000 | 0000 |  |  |  |  |  |  |

### Description

Bits [7:0] of the accelerometer Y measurement. Least significant byte of the Y axis accelerometer data.

## $\mathsf{ACC}\_\mathsf{Z}\_\mathsf{H}$

| Address | Common - 0x2E (Hex) - 46 (Dec) |                 |  |  |  |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|--|--|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |  |
| Fields  |                                | —               |  |  |  |  |  |  |  |  |  |
| Access  |                                | R               |  |  |  |  |  |  |  |  |  |
| Default |                                | 0000000         |  |  |  |  |  |  |  |  |  |

### Description

*Bits* [15:8] of the accelerometer Z measurement. Most significant byte of the Z axis accelerometer data.

### ACC\_Z\_L

| Address | Common - 0x2F (Hex) - 47 (Dec) |                 |  |  |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|--|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |
| Fields  | —                              |                 |  |  |  |  |  |  |  |  |
| Access  |                                | R               |  |  |  |  |  |  |  |  |
| Default |                                | 0000000         |  |  |  |  |  |  |  |  |

### Description

*Bits* [7:0] *of the accelerometer Z measurement.* Least significant byte of the Z axis accelerometer data.

### MAG\_X\_H

| Address | Common - 0x30 (Hex) - 48 (Dec) |                 |  |  |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|--|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |
| Fields  |                                | —               |  |  |  |  |  |  |  |  |
| Access  |                                | R               |  |  |  |  |  |  |  |  |
| Default |                                | 0000000         |  |  |  |  |  |  |  |  |

#### Description

*Bits [15:8] of the magnetometer X measurement.* Most significant byte of the X axis magnetometer data.

## $\mathsf{MAG}\_\mathsf{X}\_\mathsf{L}$

| Address | Common - 0x31 (Hex) - 49 (Dec) |                 |  |  |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|--|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |
| Fields  | —                              |                 |  |  |  |  |  |  |  |  |
| Access  |                                | R               |  |  |  |  |  |  |  |  |
| Default |                                | 0000000         |  |  |  |  |  |  |  |  |

### Description

Bits [7:0] of the magnetometer X measurement. Least significant byte of the X axis magnetometer data.

# MAG\_Y\_H

| Address | Common - 0x32 (Hex) - 50 (Dec) |                 |  |       |      |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|-------|------|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |       |      |  |  |  |  |  |
| Fields  | —                              |                 |  |       |      |  |  |  |  |  |
| Access  |                                | R               |  |       |      |  |  |  |  |  |
| Default |                                |                 |  | 00000 | 0000 |  |  |  |  |  |

#### Description

*Bits [15:8] of the magnetometer Y measurement.* Most significant byte of the Y axis magnetometer data.

# $\mathsf{MAG}\_\mathsf{Y}\_\mathsf{L}$

| Address | Common - 0x33 (Hex) - 51 (Dec) |                 |  |  |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|--|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |
| Fields  | —                              |                 |  |  |  |  |  |  |  |  |
| Access  |                                | R               |  |  |  |  |  |  |  |  |
| Default |                                | 0000000         |  |  |  |  |  |  |  |  |

### Description

Bits [7:0] of the magnetometer Y measurement. Least significant byte of the Y axis magnetometer data.

### MAG\_Z\_H

| Address | Common - 0x34 (Hex) - 52 (Dec) |                 |  |  |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|--|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |
| Fields  | —                              |                 |  |  |  |  |  |  |  |  |
| Access  |                                | R               |  |  |  |  |  |  |  |  |
| Default |                                | 0000000         |  |  |  |  |  |  |  |  |

#### Description

*Bits [15:8] of the magnetometer Z measurement.* Most significant byte of the Z axis magnetometer data.

### MAG\_Z\_L

| Address | Common - 0x35 (Hex) - 53 (Dec) |                 |  |  |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|--|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |
| Fields  |                                | —               |  |  |  |  |  |  |  |  |
| Access  |                                | R               |  |  |  |  |  |  |  |  |
| Default |                                | 0000000         |  |  |  |  |  |  |  |  |

### Description

*Bits [7:0] of the magnetometer Z measurement.* Least significant byte of the Z axis magnetometer data.

### TEMP\_H

| Address | Common - 0x36 (Hex) - 54 (Dec) |                 |  |  |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|--|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |
| Fields  | —                              |                 |  |  |  |  |  |  |  |  |
| Access  |                                | R               |  |  |  |  |  |  |  |  |
| Default | 0000000                        |                 |  |  |  |  |  |  |  |  |

### Description

*Bits [15:8] of the temperature measurement.* Most significant byte of the temperature data.

### TEMP\_L

| Address | Common - 0x37 (Hex) - 55 (Dec) |                 |  |  |  |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|--|--|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |  |
| Fields  | —                              |                 |  |  |  |  |  |  |  |  |  |
| Access  |                                | R               |  |  |  |  |  |  |  |  |  |
| Default | 0000000                        |                 |  |  |  |  |  |  |  |  |  |

### Description

*Bits* [7:0] *of the temperature measurement.* Least significant byte of the temperature data.

# **FIFO\_COUNT**

| Address | Common - 0x3C (Hex) - 60 (Dec) |                 |  |  |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|--|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |
| Fields  | —                              |                 |  |  |  |  |  |  |  |  |
| Access  |                                | R               |  |  |  |  |  |  |  |  |
| Default | 0000000                        |                 |  |  |  |  |  |  |  |  |

#### Description

Available number of FIFO samples for data set. Contains the number of FIFO words available on the FIFO.

# FIFO\_STATUS

| Address |       | Common - 0x3D (Hex) - 61 (Dec) |  |                |                 |              |           |            |  |  |  |  |  |
|---------|-------|--------------------------------|--|----------------|-----------------|--------------|-----------|------------|--|--|--|--|--|
| Bit     | 7 6 5 |                                |  | 4              | 3               | 2            | 1         | 0          |  |  |  |  |  |
| Fields  | RFU   |                                |  | fifo_data_lost | fifo_read_empty | fifo_ovthold | fifo_full | fifo_empty |  |  |  |  |  |
| Access  | R     |                                |  | R              | R               | R            | R         | R          |  |  |  |  |  |
| Default | _     |                                |  | 0              | 0               | 0            | 0         | 0          |  |  |  |  |  |

Description

FIFO Status Flags

**Fields** 

*fifo\_data\_lost:* Indicates if at least one data has been lost when the FIFO was full.

*fifo\_read\_empty:* Indicates if a read occurred when the FIFO was empty.

*fifo\_ovthold:* Indicates if the number of data in FIFO exceeds the threshold.

*fifo\_full:* Indicates if the FIFO is full.

*fifo\_empty:* Indicates if the FIFO is empty.

## FIFO\_DATA

| Address | Common - 0x3E (Hex) - 62 (Dec) |                 |  |  |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|--|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |
| Fields  | —                              |                 |  |  |  |  |  |  |  |  |
| Access  |                                | R/W             |  |  |  |  |  |  |  |  |
| Default | 0000000                        |                 |  |  |  |  |  |  |  |  |

### Description

FIFO data to be read in burst mode.

FIFO data register. Burst reading autoincrement the FIFO read pointer.

### **RST\_REG**

| Address | Common - 0x3F (Hex) - 63 (Dec) |   |     |   |   |            |             |              |
|---------|--------------------------------|---|-----|---|---|------------|-------------|--------------|
| Bit     | 7                              | 6 | 5   | 4 | 3 | 2          | 1           | 0            |
| Fields  |                                |   | RFU |   |   | parity_rst | hpf_acc_rst | hpf_gyro_rst |
| Access  |                                |   | R   |   |   | R/W        | R/W         | R/W          |
| Default |                                |   | _   |   |   | 0          | 0           | 0            |

#### Description

Reset register

#### **Fields**

parity\_rst: Triggers a reset of the parity.

0: Idle 1: Trigger

*hpf\_acc\_rst:* Sets the accelerometer HP filter and restore the output to baseline.

0: Idle 1: Trigger

*hpf\_gyro\_rst:* Sets the gyroscope HP filter and restore the output to baseline.

0: Idle 1: Trigger
## 12.2.2Bank 00

## POWER\_CFG

| Address |         | Bank 00 - 0x00 (Hex) - 0 (Dec) |         |      |   |          |          |          |  |  |
|---------|---------|--------------------------------|---------|------|---|----------|----------|----------|--|--|
| Bit     | 7       | 6                              | 6 5 4 3 |      |   |          | 1        | 0        |  |  |
| Fields  | pwr_aux |                                | pwr_    | mode | - | sns_en_z | sns_en_y | sns_en_x |  |  |
| Access  | R/W     |                                | R,      | /W   |   | R/W      | R/W      | R/W      |  |  |
| Default | 0       |                                | 00      | 000  |   | 1        | 1        | 1        |  |  |

### Description

Power mode configuration

#### **Fields**

*pwr\_aux:* When 1, pwr\_mode becomes a transition between power modes controllable by AUX pin.

- 0: Normal
- 1: DSYNC

*pwr\_mode:* Sets the power mode.

| POWER_CFG[pwr_aux] | Value | Mnemonic                                  |
|--------------------|-------|-------------------------------------------|
| 0                  | 0000  | Power-down                                |
| 0                  | 0001  | Gyro sleep                                |
| 0                  | 0010  | Gyro low power                            |
| 0                  | 0011  | Gyro low noise                            |
| 0                  | 1000  | Acc low power                             |
| 0                  | 1100  | Acc low noise                             |
| 0                  | 1101  | Acc low noise + gyro sleep                |
| 0                  | 1110  | Acc low noise + gyro low power            |
| 0                  | 1111  | Acc low noise + gyro low noise            |
| 0                  | 01XX  | Don't care                                |
| 0                  | 1001  | Don't care                                |
| 0                  | 101X  | Don't care                                |
| 1                  | 0000  | Power-down/acc low power                  |
| 1                  | 0001  | Power-down/acc low noise                  |
| 1                  | 0010  | Power-down/gyro low power                 |
| 1                  | 0011  | Power-down/gyro low noise                 |
| 1                  | 0100  | Power-down/acc low noise + gyro low noise |

| 1 | 0101 | Power-down/acc low noise + gyro low ower      |
|---|------|-----------------------------------------------|
| 1 | 0110 | Gyro sleep/gyro low noise                     |
| 1 | 0111 | Gyro sleep/acc low noise + gyro low noise     |
| 1 | 1000 | Gyro low power/acc low noise + gyro low power |

1: Enable

*sns\_en\_y:* Enables gyroscope Y axis.

0: Disable

1: Enable

sns\_en\_x: Enables gyroscope X axis.

0: Disable

1: Enable

## GYRO\_CFG1

| Address | Bank 00 - 0x01 (Hex) - 1 (Dec) |      |      |        |       |              |    |  |  |  |
|---------|--------------------------------|------|------|--------|-------|--------------|----|--|--|--|
| Bit     | 7                              | 6    | 5    | 4      | 1     | 0            |    |  |  |  |
| Fields  | self_                          | test |      | sns_lp | f_bnd | sns_dout_fsc |    |  |  |  |
| Access  | R/                             | 'W   | R/W  |        |       | R/W          |    |  |  |  |
| Default | 0                              | 0    | 1010 |        |       |              | 00 |  |  |  |

### Description

*Gyroscope configuration register* 1

### **Fields**

*self\_test:* Sets the gyroscope self-test mode.

- 00: Disabled 01: Positive sign 10: Negative sign
- 11: Negative sign

#### sns\_lpf\_bnd: Sets the gyroscope lowpass filter cutoff frequency.

| GYRO_CFG2[sns_gyr_ois_lpf] | Value | Mnemonic |
|----------------------------|-------|----------|
| 0                          | 0000  | 2Hz      |
| 0                          | 0001  | 4Hz      |
| 0                          | 0010  | 6Hz      |
| 0                          | 0011  | 8Hz      |
| 0                          | 0100  | 10Hz     |
| 0                          | 0101  | 14Hz     |
| 0                          | 0110  | 22Hz     |
| 0                          | 0111  | 32Hz     |
| 0                          | 1000  | 50Hz     |
| 0                          | 1001  | 75Hz     |
| 0                          | 1010  | 100Hz    |
| 0                          | 1011  | 150Hz    |
| 0                          | 1100  | 200Hz    |
| 0                          | 1101  | 250Hz    |
| 0                          | 1110  | 300Hz    |
| 0                          | 1111  | 400Hz    |
| 1                          | 0XXX  | 1kHz     |
| 1                          | 1XXX  | 2kHz     |

*sns\_dout\_fsc:* Sets the gyroscope full scale. 00: 2000 dps 01: 1000 dps 10: 500 dps 11: 250 dps

## GYRO\_CFG2

| Address | Bank 00 - 0x02 (Hex) - 2 (Dec) |   |                 |                |     |      |      |   |  |  |  |
|---------|--------------------------------|---|-----------------|----------------|-----|------|------|---|--|--|--|
| Bit     | 7                              | 6 | 5               | 4              | 3   | 2    | 1    | 0 |  |  |  |
| Fields  | RFU                            |   | sns_gyr_ois_lpf | sns_gyr_hpf_en |     | sns_ | _odr | - |  |  |  |
| Access  |                                | R | R/W             | R/W            | R/W |      |      |   |  |  |  |
| Default | _                              |   | 0               | 0              |     | 01   | .00  |   |  |  |  |

### Description

Gyroscope configuration register 2

### **Fields**

sns\_gyr\_ois\_lpf: Enables the gyroscope low-pass filter for OIS (low-phase delay).

0: Off 1: On ( full scales are halved)

*sns\_gyr\_hpf\_en:* Enables the gyroscope highpass filter (this option is not available in low-power mode).

0: Disabled 1: Enabled

*sns\_odr:* Sets the gyroscope output data rate (ODR).

If *pwr\_mode* is gyro low power or acc low noise + gyro low power:

| Value | Mnemonic |
|-------|----------|
| 0000  | 250Hz    |
| 0001  | 250Hz    |
| 0010  | 250Hz    |
| 0011  | 250Hz    |
| 0100  | 250Hz    |
| 0101  | 250Hz    |
| 0110  | 125Hz    |
| 0111  | 62.5Hz   |
| 1XXX  | 31.25Hz  |

| C | Otherwise: |           |  |  |  |  |  |  |  |
|---|------------|-----------|--|--|--|--|--|--|--|
|   | Value      | Mnemonic  |  |  |  |  |  |  |  |
|   | 0000       | 8kHz      |  |  |  |  |  |  |  |
|   | 0001       | 4kHz      |  |  |  |  |  |  |  |
|   | 0010       | 2kHz      |  |  |  |  |  |  |  |
|   | 0011       | 1kHz      |  |  |  |  |  |  |  |
|   | 0100       | 500Hz     |  |  |  |  |  |  |  |
|   | 0101       | 250Hz     |  |  |  |  |  |  |  |
|   | 0110       | 125Hz     |  |  |  |  |  |  |  |
|   | 0111       | 62.5Hz    |  |  |  |  |  |  |  |
|   | 1000       | 31.25Hz   |  |  |  |  |  |  |  |
|   | 1001       | 15.625Hz  |  |  |  |  |  |  |  |
|   | 1010       | 7.8125Hz  |  |  |  |  |  |  |  |
|   | 1011       | 3.90625Hz |  |  |  |  |  |  |  |
|   | 11XX       | 3.90625Hz |  |  |  |  |  |  |  |

## GYRO\_CFG3

| Address | Bank 00 - 0x03 (Hex) - 3 (Dec) |   |   |         |         |            |   |   |  |
|---------|--------------------------------|---|---|---------|---------|------------|---|---|--|
| Bit     | 7                              | 6 | 5 | 4       | 3       | 2          | 1 | 0 |  |
| Fields  | RFU                            |   |   | wait_da | ta_mode | sns_hpf_co |   |   |  |
| Access  | R                              |   |   | R/      | ′W      | V R/W      |   |   |  |
| Default | _                              |   |   | 0       | 00 000  |            |   |   |  |

### Description

Gyroscope configuration register 3

### **Fields**

wait\_data\_mode: To start the data generation, two triggers are defined (Trig1/Trig2):
Trig1: from driveON to senseON

Trig2: from senseON to NormalMode

00: None/None 01: Freq lock/freq lock 10: Freq lock/amp lock 11: Amp lock/amp lock

sns\_hpf\_co: Sets the gyroscope highpass filter cutoff frequency.

000: 0.08Hz 001: 0.24Hz 010: 0.8Hz 011: 2Hz 100: 5Hz 101: 10Hz 110: 20Hz 111: 50Hz

Back to Register Overview

## PWR\_ACC\_CFG

| Address | Bank 00 - 0x04 (Hex) - 4 (Dec) |        |               |   |   |          |          |          |  |
|---------|--------------------------------|--------|---------------|---|---|----------|----------|----------|--|
| Bit     | 7                              | 6      | 5             | 4 | 3 | 2        | 1        | 0        |  |
| Fields  | sns_a                          | cc_fsc | acc_self_test |   |   | acc_en_z | acc_en_y | acc_en_x |  |
| Access  | R/                             | W      | R/W           |   |   | R/W      | R/W      | R/W      |  |
| Default | 1                              | 1      | 000           |   |   | 1        | 1        | 1        |  |

### Description

Accelerometer power configuration

#### **Fields**

sns\_acc\_fsc: Sets the accelerometer full scale.

00: 16g 01: 8g 10: 4g 11: 2g

acc\_self\_test: Sets the accelerometer self-test mode.

000: No test 001: Positive force/Y axis self test 010: Positive force/X axis self test 011: Positive force/Z axis self test 101: Negative force/Y axis self test 110: Negative force/X axis self test 111: Negative force/Z axis self test

acc\_en\_z: Enables accelerometer Z axis.

0: Disabled 1: Enabled

acc\_en\_y: Enables accelerometer Y axis.

0: Disabled 1: Enabled

- acc\_en\_x: Enables accelerometer X axis.
  - 0: Disabled 1: Enabled

# ACC\_CFG\_1

| Address | Bank 00 - 0x05 (Hex) - 5 (Dec) |   |         |                |      |             |   |   |  |  |
|---------|--------------------------------|---|---------|----------------|------|-------------|---|---|--|--|
| Bit     | 7                              | 6 | 5       | 4              | 3    | 2           | 1 | 0 |  |  |
| Fields  | sns_acc_hpf_co                 |   | sns_acc | sns_acc_lpf_co |      | sns_acc_odr |   |   |  |  |
| Access  | R/                             | W | R/      | R/W            |      | R/W         |   |   |  |  |
| Default | 0                              | 0 | 00      |                | 0010 |             |   |   |  |  |

### Description

Accelerometer configuration register 1.

#### **Fields**

sns\_acc\_hpf\_co: Set the accelerometer highpass filter cutoff frequency.

00: ODR/400 01: ODR/200 10: ODR/100 11: ODR/50

sns\_acc\_lpf\_co: Set the accelerometer lowpass filter cutoff frequency.

| 00: ODR/48 |  |
|------------|--|
| 01: ODR/22 |  |
| 10: ODR/9  |  |
| 11: ODR/3  |  |
|            |  |

#### sns\_acc\_odr: Sets the accelerometer output data rate (ODR).

If *pwr\_mode* is acc low power:

| Value | Mnemonic    |
|-------|-------------|
| 0000  | 250Hz       |
| 0001  | 250Hz       |
| 0010  | 250Hz       |
| 0011  | 250Hz       |
| 0100  | 125Hz       |
| 0101  | 62.5Hz      |
| 0110  | 31.25Hz     |
| 0111  | 15.625Hz    |
| 1000  | 7.8125Hz    |
| 1001  | 3.90625Hz   |
| 1010  | 1.953125Hz  |
| 1011  | 0.9765625Hz |
| 11XX  | 0.9765625Hz |

#### Otherwise:

| Value | Mnemonic |
|-------|----------|
| 0000  | 2000Hz   |
| 0001  | 1000Hz   |
| 0010  | 500Hz    |
| 0011  | 250Hz    |
| 0100  | 125Hz    |
| 0101  | 62.5Hz   |
| 011X  | 31.25Hz  |
| 1XXX  | 31.25Hz  |

## ACC\_CFG\_2

| Address |   |    | l | Bank 00 - 0x06 | 6 (Hex) - 6 (Dec) |   |                |   |
|---------|---|----|---|----------------|-------------------|---|----------------|---|
| Bit     | 7 | 6  | 5 | 4              | 3                 | 2 | 1              | 0 |
| Fields  |   | RF |   | mag_odr        |                   |   | sns_acc_hpf_en |   |
| Access  |   | F  |   | R/W R/V        |                   |   | R/W            |   |
| Default |   | -  |   | 000            |                   |   | 0              |   |

### Description

Accelerometer configuration register 2

### **Fields**

sns\_acc\_hpf\_en: Enables the accelerometer highpass filter.

0: Disabled 1: Enabled

## MAG\_SLV\_CFG

| Address |        | Bank 00 - 0x07 (Hex) - 7 (Dec) |          |         |                  |             |     |    |  |  |  |
|---------|--------|--------------------------------|----------|---------|------------------|-------------|-----|----|--|--|--|
| Bit     | 7      | 6                              | 5        | 4       | 3                | 2           | 2 1 |    |  |  |  |
| Fields  | mag_en | mag_swap                       | mag_safe | mag_grp | mag_i2c_std_mode | mag_i2c_len |     | 'n |  |  |  |
| Access  | R/W    | R/W                            | R/W      | R/W     | R/W              | R/W         |     |    |  |  |  |
| Default | 0      | 0                              | 0        | 0       | 0                |             | 110 |    |  |  |  |

### Description

Magnetometer slave configuration

#### **Fields**

*mag\_en:* Enables the magnetometer. 0: Disabled

1: Enabled

mag\_swap: Selects the endian of the magnetometer data.

0: MSB First 1: MSB Last

*mag\_safe:* Enables the safe mode.

Since the external magnetometer data read operation is performed asynchronously, setting the safe mode guarantees the read data are correct if the external magnetometer data rate is set to half the transfer rate.

0: Off 1: On

mag\_grp: Data read configuration.

| Value | Mnemonic        | Description                                                                     |
|-------|-----------------|---------------------------------------------------------------------------------|
| 0     | mag_i2c_len     | Reads mag_i2c_len bytes from external magnetometer.                             |
| 1     | mag_i2c_len + 1 | Reads mag_i2c_len+1 bytes from external magnetometer and discard the first one. |

*mag\_i2c\_std\_mode:* Sets the I<sup>2</sup>C transfer rate.

0: 400kHz (fast mode)

1: 100kHz (standard mode)

*mag\_i2c\_len:* Sets the number of bytes to be read from the magnetometer.

## MAG\_SLV\_ADD

| Address |     | Bank 00 - 0x08 (Hex) - 8 (Dec) |                                       |  |         |  |  |  |  |  |  |
|---------|-----|--------------------------------|---------------------------------------|--|---------|--|--|--|--|--|--|
| Bit     | 7   | 6                              | 6     5     4     3     2     1     0 |  |         |  |  |  |  |  |  |
| Fields  | RFU |                                | mag_i2c_slv_add                       |  |         |  |  |  |  |  |  |
| Access  | R   |                                |                                       |  | R/W     |  |  |  |  |  |  |
| Default | _   |                                |                                       |  | 0000000 |  |  |  |  |  |  |

### Description

Magnetometer slave address

### **Fields**

mag\_i2c\_slv\_add: Magnetometer I<sup>2</sup>C slave address.

## MAG\_SLV\_REG

| Address | Bank 00 - 0x09 (Hex) - 9 (Dec)        |  |  |      |      |  |  |  |  |  |
|---------|---------------------------------------|--|--|------|------|--|--|--|--|--|
| Bit     | 7 6 5 4 3 2 1 0                       |  |  |      |      |  |  |  |  |  |
| Fields  | — — — — — — — — — — — — — — — — — — — |  |  |      |      |  |  |  |  |  |
| Access  |                                       |  |  | R/   | W    |  |  |  |  |  |
| Default |                                       |  |  | 0000 | 0000 |  |  |  |  |  |

### Description

Magnetometer slave register

Magnetometer I<sup>2</sup>C register address.

## MAG\_MAP\_REG

| Address |    | Bank 00 - 0x0A (Hex) - 10 (Dec) |       |           |  |   |              |              |  |  |  |  |
|---------|----|---------------------------------|-------|-----------|--|---|--------------|--------------|--|--|--|--|
| Bit     | 7  | 6                               | 5 4 3 |           |  | 2 | 1            | 0            |  |  |  |  |
| Fields  | RF | U                               |       | mag_chmap |  |   | mag_invsgn_y | mag_invsgn_x |  |  |  |  |
| Access  | R  | ł                               |       | R/W       |  |   | R/W          | R/W          |  |  |  |  |
| Default | -  | -                               | 000   |           |  | 0 | 0            | 0            |  |  |  |  |

### Description

Magnetometer mapping register

#### **Fields**

*mag\_chmap:* These three bits are used to cross the three axes in the interface between mechanic and analog front end.

Multiplexing of input signals (from A, B, C to Xi, Yi, Zi).

000: [Xi, Yi, Zi] <= [A, B, C] 001: [Xi, Yi, Zi] <= [A, C, B] 010: [Xi, Yi, Zi] <= [B, A, C] 011: [Xi, Yi, Zi] <= [C, A, B] 100: [Xi, Yi, Zi] <= [C, A, A] 101: [Xi, Yi, Zi] <= [C, B, A] 110: [Xi, Yi, Zi] <= [A, B, C] 111: [Xi, Yi, Zi] <= [A, B, C]

mag\_invsgn\_z: Invert the sign of the Z axis data produced by the external magnetometer sensor.

0: No 1: Yes

*mag\_invsgn\_y:* Invert the sign of the Y axis data produced by the external magnetometer sensor.

0: No 1: Yes

*mag\_invsgn\_x:* Invert the sign of the X axis data produced by the external magnetometer sensor.

- 0: No
- 1: Yes

# I2C\_MST\_ADD

| Address | Bank 00 - 0x0B (Hex) - 11 (Dec)       |                 |  |      |      |  |  |  |  |  |
|---------|---------------------------------------|-----------------|--|------|------|--|--|--|--|--|
| Bit     | 7                                     | 7 6 5 4 3 2 1 0 |  |      |      |  |  |  |  |  |
| Fields  | — — — — — — — — — — — — — — — — — — — |                 |  |      |      |  |  |  |  |  |
| Access  |                                       |                 |  | R/   | W    |  |  |  |  |  |
| Default |                                       |                 |  | 0000 | 0000 |  |  |  |  |  |

### Description

*I<sup>2</sup>C master register address.* 

Master I<sup>2</sup>C address register.

# I2C\_MST\_RW

| Address | Bank 00 - 0x0C (Hex) - 12 (Dec) |                 |  |      |      |  |  |  |  |  |
|---------|---------------------------------|-----------------|--|------|------|--|--|--|--|--|
| Bit     | 7                               | 7 6 5 4 3 2 1 0 |  |      |      |  |  |  |  |  |
| Fields  | —                               |                 |  |      |      |  |  |  |  |  |
| Access  |                                 |                 |  | R/   | W    |  |  |  |  |  |
| Default |                                 |                 |  | 0000 | 0000 |  |  |  |  |  |

### Description

*I<sup>2</sup>C master register data.* 

Master I<sup>2</sup>C data read/write register.

## MAG\_OFS\_X\_MSB

| Address | Bank 00 - 0x0D (Hex) - 13 (Dec) |  |  |      |      |  |  |  |  |  |
|---------|---------------------------------|--|--|------|------|--|--|--|--|--|
| Bit     | 7 6 5 4 3 2 1 0                 |  |  |      |      |  |  |  |  |  |
| Fields  | _                               |  |  |      |      |  |  |  |  |  |
| Access  |                                 |  |  | R/'  | W    |  |  |  |  |  |
| Default |                                 |  |  | 0000 | 0000 |  |  |  |  |  |

### Description

Magnetometer offset X, MSB.

Magnetometer MSB of the offset for compensation on X direction.

## MAG\_OFS\_X\_LSB

| Address | Bank 00 - 0x0E (Hex) - 14 (Dec) |  |  |      |      |  |  |  |  |  |
|---------|---------------------------------|--|--|------|------|--|--|--|--|--|
| Bit     | 7 6 5 4 3 2 1 0                 |  |  |      |      |  |  |  |  |  |
| Fields  | —                               |  |  |      |      |  |  |  |  |  |
| Access  | R/W                             |  |  |      |      |  |  |  |  |  |
| Default |                                 |  |  | 0000 | 0000 |  |  |  |  |  |

### Description

Magnetometer offset X, LSB.

Magnetometer LSB of the offset for compensation on X direction.

## MAG\_OFS\_Y\_MSB

| Address | Bank 00 - 0x0F (Hex) - 15 (Dec) |  |  |       |      |  |  |  |  |  |  |
|---------|---------------------------------|--|--|-------|------|--|--|--|--|--|--|
| Bit #   | 7 6 5 4 3 2 1 0                 |  |  |       |      |  |  |  |  |  |  |
| Fields  |                                 |  |  |       |      |  |  |  |  |  |  |
| Access  |                                 |  |  | R/\   | W    |  |  |  |  |  |  |
| Default |                                 |  |  | 00000 | 0000 |  |  |  |  |  |  |

### Description

Magnetometer offset Y, MSB.

Magnetometer MSB of the offset for compensation on Y direction.

# MAG\_OFS\_Y\_LSB

| Address | Bank 00 - 0x10 (Hex) - 16 (Dec) |  |  |      |      |  |  |  |  |  |  |
|---------|---------------------------------|--|--|------|------|--|--|--|--|--|--|
| Bit     | 7 6 5 4 3 2 1 0                 |  |  |      |      |  |  |  |  |  |  |
| Fields  | _                               |  |  |      |      |  |  |  |  |  |  |
| Access  |                                 |  |  | R/   | W    |  |  |  |  |  |  |
| Default |                                 |  |  | 0000 | 0000 |  |  |  |  |  |  |

### Description

Magnetometer offset Y, LSB.

Magnetometer LSB of the offset for compensation on Y direction.

## MAG\_OFS\_Z\_MSB

| Address | Bank 00 - 0x11 (Hex) - 17 (Dec) |  |  |      |      |  |  |  |  |  |  |
|---------|---------------------------------|--|--|------|------|--|--|--|--|--|--|
| Bit     | 7 6 5 4 3 2 1 0                 |  |  |      |      |  |  |  |  |  |  |
| Fields  | _                               |  |  |      |      |  |  |  |  |  |  |
| Access  |                                 |  |  | R/   | W    |  |  |  |  |  |  |
| Default |                                 |  |  | 0000 | 0000 |  |  |  |  |  |  |

### Description

Magnetometer offset Z, MSB.

Magnetometer MSB of the offset for compensation on Z direction.

## MAG\_OFS\_Z\_LSB

| Address | Bank 00 - 0x12 (Hex) - 18 (Dec) |                 |  |      |      |  |  |  |  |  |  |
|---------|---------------------------------|-----------------|--|------|------|--|--|--|--|--|--|
| Bit     | 7                               | 7 6 5 4 3 2 1 0 |  |      |      |  |  |  |  |  |  |
| Fields  | _                               |                 |  |      |      |  |  |  |  |  |  |
| Access  |                                 |                 |  | R/'  | W    |  |  |  |  |  |  |
| Default |                                 |                 |  | 0000 | 0000 |  |  |  |  |  |  |

### Description

Magnetometer offset Z, LSB.

Magnetometer LSB of the offset for compensation on Z direction.

# DR\_CFG

| Address |                       | Bank 00 - 0x13 (Hex) - 19 (Dec) |                 |                 |         |      |             |         |  |  |  |  |
|---------|-----------------------|---------------------------------|-----------------|-----------------|---------|------|-------------|---------|--|--|--|--|
| Bit #   | 7                     | 6                               | 5               | 4               | 3       | 2    | 1           | 0       |  |  |  |  |
| Fields  | mst_pad_bypass<br>_en | RFU                             | mst_i2c_sngl_rw | mst_i2c_sngl_en | dr_rst_ | mode | coarse_temp | temp_en |  |  |  |  |
| Access  | R/W                   | R                               | R/W             | R/W             | R/      | W    | R/W         | R/W     |  |  |  |  |
| Default | 0                     | -                               | 0               | 0               | 0       | 0    | 0           | 1       |  |  |  |  |

### Description

Data ready configuration

### **Fields**

*mst\_pad\_bypass\_en:* Enables the bypass of the I<sup>2</sup>C master pads.

0: Normal 1: Bypass

*mst\_i2c\_sngl\_rw:* Sets the direction of the I<sup>2</sup>C master operation.

0: Write 1: Read

*mst\_i2c\_sngl\_en:* Enables a one-shot single byte read/write operation.

0: Disable 1: Enable

*dr\_rst\_mode:* Sets the DATA\_READY interrupt reset and data-out update mode.

| Value | Mnemonic | Description                                                                                                                                |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 00    | All      | DATA_READY is cleared after all the active channels are read. Data are not updated until the clear operation is accomplished.              |
| 01    | Any      | DATA_READY is cleared when at least a byte of one of the active channels is read. Data are updated independently from the clear operation. |
| 10    | Status   | DATA_READY is cleared when status register is read. Data are not updated until the clear operation is accomplished.                        |

### coarse\_temp: Sets the temperature data update granularity.

| Value | Mnemonic | Description                                                                                               |
|-------|----------|-----------------------------------------------------------------------------------------------------------|
| 0     | Fine     | Temperature data is updated only when both the temperature data registers are read (TEMP_H, TEMP_L).      |
| 1     | Coarse   | Temperature data is updated only when the most significant byte of the temperature data is read (TEMP_H). |

temp\_en: Enables the temperature sensor.

0: Disabled

1: Enabled

# IO\_CFG

| Address |           | Bank 00 - 0x14 (Hex) - 20 (Dec) |            |            |            |            |            |            |  |  |  |  |
|---------|-----------|---------------------------------|------------|------------|------------|------------|------------|------------|--|--|--|--|
| Bit     | 7         | 6                               | 2          | 1          | 0          |            |            |            |  |  |  |  |
| Fields  | aux_pd_en | aux_pu_en                       | int1_pd_en | int1_pu_en | int2_pd_en | int2_pu_en | mst_pu_dis | slv_pu_dis |  |  |  |  |
| Access  | R/W       | R/W                             | R/W        | R/W        | R/W        | R/W        | R/W        | R/W        |  |  |  |  |
| Default | 0         | 0                               | 0          | 0          | 0          | 0          | 0          | 0          |  |  |  |  |

### Description

Input/output configuration

#### **Fields**

*aux\_pd\_en:* Connects the internal pulldown of the AUX pad.

- 0: Disconnected
- 1: Connected

#### *aux\_pu\_en:* Connects the internal pullup of the AUX pad.

0: Disconnected 1: Connected

#### int1\_pd\_en: Connects the internal pulldown of the INT1 pad.

0: Disconnected 1: Connected

#### int1\_pu\_en: Connects the internal pullup of the INT1 pad.

0: Disconnected 1: Connected

#### *int2\_pd\_en:* Connects the internal pulldown of the INT2 pad.

0: Disconnected 1: Connected

int2\_pu\_en: Connects the internal pullup of the INT2 pad.

0: Disconnected 1: Connected

#### *mst\_pu\_dis:* Disconnects the internal pullups of the I<sup>2</sup>C master pads.

- 0: Connected
- 1: Disconnected

*slv\_pu\_dis:* Disconnect the internal pullups of the I<sup>2</sup>C slave pads.

0: Connected 1: Disconnected

## I2C\_PAD

| Address |   | Bank 00 - 0x15 (Hex) - 21 (Dec) |     |   |              |            |                |     |  |  |  |  |  |
|---------|---|---------------------------------|-----|---|--------------|------------|----------------|-----|--|--|--|--|--|
| Bit     | 7 | 6                               | 5   | 4 | 2            | 1          | 0              |     |  |  |  |  |  |
| Fields  |   |                                 | RFU |   | strong_slave | strong_mst | strong_int_aux |     |  |  |  |  |  |
| Access  |   |                                 | R   |   |              | R/W        | R/W            | R/W |  |  |  |  |  |
| Default |   |                                 | _   |   |              | 1          | 0              | 0   |  |  |  |  |  |

### Description

PADs configuration

### **Fields**

strong\_slave: Increases the I<sup>2</sup>C slave pads speed. This mode absorbs more current.
0: Normal (low power)
1: Fast
strong\_mst: Increases the I<sup>2</sup>C master pads speed. This mode absorbs more current.

0: Normal (low power) 1: Fast

*strong\_int\_aux:* Increases the aux pad speed. This mode absorbs more current.

0: Normal (low power) 1: Fast

# I2C\_CFG

| Address |            | Bank 00 - 0x16 (Hex) - 22 (Dec) |             |     |  |            |        |         |  |  |  |  |
|---------|------------|---------------------------------|-------------|-----|--|------------|--------|---------|--|--|--|--|
| Bit     | 7          | 6                               | 5 4 3       |     |  | 2          | 1      | 0       |  |  |  |  |
| Fields  | mst_i2c_pd | ad_settings                     | i2c_setting |     |  | spi_3_wire | endian | i2c_off |  |  |  |  |
| Access  | R/         | W                               |             | R/W |  |            | R/W    | R/W     |  |  |  |  |
| Default | 0          | 0                               |             | 000 |  | 0          | 0      | 0       |  |  |  |  |

### Description

Serial interfaces configuration

#### **Fields**

*mst\_i2c\_pad\_settings:* Sets the I<sup>2</sup>C master pad configuration.

00: Without antispike filter

01: Standard configuration

10: Without filters and delays

*i2c\_setting:* Sets the I<sup>2</sup>C configuration.

000: I<sup>2</sup>C fast mode standard configuration

001: I<sup>2</sup>C fast mode without anti-spike filter

010:  $I^2$ C high-speed standard configuration

011:  $I^2$ C high-speed without anti-spike filter

100: I<sup>2</sup>C mode without filters and delays

101: SPI interface recommended

spi\_3\_wire: Sets the SPI mode.

0: SPI Mode 4 1: SPI Mode 3

endian: Sets the data output endian.

0: Big endian

1: Little endian

*i2c\_off:* Turns on/off the I<sup>2</sup>C interface.

0: Active 1: Off

Back to Register Overview

# FIFO\_THS

| Address | Bank 00 - 0x17 (Hex) - 23 (Dec) |                 |  |       |      |  |  |  |  |  |  |
|---------|---------------------------------|-----------------|--|-------|------|--|--|--|--|--|--|
| Bit     | 7                               | 7 6 5 4 3 2 1 0 |  |       |      |  |  |  |  |  |  |
| Fields  |                                 | —               |  |       |      |  |  |  |  |  |  |
| Access  |                                 |                 |  | R/'   | W    |  |  |  |  |  |  |
| Default |                                 |                 |  | 00000 | 0000 |  |  |  |  |  |  |

### Description

FIFO threshold configuration

Sets the FIFO threshold. When the number of sample stored in FIFO is above the threshold (fifo\_ths\_msb, fifo\_ths\_lsb), an interrupt is generated. The FIFO threshold shall be different from 0.

# FIFO\_CFG

| Address |           | Bank 00 - 0x18 (Hex) - 24 (Dec) |               |              |                 |                    |                    |                    |  |  |  |  |  |
|---------|-----------|---------------------------------|---------------|--------------|-----------------|--------------------|--------------------|--------------------|--|--|--|--|--|
| Bit     | 7 6 5     |                                 | 4 3           |              | 2               | 1                  | 0                  |                    |  |  |  |  |  |
| Fields  | fifo_mode |                                 | fifo_int_mode | fifo_overrun | fifo_store_quat | fifo_store_<br>mag | fifo_store_<br>acc | fifo_store_<br>gyr |  |  |  |  |  |
| Access  | R/        | W                               | R/W           | R/W          | R/W             | R/W                | R/W                | R/W                |  |  |  |  |  |
| Default | 0         | 0                               | 0             | 0            | 0               | 0                  | 0                  | 0                  |  |  |  |  |  |

### Description

FIFO mode configuration

#### **Fields**

*fifo\_mode:* Sets the FIFO mode.

| Value | e Mnemonic | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00    | Off        | FIFO is disabled and the data are exposed through the registers only.                                                                                                                                                                                                                                                                                                                                                                                           |
| 01    | Normal     | FIFO starts collecting the data immediately.                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 10    | Interrupt  | FIFO starts collecting the data right after a Rate Interrupt event (either OR or AND) is generated.                                                                                                                                                                                                                                                                                                                                                             |
| 11    | Snapshot   | FIFO starts collecting the data immediately, overwriting the<br>oldest data in case of FIFO full. When a Rate Interrupt event<br>(either OR or AND) is generated, data are collected until the FIFO<br>is full, then the data collection is stopped without overwriting<br>the oldest values.<br>This mechanism is useful in case a post-processing of the data<br>that generated the Rate Interrupt event is requested to better<br>classify the event itself. |

*fifo\_int\_mode:* When an interrupt mode is selected, these bits define which kind of mask must be used.

- 0: OR mask
- 1: AND mask
- *fifo\_overrun:* Sets the FIFO overrun mode. If overwrite, the FIFO is full the old data are overwritten. If stop on full, the FIFO stops collecting data when full.
  - 0: Stop on full
  - 1: Overwrite

*fifo\_store\_quat:* Stores the quaternion data in the FIFO.

- 0: No Quaternions in the FIFO
- 1: Quaternions in the FIFO

fifo\_store\_mag: Stores the magnetometer data in the FIFO.

- 0: No Magnetometer in the FIFO
- 1: Magnetometer in the FIFO

*fifo\_store\_acc:* Stores the accelerometer data in the FIFO.

0: No Accelerometer in the FIFO 1: Accelerometer in the FIFO

*fifo\_store\_gyr:* Stores the gyroscope data in the FIFO. 0: No Gyroscope in the FIFO 1: Gyroscope in the FIFO

## DSYNC\_CFG

| Address | Bank 00 - 0x1A (Hex) - 26 (Dec) |                   |                       |                       |                    |                   |                   |                    |  |  |
|---------|---------------------------------|-------------------|-----------------------|-----------------------|--------------------|-------------------|-------------------|--------------------|--|--|
| Bit     | 7                               | 7 6 5 4 3 2 1 0   |                       |                       |                    |                   |                   |                    |  |  |
| Fields  | ds_queue_<br>en_r               | ds_queue_<br>en_f | ds_wakeup<br>_act_edg | ds_wakeup_<br>act_low | ds_gyro_map_<br>en | ds_acc_<br>map_en | ds_mag_<br>map_en | ds_temp_<br>map_en |  |  |
| Access  | R/W                             | R/W               | R/W                   | R/W                   | R/W                | R/W               | R/W               | R/W                |  |  |
|         |                                 |                   |                       |                       |                    |                   |                   |                    |  |  |

### Description

DSYNC configuration

#### **Fields**

ds\_queue\_en\_r: Enables the data queueing when data\_sync rising edge.

- 0: Disabled
- 1: Enabled

*ds\_queue\_en\_f:* Enables the data queueing when data\_sync falling edge.

0: Disabled 1: Enabled

ds\_wakeup\_act\_edg: Selects if the data\_sync is active on edge or on level.

- 0: Active on level
- 1: Active on edge

*ds\_wakeup\_act\_low:* Selects the active level of the data\_sync to control the wake-up.

- 0: Active high
- 1: Active low

ds\_gyro\_map\_en: Enables the mapping of the data\_sync signal to the gyroscope LSB.

- 0: Disabled
- 1: Enabled

ds\_acc\_map\_en: Enables the mapping of the data\_sync signal to the accelerometer LSB.

0: Disabled 1: Enabled

ds\_mag\_map\_en: Enables the mapping of the data\_sync signal to the mag LSB.

- 0: Disabled
- 1: Enabled

ds\_temp\_map\_en: Enables the mapping of the data\_sync signal to the temperature LSB.

- 0: Disabled
- 1: Enabled

Back to Register Overview

## DSYNC\_CNT

| Address | Bank 00 - 0x1B (Hex) - 27 (Dec) |    |   |   |                 |   |   |   |  |
|---------|---------------------------------|----|---|---|-----------------|---|---|---|--|
| Bit     | 7                               | 6  | 5 | 4 | 3               | 2 | 1 | 0 |  |
| Fields  |                                 | RF | υ |   | data_sync_count |   |   |   |  |
| Access  |                                 | f  | 2 |   | R/W             |   |   |   |  |
| Default |                                 | -  | - |   | 0000            |   |   |   |  |

### Description

DSYNC counter

### **Fields**

*data\_sync\_count:* This register specifies the number of samples to be stored into the FIFO upon detecting a DATA\_SYNC active edge.

# ITF\_OTP

| Address | Bank 00 - 0x1C (Hex) - 28 (Dec) |              |           |  |              |  |              |                 |  |  |
|---------|---------------------------------|--------------|-----------|--|--------------|--|--------------|-----------------|--|--|
| Bit #   | 7                               | 6            | 5 4       |  | 3 2          |  | 1            | 0               |  |  |
| Fields  | RFU                             | parity_error | if_parity |  | otp_ecc_stat |  | chrp_in_prgs | otp_dld_restart |  |  |
| Access  | R                               | R            | R/W       |  | R            |  | R            | R/W             |  |  |
| Default | -                               | 0            | 00        |  | 00           |  | 0            | 0               |  |  |

### Description

Serial interfaces and OTP control

### **Fields**

*parity\_error:* Indicates if an error in SPI/I<sup>2</sup>C address occurred.

if\_parity: Parity setting.

00: Bit 6 is used for autoincrement mode.

- 01: Bit 6 represents the even parity bit.
- 10: Bit 6 represents the odd parity bit.

otp\_ecc\_stat: OTP download status.

00: Program OK 01: Program fail 10: Program fail 11: Program fail

*chrp\_in\_prgs:* Status of the stiction recovery operation.

0: Idle 1: In progress

otp\_dld\_restart: Triggers the OTP download.

0: Idle 1: Trigger

Back to Register Overview

## 12.2.3Bank 01

## INT\_REF\_X

| Address | Bank 01 - 0x00 (Hex) - 0 (Dec) |  |  |  |  |  |  |  |  |
|---------|--------------------------------|--|--|--|--|--|--|--|--|
| Bit     | 7 6 5 4 3 2 1 0                |  |  |  |  |  |  |  |  |
| Fields  | —                              |  |  |  |  |  |  |  |  |
| Access  | R/W                            |  |  |  |  |  |  |  |  |
| Default | 0000000                        |  |  |  |  |  |  |  |  |

### Description

Interrupt reference for X axis.

Sets the MSB of the reference for interrupt of X axis. When int\_single\_ref is set, the reference will be {int\_ref\_x, int\_ref\_y}, with int\_ref\_x MSB byte and int\_ref\_y LSB byte.

# INT\_REF\_Y

| Address | Bank 01 - 0x01 (Hex) - 1 (Dec) |  |  |  |  |  |  |  |  |
|---------|--------------------------------|--|--|--|--|--|--|--|--|
| Bit     | 7 6 5 4 3 2 1 0                |  |  |  |  |  |  |  |  |
| Fields  | —                              |  |  |  |  |  |  |  |  |
| Access  | R/W                            |  |  |  |  |  |  |  |  |
| Default | 0000000                        |  |  |  |  |  |  |  |  |

### Description

Interrupt reference for Y axis.

Sets the MSB of the reference for interrupt of Y axis. When int\_single\_ref is set, the reference will be (int\_ref\_x, int\_ref\_y) wth int\_ref\_x MSB byte and int\_ref\_y LSB byte.
# INT\_REF\_Z

| Address |                 |     | E | 3ank 01 - 0x02 | (Hex) - 2 (Dec | c) |  |  |  |  |
|---------|-----------------|-----|---|----------------|----------------|----|--|--|--|--|
| Bit     | 7 6 5 4 3 2 1 0 |     |   |                |                |    |  |  |  |  |
| Fields  |                 |     |   |                |                |    |  |  |  |  |
| Access  |                 | R/W |   |                |                |    |  |  |  |  |
| Default |                 |     |   | 0000           | 0000           |    |  |  |  |  |

## Description

Interrupt reference for Z axis

Set the MSB of the reference for interrupt of Z axis. When int\_single\_ref is set, the reference will be (int\_ref\_x, int\_ref\_y) wth int\_ref\_x MSB byte and int\_ref\_y LSB byte.

# INT\_DEB\_X

| Address |   |    | E  | 3ank 01 - 0x03 | (Hex) - 3 (Dec | :) |    |   |  |
|---------|---|----|----|----------------|----------------|----|----|---|--|
| Bit     | 7 | 6  | 5  | 4              | 3              | 2  | 1  | 0 |  |
| Fields  |   | RI | ۶U |                | int_deb_x      |    |    |   |  |
| Access  |   | I  | २  |                | R/W            |    |    |   |  |
| Default |   | -  | _  |                |                | 00 | 00 |   |  |

## Description

Interrupt debounce, X axis

#### **Fields**

int\_deb\_x: Sets the number of contiguous X axis samples that have to respect the interrupt condition
before issuing the interrupt signal.
The actual value is 2 x int\_deb\_x + 1.

# INT\_DEB\_Y

| Address |   |    | 1  | (Hex) - 4 (Dec | :)        |    |    |   |  |
|---------|---|----|----|----------------|-----------|----|----|---|--|
| Bit     | 7 | 6  | 5  | 4              | 3         | 2  | 1  | 0 |  |
| Fields  |   | RI | ۶U |                | int_deb_y |    |    |   |  |
| Access  |   | 1  | २  |                | R/W       |    |    |   |  |
| Default |   | -  | _  |                |           | 00 | 00 |   |  |

## Description

Interrupt debounce, Y axis

### **Fields**

int\_deb\_y: Sets the number of contiguous Y axis samples that have to respect the interrupt condition
before issuing the interrupt signal.
The actual value is 2 x int\_deb\_y + 1.

# INT\_DEB\_Z

| Address |   |    | I  | Bank 01 - 0x05 | i (Hex) - 5 (Dec) |    |    |   |  |
|---------|---|----|----|----------------|-------------------|----|----|---|--|
| Bit     | 7 | 6  | 5  | 4              | 3                 | 2  | 1  | 0 |  |
| Fields  |   | RI | FU |                | int_deb_z         |    |    |   |  |
| Access  |   | l  | R  |                | R/W               |    |    |   |  |
| Default |   | -  | _  |                |                   | 00 | 00 |   |  |

## Description

Interrupt debounce, Z axis

### **Fields**

int\_deb\_z: Sets the number of contiguous Z axis samples that have to respect the interrupt condition
before issuing the interrupt signal.
The actual value is 2 x int\_deb\_z + 1.

# INT\_MSK\_X

| Address |      | Bank 01 - 0x06 (Hex) - 6 (Dec) |   |   |                |               |                |               |  |  |  |  |
|---------|------|--------------------------------|---|---|----------------|---------------|----------------|---------------|--|--|--|--|
| Bit     | 7    | 6                              | 5 | 4 | 3 2            |               | 1              | 0             |  |  |  |  |
| Fields  |      | int_mask_x                     |   |   | int_x_high_pos | int_x_low_pos | int_x_high_neg | int_x_low_neg |  |  |  |  |
| Access  | R/W  |                                |   |   | R              | R             | R              | R             |  |  |  |  |
| Default | 0000 |                                |   |   | 0              | 0             | 0              | 0             |  |  |  |  |

### Description

Interrupt mask, X axis zones

### **Fields**

*int\_mask\_x:* For each bit mask it enables (1) or disables (0) the interrupt generation for threshold event detection on X axis.

Bit 0: enable (1)/disable (0) the event int\_x\_low\_neg.

Bit 1: enable (1)/disable (0) the event int\_x\_high\_neg.

Bit 2: enable (1)/disable (0) the event int\_x\_low\_pos.

Bit 3: enable (1)/disable (0) the event int\_x\_high\_pos.

For example: writing int\_mask\_x = 4'b0100 only the event int\_x\_low\_pos will generate an interrupt.

#### int\_x\_high\_pos: Signal is positive, above threshold.

0: False 1: True

*int\_x\_low\_pos:* Signal is positive, below threshold.

0: False 1: True

int\_x\_high\_neg: Signal is negative, above threshold.

0: False 1: True

int\_x\_low\_neg: Signal is negative below threshold.

0: False

1: True

# INT\_MSK\_Y

| Address |      | Bank 01 - 0x07 (Hex) - 7 (Dec)        |   |     |   |               |                |               |  |  |  |  |
|---------|------|---------------------------------------|---|-----|---|---------------|----------------|---------------|--|--|--|--|
| Bit     | 7    | 6                                     | 5 | 4   | 3 | 2 1           |                | 0             |  |  |  |  |
| Fields  |      | int_mask_y int_y_high_pos int_y_low_p |   |     |   | int_y_low_pos | int_y_high_neg | int_y_low_neg |  |  |  |  |
| Access  | R/W  |                                       |   | R/W |   | R             | R              | R             |  |  |  |  |
| Default | 0000 |                                       |   |     | 0 | 0             | 0              | 0             |  |  |  |  |

### Description

Interrupt mask, Y axis zones

#### **Fields**

int\_mask\_y: For each bit mask it enables (1) or disables (0) the interrupt generation for threshold event
 detection on Y axis.
 Dit 0: each la (1) (disable (0) the event int v; law, nee

Bit 0: enable (1)/disable (0) the event int\_y\_low\_neg.

Bit 1: enable (1)/disable (0) the event int\_y\_high\_neg.

Bit 2: enable (1)/disable (0) the event int\_y\_low\_pos.

Bit 3: enable (1)/disable (0) the event int\_y\_high\_pos.

For example: writing int\_mask\_y = 4'b0100 only the event int\_y\_low\_pos will generate an interrupt.

#### int\_y\_high\_pos: Signal is positive, above threshold.

0: False 1: True

int\_y\_low\_pos: Signal is positive, below threshold.

0: False 1: True

*int\_y\_high\_neg:* Signal is negative, above threshold.

0: False 1: True

int\_y\_low\_neg: Signal is negative below threshold.

0: False

1: True

# INT\_MSK\_Z

| Address |      | Bank 01 - 0x08 (Hex) - 8 (Dec) |       |   |                |               |                |               |  |  |  |  |
|---------|------|--------------------------------|-------|---|----------------|---------------|----------------|---------------|--|--|--|--|
| Bit     | 7    | 6                              | 5     | 4 | 3              | 2             | 1              | 0             |  |  |  |  |
| Fields  |      | int_m                          | ask_z |   | int_z_high_pos | int_z_low_pos | int_z_high_neg | int_z_low_neg |  |  |  |  |
| Access  |      | R/                             | W     |   | R              | R             | R              | R             |  |  |  |  |
| Default | 0000 |                                |       |   | 0              | 0             | 0              | 0             |  |  |  |  |

### Description

Interrupt mask, Z axis zones.

#### **Fields**

int\_mask\_z: For each bit mask it enables (1) or disables (0) the interrupt generation for threshold event detection on Z axis. Bit 0: enable (1)/disable (0) the event int\_z\_low\_neg.

Bit 0: enable (1)/disable (0) the event int\_2\_low\_neg.

Bit 1: enable (1)/disable (0) the event int\_z\_high\_neg.

Bit 2: enable (1)/disable (0) the event int\_z\_low\_pos. Bit 3: enable (1)/disable (0) the event int\_z\_high\_pos.

\_\_\_\_\_

For example: writing int\_mask\_z = 4'b0100 only the event int\_z\_low\_pos will generate an interrupt.

int\_z\_high\_pos: Signal is positive, above threshold.

0: False 1: True

*int\_z\_low\_pos:* Signal is positive, below threshold.

0: False 1: True

int\_z\_high\_neg: Signal is negative, above threshold.

- 0: False 1: True
- int\_z\_low\_neg: Signal is negative below threshold.
  - 0: False
  - 1: True

# INT\_MASK\_AO

| Address |     | Bank 01 - 0x09 (Hex) - 9 (Dec) |     |              |    |                 |     |  |  |  |  |  |
|---------|-----|--------------------------------|-----|--------------|----|-----------------|-----|--|--|--|--|--|
| Bit     | 7   | 6                              | 5   | 1            | 0  |                 |     |  |  |  |  |  |
| Fields  | RFU | int_freeze                     | int | t_mask_xyz_a | nd | int_mask_xyz_or |     |  |  |  |  |  |
| Access  | R   | R/W                            |     | R/W          |    | R/W             |     |  |  |  |  |  |
| Default | -   | 0                              |     | 000          |    |                 | 000 |  |  |  |  |  |

### Description

Interrupt masks, and/or

#### **Fields**

int\_freeze: Enables interrupt on threshold freeze.
 When enabled, the INT{X,Y,Z}\_{HIGH,LOW}\_{NEG,POS} flags hold values until interrupt
 will be cleared.
 0: Disabled
 1: Enabled

- *int\_mask\_xyz\_and:* Each bit activates an axis. The active axes are ANDed together to generate the AND interrupt.
  - int\_mask\_xyz\_or: Each bit activates an axis. The active axes are ORed together to generate the OR
    interrupt.

# INT\_CFG\_1

| Address |                                      |   |              | Bank 01 -      | 0x0A (Hex) - 10 ( | Dec)         |     |   |
|---------|--------------------------------------|---|--------------|----------------|-------------------|--------------|-----|---|
| Bit     | 7                                    | 6 | 5            | 4              | 3                 | 2            | 1   | 0 |
| Fields  | <pre>sns_intp_fsc int1_clk_out</pre> |   | int2_clk_out | int_single_deb | int_single_ref    | sns_intp_hpf | RFU |   |
| Access  | R/                                   | W | R/W          | R/W            | R/W               | R/W          | R/W | R |
| Default | 0                                    | 0 | 0            | 0              | 0                 | 0            | 0   | - |

### Description

Interrupt configuration register 1

#### **Fields**

*sns\_intp\_fsc:* Sets the full-scale applied to the gyroscope data used to issue the AND/OR interrupts.

00: 2000 dps 01: 1000 dps 10: 500 dps 11: 250 dps

*int1\_clk\_out:* INT1 pad drives out the internal clock (8.8MHz).

0: Off 1: On

int2\_clk\_out: INT2 pad drives out the internal clock (8.8MHz).

| 0: | Off |
|----|-----|
| 1: | On  |

*int\_single\_deb:* When on, the same duration (int\_deb\_x) is used for all the axes.

0: Off 1: On

*int\_single\_ref:* When on, the same threshold (int\_ref\_x, int\_ref\_y) is used for all the axes.

0: Off

1: On

sns\_intp\_hpf: Enable the highpass filtering to the gyroscope data out used to issue the AND/OR
interrupts.

0: Without highpass filtering

1: With highpass filtering

# INT\_CFG\_2

| Address |     |                        |             | Bank 01 - 0           | x0B (Hex) - 1     | 1 (Dec)     |                       |                   |  |
|---------|-----|------------------------|-------------|-----------------------|-------------------|-------------|-----------------------|-------------------|--|
| Bit #   | 7   | 7 6 5 4 3 2 1 0        |             |                       |                   |             |                       |                   |  |
| Fields  | RFU | merge_int2<br>_to_int1 | int1_enable | int1_active_<br>level | int1_out_<br>mode | int2_enable | int2_active<br>_level | int2_out_<br>mode |  |
| Access  | R   | R/W                    | R/W         | R/W                   | R/W               | R/W         | R/W                   | R/W               |  |
| Default | —   | 0                      | 1           | 0                     | 0                 | 1           | 0                     | 0                 |  |

### Description

Interrupt configuration register 2

#### **Fields**

*merge\_int2\_to\_int1:* Enables to merge the INT1 and INT2. When set, the interrupt INT1 changes its output depending on both INT1 and INT2.

0: INT1 and INT2 separated 1: INT2 merged with INT1

int1\_enable: Enables interrupts on INT1.

0: Disabled 1: Enabled

*int1\_active\_level:* Sets the INT1 active level.

0: INT1 active high 1: INT1 active low

int1\_out\_mode: Sets the INT1 output configuration.

0: Push-pull 1: Open drain

int2\_enable: Enables interrupts on INT2.

0: Disabled 1: Enabled

int2\_active\_level: Sets the INT2 active level.

0: INT2 active high 1: INT2 active low

int2\_out\_mode: Sets the INT2 output configuration.

0: Push-pull 1: Open drain

# INT\_TMO

| Address |           | Bank 01 - 0x0C (Hex) - 12 (Dec) |           |         |             |   |   |   |  |  |  |  |
|---------|-----------|---------------------------------|-----------|---------|-------------|---|---|---|--|--|--|--|
| Bit #   | 7         | 6                               | 5         | 4       | 3           | 2 | 1 | 0 |  |  |  |  |
| Fields  | int1_late | ch_mode                         | int2_late | ch_mode | int_timeout |   |   |   |  |  |  |  |
| Access  | R/        | W                               | R/        | 'W      | R/W         |   |   |   |  |  |  |  |
| Default | 0         | 0                               | 0         | 0       | 0000        |   |   |   |  |  |  |  |

## Description

Interrupt timeout

#### **Fields**

*int1\_latch\_mode:* Set the INT1 latch mode.

00: Not latched 01: Latched - Clear on read 10: Latched - Clear on write

*int2\_latch\_mode:* Set the INT2 latch mode.

00: Not latched 01: Latched - Clear on read 10: Latched - Clear on write

*int\_timeout:* Interrupt temporary period. This is shared between INT1 and INT2.

0000: 125µs 0001: 250µs 0010: 500µs 0011: 1ms 0100: 2ms 0101: 5ms 0110: 10ms 1010: 50ms 1001: 100ms 1010: 200ms 1011: 500ms

# INT\_STS\_UL

| Address |                       | Bank 01 - 0x0D (Hex) - 13 (Dec) |                         |                     |                    |                   |                            |                      |  |  |
|---------|-----------------------|---------------------------------|-------------------------|---------------------|--------------------|-------------------|----------------------------|----------------------|--|--|
| Bit     | 7                     | 7 6 5 4 3 2 1 0                 |                         |                     |                    |                   |                            |                      |  |  |
| Fields  | sts_ul_data<br>_ready | sts_ul_fifo_<br>empty           | sts_ul_fifo_<br>overrun | sts_ul_fifo<br>_ths | sts_ul_int<br>_and | sts_ul_int_<br>or | sts_ul_otp_<br>downloading | sts_ul_<br>data_sync |  |  |
| Access  | R                     | R                               | R                       | R                   | R                  | R                 | R                          | R                    |  |  |
| Default | 0                     | 0                               | 0                       | 0                   | 0                  | 0                 | 0                          | 0                    |  |  |

### Description

Interrupt sources, unlatched.

Unlatched interrupts status bits.

### **Fields**

sts\_ul\_data\_ready: DATA\_READY status

sts\_ul\_fifo\_empty: FIFO\_EMPTY status

sts\_ul\_fifo\_overrun: FIFO\_OVERRUN status

sts\_ul\_fifo\_ths: FIFO\_THRESHOLD status

sts\_ul\_int\_and: INT\_AND status

sts\_ul\_int\_or: INT\_OR status

sts\_ul\_otp\_downloading: OTP\_DOWNLOADING status

sts\_ul\_data\_sync: DATA\_SYNC status

# INT\_STS

| Address |                   | Bank 01 - 0x0E (Hex) - 14 (Dec) |                       |                   |             |             |                         |           |  |  |
|---------|-------------------|---------------------------------|-----------------------|-------------------|-------------|-------------|-------------------------|-----------|--|--|
| Bit #   | 7                 | 7 6 5 4 3 2 1 0                 |                       |                   |             |             |                         |           |  |  |
| Fields  | sts_i1_data_      | sts_i1_fifo                     | sts_i1_fifo           | sts_i1_fifo       | sts_i2_int_ | sts_i2_int_ | sts_i2_otp_             | sts_i2_   |  |  |
|         | ready             | _empty                          | _overrun              | _ths              | and         | or          | downloading             | data_sync |  |  |
| Access  | <i>ready</i><br>R | _ <i>empty</i><br>R             | _ <b>overrun</b><br>R | _ <i>ths</i><br>R | and<br>R    | or<br>R     | <i>downloading</i><br>R | data_sync |  |  |

### Description

Interrupt status register

Latched status bits.

**Fields** 

- sts\_i1\_fifo\_empty: FIFO\_EMPTY status on INT1
- sts\_i1\_fifo\_overrun: FIFO\_OVERRUN status on INT1

sts\_i1\_fifo\_ths: FIFO\_THRESHOLD status on INT1

sts\_i2\_int\_and: INT\_AND status on INT2

sts\_i2\_int\_or: INT\_OR status on INT2

sts\_i2\_otp\_downloading: OTP\_DOWNLOADING status on INT2

sts\_i2\_data\_sync: DATA\_SYNC status on INT2

# INT\_MSK

| Address | Bank 01 - 0x0F (Hex) - 15 (Dec) |                 |     |     |     |     |     |     |  |  |
|---------|---------------------------------|-----------------|-----|-----|-----|-----|-----|-----|--|--|
| Bit #   | 7                               | 7 6 5 4 3 2 1 0 |     |     |     |     |     |     |  |  |
| Fields  | msk_i1_data<br>_ready           |                 |     |     |     |     |     |     |  |  |
| Access  | R/W                             | R/W             | R/W | R/W | R/W | R/W | R/W | R/W |  |  |
| Default | 1                               | 0               | 0   | 0   | 0   | 0   | 1   | 0   |  |  |

### Description

Interrupt mask register

Enables the interrupt status (0: disabled, 1: enabled).

### **Fields**

msk\_i1\_data\_ready: DATA\_READY status on INT1

msk\_i1\_fifo\_empty: FIFO\_EMPTY status on INT1

msk\_i1\_fifo\_overrun: FIFO\_OVERRUN status on INT1

msk\_i1\_fifo\_ths: FIFO\_THRESHOLD status on INT1

msk\_i2\_int\_and: INT\_AND status on INT2

msk\_i2\_int\_or: INT\_OR status on INT2

msk\_i2\_otp\_downloading: OTP\_DOWNLOADING status on INT2

msk\_i2\_data\_sync: DATA\_SYNC status on INT2

# INT\_SRC\_SEL

| Address | Bank 01 - 0x17 (Hex) - 23 (Dec) |                 |                       |                       |                       |                       |        |       |  |  |  |  |
|---------|---------------------------------|-----------------|-----------------------|-----------------------|-----------------------|-----------------------|--------|-------|--|--|--|--|
| Bit #   | 7                               | 7 6 5 4 3 2 1 0 |                       |                       |                       |                       |        |       |  |  |  |  |
| Fields  | RI                              | Ū               | msk_gyr_int_d<br>_rdy | msk_acc_int_d_<br>rdy | msk_mag_int_d<br>_rdy | msk_qua_int_d_<br>rdy | int_sr | c_cfg |  |  |  |  |
| Access  | R                               |                 | R/W                   | R/W                   | R/W                   | R/W                   | R/     | W     |  |  |  |  |
| Default |                                 |                 |                       |                       |                       |                       |        |       |  |  |  |  |

### Description

Interrupt source selection

#### **Fields**

*msk\_gyr\_int\_d\_rdy:* If set, a new gyroscope data contributes to DATA\_READY interrupt assertion.

- 0: None
- 1: New gyroscope data to data ready

*msk\_acc\_int\_d\_rdy:* If set, a new accelerometer data contributes to DATA\_READY interrupt assertion.

- 0: None
- 1: New accelerometer data to data ready

*msk\_mag\_int\_d\_rdy:* If set, a new magnetometer data set contributes to data ready interrupt assertion.

0: None

1: New magnetometer data to data ready

*msk\_qua\_int\_d\_rdy:* When 1 a new quaternion data set contributes to data ready interrupt assertion.

- 0: None
- 1: New quaternion data to data ready

int\_src\_cfg: Configures the interrupt source.

00: gyr\_x, gyr\_y, gyr\_z 10: norm(a\_hpf), norm(a\_hpf), norm(a\_pre\_hpf) 11: norm(a\_hpf), norm(a\_pre\_hpf), norm(a\_pre\_hpf)

| Address | Bank 01 - 0x1A (Hex) - 26 (Dec) |   |  |      |      |  |  |  |  |  |
|---------|---------------------------------|---|--|------|------|--|--|--|--|--|
| Bit     | 7 6 5 4 3 2 1 0                 |   |  |      |      |  |  |  |  |  |
| Fields  |                                 | _ |  |      |      |  |  |  |  |  |
| Access  |                                 |   |  | F    | 2    |  |  |  |  |  |
| Default |                                 |   |  | 0000 | 0000 |  |  |  |  |  |

## Description

Unique serial number, byte 5

Serial number.

| Address | Bank 01 - 0x1B (Hex) - 27 (Dec) |  |  |      |      |  |  |  |  |
|---------|---------------------------------|--|--|------|------|--|--|--|--|
| Bit     | 7 6 5 4 3 2 1 0                 |  |  |      |      |  |  |  |  |
| Fields  | _                               |  |  |      |      |  |  |  |  |
| Access  |                                 |  |  | F    | 2    |  |  |  |  |
| Default |                                 |  |  | 0000 | 0000 |  |  |  |  |

## Description

Unique serial number, byte 4.

Serial number.

| Address | Bank 01 - 0x1C (Hex) - 28 (Dec) |   |  |      |      |  |  |  |  |  |
|---------|---------------------------------|---|--|------|------|--|--|--|--|--|
| Bit     | 7 6 5 4 3 2 1 0                 |   |  |      |      |  |  |  |  |  |
| Fields  |                                 | _ |  |      |      |  |  |  |  |  |
| Access  |                                 |   |  | F    | 2    |  |  |  |  |  |
| Default |                                 |   |  | 0000 | 0000 |  |  |  |  |  |

## Description

Unique serial number, byte 3.

Serial number.

| Address | Bank 01 - 0x1D (Hex) - 29 (Dec) |   |  |      |      |  |  |  |  |  |
|---------|---------------------------------|---|--|------|------|--|--|--|--|--|
| Bit     | 7 6 5 4 3 2 1 0                 |   |  |      |      |  |  |  |  |  |
| Fields  |                                 | _ |  |      |      |  |  |  |  |  |
| Access  |                                 |   |  | F    | 2    |  |  |  |  |  |
| Default |                                 |   |  | 0000 | 0000 |  |  |  |  |  |

## Description

Unique serial number, byte 2

Serial number.

| Address | Bank 01 - 0x1E (Hex) - 30 (Dec) |   |  |      |      |  |  |  |  |  |
|---------|---------------------------------|---|--|------|------|--|--|--|--|--|
| Bit     | 7 6 5 4 3 2 1 0                 |   |  |      |      |  |  |  |  |  |
| Fields  |                                 | _ |  |      |      |  |  |  |  |  |
| Access  |                                 |   |  | F    | 2    |  |  |  |  |  |
| Default |                                 |   |  | 0000 | 0000 |  |  |  |  |  |

## Description

Unique serial number, byte 1

Serial number.

| Address | Bank 01 - 0x1F (Hex) - 31 (Dec) |   |  |      |      |  |  |  |  |  |
|---------|---------------------------------|---|--|------|------|--|--|--|--|--|
| Bit     | 7 6 5 4 3 2 1 0                 |   |  |      |      |  |  |  |  |  |
| Fields  |                                 | _ |  |      |      |  |  |  |  |  |
| Access  |                                 |   |  | F    | 2    |  |  |  |  |  |
| Default |                                 |   |  | 0000 | 0000 |  |  |  |  |  |

## Description

Unique serial number, byte 0.

Serial number.

## 12.2.4Bank 02

## QUAT0\_H

| Address | Bank 02 - 0x00 (Hex) - 0 (Dec) |   |  |      |      |  |  |  |  |  |
|---------|--------------------------------|---|--|------|------|--|--|--|--|--|
| Bit     | 7 6 5 4 3 2 1 0                |   |  |      |      |  |  |  |  |  |
| Fields  |                                | _ |  |      |      |  |  |  |  |  |
| Access  |                                | R |  |      |      |  |  |  |  |  |
| Default |                                |   |  | 0000 | 0000 |  |  |  |  |  |

## Description

Bits [15:8] of the quaternion 0 measurement.

Most significant byte of the X component of the quaternion.

# QUAT0\_L

| Address | Bank 02 - 0x01 (Hex) - 1 (Dec) |   |  |      |      |  |  |  |  |  |  |
|---------|--------------------------------|---|--|------|------|--|--|--|--|--|--|
| Bit     | 7 6 5 4 3 2 1 0                |   |  |      |      |  |  |  |  |  |  |
| Fields  |                                | _ |  |      |      |  |  |  |  |  |  |
| Access  |                                |   |  | F    | R    |  |  |  |  |  |  |
| Default |                                |   |  | 0000 | 0000 |  |  |  |  |  |  |

## Description

Bits [7:0] of the quaternion 0 measurement

Least significant byte of the X component of the quaternion.

## QUAT1\_H

| Address | Bank 02 - 0x02 (Hex) - 2 (Dec) |                 |  |  |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|--|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |
| Fields  | —                              |                 |  |  |  |  |  |  |  |  |
| Access  |                                | R               |  |  |  |  |  |  |  |  |
| Default | 0000000                        |                 |  |  |  |  |  |  |  |  |

## Description

Bits [15:8] of the quaternion 1 measurement

Most significant byte of the Y component of the quaternion.

## QUAT1\_L

| Address | Bank 02 - 0x03 (Hex) - 3 (Dec) |                 |  |  |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|--|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |
| Fields  | —                              |                 |  |  |  |  |  |  |  |  |
| Access  |                                | R               |  |  |  |  |  |  |  |  |
| Default | 0000000                        |                 |  |  |  |  |  |  |  |  |

## Description

Bits [7:0] of the quaternion 1 measurement

Least significant byte of the Y component of the quaternion.

## QUAT2\_H

| Address | Bank 02 - 0x04 (Hex) - 4 (Dec) |                 |  |  |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|--|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |
| Fields  | —                              |                 |  |  |  |  |  |  |  |  |
| Access  |                                | R               |  |  |  |  |  |  |  |  |
| Default | 0000000                        |                 |  |  |  |  |  |  |  |  |

## Description

Bits [15:8] of the quaternion 2 measurement

Most significant byte of the Z component of the quaternion.

## QUAT2\_L

| Address | Bank 02 - 0x05 (Hex) - 5 (Dec) |                 |  |  |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|--|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |
| Fields  | _                              |                 |  |  |  |  |  |  |  |  |
| Access  |                                | R               |  |  |  |  |  |  |  |  |
| Default | 0000000                        |                 |  |  |  |  |  |  |  |  |

## Description

Bits [7:0] of the quaternion 2 measurement

Least significant byte of the Z component of the quaternion.

## QUAT3\_H

| Address | Bank 02 - 0x06 (Hex) - 6 (Dec) |                 |  |  |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|--|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |
| Fields  | —                              |                 |  |  |  |  |  |  |  |  |
| Access  |                                | R               |  |  |  |  |  |  |  |  |
| Default | 0000000                        |                 |  |  |  |  |  |  |  |  |

## Description

Bits [15:8] of the quaternion 3 measurement.

Most significant byte of the scalar component of the quaternion.

## QUAT3\_L

| Address | Bank 02 - 0x07 (Hex) - 7 (Dec) |                 |  |  |  |  |  |  |  |  |
|---------|--------------------------------|-----------------|--|--|--|--|--|--|--|--|
| Bit     | 7                              | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |
| Fields  | —                              |                 |  |  |  |  |  |  |  |  |
| Access  |                                | R               |  |  |  |  |  |  |  |  |
| Default | 0000000                        |                 |  |  |  |  |  |  |  |  |

## Description

Bits [7:0] of the quaternion 3 measurement.

Least significant byte of the scalar component of the quaternion.

# BIAS\_GYRO\_X\_H

| Address |                         |   | В | ank 02 - 0x13 | (Hex) - 19 (De | c)    |   |   |
|---------|-------------------------|---|---|---------------|----------------|-------|---|---|
| Bit     | 7                       | 6 | 5 | 4             | 3              | 2     | 1 | 0 |
| Fields  | RFU bias_comp_gyr_x_msb |   |   |               |                |       |   |   |
| Access  |                         | R |   | R/W           |                |       |   |   |
| Default |                         | _ |   |               |                | 00000 |   |   |

## Description

Gyroscope bias compensation, X axis, MSB

### **Fields**

The real value range is: [-34.13; +34.13] dps.

# BIAS\_GYRO\_\_X\_L

| Address | Bank 02 - 0x14 (Hex) - 20 (Dec) |                 |  |  |  |  |  |  |  |  |  |
|---------|---------------------------------|-----------------|--|--|--|--|--|--|--|--|--|
| Bit     | 7                               | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |  |
| Fields  | bias_comp_gyr_x_lsb             |                 |  |  |  |  |  |  |  |  |  |
| Access  |                                 | R/W             |  |  |  |  |  |  |  |  |  |
| Default | 0000000                         |                 |  |  |  |  |  |  |  |  |  |

## Description

Gyroscope bias compensation, X axis, LSB

#### **Fields**

# BIAS\_GYRO\_Y\_H

| Address |   |     | В | ank 02 - 0x15 | (Hex) - 21 (De | c)           |     |   |
|---------|---|-----|---|---------------|----------------|--------------|-----|---|
| Bit     | 7 | 6   | 5 | 4             | 3              | 2            | 1   | 0 |
| Fields  |   | RFU |   |               | bias_          | _comp_gyr_y_ | msb |   |
| Access  |   | R   |   | R/W           |                |              |     |   |
| Default |   | _   |   |               |                | 00000        |     |   |

## Description

Gyroscope bias compensation, Y axis, MSB

### **Fields**

bias\_comp\_gyr\_y\_msb: Most significant bits of the 13-bit gyroscope offset compensation register for the Y axis.
 The real value is computed as: bias\_comp\_gyr x 8.33mdps.
 The real value range is: [-34.13; +34.13] dps.

# BIAS\_GYRO\_Y\_L

| Address | Bank 02 - 0x16 (Hex) - 22 (Dec) |                 |  |  |  |  |  |  |  |  |  |
|---------|---------------------------------|-----------------|--|--|--|--|--|--|--|--|--|
| Bit     | 7                               | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |  |
| Fields  | bias_comp_gyr_y_lsb             |                 |  |  |  |  |  |  |  |  |  |
| Access  |                                 | R/W             |  |  |  |  |  |  |  |  |  |
| Default | 0000000                         |                 |  |  |  |  |  |  |  |  |  |

## Description

Gyroscope bias compensation, Y axis, LSB

#### **Fields**

bias\_comp\_gyr\_y\_lsb: Least significant byte of the 13-bit gyroscope offset compensation register for the Y
axis.
The real value is computed as: bias\_comp\_gyr x 8.33mdps.
The real value range is: [-34.13; +34.13] dps.

# BIAS\_GYRO\_Z\_H

| Address |                                |   | В | ank 02 - 0x17 | (Hex) - 23 (De | c)    |   |   |
|---------|--------------------------------|---|---|---------------|----------------|-------|---|---|
| Bit     | 7                              | 6 | 5 | 4             | 3              | 2     | 1 | 0 |
| Fields  | RFU <i>bias_comp_gyr_z_msb</i> |   |   |               |                |       |   |   |
| Access  |                                | R |   | R/W           |                |       |   |   |
| Default |                                | _ |   |               |                | 00000 |   |   |

## Description

Gyroscope bias compensation, Z axis, MSB.

#### **Fields**

bias\_comp\_gyr\_z\_msb: Most significant bits of the 13-bit gyroscope offset compensation register for the Z
axis.
The real value is computed as: bias\_comp\_gyr x 8.33mdps.

The real value range is: [-34.13; +34.13] dps.

# BIAS\_GYRO\_Z\_L

| Address | Bank 02 - 0x18 (Hex) - 24 (Dec) |                 |  |  |  |  |  |  |  |  |  |
|---------|---------------------------------|-----------------|--|--|--|--|--|--|--|--|--|
| Bit     | 7                               | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |  |
| Fields  | bias_comp_gyr_z_lsb             |                 |  |  |  |  |  |  |  |  |  |
| Access  |                                 | R/W             |  |  |  |  |  |  |  |  |  |
| Default | 0000000                         |                 |  |  |  |  |  |  |  |  |  |

## Description

Gyroscope bias compensation, Z axis, LSB

#### **Fields**

bias\_comp\_gyr\_z\_lsb: Least significant byte of the 13-bit gyroscope offset compensation register for the Z
axis.
The real value is computed as: bias\_comp\_gyr x 8.33mdps.
The real value range is: [-34.13; +34.13] dps.

## BIAS\_ACC\_X

| Address | Bank 02 - 0x19 (Hex) - 25 (Dec) |        |                 |  |  |  |  |  |  |  |  |
|---------|---------------------------------|--------|-----------------|--|--|--|--|--|--|--|--|
| Bit     | 7                               | 6      | 6 5 4 3 2 1 0   |  |  |  |  |  |  |  |  |
| Fields  | RFU                             |        | bias_comp_acc_x |  |  |  |  |  |  |  |  |
| Access  | R                               |        | R/W             |  |  |  |  |  |  |  |  |
| Default | _                               | 000000 |                 |  |  |  |  |  |  |  |  |

## Description

Accelerometer bias compensation, X axis

### **Fields**

bias\_comp\_acc\_x: Accelerometer offset compensation register for the X axis. The real value is computed as: bias\_comp\_acc x 4.2666mg. The real value range is: [-0.54; +0.54] g.

# BIAS\_ACC\_Y

| Address | Bank 02 - 0x1A (Hex) - 26 (Dec) |   |                 |  |  |  |  |  |  |  |  |
|---------|---------------------------------|---|-----------------|--|--|--|--|--|--|--|--|
| Bit     | 7                               | 6 | 6 5 4 3 2 1 0   |  |  |  |  |  |  |  |  |
| Fields  | RFU                             |   | bias_comp_acc_y |  |  |  |  |  |  |  |  |
| Access  | R                               |   | R/W             |  |  |  |  |  |  |  |  |
| Default | _                               |   | 000000          |  |  |  |  |  |  |  |  |

## Description

Accelerometer bias compensation, Y axis

### **Fields**

*bias\_comp\_acc\_y:* Accelerometer offset compensation register for the Y axis. The real value is computed as: bias\_comp\_acc x 4.2666mg. The real value range is: [-0.54; +0.54] g.

## BIAS\_ACC\_Z

| Address | Bank 02 - 0x1B (Hex) - 27 (Dec) |   |                 |  |  |  |  |  |  |  |  |
|---------|---------------------------------|---|-----------------|--|--|--|--|--|--|--|--|
| Bit     | 7                               | 6 | 6 5 4 3 2 1 0   |  |  |  |  |  |  |  |  |
| Fields  | RFU                             |   | bias_comp_acc_z |  |  |  |  |  |  |  |  |
| Access  | R                               |   | R/W             |  |  |  |  |  |  |  |  |
| Default | _                               |   | 000000          |  |  |  |  |  |  |  |  |

## Description

Accelerometer bias compensation, Z axis

### **Fields**

*bias\_comp\_acc\_z:* Accelerometer offset compensation register for the Z axis. The real value is computed as: bias\_comp\_acc x 4.2666 mg. The real value range is: [-0.54; +0.54] g.

# FUS\_CFG0

| Address | Bank 02 - 0x1C (Hex) - 28 (Dec) |         |   |              |               |       |      |        |  |
|---------|---------------------------------|---------|---|--------------|---------------|-------|------|--------|--|
| Bit     | 7                               | 6       | 5 | 4            | 3             | 2     | 1    | 0      |  |
| Fields  |                                 | fus_odr |   | fus_gr_hd_en | fus_auto_mode | fus_r | node | fus_en |  |
| Access  |                                 | R/W     |   | R/W          | R/W           | R/    | W    | R/W    |  |
| Default |                                 | 000     |   | 0            | 0             | 0     | 0    | 0      |  |

### Description

MME configuration register 1

#### **Fields**

fus\_odr: Fusion output data rate (ODR), computed as a ratio of the sense ODR (sns\_odr).
The sense ODR is the maximum between the accelerometer ODR and the gyroscope ODR.
Fusion ODR = sns\_odr / (fus\_odr + 1)

- *fus\_gr\_hd\_en:* When = 1, gravity and heading estimation is enabled and outputted in place of quaternion.
  - 0: Disabled 1: Enabled

*fus\_auto\_mode:* Enables the automatic managing of the fusion mode.

When enabled, the fusion mode is automatically managed according to power modes and sensor anomalies.

- 0: Normal 1: Auto
- fus\_mode: Sets the fusion mode.
  - 00: G+A+M 01: A+M 10: G only 11: G+A+M

*fus\_en:* Enables the fusion computation to produce the quaternion data.

0: Disabled 1: Enabled

# FUS\_CFG1

| Address | Bank 02 - 0x1D (Hex) - 29 (Dec) |  |                 |   |                   |                    |        |  |  |  |
|---------|---------------------------------|--|-----------------|---|-------------------|--------------------|--------|--|--|--|
| Bit     | 7 6 5 4 3                       |  | 2               | 1 | 0                 |                    |        |  |  |  |
| Fields  | fus_alpha0_trim                 |  | fus_alpha1_trim |   | force_mag_anomaly | mag_anomaly_mon_en | mag_sw |  |  |  |
| Access  | R/W                             |  | R/W             |   | R/W               | R/W                | R/W    |  |  |  |
| Default | 010                             |  | 11              |   | 0                 | 0                  | 0      |  |  |  |

### Description

MME configuration register 2

#### **Fields**

fus\_alpha0\_trim: Complementary adaptive filter minimum alpha0 factor.

000: alpha0 = 0.95 001: alpha0 = 0.96 010: alpha0 = 0.97 011: alpha0 = 0.98 100: alpha0 = 0.99 101: alpha0 = 0.994 110: alpha0 = 0.997 111: alpha0 = 0.999

*fus\_alpha1\_trim:* Complementary adaptive filter minimum alpha1 factor.

00: alpha1 = alpha0 01: alpha1 = alpha0\*2/3 + 1/3 10: alpha1 = alpha0\*1/3 + 2/3 11: alpha1 = 1

*force\_mag\_anomaly:* When written high, magnetometer anomaly is emulated through SW.

*mag\_anomaly\_mon\_en:* When high, Mag X read data LSB is used as active high magnetometer anomaly monitor information.

mag\_sw: When = 1, magnetometer triad is provide externally through SW on ofs fields after SW compensation.

## GYR\_ODR\_TRIM

| Address | Bank 02 - 0x1F (Hex) - 31 (Dec) |        |         |   |        |        |        |     |  |  |
|---------|---------------------------------|--------|---------|---|--------|--------|--------|-----|--|--|
| Bit     | 7                               | 6      | 5       | 4 | 3      | 2      | 1      | 0   |  |  |
| Fields  |                                 | gyr_od | lr_corr |   | gyr_ok | acc_ok | mag_ok | RFU |  |  |
| Access  |                                 | F      | 2       |   | R      | R      | R      | R   |  |  |
| Default |                                 | 01     | 11      |   | 0      | 0      | 0      | 0   |  |  |

## Description

Gyroscope ODR correction factor register

#### **Fields**

gyr\_odr\_corr: Real gyroscope output data rate correction factor.

| 0000: 0.901 |
|-------------|
| 0001: 0.915 |
| 0010: 0.928 |
| 0011: 0.942 |
| 0100: 0.956 |
| 0101: 0.971 |
| 0110: 0.985 |
| 0111: 1.000 |
| 1000: 1.015 |
| 1001: 1.030 |
| 1010: 1.046 |
| 1011: 1.061 |
| 1100: 1.077 |
| 1101: 1.093 |
| 1110: 1.110 |
| 1111: 1.126 |
|             |

gyr\_ok: Gyroscope drive loop is locked in amplitude and gyro sense chain is active.

0: Not OK 1: OK

*acc\_ok:* Accelerometer sense chain is active.

0: Not OK 1: OK

*mag\_ok:* Readback information: magnetometer read on I<sup>2</sup>C master is active and no magnetic anomaly is detected.

0: Not OK 1: OK

## **REVISION HISTORY**

| Revision, Date | Change          | Page(s) |
|----------------|-----------------|---------|
| 1.0, 07/15     | Initial release | _       |
|                |                 |         |