

# BMA490L

# High-performance longevity acceleration sensor



# **BMA490L - Data Sheet**

Document revision 2.1

Document release date March 2021

Document number BST-BMA490L-DS000-03

Sales Part number 0273 017 021

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

notice. Product photos and pictures are for illustration purposes only

and may differ from the real product appearance

# **BMA490L - Basic Description**

BMA490L is a high-performance longevity acceleration sensor with extended availability of up to ten years<sup>1</sup>. It is a 16 bit, digital, triaxial acceleration sensor with intelligent on-chip motion-triggered interrupt features optimized for industrial applications.

#### **Key features:**

Small package size
 LGA package (12 pins), footprint 2mm x 2mm, height 0.95 mm

• Digital Interface SPI (4-wire, 3-wire), I<sup>2</sup>C, 2 interrupt pins, V<sub>DDIO</sub> voltage range:

1.2V to 3.6V

Programmable functionality
 Acceleration ranges ±2g/±4g/±8g/±16g

Low-pass filter bandwidths 684Hz -<8Hz up to a max. output

data read out of 1.6 kHz

On-chip FIFO
 Integrated FIFO on sensor with 1 kb

On-chip interrupt features
 Any-/No-Motion interrupt

Ultra-low power
 Low current consumption of data acquisition and all integrated

features

(Secondary) Auxiliary Interface Hub for ext. Magnetometer and data synchronization

• ROHS complaint, halogen free

#### **Typical applications:**

- Industrial IoT (IIoT), e.g. predictive maintenance, vibration monitoring
- · Logistics, e.g. asset tracking
- Agricultural and industrial robots, e.g. orientation detection, tilt detection
- White goods and home appliances, e.g. vibration monitoring, power management
- Power tools, e.g. power management, device level detection



.

<sup>&</sup>lt;sup>1</sup> See longevity disclaimer on the last page of this document.

# **Index of Contents**

| ВМ | /A490 | L - Basic   | : Description                                      | 2  |
|----|-------|-------------|----------------------------------------------------|----|
| 1. | Spec  | ification . |                                                    | 8  |
|    | 1.1   | Electrical  | l Specification                                    | 8  |
| 2. | Abso  | lute max    | imum ratings                                       | 10 |
| 3. | Quic  | k Start Gı  | uide                                               | 11 |
|    |       |             |                                                    |    |
| 4. | Func  | tional De   | escription                                         | 14 |
|    | 4.1   | Block Dia   | agram                                              | 14 |
|    | 4.2   | Supply V    | oltage and Power Management                        | 14 |
|    | 4.3   | Device In   | nitialization                                      | 15 |
|    | 4.4   | Power M     | lodes                                              | 16 |
|    | 4.5   | Sensor D    | Oata                                               | 17 |
|    |       | 4.5.1       | Acceleration Data                                  | 17 |
|    |       | 4.5.2       | Filter Settings                                    | 17 |
|    |       | 4.5.3       | Accelerometer data processing for performance mode | 18 |
|    |       | 4.5.4       | Accelerometer data processing for low power mode   | 19 |
|    |       | 4.5.5       | Data Ready Interrupt                               | 19 |
|    |       | 4.5.6       | Temperature Sensor                                 | 19 |
|    |       | 4.5.7       | Sensor Time                                        | 20 |
|    |       | 4.5.8       | Configuration Changes                              | 20 |
|    | 4.6   | FIFO        |                                                    | 22 |
|    |       | 4.6.1       | Frames                                             | 22 |
|    |       | 4.6.2       | Conditions and Details                             | 24 |
|    |       | 4.6.3       | FIFO data synchronization                          | 26 |
|    |       | 4.6.4       | FIFO synchronization with external interrupts      | 28 |
|    |       | 4.6.5       | FIFO Interrupts                                    | 28 |
|    |       | 4.6.6       | FIFO Flush                                         | 28 |
|    | 4.7   | Integrate   | ed Features set:                                   | 29 |
|    |       | 4.7.1       | Any Motion / No motion detection                   | 29 |

|    | 4.8   | General I  | Interrupt Pin configuration                 | .32 |
|----|-------|------------|---------------------------------------------|-----|
|    | 4.9   | -          | Sensor Interface                            |     |
|    |       | 4.9.2      | Interface Configuration                     | .33 |
|    |       | 4.9.3      | Setup mode (AUX_IF_CONF.aux_manual_en =0b1) | .35 |
|    |       | 4.9.4      | Data mode (AUX_IF_CONF.aux_manual_en=0)     | .37 |
|    |       | 4.9.5      | Delay (Time Offset)                         | .37 |
|    | 4.10  | Sensor S   | self-Test                                   | .38 |
|    | 4.11  | Offset Co  | ompensation                                 | .39 |
|    |       |            | Manual Offset Compensation                  |     |
|    |       | 4.11.2     | Inline Calibration                          | .39 |
|    | 4.12  | ! Non-Vola | itile Memory                                | .40 |
|    | 4.13  | Soft-Res   | et                                          | .40 |
| _  |       |            |                                             |     |
| 5. | Regis | ster Desc  | ription                                     | .41 |
|    | 5.1   | General    | Remarks                                     | .41 |
|    | 5.2   | -          | Map                                         |     |
|    |       |            | Register (0x00) CHIP_ID                     |     |
|    |       |            | Register (0x02) ERR_REG                     |     |
|    |       |            | Register (0x03) STATUS                      |     |
|    |       | 5.2.4      | Register (0x0A) DATA_0                      | .46 |
|    |       | 5.2.5      | Register (0x0B) DATA_1                      | .47 |
|    |       | 5.2.6      | Register (0x0C) DATA_2                      | .47 |
|    |       | 5.2.7      | Register (0x0D) DATA_3                      | .47 |
|    |       | 5.2.8      | Register (0x0E) DATA_4                      | .48 |
|    |       | 5.2.9      | Register (0x0F) DATA_5                      | .48 |
|    |       | 5.2.10     | Register (0x10) DATA_6                      | .48 |
|    |       | 5.2.11     | Register (0x11) DATA_7                      | .49 |
|    |       | 5.2.12     | Register (0x12) DATA_8                      | .49 |
|    |       | 5.2.13     | Register (0x13) DATA_9                      | .49 |
|    |       | 5.2.14     | Register (0x14) DATA_10                     | .50 |
|    |       | 5.2.15     | Register (0x15) DATA_11                     | .50 |
|    |       |            |                                             |     |

| 5.2.16 Register (0x16) DATA_12         | 50 |
|----------------------------------------|----|
| 5.2.17 Register (0x17) DATA_13         | 51 |
| 5.2.18 Register (0x18) SENSORTIME_0    | 51 |
| 5.2.19 Register (0x19) SENSORTIME_1    | 51 |
| 5.2.20 Register (0x1A) SENSORTIME_2    | 52 |
| 5.2.21 Register (0x1B) EVENT           | 52 |
| 5.2.22 Register (0x1C) INT_STATUS_0    | 52 |
| 5.2.23 Register (0x1D) INT_STATUS_1    | 53 |
| 5.2.24 Register (0x22) TEMPERATURE     | 53 |
| 5.2.25 Register (0x24) FIFO_LENGTH_0   | 54 |
| 5.2.26 Register (0x25) FIFO_LENGTH_1   | 54 |
| 5.2.27 Register (0x26) FIFO_DATA       | 54 |
| 5.2.28 Register (0x2A) INTERNAL_STATUS | 55 |
| 5.2.29 Register (0x40) ACC_CONF        | 55 |
| 5.2.30 Register (0x41) ACC_RANGE       | 57 |
| 5.2.31 Register (0x44) AUX_CONF        | 57 |
| 5.2.32 Register (0x45) FIFO_DOWNS      | 58 |
| 5.2.33 Register (0x46) FIFO_WTM_0      | 59 |
| 5.2.34 Register (0x47) FIFO_WTM_1      | 59 |
| 5.2.35 Register (0x48) FIFO_CONFIG_0   | 59 |
| 5.2.36 Register (0x49) FIFO_CONFIG_1   | 60 |
| 5.2.37 Register (0x4B) AUX_DEV_ID      | 61 |
| 5.2.38 Register (0x4C) AUX_IF_CONF     | 61 |
| 5.2.39 Register (0x4D) AUX_RD_ADDR     | 62 |
| 5.2.40 Register (0x4E) AUX_WR_ADDR     | 62 |
| 5.2.41 Register (0x4F) AUX_WR_DATA     | 63 |
| 5.2.42 Register (0x53) INT1_IO_CTRL    | 63 |
| 5.2.43 Register (0x54) INT2_IO_CTRL    | 64 |
| 5.2.44 Register (0x55) INT_LATCH       | 65 |
| 5.2.45 Register (0x56) INT1_MAP        | 65 |
| 5.2.46 Register (0x57) INT2_MAP        | 66 |
| 5.2.47 Register (0x58) INT_MAP_DATA    | 66 |

|           |        | 5.2.48 Register (0x59) INIT_CTRL                | 67 |
|-----------|--------|-------------------------------------------------|----|
|           |        | 5.2.49 Register (0x5E) FEATURES_IN              | 67 |
|           |        | 5.2.50 Register (0x5F) INTERNAL_ERROR           | 69 |
|           |        | 5.2.51 Register (0x6A) NVM_CONF                 | 69 |
|           |        | 5.2.52 Register (0x6B) IF_CONF                  | 70 |
|           |        | 5.2.53 Register (0x6D) ACC_SELF_TEST            | 70 |
|           |        | 5.2.54 Register (0x70) NV_CONF                  | 71 |
|           |        | 5.2.55 Register (0x71) OFFSET_0                 | 72 |
|           |        | 5.2.56 Register (0x72) OFFSET_1                 | 72 |
|           |        | 5.2.57 Register (0x73) OFFSET_2                 | 73 |
|           |        | 5.2.58 Register (0x7C) PWR_CONF                 | 73 |
|           |        | 5.2.59 Register (0x7D) PWR_CTRL                 | 74 |
|           |        | 5.2.60 Register (0x7E) CMD                      | 74 |
| 6.        | Digita | al Interfaces                                   | 75 |
|           | 6.1    | Interfaces                                      | 75 |
|           | 6.2    | Primary Interface                               | 76 |
|           | 6.3    | Primary Interface I2C/SPI Protocol Selection    | 77 |
|           | 6.4    | SPI interface and protocol                      | 77 |
|           | 6.5    | Primary I2C Interface                           | 81 |
|           | 6.6    | SPI and I <sup>2</sup> C Access Restrictions    | 85 |
|           | 6.7    | Auxiliary Interface                             | 85 |
| 7.        | Pin-o  | out and Connection Diagrams                     | 86 |
|           | 7.1    | Pin-out                                         | 86 |
|           | 7.2    | Connection Diagrams without Auxiliary Interface | 87 |
|           | 7.3    | Connection Diagrams with Auxiliary Interface    | 88 |
| _         |        |                                                 |    |
| <b>შ.</b> | Pack   | age                                             | 90 |
|           | 8.1    | Package outline dimensions                      | 90 |
|           | 8.2    | Sensing axis orientation                        | 91 |
|           | 8.3    | Landing pattern recommendation                  | 93 |

| 8.4     | Marking                        | 94  |
|---------|--------------------------------|-----|
| 8.5     | Soldering guidelines           | 95  |
| 8.6     | Handling instructions          | 96  |
| 8.7     | Tape and Reel specification    | 97  |
| 8.8     | Environmental safety           | 98  |
| 9. Lega | al disclaimer                  | 99  |
| 9.1     | Engineering samples            | 99  |
| 9.2     | Product use                    | 99  |
| 9.3     | Application examples and hints | 99  |
| 10.Docu | ument history and modification | 100 |

# 1. Specification

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

# 1.1 Electrical Specification

Table 1: Electrical Parameter specification

| OPERATING CONDITIONS                           |                    |                                                                         |                      |     |                      |        |  |  |  |  |
|------------------------------------------------|--------------------|-------------------------------------------------------------------------|----------------------|-----|----------------------|--------|--|--|--|--|
| Parameter                                      | Symbol             | Condition                                                               | Min                  | Тур | Max                  | Units  |  |  |  |  |
|                                                | <b>g</b> FS2g      |                                                                         |                      | ±2  |                      | g      |  |  |  |  |
| Acceleration Range                             | <b>g</b> FS4g      | Selectable<br>via serial digital                                        |                      | ±4  |                      | g      |  |  |  |  |
| Acceleration hange                             | <b>g</b> FS8g      | interface                                                               |                      | ±8  |                      | g      |  |  |  |  |
|                                                | <b>g</b> FS16g     |                                                                         |                      | ±16 |                      | g      |  |  |  |  |
| Supply Voltage<br>Internal Domains             | $V_{DD}$           |                                                                         | 1.62                 | 1.8 | 3.6                  | V      |  |  |  |  |
| Supply Voltage<br>I/O Domain                   | $V_{\text{DDIO}}$  |                                                                         | 1.2                  | 1.8 | 3.6                  | V      |  |  |  |  |
| Voltage Input<br>Low Level                     | VIL                | SPI & I <sup>2</sup> C                                                  |                      |     | 0.3V <sub>DDIO</sub> | -      |  |  |  |  |
| Voltage Input<br>High Level                    | V <sub>IH</sub>    | SPI & I <sup>2</sup> C                                                  | 0.7V <sub>DDIO</sub> |     |                      | -      |  |  |  |  |
| Voltage Output                                 | \/                 | $V_{DDIO}$ >=1.62V,<br>$I_{OL}$ <=2mA, SPI                              |                      |     | 0.2V <sub>DDIO</sub> | -      |  |  |  |  |
| Low Level                                      | V <sub>OL</sub>    | V <sub>DDIO</sub> <1.62V,<br>I <sub>OL</sub> <=1.5mA, SPI               |                      |     | 0.2V <sub>DDIO</sub> | -      |  |  |  |  |
| Voltage Output                                 | Vон                | $V_{DDIO}$ >=1.62V,<br>$I_{OH}$ <=2mA, SPI                              | 0.8V <sub>DDIO</sub> |     |                      | -      |  |  |  |  |
| High Level                                     |                    | V <sub>DDIO</sub> <=1.62V,<br>I <sub>OH</sub> <=1.5mA, SPI              | 0.8V <sub>DDIO</sub> |     |                      | -      |  |  |  |  |
| Total Supply<br>Current in<br>Performance mode | I <sub>DD</sub>    | Nominal V <sub>DD</sub> and V <sub>DDIO</sub> , 25°C, g <sub>FS4g</sub> |                      | 150 |                      | μА     |  |  |  |  |
| Total Supply<br>Current in<br>Suspend Mode     | $I_{DDsum}$        | Nominal $V_{DD}$ and $V_{DDIO}$ , 25°C                                  |                      | 3.5 |                      | μА     |  |  |  |  |
| Total Supply<br>Current in<br>Low-power Mode   | I <sub>DDlp1</sub> | Nominal V <sub>DD</sub> and V <sub>DDIO</sub> ,<br>25°C<br>50 Hz ODR    |                      | 14  |                      | μА     |  |  |  |  |
| Power-Up Time                                  | ts_up              |                                                                         |                      |     | 1                    | ms     |  |  |  |  |
| Non-volatile<br>memory (NVM)<br>write-cycles   | п <sub>NVM</sub>   |                                                                         |                      |     | 15                   | cycles |  |  |  |  |
| Operating<br>Temperature                       | TA                 |                                                                         | -40                  |     | +85                  | °C     |  |  |  |  |

|                                               |                     | OUTPUT SIGNA                                                            | L    |                            |      |             |
|-----------------------------------------------|---------------------|-------------------------------------------------------------------------|------|----------------------------|------|-------------|
| Parameter                                     | Symbol              | Condition                                                               | Min  | Тур                        | Max  | Units       |
| Sensitivity                                   | S <sub>2g</sub>     | g <sub>FS2g</sub> , T <sub>A</sub> =25°C                                |      | 16384                      |      | LSB/g       |
|                                               | S <sub>4g</sub>     | g <sub>FS4g</sub> , T <sub>A</sub> =25°C                                |      | 8192                       |      | LSB/g       |
|                                               | S <sub>8g</sub>     | g <sub>FS8g</sub> , T <sub>A</sub> =25°C                                |      | 4096                       |      | LSB/g       |
|                                               | S <sub>16g</sub>    | g <sub>FS16g</sub> , T <sub>A</sub> =25°C                               |      | 2048                       |      | LSB/g       |
| Sensitivity<br>Temperature Drift              | TCS                 |                                                                         |      | 0.005                      |      | %/K         |
| Resolution (in ±2g range)                     |                     |                                                                         |      | 0.06                       |      | mg          |
| Zero-g Offset                                 | Off                 | Nominal V <sub>DD</sub> and VDD <sub>IO</sub> , 25°C, g <sub>FS4g</sub> |      | ±30                        |      | mg          |
| Zero-g Offset<br>Temperature Drift            | TCO                 |                                                                         |      | 0,25                       |      | mg/K        |
| Output Data Rate                              | ODR <sub>PERF</sub> | Performance mode                                                        | 12.5 |                            | 1600 | Hz          |
| Output data rate                              | ODR <sub>12.5</sub> | 3dB cutoff frequency of                                                 |      | 5.06                       |      | Hz          |
| and BW in<br>Performance mode                 | ODR <sub>25</sub>   | the accelerometer                                                       |      | 10.12                      |      | Hz          |
| Performance mode                              | ODR <sub>50</sub>   | according to ODR with normal filter mode                                |      | 20.25                      |      | Hz          |
|                                               | ODR <sub>100</sub>  | Tronnar meer meas                                                       |      | 40.5                       |      | Hz          |
|                                               | ODR <sub>200</sub>  |                                                                         |      | 80                         |      | Hz          |
|                                               | ODR <sub>400</sub>  |                                                                         |      | 162 (155<br>for Z axis)    |      | Hz          |
|                                               | ODR <sub>800</sub>  |                                                                         |      | 324<br>(262 for Z<br>axis) |      | Hz          |
|                                               | ODR <sub>1600</sub> |                                                                         |      | 684<br>(353 for Z<br>axis) |      | HZ          |
| Output Data Rate                              | ODR <sub>LPM</sub>  | Low-power mode                                                          | 0.78 |                            | 400  | Hz          |
| Nonlinearity                                  | NL                  | Nominal V <sub>DD</sub> and VDD <sub>IO</sub> , 25°C, g <sub>FS4g</sub> |      | 0.5                        |      | %FS         |
| Output Noise<br>Density                       | N <sub>dens</sub>   | Nominal V <sub>DD</sub> and VDD <sub>IO</sub> , 25°C, g <sub>FS4g</sub> |      | 120                        |      | µg/√Hz      |
| Temperature<br>sensor<br>Measurement<br>Range | Ts                  |                                                                         | -40  |                            | +80  | °C          |
| Temperature<br>Sensor Slope                   | dTs                 |                                                                         |      | 1                          |      | K/LSB       |
| Temperature<br>Sensor Offset                  | OTs                 | at 23°C                                                                 |      | 1                          |      | K           |
| Power Supply<br>Rejection Ratio               | PSRR                |                                                                         |      | 1                          |      | mg/50m<br>V |

| MECHANICAL CHARACTERISTICS |        |                                                               |     |     |     |       |  |  |  |  |
|----------------------------|--------|---------------------------------------------------------------|-----|-----|-----|-------|--|--|--|--|
| Parameter                  | Symbol | Condition                                                     | Min | Тур | Max | Units |  |  |  |  |
| Cross Axis<br>Sensitivity  | S      | relative contribution<br>between any two of the<br>three axes |     | 0,7 |     | %     |  |  |  |  |
| Alignment Error            | EA     | relative to package outline                                   |     | 0.5 |     | 0     |  |  |  |  |

# 2. Absolute maximum ratings

Table 2: Absolute maximum ratings

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

#### Note:

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

# 3. Quick Start Guide

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

#### Note about using the BMA490L:

- The communication between application processor and BMA490L will happen either over I2C or SPI interface. For more information about the interfaces, read the related chapter 6 Digital Interfaces.
- Before starting the test, the device has to be properly connected to the master (AP) and powered up. For more information about it, read the related chapter 7 Pin-out and Connection Diagrams.

### First application setup examples algorithms:

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

# Example 1: Testing communication with the BMA490L and initializing feature engine

a. -reading chip id (checking correct communication)



b. -performing initialization sequence (interrupt feature engine)



c. -checking the correct status of the interrupt feature engine



# **Example 2:** Reading acceleration data from BMA490L (example: low power mode) -setting data processing parameters (power, bandwidth, range) and reading sensor data



#### **Further steps:**

The BMA490L has many more capabilities that are described in this document and include FIFO, power saving modes, synchronization capabilities with host processor, data synchronization and integration with third party sensors, many interrupts generation and features like any motion/no motion.

# 4. Functional Description

# 4.1 Block Diagram



# 4.2 Supply Voltage and Power Management

BMA490L has two distinct power supply pins:

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

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

#### 4.3 **Device Initialization**

After power up sequence the accelerometer is in suspend mode, device must be initialized through the following procedure. Initialization has to be performed as well after every POR or soft reset.

- Disable advanced power save mode: PWR\_CONF.adv\_power\_save =0b0
- Wait for 450 us. The register SENSORTIME\_0 increments every 39.25 μsec and may be used for accurate timing.
- Write INIT\_CTRL.init\_ctrl=0x00
- Load configuration file
  - Burst write initialization data to Register FEATURES\_IN. The configuration file is included
    in the driver available on the Bosch Sensortec website (www.bosch-sensortec.com) or from
    your regional support team. Optionally the configuration file can be written to the Register
    FEATURES\_IN\_in several consecutive burst write access. Every burst write must contain
    an even number of bytes.
  - Optionally: Burst read configuration file from Register FEATURES\_IN and check correctness. Check sensor API for details of timing & length.
- Enable sensor features— write 0x01 into register INIT\_CTRL.init\_ctrl.\_This operation must not be performed more than once after POR or softreset.
- Wait until Register INTERNAL\_STATUS.message contains the value 0b1. This will happen after at most 140-150 msec.

After initialization sequence has been completed, the device is in configuration mode (power mode). Now it is possible to switch to the required power mode and all features are ready to use as described in chapter 4.

#### 4.4 Power Modes

The power state of the BMA490L is controlled through the registers PWR\_CONF and PWR\_CTRL. The Register PWR\_CTRL enables and disables the accelerometer and the auxiliary sensor. The Register PWR\_CONF controls which power state the sensors enter if they are enabled or disabled in the Register PWR\_CTRL. The power state impacts the behavior of the sensor with respect to start-up time, available functions, etc. but not the sensor data quality. The sensor data quality is controlled in the Registers ACC\_CONF.

In all global power configurations both register contents and FIFO contents are retained.

Low Power Mode: This power configuration aggressively reduces power of the device as much as possible. The low mode configuration is activated through power enabling PWR CONF.adv power save=0b1 and disabling ACC CONF.acc perf mode=0b0. this ln configuration these externally user visible features may not be available:

- Register writes need an inter-write-delay of at least 450 μs.
- The sensors log data into the FIFO in performance and low power mode. When the FIFO watermark interrupt is active, the FIFO is accessible for reading in low power mode until a burst read operation on Register FIFO\_DATA completes when PWR\_CONF.fifo\_self\_wakeup=0b1. When PWR\_CONF.fifo\_self\_wakeup=0b0, the user needs to disable advanced power save mode (PWR\_CONF.adv\_power\_save=0b0) and wait for 250 µs before reading the FIFO.
- To read out FIFO data w/o a FIFO watermark interrupt, the advanced power save configuration needs to be disabled (PWR\_CONF.adv\_power\_save=0b0)

| Usecase                     | ACC_CONF. acc_perf_m ode | PWR_CONF<br>.adv_power<br>_save | PWR_CTR<br>L.acc_en | Power consumption |
|-----------------------------|--------------------------|---------------------------------|---------------------|-------------------|
| Configuration mode          | х                        | 0                               | х                   |                   |
| Suspend (lowest power mode) | х                        | 1                               | 0                   | suspend power     |
| Performance                 | 1                        | Х                               | 1                   | Accel works in    |
| mode                        |                          |                                 |                     | continuous mode   |

Table 3: Examples with the optimal power configurations:

0

The PWR\_CTRL register is used to enable and disable sensors. Per default, all sensors are disabled. Acceleration sensor must be enabled by setting PWR\_CTRL.acc\_en=0b1.

1

1

The auxiliary sensor functionality is supported only when the auxiliary interface is connected for the auxiliary sensor operation. If the auxiliary interface is not used for auxiliary sensor operation, then the auxiliary sensor interface must remain disabled by setting PWR\_CTRL.aux\_en=0b0 (default).

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

- Set the auxiliary sensor interface to suspend in Register PWR\_CTRL.aux\_en=0b0. Changing the
  auxiliary sensor interface power mode to suspend does not imply any mode change in the
  auxiliary sensor.
- The auxiliary sensor part itself must be put into suspend mode by writing the respective configuration bits of the auxiliary sensor part. The power mode of the auxiliary sensor part is

Low power mode

Depends on

ACC\_CONF

controlled by setting the BMA490L auxiliary sensor interface into manual mode by AUX\_IF\_CONF.aux\_manual\_en=0b1 and then communicating with the auxiliary sensor part through the BMA490L registers AUX\_RD\_ADDR, AUX\_WR\_ADDR, and AUX\_WR\_DATA. For details see Chapter 4.9.

Table 4: Current consumption in low power mode

| Current Consumption <sup>2</sup> [µA] depending on number of averaged samples in low power |        |       |       |       |        |        |        |         |  |  |  |
|--------------------------------------------------------------------------------------------|--------|-------|-------|-------|--------|--------|--------|---------|--|--|--|
|                                                                                            |        |       |       | mode  |        |        |        |         |  |  |  |
| ODR                                                                                        | No Avg | Avg 2 | Avg 4 | Avg 8 | Avg 16 | Avg 32 | Avg 64 | Avg 128 |  |  |  |
| ODR 0.78                                                                                   | 3      | 3     | 3     | 4     | 4      | 5      | 7      | 12      |  |  |  |
| ODR_1.56                                                                                   | 3      | 3     | 3     | 4     | 4      | 6      | 10     | 15      |  |  |  |
| ODR_3.125                                                                                  | 4      | 4     | 4     | 6     | 8      | 12     | 21     | 39      |  |  |  |
| ODR_6.25                                                                                   | 4      | 5     | 6     | 8     | 13     | 22     | 40     | 77      |  |  |  |
| ODR_12.5                                                                                   | 6      | 7     | 9     | 14    | 23     | 40     | 77     | 152     |  |  |  |
| ODR_25                                                                                     | 8      | 11    | 14    | 24    | 43     | 79     | 152    | 152     |  |  |  |
| ODR_50                                                                                     | 14     | 18    | 27    | 45    | 83     | 152    | 152    | 152     |  |  |  |
| ODR_100                                                                                    | 22     | 32    | 51    | 87    | 152    | 152    | 152    | 152     |  |  |  |
| ODR_200                                                                                    | 42     | 60    | 97    | 152   | 152    | 152    | 152    | 152     |  |  |  |
| ODR_400                                                                                    | 80     | 118   | 152   | 152   | 152    | 152    | 152    | 152     |  |  |  |

# 4.5 **Sensor Data**

#### 4.5.1 Acceleration Data

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

#### 4.5.2 Filter Settings

The accelerometer digital filter can be configured through the Register ACC\_CONF.

Illegal settings in configuration registers will result in an error code in Register ERR\_REG. The content of the data register is undefined, and if the FIFO is used, it may contain no value.

\_

<sup>&</sup>lt;sup>2</sup> Current consumption based on limited lab measurements. Only for reference.

# 4.5.3 Accelerometer data processing for performance mode

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

The filter bandwidth shows a 3db cutoff frequency shown in the following table:

Table 5: 3dB cutoff frequency of the accelerometer according to ODR with normal filter mode

| Accelerometer ODR [Hz] | 12.5 | 25    | 50    | 100  | 200 | 400      | 800      | 1600     |
|------------------------|------|-------|-------|------|-----|----------|----------|----------|
| 3dB Cutoff frequency   | 5.06 | 10.12 | 20.25 | 40.5 | 80  | 162      | 324      | 684      |
| [Hz]                   |      |       |       |      |     | (155 for | (262 for | (353 for |
|                        |      |       |       |      |     | Z axis)  | Z axis)  | Z axis)  |

The noise is also depending on the filter settings and ODR, see table below.

Table 6: Accelerometer noise in mg according to ODR with normal filter mode (range +/- 4g) (based on device measurement)

| ODR in Hz             | 25  | 50  | 100 | 200 | 400 |
|-----------------------|-----|-----|-----|-----|-----|
| RMS-Noise (typ.) [mg] | 0.5 | 0.7 | 0.9 | 1.3 | 1.7 |

# 4.5.4 Accelerometer data processing for low power mode

be enabled PWR CONF.adv power save=0b1 Low power mode can by ACC\_CONF.acc\_perf\_mode=0b0. In this power mode, the accelerometer regularly changes between a suspend power mode phase where no measurement is performed and a performance power mode phase, where data is acquired. The period of the duty cycle for changing between suspend and performance mode will be determined by the output data rate (ACC CONF.acc odr). The output data rate can be configured in one of 10 different valid ODR configurations going from 0.78Hz up to 400Hz. The samples acquired during the normal mode phase will be averaged and the result will be the output data. The number of averaged samples can be determined by the parameter ACC\_CONF.acc\_bwp through the following formula:

```
averaged samples = 2<sup>(Val(acc_bwp))</sup>
skipped samples = (1600/ODR)-averaged samples
```

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

# 4.5.5 Data Ready Interrupt

This interrupt fires whenever a new data sample set from accelerometer, or auxiliary sensor is complete. This allows a low latency data readout. In non-latched mode, the interrupt and the flag in Register INT\_STATUS\_1 are cleared automatically after 1/(3200Hz). If this automatic clearance is unwanted, latched-mode can be used.

In order to enable/use the data ready interrupt map it on the desired interrupt pin via INT MAP DATA.

#### 4.5.6 Temperature Sensor

The temperature sensor has 8 bits. The temperature value is defined in Register TEMPERATURE and updated every 1.28 s.

| Table 7: The temperature sen |  |  |
|------------------------------|--|--|
|                              |  |  |
|                              |  |  |

| Value | Temperature |
|-------|-------------|
| 0x7F  | 150 °C      |
| •••   | •••         |
| 0x00  | 23 °C       |
| •••   |             |
| 0x81  | -104 °C     |
| 0x80  | Invalid     |

When there is no valid temperature information available (i.e. last measurement before the time defined above), the temperature indicates an invalid value: 0x80.

#### 4.5.7 Sensor Time

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

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

Table 8: Bit m in sensor time with Resolution in [s]

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

Table 9: Bit m in sensor\_time with Resolution in [ms]

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

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

The sensortime is synchronized with the data capturing in the data register and the FIFO. Between the data sampling and the data capturing there is a delay which depends on the settings in the Register ACC\_CONF. The sensortime supports multiple seconds of sample counting and a sub-microsecond resolution, see Register SENSORTIME\_0 for details.

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

#### 4.5.8 Configuration Changes

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



Due to filter settling, some invalid samples can be suppressed in addition after a configuration change.

#### 4.6 **FIFO**

The device supports the following FIFO operating modes:

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

The FIFO depth is 1024 byte and supports the following interrupts:

- FIFO full interrupt
- FIFO watermark interrupt

FIFO is enabled with FIFO\_CONFIG\_1.fifo\_acc\_en=0b1 (to enable FIFO for accelerometer data, 0b0=disabled), or set FIFO\_CONFIG\_1.fifo\_aux\_en=0b1 (to enable the FIFO for the auxiliary interface (magnetometer), 0b0=disabled).

#### **4.6.1 Frames**

The FIFO captures data in frames, which consist of a header and a payload. The FIFO can be configured to skip the header (headerless mode) in which case only payload is stored.

- In header mode (standard configuration) each regular frame consists of a one byte header describing properties of the frame, (which sensors are included in this frame) and the data itself. Beside the regular frames, there are control frames.
- In headerless mode the FIFO contains sampled data only.

#### Header mode

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

| Bit     | 7      | 6       | 5       | 4 | 3      | 2 | 1      | 0      |
|---------|--------|---------|---------|---|--------|---|--------|--------|
| Content | fh_mod | le<1:0> | fh_parr |   | n<3:0> |   | fh_ext | t<1:0> |

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

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

fh\_parm=0b0000 is invalid for regular mode, a header of 0x80 indicates an uninitialized frame.

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

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

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

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

The data format for data frames is identical to the format defined for the Register (0x0A) DATA\_0 to Register (0x17) DATA\_13 register. Only frames which contain data of at least one sensor will be written into the FIFO. E.g. fh\_parm=0b0101 the data in the frame are shown below. If the read burst length is less than 8 byte, the number of auxiliary sensor data in the frame is reduced to the burst length.

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

#### Headerless mode

When the data rates of all enabled sensor elements are identical, the FIFO header may be disabled in FIFO\_CONFIG\_1.fifo\_header\_en.

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

If the auxiliary sensor interface is enabled, the number of auxiliary sensor bytes in a FIFO frame is always AUX\_IF\_CONF.aux\_rd\_burst bytes (see chapter 4.8). If the burst length is less than 8, BMA490L will pad the values read form the auxiliary sensor. E.g. if AUX\_IF\_CONF.aux\_rd\_burst=0b01 (2 Bytes), a frame with auxiliary sensor and accelerometer data will look like

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

#### 4.6.2 Conditions and Details

#### Frame rates

The frame sampling rate of the FIFO is defined by the maximum output data rate of the sensors enabled for FIFO sampling. The FIFO sampling configuration is set in register FIFO\_CONFIG\_0 to FIFO\_CONFIG\_1. It is possible to select filtered or pre-filtered data as an input to the FIFO. If un-filtered data are selected in register FIFO\_DOWNS.acc\_fifo\_filt\_data for the accelerometer, the sample rate is 1600 Hz. The input data rate to the FIFO can be reduced by selecting a down-sampling factor  $2^k$  in register FIFO\_DOWNS.acc\_fifo\_downs, where k=[0,1...7].

#### FIFO Overflow

In the case of overflow the FIFO can either stop recording data or overwrite the oldest data. The behavior is controlled by Register FIFO\_CONFIG\_0.fifo\_stop\_on\_full. When FIFO\_CONFIG\_0.fifo\_stop\_on\_full =0b0, the FIFO logic may delete the oldest frames. If header mode is enabled, the skip frame is prepended at the next FIFO readout, when the free FIFO space falls below the maximum size frame. If FIFO\_CONFIG\_0.fifo\_stop\_on\_full =0b1, the newest frame may be discarded, if the free FIFO space falls below the maximum size frame. If header mode is enabled, a skip frame is prepended at the next FIFO readout (which is **not** the position where the frame(s) have been discarded).

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

#### Control frames

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

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

The FIFO fill level is contained in registers FIFO\_LENGTH\_1.fifo\_byte\_counter\_13\_8 and FIFO\_LENGTH\_0.fifo\_byte\_counter\_7\_0 and includes the control frames, with the exception of the sensortime frame.

| fh_mode<3:0> | Definition              |
|--------------|-------------------------|
| 0x0          | Skip Frame              |
| 0x1          | Sensortime Frame        |
| 0x2          | Fifo_Input_Config Frame |
| 0x3          | Reserved                |
| 0x4          | Sample Drop Frame       |
| 0x5 - 0x7    | Reserved                |

#### Skip Frame (fh\_parm=0x0):

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

#### Sensortime Frame (fh\_parm=0x1):

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

#### Fifo\_Input\_Config Frame (fh\_parm=0x2):

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

| Bit     | 7    | 6     | 5             | 4               | 3        | 2        | 1                    | 0               |
|---------|------|-------|---------------|-----------------|----------|----------|----------------------|-----------------|
| Content | rese | erved | aux_<br>if_ch | aux_<br>conf_ch | reserved | reserved | acc_<br>range_c<br>h | acc_<br>conf_ch |

aux\_if\_ch: A write to Register AUX\_IF\_CONF, AUX\_RD\_ADDR, or AUX\_WR\_ADDR becomes

active.

aux\_conf\_ch: A write to Register AUX\_CONF becomes active. acc\_range\_ch: A write to Register ACC\_RANGE becomes active.

acc\_conf\_ch: A write to Register ACC\_CONF or acc\_FIFO\_filt\_data or acc\_FIFO\_downsampling in

Register FIFO\_DOWNS becomes active.

#### **Sample Drop Frame**

A sample drop frame has always one byte payload, defined through

| Bit     | 7        | 6 | 5 | 4 | 3       | 2       | 1    | 0    |
|---------|----------|---|---|---|---------|---------|------|------|
| Content | reserved |   |   |   | aux_dro | reserve | acc_ |      |
|         |          |   |   |   |         | р       | d    | drop |

Sample drop frame will be inserted after a Fifo\_Input\_Config frame at the ODR tick at which the sample was dropped and only if no other sensor provides a valid sample at this ODR tick. If another sensor provides valid data, the data of this sensor is just not included and the appropriate header bit of the data frame is not set.

Sample drop frames will be inserted only for transition phases after configuration changes, not for samples dropped between sensor enable and first valid sample. For a detailed description of configuration changes see Section 4.5, Subsection "Configuration Changes".

#### FIFO Partial frame reads

When a frame is only partially read through the Register FIFO\_DATA\_it will be repeated completely with the next access both in headerless and in header mode. In headermode, this includes the header. In the case of a FIFO overflow between the first partial read and the second read attempt, the frame may be deleted.

#### FIFO overreads

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

#### 4.6.3 FIFO data synchronization

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

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

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



### 4.6.4 FIFO synchronization with external interrupts

External interrupts may be synchronized into the FIFO data. For this operation mode the FIFO\_CONFIG\_1.fifo\_tag\_int1\_en and/or FIFO\_CONFIG\_1.fifo\_tag\_int2\_en need to be enabled, as well as INT1\_IO\_CTRL.input\_en and/or INT2\_IO\_CTRL.input\_en. The fh\_ext field in FIFO header will then be set according to the signal at the INT1/INT2 inputs.

# 4.6.5 FIFO Interrupts

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

- The FIFO full interrupt is issued when the FIFO fill level is above the full threshold. The full threshold is reached just before the last two frames are stored in the FIFO.
- The FIFO watermark is issued when the FIFO fill level is equal or above a watermark defined in Register FIFO\_WTM\_0 and FIFO\_WTM\_1.

In order to enable/use the FIFO full or watermark interrupts map them on the desired interrupt pin via INT\_MAP\_DATA.

Both interrupts are suppressed when a read operation on the Register FIFO\_DATA is ongoing. Latched FIFO interrupts will only get cleared, if the status register gets read and the fill level is below the corresponding FIFO interrupt (full or watermark).

#### 4.6.6 FIFO Flush

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

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

# 4.7 Integrated Features set:

# 4.7.1 Any Motion / No motion detection

#### **Any-motion detection:**

Any-motion detection uses the slope between current input and reference acceleration samples to detect the motion status of the device. Feature can be enabled by setting at least one of the following: FEATURES\_IN.any\_motion.settings\_2.x\_en, FEATURES\_IN.any\_motion.settings\_2.y\_en and FEATURES\_IN.any\_motion.settings\_2.z\_en, respectively for each axis.

Any-motion provides an interrupt when the absolute value of the slope exceeds the configurable FEATURES\_IN.any\_motion.settings\_1.threshold for consecutive

FEATURES\_IN.any\_motion.settings\_2.duration samples for at-least one of the enabled sensing axis. Reference acceleration sample is updated only when an any-motion interrupt is triggered. The interrupt status is reset as soon as the slope falls below the set

FEATURES\_IN.any\_motion.setings\_1.threshold value. The signals and timings relevant to the anymotion interrupt functionality are depicted in the figure below:



#### **Configuration settings:**

- 1. FEATURES\_IN.any\_motion.settings\_1.threshold the slope threshold.
- 2. FEATURES\_IN.any\_motion.settings\_2.duration the number of consecutive data points for which the threshold condition must be respected, for interrupt assertion.
- 3. FEATURES\_IN.any\_motion.settings\_2.x\_en indicates if this feature is enabled for x axis
- 4. FEATURES\_IN.any\_motion.settings\_2.y\_en indicates if this feature is enabled for y axis
- 5. FEATURES\_IN.any\_motion.settings\_2.z\_en -indicates if this feature is enabled for z axis

#### No Motion Detection:

No-motion detection uses the slope between two consecutive acceleration signal samples to detect static state of the device. Feature can be enabled by setting at least one of the following flags: FEATURES\_IN.no\_motion.settings\_2.x\_en, FEATURES\_IN.no\_motion.settings\_2.y\_en and FEATURES\_IN.no\_motion.settings\_2.z\_en, respectively for each axis.

No-motion interrupt is triggered when the slope on all enabled sensing axis remains smaller than the configurable FEATURES\_IN.no\_motion.settings\_1.threshold for the duration configured by FEATURES\_IN.no\_motion.settings\_2.duration. No-motion interrupt is cleared as soon as the acceleration slope exceeds the set threshold. The signals and timings relevant to the no-motion interrupt functionality are depicted in the figure below.

Signal and timing diagram for no-motion interrupt detection



Register FEATURES\_IN.no\_motion.settings\_2.duration defines the number of consecutive data points for which the slope of enabled axis must be smaller than the threshold for an interrupt to be asserted.

# **Configuration settings:**

- 1. FEATURES\_IN.no\_motion.settings\_1.threshold the slope threshold.
- 2. FEATURES\_IN.no\_motion.settings\_2.duration the number of consecutive data points for which the threshold condition must be respected, for interrupt assertion.
- 3. FEATURES\_IN.no\_motion.settings\_2.x\_en indicates if this feature is enabled for x axis
- 4. FEATURES\_IN.no\_motion.settings\_2.y\_en indicates if this feature is enabled for y axis
- 5. FEATURES\_IN.no\_motion.settings\_2.z\_en -indicates if this feature is enabled for z axis

<u>Note</u>: The firmware image with any motion and no motion feature set mentioned in the section above is available for download under the following link

https://github.com/BoschSensortec/BMA490L-Sensor-API

# 4.8 General Interrupt Pin configuration

## Electrical Interrupt Pin Behavior

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

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

Both interrupt pins can be configured as input pins via INT1\_IO\_CTRL.input\_en respectively INT2\_IO\_CTRL.input\_en. This is necessary when FIFO tag feature is used (see the respective FIFO chapter) If both are enabled, the input (e.g. marking FIFO) is driven by the interrupt output. BMA490L supports edge and level triggered interrupt inputs, this can be configured through INT1\_IO\_CTRL.edge\_ctrl respectively INT2\_IO\_CTRL.edge\_ctrl.

BMA490L supports non-latched and latched interrupts modes for data-ready, FIFO full and FIFO watermark. The mode is selected by INT\_LATCH.int\_latch. The feature interrupts described in chapter FIFO Interrupts, support only latched mode described below.

In latched mode an asserted interrupt status in INT\_STATUS\_0 or INT\_STATUS\_1 and the selected pin are cleared if the corresponding status register is read. If more than one interrupt pin is used in latched mode, all interrupts in INT\_STATUS\_0 should be mapped to one pin and all interrupts in INT\_STATUS\_1 should be mapped to the other pin. If just one interrupt pin is used all interrupts may be mapped to this pin. If the activation condition still holds when it is cleared, the interrupt status is asserted again when the interrupt condition holds again.

In the non-latched mode (only for data-ready, FIFO full and FIFO watermark) the interrupt status bit and the selected pin are reset as soon as the activation condition is not valid anymore.

#### Interrupt Pin Mapping

In order, for the Host to react to the features output, they can be mapped to the external pin INT1 or pin INT2, by setting the corresponding bits from the registers INT1\_MAP, respectively INT2\_MAP.

To disconnect the features outputs to the external pins, the same corresponding bits must be reset, from the registers, INT1\_MAP, respectively INT2\_MAP.

Once a feature triggered the output pin, the Host can read out the corresponding bit from the register, INT\_STATUS\_0 (Feature Interrupts) or INT\_STATUS\_1 (FIFO and data ready).

### 4.9 Auxiliary Sensor Interface

The auxiliary interface allows to attach one auxiliary sensor (e.g. magnetometer) on dedicated auxiliary sensor interface as shown below.



6 DOF Solution w/ BMA490L and BMM150

# 4.9.1 Structure and Concept

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

The BMA490L autonomously reads the sensor data from a compatible auxiliary sensor without intervention of the application processor and stores the data in its data registers and FIFO. The initial setup of the auxiliary sensor after power-on is done through indirect addressing (in setup mode as described in following section).

The main benefits of the auxiliary sensor interface are

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

# 4.9.2 Interface Configuration

The configuration registers that control the auxiliary sensor interface operation, are only affecting the interface to the auxiliary sensor, not the configuration of the accelerometer sensor itself (this must be done in setup mode).

There are three basis configurations/modes of the auxiliary sensor interface:

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

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

In setup mode, the auxiliary sensor may be configured and trim data may be read out from the auxiliary sensor. In the data mode the auxiliary sensor data are continuously copied into BMA490L registers and may be read out from BMA490L directly over the primary interface. For a BMM150 magnetometer, these are the auxiliary sensor data itself and Hall resistance, temperature is not required. The table below shows how to configure these three modes using the registers PWR\_CONF, PWR\_CTRL, and AUX\_IF\_CONF.aux\_manual\_en.

| Mode                | AUX_IF_CONF.aux_<br>manual_en | PWR_CONF.adv_powe r_save | PWR_CTRL.aux_en |  |
|---------------------|-------------------------------|--------------------------|-----------------|--|
| No auxiliary sensor | 1                             | 1                        | 0               |  |
| access              |                               |                          |                 |  |
| Setup mode          | 1                             | 0                        | 0               |  |
| Data mode           | 0                             | x                        | 1               |  |

The auxiliary sensor interface mode may be enabled by setting bit IF\_CONF.if\_mode according to the following table.

| IF_CONF.if_mode | Result                          |  |  |  |
|-----------------|---------------------------------|--|--|--|
| 0               | Secondary IF disabled (default) |  |  |  |
| 1               | AuxIF enabled                   |  |  |  |

The auxiliary sensor interface operates at 400 kHz. This results in an I2C readout delay of about 250 us for 10 bytes of data.

The I2C slave address of the auxiliary sensor is defined in AUX\_DEV\_ID. i2c\_device\_addr.

# 4.9.3 Setup mode (AUX\_IF\_CONF.aux\_manual\_en =0b1)

Through the primary interface the auxiliary sensor may be accessed using indirect addressing through the AUX\_\* registers. AUX\_RD\_ADDR and AUX\_WR\_ADDR define the address of the register to read/write in the auxiliary sensor register map and triggers the operation itself, when the auxiliary sensor interface is enabled through PWR\_CTRL.aux\_en.

For reads, the number of data bytes defined in AUX\_IF\_CONF.aux\_rd\_burst are read from the auxiliary sensor and written into the BMA490L Register DATA\_0 to DATA\_7. For writes only single bytes are written, independent of the settings in AUX\_IF\_CONF.aux\_rd\_burst. The data for the I2C write to auxiliary sensor must be stored in AUX\_WR\_DATA before the auxiliary sensor register address is written into AUX\_WR\_ADDR.

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

Configuration phase of the auxiliary sensor.

Example: Read bytes 5 and 6 of auxiliary sensor



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



#### 4.9.4 Data mode (AUX\_IF\_CONF.aux\_manual\_en=0)

AUX\_RD\_ADDR.read\_addr defines the address of the data register from which to read the number of data bytes configured in AUX\_IF\_CONF.aux\_rd\_burst from AUX\_0... AUX\_7 data of the auxiliary sensor. These data are stored in the DATA\_0 up to DATA\_7 register. The data ready status is set in STATUS.drdy\_aux, it is typically cleared through reading one of the DATA\_0 to DATA\_7 registers. AUX\_WR\_ADDR.write\_addr defines the register address of auxiliary sensor to start a measurement in forced mode in the auxiliary sensor register map. The delay (time offset) between triggering an auxiliary sensor measurement and reading the measurement data is specified in AUX\_CONF.aux\_offset. Reading of the data is done in a single I2C read operation with a burst length specified in AUX\_IF\_CONF.aux\_rd\_burst. For BMM150 AUX\_IF\_CONF.aux\_rd\_burst should be set to 0b11, i.e. 8 bytes. If AUX\_IF\_CONF.aux\_rd\_burst is set to a value lower than 8 bytes, the remaining auxiliary sensor data in the Register DATA\_0 to DATA\_7 and the FIFO are undefined.

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

#### 4.9.5 Delay (Time Offset)

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

#### 4.10 Sensor Self-Test

The BMA490L has a comprehensive self test function for the MEMS element by applying electrostatic forces to the sensor core instead of external accelerations. By actually deflecting the seismic mass, the entire signal path of the sensor can be tested. Activating the self-test results in a static offset of the acceleration data; any external acceleration or gravitational force applied to the sensor during active self-test will be observed in the output as a superposition of both acceleration and self-test signal.

Before the self-test is enabled the g-range should be set to 8g. The self-test is activated for all axes by writing ACC\_SELF\_TEST.acc\_self\_test\_en = 1b1. The self-test is disabled by writing ACC\_SELF\_TEST.acc\_self\_test\_en = 1b0. It is possible to control the direction of the deflection through bit ACC\_SELF\_TEST.acc\_self\_test\_sign. The excitation occurs in positive (negative) direction if ACC\_SELF\_TEST.acc\_self\_test\_sign= 1b1 ('b0). The amplitude of the deflection has to be set low by writing ACC\_SELF\_TEST.acc\_self\_test\_amp = 1b0. After the self-test is enabled, the user should wait 50ms before interpreting the acceleration data.

In order to ensure a proper interpretation of the self-test signal it is recommended to perform the self-test for both (positive and negative) directions and then to calculate the difference of the resulting acceleration values. The table below shows the minimum differences for each axis in order for the self test to pass. The actually measured signal differences can be significantly larger.

Self-test: Resulting minimum difference signal for BMA490L.

|         | x-axis signal | y-axis signal | z-axis signal |
|---------|---------------|---------------|---------------|
| BMA490L | 1800 mg       | 1800 mg       | 1800 mg       |

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

The recommended self test procedure is as follows:

- 1. Enable accelerometer with register PWR\_CTRL.acc\_en=1b1.
- 2. Set ±8g range in register ACC\_RANGE.acc\_range
- 3. Set self test amplitude to low by setting ACC\_SELF\_TEST.acc\_self\_test\_amp = 1b0
- 4. Set ACC\_CONF.acc\_odr=1600Hz, Continuous sampling mode, ACC\_CONF.acc\_bwp=norm\_avg4, ACC\_CONF.acc\_perf\_mode=1b1.
- 5. Wait for > 2 ms
- 6. Enable self-test and set positive self-test polarity (ACC SELF TEST.acc self test sign= 1b1)
- 7. Wait for > 50ms
- 8. Read and store positive acceleration value of each axis from registers DATA\_8 to DATA\_13
- 9. Enable self-test and set negative self-test polarity ACC SELF TEST.acc self test sign= 1b0)
- 10. Wait for > 50ms
- 11. Read and store negative acceleration value of each axis from registers DATA 8 to DATA 13
- 12. Calculate difference of positive and negative acceleration values and compare against threshold values

#### 4.11 Offset Compensation

BMA490L offers manual compensation as well as inline calibration.

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

The public offset compensation Registers OFFSET\_0 to OFFSET\_2 are images of the corresponding registers in the NVM. With each image update the contents of the NVM registers are written to the public registers. The public registers can be overwritten by the user at any time.

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

#### 4.11.1 Manual Offset Compensation

The contents of the public compensation Register OFFSET\_0 to OFFSET\_2 may be set manually via the digital interface. After modifying the Register OFFSET\_0 to OFFSET\_2 the next data sample is not valid.

Offset compensation needs to be enabled through NV\_CONF.acc\_off\_en.

#### 4.11.2 Inline Calibration

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

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

#### 4.12 Non-Volatile Memory

The registers NV\_CONF and OFFSET\_0 to OFFSET\_2 have an NVM backup which are accessible by the user.

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

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

Writing to the NVM is a 4-step procedure:

- Set PWR\_CONF.adv\_power\_save = 0b0
- 2. Write the new contents to the image registers.
- 3. Write 0b1 to bit NVM\_CONF.nvm\_prog\_en in order to unlock the NVM.
- 4. Write nvm prog to the CMD register to trigger the write process.
- 5. Write 0b0 to bit NVM\_CONF.nvm\_prog\_en in order to lock the NVM, after the write process is completed

Writing to the NVM always renews the entire NVM contents. It is possible to check the write status by reading *STATUS.cmd\_rdy*. While *STATUS.cmd\_rdy* = 0b0, the write process is still in progress; when *STATUS.cmd\_rdy* = 0b1, writing is completed. An NVM write cycle can only be initiated, if PWR CONF.adv power save = 0b0.

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

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

#### 4.13 Soft-Reset

A softreset can be initiated at any time by writing the command *softreset (0xB6)* to register CMD. The softreset performs a fundamental reset to the device which is largely equivalent to a power cycle. Following a delay, all user configuration settings are overwritten with their default state (setting stored in the NVM) wherever applicable. This command is functional in all operation modes but must not be performed while NVM writing operation is in progress.

# 5. Register Description

## 5.1 **General Remarks**

Registers can be read and written in all power configurations with the exception of FEATURES\_IN and FIFO\_DATA which need PWR\_CONF.adv\_power\_save set to 0b0. The following chapter contains only the general register map, feature related registers are excluded.

#### 5.2 **Register Map**

| r                   | ead/write                 |                  | rea                | d only   |         |     | write     | only                      |                            | reserved                 |                        |
|---------------------|---------------------------|------------------|--------------------|----------|---------|-----|-----------|---------------------------|----------------------------|--------------------------|------------------------|
|                     |                           |                  |                    |          |         |     |           |                           |                            |                          |                        |
| <b>.</b>            |                           | 564              |                    |          | E       | - [ |           |                           | <u> </u>                   |                          | ID:                    |
| Register<br>Address | Register<br>Name          | Default<br>Value | 7                  | 6        | 5       |     | 4         | 3                         | 2                          | 1                        | 0                      |
| 0x7E                | CMD                       | 0x00             |                    |          |         |     | C         | md                        |                            |                          |                        |
| 0x7D                | PWR_CT<br>RL              | 0x00             |                    |          | reserve | ed  |           |                           | acc_en                     | reserved                 | aux_en                 |
| 0x7C                | PWR_CO<br>NF              | 0x03             |                    |          | re      | ese | erved     |                           |                            | fifo_self<br>_wakeu<br>p | adv_po<br>wer_sav<br>e |
| 0x7B                | -                         | -                |                    |          |         |     | res       | erved                     |                            |                          |                        |
|                     | -                         | -                |                    |          |         |     | res       | erved                     |                            |                          |                        |
| 0x74                | -                         | -                |                    |          |         |     | res       | erved                     |                            |                          |                        |
| 0x73                | OFFSET 2                  | 0x00             |                    |          |         |     | off_      | acc_z                     |                            |                          |                        |
| 0x72                | <u>OFFSET</u> <u>1</u>    | 0x00             |                    |          |         |     | off_      | acc_y                     |                            |                          |                        |
| 0x71                | <u>OFFSET</u><br><u>0</u> | 0x00             |                    |          |         |     | off_      | acc_x                     |                            |                          |                        |
| 0x70                | NV_CONF                   | 0×00             |                    | res      | erved   |     |           | acc_off_<br>en            | i2c_wdt_<br>en             | i2c_wdt_<br>sel          | spi_en                 |
| 0x6F                | -                         | -                |                    |          |         |     | res       | erved                     |                            |                          |                        |
| 0x6E                | -                         | -                |                    |          |         |     | res       | erved                     |                            |                          |                        |
| 0x6D                | ACC_SEL<br>F_TEST         | 0x00             |                    | res      | erved   |     |           | acc_self<br>_test_a<br>mp | acc_self<br>_test_si<br>gn | reserved                 | acc_self<br>_test_en   |
| 0x6C                | -                         | -                |                    |          |         |     | res       | erved                     |                            |                          |                        |
| 0x6B                | IF_CONF                   | 0x00             |                    | reserved |         |     | if_mode   |                           | reserved                   |                          | spi3                   |
| 0x6A                | NVM_CO<br>NF              | 0x00             |                    |          | re      | ese | erved     |                           |                            | nvm_pro<br>g_en          | reserved               |
| 0x69                | -                         | -                |                    |          |         |     | res       | erved                     |                            |                          |                        |
|                     | -                         | -                |                    |          |         |     | res       | erved                     |                            |                          |                        |
| 0x60                | -                         | -                |                    | reserved |         |     |           |                           |                            |                          |                        |
| 0x5F                | INTERNA<br>L_ERROR        | 0x00             | reserved int_err_2 |          |         |     | int_err_1 | reserved                  |                            |                          |                        |
| 0x5E                | FEATURE<br>S_IN           | 0x00             | features_in        |          |         |     |           |                           |                            |                          |                        |
| 0x5D                | -                         | -                |                    |          |         |     | res       | erved                     |                            |                          |                        |
|                     | -                         | -                |                    |          |         |     | res       | erved                     |                            |                          |                        |
| 0x5A                | -                         | -                |                    |          |         |     | res       | erved                     |                            |                          |                        |

| 0x58    DATA     0x00     reserved dy m    int2_ffull reserved y       0x57    INT2_MA P     0x00    out tion_o ut ion_out ion_out ion_out ion_out ion_out ion_out ion_out ion_out reserved       0x56    INT1_MA P     0x00    out tion_o ut ion_out ion_out ion_out ion_out ion_out reserved | nt1_fw int1_ffull                 |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--|--|--|--|
| 0x57     INT2 MA P     0x00     error_int out     no_mo tion_o ut     any_mot ion_out       0x56     INT1 MA P     0x00     error_int out     no_mo tion_o ut     any_mot ion_out       0x55     INT_LATC     0x00                                                                             | m Int1_ffull                      |  |  |  |  |
| 0x57     INT2_MA P     0x00     error_int tion_o ut     any_mot ion_out       0x56     INT1_MA P     0x00     error_int tion_o ut     any_mot ion_out       0x55     INT_LATC     0x00                                                                                                         |                                   |  |  |  |  |
| 0x56 P 0x00 error_int tion_o any_mot ion_out reserved  0x55 INT_LATC 0x00 reserved                                                                                                                                                                                                             |                                   |  |  |  |  |
| 0x55   0x00   reserved                                                                                                                                                                                                                                                                         |                                   |  |  |  |  |
| <u>H</u>                                                                                                                                                                                                                                                                                       | int_latch                         |  |  |  |  |
| 0x54 INT2 IO                                                                                                                                                                                                                                                                                   | lvl edge_ctr                      |  |  |  |  |
| 0x53 INT1 IO                                                                                                                                                                                                                                                                                   | lvl edge_ctr                      |  |  |  |  |
| 0x52 - reserved                                                                                                                                                                                                                                                                                |                                   |  |  |  |  |
| reserved                                                                                                                                                                                                                                                                                       |                                   |  |  |  |  |
| 0x50 reserved                                                                                                                                                                                                                                                                                  |                                   |  |  |  |  |
| 0x4F AUX WR                                                                                                                                                                                                                                                                                    |                                   |  |  |  |  |
| 0x4E AUX WR ADDR 0x4C write_addr                                                                                                                                                                                                                                                               | write_addr                        |  |  |  |  |
| 0x4D ADDR 0x42 read_addr                                                                                                                                                                                                                                                                       |                                   |  |  |  |  |
| 0x4C AUX_IF_C ONF Ox83 aux_ma reserved nual_en                                                                                                                                                                                                                                                 | aux_rd_burst                      |  |  |  |  |
| 0x4B                                                                                                                                                                                                                                                                                           | reserved                          |  |  |  |  |
| 0x4A - reserved                                                                                                                                                                                                                                                                                |                                   |  |  |  |  |
| 0x49 FIFO CO NFIG 1  0x10 reserved fifo_ac fifo_aux fifo_hea fifo_tag_ fifo_tag_ int2_en                                                                                                                                                                                                       | reserved                          |  |  |  |  |
| 0x48   0x02   reserved                                                                                                                                                                                                                                                                         | o_time fifo_stop<br>_en _on_full  |  |  |  |  |
| 0x47         FIFO_WT<br>M_1         0x02         reserved         fifo_water_mark_12_6                                                                                                                                                                                                         |                                   |  |  |  |  |
| 0x46 FIFO_WT                                                                                                                                                                                                                                                                                   |                                   |  |  |  |  |
| 0x45 FIFO_DO                                                                                                                                                                                                                                                                                   | _filt_dat acc_fifo_downs reserved |  |  |  |  |
| 0x44 AUX CON<br>E 0x46 aux_offset aux_odr                                                                                                                                                                                                                                                      |                                   |  |  |  |  |
|                                                                                                                                                                                                                                                                                                | reserved                          |  |  |  |  |
| Teserveu                                                                                                                                                                                                                                                                                       | reserved                          |  |  |  |  |
|                                                                                                                                                                                                                                                                                                | reserved acc_range                |  |  |  |  |
| 0x42 reserved ACC_RAN                                                                                                                                                                                                                                                                          | acc_range                         |  |  |  |  |
| 0x42         -         -         reserved           0x41         ACC_RAN<br>0x01         reserved                                                                                                                                                                                              |                                   |  |  |  |  |

|      |                   | -    |                                                    |              |                  | roconied               |         |                  |
|------|-------------------|------|----------------------------------------------------|--------------|------------------|------------------------|---------|------------------|
| 0x2B | -                 |      |                                                    |              |                  | reserved               |         |                  |
| UX2B | INITEDNIA         | -    |                                                    |              |                  | reserved               |         |                  |
| 0.04 | INTERNA           | 0.00 |                                                    | odr_5        | axes_re          |                        |         |                  |
| 0x2A | L_STATU           | 0x00 | reserved                                           | 0Hz_e        | map_err          | message                |         |                  |
| 0.00 | <u>S</u>          |      |                                                    | rror         | or               |                        | _       | _                |
| 0x29 | -                 | =    |                                                    |              |                  | reserved               |         |                  |
|      | -                 | =    |                                                    | reserved     |                  |                        |         |                  |
| 0x27 | - FIEO DAT        | =    |                                                    |              |                  | reserved               |         |                  |
| 0x26 | FIFO_DAT  A       | 0x00 |                                                    |              | _                | fifo_data              |         |                  |
| 0x25 | FIFO_LEN<br>GTH_1 | 0x00 | reser                                              | ved          |                  | fifo_byte_counter_13_8 | 1       |                  |
| 0x24 | FIFO_LEN<br>GTH_0 | 0x00 |                                                    |              |                  | fifo_byte_counter_7_0  |         |                  |
| 0x23 | -                 | -    |                                                    |              |                  | reserved               |         |                  |
| 0x22 | TEMPERA<br>TURE   | 0x00 |                                                    |              |                  | temperature            |         |                  |
| 0x21 | -                 | =    |                                                    |              |                  | reserved               |         |                  |
|      | -                 | =    |                                                    |              |                  | reserved               |         |                  |
| 0x1E | -                 | -    |                                                    |              |                  | reserved               |         |                  |
| 0x1D | INT_STAT US_1     | 0x00 | acc_drd<br>y_int                                   | reserv<br>ed | aux_drd<br>y_int | reserved               | fwm_int | ffull_int        |
| 0x1C | INT_STAT<br>US_0  | 0x00 | error_int no_mo any_mot tion_o ion_out ut reserved |              |                  |                        |         |                  |
| 0x1B | EVENT             | 0x01 |                                                    |              |                  | reserved               |         | por_dete<br>cted |
| 0x1A | SENSORT<br>IME_2  | 0x00 |                                                    |              |                  | sensor_time_23_16      |         |                  |
| 0x19 | SENSORT<br>IME_1  | 0x00 |                                                    |              |                  | sensor_time_15_8       |         |                  |
| 0x18 | SENSORT<br>IME_0  | 0x00 |                                                    |              |                  | sensor_time_7_0        |         |                  |
| 0x17 | DATA_13           | 0x00 |                                                    |              |                  | acc_z_15_8             |         |                  |
| 0x16 | DATA_12           | 0x00 |                                                    |              |                  | acc_z_7_0              |         |                  |
| 0x15 | <u>DATA_11</u>    | 0x00 |                                                    |              |                  | acc_y_15_8             |         |                  |
| 0x14 | <u>DATA_10</u>    | 0x00 |                                                    |              |                  | acc_y_7_0              |         |                  |
| 0x13 | DATA_9            | 0x00 |                                                    |              |                  | acc_x_15_8             |         |                  |
| 0x12 | DATA_8            | 0x00 |                                                    |              |                  | acc_x_7_0              |         |                  |
| 0x11 | DATA_7            | 0x00 |                                                    |              |                  | aux_r_15_8             |         |                  |
| 0x10 | DATA_6            | 0x00 |                                                    |              |                  | aux_r_7_0              |         |                  |
| 0x0F | DATA_5            | 0x00 | aux_z_15_8                                         |              |                  |                        |         |                  |
| 0x0E | DATA_4            | 0x00 | aux_z_7_0                                          |              |                  |                        |         |                  |
| 0x0D | DATA_3            | 0x00 | aux_y_15_8                                         |              |                  |                        |         |                  |
| 0x0C | DATA_2            | 0x00 | aux_y_7_0                                          |              |                  |                        |         |                  |
| 0x0B | DATA_1            | 0x00 | aux_x_15_8                                         |              |                  |                        |         |                  |
| 0x0A | DATA_0            | 0x00 | aux_x_7_0                                          |              |                  |                        |         |                  |
| 0x09 |                   |      |                                                    |              |                  | reserved               |         |                  |
|      | -                 | -    |                                                    |              |                  | reserved               |         |                  |
| -    |                   |      |                                                    |              |                  |                        |         |                  |

| 0x04 | =             | -    | reserved     |              |              |         |          |                |           |      |
|------|---------------|------|--------------|--------------|--------------|---------|----------|----------------|-----------|------|
| 0x03 | <u>STATUS</u> | 0x10 | drdy_ac<br>c | reserv<br>ed | drdy_au<br>x | cmd_rdy | reserved | aux_ma<br>n_op | rese      | rved |
| 0x02 | ERR_REG       | 0x00 | aux_err      | fifo_er<br>r | reserved     |         |          |                | fatal_err |      |
| 0x01 | -             | -    |              | reserved     |              |         |          |                |           |      |
| 0x00 | CHIP_ID       | 0x1A |              |              |              | ch      | ip_id    |                |           |      |

FEATURES IN

| FEATURES      | S_IN                                  |         | ı                | 1       | 1                       | 1        | -      | _                       | ı         | ı                       |
|---------------|---------------------------------------|---------|------------------|---------|-------------------------|----------|--------|-------------------------|-----------|-------------------------|
| Register      | Registe                               | Default | 7                | 6       | 5                       | 4        | 3      | 2                       | 1         | 0                       |
| Address       | r Name                                | Value   |                  |         |                         |          |        |                         |           |                         |
| 0x5E:<br>0x0B | settings. axes re mapping [1]         | 0x00    |                  |         |                         | reserved |        |                         |           | map_z_<br>axis_sig<br>n |
| 0x5E:<br>0x0A | general settings. axes re mapping [0] | 0x88    | map <sub>.</sub> | _z_axis | map_y_<br>axis_sig<br>n | map_     | y_axis | map_x_<br>axis_sig<br>n | map_      | x_axis                  |
| 0x5E:<br>0x09 | general settings. Reserve d[1]        | 0x00    |                  |         |                         | Res      | erved  |                         |           |                         |
| 0x5E:<br>0x08 | general settings. Reserve d[0]        | 0x00    |                  |         |                         | Res      | erved  |                         |           |                         |
| 0x5E:<br>0x07 | no_moti<br>on.settin<br>gs_2[1]       | 0x00    | z_en             | y_en    | x_en                    |          |        | duration                |           |                         |
| 0x5E:<br>0x06 | no_moti<br>on.settin<br>gs_2[0]       | 0x05    |                  |         |                         | dur      | ration |                         |           |                         |
| 0x5E:<br>0x05 | no_moti<br>on.settin<br>gs_1[1]       | 0x00    |                  |         | reserved                |          |        |                         | threshold |                         |
| 0x5E:<br>0x04 | no moti<br>on.settin<br>gs 1[0]       | 0xAA    |                  |         |                         | thre     | shold  |                         |           |                         |
| 0x5E:<br>0x03 | any_mot<br>ion.setti<br>ngs_2[1]      | 0x00    | z_en             | y_en    | x_en                    |          |        | duration                |           |                         |
| 0x5E:<br>0x02 | any mot<br>ion.setti<br>ngs 2[0]      | 0x05    |                  |         |                         | dur      | ration |                         |           |                         |
| 0x5E:<br>0x01 | any_mot<br>ion.setti<br>ngs_1[1]      | 0x00    |                  |         | reserved                |          |        |                         | threshold |                         |

| 0x5E:<br>0x00 | any_mot<br>ion.setti<br>ngs_1[0] | 0xAA | threshold |
|---------------|----------------------------------|------|-----------|
|---------------|----------------------------------|------|-----------|

#### 5.2.1 Register (0x00) CHIP\_ID

DESCRIPTION: Chip identification code

RESET: 0x1A

DEFINITION (Go to register map):

| Name        | Register (0x00) CHIP_ID |         |      |   |  |  |  |
|-------------|-------------------------|---------|------|---|--|--|--|
| Bit         | 7                       | 6       | 5    | 4 |  |  |  |
| Read/Write  | R                       | R       | R    | R |  |  |  |
| Reset Value | 0                       | 0       | 0    | 1 |  |  |  |
| Content     |                         | chip    | o_id |   |  |  |  |
| Bit         | 3                       | 2       | 1    | 0 |  |  |  |
| Read/Write  | R                       | R       | R    | R |  |  |  |
| Reset Value | 1                       | 0       | 1    | 0 |  |  |  |
| Content     |                         | chip_id |      |   |  |  |  |

chip\_id: Chip identification code for BMA490L

### 5.2.2 Register (0x02) ERR\_REG

**DESCRIPTION:** Reports sensor error conditions

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x02) ERR_REG |                |          |            |  |  |  |  |
|-------------|-------------------------|----------------|----------|------------|--|--|--|--|
|             | _                       | Tregister (oxe |          |            |  |  |  |  |
| Bit         | /                       | 6              | 5        | 4          |  |  |  |  |
| Read/Write  | R                       | R              | n/a      | R          |  |  |  |  |
| Reset Value | 0                       | 0              | 0        | 0          |  |  |  |  |
| Content     | aux_err                 | fifo_err       | reserved | error_code |  |  |  |  |
| Bit         | 3                       | 2              | 1        | 0          |  |  |  |  |
| Read/Write  | R                       | R              | R        | R          |  |  |  |  |
| Reset Value | 0                       | 0              | 0        | 0          |  |  |  |  |
| Content     | error                   | _code          | cmd_err  | fatal_err  |  |  |  |  |

fatal\_err: Fatal Error, chip is not in operational state (Boot-, power-system). This flag will be reset only by power-on-reset or softreset.

cmd\_err: Command execution failed.

error\_code: Error codes for persistent errors

|            |          | •                          |
|------------|----------|----------------------------|
| error_code |          |                            |
| 0x00       | no_error | no error is reported       |
| 0x01       | acc_err  | error in Register ACC_CONF |

fifo\_err: Error in FIFO detected: Input data was discarded in stream mode. This flag will be reset when read.

aux\_err: Error in I2C-Master detected. This flag will be reset when read.

#### 5.2.3 Register (0x03) STATUS

**DESCRIPTION: Sensor status flags** 

RESET: 0x10

DEFINITION (Go to register map):

| Name        | Register (0x03) STATUS |            |          |         |  |  |  |
|-------------|------------------------|------------|----------|---------|--|--|--|
| Bit         | 7                      | 6          | 5        | 4       |  |  |  |
| Read/Write  | R                      | n/a        | R        | R       |  |  |  |
| Reset Value | 0                      | 0          | 0        | 1       |  |  |  |
| Content     | drdy_acc               | reserved   | drdy_aux | cmd_rdy |  |  |  |
| Bit         | 3                      | 2          | 1        | 0       |  |  |  |
| Read/Write  | n/a                    | R          | n/a      | n/a     |  |  |  |
| Reset Value | 0                      | 0          | 0        | 0       |  |  |  |
| Content     | reserved               | aux_man_op | rese     | erved   |  |  |  |

aux\_man\_op: '1'('0') indicate a (no) manual auxiliary interface operation is ongoing.

cmd\_rdy: CMD decoder status. '0' -> Command in progress '1' -> Command decoder is ready to accept

a new command

drdy\_aux: Data ready for auxiliary sensor. It gets reset when one auxiliary DATA register is read out drdy\_acc: Data ready for accelerometer. It gets reset when one accelerometer DATA register is read out

## 5.2.4 Register (0x0A) DATA\_0

DESCRIPTION: AUX\_X(LSB)

RESET: 0x00

| Name        | Register (0x0A) DATA_0 |       |              |   |  |  |  |
|-------------|------------------------|-------|--------------|---|--|--|--|
| Bit         | 7                      | 6     | 5            | 4 |  |  |  |
| Read/Write  | R                      | R     | R            | R |  |  |  |
| Reset Value | 0                      | 0     | 0            | 0 |  |  |  |
| Content     |                        | aux_> | <u>_</u> 7_0 |   |  |  |  |
| Bit         | 3                      | 2     | 1            | 0 |  |  |  |
| Read/Write  | R                      | R     | R            | R |  |  |  |
| Reset Value | 0                      | 0     | 0            | 0 |  |  |  |
| Content     | aux_x_7_0              |       |              |   |  |  |  |

## 5.2.5 Register (0x0B) DATA\_1

DESCRIPTION: AUX\_X(MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x0B) DATA_1 |   |   |   |
|-------------|------------------------|---|---|---|
| Bit         | 7                      | 6 | 5 | 4 |
| Read/Write  | R                      | R | R | R |
| Reset Value | 0                      | 0 | 0 | 0 |
| Content     | aux_x_15_8             |   |   |   |
| Bit         | 3                      | 2 | 1 | 0 |
| Read/Write  | R                      | R | R | R |
| Reset Value | 0 0 0 0                |   |   |   |
| Content     | aux_x_15_8             |   |   |   |

# 5.2.6 Register (0x0C) DATA\_2

DESCRIPTION: AUX\_Y(LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x0C) DATA_2 |   |   |   |
|-------------|------------------------|---|---|---|
| Bit         | 7                      | 6 | 5 | 4 |
| Read/Write  | R                      | R | R | R |
| Reset Value | 0                      | 0 | 0 | 0 |
| Content     | aux_y_7_0              |   |   |   |
| Bit         | 3                      | 2 | 1 | 0 |
| Read/Write  | R                      | R | R | R |
| Reset Value | 0 0 0 0                |   |   |   |
| Content     | aux_y_7_0              |   |   |   |

# 5.2.7 Register (0x0D) DATA\_3

DESCRIPTION: AUX\_Y(MSB)

RESET: 0x00

| Name        |   | Register (0x0D) DATA_3 |       |   |  |
|-------------|---|------------------------|-------|---|--|
| Bit         | 7 | 7 6 5 4                |       |   |  |
| Read/Write  | R | R                      | R     | R |  |
| Reset Value | 0 | 0                      | 0     | 0 |  |
| Content     |   | aux_y                  | _15_8 |   |  |
| Bit         | 3 | 2                      | 1     | 0 |  |
| Read/Write  | R | R                      | R     | R |  |
| Reset Value | 0 | 0                      | 0     | 0 |  |
| Content     |   | aux_y_15_8             |       |   |  |

## 5.2.8 Register (0x0E) DATA\_4

DESCRIPTION: AUX\_Z(LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x0E) DATA_4 |   |   |   |
|-------------|------------------------|---|---|---|
| Bit         | 7                      | 6 | 5 | 4 |
| Read/Write  | R                      | R | R | R |
| Reset Value | 0                      | 0 | 0 | 0 |
| Content     | aux_z_7_0              |   |   |   |
| Bit         | 3                      | 2 | 1 | 0 |
| Read/Write  | R                      | R | R | R |
| Reset Value | 0                      | 0 | 0 | 0 |
| Content     | aux_z_7_0              |   |   |   |

# 5.2.9 Register (0x0F) DATA\_5

DESCRIPTION: AUX\_Z(MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x0F) DATA_5 |   |   |   |
|-------------|------------------------|---|---|---|
| Bit         | 7                      | 6 | 5 | 4 |
| Read/Write  | R                      | R | R | R |
| Reset Value | 0                      | 0 | 0 | 0 |
| Content     | aux_z_15_8             |   |   |   |
| Bit         | 3                      | 2 | 1 | 0 |
| Read/Write  | R                      | R | R | R |
| Reset Value | 0                      | 0 | 0 | 0 |
| Content     | aux_z_15_8             |   |   |   |

# 5.2.10 Register (0x10) DATA\_6

DESCRIPTION: AUX\_R(LSB)

RESET: 0x00

| Name        | Register (0x10) DATA_6 |      |       |   |
|-------------|------------------------|------|-------|---|
| Bit         | 7                      | 6    | 5     | 4 |
| Read/Write  | R                      | R    | R     | R |
| Reset Value | 0                      | 0    | 0     | 0 |
| Content     |                        | aux_ | r_7_0 |   |
| Bit         | 3                      | 2    | 1     | 0 |
| Read/Write  | R                      | R    | R     | R |
| Reset Value | 0                      | 0    | 0     | 0 |
| Content     | aux r 7 0              |      |       |   |

# 5.2.11 Register (0x11) DATA\_7

DESCRIPTION: AUX\_R(MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x11) DATA_7 |   |   |   |
|-------------|------------------------|---|---|---|
| Bit         | 7                      | 6 | 5 | 4 |
| Read/Write  | R                      | R | R | R |
| Reset Value | 0                      | 0 | 0 | 0 |
| Content     | aux_r_15_8             |   |   |   |
| Bit         | 3                      | 2 | 1 | 0 |
| Read/Write  | R                      | R | R | R |
| Reset Value | 0                      | 0 | 0 | 0 |
| Content     | aux_r_15_8             |   |   |   |

# 5.2.12 Register (0x12) DATA\_8

DESCRIPTION: ACC\_X(LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Name        |   | Register (0x12) DATA_8 |   |   |
|-------------|---|------------------------|---|---|
| Bit         | 7 | 6                      | 5 | 4 |
| Read/Write  | R | R                      | R | R |
| Reset Value | 0 | 0                      | 0 | 0 |
| Content     |   | acc_x_7_0              |   |   |
| Bit         | 3 | 2                      | 1 | 0 |
| Read/Write  | R | R                      | R | R |
| Reset Value | 0 | 0                      | 0 | 0 |
| Content     |   | acc_x_7_0              |   |   |

# 5.2.13 Register (0x13) DATA\_9

DESCRIPTION: ACC\_X(MSB)

RESET: 0x00

| Name        |   | Register (0x13) DATA_9 |   |   |
|-------------|---|------------------------|---|---|
| Bit         | 7 | 6                      | 5 | 4 |
| Read/Write  | R | R                      | R | R |
| Reset Value | 0 | 0                      | 0 | 0 |
| Content     |   | acc_x_15_8             |   |   |
| Bit         | 3 | 2                      | 1 | 0 |
| Read/Write  | R | R                      | R | R |
| Reset Value | 0 | 0                      | 0 | 0 |
| Content     |   | acc_x_15_8             |   |   |

## 5.2.14 Register (0x14) DATA\_10

DESCRIPTION: ACC\_Y(LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x14) DATA_10 |   |   |   |
|-------------|-------------------------|---|---|---|
| Bit         | 7                       | 6 | 5 | 4 |
| Read/Write  | R                       | R | R | R |
| Reset Value | 0                       | 0 | 0 | 0 |
| Content     | acc_y_7_0               |   |   |   |
| Bit         | 3                       | 2 | 1 | 0 |
| Read/Write  | R                       | R | R | R |
| Reset Value | 0                       | 0 | 0 | 0 |
| Content     | acc_y_7_0               |   |   |   |

# 5.2.15 Register (0x15) DATA\_11

DESCRIPTION: ACC\_Y(MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Name        |   | Register (0x15) DATA_11 |   |   |
|-------------|---|-------------------------|---|---|
| Bit         | 7 | 6                       | 5 | 4 |
| Read/Write  | R | R                       | R | R |
| Reset Value | 0 | 0                       | 0 | 0 |
| Content     |   | acc_y_15_8              |   |   |
| Bit         | 3 | 2                       | 1 | 0 |
| Read/Write  | R | R                       | R | R |
| Reset Value | 0 | 0                       | 0 | 0 |
| Content     |   | acc_y_15_8              |   |   |

# 5.2.16 Register (0x16) DATA\_12

DESCRIPTION: ACC\_Z(LSB)

RESET: 0x00

| Name        | Register (0x16) DATA_12 |       |       |   |
|-------------|-------------------------|-------|-------|---|
| Bit         | 7                       | 6     | 5     | 4 |
| Read/Write  | R                       | R     | R     | R |
| Reset Value | 0                       | 0     | 0     | 0 |
| Content     |                         | acc_z | z_7_0 |   |
| Bit         | 3                       | 2     | 1     | 0 |
| Read/Write  | R                       | R     | R     | R |
| Reset Value | 0                       | 0     | 0     | 0 |
| Content     | acc z 7 0               |       |       |   |

## 5.2.17 Register (0x17) DATA\_13

DESCRIPTION: ACC\_Z(MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x17) DATA_13 |            |   |   |
|-------------|-------------------------|------------|---|---|
| Bit         | 7                       | 6          | 5 | 4 |
| Read/Write  | R                       | R          | R | R |
| Reset Value | 0                       | 0          | 0 | 0 |
| Content     |                         | acc_z_15_8 |   |   |
| Bit         | 3                       | 2          | 1 | 0 |
| Read/Write  | R                       | R          | R | R |
| Reset Value | 0                       | 0          | 0 | 0 |
| Content     | acc z 15 8              |            |   |   |

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

DESCRIPTION: Sensor time <7:0>

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x18) SENSORTIME_0 |                 |         |   |
|-------------|------------------------------|-----------------|---------|---|
| Bit         | 7                            | 6               | 5       | 4 |
| Read/Write  | R                            | R               | R       | R |
| Reset Value | 0                            | 0               | 0       | 0 |
| Content     |                              | sensor_time_7_0 |         |   |
| Bit         | 3                            | 2               | 1       | 0 |
| Read/Write  | R                            | R               | R       | R |
| Reset Value | 0                            | 0               | 0       | 0 |
| Content     |                              | sensor_t        | ime_7_0 |   |

sensor\_time\_7\_0: Sensor time <7:0> in units of 39.0625 us.

# 5.2.19 Register (0x19) SENSORTIME\_1

DESCRIPTION: Sensor time <15:8>

RESET: 0x00

DEFINITION (Go to register map):

| Name        |   | Register (0x19) SENSORTIME_1 |   |   |  |
|-------------|---|------------------------------|---|---|--|
| Bit         | 7 | 6                            | 5 | 4 |  |
| Read/Write  | R | R                            | R | R |  |
| Reset Value | 0 | 0                            | 0 | 0 |  |
| Content     |   | sensor_time_15_8             |   |   |  |
| Bit         | 3 | 2                            | 1 | 0 |  |
| Read/Write  | R | R                            | R | R |  |
| Reset Value | 0 | 0                            | 0 | 0 |  |
| Content     |   | sensor_time_15_8             |   |   |  |

sensor\_time\_15\_8: Sensor time <15:8> in units of 10 ms.

## 5.2.20 Register (0x1A) SENSORTIME\_2

DESCRIPTION: Sensor time <23:16>

RESET: 0x00

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

| Name        | Register (0x1A) SENSORTIME_2 |            |          |   |
|-------------|------------------------------|------------|----------|---|
| Bit         | 7                            | 6          | 5        | 4 |
| Read/Write  | R                            | R          | R        | R |
| Reset Value | 0                            | 0          | 0        | 0 |
| Content     | sensor_time_23_16            |            |          |   |
| Bit         | 3                            | 2          | 1        | 0 |
| Read/Write  | R                            | R          | R        | R |
| Reset Value | 0                            | 0          | 0        | 0 |
| Content     |                              | sensor_tir | ne_23_16 |   |

sensor\_time\_23\_16: Sensor time <23:16> in units of 2.56 s.

### 5.2.21 Register (0x1B) EVENT

**DESCRIPTION: Sensor status flags** 

RESET: 0x01

DEFINITION (Go to register map):

| Name        | Register (0x1B) EVENT |     |     |              |
|-------------|-----------------------|-----|-----|--------------|
| Bit         | 7 6 5 4               |     |     |              |
| Read/Write  | n/a                   | n/a | n/a | n/a          |
| Reset Value | 0                     | 0   | 0   | 0            |
| Content     | reserved              |     |     |              |
| Bit         | 3                     | 2   | 1   | 0            |
| Read/Write  | n/a                   | n/a | n/a | R            |
| Reset Value | 0 0 0                 |     |     | 1            |
| Content     | reserved              |     |     | por_detected |

por\_detected: '1' after device power up or softreset. Clear-on-read

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

DESCRIPTION: Interrupt/Feature status. This register will be cleared on read.

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x1C) INT_STATUS_0 |               |                |          |
|-------------|------------------------------|---------------|----------------|----------|
| Bit         | 7                            | 6             | 5              | 4        |
| Read/Write  | R                            | R             | R              | n/a      |
| Reset Value | 0                            | 0             | 0              | 0        |
| Content     | error_int_out                | no_motion_out | any_motion_out | reserved |
| Bit         | 3                            | 2             | 1              | 0        |
| Read/Write  | n/a                          | n/a           | n/a            | n/a      |
| Reset Value | 0                            | 0             | 0              | 0        |
| Content     | reserved                     |               |                |          |

any\_motion\_out: Any-motion detection output

no\_motion\_out: No-motion detection output

error\_int\_out: Error interrupt output

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

DESCRIPTION: Interrupt Status. This register will be cleared on read.

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x1D) INT_STATUS_1 |          |              |           |
|-------------|------------------------------|----------|--------------|-----------|
| Bit         | 7                            | 6        | 5            | 4         |
| Read/Write  | R                            | n/a      | R            | n/a       |
| Reset Value | 0                            | 0        | 0            | 0         |
| Content     | acc_drdy_int                 | reserved | aux_drdy_int | reserved  |
| Bit         | 3                            | 2        | 1            | 0         |
| Read/Write  | n/a                          | n/a      | R            | R         |
| Reset Value | 0                            | 0        | 0            | 0         |
| Content     | rese                         | rved     | fwm_int      | ffull_int |

ffull\_int: FIFO Full Interrupt
fwm\_int: FIFO Watermark Interrupt

aux\_drdy\_int: Auxiliary sensor data ready interruptacc\_drdy\_int: Accelerometer data ready interrupt

### 5.2.24 Register (0x22) TEMPERATURE

DESCRIPTION: Contains the temperature value of the sensor

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x22) TEMPERATURE |             |   |   |
|-------------|-----------------------------|-------------|---|---|
| Bit         | 7                           | 6           | 5 | 4 |
| Read/Write  | R                           | R           | R | R |
| Reset Value | 0                           | 0           | 0 | 0 |
| Content     |                             | temperature |   |   |
| Bit         | 3                           | 2           | 1 | 0 |
| Read/Write  | R                           | R           | R | R |
| Reset Value | 0                           | 0           | 0 | 0 |
| Content     |                             | temperature |   |   |

temperature: Temperature value in two's complement representation in units of 1 Kelvin: 0x00 corresponds to 23 degree Celsius.

## 5.2.25 Register (0x24) FIFO\_LENGTH\_0

DESCRIPTION: FIFO byte count register (LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x24) FIFO_LENGTH_0 |             |            |   |
|-------------|-------------------------------|-------------|------------|---|
| Bit         | 7                             | 6           | 5          | 4 |
| Read/Write  | R                             | R           | R          | R |
| Reset Value | 0                             | 0           | 0          | 0 |
| Content     | fifo_byte_counter_7_0         |             |            |   |
| Bit         | 3                             | 2           | 1          | 0 |
| Read/Write  | R                             | R           | R          | R |
| Reset Value | 0                             | 0           | 0          | 0 |
| Content     |                               | fifo_byte_c | ounter_7_0 |   |

fifo\_byte\_counter\_7\_0: Current fill level of FIFO buffer.

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

DESCRIPTION: FIFO byte count register (MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Name        |      | Register (0x25) FIFO_LENGTH_1 |             |             |  |
|-------------|------|-------------------------------|-------------|-------------|--|
| Bit         | 7    | 6                             | 5           | 4           |  |
| Read/Write  | n/a  | n/a                           | R           | R           |  |
| Reset Value | 0    | 0                             | 0           | 0           |  |
| Content     | rese | reserved                      |             | ounter_13_8 |  |
| Bit         | 3    | 2                             | 1           | 0           |  |
| Read/Write  | R    | R                             | R           | R           |  |
| Reset Value | 0    | 0                             | 0           | 0           |  |
| Content     |      | fifo_byte_co                  | ounter_13_8 |             |  |

fifo\_byte\_counter\_13\_8: FIFO byte counter bits 13..8

## 5.2.27 Register (0x26) FIFO\_DATA

DESCRIPTION: FIFO data output register

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x26) FIFO_DATA |         |      |   |  |  |
|-------------|---------------------------|---------|------|---|--|--|
| Bit         | 7                         | 7 6 5 4 |      |   |  |  |
| Read/Write  | R                         | R       | R    | R |  |  |
| Reset Value | 0                         | 0       | 0    | 0 |  |  |
| Content     |                           | fifo_   | data |   |  |  |
| Bit         | 3                         | 2       | 1    | 0 |  |  |
| Read/Write  | R                         | R       | R    | R |  |  |
| Reset Value | 0                         | 0       | 0    | 0 |  |  |
| Content     | fifo data                 |         |      |   |  |  |

fifo\_data: FIFO read data.

#### 5.2.28 Register (0x2A) INTERNAL\_STATUS

DESCRIPTION: Error bits and message indicating internal status

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x2A) INTERNAL_STATUS |                |                  |         |
|-------------|---------------------------------|----------------|------------------|---------|
| Bit         | 7                               | 6              | 5                | 4       |
| Read/Write  | n/a                             | R              | R                | R       |
| Reset Value | 0                               | 0              | 0                | 0       |
| Content     | reserved                        | odr_50Hz_error | axes_remap_error | message |
| Bit         | 3                               | 2              | 1                | 0       |
| Read/Write  | R                               | R              | R                | R       |
| Reset Value | 0                               | 0              | 0                | 0       |
| Content     | message                         |                |                  |         |

message: Internal status message

| message |          |                         |
|---------|----------|-------------------------|
| 0x00    | not_init | ASIC is not initialized |
| 0x01    | init_ok  | ASIC initialized        |
| 0x02    | init_err | Initialization error    |
| 0x03    | drv_err  | Invalid driver          |
| 0x04    | sns_stop | Sensor stopped          |

axes\_remap\_error: Incorrect axes remapping. X,Y,Z axes must be mapped to exclusively separate axes i.e. they cannot be mapped to same axes.

odr\_50Hz\_error: The minimum bandwidth conditions are not respected for the features which require 50 Hz data

### 5.2.29 Register (0x40) ACC\_CONF

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

DEFINITION (Go to register map):

| Name        | Register (0x40) ACC_CONF |         |    |    |
|-------------|--------------------------|---------|----|----|
| Bit         | 7                        | 6       | 5  | 4  |
| Read/Write  | RW                       | RW      | RW | RW |
| Reset Value | 1                        | 0       | 1  | 0  |
| Content     | acc_perf_mode            | acc_bwp |    |    |
| Bit         | 3                        | 2       | 1  | 0  |
| Read/Write  | RW                       | RW      | RW | RW |
| Reset Value | 1                        | 0       | 0  | 0  |
| Content     | acc_odr                  |         |    |    |

acc\_odr: ODR in Hz. The output data rate is independent of the power mode setting for the sensor, but not all settings are supported in all power modes.

| acc_odr |          |          |
|---------|----------|----------|
| 0x00    | reserved | Reserved |
| 0x01    | odr_0p78 | 25/32    |
| 0x02    | odr_1p5  | 25/16    |
| 0x03    | odr_3p1  | 25/8     |
| 0x04    | odr_6p25 | 25/4     |
| 0x05    | odr_12p5 | 25/2     |
| 0x06    | odr_25   | 25       |
| 0x07    | odr_50   | 50       |
| 0x08    | odr_100  | 100      |
| 0x09    | odr_200  | 200      |
| 0x0a    | odr_400  | 400      |
| 0x0b    | odr_800  | 800      |
| 0x0c    | odr_1k6  | 1600     |
| 0x0d    | odr_3k2  | Reserved |
| 0x0e    | odr_6k4  | Reserved |
| 0x0f    | odr_12k8 | Reserved |

acc\_bwp: Bandwidth parameter, determines filter configuration (acc\_perf\_mode=1) and averaging for undersampling mode (acc\_perf\_mode=0)

| acc_bwp |            |                                                                         |
|---------|------------|-------------------------------------------------------------------------|
| 0x00    | osr4_avg1  | acc_perf_mode = 1 -> OSR4 mode; acc_perf_mode = 0 -> no averaging       |
| 0x01    | osr2_avg2  | acc_perf_mode = 1 -> OSR2 mode; acc_perf_mode = 0 -> average 2 samples  |
| 0x02    | norm_avg4  | acc_perf_mode = 1 -> normal mode; acc_perf_mode = 0 -> average 4        |
|         |            | samples                                                                 |
| 0x03    | cic_avg8   | acc_perf_mode = 1 -> Reserved; acc_perf_mode = 0 -> average 8 samples   |
| 0x04    | res_avg16  | acc_perf_mode = 1 -> Reserved; acc_perf_mode = 0 -> average 16 samples  |
| 0x05    | res_avg32  | acc_perf_mode = 1 -> Reserved; acc_perf_mode = 0 -> average 32 samples  |
| 0x06    | res_avg64  | acc_perf_mode = 1 -> Reserved; acc_perf_mode = 0 -> average 64 samples  |
| 0x07    | res_avg128 | acc_perf_mode = 1 -> Reserved; acc_perf_mode = 0 -> average 128 samples |

acc\_perf\_mode: Select accelerometer filter performance mode:

| acc_perf_mode |         |                             |
|---------------|---------|-----------------------------|
| 0x00          | cic_avg | averaging mode.             |
| 0x01          | cont    | continuous filter function. |

## 5.2.30 Register (0x41) ACC\_RANGE

DESCRIPTION: Selection of the Accelerometer g-range

RESET: 0x01

DEFINITION (Go to register map):

| Name        | Register (0x41) ACC_RANGE |          |      |       |
|-------------|---------------------------|----------|------|-------|
| Bit         | 7                         | 6        | 5    | 4     |
| Read/Write  | n/a                       | n/a      | n/a  | n/a   |
| Reset Value | 0                         | 0        | 0    | 0     |
| Content     |                           | reserved |      |       |
| Bit         | 3                         | 2        | 1    | 0     |
| Read/Write  | n/a                       | n/a      | RW   | RW    |
| Reset Value | 0                         | 0        | 0    | 1     |
| Content     | rese                      | erved    | acc_ | range |

acc\_range: Accelerometer g-range

| acc_range |           |        |
|-----------|-----------|--------|
| 0x00      | range_2g  | +/-2g  |
| 0x01      | range_4g  | +/-4g  |
| 0x02      | range_8g  | +/-8g  |
| 0x03      | range_16g | +/-16g |

# 5.2.31 Register (0x44) AUX\_CONF

DESCRIPTION: Sets the output data rate of the Auxiliary interface

RESET: 0x46

DEFINITION (Go to register map):

| Name        | Register (0x44) AUX_CONF |            |    |    |
|-------------|--------------------------|------------|----|----|
| Bit         | 7                        | 6          | 5  | 4  |
| Read/Write  | RW                       | RW         | RW | RW |
| Reset Value | 0                        | 1          | 0  | 0  |
| Content     |                          | aux offset |    |    |
| Bit         | 3                        | 2          | 1  | 0  |
| Read/Write  | RW                       | RW         | RW | RW |
| Reset Value | 0                        | 1          | 1  | 0  |
| Content     | aux_odr                  |            |    |    |

aux\_odr: Select the poll rate for the sensor attached to the Auxiliary interface.

| aux_odr |          |          |
|---------|----------|----------|
| 0x00    | reserved | Reserved |
| 0x01    | odr_0p78 | 25/32    |
| 0x02    | odr_1p5  | 25/16    |
| 0x03    | odr_3p1  | 25/8     |
| 0x04    | odr_6p25 | 25/4     |
| 0x05    | odr_12p5 | 25/2     |
| 0x06    | odr_25   | 25       |
| 0x07    | odr_50   | 50       |
| 0x08    | odr_100  | 100      |
| 0x09    | odr_200  | 200      |
| 0x0a    | odr_400  | 400      |
| 0x0b    | odr_800  | 800      |
| 0x0c    | odr_1k6  | Reserved |
| 0x0d    | odr_3k2  | Reserved |
| 0x0e    | odr_6k4  | Reserved |
| 0x0f    | odr_12k8 | Reserved |

aux\_offset: trigger-readout offset in units of 2.5 ms. If set to zero, the offset is maximum, i.e. after readout a trigger is issued immediately.

## 5.2.32 Register (0x45) FIFO\_DOWNS

DESCRIPTION: Configure Accelerometer downsampling rates for FIFO

RESET: 0x80

DEFINITION (Go to register map):

| Name        | Register (0x45) FIFO_DOWNS |                |     |     |
|-------------|----------------------------|----------------|-----|-----|
| Bit         | 7                          | 6              | 5   | 4   |
| Read/Write  | RW                         | RW             | RW  | RW  |
| Reset Value | 1                          | 0              | 0   | 0   |
| Content     | acc_fifo_filt_data         | acc_fifo_downs |     |     |
| Bit         | 3                          | 2              | 1   | 0   |
| Read/Write  | n/a                        | n/a            | n/a | n/a |
| Reset Value | 0                          | 0              | 0   | 0   |
| Content     | reserved                   |                |     |     |

acc\_fifo\_downs: Downsampling for accelerometer data (2\*\*acc\_fifo\_downs) acc\_fifo\_filt\_data: selects filtered or unfiltered Accelerometer data for fifo

| acc_fifo_filt_data |            |                 |
|--------------------|------------|-----------------|
| 0x00               | unfiltered | Unfiltered data |
| 0x01               | filtered   | Filtered data   |

## 5.2.33 Register (0x46) FIFO\_WTM\_0

DESCRIPTION: FIFO Watermark level LSB

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x46) FIFO_WTM_0 |    |    |    |
|-------------|----------------------------|----|----|----|
| Bit         | 7                          | 6  | 5  | 4  |
| Read/Write  | RW                         | RW | RW | RW |
| Reset Value | 0                          | 0  | 0  | 0  |
| Content     | fifo_water_mark_7_0        |    |    |    |
| Bit         | 3                          | 2  | 1  | 0  |
| Read/Write  | RW                         | RW | RW | RW |
| Reset Value | 0                          | 0  | 0  | 0  |
| Content     | fifo_water_mark_7_0        |    |    |    |

## 5.2.34 Register (0x47) FIFO\_WTM\_1

DESCRIPTION: FIFO Watermark level MSB

RESET: 0x02

DEFINITION (Go to register map):

| Name        | Register (0x47) FIFO_WTM_1 |             |           |                          |
|-------------|----------------------------|-------------|-----------|--------------------------|
| Bit         | 7                          | 6           | 5         | 4                        |
| Read/Write  | n/a                        | n/a         | n/a       | RW                       |
| Reset Value | 0                          | 0           | 0         | 0                        |
| Content     | reserved                   |             |           | fifo_water_mark_1<br>2_8 |
| Bit         | 3                          | 2           | 1         | 0                        |
| Read/Write  | RW                         | RW          | RW        | RW                       |
| Reset Value | 0                          | 0           | 1         | 0                        |
| Content     |                            | fifo_water_ | mark_12_8 |                          |

## 5.2.35 Register (0x48) FIFO\_CONFIG\_0

DESCRIPTION: FIFO frame content configuration

RESET: 0x02

| Name        | Register (0x48) FIFO_CONFIG_0 |         |              |                   |  |  |
|-------------|-------------------------------|---------|--------------|-------------------|--|--|
| Bit         | 7                             | 7 6 5 4 |              |                   |  |  |
| Read/Write  | n/a                           | n/a     | n/a          | n/a               |  |  |
| Reset Value | 0                             | 0       | 0            | 0                 |  |  |
| Content     |                               | rese    | rved         |                   |  |  |
| Bit         | 3                             | 2       | 1            | 0                 |  |  |
| Read/Write  | n/a                           | n/a     | RW           | RW                |  |  |
| Reset Value | 0                             | 0       | 1            | 0                 |  |  |
| Content     | rese                          | rved    | fifo_time_en | fifo_stop_on_full |  |  |

fifo\_stop\_on\_full: Stop writing samples into FIFO when FIFO is full.

| fifo_stop_on_full |         |                                       |
|-------------------|---------|---------------------------------------|
| 0x00              | disable | do not stop writing to FIFO when full |
| 0x01              | enable  | Stop writing into FIFO when full.     |

fifo\_time\_en: Return sensortime frame after the last valid data frame.

| fifo_time_en |         |                                |
|--------------|---------|--------------------------------|
| 0x00         | disable | do not return sensortime frame |
| 0x01         | enable  | return sensortime frame        |

# 5.2.36 Register (0x49) FIFO\_CONFIG\_1

DESCRIPTION: FIFO frame content configuration

RESET: 0x10

DEFINITION (Go to register map):

| Name        | Register (0x49) FIFO_CONFIG_1 |                  |             |                |
|-------------|-------------------------------|------------------|-------------|----------------|
| Bit         | 7                             | 6                | 5           | 4              |
| Read/Write  | n/a                           | RW               | RW          | RW             |
| Reset Value | 0                             | 0                | 0           | 1              |
| Content     | reserved                      | fifo_acc_en      | fifo_aux_en | fifo_header_en |
| Bit         | 3                             | 2                | 1           | 0              |
| Read/Write  | RW                            | RW               | n/a         | n/a            |
| Reset Value | 0                             | 0                | 0           | 0              |
| Content     | fifo_tag_int1_en              | fifo_tag_int2_en | reserved    |                |

fifo\_tag\_int2\_en: FIFO interrupt 2 tag enable

| fifo_tag_int2_en |         |             |
|------------------|---------|-------------|
| 0x00             | disable | disable tag |
| 0x01             | enable  | enable tag  |

fifo\_tag\_int1\_en: FIFO interrupt 1 tag enable

| fifo_tag_int1_en |         |             |
|------------------|---------|-------------|
| 0x00             | disable | disable tag |
| 0x01             | enable  | enable tag  |

fifo\_header\_en: FIFO frame header enable

| fifo_header_en |         |                                              |
|----------------|---------|----------------------------------------------|
| 0x00           | disable | no header is stored (output data rate of all |
|                |         | enabled sensors need to be identical)        |
| 0x01           | enable  | header is stored                             |

fifo\_aux\_en: Store Auxiliary data in FIFO (all 3 axes)

| fifo_aux_en |         |                             |
|-------------|---------|-----------------------------|
| 0x00        | disable | no Auxiliary data is stored |
| 0x01        | enable  | Auxiliary data is stored    |

fifo\_acc\_en: Store Accelerometer data in FIFO (all 3 axes)

| fifo_acc_en |         |                                 |
|-------------|---------|---------------------------------|
| 0x00        | disable | no Accelerometer data is stored |
| 0x01        | enable  | Accelerometer data is stored    |

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

DESCRIPTION: Auxiliary interface slave device id

RESET: 0x20

DEFINITION (Go to register map):

| Name        | Register (0x4B) AUX_DEV_ID |    |    |          |  |  |
|-------------|----------------------------|----|----|----------|--|--|
| Bit         | 7 6 5 4                    |    |    |          |  |  |
| Read/Write  | RW                         | RW | RW | RW       |  |  |
| Reset Value | 0                          | 0  | 1  | 0        |  |  |
| Content     | i2c device addr            |    |    |          |  |  |
| Bit         | 3 2 1 0                    |    |    |          |  |  |
| Read/Write  | RW                         | RW | RW | n/a      |  |  |
| Reset Value | 0                          | 0  | 0  | 0        |  |  |
| Content     | i2c_device_addr            |    |    | reserved |  |  |

i2c\_device\_addr: I2C device address of Auxiliary slave

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

DESCRIPTION: Auxiliary interface configuration

RESET: 0x83

| Name        | Register (0x4C) AUX_IF_CONF |          |              |     |
|-------------|-----------------------------|----------|--------------|-----|
| Bit         | 7                           | 6        | 5            | 4   |
| Read/Write  | RW                          | n/a      | n/a          | n/a |
| Reset Value | 1                           | 0        | 0            | 0   |
| Content     | aux_manual_en               | reserved |              |     |
| Bit         | 3                           | 2        | 1            | 0   |
| Read/Write  | n/a                         | n/a      | RW           | RW  |
| Reset Value | 0                           | 0        | 1            | 1   |
| Content     | reserved                    |          | aux_rd_burst |     |

aux\_rd\_burst: Burst data length (1,2,6,8 byte)

| aux_rd_burst |     |                |
|--------------|-----|----------------|
| 0x00         | BL1 | Burst length 1 |
| 0x01         | BL2 | Burst length 2 |
| 0x02         | BL6 | Burst length 6 |
| 0x03         | BL8 | Burst length 8 |

aux\_manual\_en: Enable auxiliary interface manual mode.

| aux_manual_en |         |            |
|---------------|---------|------------|
| 0x00          | disable | Data mode  |
| 0x01          | enable  | Setup mode |

## 5.2.39 Register (0x4D) AUX\_RD\_ADDR

DESCRIPTION: Auxiliary interface read register address

RESET: 0x42

DEFINITION (Go to register map):

| Name        | Register (0x4D) AUX_RD_ADDR |           |    |    |
|-------------|-----------------------------|-----------|----|----|
| Bit         | 7                           | 6         | 5  | 4  |
| Read/Write  | RW                          | RW        | RW | RW |
| Reset Value | 0                           | 1         | 0  | 0  |
| Content     |                             | read_addr |    |    |
| Bit         | 3                           | 2         | 1  | 0  |
| Read/Write  | RW                          | RW        | RW | RW |
| Reset Value | 0                           | 0         | 1  | 0  |
| Content     | read_addr                   |           |    |    |

read\_addr: Address to read

### 5.2.40 Register (0x4E) AUX\_WR\_ADDR

DESCRIPTION: Auxiliary interface write register address

RESET: 0x4C

DEFINITION (Go to register map):

| Name        | Register (0x4E) AUX_WR_ADDR |            |    |    |
|-------------|-----------------------------|------------|----|----|
| Bit         | 7                           | 6          | 5  | 4  |
| Read/Write  | RW                          | RW         | RW | RW |
| Reset Value | 0                           | 1          | 0  | 0  |
| Content     |                             | write_addr |    |    |
| Bit         | 3                           | 2          | 1  | 0  |
| Read/Write  | RW                          | RW         | RW | RW |
| Reset Value | 1                           | 1          | 0  | 0  |
| Content     | write_addr                  |            |    |    |

write\_addr: Address to write

## 5.2.41 Register (0x4F) AUX\_WR\_DATA

DESCRIPTION: Auxiliary interface write data

RESET: 0x02

DEFINITION (Go to register map):

| Name        | Register (0x4F) AUX_WR_DATA |            |    |    |
|-------------|-----------------------------|------------|----|----|
| Bit         | 7                           | 6          | 5  | 4  |
| Read/Write  | RW                          | RW         | RW | RW |
| Reset Value | 0                           | 0          | 0  | 0  |
| Content     |                             | write data |    |    |
| Bit         | 3                           | 2          | 1  | 0  |
| Read/Write  | RW                          | RW         | RW | RW |
| Reset Value | 0                           | 0          | 1  | 0  |
| Content     | write_data                  |            |    |    |

write\_data: Data to write

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

DESCRIPTION: Configure the electrical behaviour of the interrupt pins

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x53) INT1_IO_CTRL |          |     |           |
|-------------|------------------------------|----------|-----|-----------|
| Bit         | 7                            | 6        | 5   | 4         |
| Read/Write  | n/a                          | n/a      | n/a | RW        |
| Reset Value | 0                            | 0        | 0   | 0         |
| Content     |                              | reserved |     |           |
| Bit         | 3                            | 2        | 1   | 0         |
| Read/Write  | RW                           | RW       | RW  | RW        |
| Reset Value | 0                            | 0        | 0   | 0         |
| Content     | output_en                    | od       | lvl | edge_ctrl |

### edge\_ctrl: Configure trigger condition of INT1 pin (input)

| edge_ctrl |          |       |
|-----------|----------|-------|
| 0x00      | level_tr | Level |
| 0x01      | edge_tr  | Edge  |

#### lvl: Configure level of INT1 pin

| lvl  |             |             |
|------|-------------|-------------|
| 0x00 | active_low  | active low  |
| 0x01 | active_high | active high |

#### od: Configure behaviour of INT1 pin to open drain.

| od   |            |            |
|------|------------|------------|
| 0x00 | push_pull  | push-pull  |
| 0x01 | open_drain | open drain |

output\_en: Output enable for INT1 pin

| output_en |     |                 |
|-----------|-----|-----------------|
| 0x00      | off | Output disabled |
| 0x01      | on  | Output enabled  |

input\_en: Input enable for INT1 pin

| input_en |     |                |
|----------|-----|----------------|
| 0x00     | off | Input disabled |
| 0x01     | on  | Input enabled  |

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

DESCRIPTION: Configure the electrical behaviour of the interrupt pins

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x54) INT2_IO_CTRL |          |     |           |
|-------------|------------------------------|----------|-----|-----------|
| Bit         | 7                            | 6        | 5   | 4         |
| Read/Write  | n/a                          | n/a      | n/a | RW        |
| Reset Value | 0                            | 0        | 0   | 0         |
| Content     |                              | reserved |     |           |
| Bit         | 3                            | 2        | 1   | 0         |
| Read/Write  | RW                           | RW       | RW  | RW        |
| Reset Value | 0                            | 0        | 0   | 0         |
| Content     | output_en                    | od       | lvl | edge_ctrl |

edge\_ctrl: Configure trigger condition of INT2 pin (input)

| edge_ctrl |          |       |
|-----------|----------|-------|
| 0x00      | level_tr | Level |
| 0x01      | edge_tr  | Edge  |

Ivl: Configure level of INT2 pin

| lvl  |             |             |
|------|-------------|-------------|
| 0x00 | active_low  | active low  |
| 0x01 | active_high | active high |

od: Configure behaviour of INT2 pin to open drain.

| od   |            |            |
|------|------------|------------|
| 0x00 | push_pull  | push-pull  |
| 0x01 | open_drain | open drain |

output\_en: Output enable for INT2 pin

|           | -   |                 |
|-----------|-----|-----------------|
| output_en |     |                 |
| 0x00      | off | Output disabled |
| 0x01      | on  | Output enabled  |

input\_en: Input enable for INT2 pin

| input_en |     |                |
|----------|-----|----------------|
| 0x00     | off | Input disabled |
| 0x01     | on  | Input enabled  |

### 5.2.44 Register (0x55) INT\_LATCH

DESCRIPTION: Configure interrupt modes

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x55) INT_LATCH |     |     |           |
|-------------|---------------------------|-----|-----|-----------|
| Bit         | 7                         | 6   | 5   | 4         |
| Read/Write  | n/a                       | n/a | n/a | n/a       |
| Reset Value | 0                         | 0   | 0   | 0         |
| Content     | reserved                  |     |     |           |
| Bit         | 3                         | 2   | 1   | 0         |
| Read/Write  | n/a                       | n/a | n/a | RW        |
| Reset Value | 0                         | 0   | 0   | 0         |
| Content     | reserved                  |     |     | int_latch |

int\_latch: Latched/non-latched/temporary interrupt modes

| int_latch |           |             |
|-----------|-----------|-------------|
| 0x00      | none      | non latched |
| 0x01      | permanent | latched     |

## 5.2.45 Register (0x56) INT1\_MAP

DESCRIPTION: Interrupt/Feature mapping on INT1

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x56) INT1_MAP |               |                |          |
|-------------|--------------------------|---------------|----------------|----------|
| Bit         | 7                        | 6             | 5              | 4        |
| Read/Write  | RW                       | RW            | RW             | n/a      |
| Reset Value | 0                        | 0             | 0              | 0        |
| Content     | error_int_out            | no_motion_out | any_motion_out | reserved |
| Bit         | 3                        | 2             | 1              | 0        |
| Read/Write  | n/a                      | n/a           | n/a            | n/a      |
| Reset Value | 0                        | 0             | 0              | 0        |
| Content     | reserved                 |               |                |          |

any\_motion\_out: Any-motion detection output no\_motion\_out: No-motion detection output

error\_int\_out: Error interrupt output

#### 5.2.46 Register (0x57) INT2\_MAP

DESCRIPTION: Interrupt/Feature mapping on INT2

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x57) INT2_MAP |               |                |          |
|-------------|--------------------------|---------------|----------------|----------|
| Bit         | 7                        | 6             | 5              | 4        |
| Read/Write  | RW                       | RW            | RW             | n/a      |
| Reset Value | 0                        | 0             | 0              | 0        |
| Content     | error_int_out            | no_motion_out | any_motion_out | reserved |
| Bit         | 3                        | 2             | 1              | 0        |
| Read/Write  | n/a                      | n/a           | n/a            | n/a      |
| Reset Value | 0                        | 0             | 0              | 0        |
| Content     | reserved                 |               |                |          |

any\_motion\_out: Any-motion detection output no\_motion\_out: No-motion detection output

error\_int\_out: Error interrupt output

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

DESCRIPTION: Interrupt mapping hardware interrupts

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x58) INT_MAP_DATA |           |          |            |
|-------------|------------------------------|-----------|----------|------------|
| Bit         | 7                            | 6         | 5        | 4          |
| Read/Write  | n/a                          | RW        | RW       | RW         |
| Reset Value | 0                            | 0         | 0        | 0          |
| Content     | reserved                     | int2_drdy | int2_fwm | int2_ffull |
| Bit         | 3                            | 2         | 1        | 0          |
| Read/Write  | n/a                          | RW        | RW       | RW         |
| Reset Value | 0                            | 0         | 0        | 0          |
| Content     | reserved                     | int1_drdy | int1_fwm | int1_ffull |

int1\_ffull: FIFO Full interrupt mapped to INT1

int1\_fwm: FIFO Watermark interrupt mapped to INT1 int1\_drdy: Data Ready interrupt mapped to INT1 int2\_ffull: FIFO Full interrupt mapped to INT2

int2\_fwm: FIFO Watermark interrupt mapped to INT2 int2\_drdy: Data Ready interrupt mapped to INT2

## 5.2.48 Register (0x59) INIT\_CTRL

DESCRIPTION: Start initialization

RESET: 0x90

DEFINITION (Go to register map):

| Name        | Register (0x59) INIT_CTRL |    |    |    |
|-------------|---------------------------|----|----|----|
| Bit         | 7                         | 6  | 5  | 4  |
| Read/Write  | RW                        | RW | RW | RW |
| Reset Value | 1                         | 0  | 0  | 1  |
| Content     | init_ctrl                 |    |    |    |
| Bit         | 3                         | 2  | 1  | 0  |
| Read/Write  | RW                        | RW | RW | RW |
| Reset Value | 0                         | 0  | 0  | 0  |
| Content     | init_ctrl                 |    |    |    |

init\_ctrl: Start initialization

# 5.2.49 Register (0x5E) FEATURES\_IN

DESCRIPTION: Feature configuration read/write port

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x5E) FEATURES_IN |    |    |    |
|-------------|-----------------------------|----|----|----|
| Bit         | 7                           | 6  | 5  | 4  |
| Read/Write  | RW                          | RW | RW | RW |
| Reset Value | 0                           | 0  | 0  | 0  |
| Content     | features_in                 |    |    |    |
| Bit         | 3                           | 2  | 1  | 0  |
| Read/Write  | RW                          | RW | RW | RW |
| Reset Value | 0                           | 0  | 0  | 0  |
| Content     | features_in                 |    |    |    |

features\_in: Feature configuration read/write data

| Address | Bit        | Name       | Description                                   | Reset  | Access |
|---------|------------|------------|-----------------------------------------------|--------|--------|
|         | any_motion |            |                                               |        |        |
| 0x5E:   |            | settings_1 | Any-motion detection general configuration    | 0x00AA |        |
| 0x00    |            |            | flags - part 1                                |        |        |
|         | 100        | threshold  | Slope threshold value for any-motion          | 0xAA   | RW     |
|         |            |            | detection. Range is 0 to 1g. Default value is |        |        |
|         |            |            | 0xAA = 83mg.                                  |        |        |
| 0x5E:   |            | settings_2 | Any-motion detection general configuration    | 0x0005 |        |
| 0x02    |            |            | flags - part 2                                |        |        |
|         | 120        | duration   | Defines the number of consecutive data points | 0x5    | RW     |
|         |            |            | for which the threshold condition must be     |        |        |
|         |            |            | respected for interrupt assertion.            |        |        |
|         |            |            | It is expressed in 50 Hz samples (20 ms).     |        |        |
|         |            |            | Range is 0 to 163sec. Default value is        |        |        |
|         |            |            | 5=100ms.                                      |        |        |
|         | 13         | x_en       | Enables the feature on a per-axis basis       | 0x0    | RW     |

|       | 14  | y_en       | Enables the feature on a per-axis basis        | 0x0       | RW |
|-------|-----|------------|------------------------------------------------|-----------|----|
|       | 15  | z_en       | Enables the feature on a per-axis basis        | 0x0       | RW |
|       | ,   |            | no motion                                      |           |    |
| 0x5E: |     | settings_1 | No-motion detection general configuration      | 0x00AA    |    |
| 0x04  |     | 00180      | flags - part 1                                 | 0,100,111 |    |
| •     | 100 | threshold  | Slope threshold value for no-motion detection. | 0xAA      | RW |
|       |     |            | Range is 0 to 1g. Default value is 0xAA =      |           |    |
|       |     |            | 83mg.                                          |           |    |
| 0x5E: |     | settings_2 | No-motion detection general configuration      | 0x0005    |    |
| 0x06  |     |            | flags - part 2                                 |           |    |
|       | 120 | duration   | Defines the number of consecutive data points  | 0x5       | RW |
|       |     |            | for which the threshold condition must be      |           |    |
|       |     |            | respected for interrupt assertion.             |           |    |
|       |     |            | It is expressed in 50 Hz samples (20 ms).      |           |    |
|       |     |            | Range is 0 to 163sec. Default value is         |           |    |
|       |     |            | 5=100ms.                                       |           |    |
|       | 13  | x_en       | Enables the feature on a per-axis basis        | 0x0       | RW |
|       | 14  | y_en       | Enables the feature on a per-axis basis        | 0x0       | RW |
|       | 15  | z_en       | Enables the feature on a per-axis basis        | 0x0       | RW |
|       |     |            | general_settings                               | 1 0110    |    |
| 0x5E: |     | Reserved   | Reserved                                       | 0x0000    |    |
| 0x08  | 150 | Reserved   | Reserved                                       | 0x0       |    |
| 0x5E: | 200 | axes_remap | Describes axes remapping                       | 0x0088    |    |
| 0x0A  |     | ping       | besonibes axes remapping                       | 0,0000    |    |
|       | 10  | map_x_axis | Map the x axis to desired axis                 | 0x0       | RW |
|       |     |            | Value Name Description                         |           |    |
|       |     |            | 0x00 x_axis Map to x-axis                      |           |    |
|       |     |            | 0x01 y_axis Map to y-axis                      |           |    |
|       |     |            | 0x02 z_axis Map to z-axis                      |           |    |
|       |     |            | 0x03 reserved Map to x-axis                    |           |    |
|       | 2   | map_x_axis | Map the x axis sign to the desired one         | 0x0       | RW |
|       |     | _sign      | Value Name Description                         |           |    |
|       |     | 0          | 0x00 not_invert Clear this bit to              |           |    |
|       |     |            | not invert the x                               |           |    |
|       |     |            | axis                                           |           |    |
|       |     |            | 0x01 inverted Set this bit to                  |           |    |
|       |     |            | invert the x axis                              |           |    |
|       | 43  | map_y_axis | Map the y axis to desired axis                 | 0x1       | RW |
|       |     |            | Value Name Description                         |           |    |
|       |     |            | 0x00 x_axis Map to x-axis                      |           |    |
|       |     |            | 0x01 y_axis Map to y-axis                      |           |    |
|       |     |            | 0x02 z_axis Map to z-axis                      |           |    |
|       |     |            | 0x03 reserved Map to y-axis                    |           |    |
|       | 5   | map_y_axis | Map the y axis sign to the desired one         | 0x0       | RW |
|       |     | _sign      | Value Name Description                         |           |    |
|       |     | _ 0        | 0x00 not_invert Clear this bit to              |           |    |
|       |     |            | not invert the y                               |           |    |
|       |     |            | axis                                           |           |    |
|       |     |            | 0x01 inverted Set this bit to                  |           |    |
|       |     |            |                                                |           |    |

| 76 | map_z_axis |       | Map the z a | axis to desired axis    | 0x2 | RW |
|----|------------|-------|-------------|-------------------------|-----|----|
|    |            | Value | Name        | Description             |     |    |
|    |            | 0x00  | x_axis      | Map to x-axis           |     |    |
|    |            | 0x01  | y_axis      | Map to y-axis           |     |    |
|    |            | 0x02  | z_axis      | Map to z-axis           |     |    |
|    |            | 0x03  | reserved    | Map to z-axis           |     |    |
| 8  | map_z_axis | Map   | the z axis  | sign to the desired one | 0x0 | RW |
|    | _sign      | Value | Name        | Description             |     |    |
|    |            | 0x00  | not_invert  | Clear this bit to       |     |    |
|    |            |       |             | not invert the z        |     |    |
|    |            |       |             | axis                    |     |    |
|    |            | 0x01  | inverted    | Set this bit to         |     |    |
|    |            |       |             | invert the z axis       |     |    |

## 5.2.50 Register (0x5F) INTERNAL\_ERROR

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

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x5F) INTERNAL_ERROR |           |           |          |  |
|-------------|--------------------------------|-----------|-----------|----------|--|
| Bit         | 7                              | 6         | 5         | 4        |  |
| Read/Write  | n/a                            | n/a       | n/a       | n/a      |  |
| Reset Value | 0                              | 0         | 0         | 0        |  |
| Content     | reserved                       |           |           |          |  |
| Bit         | 3                              | 2         | 1         | 0        |  |
| Read/Write  | n/a                            | R         | R         | n/a      |  |
| Reset Value | 0                              | 0         | 0         | 0        |  |
| Content     | reserved                       | int_err_2 | int_err_1 | reserved |  |

int\_err\_1: Internal error flag - long processing time, processing halted

int\_err\_2: Internal error flag - fatal error, processing halted

## 5.2.51 Register (0x6A) NVM\_CONF

DESCRIPTION: NVM controller mode (Prog/Erase or Read only)

RESET: 0x00

| Name        | Register (0x6A) NVM_CONF |       |             |          |  |
|-------------|--------------------------|-------|-------------|----------|--|
| Bit         | 7                        | 6     | 5           | 4        |  |
| Read/Write  | n/a                      | n/a   | n/a         | n/a      |  |
| Reset Value | 0                        | 0     | 0           | 0        |  |
| Content     | reserved                 |       |             |          |  |
| Bit         | 3                        | 2     | 1           | 0        |  |
| Read/Write  | n/a                      | n/a   | RW          | n/a      |  |
| Reset Value | 0                        | 0     | 0           | 0        |  |
| Content     | rese                     | erved | nvm_prog_en | reserved |  |

nvm\_prog\_en: Enable NVM programming

| nvm_prog_en |         |         |
|-------------|---------|---------|
| 0x00        | disable | disable |
| 0x01        | enable  | enable  |

### 5.2.52 Register (0x6B) IF\_CONF

**DESCRIPTION: Serial interface settings** 

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x6B) IF_CONF |     |     |         |
|-------------|-------------------------|-----|-----|---------|
| Bit         | 7                       | 6   | 5   | 4       |
| Read/Write  | n/a                     | n/a | n/a | RW      |
| Reset Value | 0                       | 0   | 0   | 0       |
| Content     | reserved                |     |     | if_mode |
| Bit         | 3                       | 2   | 1   | 0       |
| Read/Write  | n/a                     | n/a | n/a | RW      |
| Reset Value | 0                       | 0   | 0   | 0       |
| Content     | reserved                |     |     | spi3    |

spi3: Configure SPI Interface Mode for primary interface

| spi3 |      |                 |
|------|------|-----------------|
| 0x00 | spi4 | SPI 4-wire mode |
| 0x01 | spi3 | SPI 3-wire mode |

if\_mode: Auxiliary interface configuration

|         | <u> </u>     | Ö                               |
|---------|--------------|---------------------------------|
| if_mode |              |                                 |
| 0x00    | p_auto_s_off | Auxiliary interface:off         |
| 0x01    | p_auto_s_mag | Auxilary interface:Magnetometer |

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

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

RESET: 0x00

| Name        | Register (0x6D) ACC_SELF_TEST |                    |          |                  |
|-------------|-------------------------------|--------------------|----------|------------------|
| Bit         | 7                             | 6                  | 5        | 4                |
| Read/Write  | n/a                           | n/a                | n/a      | n/a              |
| Reset Value | 0                             | 0                  | 0        | 0                |
| Content     | reserved                      |                    |          |                  |
| Bit         | 3                             | 2                  | 1        | 0                |
| Read/Write  | RW                            | RW                 | n/a      | RW               |
| Reset Value | 0                             | 0                  | 0        | 0                |
| Content     | acc_self_test_am              | acc_self_test_sign | reserved | acc_self_test_en |
|             | р                             |                    |          |                  |

acc\_self\_test\_en: Enable accelerometer self-test

| acc_self_test_en |          |          |
|------------------|----------|----------|
| 0x00             | disabled | disabled |
| 0x01             | enabled  | enabled  |

acc self test sign: select sign of self-test excitation as

| acc_self_test_sign |          |          |
|--------------------|----------|----------|
| 0x00               | negative | negative |
| 0x01               | positive | positive |

acc self test amp: select amplitude of the selftest deflection:

| acc_self_test_amp |      |      |
|-------------------|------|------|
| 0x00              | low  | low  |
| 0x01              | high | high |

## 5.2.54 Register (0x70) NV\_CONF

DESCRIPTION: NVM backed configuration bits.

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x70) NV_CONF |            |             |        |
|-------------|-------------------------|------------|-------------|--------|
| Bit         | 7                       | 6          | 5           | 4      |
| Read/Write  | n/a                     | n/a        | n/a         | n/a    |
| Reset Value | 0                       | 0          | 0           | 0      |
| Content     | reserved                |            |             |        |
| Bit         | 3                       | 2          | 1           | 0      |
| Read/Write  | RW                      | RW         | RW          | RW     |
| Reset Value | 0                       | 0          | 0           | 0      |
| Content     | acc_off_en              | i2c_wdt_en | i2c_wdt_sel | spi_en |

spi\_en: disable the I2C and enable SPI for the primary interface, when it is in autoconfig mode

| spi_en |          |              |
|--------|----------|--------------|
| 0x00   | disabled | I2C enabled  |
| 0x01   | enabled  | I2C disabled |

i2c\_wdt\_sel: Select timer period for I2C Watchdog

| i2c_wdt_sel |           |                                    |
|-------------|-----------|------------------------------------|
| 0x00        | wdt_short | I2C watchdog timeout after 1.25 ms |
| 0x01        | wdt_long  | I2C watchdog timeout after 40 ms   |

i2c\_wdt\_en: I2C Watchdog at the SDI pin in I2C interface mode

| i2c_wdt_en |         |                      |
|------------|---------|----------------------|
| 0x00       | Disable | Disable I2C watchdog |
| 0x01       | Enable  | Enable I2C watchdog  |

acc\_off\_en: Add the offset defined in the off\_acc\_[xyz] OFFSET register to filtered and unfiltered

Accelerometer data

| acc_off_en |          |          |
|------------|----------|----------|
| 0x00       | disabled | Disabled |
| 0x01       | enabled  | Enabled  |

## 5.2.55 Register (0x71) OFFSET\_0

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

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x71) OFFSET_0 |    |    |    |  |  |
|-------------|--------------------------|----|----|----|--|--|
| Bit         | 7 6 5 4                  |    |    |    |  |  |
| Read/Write  | RW                       | RW | RW | RW |  |  |
| Reset Value | 0                        | 0  | 0  | 0  |  |  |
| Content     | off_acc_x                |    |    |    |  |  |
| Bit         | 3                        | 2  | 1  | 0  |  |  |
| Read/Write  | RW                       | RW | RW | RW |  |  |
| Reset Value | 0                        | 0  | 0  | 0  |  |  |
| Content     | off_acc_x                |    |    |    |  |  |

off\_acc\_x: Accelerometer offset compensation (X-axis).

# 5.2.56 Register (0x72) OFFSET\_1

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

RESET: 0x00

| Name        | Register (0x72) OFFSET_1 |    |    |    |  |  |
|-------------|--------------------------|----|----|----|--|--|
| Bit         | 7 6 5 4                  |    |    |    |  |  |
| Read/Write  | RW                       | RW | RW | RW |  |  |
| Reset Value | 0                        | 0  | 0  | 0  |  |  |
| Content     | off_acc_y                |    |    |    |  |  |
| Bit         | 3 2 1 0                  |    |    |    |  |  |
| Read/Write  | RW                       | RW | RW | RW |  |  |
| Reset Value | 0                        | 0  | 0  | 0  |  |  |
| Content     | off_acc_y                |    |    |    |  |  |

off\_acc\_y: Accelerometer offset compensation (Y-axis).

## 5.2.57 Register (0x73) OFFSET\_2

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

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x73) OFFSET_2 |           |    |    |  |  |  |
|-------------|--------------------------|-----------|----|----|--|--|--|
| Bit         | 7                        | 6         | 5  | 4  |  |  |  |
| Read/Write  | RW                       | RW        | RW | RW |  |  |  |
| Reset Value | 0                        | 0         | 0  | 0  |  |  |  |
| Content     |                          | off_acc_z |    |    |  |  |  |
| Bit         | 3                        | 2         | 1  | 0  |  |  |  |
| Read/Write  | RW                       | RW        | RW | RW |  |  |  |
| Reset Value | 0                        | 0         | 0  | 0  |  |  |  |
| Content     | off_acc_z                |           |    |    |  |  |  |

off\_acc\_z: Accelerometer offset compensation (Z-axis).

## 5.2.58 Register (0x7C) PWR\_CONF

DESCRIPTION: Power mode configuration register

RESET: 0x03

DEFINITION (Go to register map):

| Name        | Register (0x7C) PWR_CONF                |         |    |     |  |  |
|-------------|-----------------------------------------|---------|----|-----|--|--|
| Bit         | 7                                       | 6       | 5  | 4   |  |  |
| Read/Write  | n/a                                     | n/a n/a |    | n/a |  |  |
| Reset Value | 0                                       | 0 0 0   |    |     |  |  |
| Content     | reserved                                |         |    |     |  |  |
| Bit         | 3                                       | 3 2     |    | 0   |  |  |
| Read/Write  | Nrite n/a n/a RW                        |         | RW |     |  |  |
| Reset Value | 0 0                                     |         | 1  | 1   |  |  |
| Content     | reserved fifo_self_wakeup adv_power_sav |         |    |     |  |  |

| adv_power_save |         |                                                         |
|----------------|---------|---------------------------------------------------------|
| 0x00           | aps_off | advanced power save disabled (fast clk always enabled). |
| 0x01           | aps_on  | advanced power mode enabled (slow clk is active when no |
|                |         | measurement is ongoing.)                                |

| fifo_self_wakeup |         |                                                                  |
|------------------|---------|------------------------------------------------------------------|
| 0x00             | fsw_off | FIFO read disabled in advanced power saving mode.                |
| 0x01             | fsw_on  | FIFO read enabled after interrupt in advanced power saving mode. |

## 5.2.59 Register (0x7D) PWR\_CTRL

DESCRIPTION: Sensor enable register

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x7D) PWR_CTRL |        |          |        |  |  |
|-------------|--------------------------|--------|----------|--------|--|--|
| Bit         | 7                        | 6      | 5        | 4      |  |  |
| Read/Write  | n/a                      | n/a    | n/a      | n/a    |  |  |
| Reset Value | 0                        | 0      | 0 0      |        |  |  |
| Content     | reserved                 |        |          |        |  |  |
| Bit         | 3                        | 2      | 1        | 0      |  |  |
| Read/Write  | n/a                      | RW     | n/a      | RW     |  |  |
| Reset Value | 0                        | 0      | 0        | 0      |  |  |
| Content     | reserved                 | acc_en | reserved | aux_en |  |  |

| aux_en |         |                                |
|--------|---------|--------------------------------|
| 0x00   | mag_off | Disables the auxiliary sensor. |
| 0x01   | mag_on  | Enables the auxiliary sensor.  |

| acc_en |         |                             |
|--------|---------|-----------------------------|
| 0x00   | acc_off | Disables the Accelerometer. |
| 0x01   | acc_on  | Enables the Accelerometer.  |

## 5.2.60 Register (0x7E) CMD

**DESCRIPTION: Command Register** 

RESET: 0x00

DEFINITION (Go to register map):

| Name        | Register (0x7E) CMD |     |    |    |  |  |  |
|-------------|---------------------|-----|----|----|--|--|--|
| Bit         | 7                   | 6   | 5  | 4  |  |  |  |
| Read/Write  | RW                  | RW  | RW | RW |  |  |  |
| Reset Value | 0                   | 0   | 0  | 0  |  |  |  |
| Content     |                     | cmd |    |    |  |  |  |
| Bit         | 3                   | 2   | 1  | 0  |  |  |  |
| Read/Write  | RW                  | RW  | RW | RW |  |  |  |
| Reset Value | 0                   | 0   | 0  | 0  |  |  |  |
| Content     | cmd                 |     |    |    |  |  |  |

cmd: Available commands (Note: Register will always read as 0x00):

| cmd  |            |                                                                                      |
|------|------------|--------------------------------------------------------------------------------------|
| 0xa0 | nvm_prog   | Writes the NVM backed registers into NVM                                             |
| 0xb0 | fifo_flush | Clears all data in the FIFO, does not change FIFO_CONFIG and                         |
|      |            | FIFO_DOWNS registers                                                                 |
| 0xb6 | softreset  | Triggers a reset, all user configuration settings are overwritten with their default |
|      |            | state                                                                                |

## 6. Digital Interfaces

### 6.1 Interfaces

Beside the standard primary interface (I2C and SPI configurable), where sensor acts as a slave to the application processor, BMA490L supports an auxiliary interface. See picture below. If the auxiliary interface is enabled, the BMA490L can be connected to an external sensor (e.g. a magnetometer) in order to build a 6-DoF solution. Then the BMA490L will act as a master to the external sensor, reading the sensor data automatically and providing it to the application processor via the primary interface.



### 6.2 **Primary Interface**

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

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

| Pin# | Pin# Name I/O |             | I/O Type Description                                                                                        |                     | nect to (Prin       | nary IF)                  |
|------|---------------|-------------|-------------------------------------------------------------------------------------------------------------|---------------------|---------------------|---------------------------|
|      |               |             |                                                                                                             | in SPI4W            | in SPI3W            | in I2C                    |
| 1    | SDO           | Digital I/O | Serial data output in SPI<br>Address select in I <sup>2</sup> C mode<br>see chapter 7.2                     | SDO                 | DNC (float)         | GND for default I2C addr. |
| 2    | SDX           | Digital I/O | SDA serial data I/O in I <sup>2</sup> C<br>SDI serial data input in SPI 4W<br>SDA serial data I/O in SPI 3W | SDI                 | SDA                 | SDA                       |
| 5    | INT1          | Digital I/O | Interrupt output 1 (default) (Input for external FIFO sync) *                                               | INT1<br>(FIFO sync) | INT1<br>(FIFO sync) | INT1<br>(FIFO sync)       |
| 6    | INT2          | Digital I/O | Interrupt output 2 (default) (Input for external FIFO sync) *                                               | INT2<br>(FIFO sync) | INT2<br>(FIFO sync) | INT2<br>(FIFO sync)       |
| 10   | CSB           | Digital in  | Chip select for SPI mode                                                                                    | CSB                 | CSB                 | V <sub>DDIO</sub> -       |
| 12   | SCX           | Digital in  | SCK for SPI serial clock<br>SCL for I <sup>2</sup> C serial clock                                           | SCK                 | SCK                 | SCL                       |

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

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

| Parameter                                   | Symbol   | Condition                                  | Min | Тур | Max | Units |
|---------------------------------------------|----------|--------------------------------------------|-----|-----|-----|-------|
| Pull-up Resistance,<br>CSB pin              | $R_{up}$ | Internal Pull-up<br>Resistance to<br>VDDIO | 75  | 100 | 125 | kΩ    |
| Input Capacitance                           | Cin      |                                            |     | 5   |     | pF    |
| I <sup>2</sup> C Bus Load Capacitance (max. |          | V <sub>DDIO</sub> >=1.62V                  |     |     | 400 | pF    |
| drive capability<br>Cı2C_Load               | ()       | V <sub>DDIO</sub> <1.62V                   |     |     | 120 | pF    |

### 6.3 Primary Interface I2C/SPI Protocol Selection

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

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

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

If toggling of the CSB bit is not possible without data communication, there is in addition the spi\_en bit in Register NV CONF, which can be used to permanently set the primary interface to SPI without the need to toggle the CSB pin at every power-up or reset.

### 6.4 SPI interface and protocol

The timing specification for SPI of the BMA490L is given in the following table: SPI timing, valid at  $V_{DDIO} \ge 1.71V$ 

| Parameter                                                        | Symbol                     | Condition                                                           | Min | Max | Units |
|------------------------------------------------------------------|----------------------------|---------------------------------------------------------------------|-----|-----|-------|
| Clock Frequency                                                  | fspi                       | Max. Load on<br>SDI or SDO =<br>30pF, V <sub>DDIO</sub> ≥<br>1.62 V |     | 10  | MHz   |
|                                                                  |                            | $V_{DDIO} < 1.62V$                                                  |     | 7   | MHz   |
| SCK Low Pulse                                                    | <b>t</b> sckl              | V <sub>DDIO</sub> >=1.62V                                           | 45  |     | ns    |
| SCK High Pulse                                                   | <b>t</b> sckh              | $V_{DDIO}>=1.62V$                                                   | 45  |     | ns    |
| SCK Low Pulse                                                    | <b>t</b> sckl              | V <sub>DDIO</sub> <1.62V                                            | 66  |     | ns    |
| SCK High Pulse                                                   | <b>t</b> sckh              | $V_{DDIO}$ < 1.62 $V$                                               | 66  |     | ns    |
| SDI Setup Time                                                   | <b>t</b> SDI_setup         |                                                                     | 20  |     | ns    |
| SDI Hold Time                                                    | <b>t</b> SDI_hold          |                                                                     | 20  |     | ns    |
| SDO Output Delay                                                 | t <sub>SDO_OD</sub>        | Load = 30pF,<br>V <sub>DDIO</sub> ≥ 1.62V                           |     | 30  | ns    |
| CSB Setup Time                                                   | t <sub>CSB_setup</sub>     |                                                                     | 40  |     | ns    |
| CSB Hold Time                                                    | t <sub>CSB_hold</sub>      |                                                                     | 40  |     | ns    |
| Idle time between write accesses, suspend mode, low-power mode 1 | t <sub>IDLE_wacc_sum</sub> |                                                                     | 450 |     | μs    |
| Idle time after write<br>and read access,<br>active state        | tIDLE_wr_act               |                                                                     | 2   |     | μs    |

The following figure shows the definition of the SPI timings:



SPI timing diagram

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

Two configurations of the SPI interface are supported by the BMA490L: 4-wire and 3-wire. The same protocol is used by both configurations. The device operates in 4-wire configuration by default. It can be switched to 3-wire configuration by writing <a href="IF\_CONF.spi3">IF\_CONF.spi3</a> = 0b1. Pin SDI is used as the common data pin in 3-wire configuration.

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

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

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



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

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



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



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

The data bits are used as follows:

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

AD6-AD0: Address

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

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

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

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



3-wire basic SPI read or write sequence (mode '11')

### 6.5 **Primary I2C Interface**

The I<sup>2</sup>C bus uses SCL (= SCx pin, serial clock) and SDA (= SDx pin, serial data input and output) signal lines. Both lines should connected to  $V_{\rm DDIO}$  externally via pull-up resistors so that they are pulled high when the bus is free.

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

The I<sup>2</sup>C interface of the BMA490L is compatible with the I<sup>2</sup>C Specification UM10204 Rev. 03 (19 June 2007), available at http://www.nxp.com. The BMA490L supports I<sup>2</sup>C standard mode and fast mode, only 7-bit address mode is supported. For  $V_{DDIO} = 1.2V$  to 1.62 V the guaranteed voltage output levels are slightly relaxed as described in Table 1 of the electrical specification section.

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

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

| Parameter                | Symbol             | Condition      | Min | Max  | Units |
|--------------------------|--------------------|----------------|-----|------|-------|
| Clock Frequency          | f <sub>SCL</sub>   |                |     | 1000 | kHz   |
| SCL Low Period           | t <sub>LOW</sub>   |                | 1.3 |      | μs    |
| SCL High Period          | <b>t</b> HIGH      |                | 0.6 |      |       |
| SDA Setup Time           | <b>t</b> sudat     |                | 0.1 |      |       |
| SDA Hold Time            | t <sub>HDDAT</sub> |                | 0.0 |      |       |
| Setup Time for a         | <b>t</b> susta     |                | 0.6 |      |       |
| repeated Start Condition |                    |                |     |      |       |
| Hold Time for a Start    | <b>t</b> hdsta     |                | 0.6 |      |       |
| Condition                |                    |                |     |      |       |
| Setup Time for a Stop    | <b>t</b> susto     |                | 0.6 |      |       |
| Condition                |                    |                |     |      |       |
| Time before a new        | <b>t</b> BUF       | low power mode | 400 |      |       |
| Transmission can start   |                    | performance    | 2   |      |       |
|                          |                    | mode           |     |      |       |
| Idle time between write  | tIDLE_wacc_n       | low power mode | 450 |      |       |
| accesses, performance    | m                  | performance    | 2   |      |       |
| mode, low-power mode     |                    | mode           |     |      |       |
| Idle time between write  | tIDLE_wacc_su      |                | 450 |      |       |
| accesses, suspend        | m                  |                |     |      |       |
| mode, low-power mode     |                    |                |     |      |       |

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



I2C timing diagram

The I2C protocol works as follows:

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

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

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

In the following diagrams these abbreviations are used:

| 5    | Start     |
|------|-----------|
| Р    | Stop      |
| ACKS | Acknowled |
|      |           |

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

RW Read / Write

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

#### I<sup>2</sup>C write access:

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

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

Example of an I2C write access:

| Star | t |               | Slav       | ve Ad      | lress |   |   | R/W | ACK |   | R | Regist | er ad | dress | s (0x4 | 1) |   | ACK |   |   | Regi | ster c | lata ( | 0x01) |   |   | ACK | Stop |
|------|---|---------------|------------|------------|-------|---|---|-----|-----|---|---|--------|-------|-------|--------|----|---|-----|---|---|------|--------|--------|-------|---|---|-----|------|
| S    | 0 | 0             | 1<br> <br> | 1<br> <br> | 0     | 0 | 0 | 0   | 0   | 0 | 1 | 0      | 0     | 0     | 0      | 0  | 1 | 0   | 0 | 0 | 0    | 0      | 0      | 0     | 0 | 1 | 0   | Р    |
|      |   | ster<br>ve -> |            |            |       |   |   |     |     |   |   | 10.0   |       |       |        |    |   |     |   |   |      |        |        |       |   |   |     |      |

I<sup>2</sup>C write

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

| S 0 0       | 1 1 0 0 0         |     |     |         |     |     |                 |          |          |
|-------------|-------------------|-----|-----|---------|-----|-----|-----------------|----------|----------|
|             |                   | 0 0 | 0 1 | 0 0 0 1 | 0 1 | 0 1 | 0 0 0           |          | 0 0      |
| Register da | ata byte 1 (0x64) | ACK |     |         | ACK | Reg | ister data byte | n (0xXX) | ACK Stop |
| 0 1 1 (     |                   | 0 . |     |         | . 0 | x x |                 |          | 0 P      |

#### I<sup>2</sup>C read access:

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

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

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

| Start           |   |                    | Sla | ve I2       | C ID       |   |   | R/W | ACK |   | R   | egist      | er ad       | dress | (0x1   | 2)        |   | ACK   |   |             |         |             |      |        |          |             |     |  |
|-----------------|---|--------------------|-----|-------------|------------|---|---|-----|-----|---|-----|------------|-------------|-------|--------|-----------|---|-------|---|-------------|---------|-------------|------|--------|----------|-------------|-----|--|
| S               | 0 | 0<br>              | 1   | <br>  1<br> | <b>I</b> 0 | 0 | 0 | 0   | 0   | Х | 0   | 0          | 1           | 0     | 0      | 1         | 0 | 0     |   |             |         |             |      |        |          |             |     |  |
|                 |   |                    |     |             |            |   |   |     |     |   |     |            | Data        | byte  |        |           |   |       |   |             |         | Data        | byte |        |          |             | I   |  |
| Repeat<br>Start |   |                    | Sla | ve I2       | C ID       |   |   | R/W | ACK |   | Reg | ister      | data -      | - add | ress   | 0x12      |   | ACK   |   | Regi        | ister ( | data -      | addı | ress ( | 0x13     |             | ACK |  |
| Sr              | 0 | 0<br>              | 1   | 1<br> <br>  | <b>I</b> 0 | 0 | 0 | 1   | 0   | Х | X   | Х          | Х           | Х     | X      | X         | X | 0     | Х | <br>  X<br> | X       | <br>  X<br> | Х    | X      | X<br>  X | X<br>I      | 0   |  |
|                 |   |                    |     |             |            |   |   |     |     |   |     |            | Data        | byte  |        |           |   |       |   |             |         | Data        | byte |        |          | _           |     |  |
|                 |   |                    |     |             |            |   |   |     |     |   |     |            |             |       |        |           |   | 4.014 |   | D           |         |             |      |        |          |             |     |  |
|                 |   |                    |     |             |            |   |   |     |     |   | Reg | ister      | data -      | - add | ress   | 0x14      |   | ACK   |   | Regi        | ister ( | data -      | addı | ress   | 0x15     |             | ACK |  |
|                 |   | ter -><br>'e -> l' |     |             |            |   |   |     |     | X |     | ister<br>X | data -<br>X | x     | x      | 0x14<br>X | X | 0     | Х | Kegi        | X       |             | X    |        |          | <br>  X<br> | O O |  |
|                 |   |                    |     |             |            |   |   |     |     | X |     |            |             | X     | X      |           | X |       | Х |             | X       |             | Х    | X      |          |             |     |  |
|                 |   |                    |     |             |            |   |   |     |     | X | X   | X          | Х           | X     | X<br>L | X         | X |       | Х | X           | X       | X           | X    | X      | X        |             |     |  |

In order to prevent the I²C slave of the device to lock-up the I²C bus, a watchdog timer (WDT) is implemented. The WDT observes internal I²C signals and resets the I²C interface if the bus is locked-up by the BMA490L. The activity and the timer period of the WDT can be configured through the bits NV\_CONF.i2c\_wdt\_en and NV\_CONF.i2c\_wdt\_sel.

#### 6.6 SPI and I<sup>2</sup>C Access Restrictions

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

As illustrated in the figure below, an interface idle time of at least 2  $\mu$ s is required following a write operation when the device operates in performance mode. In suspend mode and low power mode an interface idle time of at least 450  $\mu$ s is required.



Post-Write Access Timing Constraints

### 6.7 **Auxiliary Interface**

The BMA490L allows attaching an external sensor (MAG-sensor) to a BMA490L via the auxiliary interface. The connection diagrams for the auxiliary interface are depicted in the chapter 7.3. The timings of the secondary I2C interface are the same as for the primary I2C interface, see chapter 6.5.

BMA490L acts as a master of the secondary interface, controls the data acquisition of the MAG-sensor (slave of the secondary interface) and presents the data to the application processor (AP) in the user registers of the BMA490L through the primary interface. The internal pull-up resistors of ASCL and ASDA are by default disabled, so it is recommended to added pull-up resistors externally onto the secondary interface for proper I2C communication. Please contact your regional sales representative in case the internal pull-up resistors are necessary to be enabled. No additional I2C master or slave devices must be attached to the magnetometer interfaces.

The BMA490L autonomously reads out the sensor data from BMM150 without intervention of the AP and stores the data in its data registers (per default) and FIFO (see Register FIFO CONFIG 1.fifo aux en). The initial setup of the BMM150 after power-on is done through indirect addressing in the BMA490L. From a system perspective the initialization for BMM150 when attached to BMA490L should be possible within 100ms.

More information about the usage of Auxiliary Interface can be found in chapter 4.9.

## 7. Pin-out and Connection Diagrams

### 7.1 **Pin-out**





Pin description

|       | F       |             | T III dese                              |                   |              |                     |
|-------|---------|-------------|-----------------------------------------|-------------------|--------------|---------------------|
| Pin#  | Name    | I/O Type    | Description                             |                   | Connect to   | )                   |
| PIII# | ivaille | I/O Type    | Description                             | in SPI 4W         | In SPI 3W    | in I <sup>2</sup> C |
| 1     | SDO     | Digital I/O | Serial data output in SPI               | SDO               | DNC (float)  | GND for default I2C |
|       |         |             | Address select in I <sup>2</sup> C mode |                   |              | addr.               |
|       |         |             | see chapter 6.5                         |                   |              |                     |
| 2     | SDX     | Digital I/O | SDA serial data I/O in I <sup>2</sup> C | SDI               | SDA          | SDA                 |
|       |         |             | SDI serial data input in SPI 4W         |                   |              |                     |
|       |         |             | SDA serial data I/O in SPI 3W           |                   |              |                     |
| 3     | VDDIO   | Supply      | Digital I/O supply voltage              | $V_{\text{DDIO}}$ | $V_{DDIO}$   | $V_{DDIO}$          |
|       |         |             | (1.2V 3.6V)                             |                   |              |                     |
| 4     | ASDA    | Digital I/O | Serial data I/O – Secondary             | VDDIO/            | VDDIO/       | VDDIO/ GNDIO/NC     |
|       |         |             | Interface (I <sup>2</sup> C Master for  | GNDIO/NC or       | GNDIO/NC or  | or                  |
|       |         |             | Magnetometer)                           | (ASDA -           | (ASDA -      | (ASDA - Secondary   |
|       |         |             |                                         | Secondary         | Secondary    | interface)          |
|       |         |             |                                         | interface)        | interface)   |                     |
| 5     | INT1    | Digital I/O | Interrupt output 1 (default)            | INT1              | INT1         | INT1                |
|       |         |             | (Input for external FIFO sync) *        | (FIFO sync)       | (FIFO sync)  | (FIFO sync)         |
| 6     | INT2    | Digital I/O | Interrupt output 2 (default)            | INT2              | INT2         | INT2                |
|       |         |             | (Input for external FIFO sync) *        | (FIFO sync)       | (FIFO sync)  | (FIFO sync)         |
| 7     | VDD     | Supply      | Power supply for analog & digital       | $V_{DD}$          | $V_{DD}$     | $V_{DD}$            |
|       |         |             | domain (1.62V 3.6V)                     |                   |              |                     |
| 8     | GNDIO   | Ground      | Ground for I/O                          | GND               | GND          | GND                 |
| 9     | GND     | Ground      | Ground for digital & analog             | GND               | GND          | GND                 |
| 10    | CSB     | Digital in  | Chip select for SPI mode                | CSB               | CSB          | V <sub>DDIO</sub>   |
| 11    | ASCL    | Digital out | Digital clock (out) – Secondary         | VDDIO/            | VDDIO/       | VDDIO/ GNDIO/       |
|       |         |             | Interface (I <sup>2</sup> C Master for  | GNDIO/NC or       | GNDIO/ NC or | NC or (ASCL -       |
|       |         |             | Magnetometer)                           | (ASCL -           | (ASCL -      | Secondary           |
|       |         |             |                                         | Secondary         | Secondary    | interface)          |
|       |         |             |                                         | interface)        | interface)   |                     |
| 12    | SCX     | Digital in  | SCK for SPI serial clock                | SCK               | SCK          | SCL                 |
|       |         |             | SCL for I <sup>2</sup> C serial clock   |                   |              |                     |

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

## 7.2 Connection Diagrams without Auxiliary Interface

SPI

3-wire



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

#### 4-wire



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

I2C



It is recommended to use 100nF decoupling capacitors at pin 3 (VDDIO) and pin 7 (VDD). SDA and SCL should be connected to  $V_{\text{DDIO}}$  externally via pull-up resistors so that they are pulled high when the bus is free.

### 7.3 Connection Diagrams with Auxiliary Interface

The internal pull-up resistors of ASCL and ASDA are by default disabled, so it is recommended to added pull-up resistors externally onto the secondary interface for proper I2C communication.

SPI

3-wire



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

#### 4-wire



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





It is recommended to use 100nF decoupling capacitors at pin 3 (VDDIO) and pin 7 (VDD). SDA and SCL should be connected to  $V_{DDIO}$  externally via pull-up resistors so that they are pulled high when the bus is free.

## 8. Package

## 8.1 Package outline dimensions





Note that the pin 5, 6, 11, 12 are in same direction (0.280\*0.290, 4x), while pin 1, 2, 3, 4, 7, 8, 9, 10 are in same direction (0.290\*0.280, 8x).

### 8.2 Sensing axis orientation

If the sensor is accelerated in the indicated directions, the corresponding channel will deliver a positive acceleration signal (dynamic acceleration). If the sensor is at rest and the force of gravity is acting along the indicated directions, the output of the corresponding channel will be negative (static acceleration).

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

- ± 0g for the X channel
- ± 0g for the Y channel
- + 1g for the Z channel



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

| Sensor Orientation<br>(gravity vector ↓) | •            | •          | •          | •            | unright    | triginqu     |
|------------------------------------------|--------------|------------|------------|--------------|------------|--------------|
| Output Signal X                          | 0g/0LSB      | 1g/511 LSB | 0g/0LSB    | -1g/-512 LSB | 0g/0LSB    | 0g/0LSB      |
| Output Signal Y                          | -1g/-512 LSB | 0g/0LSB    | 1g/511 LSB | 0g/0LSB      | 0g/0LSB    | 0g/0LSB      |
| Output Signal Z                          | 0g/0LSB      | 0g/0LSB    | 0g/0LSB    | 0g/0LSB      | 1g/511 LSB | -1g/-512 LSB |

For reference the figure below shows the typical device orientation with an integrated BMA490L.



## 8.3 Landing pattern recommendation

The recommended landing pattern for the BMA490L on customer's PCB is given in the following figure. It is recommended to avoid any wiring underneath the BMA490L (shaded area).



## 8.4 Marking

### **Mass production**

| Labeling | Name                         | Symbol | Remark                                                  |
|----------|------------------------------|--------|---------------------------------------------------------|
|          | Internal Code                | ZZ     | internal                                                |
| • ZZ     | Counter ID                   | ccc    | 3 alphanumeric digits, variable to generate trace-code. |
| CCC      | Pin 1 identifier<br>top side | •      |                                                         |

## **Engineering samples**

| Labeling    | Name                         | Symbol | Remark                                                               |
|-------------|------------------------------|--------|----------------------------------------------------------------------|
|             | Internal Code                | X      | internal                                                             |
|             | Eng. sample ID               | E, N   | 2 alphanumeric digits, fixed to identify engineering sample, N = "C" |
| ● XE<br>NCC | Sample ID                    | СС     | 2 alphanumeric digits, variable to generate trace-code.              |
|             | Pin 1 identifier<br>top side | •      |                                                                      |

### 8.5 Soldering guidelines

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

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

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

| Profile Feature                                                                                                                           | Pb-Free Assembly                   |
|-------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|
| Average Ramp-Up Rate<br>(Ts <sub>max</sub> to Tp)                                                                                         | 3° C/second max.                   |
| Preheat  - Temperature Min (Ts <sub>min</sub> )  - Temperature Max (Ts <sub>max</sub> )  - Time (ts <sub>min</sub> to ts <sub>max</sub> ) | 150 °C<br>200 °C<br>60-180 seconds |
| Time maintained above:  - Temperature (T <sub>L</sub> )  - Time (t <sub>L</sub> )                                                         | 217 °C<br>60-150 seconds           |
| Peak/Classification Temperature (Tp)                                                                                                      | 260 °C                             |
| Time within 5 °C of actual Peak<br>Temperature (tp)                                                                                       | 20-40 seconds                      |
| Ramp-Down Rate                                                                                                                            | 6 °C/second max.                   |
| Time 25 °C to Peak Temperature                                                                                                            | 8 minutes max.                     |

Note 1: All temperatures refer to topside of the package, measured on the package body surface.



### 8.6 Handling instructions

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

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

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

## 8.7 Tape and Reel specification



| Ao | 2.35 +/- 0.05       |
|----|---------------------|
| Во | 2.30 +/- 0.05       |
| Ko | 1.10 +/- 0.05       |
| F  | 5.50 +/- 0.05       |
| P1 | 4.00 +/- 0.10       |
| W  | 12.00 +0.30 / -0.10 |

#### 8.8 Environmental safety

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

Directive 2015/863 (amending Annex II to Directive 2011/65/EU) of the European Parliament and of the Council on the restriction of the use of certain hazardous substances in electrical and electronic equipment.

#### **Halogen content**

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

#### Internal package structure

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

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

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

## 9. Legal disclaimer

### 9.1 Engineering samples

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

#### 9.2 Product use

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

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

The resale and/or use of Bosch Sensortec products are at the purchaser's own risk and his own responsibility. The examination of fitness for the intended use is the sole responsibility of the purchaser. The purchaser shall indemnify Bosch Sensortec from all third party claims arising from any product use not covered by the parameters of this product data sheet or not approved by Bosch Sensortec and reimburse Bosch Sensortec for all costs in connection with such claims.

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

#### 9.3 Application examples and hints

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

# 10. Document history and modification

| Rev. No | Chapter | Description of modification/changes | Date    |
|---------|---------|-------------------------------------|---------|
| 1.0     | All     | Public release                      | 06.2020 |
| 2.0     | 9       | Disclaimer update                   | 11.2020 |
| 2.1     | 1.1     | Offset value update                 | 03.2021 |
|         | 4.7     | Integrated feature set update       |         |

#### \*Longevity Disclaimer

Bosch Sensortec strives to maintain the supply of longevity product variants for a period of 10 years (from SOD/product introduction date), including the notification period. During such period, in case of significant volume decrease or manufacturing changes Bosch Sensortec may decide to

- (i) replace the product by another (comparable) product and/or
- (ii) change the technology, manufacturing facilities and/or process

Any change will be notified to customers using the standard Bosch Sensortec product/process change policy (PCN)

#### **Bosch Sensortec GmbH**

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

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

Modifications reserved
Preliminary - specifications subject to change without notice
Document number: BST-BMA490L-DS000-03
Revision\_2.1\_032021