Data sheet

# BMC050 Electronic Compass

**Bosch Sensortec** 





BMC050: Data sheet

Document revision 1.0

Document release date October 28<sup>th</sup>, 2011

Document number BST-BMC050-DS000-10

Technical reference code(s) 0 273 141 124

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

notice. Product photos and pictures are for illustration purposes only and

may differ from the real product's appearance. This document is confidential and under NDA.



Page 2 Confidential

## **BMC050**

# ELECTRONIC COMPASS WITH THREE-AXIS MAGNETIC FIELD SENSOR AND THREE-AXIS ACCELEROMETER

## **Key features**

Three-axis magnetic field sensor and three-axis accelerometer in one package

• Accelerometer can still be used independently from magnetometer operation

• Ultra-Small package LGA package (16 pins), footprint 3mm x 3mm, height

0.95mm

Digital interface
 SPI (4-wire, 3-wire), I<sup>2</sup>C, 4 interrupt pins

(2 acceleration sensor, 2 magnetic sensor interrupt pins)

Low voltage operation
 V<sub>DD</sub> supply voltage range: 1.62V to 3.6V

 $\ensuremath{V_{\text{DDIO}}}$  interface voltage range: 1.2V to 3.6V

• Flexible functionality Acceleration ranges  $\pm 2g / \pm 4g / \pm 8g / \pm 16g$ 

Acceleration Low-pass filter bandwidths 1 kHz - <8Hz

Magnetic field range typical  $\pm 1000 \mu T$ Magnetic field resolution of  $\sim 0.3 \mu T$ 

On-chip interrupt controller
 Motion-triggered interrupt-signal generation for

- new data (separate for accelerometer and magnetometer)

- any-motion (slope) detection

- tap sensing (single tap / double tap)

- orientation recognition

- flat detection

- low-g/high-g detection

- magnetic Low-/High-Threshold detection

• Ultra-low power Low current consumption (190μA @ 10 Hz including

accelerometer and magnetic sensor in low power preset), short wake-up time, advanced features for system power

management

Temperature range -40 °C ... +85 °C

· RoHS compliant, halogen-free

#### **Typical applications**

- Tilt-compensated electronic compass for map rotation, navigation and augmented reality
- 6-axis orientation for gaming
- Display profile switching
- Menu scrolling, tap / double tap sensing
- Pedometer / step counting
- Free-fall detection
- Drop detection for warranty logging
- Advanced system power management for mobile applications



Page 3 Confidential

#### **General Description**

The BMC050 is an integrated electronic compass solution for consumer market applications. It comprises a leading edge triaxial, low-g acceleration sensor and an ultra-low power, high precision triaxial magnetic field sensor. It allows measurements of acceleration and magnetic field in three perpendicular axes. Performance and features of both sensing technologies are carefully tuned and perfectly match the demanding requirements of all 6-axis mobile applications such as electronic compass, navigation or augmented reality.

An evaluation circuitry (ASIC) converts the output of the micromechanical sensing structures (MEMS) to digital results which can be read out over the industry standard digital interfaces.

Package and interfaces of the BMC050 have been designed to match a multitude of hardware requirements. As the sensor features an ultra-small footprint and a flat package, it is ingeniously suited for mobile applications.

The BMC050 offers ultra-low voltage operation ( $V_{DD}$  voltage range from 1.62V to 3.6V,  $V_{DDIO}$  voltage range 1.2V to 3.6V) and can be programmed to optimize functionality, performance and power consumption in customer specific applications. The programmable interrupt engine sets new standards in terms of flexibility.

The BMC050 senses orientation, tilt, motion, shock, vibration and heading in cell phones, handhelds, computer peripherals, man-machine interfaces, virtual reality features and game controllers.



Page 4 Confidential

# **Index of Contents**

| 1. S | PECIFICATION                            | 7                    |
|------|-----------------------------------------|----------------------|
| 1.   | 1 COMPASS ELECTRICAL SPECIFICATION      | 7                    |
| 1.   | 2 ACCELEROMETER SPECIFICATION           | 7                    |
| 1.   | 3 Magnetometer specification            | 9                    |
| 2. A | BSOLUTE MAXIMUM RATINGS                 | 12                   |
| 3. B | LOCK DIAGRAM                            | 13                   |
| 4. F | UNCTIONAL DESCRIPTION                   | 14                   |
| 4.   | 1 Power management                      | 14                   |
| 4.   | 2 Protocol selection                    | 14                   |
| 4.   | 3 Power modes                           | 15                   |
|      | 4.3.1 ACCELEROMETER POWER MODES         | 18                   |
| 4.   | 4 Sensor data                           | . 21                 |
|      | 4.4.1 ACCELERATION DATA                 | 23<br>23             |
| 4.   | 5 SELF-TEST                             | 26                   |
|      | 4.5.1 ACCELEROMETER SELF-TEST           |                      |
| 4.   | 6 ACCELEROMETER OFFSET COMPENSATION     | . 28                 |
|      | 4.6.1 SLOW COMPENSATION                 | 30<br>31             |
| 4.   | 7 Non-volatile memory                   | 32                   |
|      | 4.7.1 ACCELEROMETER NON-VOLATILE MEMORY |                      |
| 4.   | 8 ACCELEROMETER INTERRUPT CONTROLLER    | . 33                 |
|      | 4.8.1 GENERAL FEATURES                  | 34<br>35<br>35<br>36 |
|      | 4.8.8 FLAT DETECTION                    | 43                   |
|      | 4.8.9 Low-g interrupt                   | 43                   |



Page 5 Confidential

| 4.8.10 High-g interrupt                                                                                                                                                                   | 44                        |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
| 4.9 MAGNETOMETER INTERRUPT CONTROLLER                                                                                                                                                     | 45                        |
| 4.9.1 GENERAL FEATURES 4.9.2 ELECTRICAL BEHAVIOR OF MAGNETIC INTERRUPT PINS 4.9.3 DATA READY / DRDY INTERRUPT 4.9.4 LOW-THRESHOLD INTERRUPT 4.9.5 HIGH-THRESHOLD INTERRUPT 4.9.6 OVERFLOW |                           |
| 5. ACCELEROMETER REGISTER DESCRIPTION                                                                                                                                                     | 49                        |
| 5.1 GENERAL REMARKS                                                                                                                                                                       | 49                        |
| 5.2 REGISTER MAP                                                                                                                                                                          | 50                        |
| 5.3 CHIP ID                                                                                                                                                                               | 50                        |
| 5.4 Acceleration data                                                                                                                                                                     | 51                        |
| 5.5 TEMPERATURE DATA                                                                                                                                                                      | 53                        |
| 5.6 Status registers                                                                                                                                                                      | 53                        |
| 5.7 g-range selection                                                                                                                                                                     | 55                        |
| 5.8 BANDWIDTHS                                                                                                                                                                            | 55                        |
| 5.9 Power modes                                                                                                                                                                           | 55                        |
| 5.10 SPECIAL CONTROL SETTINGS                                                                                                                                                             |                           |
| 5.11 Interrupt settings                                                                                                                                                                   | 56                        |
| 5.12 SELF-TEST                                                                                                                                                                            |                           |
| 5.13 Non-volatile memory control (EEPROM control)                                                                                                                                         | 65                        |
| 5.14 Interface configuration                                                                                                                                                              |                           |
| 5.15 Offset compensation                                                                                                                                                                  | 67                        |
| 6. MAGNETOMETER REGISTER DESCRIPTION                                                                                                                                                      | 69                        |
| 6.1 GENERAL REMARKS                                                                                                                                                                       | 69                        |
| 6.2 REGISTER MAP                                                                                                                                                                          | 69                        |
| 6.3 CHIP ID                                                                                                                                                                               | 70                        |
| 6.4 Magnetic field data                                                                                                                                                                   | 70                        |
| 6.5 Interrupt status register                                                                                                                                                             | 73                        |
| 6.6 Power and operation modes, self-test and data output f                                                                                                                                | RATE CONTROL REGISTERS 73 |
| 6.7 Interrupt and axis enable settings control registers                                                                                                                                  | 75                        |
| 6.8 Number of repetitions control registers                                                                                                                                               | 77                        |
| 7. DIGITAL INTERFACES                                                                                                                                                                     | 79                        |
| 7.1 SERIAL PERIPHERAL INTERFACE (SPI)                                                                                                                                                     | 80                        |
| 7.2 INTER-INTEGRATED CIRCUIT (I <sup>2</sup> C)                                                                                                                                           | 84                        |



Page 6 Confidential

| 8. PIN-OUT AND CONNECTION DIAGRAM       | 88  |
|-----------------------------------------|-----|
| 8.1 PIN-OUT                             | 88  |
| 8.2 Connection diagram 4-wire SPI       | 90  |
| 8.3 Connection diagram 3-wire SPI       | 91  |
| 8.4 CONNECTION DIAGRAM I <sup>2</sup> C | 92  |
| 9. PACKAGE                              | 93  |
| 9.1 OUTLINE DIMENSIONS                  | 93  |
| 9.2 Sensing axes orientation            | 94  |
| 9.3 Android axes orientation            | 95  |
| 9.4 LANDING PATTERN RECOMMENDATION      | 97  |
| 9.5 Marking                             | 98  |
| 9.5.1 Mass production devices           |     |
| 9.6 SOLDERING GUIDELINES                | 99  |
| 9.7 Handling instructions               | 100 |
| 9.8 TAPE AND REEL SPECIFICATION         | 101 |
| 9.8.1 TAPE AND REEL DIMENSIONS          |     |
| 9.9 Environmental safety                | 103 |
| 9.9.1 HALOGEN CONTENT                   |     |
| 10. LEGAL DISCLAIMER                    | 104 |
| 10.1 Engineering samples                | 104 |
| 10.2 PRODUCT USE                        | 104 |
| 10.3 APPLICATION EXAMPLES AND HINTS     | 104 |
| 11. DOCUMENT HISTORY AND MODIFICATION   | 105 |

Page 7
Confidential

## 1. Specification

If not stated otherwise, the given values are over lifetime and full performance temperature and voltage ranges, minimum/maximum values are  $\pm 3\sigma$ . The specifications are split into accelerometer part and magnetometer part of BMC050.

## 1.1 Compass electrical specification

Table 1: Compass electrical parameter specification

| COMPASS OPERATING CONDITIONS       |                     |                                                                   |                        |     |                        |      |  |
|------------------------------------|---------------------|-------------------------------------------------------------------|------------------------|-----|------------------------|------|--|
| Parameter                          | Symbol              | Condition                                                         | Min                    | Тур | Max                    | Unit |  |
| Supply Voltage<br>Internal Domains | $V_{DD}$            |                                                                   | 1.62                   | 2.4 | 3.6                    | V    |  |
| Supply Voltage<br>I/O Domain       | $V_{\rm DDIO}$      |                                                                   | 1.2                    | 1.8 | 3.6                    | V    |  |
| Voltage Input<br>Low Level         | $V_{IL,a}$          | SPI & I <sup>2</sup> C                                            |                        |     | 0.3V <sub>DDIO</sub>   | -    |  |
| Voltage Input<br>High Level        | $V_{\text{IH,a}}$   | SPI & I <sup>2</sup> C                                            | 0.7V <sub>DDIO</sub>   |     |                        | -    |  |
| Voltage Output                     | $V_{OL,a}$          | $V_{DDIO} = 1.62V$<br>$I_{OL} = 3 \text{ mA, SPI \& I}^2\text{C}$ |                        |     | 0.2V <sub>DDIO</sub>   | -    |  |
| Low Level                          |                     | $V_{DDIO}$ = 1.2V $I_{OL}$ = 3 mA, SPI & I <sup>2</sup> C         |                        |     | 0.23 V <sub>DDIO</sub> | -    |  |
| Voltage Output                     | V                   | $V_{DDIO} = 1.62V$<br>$I_{OL} = 2 \text{ mA, SPI \& I}^2\text{C}$ | 0.8V <sub>DDIO</sub>   |     |                        | -    |  |
| High Level                         | $V_{\mathrm{OH,a}}$ | $V_{DDIO}$ = 1.2V $I_{OL}$ = 2 mA, SPI & I <sup>2</sup> C         | 0.62 V <sub>DDIO</sub> |     |                        | -    |  |

## 1.2 Accelerometer specification

Table 2: Accelerometer parameter specification

| ACCELEROMETER OPERATING CONDITIONS |                       |                                                                                    |     |     |     |      |  |  |
|------------------------------------|-----------------------|------------------------------------------------------------------------------------|-----|-----|-----|------|--|--|
| Parameter                          | Symbol                | Condition                                                                          | Min | Тур | Max | Unit |  |  |
|                                    | <b>g</b> FS2g         |                                                                                    |     | ±2  |     | g    |  |  |
| Acceleration Range                 | <b>g</b> FS4g         | Selectable                                                                         |     | ±4  |     | g    |  |  |
| Acceleration Name                  | <b>g</b> FS8g         | via serial digital interface                                                       |     | ±8  |     | g    |  |  |
|                                    | <b>g</b> FS16g        |                                                                                    |     | ±16 |     | g    |  |  |
| Supply Current in<br>Normal Mode   | I <sub>DD,a</sub>     | Nominal $V_{DD}$ supplies $T_A=25$ °C, bw = 1kHz                                   |     | 139 |     | μΑ   |  |  |
| Supply Current in Low-Power Mode   | $I_{\mathrm{DDIp,a}}$ | Nominal $V_{DD}$ supplies $T_A=25^{\circ}C$ , bw = 1kHz sleep duration $\geq$ 25ms |     | 7   |     | μΑ   |  |  |
| Supply Current in<br>Suspend Mode  | I <sub>DDsm,a</sub>   | Nominal $V_{DD}$ supplies $T_A$ =25°C                                              |     | 0.5 |     | μΑ   |  |  |



Page 8 Confidential

| Wake-Up Time                            | t <sub>w_up,a</sub> | from Low-Power Mode<br>or Suspend Mode,<br>bw = 1kHz                                        |            | 0.8   |       | ms     |  |  |  |  |  |
|-----------------------------------------|---------------------|---------------------------------------------------------------------------------------------|------------|-------|-------|--------|--|--|--|--|--|
| Start-Up Time                           | t <sub>s_up,a</sub> | POR, bw = 1kHz                                                                              |            | 2     |       | ms     |  |  |  |  |  |
| Operating<br>Temperature                | T <sub>A</sub>      | Same for accelerometer and magnetometer                                                     | -40        |       | +85   | °C     |  |  |  |  |  |
|                                         |                     | ACCELEROMETER OUTP                                                                          | PUT SIGNAL |       |       |        |  |  |  |  |  |
| Parameter                               |                     |                                                                                             |            |       |       |        |  |  |  |  |  |
| Device Resolution                       | $D_{res,a}$         | <b>g</b> FS2g                                                                               |            | 3.91  |       | mg     |  |  |  |  |  |
|                                         | $S_{2g}$            | g <sub>FS2g</sub> , T <sub>A</sub> =25°C                                                    |            | 256   |       | LSB/g  |  |  |  |  |  |
| 0 11 - 11                               | S <sub>4g</sub>     | g <sub>FS4g</sub> , T <sub>A</sub> =25°C                                                    |            | 128   |       | LSB/g  |  |  |  |  |  |
| Sensitivity                             | S <sub>8g</sub>     | g <sub>FS8g</sub> , T <sub>A</sub> =25°C                                                    |            | 64    |       | LSB/g  |  |  |  |  |  |
|                                         | S <sub>16g</sub>    | g <sub>FS16g</sub> , T <sub>A</sub> =25°C                                                   |            | 32    |       | LSB/g  |  |  |  |  |  |
| Sensitivity<br>Temperature Drift        | TCSa                | $g_{FS2g}$ , -40°C $\leq T_A \leq$ +85°C<br>Nominal $V_{DD}$ supplies                       |            | ±0.02 |       | %/K    |  |  |  |  |  |
| Zero-g Offset                           | Offa                | g <sub>FS2g</sub> , T <sub>A</sub> =25°C<br>Nominal V <sub>DD</sub> supplies                |            | ±80   |       | mg     |  |  |  |  |  |
| Zero-g Offset<br>Temperature Drift      | TCOa                | $g_{FS2g}$ , -40°C $\leq T_A \leq$ +85°C<br>Nominal $V_{DD}$ supplies                       |            | ±1    |       | mg/K   |  |  |  |  |  |
|                                         | bw <sub>8</sub>     |                                                                                             |            | 8     |       | Hz     |  |  |  |  |  |
|                                         | $bw_{16}$           |                                                                                             |            | 16    |       | Hz     |  |  |  |  |  |
|                                         | bw <sub>31</sub>    |                                                                                             |            | 31    |       | Hz     |  |  |  |  |  |
| Bandwidth                               | bw <sub>63</sub>    | 1 <sup>st</sup> order filter, selectable via serial digital interface                       |            | 63    |       | Hz     |  |  |  |  |  |
| Danuwium                                | bw <sub>125</sub>   |                                                                                             |            | 125   |       | Hz     |  |  |  |  |  |
|                                         | bw <sub>250</sub>   |                                                                                             |            | 250   |       | Hz     |  |  |  |  |  |
|                                         | bw <sub>500</sub>   |                                                                                             |            | 500   |       | Hz     |  |  |  |  |  |
|                                         | bw <sub>1000</sub>  |                                                                                             |            | 1000  |       | Hz     |  |  |  |  |  |
| Nonlinearity                            | $NL_{,a}$           | best fit straight line                                                                      |            | ±0.5  |       | %FS    |  |  |  |  |  |
| Output Noise                            | n <sub>rms,a</sub>  | g <sub>FS2g</sub> , T <sub>A</sub> =25°C<br>Nominal V <sub>DD</sub> supplies<br>Normal mode |            | 0.8   |       | mg/√Hz |  |  |  |  |  |
| Power Supply<br>Rejection Rate          | PSRRa               | $T_A$ =25°C<br>Nominal $V_{DD}$ supplies                                                    |            |       | 20    | mg/V   |  |  |  |  |  |
| Temperature Sensor<br>Measurement Range | $T_S$               | $T_A$ =25°C Nominal $V_{DD}$ supplies                                                       | -40        |       | +87.5 | °C     |  |  |  |  |  |
| Temperature Sensor<br>Slope             | dT <sub>S</sub>     | $T_A$ =25°C<br>Nominal $V_{DD}$ supplies                                                    |            | 0.5   |       | LSB/K  |  |  |  |  |  |
| Temperature Sensor<br>Offset            | OTs                 | T <sub>A</sub> =25°C<br>Nominal V <sub>DD</sub> supplies                                    |            | ±5    |       | К      |  |  |  |  |  |



Page 9 Confidential

| ACCELEROMETER MECHANICAL CHARACTERISTICS |           |                                                               |     |      |     |      |  |  |
|------------------------------------------|-----------|---------------------------------------------------------------|-----|------|-----|------|--|--|
| Parameter                                | Symbol    | Condition                                                     | Min | Тур  | Max | Unit |  |  |
| Cross Axis<br>Sensitivity                | Sa        | relative contribution<br>between any two of the<br>three axes |     | 1    |     | %    |  |  |
| Alignment Error                          | $E_{A,a}$ | relative to package<br>outline                                |     | ±0.5 |     | o    |  |  |

## 1.3 Magnetometer specification

Table 3: Magnetometer parameter specification

| MAGNETOMETER OPERATING CONDITIONS          |                        |                                                                                               |     |       |      |        |  |  |
|--------------------------------------------|------------------------|-----------------------------------------------------------------------------------------------|-----|-------|------|--------|--|--|
| Parameter                                  | Symbol                 | Condition                                                                                     | Min | Тур   | Max  | Unit   |  |  |
| Magnetic field                             | $B_{rg,xy}$            | T <sub>A</sub> =25°C, full active                                                             |     | ±1000 |      | μΤ     |  |  |
| range                                      | $B_{rg,z}$             | measurement range                                                                             |     | 2500  |      | μΤ     |  |  |
| Magnetometer heading accuracy <sup>1</sup> | Am <sub>heading</sub>  | $30\mu T$ horizontal geomagnetic field component, $T_A$ =25°C                                 |     |       | ±2.5 | degree |  |  |
| System heading accuracy <sup>2</sup>       | As <sub>heading</sub>  | 30µT horizontal<br>geomagnetic field<br>component, T <sub>A</sub> =25°C                       |     |       | ±3.5 | degree |  |  |
|                                            | $I_{\mathrm{DD,lp,m}}$ | Low power preset<br>Nominal $V_{DD}$ supplies<br>$T_A$ =25°C, ODR=10Hz                        |     | 170   |      | μА     |  |  |
| Supply Current in<br>Active Mode           | I <sub>DD,rg,m</sub>   | Regular preset<br>Nominal V <sub>DD</sub> supplies<br>T <sub>A</sub> =25°C, ODR=10Hz          |     | 0.5   |      | mA     |  |  |
| (average) <sup>3</sup>                     | I <sub>DD,eh,m</sub>   | Enhanced regular preset<br>Nominal V <sub>DD</sub> supplies<br>T <sub>A</sub> =25°C, ODR=10Hz |     | 0.8   |      | mA     |  |  |
|                                            | I <sub>DD,ha,m</sub>   | High accuracy preset<br>Nominal $V_{DD}$ supplies<br>$T_A$ =25°C, ODR=20Hz                    |     | 4.9   |      | mA     |  |  |
| Supply Current in<br>Suspend Mode          | I <sub>DDsm,m</sub>    | Nominal $V_{DD}/V_{DDIO}$ supplies, $T_A$ =25°C                                               |     | 1     |      | μΑ     |  |  |
| Peak supply current in Active Mode         | $I_{\mathrm{DDpk,m}}$  | In measurement phase Nominal $V_{DD}$ supplies $T_A$ =25°C                                    |     | 18    |      | mA     |  |  |

<sup>&</sup>lt;sup>1</sup> Theoretical heading accuracy of the 3-axis magnetometer alone, assuming ideal accelerometer and calibration with Bosch Sensortec eCompass software. Average value over various device orientations (typical device usage).

-

<sup>&</sup>lt;sup>2</sup> Heading accuracy of the tilt-compensated 6-axis eCompass system, assuming calibration with Bosch Sensortec eCompass software. Average value over various device orientations (typical device usage).

<sup>&</sup>lt;sup>3</sup> For details on magnetometer current consumption calculation refer to chapter 4.3.2 and 4.3.3.



Page 10 Confidential

| Peak logic supply<br>current in active<br>mode | $I_{\mathrm{DDIOpk,m}}$ | Only during<br>measurement phase<br>Nominal V <sub>DDIO</sub> supplies<br>T <sub>A</sub> =25°C | 210 |     | μΑ |
|------------------------------------------------|-------------------------|------------------------------------------------------------------------------------------------|-----|-----|----|
| POR time                                       | t <sub>w_up,m</sub>     | from OFF to suspend;<br>time starts when<br>VDD>1.5V and<br>VDDIO>1.1V                         |     | 1.0 | ms |
| Start-Up Time                                  | t <sub>s_up,m</sub>     | from suspend to sleep                                                                          | 3   |     | ms |

| MAGNETOMETER OUTPUT SIGNAL       |                          |                                                                                                                  |     |       |      |                                                      |  |
|----------------------------------|--------------------------|------------------------------------------------------------------------------------------------------------------|-----|-------|------|------------------------------------------------------|--|
| Parameter                        | Symbol                   | Condition                                                                                                        | Min | Тур   | Max  | Unit                                                 |  |
| Device Resolution                | $D_{\text{res},m}$       | $T_A=25$ °C (x,y,z)                                                                                              |     | 0.3   |      | μΤ                                                   |  |
| Sensitivity                      | S <sub>m</sub>           | After temperature<br>compensation<br>T <sub>A</sub> =25°C<br>Nominal V <sub>DD</sub> supplies                    |     | 1     |      | μT<br>sensor<br>output<br>per μT<br>applied<br>field |  |
| Sensitivity<br>Temperature Drift | TCS <sub>m</sub>         | After temperature compensation $-40^{\circ}\text{C} \le T_{A} \le +85^{\circ}\text{C}$ Nominal $V_{DD}$ supplies |     | ±0.01 |      | %/K                                                  |  |
| Zero-B offset                    | OFF <sub>m</sub>         | T <sub>A</sub> =25°C                                                                                             |     | ±10   |      | μΤ                                                   |  |
| ODR (data output                 | $odr_{lp}$               | Low power preset                                                                                                 |     | 10    |      | Hz                                                   |  |
| rate), normal mode               | $odr_{rg}$               | Regular preset                                                                                                   |     | 10    |      | Hz                                                   |  |
|                                  | odr <sub>eh</sub>        | Enhanced regular preset                                                                                          |     | 10    |      | Hz                                                   |  |
|                                  | odr <sub>ha</sub>        | High accuracy preset                                                                                             |     | 20    |      | Hz                                                   |  |
| ODR (data output                 | $odr_{lp}$               | Low power preset                                                                                                 | 0   |       | >300 | Hz                                                   |  |
| rate), forced mode               | $odr_{rg}$               | Regular preset                                                                                                   | 0   |       | 100  | Hz                                                   |  |
|                                  | $odr_{eh}$               | Enhanced regular preset                                                                                          | 0   |       | 60   | Hz                                                   |  |
|                                  | $odr_{ha}$               | High accuracy preset                                                                                             | 0   |       | 20   | Hz                                                   |  |
| Full-scale<br>Nonlinearity       | $NL_{m, FS}$             | best fit straight line                                                                                           |     |       | 1    | %FS                                                  |  |
| Output Noise                     | n <sub>rms,lp,m,xy</sub> | Low power preset x-, y-axis, $T_A$ =25°C Nominal $V_{DD}$ supplies                                               |     | 1.0   |      | μΤ                                                   |  |
|                                  | n <sub>rms,lp,m,z</sub>  | Low power preset<br>z-axis, T <sub>A</sub> =25°C<br>Nominal V <sub>DD</sub> supplies                             |     | 1.4   |      | μТ                                                   |  |
|                                  | $n_{\text{rms,rg,m}}$    | Regular preset<br>T <sub>A</sub> =25°C<br>Nominal V <sub>DD</sub> supplies                                       |     | 0.6   |      | μТ                                                   |  |



Page 11 Confidential

|                                | n <sub>rms,eh,m</sub> | Enhanced regular preset $T_A$ =25°C Nominal $V_{DD}$ supplies                    | 0.5  | μТ   |
|--------------------------------|-----------------------|----------------------------------------------------------------------------------|------|------|
|                                | n <sub>rms,ha,m</sub> | High accuracy preset<br>T <sub>A</sub> =25°C<br>Nominal V <sub>DD</sub> supplies | 0.3  | μТ   |
| Power Supply<br>Rejection Rate | PSRR <sub>m</sub>     | $T_A$ =25°C<br>Nominal V <sub>DD</sub> supplies                                  | ±0.5 | μT/V |

Page 12 Confidential

# 2. Absolute maximum ratings

The absolute maximum ratings provided in Table 4 apply to both the accelerometer and magnetometer part of BMC050.

Table 4: Absolute maximum ratings

| Parameter                             | Condition                    | Min  | Max            | Unit |
|---------------------------------------|------------------------------|------|----------------|------|
|                                       | $V_{DD}$ Pin                 | -0.3 | 4.0            | V    |
| Voltage at Supply Pin                 | V <sub>DDIO</sub> Pin        | -0.3 | 4.0            | V    |
| Voltage at any Logic Pad              | Non-Supply Pin               | -0.3 | VDDIO +<br>0.3 | V    |
| Operating Temperature, T <sub>A</sub> | Active operation             | -40  | +85            | °C   |
| Passive Storage Temp. Range           | ≤ 65% rel. H.                | -50  | +150           | °C   |
|                                       | Duration ≤ 200µs             |      | 10,000         | g    |
| Mechanical Shock                      | Duration ≤ 1.0ms             |      | 2,000          | g    |
| Weenanear Shock                       | Free fall onto hard surfaces |      | 1.8            | m    |
| ESD                                   | HBM, at any Pin              |      | 2              | kV   |
| LSD                                   | CDM                          |      | 500            | V    |
| Magnetic field                        | Any direction                |      | > 7            | T    |



# 3. Block diagram

Figure 1 shows the basic building blocks of the BMC050:



Figure 1: Block diagram of BMC050



Page 14 Confidential

## 4. Functional description

BMC050 is a SiP (system in package) integration of a triaxial accelerometer (Sensing element and ASIC) and a triaxial geomagnetic sensor (Sensing element and ASIC) in one package. The two ASICs act as two separate slave devices on the digital bus (with different I<sup>2</sup>C address in I<sup>2</sup>C mode, or separate CSB lines in SPI mode, respectively), which allows an almost independent operation of accelerometer and magnetometer parts in order to fit into a wide range of usage scenarios.

Note: Default values for registers can be found in chapters 5 and 6.

## 4.1 Power management

The BMC050 has two distinct power supply pins which supply both the acceleration sensor part and the magnetometer sensor part:

- V<sub>DD</sub> is the main power supply for all internal analog and digital functional blocks;
- V<sub>DDIO</sub> is a separate power supply pin, used for the supply of the digital interface as well as the magnetic sensor's logic.

There are no limitations on the voltage levels of both pins relative to each other, as long as each of them lies within its operating range. Furthermore, the device can be completely switched off  $(V_{DD} = 0V)$  while keeping the  $V_{DDIO}$  supply on  $(V_{DDIO} > 0V)$ . To switch off the interface supply  $(V_{DDIO} = 0V)$  and keep the internal supply on  $(V_{DD} > 0V)$  is safe only in normal mode of the accelerometer part (magnetic sensor will switch to off mode automatically). If the accelerometer part of the device is in low-power mode or suspend mode while  $V_{DDIO} = 0V$ , there is a risk of excess current consumption on the  $V_{DD}$  supply (non-destructive).

It is absolutely prohibited to keep any interface at a logical high level when  $V_{DDIO}$  is switched off. Such a configuration will permanently damage the device (i.e. if  $V_{DDIO} = 0 \rightarrow [SDI \& SDO \& SCK \& CSB1 \& CSB2] \neq high)$ .

The device contains a power on reset (POR) generator for each of the sensor parts, accelerometer part and magnetometer part. It resets the logic part and the register values of the concerned ASIC after powering-on  $V_{DD}$  and  $V_{DDIO}$ . There is no limitation on the sequence of switching on both supply voltages. In case the I<sup>2</sup>C interface is used, a direct electrical connection between  $V_{DDIO}$  supply and the PS pins (PS1 and PS2) is needed in order to ensure reliable protocol selection (see chapter 4.2).

#### 4.2 Protocol selection

The BMC050 acts as two separate slave devices (i.e. accelerometer part and magnetometer part), on a digital interface (SPI or  $I^2C$ ) which is controlled by the external bus master (e.g.  $\mu C$ ). The master obtains measurement data and status information from the device through the digital interface. In particular, the master can configure the interrupt controllers and read out the interrupt status registers. Moreover, it can freely configure and use the interrupt pins (INT1, INT2, INT3 and DRDY).

All pads are in input mode (no output driver active) during the start-up sequence until the interface type is selected. The start-up sequence is run after power-up and after reset.



Page 15 Confidential

Note: It is not possible to select mixed interfaces (I<sup>2</sup>C for accelerometer part and SPI for magnetometer part or vice versa), because the digital interface uses shared pins.

Figure 2 illustrates the protocol selection:



Figure 2: Protocol selection

## 4.3 Power modes

The BMC050 features separately configurable power modes for the accelerometer and the magnetometer part. The advantage is that different characteristics regarding optimum system power saving of the two sensor types are exploited, and that the accelerometer part may also be used alone in certain usage scenarios where no magnetic field data is required. In such an example, the magnetometer part is able to suspend and save power during the time in which it is not required.

In the following chapters, power modes for both accelerometer and magnetometer part are described.

#### 4.3.1 Accelerometer power modes

The BMC050 accelerometer part has four different power modes (see Figure 4). Besides normal mode, which represents the fully operational state of the device, there are two special energy saving modes: low-power mode and suspend mode.



Page 16 Confidential

The possible transitions between the power modes are illustrated in Figure 3:



Figure 3: Accelerometer power mode transition diagram

<u>Power off mode</u> is enabled when  $V_{DD}$  and/or  $V_{DDIO}$  are unpowered. In this state, the accelerometer does not operate. Power on reset is performed after both supply voltages have risen above their detection thresholds.

In **normal mode**, all parts of the electronic circuit are held powered-up and data acquisition is performed continuously.

In contrast to this, in **suspend mode** the whole analog part, oscillators included, is powered down. No data acquisition is performed, the only supported operations are reading registers (latest acceleration data are kept) and writing to the (0x11) suspend bit or (0x14) softreset register. Suspend mode is entered (left) by writing "1" ("0") to the (0x11) suspend bit.

In **low-power mode**, the device is periodically switching between a sleep phase and a wake-up phase. The wake-up phase essentially corresponds to operation in normal mode with complete power-up of the circuitry. During the sleep phase the analog part except the oscillators is powered down. Low-power mode is entered (left) by writing "1" ("0") to the *(0x11) lowpower\_en* bit.

During the wake-up phase the number of samples required by any enabled interrupt is processed. If an interrupt is detected, the device stays in the wake-up phase as long as the interrupt condition endures (non-latched interrupt), or until the latch time expires (temporary interrupt), or until the interrupt is reset (latched interrupt). If no interrupt is detected, the device enters the sleep phase.

Page 17 Confidential

The duration of the sleep phase is set by the (0x11) sleep\_dur bits as shown in the following table:

(0x11)Sleep Phase Duration sleep\_dur *t*<sub>sleepa</sub> 0000b 0.5ms 0001b 0.5ms 0.5ms 0010b 0011b 0.5ms 0100b 0.5ms 0101b 0.5ms 0110b 1ms 0111b 2ms 1000b 4ms 1001b 6ms 1010b 10<sub>ms</sub> 1011b 25ms 1100b 50<sub>ms</sub> 1101b 100ms 1110b 500ms 1111b 1s

Table 5: Sleep phase duration settings

The current consumption of the BMC050 accelerometer part can be calculated according to this formula:

$$I_{\mathrm{DDlp,a}} \approx \frac{t_{\mathrm{sleep,a}} \cdot I_{\mathrm{DDsm,a}} + t_{\mathrm{active,a}} \cdot I_{\mathrm{DD,a}}}{t_{\mathrm{sleep,a}} + t_{\mathrm{active,a}}} \, .$$

In this formula, the subfix "a" indicates that the current and time variables refer to the accelerometer part of BMC050, to distinguish from the magnetometer part.

When making an estimation about the length of the wake-up phase  $t_{active,a}$ , the wake-up time,  $t_{w\_up,a}$ , has to be considered. Therefore,  $t_{active,a} = t_{u,at} + t_{w\_up,a}$ , where  $t_{u,at}$  is given in Table 9. During the wake-up phase all analog modules are held powered-up, while during the sleep phase most analog modules are powered down. As a consequence, a wake-up time of less than 1ms (typ. value 0.8ms) is needed to settle the analog modules in order to get reliable acceleration data.

Table 6 gives an overview of the resulting average supply currents for the different sleep phase durations and a selected bandwidth of 1000Hz, assuming no interrupt is active and thus only one sample per wake-up phase is taken:



Page 18 Confidential

Table 6: Accelerometer part average current consumption in low-power mode

| Sleep phase duration | Average current consumption |
|----------------------|-----------------------------|
| 0.5ms                | 100.5 μΑ                    |
| 1ms                  | 78.8 µA                     |
| 2ms                  | 55.0 μΑ                     |
| 4ms                  | 34.5 μΑ                     |
| 6ms                  | 25.2 μΑ                     |
| 10ms                 | 16.4 μΑ                     |
| 25ms                 | 7.4 μΑ                      |
| 50ms                 | 4.0 μΑ                      |
| 100ms                | 2.3 μΑ                      |
| 500ms                | 0.9 μΑ                      |
| 1s                   | 0.7 μΑ                      |

## 4.3.2 Magnetometer power modes

The BMC050 magnetometer part has four power modes:

#### Power off mode

In Power off mode,  $V_{DD}$  and/or VDDIO are unpowered. The magnetometer part does not operate in this mode. When only one of  $V_{DD}$  or  $V_{DDIO}$  is supplied, the magnetic sensor will still be in Power off mode. Power on reset is performed after both  $V_{DD}$  and  $V_{DDIO}$  have risen above their detection thresholds.

#### Suspend mode

Suspend mode is the default power mode of BMC050 magnetometer part after the chip is powered. When VDD and VDDIO are turned on the POR (power on reset) circuits operate and the device's registers are initialized. After POR becomes inactive, a start up sequence is executed. In this sequence NVM content is downloaded to shadow registers located in the device core. After the start up sequence the device is put in the Suspend mode. In this mode only registers supplied directly by VDDIO which store I<sup>2</sup>C slave device address, power control bit information and some others can be accessed by the user. No other registers can be accessed in Suspend mode. All registers lose their content, except the control register (0x4B). In particular, in this mode a Chip ID read (register 0x40) returns "0x00h" (I<sup>2</sup>C) or high-Z (SPI).

## Sleep mode

The user puts device from suspend into Sleep mode by setting the Power bit to "1", or from active modes (normal or forced) by setting OpMode bits to "11". In this state the user has full access to the device registers. In particular, the Chip ID can be read. Setting the power control bit to "0" (register 0x4B bit0) will bring the device back into Suspend mode. From the Sleep mode the user can put the device back into Suspend mode or into Active mode.

Page 19 Confidential

#### **Active mode**

The device can switch into Active mode from Sleep mode by setting OpMode bits (register 0x4C). In active mode the magnetic field measurements are performed. In active mode, all registers are accessible.

In active mode, two operation modes can be distinguished:

- Normal mode: selected channels are periodically measured according to settings set in user registers. After measurements are completed, output data is put into data registers and the device waits for the next measurement period, which is set by programmed output data rate (ODR). From normal mode, the user can return to sleep mode by setting OpMode to "11" or by performing a soft reset (see chapter 6.6). Suspend mode can be entered by setting power control bit to "0".
- Forced mode (single measurement): When set by the host, the selected channels are measured according to settings programmed in user registers. After measurements are completed, output data is put into data registers, OpMode register value returns to "11" and the device returns to sleep mode. The forced mode is useful to achieve synchronized operation between host microcontroller and BMC050. Also, different data output rates from the ones selectable in normal mode can be achieved using forced mode.



Figure 4: Magnetometer power mode transition diagram

In Active Mode and normal operation, in principle any desired balance between output noise and active time (hence power consumption) can be adjusted by the repetition settings for x/y-axis and z-axis and the output data rate ODR. The average power consumption depends on the ratio of high current phase time (during data acquisition) and low current phase time (between data acquisitions). Hence, the more repetitions are acquired to generate one magnetic field data point, the longer the active time ratio in one sample phase, and the higher the average current. Thanks to longer internal averaging, the noise level of the output data reduces with increasing number of repetitions.



Page 20 Confidential

By using forced mode, it is possible to trigger new measurements at any rate. The user can therefore trigger measurements in a shorter interval than it takes for a measurement cycle to complete. If a measurement cycle is not allowed to complete, the resulting data will not be written into the data registers. To prevent this, the manually triggered measurement intervals must not be shorter than the active measurement time which is a function of the selected number of repetitions. The maximum selectable read-out frequency in forced mode can be calculated as follows:

$$f_{\text{max, ODR}} \approx \frac{1}{145\mu s \times nXY + 500\mu s \times nZ + 980\mu s}$$

Hereby nXY is the number of repetitions on X/Y-axis (not the register value) and nZ the number of repetitions on Z-axis (not the register value) (see description of XY\_REP and Z\_REP registers in chapter 6).

Although the repetition numbers for X/Y and Z axis and the ODR can be adjusted independently and in a wide range, there are four recommended presets (High accuracy preset, Enhanced regular preset, Regular preset, Low power preset) which reflect the most common usage scenarios, i.e. required output accuracy at a given current consumption, of the BMC050 magnetometer part.

The three presets consist of the below register configurations, which are automatically set by the BMC050 API or driver provided by Bosch Sensortec when a preset is selected. Table 7 shows the recommended presets and the resulting magnetic field output noise and magnetometer part current consumption:

Table 7: Magnetometer presets in Active operation and normal mode:

| Preset                  | X/Y rep | Z rep | ODR   | ODR <sub>max</sub><br>(forced<br>mode) | RMS<br>Noise<br>x/y/z | Average current consumption |
|-------------------------|---------|-------|-------|----------------------------------------|-----------------------|-----------------------------|
| Low power preset        | 3       | 3     | 10 Hz | >300 Hz                                | 1.0/1.0/1.4<br>μT     | 170 μΑ                      |
| Regular preset          | 9       | 15    | 10 Hz | 100 Hz                                 | 0.6/0.6/0.6<br>μT     | 0.5 mA                      |
| Enhanced regular preset | 15      | 27    | 10 Hz | 60 Hz                                  | 0.5/0.5/0.5<br>μT     | 0.8 mA                      |
| High accuracy preset    | 47      | 83    | 20 Hz | 20 Hz                                  | 0.3/0.3/0.3<br>μT     | 4.9 mA                      |



Page 21 Confidential

## 4.3.3 BMC050 overall power consumption

Below, Table 8 shows the overall current consumption of BMC050 (sum of accelerometer and magnetometer part) in typical scenarios such as a tilt-compensated electronic compass application.

Table 8: BMC050 overall current consumption in typical usage scenarios:

| Compass preset          | Acc. Active / sleep interval | Mag.<br>DOR | Acc. BW<br>/ DOR | Mag. avg.<br>current | Acc. avg. current | Total<br>average<br>current |
|-------------------------|------------------------------|-------------|------------------|----------------------|-------------------|-----------------------------|
| Low power preset        | 8 / 50 ms                    | 10 Hz       | 62.5 / 17<br>Hz  | 170 μΑ               | 20 μΑ             | 190 μΑ                      |
| Regular preset          | 16 / 50 ms                   | 10 Hz       | 31 / 15<br>Hz    | 0.5 mA               | 35 μΑ             | 0.54 mA                     |
| Enhanced regular preset | 16 / 50 ms                   | 10 Hz       | 31 / 15<br>Hz    | 0.8 mA               | 35 μΑ             | 0.84 mA                     |
| High accuracy preset    | 16 /25 ms                    | 20 Hz       | 31 / 24<br>Hz    | 4.9 mA               | 55 μΑ             | 5.0 mA                      |

#### 4.4 Sensor data

#### 4.4.1 Acceleration data

The width of acceleration data is 10 bits given in two's complement representation. The 10 bits for each axis are split into an MSB upper part (one byte containing bits 9 to 2) and an LSB lower part (one byte containing bits 1 and 0 of acceleration and a (0x02, 0x04, 0x06) new\_data flag). Reading the acceleration data registers shall always start with the LSB part. The content of an MSB register is updated by reading the corresponding LSB register (shadowing procedure). The shadowing procedure can be disabled (enabled) by writing "1" ("0") to the bit shadow\_dis. With disabled shadowing, the content of both MSB and LSB registers is updated by a new value immediately. Unused bits of the LSB registers are fixed to 0. The (0x02, 0x04, 0x06) new\_data flag of each LSB register is set if the data registers are updated, it is reset if either the corresponding MSB or LSB part is read.

Two different streams of acceleration data are available, unfiltered and filtered. The unfiltered data is sampled with 2kHz. The sampling rate of the filtered data depends on the selected filter bandwidth; it is twice the bandwidth. Which kind of data is stored in the acceleration data registers depends on bit (0x13)  $data_high_bw$ . If (0x13)  $data_high_bw$  is "0" ("1"), then filtered (unfiltered) data is stored in the registers. Both data streams are separately offset-compensated. Both kinds of data can be processed by the interrupt controller.



Page 22 Confidential

The bandwidth of filtered acceleration data is determined by setting the (0x10) bw bit as follows:

Table 9: Bandwidth configuration

| bw    | Bandwidth | Update Time t <sub>ut</sub> |
|-------|-----------|-----------------------------|
| 00xxx | *)        | -                           |
| 01000 | 7.81Hz    | 64ms                        |
| 01001 | 15.63Hz   | 32ms                        |
| 01010 | 31.25Hz   | 16ms                        |
| 01011 | 62.5Hz    | 8ms                         |
| 01100 | 125Hz     | 4ms                         |
| 01101 | 250Hz     | 2ms                         |
| 01110 | 500Hz     | 1ms                         |
| 01111 | 1000Hz    | 0.5ms                       |
| 1xxxx | *)        | -                           |

<sup>\*)</sup> Note: Settings 00xxx result in a bandwidth of 7.81 Hz; settings 1xxxx result in a bandwidth of 1000 Hz. It is recommended to actively use the range from "01000b" to "01111b" only in order to be compatible with future products.



Page 23 Confidential

The BMC050's accelerometer part supports four different acceleration measurement ranges. A measurement range is selected by setting the (0x0F) range bits as follows:

Table 10: Range selection

| Range  | Acceleration measurement range | Resolution  |
|--------|--------------------------------|-------------|
| 0011   | ±2g                            | 3.91mg/LSB  |
| 0101   | ±4g                            | 7.81mg/LSB  |
| 1000   | ±8g                            | 15.62mg/LSB |
| 1100   | ±16g                           | 31.25mg/LSB |
| others | reserved                       | -           |

## 4.4.2 Temperature data

The width of temperature data is 8 bits given in two's complement representation. Temperature values are available in the (0x08) temp register.

The slope of the temperature sensor is 0.5 K/LSB, its center temperature is  $24^{\circ}\text{C}$  [(0x08) temp = 0x00]. Therefore, the typical temperature measurement range is -40°C up to 87.5°C.

## 4.4.3 Magnetic field data

The representation of magnetic field data is different between X/Y-axis and Z-axis. The width of X- and Y-axis magnetic field data is 13 bits each and stored in two's complement. DATAX\_LSB (0x42) contains 5-bit LSB part [4:0] of the 13 bit output data of the X-channel. DATAX\_MSB (0x43) contains 8-bit MSB part [12:5] of the 13 bit output data of the Y-channel. DATAY\_LSB (0x44) contains 5-bit LSB part [4:0] of the 13 bit output data of the Y-channel. DATAY\_MSB (0x45) contains 8-bit MSB part [12:5] of the 13 bit output data of the Y-channel.

The width of the Z-axis magnetic field data is 15 bit word stored in two's complement. DATAZ\_LSB (0x46) contains 7-bit LSB part [6:0] of the 15 bit output data of the Z-channel. DATAZ\_MSB (0x47) contains 8-bit MSB part [14:7] of the 15 bit output data of the Z-channel.

For all axes, temperature compensation on the host is used to get ideally matching sensitivity over the full temperature range. The temperature compensation is based on a resistance measurement of the hall sensor plate. The resistance value is represented by a 14 bit unsigned output word.

RHALL\_LSB (0x48) contains 6-bit LSB part [5:0] of the 14 bit output data of the RHALL-channel

RHALL\_MSB (0x49) contains 8-bit MSB part [13:6] of the 14 bit output data of the RHALL-channel.

All signed register values are in two's complement representation. Bits which are marked "reserved" can have different values or can in some cases not be read at all (read will return 0x00 in I<sup>2</sup>C mode and high-Z in SPI mode).

Data register readout and shadowing is implemented as follows:

After all enabled axes have been measured, complete data packages consisting of DATAX, DATAY, DATAZ and RHALL are updated at once in the data registers. This way, it is prevented



Page 24 Confidential

that a following axis is updated while the first axis is still being read (axis mix-up) or that MSB part of an axis is updated while LSB part is being read.

While reading from any data register, data register update is blocked. Instead, incoming new data is written into shadow registers which will be written to data registers after the previous read sequence is completed (i.e. upon stop condition in I<sup>2</sup>C mode, or CSB going high in SPI mode, respectively). Hence, it is recommended to read out at all data at once (0x42 to 0x49 or 0x4A if status bits are also required) with a burst read.

Single bytes or axes can be read out, while in this case it is not assured that adjacent registers are not updated during readout sequence.

The "Data ready status" bit (register 0x48 bit0) is set "1" when the data registers have been updated but the data was not yet read out over digital interface. Data ready is cleared (set "0") directly after completed read out of any of the data registers and subsequent stop condition (I<sup>2</sup>C) or lifting of CSB (SPI).

In addition, when enabled the "Data overrun" bit (register 0x4A bit7) turns "1" whenever data registers are updated internally, but the old data was not yet read out over digital interface (i.e. data ready bit was still high). The "Data overrun" bit is cleared when the interrupt status register 0x4A is read out. This function needs to be enabled separately by setting the "Data overrun En" bit (register 0x4D bit7)).

Note: Please also see chapter 6 for detailed register descriptions.

Page 25 Confidential

## 4.4.4 Magnetic field data temperature compensation

The raw register values DATAX, DATAY, DATAZ and RHALL are read out from the host processor using the BMC050 API/driver which is provided by Bosch Sensortec. The API/driver performs an off-chip temperature compensation and outputs x/y/z magnetic field data in 16 LSB/ $\mu$ T to the upper application layer:



Figure 5: Calculation flow of magnetic field data from raw BMC050 register data

The API/driver performs all calculations using highly optimized fixed-point C-code arithmetic. For platforms that do not support C code, a floating-point formula is available as well.



Page 26 Confidential

#### 4.5 Self-test

#### 4.5.1 Accelerometer self-test

This feature permits to check the BMC050's accelerometer part functionality 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.

The self-test is activated individually for each axis by writing the proper value to the (0x32) self\_test\_axis bits ("01b" for x-axis, "10b" for y-axis, "11b" for z-axis, "00b" to deactivate self-test). It is possible to control the direction of the deflection through bit (0x32) self\_test\_sign. The excitation occurs in positive (negative) direction if (0x32) self\_test\_sign = "0" ("1").

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. Table 11 shows the minimum differences for each axis. The actually measured signal differences can be significantly larger.

Table 11: Self-test difference values

|                                           | x-axis signal | y-axis signal | z-axis signal |
|-------------------------------------------|---------------|---------------|---------------|
| resulting<br>minimum<br>difference signal | +0.8 g        | +0.8 g        | +0.4 g        |

It is recommended to perform a reset of the device after self-test. 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 600  $\mu$ s, enable desired interrupts.

#### 4.5.2 Magnetometer self-test

BMC050 supports two self-tests modes for the magnetometer part: Normal self-test and advanced self-test.

#### Normal self test

During normal self-test, the following verifications are performed:

- FlipCore signal path is verified by generating signals on-chip. These are processed through the signal path and the measurement result is compared to known thresholds.
- FlipCore (X and Y) bondwires to ASIC are checked for connectivity
- FlipCore (X and Y) bondwires and MEMS are checked for shorts
- Hall sensor connectivity is checked for open and shorted connections
- Hall sensor signal path and hall sensor element offset are checked for overflow.

To perform a self test, the sensor must first be put into sleep mode (OpMode = "11"). Self-test mode is then entered by setting the bit "Self test" (register 0x4C bit0) to "1". After performing self



Page 27 Confidential

test, this bit is set back to "0". When self-test is successful, the corresponding self-test result bits are set to "1" ("X-Self-Test" register 0x42 bit0, "Y-Self-Test" register 0x44 bit0, "Z-Self-Test" register 0x46 bit0). If self-test fails for an axis, the corresponding result bit returns "0".

#### Advanced self test

Advanced self test performs a verification of the Z channel signal path functionality and sensitivity. An on-chip coil wound around the hall sensor can be driven in both directions with a calibrated current to generate a positive or negative field of around  $100~\mu T$ .

Advanced self test is an option that is active in parallel to the other operation modes. The only difference is that during the active measurement phase, the coil current is enabled. The recommended usage of advanced self test is the following:

- Set sleep mode
- 2. Disable X, Y axis
- 3. Set Z repetitions to desired level
- 4. Enable positive advanced self test current
- 5. Set forced mode, readout Z and R channel after measurement is finished
- 6. Enable negative advanced self test current
- 7. Set forced mode, readout Z and R channel after measurement is finished
- 8. Disable advanced self test current (this must be done manually)
- 9. Calculate difference between the two compensated field values. This difference should be around 200  $\mu T$  with some margins.
- 10. Perform a soft reset of manually restore desired settings

Please refer to the corresponding application note for the exact thresholds to evaluate advanced self-test.

Below table describes how the advanced self-test is controlled:

Table 12: Magnetometer advanced self-test control

| (0x4C)<br>Adv.ST <1:0> | Configuration                              |
|------------------------|--------------------------------------------|
| 00b                    | Normal operation (no self-test), default   |
| 01b                    | Reserved, do not use                       |
| 10b                    | Negative on-chip magnetic field generation |
| 11b                    | Positive on-chip magnetic field generation |

The BMC050 API/driver provided by Bosch Sensortec provides a comfortable way to perform both self-tests and to directly obtain the result without further calculations. It is recommended to use this as a reference.

Page 28 Confidential

## 4.6 Accelerometer offset compensation

Offsets in measured acceleration signals can have several causes but they are always unwanted and disturbing in many cases. Therefore, the BMC050 offers an advanced set of four digital offset compensation methods which are closely matched to each other. These are slow, fast, and manual compensation, and inline calibration.

The compensation is performed for unfiltered and filtered acceleration data independently. It is done by adding a compensation value to the acceleration data coming from the ADC. The result of this computation is saturated if necessary to prevent any overflow errors (the smallest or biggest possible value is set, depending on the sign). However, the public registers used to read and write compensation values have only a width of 8 bits.

An overview of the offset compensation principle is given in Figure 6:



Figure 6: Principle of offset compensation

The meaning of both public and internal registers is the same for all acceleration measurement ranges. Therefore, with measurement ranges other than ±2g, one or more lower significant bits of the internal registers are lost when added to an acceleration value, or are set to zero when the internal compensation value is computed. If a compensation value is too small or too big to fit into the corresponding internal register, it is saturated to prevent an overflow error.

In a similar way the conversion of the internal register value to the public register value (10bit to 8bit) uses saturation.



Page 29 Confidential

Summarized, in dependence to the measurement range which has been set, the compensation value, which has been written into the public register will correct the data output according to Figure 6.

## e.g. ±2g range:

```
public register = 00000001b \rightarrow add to acceleration data = \pm 7.8mg = \pm 2LSB public register = 00000010b \rightarrow add to acceleration data = \pm 15.6mg = \pm 4LSB public register = 00000101b \rightarrow add to acceleration data = \pm 39.1mg = \pm 10LSB
```

The public registers are image registers of EEPROM registers. With each image update (see chapter 4.7 for details) the contents of the non-volatile EEPROM registers are written to the public registers. At any time the public register can be over-written by the user. After changing the contents of the public registers by either an image update or manually, all 8bit values are widened to 10bit values and stored in the corresponding internal registers. In the opposite direction, if the value of an internal register changes due to the computation performed by a compensation algorithm, it is converted to an 8bit value and stored in the public register. For slow and fast offset compensation, the compensation target can be chosen by setting the bits (0x37) offset\_target\_x, (0x37) offset\_target\_y, and (0x37) offset\_target\_z according to Table 13:

 (0x37)
 Target value

 00b
 0g

 01b
 +1g

 10b
 -1g

 11b
 0g

Table 13: Offset target settings

By writing "1" to the (0x36) offset reset bit, all offset compensation registers are reset to zero.

#### 4.6.1 Slow compensation

Slow compensation is a quasi-continuous process which regulates the acceleration value of each axis towards the target value by comparing the current value with the target and adding or subtracting a fixed value depending on the comparison.

The algorithm in detail: If an acceleration value is larger (smaller) than the target value (0x37) offset\_target\_x/y/z for a number of samples (given by the parameter Offset Period, see Table 14), the internal offset compensation value (0x38, 0x39, 0x3A) offset\_filt\_x/y/z or (0x3B, 0x03C, 0x3D) offset\_unfilt\_x/y/z is decremented (incremented) by 4 LSB.

The public registers (0x38, 0x39, 0x3A) offset\_filt\_x/y/z and (0x3B, 0x03C, 0x3D) offset\_unfilt\_x/y/z are not used for the computations but they are updated with the contents of the internal registers (using saturation if necessary) and can be read by the user.



Page 30 Confidential

The compensation period offset\_period is set by the (0x37) cut\_off bit as represented in Table 14:

Table 14: Compensation period settings

| (0x37)<br>cut_off | Offset<br>Period |
|-------------------|------------------|
| 0b                | 8                |
| 1b                | 16               |

The slow compensation can be enabled (disabled) for each axis independently by setting the bits  $(0x36) hp_xen, hp_yen, hp_zen$  to "1" ("0"), respectively.

Slow compensation should not be used in combination with low-power mode. In low-power mode the conditions (availability of necessary data) for proper function of slow compensation are not fulfilled.

## 4.6.2 Fast compensation

Fast compensation is a one-shot process by which the compensation value is set in such a way that when added to the raw acceleration, the resulting acceleration value of each axis equals the target value.

The algorithm in detail: An average of 16 consecutive acceleration values is computed and the difference between target value and computed value is written to (0x38, 0x39, 0x3A) offset\_filt\_x/y/z or (0x3B, 0x3C, 0x3D) offset\_unfilt\_x/y/z The public registers (0x38, 0x39, 0x3A) offset\_filt\_x/y/z and (0x3B, 0x3C, 0x3D) offset\_unfilt\_x/y/z are updated with the contents of the internal registers (using saturation if necessary) and can be read by the user.

Fast compensation is triggered for each axis individually by setting the (0x36) cal\_trigger bits as shown in Table 15:

Table 15: Fast compensation axis selection

| (0x36)<br>cal_trigger | Selected Axis |
|-----------------------|---------------|
| 00b                   | none          |
| 01b                   | X             |
| 10b                   | у             |
| 11b                   | Z             |

The register (0x36) cal\_trigger keeps its non-zero value while the fast compensation procedure is running. Slow compensation is blocked as long as fast compensation endures. Bit (0x36) cal\_rdy is "0" when (0x36) cal\_trigger is not "00".

Fast compensation should not be used in combination with low-power mode. In low-power mode the conditions (availability of necessary data) for proper function of fast compensation are not fulfilled.



Page 31 Confidential

## 4.6.3 Manual compensation

As explained above, the contents of the public compensation registers (0x38, 0x39, 0x3A) offset\_filt\_x/y/z and (0x3B, 0x3C, 0x3D) offset\_unfilt\_x/y/z can be set manually via the digital interface. It is recommended to write into these registers immediately after a new data interrupt in order not to disturb running offset computations.

Writing to the offset compensation registers is not allowed if slow compensation is enabled or if the fast compensation procedure is running.

#### 4.6.4 Inline calibration

For a given application, it is often desirable to calibrate the offset once and to store the compensation values permanently. This can be achieved by using one of the aforementioned offset compensation methods to determine the proper compensation values and then storing these values permanently in the non-volatile memory (EEPROM). See chapter 4.7 for details of the storing procedure.

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 until they are possibly overwritten using one of the other compensation methods.



Page 32 Confidential

## 4.7 Non-volatile memory

## 4.7.1 Accelerometer non-volatile memory

The memory of the accelerometer part of BMC050 consists of three different kinds of registers: hard-wired, volatile, and non-volatile. Non-volatile memory is implemented as EEPROM. Part of it can be both read and written by the user. Access to non-volatile memory is only possible through (volatile) image registers.

Altogether, there are eight registers (bytes) of EEPROM which are accessible by the customer. The address range of the image registers range from 0x38 to 0x3F. While the addresses up to 0x3D are used for offset compensation (see 4.6 Offset Compensation), addresses 0x3E and 0x3F are general purpose registers not linked to any sensor-specific functionality.

The content of the EEPROM is loaded to the image registers after a reset (either POR or softreset) or after a user request which is performed by writing "1" to bit (0x33) nvm\_load. As long as the image update is not yet complete, bit (0x33) nvm\_load is "1", otherwise it is "0".

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

Writing to the EEPROM is a three-step procedure:

- 1. Write the new contents to the image registers.
- 2. Write "1" to bit (0x33) nvm prog mode in order to unlock the EEPROM.
- 3. Write "1" to bit (0x33) nvm\_prog\_trig and keep "1" in bit (0x33) nvm\_prog\_mode in order to trigger the write process.

Writing to the EEPROM always renews the entire EEPROM contents. It is possible to check the write status by reading bit (0x33)  $nvm_rdy$ . While (0x33)  $nvm_rdy$  = "0", the write process is still enduring; if (0x33)  $nvm_rdy$  = "1", then writing is completed. As long as the write process is ongoing, no power mode change and no image update is allowed. It is forbidden to write to the EEPROM while the image update is running, in low-power mode, and in suspend mode.

## 4.7.2 Magnetometer non-volatile memory

Some of the memory of the BMC050 magnetometer is non-volatile memory (NVM). This NVM is pre-programmed in Bosch Sensortec fabrication line and can not be modified afterwards. It contains trimming data which are required for sensor operation and sensor data compensation, thus it is read out by the BMC050 API/driver during initialization.



Page 33 Confidential

## 4.8 Accelerometer interrupt controller

Seven accelerometer based interrupt engines are integrated in the accelerometer part of BMC050. Each interrupt can be independently enabled and configured. If the condition of an enabled interrupt is fulfilled, the corresponding status bit is set to "1" and the selected interrupt pin is activated. There are two interrupt pins for the accelerometer part, INT1 and INT2; interrupts can be freely mapped to any of these pins. The pin state is a logic 'or' combination of all mapped interrupts.

The interrupt status registers are updated together with writing new data into the acceleration data registers. If an interrupt is disabled, all active status bits and pins are immediately reset. All time constants are based upon the typical frequency of the internal oscillator. This is reflected by the bandwidths (*bw*) as specified in Table 9.

#### 4.8.1 General features

An interrupt is cleared depending on the selected interrupt mode, which is common to all interrupts. There are three different interrupt modes for the accelerometer part: non-latched, latched, and temporary. The mode is selected by the (0x21) latch\_int bits according to Table 16.

Table 16: Accelerometer interrupt mode selection

| (0x21)<br>latch_int | Interrupt mode    |
|---------------------|-------------------|
| 0000b               | non-latched       |
| 0001b               | temporary, 250ms  |
| 0010b               | temporary, 500ms  |
| 0011b               | temporary, 1s     |
| 0100b               | temporary, 2s     |
| 0101b               | temporary, 4s     |
| 0110b               | temporary, 8s     |
| 0111b               | latched           |
| 1000b               | non-latched       |
| 1001b               | temporary, 500µs  |
| 1010b               | temporary, 500µs  |
| 1011b               | temporary, 1ms    |
| 1100b               | temporary, 12.5ms |
| 1101b               | temporary, 25ms   |
| 1110b               | temporary, 50ms   |
| 1111b               | latched           |

An interrupt is generated if its activation condition is met. It can not be cleared as long as the activation condition is fulfilled. In the non-latched mode the interrupt status bit and the selected pin (the contribution to the 'or' condition for INT1 and/or INT2) are cleared as soon as the activation condition is no more valid. Exceptions to this behaviour are the new data, orientation, and flat interrupts, which are automatically reset after a fixed time.



Page 34 Confidential

In the latched mode an asserted interrupt status and the selected pin are cleared by writing "1" to bit (0x21) reset\_int. If the activation condition still holds when it is cleared, the interrupt status is asserted again with the next change of the acceleration registers.

In the temporary mode an asserted interrupt and selected pin are cleared after a defined period of time. The behaviour of the different interrupt modes is shown graphically in Figure 7:



Figure 7: Interrupt modes

Several interrupt engines can use either unfiltered or filtered acceleration data as their input. For these interrupts, the source can be selected with the respective (0x1E)  $int\_src\_...$  bits, in details these are (0x1E)  $int\_src\_data$ , (0x1E)  $int\_src\_tap$ , (0x1E)  $int\_src\_slope$ , (0x1E)  $int\_src\_low$ . Setting the respective bits to "0" ("1") selects filtered (unfiltered) data as input. For the other interrupts, orientation recognition and flat detection, such a selection is not possible. They always use filtered input data.

It is strongly recommended to set interrupt parameters prior to enabling the interrupt. Changing parameters of an already enabled interrupt may cause unwanted interrupt generation and generation of a false interrupt history. A safe way to change parameters of an enabled interrupt is to keep the following sequence: disable the desired interrupt, change parameters, wait for at least 600 µs, enable the desired interrupt.

## 4.8.2 Mapping (inttype to INT Pin#)

The mapping of interrupts to the interrupt pins #05 or #06 is done by registers (0x19) to (0x1B). Setting (0x19) int1\_"inttyp" to "1" ("0") maps (unmaps) "inttyp" to pin #5 (INT1), correspondingly setting (0x1B) int2\_"inttyp" to "1" ("0") maps (unmaps) "inttyp" to pin #6 (INT2).

Note: "inttyp" to be replaced with the precise notation, given in the memory map in chapter 5.

Example: For flat interrupt (int1\_flat): Setting (0x19) int1\_flat to "1" maps int1\_flat to pin #5 (INT1).

## 4.8.3 Electrical behavior (INT pin# to open-drive or push-pull)

Both interrupt pins can be configured to show desired electrical behaviour. The 'active' level of each pin is determined by the (0x20) int1\_lvl and (0x20) int2\_lvl bits.

Page 35 Confidential

If (0x20)  $int1_lvl = "1"$  ("0") / (0x20)  $int2_lvl = "1"$  ("0"), then pin #05 (INT1) / pin #06 (INT2) is active "1" ("0"). In addition to that, also the electric type of the interrupt pins can be selected. By setting bits (0x20)  $int1_od$  / (0x20)  $int2_od$  to "0", the interrupt pin output type becomes open-drive, by setting the configuration bits to "1", the output type becomes push-pull.

Remark: The states of both INT pins are not defined during the first 2 ms after power-up.

## 4.8.4 New data interrupt

This interrupt serves for synchronous reading of acceleration data. It is generated after storing a new value of z-axis acceleration data in the data register. The interrupt is cleared automatically when the next cycle of data acquisition starts. The interrupt status is "0" for at least 50µs.

The interrupt mode of the new data interrupt is fixed to non-latched.

It is enabled (disabled) by writing "1" ("0") to bit (0x17) data\_en. The interrupt status is stored in bit (0x0A) data\_int.

## 4.8.5 Any-motion (slope) detection

Any-motion detection uses the slope between successive acceleration signals to detect changes in motion. An interrupt is generated when the slope (absolute value of acceleration difference) exceeds a preset threshold. It is cleared as soon as the slope falls below the threshold. The principle is clarified in Figure 8.



Figure 8: Principle of any-motion detection



Page 36 Confidential

The threshold is set with the value of register (0x28) slope\_th. 1 LSB of (0x28) slope\_th corresponds to 1 LSB of acceleration data. Therefore, an increment of (0x28) slope\_th is 3.91 mg in 2g-range (7.81 mg in 4g-range, 15.6 mg in 8g-range and 31.3 mg in 16g-range). And the maximum value is 996 mg in 2g-range (1.99g in 4g-range, 3.98g in 8g-range and 7.97g in 16g-range).

The time difference between the successive acceleration signals depends on the selected bandwidth and equates to 1/(2\*bandwidth) ( $\Delta t = 1/(2*bw)$ ). In order to suppress failure signals, the interrupt is only generated (cleared) if a certain number N of consecutive slope data points is larger (smaller) than the slope threshold given by (0x28)  $slope_th$ . This number is set by the (0x27)  $slope_dur$  bits. It is N = (0x27)  $slope_dur + 1$  for (0x27).

Example: (0x27) slope\_dur = 00b, ..., 11b = 1decimal, ..., 4decimal

## 4.8.5.1 Enabling (disabling) for each axis

Any-motion detection can be enabled (disabled) for each axis separately by writing "1" ("0") to bits (0x16)  $slope\_en\_x$ , (0x16)  $slope\_en\_y$ , (0x16)  $slope\_en\_z$ . The criteria for any-motion detection are fulfilled and the slope interrupt is generated if the slope of any of the enabled axes exceeds the threshold (0x28)  $slope\_th$  for [(0x27)  $slope\_dur$  +1] consecutive times. As soon as the slopes of all enabled axes fall or stay below this threshold for [(0x27)  $slope\_dur$  +1] consecutive times the interrupt is cleared unless interrupt signal is latched.

## 4.8.5.2 Axis and sign information of any motion interrupt

The interrupt status is stored in bit (0x09)  $slope_int$ . The any-motion interrupt supplies additional information about the detected slope. The axis which triggered the interrupt is given by that one of bits (0x0B)  $slope_first_x$ , (0x0B)  $slope_first_y$ , (0x0B)  $slope_first_z$  that contains a "1". The sign of the triggering slope is held in bit (0x0B)  $slope_sign$ . If (0x0B)  $slope_sign =$  "0" ("1"), the sign is positive (negative).

## 4.8.5.3 Serial interface and dedicated wake-up mode

When serial interface is active, any-motion detection logic is enabled if any of the axis specific (0x16) slope\_en\_... register bits are set. To disable the any-motion interrupt, clear all the axis specific (0x16) slope en ... bits.

## 4.8.6 Tap sensing

Tap sensing has a functional similarity with a common laptop touch-pad or clicking keys of a computer mouse. A tap event is detected if a pre-defined slope of the acceleration of at least one axis is exceeded. Two different tap events are distinguished: A 'single tap' is a single event within a certain time, followed by a certain quiet time. A 'double tap' consists of a first such event followed by a second event within a defined time frame.

Only one of the tap interrupts can be enabled at the same time. Single tap interrupt is enabled (disabled) by writing "1" ("0") to bit (0x16)  $s_tap_en$ . Double tap interrupt is enabled (disabled) by writing "1" ("0") to bit (0x16)  $d_tap_en$ . If one tries to enable both interrupts by writing "1" to (0x16)  $s_tap_en$  and (0x16)  $d_tap_en$ , then only (0x16)  $d_tap_en$  keeps the value "1" and the double tap interrupt is enabled.

The status of the single tap interrupt is stored in bit (0x09)  $s_tap_int$ , the status of the double tap interrupt is stored in bit (0x09)  $d_tap_int$ .



Page 37 Confidential

The slope threshold for detecting a tap event is set by bits (0x2B) tap\_th. The meaning of (0x2B) tap\_th depends on the range setting. 1 LSB of (0x2B) tap\_th corresponds to a slope of 62.5mg in 2g-range, 125mg in 4g-range, 250mg in 8g-range, and 500mg in 16g-range.

In Figure 9 the meaning of the different timing parameters is visualized:



Figure 9: Timing of tap detection

The parameters (0x2A)  $tap\_shock$  and (0x2A)  $tap\_quiet$  apply to both single tap and double tap detection, while (0x2A)  $tap\_dur$  applies to double tap detection only. Within the duration of (0x2A)  $tap\_shock$  any slope exceeding (0x2B)  $tap\_th$  after the first event is ignored. Contrary to this, within the duration of (0x2A)  $tap\_quiet$  no slope exceeding (0x2B)  $tap\_th$  must occur, otherwise the first event will be cancelled.

#### 4.8.6.1 Single tap detection

A single tap is detected and the single tap interrupt is generated after the combined durations of (0x2A)  $tap\_shock$  and (0x2A)  $tap\_quiet$ , if the corresponding slope conditions are fulfilled. The interrupt is cleared after a delay of 12.5 ms.



Page 38 Confidential

#### 4.8.6.2 Double tap detection

A double tap is detected and the double tap interrupt is generated if an event fulfilling the conditions for a single tap occurs within the set duration in (0x2A)  $tap_dur$  after the completion of the first tap event. The interrupt is cleared after a delay of 12.5 ms.

#### 4.8.6.3 Selecting the timing of tap detection

For each of parameters (0x2A)  $tap\_shock$  and (0x2A)  $tap\_quiet$  two values are selectable. By writing "0" ("1") to bit (0x2A)  $tap\_shock$  the duration of (0x2A)  $tap\_shock$  is set to 50 ms (75 ms). By writing "0" ("1") to bit (0x2A)  $tap\_quiet$  the duration of (0x2A)  $tap\_quiet$  is set to 30 ms (20 ms).

The length of (0x2A)  $tap\_dur$  can be selected by setting the (0x2A)  $tap\_dur$  bits according to Table 17:

| (0x2A)<br>tap_dur | length of tap_dur |
|-------------------|-------------------|
| 000b              | 50 ms             |
| 001b              | 100 ms            |
| 010b              | 150 ms            |
| 011b              | 200 ms            |
| 100b              | 250 ms            |
| 101b              | 375 ms            |
| 110b              | 500 ms            |
| 111b              | 700 ms            |

Table 17: Selection of tap\_dur

#### 4.8.6.4 Axis and sign information of tap sensing

The sign of the slope of the first tap which triggered the interrupt is stored in bit (0x0B) tap\_sign ("0" means positive sign, "1" means negative sign). The value of this bit persists after clearing the interrupt.

The axis which triggered the interrupt is indicated by bits (0x0B)  $tap_first_x$ , (0x0B)  $tap_first_y$ , and (0x0B)  $tap_first_z$ .

The bit corresponding to the triggering axis contains a "1" while the other bits hold a "0". These bits are cleared together with clearing the interrupt status.

Page 39 Confidential

#### 4.8.6.5 Tap sensing in low power mode

In low-power mode, a limited number of samples is processed after wake-up to decide whether an interrupt condition is fulfilled. The number of samples is selected by bits (0x2B) tap\_samp according to Table 18.

| (0x2B)<br>tap_samp | Number of<br>Samples |
|--------------------|----------------------|
| 00b                | 2                    |
| 01b                | 4                    |

8

16

10b

11b

Table 18: Meaning of (0x2B) tap\_samp

#### 4.8.7 Orientation recognition

The orientation recognition feature informs on an orientation change of the sensor with respect to the gravitational field vector 'g'. The measured acceleration vector components with respect to the gravitational field are defined as shown in Figure 10.



Figure 10: Definition of vector components

Therefore, the magnitudes of the acceleration vectors are calculated as follows:

$$acc_x = 1g \cdot sin\theta \cdot cos\varphi$$
  
 $acc_y = -1g \cdot sin\theta \cdot sin\varphi$   
 $acc_z = 1g \cdot cos\theta$   
 $\rightarrow acc_y/acc_x = -tan\varphi$ 

Depending on the magnitudes of the acceleration vectors the orientation of the device in the space is determined and stored in the three (0x0C) orient bits. These bits may not be reset in the sleep phase of low-power mode. There are three orientation calculation modes with different thresholds for switching between different orientations: symmetrical, high-asymmetrical, and low-asymmetrical. The mode is selected by setting the (0x2C) orient\_mode bits as given in Table 19.

Page 40 Confidential

Table 19: Orientation mode settings

| (0x2C) orient_mode | Orientation Mode  |
|--------------------|-------------------|
| 00b                | symmetrical       |
| 01b                | high-asymmetrical |
| 10b                | low-asymmetrical  |
| 11b                | symmetrical       |

For each orientation mode the (0x0C) orient bits have a different meaning as shown in Table 20 to Table 22:

Table 20: Meaning of the (0x0C) orient bits in symmetrical mode

| (0x0C)<br>orient | Name                 | Angle           | Condition                                                   |
|------------------|----------------------|-----------------|-------------------------------------------------------------|
| x00              | portrait upright     | 315° < φ < 45°  | $ acc_y  <  acc_x  - 'hyst'$<br>and $acc_x - 'hyst'' \ge 0$ |
| x01              | portrait upside down | 135° < φ < 225° | acc_y  <  acc_x  - 'hyst'<br>and acc_x + 'hyst' < 0         |
| x10              | landscape left       | 45° < φ < 135°  | $ acc_y  \ge  acc_x  + 'hyst'$<br>and $acc_y < 0$           |
| x11              | landscape right      | 225° < φ < 315° | $ acc_y  \ge  acc_x  + 'hyst'$<br>and $acc_y \ge 0$         |

Table 21: Meaning of the (0x0C) orient bits in high-asymmetrical mode

| (0x0C)<br>orient | Name                 | Angle           | Condition                                                          |
|------------------|----------------------|-----------------|--------------------------------------------------------------------|
| x00              | portrait upright     | 297° < φ < 63°  | $ acc_y  < 2 \cdot  acc_x  - 'hyst'$<br>and $acc_x - 'hyst' \ge 0$ |
| x01              | portrait upside down | 117° < φ < 243° | $ acc_y  < 2 \cdot  acc_x  - 'hyst'$<br>and acc_x + 'hyst' < 0     |
| x10              | landscape left       | 63° < φ < 117°  | $ acc_y  \ge 2 \cdot  acc_x  + 'hyst'$<br>and $acc_y < 0$          |
| x11              | landscape right      | 243° < φ < 297° | $ acc_y  \ge 2 \cdot  acc_x  + 'hyst'$<br>and $acc_y \ge 0$        |

Page 41 Confidential

Table 22: Meaning of the (0x0C) orient bits in low-asymmetrical mode

| (0x0C)<br>orient | Name                 | Angle           | Condition                                                            |
|------------------|----------------------|-----------------|----------------------------------------------------------------------|
| x00              | portrait upright     | 333° < φ < 27°  | $ acc_y  < 0.5 \cdot  acc_x  - 'hyst'$<br>and $acc_x - 'hyst' \ge 0$ |
| x01              | portrait upside down | 153° < φ < 207° | $ acc_y  < 0.5 \cdot  acc_x  - 'hyst'$<br>and $acc_x + 'hyst' < 0$   |
| x10              | landscape left       | 27° < φ < 153°  | $ acc_y  \ge 0.5 \cdot  acc_x  + 'hyst'$<br>and $acc_y < 0$          |
| x11              | landscape right      | 207° < φ < 333° | $ acc_y  \ge 0.5 \cdot  acc_x  + 'hyst'$<br>and $acc_y \ge 0$        |

In the preceding tables, the parameter 'hyst' stands for a hysteresis, which can be selected by setting the (0x0C) orient\_hyst bits. 1 LSB of (0x0C) orient\_hyst always corresponds to 62.5 mg, in any g-range (i.e. increment is independent from g-range setting). It is important to note that by using a hysteresis  $\neq 0$  the actual switching angles become different from the angles given in the tables since there is an overlap between the different orientations.

The most significant bit of the (0x0C) orient bits (which is displayed as an "x" in the above given tables) contains information about the direction of the z-axis. It is set to "0" ("1") if  $acc_z \ge 0$  (acc z < 0).

Figure 11 shows the typical switching conditions between the four different orientations for the symmetrical mode (i.e. without hysteresis):



Figure 11: Typical orientation switching conditions w/o hysteresis

The orientation interrupt is enabled (disabled) by writing "1" ("0") to bit (0x16) orient\_en. The interrupt is generated if the value of (0x0C) orient has changed. It is automatically cleared after one stable period of the (0x0C) orient value. The interrupt status is stored in the (0x09) orient\_int bit.

Page 42 Confidential

If temporary or latched interrupt mode is used, after the generation of the interrupt the changed (0x0C) orient value is kept fixed as long as the interrupt persists (e. g. until the latch time expires or the interrupt is reset). After clearing the interrupt, the (0x0C) orient is only updated with the next following value change (i.e. with the next occurring interrupt). In order to ensure the continuous availability of up-to-date orientation data it is therefore optimal to use the non-latched interrupt. It is strongly advised against using latched interrupt mode or temporary interrupt mode with latch times above 50 ms for orient recognition.

#### 4.8.7.1 Orientation blocking

The change of the (0x0C) orient value and – as a consequence – the generation of the interrupt can be blocked according to conditions selected by setting the value of the (0x2C) orient\_blocking bits as described by Table 23.

| (0x2C) orient_blocking | Conditions                                                                                                    |
|------------------------|---------------------------------------------------------------------------------------------------------------|
| 00b                    | no blocking                                                                                                   |
| 01b                    | theta blocking                                                                                                |
| 10b                    | theta blocking<br>or<br>acceleration slope in any axis > 0.2 g                                                |
| 11b                    | value of orient is not stable for at least 100 ms or theta blocking or acceleration slope in any axis > 0.4 g |

Table 23: Blocking conditions for orientation recognition

The theta blocking is defined by the following inequality:

$$|\tan \theta| < \frac{\sqrt{\text{blocking theta}}}{8}$$

The parameter *blocking\_theta* of the above given equation stands for the contents of the *(0x2D)* orient\_theta bits. Hereby it is possible to define a blocking angle between 0° and 44.8°. The internal blocking algorithm saturates the acceleration values before further processing. As a consequence, the blocking angles are strictly valid only for a device at rest; they can be different if the device is moved.

#### Example:

To get a maximum blocking angle of 19° the parameter *blocking\_theta* is determined in the following way:  $(8 * tan(19°))^2 = 7.588$ , therefore, *blocking\_value* = 8dec = 001000b has to be chosen.

In order to avoid unwanted generation of the orientation interrupt in a nearly flat position (z  $\sim$  0, sign change due to small movements or noise), a hysteresis of 0.2 g is implemented for the z-axis, i. e. a after a sign change the interrupt is only generated after |z| > 0.2 g.

Page 43 Confidential

#### 4.8.8 Flat detection

The flat detection feature gives information about the orientation of the devices' z-axis relative to the g-vector, i. e. it recognizes whether the device is in a flat position or not.

The condition for the device to be in the flat position is

$$|\tan \theta| < \frac{\sqrt{\text{parameter \_theta}}}{8}$$

Like  $blocking\_theta$ , used with orientation recognition, the  $parameter\_theta$  stands for a user-defined setting. In this case the content of the (0x2E)  $flat\_theta$  bits. The possible flat angles also range from 0° to 44.8°. To ensure proper operation,  $parameter\_theta$  has to be less than or equal to  $blocking\_theta$ .

The flat interrupt is enabled (disabled) by writing "1" ("0") to bit (0x16) flat\_en. The flat interrupt is generated if the flat value has changed and the new value is stable for at least the time given by the (0x2F) flat\_hold\_time bits. The flat value is stored in the (0x0C) flat bit if the interrupt is enabled. This value is "1" if the device is in the flat position, it is "0" otherwise. The content of the (0x0C) flat bit is changed only if the interrupt is generated. The interrupt is automatically cleared after one sample period. Its status is stored in the (0x09) flat\_int bit.

If temporary or latched interrupt mode is used, after the generation of the interrupt the changed (0x0C) flat value is kept fixed as long as the interrupt persists (e. g. until the latch time expires or the interrupt is reset). After clearing the interrupt, the (0x0C) flat value is only updated with the next following value change (i.e. with the next occurring interrupt).

The meaning of the (0x2F) flat\_hold\_time bits can be seen from Table 24.

 (0x2F)
 Time

 flat\_hold\_time
 0

 00b
 0

 01b
 512 ms

 10b
 1024 ms

 11b
 2048 ms

Table 24: Meaning of flat\_hold\_time

#### 4.8.9 Low-g interrupt

This interrupt is based on the comparison of acceleration data against a low-g threshold, which is most useful for free-fall detection.

The interrupt is enabled (disabled) by writing "1" ("0") to the (0x17) low\_en bit. There are two modes available, 'single' mode and 'sum' mode. In 'single' mode, the acceleration of each axis is compared with the threshold; in 'sum' mode, the sum of absolute values of all accelerations  $|acc_x| + |acc_y| + |acc_z|$  is compared with the threshold. The mode is selected by the contents of the (0x24) low\_mode bit: "0" means 'single' mode, "1" means 'sum' mode.

The low-g threshold is set through the (0x23) low\_th register. 1 LSB of (0x23) low\_th always corresponds to an acceleration of 7.81 mg (i.e. increment is independent from g-range setting).



Page 44 Confidential

A hysteresis can be selected by setting the (0x24) low\_hy bits. 1 LSB of (0x24) low\_hy always corresponds to an acceleration difference of 125 mg in any g-range (as well, increment is independent from g-range setting).

The low-g interrupt is generated if the absolute values of the acceleration of all axes ('and' relation, in case of single mode) or their sum (in case of sum mode) are lower than the threshold for at least the time defined by the (0x22)  $low_dur$  register. The interrupt is reset if the absolute value of the acceleration of at least one axis ('or' relation, in case of single mode) or the sum of absolute values (in case of sum mode) is higher than the threshold plus the hysteresis for at least one data acquisition. In bit (0x09)  $low_int$  the interrupt status is stored.

The relation between the content of (0x22)  $low_dur$  and the actual delay of the interrupt generation is: delay [ms] = [(0x22)  $low_dur + 1] \cdot 2$  ms. Therefore, possible delay times range from 2 ms to 512 ms.

#### 4.8.10 **High-g interrupt**

This interrupt is based on the comparison of acceleration data against a high-g threshold for the detection of shock or other high-acceleration events.

The high-g interrupt is enabled (disabled) per axis by writing "1" ("0") to bits (0x17) high\_en\_x, (0x17) high\_en\_y, and (0x17) high\_en\_z, respectively. The high-g threshold is set through the (0x26) high\_th register. The meaning of an LSB of (0x26) high\_th depends on the selected grange: it corresponds to 7.81 mg in 2g-range, 15.63 mg in 4g-range, 31.25 mg in 8g-range, and 62.5 mg in 16g-range (i.e. increment depends from g-range setting).

A hysteresis can be selected by setting the (0x24) high\_hy bits. Analogously to (0x26) high\_th, the meaning of an LSB of (0x24) high\_hy is g-range dependent: it corresponds to an acceleration difference of 125 mg in 2g-range, 250 mg in 4g-range, 500 mg in 8g-range, and 1000mg in 16g-range (as well, increment depends from g-range setting).

The high-g interrupt is generated if the absolute value of the acceleration of at least one of the enabled axes ('or' relation) is higher than the threshold for at least the time defined by the (0x25) high\_dur register. The interrupt is reset if the absolute value of the acceleration of all enabled axes ('and' relation) is lower than the threshold minus the hysteresis for at least the time defined by the (0x25) high\_dur register. In bit (0x09) high\_int the interrupt status is stored. The relation between the content of (0x25) high\_dur and the actual delay of the interrupt generation is delay [ms] = [(0x22) low\_dur + 1] • 2 ms. Therefore, possible delay times range from 2 ms to 512 ms.

#### 4.8.10.1 Axis and sign information of high-g interrupt

The axis which triggered the interrupt is indicated by bits (0x0C) high\_first\_x, (0x0C) high\_first\_y, and (0x0C) high\_first\_z. The bit corresponding to the triggering axis contains a "1" while the other bits hold a "0". These bits are cleared together with clearing the interrupt status. The sign of the triggering acceleration is stored in bit (0x0C) high\_sign. If (0x0C) high\_sign = "0" ("1"), the sign is positive (negative).



Page 45 Confidential

#### 4.9 Magnetometer interrupt controller

Four magnetometer based interrupt engines are integrated in the magnetometer part of BMC050: Low-Threshold, High-Threshold, Overflow and Data Ready (DRDY). Each interrupt can be enabled independently.

When enabled, an interrupt sets the corresponding status bit in the interrupt status register (0x4A) when its condition is satisfied.

When the "Interrupt Pin Enable" bit (register 0x4E bit6) is set, any occurring activated interrupts are flagged on the BMC050's INT3 output pin. By default, the interrupt pin is disabled (high-Z status).

Low-Threshold, High-Threshold and Overflow interrupts are mapped to the INT3 pin when enabled, Data Ready (DRDY) interrupt is mapped to the DRDY pin of BMC050 when enabled. For High- and Low-Threshold interrupts each axis X/Y/Z can be enabled separately for interrupt detection in the registers "High Int Z en", "High Int Y en", "High Int X en", "Low Int Z en", "Low Int Y En" and "Low Int X En" in register 0x4D bit5-bit0. Overflow interrupt is shared for X, Y and Z axis.

When the "Data Ready Pin En" bit (register 0x4E bit7) is set, the Data Ready (DRDY) interrupt event is flagged on the BMC050's DRDY output pin (by default the "Data Ready Pin En" bit is not set and DRDY pin is in high-Z state).

The interrupt status registers are updated together with writing new data into the magnetic field data registers. The status bits for Low-/High-Threshold interrupts are located in register 0x4A, the Data Ready (DRDY) status flag is located at register 0x48 bit0.

If an interrupt is disabled, all active status bits and pins are reset after the next measurement was performed.

#### 4.9.1 General features

An interrupt is cleared depending on the selected interrupt mode, which is common to all interrupts. There are two different interrupt modes: non-latched and latched. All interrupts (except Data Ready) can be latched or non-latched. Data Ready (DRDY) is always cleared after readout of data registers ends.

A non-latched interrupt will be cleared on a new measurement when the interrupt condition is not valid anymore, whereas a latched interrupt will stay high until the interrupts status register (0x4A) is read out. After reading the interrupt status, both the interrupt status bits and the interrupt pin are reset. The mode is selected by the "Interrupt latch" bit (register 0x4A bit1), where the default setting of "1" means latched. Figure 12 shows the difference between the modes for the example Low-Threshold interrupt.

INT3 and DRDY pin polarity can be changed by the "Interrupt polarity" bit (register 0x4E bit0) and "DR polarity" (register 0x4E bit2), from the default high active ("1") to low active ("0").



Page 46 Confidential



Figure 12: Interrupt latched and non-latched mode

## 4.9.2 Electrical behavior of magnetic interrupt pins

Both interrupt pins INT3 and DRDY are push/pull when the corresponding interrupt pin enable bit is set, and are floating (High-Z) when the corresponding interrupt pin enable bit is disabled (default).

#### 4.9.3 **Data ready / DRDY interrupt**

This interrupt serves for synchronous reading of magnetometer data. It is generated after storing a new set of values (DATAX, DATAY, DATAZ, RHALL) in the data registers:



Figure 13: Data acquisition and DRDY operation (DRDY in "high active" polarity)

The interrupt mode of the Data Ready (DRDY) interrupt is fixed to non-latched.

It is enabled (disabled) by writing "1" ("0") to "Data Ready pin En" in register 0x4E bit7.



Page 47 Confidential

DRDY pin polarity can be changed by the "DR polarity" bit (register 0x4E bit2), from the default high active ("1") to low active ("0").

#### 4.9.4 Low-threshold interrupt

When the data registers' (DATAX, DATAY and DATAZ) values drop below the threshold level defined by the "Low Threshold register (0x4F), the corresponding interrupt status bits for those axes are set ("Low Int X", "Low Int Y" and "Low Int Z" in register 0x4A). This is done for each axis independently. Please note that the X and Y axis value for overflow is -4096. However, no interrupt is generated on these values. See chapter 4.9.6 for more information on overflow.

Hereby, one bit in "Low Threshold" corresponds to roughly  $6\mu T$  (not exactly, as the raw magnetic field values DATAX, DATAY and DATAZ are not temperature compensated).

The Low-threshold interrupt is issued on INT3 pin when one or more values of the data registers DATAX, DATAY and DATAZ drop below the threshold level defined by the "Low Threshold" register (0x4F), and when the axis where the threshold was exceeded is enabled for interrupt generation:

Result = (DATAX < "Low Threshold" x 16) AND "Low Int X en" is "0" OR (DATAY < "Low Threshold" x 16) AND "Low Int Y en" is "0" OR (DATAZ < "Low Threshold" x 16) AND "Low Int Z en" is "0"

Note: Threshold interrupt enable bits ("Low INT [XYZ] en") are active low and "1" (disabled) by default.



Figure 14: Low-threshold interrupt function



Page 48 Confidential

#### 4.9.5 High-threshold interrupt

When the data registers' (DATAX, DATAY and DATAZ) values exceed the threshold level defined by the "High Threshold register (0x50), the corresponding interrupt status bits for those axes are set ("High Int X", "High Int Y" and "High Int Z" in register 0x4A). This is done for each axis independently.

Hereby, one bit in "High Threshold" corresponds to roughly  $6\mu T$  (not exactly, as the raw magnetic field values DATAX, DATAY and DATAZ are not temperature compensated).

The High-threshold interrupt is issued on INT3 pin when one or more values of the data registers DATAX, DATAY and DATAZ exceed the threshold level defined by the "High Threshold" register (0x50), and when the axis where the threshold was exceeded is enabled for interrupt generation:

Result = (DATAX > "High Threshold" x 16) AND "High Int X en" is "0" OR (DATAY > "High Threshold" x 16) AND "High Int Y en" is "0" OR (DATAZ > "High Threshold" x 16) AND "High Int Z en" is "0"

Note: Threshold interrupt enable bits ("High INT [XYZ] en") are active low and "1" (disabled) by default.



Figure 15: High-threshold interrupt function

#### 4.9.6 Overflow

When a measurement axis had an overflow, the corresponding data register is saturated to the most negative value. For X and Y axis, the data register is set to the value -4096. For the Z axis, the data register is set to the value -16384.

The "Overflow" flag (register 0x4A bit6) indicates that the measured magnetic field raw data of one or more axes exceeded maximum range of the device. The overflow condition can be flagged on the INT3 pin by setting the bit "overflow int enable" (register 0x4D bit6, active high, default value "0"). The channel on which overflow occurred can be determined by assessing the DATAX/Y/Z registers.



Page 49 Confidential

# 5. Accelerometer register description

#### 5.1 General remarks

The entire communication with the device is performed by reading from and writing to registers. Registers have a width of 8 bits; they are mapped to a common space of 64 addresses from (0x00) up to (0x3F). Within the used range there are several registers which are either completely or partially marked as 'reserved'. Any reserved bit is ignored when it is written and no specific value is guaranteed when read. It is recommended not to use registers at all which are completely marked as 'reserved'. Further-more it is recommended to mask out (logical and with zero) reserved bits of registers which are partially marked as reserved.

Registers with addresses from (0x00) up to (0x0E) are read-only. Any attempt to write to these registers is ignored. There are bits within some registers that connected with an action to be done and, therefore, are intended for write-only access, e. g. (0x21) reset\_int or the entire (0x14) softreset register. Such bits always give "0" when read.

Page 50 Confidential

## 5.2 Register map

| Register Address | Default Value | bit7                               | bit6                                                                           | bit5             | bit4        | bit3              | bit2           | bit1          | bit0          |
|------------------|---------------|------------------------------------|--------------------------------------------------------------------------------|------------------|-------------|-------------------|----------------|---------------|---------------|
| 0x3F             | 0x00          | reserved                           |                                                                                |                  |             |                   |                |               |               |
| 0x3E             | 0x00          |                                    | reserved                                                                       |                  |             |                   |                |               |               |
| 0x3D             | 0x00          |                                    |                                                                                |                  |             | nfilt_z<7:0>      |                |               |               |
| 0x3C             | 0x00          |                                    |                                                                                |                  |             | nfilt_y<7:0>      |                |               |               |
| 0x3B             | 0x00          |                                    |                                                                                |                  |             | nfilt_x<7:0>      |                |               |               |
| 0x3A             | 0x00          |                                    |                                                                                |                  |             | ilt_z<7:0>        |                |               |               |
| 0x39             | 0x00          |                                    |                                                                                |                  |             | ilt_y<7:0>        |                |               |               |
| 0x38             | 0x00          |                                    |                                                                                |                  |             | ilt_x<7:0>        | -#             |               |               |
| 0x37<br>0x36     | 0x00<br>0x00  | reserved                           |                                                                                | get_z<1:0>       |             | get_y<1:0>        |                | get_x<1:0>    | cut_off       |
| 0x35             | 0x00          | offset_reset                       | cai_trig                                                                       | ger<1:0>         | cal_rdy     | reserved<br>erved | hp_z_en        | hp_y_en       | hp_x_en       |
| 0x35<br>0x34     | 0x00          |                                    |                                                                                | reserved         | res         | ervea             | i2c wdt en     | i2c wdt sel   | spi3          |
| 0x34<br>0x33     | 0x04          |                                    | ****                                                                           | erved            |             | nvm_load          | nvm_rdy        | nvm_prog_trig | nvm_prog_mode |
| 0x33             | 0x04<br>0x70  |                                    | 1626                                                                           | reserved         |             | IIVIII_IOdu       | self_test_sign |               | st axis       |
| 0x32<br>0x31     | 0x00          |                                    |                                                                                | reserveu         | roo         | erved             | Sell_test_sign | 3CII_10       | St_axiS       |
| 0x31             | 0x00          |                                    |                                                                                |                  |             | erved<br>erved    |                |               |               |
| 0x36<br>0x2F     | 0x10          | rese                               | nied                                                                           | flat hold        | time<1:0>   | erveu             | rosa           | erved         |               |
| 0x2F<br>0x2E     | 0x10          | rese                               |                                                                                | iiat_ii0lu_      |             | flat the          | ta<5:0>        |               |               |
| 0x2E<br>0x2D     | 0x08          | rese                               |                                                                                |                  |             |                   | neta<5:0>      |               |               |
| 0x2C             | 0x18          | reserved                           |                                                                                | orient_hyst<2:0> |             |                   | cking<1:0>     | orient m      | ode<1:0>      |
| 0x2B             | 0x0A          | tap san                            | np<1:0>                                                                        | reserved         |             | Onent_blo         | tap th<4:0>    | Unent_II      | 040 1.07      |
| 0x2A             | 0x04          | tap_quiet                          | tap_shock                                                                      | reserved         | reserved    |                   | tap_ti1>4:02   | tap_dur<2:0>  |               |
| 0x2A<br>0x29     | 0x04<br>0x00  | tap_quict                          | тар_эпоск                                                                      |                  |             | erved             |                | tap_dui -2.0> |               |
| 0x28             | 0x14          |                                    |                                                                                |                  |             | th<7:0>           |                |               |               |
| 0x27             | 0x00          |                                    |                                                                                | roso             | erved       | _01177.07         |                | slone (       | lur<1:0>      |
| 0x26             | 0xC0          |                                    |                                                                                | 7636             |             | th<7:0>           |                | Siopc_t       | 101 -1.02     |
| 0x25             | 0x0F          |                                    |                                                                                |                  |             | dur<7:0>          |                |               |               |
| 0x24             | 0x81          | high h                             | v<1·0>                                                                         |                  | reserved    | aul 41.02         | low mode       | low h         | v<1·0>        |
| 0x23             | 0x30          | IIIgit_ti                          | high_hy<1:0>                                                                   |                  |             | y 11.07           |                |               |               |
| 0x22             | 0x09          |                                    | IOW UTT/30> Iow dur(7)0>                                                       |                  |             |                   |                |               |               |
| 0x21             | 0x00          | reset int                          |                                                                                |                  |             |                   |                |               |               |
| 0x20             | 0x05          | TODOL_IIIC                         | rosa                                                                           | erved            |             | int2 od           | int2 lvl       | int1 od       | int1 lvl      |
| 0x1F             | 0x00          | reserved III Ou III IV III OU IIII |                                                                                |                  | 11112_111   |                   |                |               |               |
| 0x1E             | 0x00          |                                    |                                                                                |                  | int src low |                   |                |               |               |
| 0x1D             | 0x00          |                                    | reserved int sic data int sic tap reserved int sic slope int sic ingil int sic |                  |             |                   |                |               |               |
| 0x1C             | 0x00          |                                    |                                                                                |                  |             | erved             |                |               |               |
| 0x1B             | 0x00          | int2 flat                          | int2 orient                                                                    | int2 s tap       | int2 d tap  | reserved          | int2 slope     | int2 high     | int2 low      |
| 0x1A             | 0x00          | int2 data                          |                                                                                |                  | res         | erved             |                |               | int1 data     |
| 0x19             | 0x00          | int1 flat                          | int1 orient                                                                    | int1_s_tap       | int1_d_tap  | reserved          | int1_slope     | int1_high     | int1 low      |
| 0x18             | 0x00          |                                    |                                                                                |                  | res         | erved             |                |               |               |
| 0x17             | 0x00          |                                    | reserved                                                                       |                  | data_en     | low_en            | high_en_z      | high_en_y     | high_en_x     |
| 0x16             | 0x00          | flat_en                            | orient_en                                                                      | s_tap_en         | d_tap_en    | reserved          | slope_en_z     | slope_en_y    | slope_en_x    |
| 0x15             | 0x00          |                                    |                                                                                |                  |             | erved             |                |               |               |
| 0x14             | 0x00          |                                    |                                                                                |                  | sof         | treset            |                |               |               |
| 0x13             | 0x00          | data_high_bw                       | shadow_dis                                                                     |                  |             |                   | rved           |               |               |
| 0x12             | 0x00          |                                    |                                                                                |                  | res         | erved             |                |               |               |
| 0x11             | 0x00          | suspend                            | lowpower_en                                                                    | reserved         |             | sleep_c           | dur<3:0>       |               | reserved      |
| 0x10             | 0x1F          |                                    | reserved                                                                       |                  |             |                   | bw<4:0>        |               |               |
| 0x0F             | 0x03          | reserved range<3:0>                |                                                                                |                  |             |                   |                |               |               |
| 0x0E             | 0x00          |                                    |                                                                                |                  |             | erved             |                |               |               |
| 0x0D             | 0x00          |                                    |                                                                                |                  | res         | erved             |                |               |               |
| 0x0C             | 0x00          | flat                               |                                                                                | orient[2:0]      |             | high_sign         | high_first_z   | high_first_y  | high_first_x  |
| 0x0B             | 0x00          | tap_sign                           | tap_first_z                                                                    | tap_first_y      | tap_first_x | slope_sign        | slope_first_z  | slope_first_y | slope_first_x |
| 0x0A             | 0x00          | data_int                           |                                                                                |                  |             | reserved          |                |               |               |
| 0x09             | 0x00          | flat_int                           | orient_int                                                                     | s_tap_int        | d_tap_int   | reserved          | slope_int      | high_int      | low_int       |
| 0x08             | 0x00          | temp<7:0>                          |                                                                                |                  |             |                   |                |               |               |
| 0x07             | 0x00          | acc_z_msb<9:2>                     |                                                                                |                  |             |                   |                |               |               |
| 0x06             | 0x00          | acc_z_lsb<1:0> 0 new_data_z        |                                                                                |                  | new_data_z  |                   |                |               |               |
| 0x05             | 0x00          |                                    |                                                                                |                  | acc_y_i     | msb<9:2>          |                |               |               |
| 0x04             | 0x00          | acc_y_l                            | sb<1:0>                                                                        |                  |             | 0                 |                |               | new_data_y    |
| 0x03             | 0x00          |                                    |                                                                                |                  | acc_x_i     | msb<9:2>          |                |               |               |
| 0x02             | 0x00          | acc_x_l                            | sb<1:0>                                                                        |                  |             | 0                 |                |               | new_data_x    |
| 0x01             | 0x21          |                                    |                                                                                |                  |             | erved<br>hip ID   |                |               |               |
| 0x00             | 0x03          |                                    |                                                                                |                  |             |                   |                |               |               |

| w/r        |
|------------|
| write only |
| read only  |
| reserved   |

# 5.3 Chip ID

**Register (0x00)** Chip ID contains the accelerometer chip identification number.

Table 25: Chip identification number, register (0x00)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     | 0     | 1     | 1     |

## Register (0x01) is reserved

Page 51 Confidential

#### 5.4 Acceleration data

**Register** (0x02) contains the LSB part of x-axis acceleration data and the new data flag for the x-axis.

Table 26: LSB part of x-axis acceleration, register (0x02)

| (0x02) Bit | Name          | Description                               |
|------------|---------------|-------------------------------------------|
| Bit 7      | acc_x_lsb <1> | Bit 1 of x-axis acceleration data         |
| Bit 6      | acc_x_lsb <0> | Bit 0 of x-axis acceleration data = x LSB |
| Bit 5      | -             | (fixed to 0)                              |
| Bit 4      | -             | (fixed to 0)                              |
| Bit 3      | -             | (fixed to 0)                              |
| Bit 2      | -             | (fixed to 0)                              |
| Bit 1      | -             | (fixed to 0)                              |
| Bit 0      | new_data_x    | New data flag of x-axis                   |

**Register (0x03)** contains the MSB part of x-axis acceleration data.

Table 27: MSB part of x-axis acceleration, register (0x03)

| (0x03)<br>Bit | Name          | Description                               |
|---------------|---------------|-------------------------------------------|
| Bit 7         | acc_x_msb <9> | Bit 9 of x-axis acceleration data = x MSB |
| Bit 6         | acc_x_msb <8> | Bit 8 of x-axis acceleration data         |
| Bit 5         | acc_x_msb <7> | Bit 7 of x-axis acceleration data         |
| Bit 4         | acc_x_msb <6> | Bit 6 of x-axis acceleration data         |
| Bit 3         | acc_x_msb <5> | Bit 5 of x-axis acceleration data         |
| Bit 2         | acc_x_msb <4> | Bit 4 of x-axis acceleration data         |
| Bit 1         | acc_x_msb <3> | Bit 3 of x-axis acceleration data         |
| Bit 0         | acc_x_msb <2> | Bit 2 of x-axis acceleration data         |

**Register** (0x04) contains the LSB part of y-axis acceleration data and the new data flag for the y-axis.

Table 28: LSB part of y-axis acceleration, register (0x04)

| (0x04)<br>Bit | Name          | Description                               |
|---------------|---------------|-------------------------------------------|
| Bit 7         | acc y lsb <1> | Bit 1 of y-axis acceleration data         |
| Bit 6         | acc_y_lsb <0> | Bit 0 of y-axis acceleration data = y LSB |
| Bit 5         | -             | (fixed to 0)                              |
| Bit 4         | -             | (fixed to 0)                              |
| Bit 3         | -             | (fixed to 0)                              |
| Bit 2         | -             | (fixed to 0)                              |
| Bit 1         | -             | (fixed to 0)                              |
| Bit 0         | new_data_y    | New data flag of y-axis                   |

Page 52 Confidential

**Register (0x05)** contains the MSB part of acceleration data for the y-axis.

Table 29: MSB part of y-axis acceleration, register (0x05)

| (0x05)<br>Bit | Name          | Description                               |
|---------------|---------------|-------------------------------------------|
| Bit 7         | acc_y_msb <9> | Bit 9 of y-axis acceleration data = y MSB |
| Bit 6         | acc_y_msb <8> | Bit 8 of y-axis acceleration data         |
| Bit 5         | acc_y_msb <7> | Bit 7 of y-axis acceleration data         |
| Bit 4         | acc_y_msb <6> | Bit 6 of y-axis acceleration data         |
| Bit 3         | acc_y_msb <5> | Bit 5 of y-axis acceleration data         |
| Bit 2         | acc_y_msb <4> | Bit 4 of y-axis acceleration data         |
| Bit 1         | acc_y_msb <3> | Bit 3 of y-axis acceleration data         |
| Bit 0         | acc_y_msb <2> | Bit 2 of y-axis acceleration data         |

**Register (0x06)** contains the LSB part of acceleration data and the new data flag for the z-axis.

Table 30: LSB part of y-axis acceleration, register (0x06)

| (0x06)<br>Bit | Name          | Description                               |
|---------------|---------------|-------------------------------------------|
| Bit 7         | acc_z_lsb <1> | Bit 1 of z-axis acceleration data         |
| Bit 6         | acc_z_lsb <0> | Bit 0 of z-axis acceleration data = z LSB |
| Bit 5         | -             | (fixed to 0)                              |
| Bit 4         | -             | (fixed to 0)                              |
| Bit 3         | -             | (fixed to 0)                              |
| Bit 2         | -             | (fixed to 0)                              |
| Bit 1         | -             | (fixed to 0)                              |
| Bit 0         | new_data_z    | New data flag of z-axis                   |

**Register (0x07)** contains the MSB part of acceleration data for the z-axis.

Table 31: MSB part of z-axis acceleration, register (0x07)

| (0x07) | Name          | Description                               |  |  |  |  |
|--------|---------------|-------------------------------------------|--|--|--|--|
| Bit    |               |                                           |  |  |  |  |
| Bit 7  | acc_z_msb <9> | Bit 9 of z-axis acceleration data = z MSB |  |  |  |  |
| Bit 6  | acc_z_msb <8> | Bit 8 of z-axis acceleration data         |  |  |  |  |
| Bit 5  | acc_z_msb <7> | Bit 7 of z-axis acceleration data         |  |  |  |  |
| Bit 4  | acc_z_msb <6> | Bit 6 of z-axis acceleration data         |  |  |  |  |
| Bit 3  | acc_z_msb <5> | Bit 5 of z-axis acceleration data         |  |  |  |  |
| Bit 2  | acc_z_msb <4> | Bit 4 of z-axis acceleration data         |  |  |  |  |
| Bit 1  | acc_z_msb <3> | Bit 3 of z-axis acceleration data         |  |  |  |  |
| Bit 0  | acc_z_msb <2> | Bit 2 of z-axis acceleration data         |  |  |  |  |

Page 53 Confidential

## 5.5 Temperature data

**Register** (0x08) temp contains temperature data in two's complement representation. Center temperature =  $24 \, ^{\circ}\text{C} \rightarrow \text{i.e.}$  (0x08) temp = 000000000b

1 LSB increment of temperature sensor is 0.5 °C (0.9 °F).

Table 32: Temperature data, register (0x08)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| Temp  |
| <7>   | <6>   | <5>   | <4>   | <3>   | <2>   | <1>   | <0>   |

## **5.6 Status registers**

**Register** (0x09) contains the states of several interrupts.

Table 33: Interrupt status, register (0x09)

| (0x09)<br>Bit | Name         | Description                  |
|---------------|--------------|------------------------------|
| Bit 7         | flat_int     | Flat interrupt status        |
| Bit 6         | orient_int   | Orientation interrupt status |
| Bit 5         | s_tap_int    | Single tap interrupt status  |
| Bit 4         | d_tap_int    | Double tap interrupt status  |
| Bit 3         | - reserved - | reserved                     |
| Bit 2         | slope_int    | Slope interrupt status       |
| Bit 1         | high_int     | High-g interrupt status      |
| Bit 0         | low_int      | Low-g interrupt status       |

**Register (0x0A)** contains the status of the new data interrupt.

Table 34: New data status, register (0x0A)

| (0x0A) Bit | Name         | Description               |
|------------|--------------|---------------------------|
| Bit 7      | data_int     | New data interrupt status |
| Bit 6      | - reserved - | reserved                  |
| Bit 5      | - reserved - | reserved                  |
| Bit 4      | - reserved - | reserved                  |
| Bit 3      | - reserved - | reserved                  |
| Bit 2      | - reserved - | reserved                  |
| Bit 1      | - reserved - | reserved                  |
| Bit 0      | - reserved - | reserved                  |

Page 54 Confidential

**Register** (0x0B) contains the sign and triggering axis information for the tap and slope interrupts. Here tap interrupt comprises both single and double tap interrupt.

Table 35: Tap and slope interrupts status, register (0x0B)

| (0x0B) Bit | Name          | Description                                                             |  |  |  |  |
|------------|---------------|-------------------------------------------------------------------------|--|--|--|--|
| Bit 7      | tap_sign      | Sign of 1 <sup>st</sup> tap that triggered the interrupt ("0"=positive, |  |  |  |  |
|            |               | "1"=negative)                                                           |  |  |  |  |
| Bit 6      | tap_first_z   | "1" indicates that z-axis is triggering axis of tap interrupt           |  |  |  |  |
| Bit 5      | tap_first_y   | "1" indicates that y-axis is triggering axis of tap interrupt           |  |  |  |  |
| Bit 4      | tap_first_x   | "1" indicates that x-axis is triggering axis of tap interrupt           |  |  |  |  |
| Bit 3      | slope_sign    | Sign of slope that triggered the interrupt ("0"=positive,               |  |  |  |  |
|            |               | "1"=negative)                                                           |  |  |  |  |
| Bit 2      | slope_first_z | "1" indicates that z-axis is triggering axis of slope                   |  |  |  |  |
|            |               | interrupt                                                               |  |  |  |  |
| Bit 1      | slope_first_y | "1" indicates that y-axis is triggering axis of slope                   |  |  |  |  |
|            |               | interrupt                                                               |  |  |  |  |
| Bit 0      | slope_first_x | "1" indicates that x-axis is triggering axis of slope                   |  |  |  |  |
|            |               | interrupt                                                               |  |  |  |  |

**Register** (0x0C) contains the flat and orientation status, and the sign and triggering axis information for the high-g interrupt. Registers (0x0D) and (0x0E) are reserved.

Table 36: Flat and orientation Status, register (0x0C)

| (0x0C) Bit | Name         | Description                                                                  |  |  |  |  |  |
|------------|--------------|------------------------------------------------------------------------------|--|--|--|--|--|
| Bit 7      | flat         | flat detection ("1" if flat condition is fulfilled, "0" otherwise)           |  |  |  |  |  |
| Bit 6      | orient <2>   | orientation value of z-axis ("0" if upward looking, "1" if downward looking) |  |  |  |  |  |
| Bit 5      | orient <1>   | rientation value of x-y plane ("00"=portrait upright,                        |  |  |  |  |  |
| Bit 4      | orient <0>   | "01"=portrait upside-down, "10"=landscape left, "11"=landscape right)        |  |  |  |  |  |
| Bit 3      | high_sign    | Sign of slope that triggered the interrupt ("0"=positive, "1"=negative)      |  |  |  |  |  |
| Bit 2      | high_first_z | "1" indicates that z-axis is triggering axis of high-g interrupt             |  |  |  |  |  |
| Bit 1      | high_first_y | 1" indicates that y-axis is triggering axis of high-g                        |  |  |  |  |  |
| Bit 0      | high_first_x | "1" indicates that x-axis is triggering axis of high-g interrupt             |  |  |  |  |  |

**Registers** (0x0D) and (0x0E) are reserved.

Page 55 Confidential

#### 5.7 g-range selection

**Register** (0x0F) contains the selection of the g-range. Proper settings for (0x0F) range are "0011b" (selects ±2g range), "0101b" (selects ±4g range), "1000b" (selects ±8g range), "1100b" (selects ±16g range). All other settings are irregular; if such a setting is used, ±2g range is selected. Default value of (0x0F) range (after reset) is "0011b".

Table 37: g-range, register (0x0F)

| Bit 7   | Bit 6   | Bit 5   | Bit 4   | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|---------|---------|---------|-------|-------|-------|-------|
| reserve | reserve | reserve | reserve | range | range | range | range |
| d       | d       | d       | d       | <3>   | <2>   | <1>   | <0>   |

#### 5.8 Bandwidths

**Register** (0x10) contains the selection of the bandwidth for filtered acceleration data. Settings for (0x10) bw are "00xxxb" (bandwidth = 7.81 Hz), "01000b" (bandwidth = 7.81 Hz), "01001b" (bandwidth = 15.63 Hz), "01010b" (bandwidth = 31.25 Hz), "01011b" (bandwidth = 62.5 Hz), "01100b" (bandwidth = 125 Hz), "01101b" (bandwidth = 250 Hz), "01111b" (bandwidth = 1000 Hz), "1xxxxb" (bandwidth = 1000 Hz). Default value of (0x10) bw (after reset) is "11111b". It is recommended to actively use the range from "01000b" to "01111b" only in order to be compatible with future products.

Table 38: Bandwidths, register (0x10)

| Bit 7    | Bit 6    | Bit 5    | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|----------|----------|----------|--------|--------|--------|--------|--------|
| reserved | reserved | reserved | bw <4> | bw <3> | bw <2> | bw <1> | bw <0> |

#### 5.9 Power modes

**Register (0x11)** contains the configuration of the power modes. (0x11) suspend = "1" ("0") sets (resets) suspend mode; default value of (0x11) suspend is "0".

(0x11) lowpower\_en = "1" ("0") sets (resets) low-power mode, default value of (0x11) lowpower\_en is "0".

The settings for (0x11) sleep\_dur are "0000b" to "0101b" (sleep phase duration = 0.5 ms), "0110b" (sleep phase duration = 1 ms), "0111b" (sleep phase duration = 2 ms), "1000b" (sleep phase duration = 4 ms), "1001b" (sleep phase duration = 6 ms), "1010b" (sleep phase duration = 10 ms), "1011b" (sleep phase duration = 25 ms), "1100b" (sleep phase duration = 50 ms), "1110b" (sleep phase duration = 100 ms), "1110b" (sleep phase duration = 500 ms), "1111b" (sleep phase duration = 1 s). Default value of (0x11) sleep\_dur is "0000b".

Table 39: Power modes, register (0x11)

| Bit 7       | Bit 6               | Bit 5        | Bit 4            | Bit 3            | Bit 2            | Bit 1            | Bit 0        |
|-------------|---------------------|--------------|------------------|------------------|------------------|------------------|--------------|
| suspen<br>d | lowpowe<br>r<br>_en | reserve<br>d | sleep_<br>dur<3> | sleep_<br>dur<2> | sleep_<br>dur<1> | sleep_<br>dur<0> | reserve<br>d |

Page 56 Confidential

## 5.10 Special control settings

Register (0x12) is reserved.

**Register (0x13)** contains settings for the configuration of the acceleration data acquisition and the data output format.

(0x13) data\_high\_bw = "0" ("1") selects filtered (unfiltered) acceleration data to be written into the data registers (0x02) to (0x07). Default value of (0x13) data\_high\_bw is "0".

(0x13) shadow\_dis = "0" ("1") enables (disables) the shadowing procedure. Shadowing means that the MSB register is updated by reading the corresponding LSB register. Default value of (0x13) shadow\_dis is "0".

Table 40: Acceleration data acquisition & data output format, register (0x13)

| Bit 7    | Bit 6  | Bit 5    | Bit 4   | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|----------|--------|----------|---------|---------|---------|---------|---------|
| data_hig | shadow | reserved | reserve | reserve | reserve | reserve | reserve |
| h        | _dis   |          | d       | d       | d       | d       | d       |
| _bw      | _      |          |         |         |         |         |         |

**Register** (0x14) is the *softreset* register. A user-triggered reset (softreset) of the sensor is performed after writing "0xB6h" to the softreset register. After that reset all registers return to their default values. Reading (0x14) softreset returns 0x00.

Register (0x15) is reserved.

## 5.11 Interrupt settings

**Registers** (0x16) and (0x17) contain the enable bits for the interrupts. Default value of each enable bit is "0".

Table 41: Interrupt setting, register (0x16)

| (0x16) Bit | Name         | Description                                             |
|------------|--------------|---------------------------------------------------------|
| Bit 7      | flat_en      | "1" ("0") enables (disables) flat interrupt             |
| Bit 6      | orient_en    | "1" ("0") enables (disables) orientation interrupt      |
| Bit 5      | s_tap_en     | "1" ("0") enables (disables) single tap interrupt       |
| Bit 4      | d_tap_en     | "1" ("0") enables (disables) double tap interrupt       |
| Bit 3      | - reserved - | reserved                                                |
| Bit 2      | slope_en_z   | "1" ("0") enables (disables) slope interrupt for z-axis |
| Bit 1      | slope_en_y   | "1" ("0") enables (disables) slope interrupt for y-axis |
| Bit 0      | slope_en_x   | "1" ("0") enables (disables) slope interrupt for x-axis |



Page 57 Confidential

Table 42: Interrupt setting, register (0x17)

| (0x17) Bit | Name         | Description                                              |
|------------|--------------|----------------------------------------------------------|
| Bit 7      | - reserved - | reserved                                                 |
| Bit 6      | - reserved - | reserved                                                 |
| Bit 5      | - reserved - | reserved                                                 |
| Bit 4      | data_en      | "1" ("0") enables (disables) new data interrupt          |
| Bit 3      | low_en       | "1" ("0") enables (disables) low-g interrupt             |
| Bit 2      | high_en_z    | "1" ("0") enables (disables) high-g interrupt for z-axis |
| Bit 1      | high_en_y    | "1" ("0") enables (disables) high-g interrupt for y-axis |
| Bit 0      | high_en_x    | "1" ("0") enables (disables) high-g interrupt for x-axis |

Register (0x18) is reserved.

**Registers** (0x19) to (0x1B) contain the mapping of interrupts onto the interrupt pins. Default value of each mapping bit is "0".

Table 43: Interrupt mapping, register (0x19)

| (0x19) Bit | Name         | Description                                               |
|------------|--------------|-----------------------------------------------------------|
| Bit 7      | int1_flat    | "1" ("0") maps (unmaps) flat interrupt to INT1 pin        |
| Bit 6      | int1_orient  | "1" ("0") maps (unmaps) orientation interrupt to INT1 pin |
| Bit 5      | int1_s_tap   | "1" ("0") maps (unmaps) single tap interrupt to INT1 pin  |
| Bit 4      | int1_d_tap   | "1" ("0") maps (unmaps) double tap interrupt to INT1 pin  |
| Bit 3      | - reserved - | reserved                                                  |
| Bit 2      | int1_slope   | "1" ("0") maps (unmaps) slope interrupt to INT1 pin       |
| Bit 1      | int1_high    | "1" ("0) maps (unmaps) high-g interrupt to INT1 pin       |
| Bit 0      | int1_low     | "1" ("0") maps (unmaps) low-g interrupt to INT1 pin       |

Table 44: Interrupt mapping, register (0x1A)

| (0x1A) Bit | Name         | Description                                            |
|------------|--------------|--------------------------------------------------------|
| Bit 7      | int2_data    | "1" ("0") maps (unmaps) new data interrupt to INT2 pin |
| Bit 6      | - reserved - | reserved                                               |
| Bit 5      | - reserved - | reserved                                               |
| Bit 4      | - reserved - | reserved                                               |
| Bit 3      | - reserved - | reserved                                               |
| Bit 2      | - reserved - | reserved                                               |
| Bit 1      | - reserved - | reserved                                               |
| Bit 0      | int1_data    | "1" ("0") maps (unmaps) new data interrupt to INT1 pin |



Page 58 Confidential

Table 45: Interrupt mapping, register (0x1B)

| (0x1B) Bit | Name         | Description                                               |
|------------|--------------|-----------------------------------------------------------|
| Bit 7      | int2_flat    | "1" ("0") maps (unmaps) flat interrupt to INT2 pin        |
| Bit 6      | int2_orient  | "1" ("0") maps (unmaps) orientation interrupt to INT2 pin |
| Bit 5      | int2_s_tap   | "1" ("0") maps (unmaps) single tap interrupt to INT2 pin  |
| Bit 4      | int2_d_tap   | "1" ("0") maps (unmaps) double tap interrupt to INT2 pin  |
| Bit 3      | - reserved - | reserved                                                  |
| Bit 2      | int2_slope   | "1" ("0") maps (unmaps) slope interrupt to INT2 pin       |
| Bit 1      | int2_high    | "1" ("0") maps (unmaps) high-g interrupt to INT2 pin      |
| Bit 0      | int2_low     | "1" ("0") maps (unmaps) low-g interrupt to INT2 pin       |

Registers (0x1C) and (0x1D) are reserved.

**Register** (0x1E) contains the data source definition for those interrupts with selectable data source. Default value of each data source selection bit is "0".

Table 46: Interrupt data source definition, register (0x1E)

| (0x1E) Bit | Name          | Description                                                     |  |  |  |  |
|------------|---------------|-----------------------------------------------------------------|--|--|--|--|
| Bit 7      | - reserved -  | reserved                                                        |  |  |  |  |
| Bit 6      | - reserved -  | reserved                                                        |  |  |  |  |
| Bit 5      | int_src_data  | "1" ("0") selects unfiltered (filtered) data for the new data   |  |  |  |  |
|            |               | interrupt                                                       |  |  |  |  |
| Bit 4      | int_src_tap   | "1" ("0") selects unfiltered (filtered) data for the single tap |  |  |  |  |
|            |               | and                                                             |  |  |  |  |
|            |               | double tap interrupts                                           |  |  |  |  |
| Bit 3      | - reserved -  | reserved                                                        |  |  |  |  |
| Bit 2      | int_src_slope | "1" ("0") selects unfiltered (filtered) data for the slope      |  |  |  |  |
|            |               | interrupt                                                       |  |  |  |  |
| Bit 1      | int_src_high  | "1" ("0") selects unfiltered (filtered) data for the high-g     |  |  |  |  |
|            |               | interrupt                                                       |  |  |  |  |
| Bit 0      | int_src_low   | "1" ("0") selects unfiltered (filtered) data for the low-g      |  |  |  |  |
|            |               | interrupt                                                       |  |  |  |  |

Register (0x1F) is reserved.



Page 59 Confidential

**Register** (0x20) contains the behavioural configuration (electrical behaviour) of the interrupt pins. Default value of (0x20) int1\_od and (0x20) int2\_od is "0". Default value of (0x20) int1\_lvl and (0x20) int2\_lvl is "1".

Table 47: Electrical behaviour of interrupt pin, register (0x20)

| (0x20) Bit | Name         | Description                                                |
|------------|--------------|------------------------------------------------------------|
| Bit 7      | - reserved - | reserved                                                   |
| Bit 6      | - reserved - | reserved                                                   |
| Bit 5      | - reserved - | reserved                                                   |
| Bit 4      | - reserved - | reserved                                                   |
| Bit 3      | int2_od      | "0" selects push-pull, "1" selects open drive for INT2 pin |
| Bit 2      | int2_lvl     | "0" ("1") selects active level "0" ("1") for INT2 pin      |
| Bit 1      | int1_od      | "0" selects push-pull, "1" selects open drive for INT1     |
| Bit 0      | int1_lvl     | "0" ("1") selects active level "0" ("1") for INT1 pin      |

**Register (0x21)** contains the interrupt reset bit and the interrupt mode selection. Writing "1" to (0x21) reset\_int resets any latched interrupt.

The settings for (0x21) latch\_int are "0000b" (non-latched), "0001b" (temporary, 250 ms), "0010b" (temporary, 500 ms), "0011b" (temporary, 1 s), "0100b" (temporary, 2 s), "0101b" (temporary, 4 s), "0110b" (temporary, 8 s), "0111b" (latched), "1000b" (non-latched), "1001b" (temporary, 500  $\mu$ s), "1010b" (temporary, 500  $\mu$ s), "1011b" (temporary, 12.5 ms), "1111b" (temporary, 25 ms), "1110b" (temporary, 50 ms), "1111b" (latched).

Default value of (0x21) latch int is "0000b".

Table 48: Interrupt reset bit and interrupt mode selection, register (0x21)

| Bit 7     | Bit 6    | Bit 5    | Bit 4    | Bit 3            | Bit 2            | Bit 1            | Bit 0            |
|-----------|----------|----------|----------|------------------|------------------|------------------|------------------|
| reset_int | reserved | reserved | reserved | latch_<br>int<3> | latch_<br>int<2> | latch_<br>int<1> | latch_<br>int<0> |

**Register** (0x22) contains the delay time definition for the low-g interrupt. The physical delay time can be computed from the content of  $(0x22) low_dur$  according to: delay [ms] =  $[(0x22) low_dur + 1] \cdot 2$  ms.

Possible delay times range from 2 ms to 512 ms. Default value of (0x22) low\_dur is 0x09, corresponding to a delay of 20 ms.

Table 49: Delay time definition for the low-g interrupt, register (0x22)

| Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|--------|--------|--------|--------|--------|--------|--------|--------|
| low_   |
| dur<7> | dur<6> | dur<5> | dur<4> | dur<3> | dur<2> | dur<1> | dur<0> |

Page 60 Confidential

**Register** (0x23) contains the threshold definition for the low-g interrupt. An LSB of (0x23)  $low_th$  corresponds to an actual acceleration of 7.81 mg. Therefore, the threshold ranges from 0 g to 1.992 g. Default value of (0x23)  $low_th$  is 0x30, corresponding to an acceleration of 375 mg.

Table 50: Threshold definition for the low-g interrupt, register (0x23)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| low_  |
| th<7> | th<6> | th<5> | th<4> | th<3> | th<2> | th<1> | th<0> |

**Register** (0x24) contains the low-g interrupt mode selection, the low-g interrupt hysteresis setting, and the high-g interrupt hysteresis setting. Setting (0x24) low\_mode to "0" ("1") selects 'single' mode ('sum' mode). Default value is "0" ('single' mode).

(0x24) low\_hy sets the hysteresis of the low-g interrupt. An LSB of (0x24) low\_hy corresponds to an acceleration difference of 125 mg. Default value of (0x24) low hy is "01b".

(0x24) high\_hy sets the hysteresis of the high-g interrupt. The meaning of an LSB of (0x24) high\_hy depends on the selected g-range. It corresponds to an acceleration difference of 125 mg in 2g-range, 250 mg in 4g-range, 500 mg in 8g-range, and 1000mg in 16g-range. Default value of (0x24) high\_hy is "10b".

Table 51: Threshold definition for the low-g interrupt, register (0x24)

| Bit 7 | Bit 6 | Bit 5    | Bit 4    | Bit 3    | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|----------|----------|----------|-------|-------|-------|
| high_ | high_ | reserved | reserved | reserved | low_  | low_  | low_  |
| hy<1> | hy<0> |          |          |          | mode  | hy<1> | hy<0> |

**Register** (0x25) contains the delay time definition for the high-g interrupt. The physical delay time can be computed from the content of (0x25) high\_dur according to delay [ms] = [(0x22) high\_dur + 1] • 2 ms. Possible delay times range from 2 ms to 512 ms. Default value of (0x25) high\_dur is 0x0F, corresponding to a delay of 32 ms.

Table 52: Delay time definition for the high-g interrupt, register (0x25)

| Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|--------|--------|--------|--------|--------|--------|--------|--------|
| high_  |
| dur<7> | dur<6> | dur<5> | dur<4> | dur<3> | dur<2> | dur<1> | dur<0> |

**Register (0x26)** contains the threshold definition for the high-g interrupt. The meaning of an LSB of (0x26) high\_th depends on the selected g-range. It corresponds to 7.81 mg in 2g-range, 15.63 mg in 4g-range, 31.25 mg in 8g-range, and 62.5 mg in 16g-range. Default value of (0x26) high\_th is 0xC0.

Table 53: Threshold definition for the high-g interrupt, register (0x26)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| high_ |
| th<7> | th<6> | th<5> | th<4> | th<3> | th<2> | th<1> | th<0> |

Page 61 Confidential

**Register (0x27)** contains the definition of the number of samples to be evaluated for the slope interrupt (any-motion detection). The number of samples is N = (0x27) slope\_dur + 1. Default value of (0x27) slope\_dur is "00b".

Table 54: Samples number definition for the slope interrupt, register (0x27)

| Bit 7    | Bit 6    | Bit 5    | Bit 4    | Bit 3    | Bit 2    | Bit 1  | Bit 0  |
|----------|----------|----------|----------|----------|----------|--------|--------|
| reserved | reserved | reserved | reserved | reserved | reserved | slope_ | slope_ |
|          |          |          |          |          |          | dur<1> | dur<0> |

**Register** (0x28) contains the threshold definition for the slope interrupt. An LSB of (0x28)  $slope\_th$  corresponds to an LSB of acceleration data. Its meaning therefore depends on the selected g-range. Default value of (0x28)  $slope\_th$  is 0x14.

Table 55: Samples number definition for the slope interrupt, register (0x28)

| Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|--------|--------|--------|--------|--------|--------|--------|--------|
| slope_ |
| th<7>  | th<6>  | th<5>  | th<4>  | th<3>  | th<2>  | th<1>  | th<0>  |

Register (0x29) is reserved.

**Register (0x2A)** contains the timing definitions for the single tap and double tap interrupts.

(0x2A) tap\_quiet = "0" ("1") selects a quiet duration of 30 ms (20 ms). The default value of (0x2A) tap\_quiet is "0".

(0x2A) tap\_shock = "0" ("1") selects a shock duration of 50 ms (75 ms). The default value of (0x2A) tap\_shock is "0".

(0x2A)  $tap\_dur$  selects the length of the time window for the second shock event (for double tap detection). The settings for (0x2A)  $tap\_dur$  are "000b" (50 ms), "001b" (100 ms), "010b" (150 ms), "011b" (200 ms), "100b" (250 ms), "101b" (375 ms), "110b" (500 ms), "111b" (700 ms). The default value of (0x2A)  $tap\_dur$  is "100b".

Table 56: Tap Quiet duration and tap shock duration, register (0x2A)

| Bit 7 | Bit 6 | Bit 5    | Bit 4    | Bit 3    | Bit 2  | Bit 1  | Bit 0  |
|-------|-------|----------|----------|----------|--------|--------|--------|
| tap_  | tap_  | reserved | reserved | reserved | tap_   | tap_   | tap_   |
| quiet | shock |          |          |          | dur<2> | dur<1> | dur<0> |

**Register** (0x2B) contains the definition of the number of samples to be processed after wake-up in low-power mode and the threshold definition for the single and double tap interrupts. (0x2B)  $tap\_samp$  selects the number of samples that are processed after wake-up in the low-power mode. The settings for (0x2B)  $tap\_samp$  are "00b" (2 samples), "01b" (4 samples), "10b" (8 samples), and "11b" (16 samples). Default value of (0x2B)  $tap\_samp$  is "00b".

Page 62 Confidential

The meaning of an LSB of (0x2B) tap\_th depends on the selected g-range. It corresponds to an acceleration difference of 62.5mg in 2g-range, 125mg in 4g-range, 250mg in 8g-range, and 500mg in 16g-range. Default value of (0x2B) tap\_th is 0x0A.

Table 57: Samples number after wake-up and threshold tap interrupt, register (0x2B)

| Bit 7   | Bit 6   | Bit 5    | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|---------|----------|-------|-------|-------|-------|-------|
| tap_    | tap_    | reserved | tap_  | tap_  | tap_  | tap_  | tap_  |
| samp<1> | samp<0> |          | th<4> | th<3> | th<2> | th<1> | th<0> |

**Register** (0x2C) contains the definition of hysteresis, blocking, and mode for the orientation interrupt. (0x2C) orient\_hyst sets the hysteresis of the orientation interrupt; 1 LSB always corresponds to 62.5 mg, in any g-range (i.e. increment is independent from g-range setting). Default value of (0x2C) orient\_hyst is "001b".

(0x2C) orient\_blocking selects the kind of blocking that is used for the generation of the orientation interrupt. The settings for (0x2C) orient\_blocking are "00b" (no blocking), "01b" (theta blocking), "10b" (theta blocking or slope in any axis > 0.2 g), and "11b" (orient value not stable for at least 100 ms or theta blocking or slope in any axis > 0.4 g). Default value of (0x2C) orient\_blocking is "10b".

(0x2C) orient\_mode sets the thresholds for switching between the different orientations. The settings for (0x2C) orient\_mode are "00b" (symmetrical), "01b" (high-asymmetrical), "10b" (low-asymmetrical), "11b" (symmetrical). Default value of (0x2C) orient\_mode is "00b".

Table 58: Hysteresis, Blocking for Orientation Interrupt, Register (0x2C)

| Bit 7    | Bit 6             | Bit 5                                  | Bit 4             | Bit 3        | Bit 2                  | Bit 1             | Bit 0                                  |
|----------|-------------------|----------------------------------------|-------------------|--------------|------------------------|-------------------|----------------------------------------|
| reserved | orient_<br>hvst<2 | orient_<br>hvst<1                      | orient_<br>hvst<0 | orient_      | orient_<br>blocking<0> | orient_<br>mode<1 | orient_<br>mode<0                      |
|          | 11y3t\2<br>>      | ////////////////////////////////////// | 11y3t<0<br>>      | DIOCKING \1> | Diocking \0>           | >                 | ////////////////////////////////////// |

**Register** (0x2D) contains the definition of the theta blocking angle for the orientation interrupt. (0x2D) orient\_theta defines a blocking angle between 0° and 44.8° as described in chapter 4.8.7.1. Default value of (0x2D) orient\_theta is 0x08.

Table 59: Theta blocking angle, register (0x2D)

| Bit 7    | Bit 6    | Bit 5    | Bit 4    | Bit 3    | Bit 2                  | Bit 1                  | Bit 0    |
|----------|----------|----------|----------|----------|------------------------|------------------------|----------|
| reserved | reserved | orient_  | orient_  | orient_  | orient_                | orient_                | orient_  |
|          |          | theta<5> | theta<4> | theta<3> | theta $<\overline{2}>$ | theta $<\overline{1}>$ | theta<0> |

**Register** (0x2E) contains the definition of the flat threshold angle for the flat interrupt. (0x2E) flat\_theta defines a blocking angle between 0° and 44.8° as described in chapter 4.8.8. Default value of (0x2E) flat\_theta is 0x08.

Table 60: Flat threshold angle, register (0x2E)

| Bit 7    | Bit 6    | Bit 5    | Bit 4    | Bit 3    | Bit 2    | Bit 1    | Bit 0    |
|----------|----------|----------|----------|----------|----------|----------|----------|
| reserved | reserved | flat_    | flat_    | flat_    | flat_    | flat_    | flat_    |
|          |          | theta<5> | theta<4> | theta<3> | theta<2> | theta<1> | theta<0> |



Page 63 Confidential

**Register** (0x2F) contains the definition of the flat hold time. (0x2F) flat\_hold\_time defines the time a new flat value has to be at least stable for before the interrupt is generated. The settings for (0x2F) flat\_hold\_time are "00b" (0), "01b" (512 ms), "10b" (1024 ms), "11b" (2048 ms). Default value of (0x2F) flat\_hold\_time is "01b".

Table 61: Flat threshold angle, register (0x2F)

| Bit 7    | Bit 6    | Bit 5                 | Bit 4                 | Bit 3    | Bit 2    | Bit 1    | Bit 0    |
|----------|----------|-----------------------|-----------------------|----------|----------|----------|----------|
| reserved | reserved | flat_hold_<br>time<1> | flat_hold_<br>time<0> | reserved | reserved | reserved | reserved |

Register (0x30) and (0x31) are reserved.



Page 64 Confidential

#### 5.12 Self-test

**Register (0x32)** contains the settings for the activation of the sensor self-test.

(0x32) self\_test\_sign sets the sign of the electrostatic excitation. The settings for (0x32) self\_test\_sign are "0" (positive sign) and "1" (negative sign). Default value of (0x32) self\_test\_sign is "0".

(0x32) self\_test\_axis defines the axis which shall be excited. Only one axis can be excited at the same time. The settings for (0x32) self\_test\_axis are "00b" (no self-test), "01" (x-axis), "10" (y-axis), and "11" (z-axis). Default value of (0x32) self\_test\_axis is "00b".

Table 62: Sensor self-test, register (0x32)

| Bit 7    | Bit 6    | Bit 5    | Bit 4    | Bit 3    | Bit 2     | Bit 1     | Bit 0     |
|----------|----------|----------|----------|----------|-----------|-----------|-----------|
| reserved | reserved | reserved | reserved | reserved | self_test | self_test | self_test |
|          |          |          |          |          | _sign     | _axis<1>  | _axis<0>  |



Page 65 Confidential

## 5.13 Non-volatile memory control (EEPROM control)

**Register** (0x33) contains the control settings for the non-volatile memory (EEPROM). (0x33) nvm\_load is used to perform a user-defined image update. Writing "1" (0x33) nvm\_load starts the update procedure. The value "1" is kept as long as the update procedure runs, afterwards it is reset to "0".

(0x33) nvm\_rdy contains the status of writing the EEPROM. (0x33) nvm\_rdy is "0" as long as writing the EEPROM endures, it is "1" if currently no write access is performed and, therefore, a new write access can be initiated.

Writing "1" to (0x33) nvm\_prog\_trig triggers writing the EEPROM. The EEPROM can only be written if it was unlocked before.

Writing "1" to (0x33) nvm\_prog\_mode unlocks the EEPROM.

Table 63: EEPROM control settings, register (0x33)

| Bit 7    | Bit 6    | Bit 5    | Bit 4    | Bit 3    | Bit 2   | Bit 1             | Bit 0             |
|----------|----------|----------|----------|----------|---------|-------------------|-------------------|
| reserved | reserved | reserved | reserved | nvm_load | nvm_rdy | nvm_prog<br>_trig | nvm_prog<br>_mode |



Page 66 Confidential

## 5.14 Interface configuration

**Register** (0x34) contains the settings for the digital interfaces. Writing "1" to (0x34)  $i2c_wdt_en$  enables the watchdog at the SDI pin (= SDA for I<sup>2</sup>C) if I<sup>2</sup>C is selected. Default value of (0x34)  $i2c_wdt_en$  is "0".

(0x34) i2c\_wdt\_sel selects the l<sup>2</sup>C data pad watchdog timer period. The settings for (0x34) i2c\_wdt\_sel are "0" (1 ms) and "1" (50 ms). Default value of (0x34) i2c\_wdt\_sel is "0".

(0x34) spi3 selects the SPI mode. The settings for (0x34) spi3 are "0" (4-wire SPI) and "1" (3-wire SPI). Default value of (0x34) spi3 is "0".

Table 64: EEPROM control settings, register (0x34)

| Bit 7    | Bit 6    | Bit 5    | Bit 4    | Bit 3    | Bit 2   | Bit 1   | Bit 0 |
|----------|----------|----------|----------|----------|---------|---------|-------|
| reserved | reserved | reserved | reserved | reserved | i2c_wdt | i2c_wdt | spi3  |
|          |          |          |          |          | _en     | _sel    |       |

Register (0x35) is reserved.

Page 67 Confidential

#### 5.15 Offset compensation

**Register** (0x36) contains settings for the offset compensation in general, for fast offset compensation, and for slow offset compensation. Writing "1" to (0x36) offset\_reset sets all offset compensation registers (0x38 to 0x3D) to zero.

Default value of (0x36) offset reset is "0".

(0x36) cal\_trigger starts the fast compensation process for the specified axis. The settings for (0x36) cal\_trigger are "00b" (no axis selected), "01b" (x-axis), "10b" (y-axis), "11b" (z-axis). A non-zero value is kept until the fast compensation procedure is finished. Default value of (0x36) cal\_trigger is "00b".

(0x36) cal\_rdy indicates the state of the fast compensation. (0x36) cal\_rdy is "0" when (0x36) cal\_trigger has a nonzero value, otherwise (0x36) cal\_rdy is "1".

Writing "1" ("0") to (0x36)  $hp\_z\_en$  enables (disables) slow offset compensation for the z-axis. Writing "1" ("0") to (0x36)  $hp\_y\_en$  enables (disables) slow offset compensation for the y-axis. Writing "1" ("0") to (0x36)  $hp\_x\_en$  enables (disables) slow offset compensation for the x-axis. Default value for each of (0x36)  $hp\_x\_en$ , (0x36)  $hp\_y\_en$ , and (0x36)  $hp\_x\_en$  is "0", respectively.

Table 65: Offset compensation, fast offset compensation, register (0x36)

| Bit 7  | Bit 6      | Bit 5 | Bit 4   | Bit 3    | Bit 2   | Bit 1   | Bit 0   |
|--------|------------|-------|---------|----------|---------|---------|---------|
| offset | cal_       | cal_  | cal_rdy | reserved | hp_z_en | hp_y_en | hp_x_en |
| _reset | trigger<1> |       |         |          |         |         |         |

**Register** (0x37) contains settings for the offset compensation in general, and for slow offset compensation. (0x37) offset\_target\_z sets the target value for the offset compensation of the z-axis.

(0x37) offset\_target\_y sets the target value for the offset compensation of the y-axis. (0x37) offset\_target\_x sets the target value for the offset compensation of the x-axis. The settings for (0x37) offset\_target\_x, (0x37) offset\_target\_y, and (0x37) offset\_target\_z are "00b" (0 g), "01b" (+1 g), "10b" (-1 g), and "11b" (0 g). Default value of each of (0x37) offset\_target\_x, (0x37) offset\_target\_y, and (0x37) offset\_target\_z is "00b", respectively.

(0x37) cut\_off defines the number of samples for comparison by the slow offset compensation. The settings for (0x37) cut\_off are "0" (8 samples) and "1" (16 samples). The default value of (0x37) cut\_off is "0".

Table 66: Offset compensation, slow offset compensation, register (0x37)

| Bit 7   | Bit 6     | Bit 5     | Bit 4     | Bit 3     | Bit 2     | Bit 1     | Bit 0   |
|---------|-----------|-----------|-----------|-----------|-----------|-----------|---------|
| reserve | offset_ta | offset_ta | offset_ta | offset_ta | offset_ta | offset_ta | cut_off |
| d       | rget_z<   | rget_z<   | rget_y<   | rget_y<   | rget_x<   | rget_x<   |         |
|         | 1>        | 0>        | 1>        | 0>        | 1>        | 0>        |         |

**Register** (0x38) contains the compensation value for filtered data for the x-axis. The contents of each of the registers (0x38) to (0x3D) is added to the corresponding acceleration data; it can be set either automatically by one of the implemented compensation algorithms or manually. These

Page 68 Confidential

registers are image registers of registers in the EEPROM; the content of the EEPROM is copied to them after every reset.

Table 67: Filtered data compensation for the x-axis, register (0x38)

| Bit 7          | Bit 6                     | Bit 5                  | Bit 4                     | Bit 3          | Bit 2       | Bit 1                  | Bit 0       |
|----------------|---------------------------|------------------------|---------------------------|----------------|-------------|------------------------|-------------|
| offset_        | offset_                   | offset_                | offset_                   | offset_        | offset_     | offset_                | offset_     |
| filt $x < 7 >$ | filt $x < \overline{6} >$ | filt $x<\overline{5}>$ | filt $x < \overline{4} >$ | filt $x < 3 >$ | filt $x<2>$ | filt $x<\overline{1}>$ | filt $x<0>$ |

**Register (0x39)** contains the compensation value for filtered data for the y-axis.

Table 68: Filtered data compensation for the y-axis, register (0x39)

| Bit 7                     | Bit 6                     | Bit 5                     | Bit 4                     | Bit 3                  | Bit 2                  | Bit 1                     | Bit 0                  |
|---------------------------|---------------------------|---------------------------|---------------------------|------------------------|------------------------|---------------------------|------------------------|
| offset_                   | offset_                   | offset_                   | offset_                   | offset_                | offset_                | offset_                   | offset_                |
| filt $y < \overline{7} >$ | filt $y < \overline{6} >$ | filt $y < \overline{5} >$ | filt $y < \overline{4} >$ | filt $y<\overline{3}>$ | filt $y<\overline{2}>$ | filt $y < \overline{1} >$ | filt $y<\overline{0}>$ |

**Register (0x3A)** contains the compensation value for filtered data for the z-axis.

Table 69: Filtered data compensation for the z-axis, register (0x3A)

| Bit 7     | Bit 6     | Bit 5     | Bit 4     | Bit 3     | Bit 2     | Bit 1     | Bit 0     |
|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| offset_   |
| filt_z<7> | filt_z<6> | filt_z<5> | filt_z<4> | filt_z<3> | filt_z<2> | filt_z<1> | filt_z<0> |

**Register (0x3B)** contains the compensation value for unfiltered data for the x-axis.

Table 70: Unfiltered data compensation for the x-axis, register (0x3B)

| Bit 7    | Bit 6    | Bit 5    | Bit 4    | Bit 3    | Bit 2    | Bit 1    | Bit 0    |
|----------|----------|----------|----------|----------|----------|----------|----------|
| offset_  |
| unfilt_x |
| <7>      | <6>      | <5>      | <4>      | <3>      | <2>      | <1>      | <0>      |

**Register (0x3C)** contains the compensation value for unfiltered data for the y-axis.

Table 71: Unfiltered data compensation for the x-axis, register (0x3C)

| Bit 7    | Bit 6    | Bit 5    | Bit 4    | Bit 3    | Bit 2    | Bit 1    | Bit 0    |
|----------|----------|----------|----------|----------|----------|----------|----------|
| offset_  |
| unfilt_y |
| <7>      | <6>      | <5>      | <4>      | <3>      | <2>      | <1>      | <0>      |

**Register (0x3D)** contains the compensation value for unfiltered data for the z-axis.

Table 72: Unfiltered data compensation for the y-axis, register (0x3D)

| Bit 7    | Bit 6    | Bit 5            | Bit 4    | Bit 3    | Bit 2    | Bit 1    | Bit 0    |
|----------|----------|------------------|----------|----------|----------|----------|----------|
| offset_  | offset_  | offset_          | offset_  | offset_  | offset_  | offset_  | offset_  |
| unfilt_z | unfilt_z | unfilt_z         | unfilt_z | unfilt_z | unfilt_z | unfilt_z | unfilt_z |
| <7>      | <6>      | <i>&lt;5&gt;</i> | <4>      | <3>      | <2>      | <1>      | <0>      |

**Registers** (0x3E) and (0x3F) are image registers of registers in the EEPROM. They are not linked to any sensor-specific functionality.

Page 69 Confidential

# 6. Magnetometer register description

#### 6.1 General remarks

The entire communication with the device's magnetometer part is performed by reading from and writing to registers. Registers have a width of 8 bits; they are mapped to a common space of 50 addresses from (0x40) up to (0x71). Within the used range there are several registers which are marked as 'reserved'. Any reserved bit is ignored when it is written and no specific value is guaranteed when read. Especially, in SPI mode the SDO pin may stay in high-Z state when reading some of these registers.

Registers with addresses from (0x40) up to (0x4A) are read-only. Any attempt to write to these registers is ignored.

## 6.2 Register map

| Register Address | Default Value | bit7              | bit6                                             | bit5          | bit4                      | bit3                          | bit2         | bit1            | bit0               |
|------------------|---------------|-------------------|--------------------------------------------------|---------------|---------------------------|-------------------------------|--------------|-----------------|--------------------|
| 0x71             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x70             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x6F             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x6E             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x6D             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x6C             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x6B             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x6A             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x69             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x68             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x67             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x66             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x65             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x64             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x63             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x62             | N/A           |                   |                                                  |               | rese                      | erved                         |              |                 |                    |
| 0x61             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x60             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x5F             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x5E             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x5D             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x5C             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x5B             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x5A             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x59             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x58             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x57             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x56             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x55             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x54             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x53             | N/A           |                   |                                                  |               |                           |                               |              |                 |                    |
| 0x52             | 0x00          |                   |                                                  |               | REPZ Number Of Rep        | etitions (valid for Z) [7:0]  |              |                 |                    |
| 0x51             | 0x00          |                   |                                                  |               | REPXY Number Of Repo      | etitions (valid for XY) [7:0] |              |                 |                    |
| 0x50             | 0x00          |                   |                                                  |               | High Thre                 | eshold [7:0]                  |              |                 |                    |
| 0x4F             | 0x00          |                   |                                                  |               |                           | shold [7:0]                   |              |                 |                    |
| 0x4E             | 0x07          | Data Ready Pin En | Interrupt Pin En                                 | Channel Z     | Channel Y                 | Channel X                     | DR Polarity  | Interrupt Latch | Interrupt Polarity |
| 0X4D             | 0x3F          | Data Overrun En   | Overflow Int En                                  | High Int Z en | High Int Y en             | High Int X en                 | Low Int Z en | Low Int Y en    | Low Int X en       |
| 0x4C             | 0x06          |                   | T [1:0]                                          |               | Data Rate [2:0]           |                               |              | de [1:0]        | Self Test          |
| 0x4B             | 0x01          | Soft Reset '1'    | fixed '0'                                        | fixed '0'     | fixed '0'                 | fixed '0'                     | SPI3en       | Soft Reset '1'  | Power Control Bit  |
| 0x4A             | 0x00          | Data Overrun      | Overflow                                         | High Int Z    | High Int Y                | High Int X                    | Low Int Z    | Low Int Y       | Low Int X          |
| 0x49             | N/A           |                   | RHALL [13:6] MSB                                 |               |                           |                               |              |                 |                    |
| 0x48             | N/A           |                   | RHALL [5:0] LSB fixed '0' Data Ready Statu       |               |                           |                               |              |                 |                    |
| 0x47             | N/A           |                   | DATA Z [14:7] MSB                                |               |                           |                               |              |                 |                    |
| 0x46             | N/A           |                   |                                                  |               |                           |                               |              |                 | Z-Self-Test        |
| 0x45             | N/A           | DATA Y [12:5] MSB |                                                  |               |                           |                               |              |                 |                    |
| 0x44             | N/A           |                   | DATA Y (4:0) LSB fixed '0' fixed '0' Y-Self-Test |               |                           |                               |              |                 |                    |
| 0x43             | N/A           |                   | DATA X [12:5] MSB                                |               |                           |                               |              |                 |                    |
| 0x42             | N/A           |                   | DATA X [4:0] LSB fixed '0' fixed '0' X-Self-Test |               |                           |                               |              |                 |                    |
| 0x41             | N/A           |                   |                                                  |               |                           | erved                         |              |                 |                    |
| 0x40             | 0x32          |                   |                                                  | Chi           | ip ID = 0x32 (can only be | read if power control bit =   | -"1")        |                 |                    |



Page 70 Confidential

## 6.3 Chip ID

**Register** (0x40) Chip ID contains the magnetometer chip identification number, which is 0x32. This number can only be read if the power control bit (register 0x4B bit0) is enabled.

Table 73: Chip identification number, register (0x40)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 1     | 1     | 0     | 0     | 1     | 0     |

Register (0x01) is reserved

## 6.4 Magnetic field data

**Register** (0x42) contains the LSB part of x-axis magnetic field data and the self-test result flag for the x-axis.

Table 74: LSB part of x-axis magnetic field, register (0x42)

| (0x42) Bit | Name          | Description                                      |
|------------|---------------|--------------------------------------------------|
| Bit 7      | DATAX_lsb <4> | Bit 4 of x-axis magnetic field data              |
| Bit 6      | DATAX_lsb <3> | Bit 3 of x-axis magnetic field data              |
| Bit 5      | DATAX_lsb <2> | Bit 2 of x-axis magnetic field data              |
| Bit 4      | DATAX_lsb <1> | Bit 1 of x-axis magnetic field data              |
| Bit 3      | DATAX_lsb <0> | Bit 0 of x-axis magnetic field data = x LSB      |
| Bit 2      | -             | (fixed to 0)                                     |
| Bit 1      | •             | (fixed to 0)                                     |
| Bit 0      | SelfTestX     | Self-test result flag for x-axis, default is "1" |

**Register (0x43)** contains the MSB part of x-axis magnetic field data.

Table 75: MSB part of x-axis magnetic field, register (0x43)

| (0x43)<br>Bit | Name           | Description                                  |
|---------------|----------------|----------------------------------------------|
| Bit 7         | DATAX_msb <12> | Bit 12 of x-axis magnetic field data = x MSB |
| Bit 6         | DATAX_msb <11> | Bit 11 of x-axis magnetic field data         |
| Bit 5         | DATAX_msb <10> | Bit 10 of x-axis magnetic field data         |
| Bit 4         | DATAX_msb <9>  | Bit 9 of x-axis magnetic field data          |
| Bit 3         | DATAX_msb <8>  | Bit 8 of x-axis magnetic field data          |
| Bit 2         | DATAX_msb <7>  | Bit 7 of x-axis magnetic field data          |
| Bit 1         | DATAX_msb <6>  | Bit 6 of x-axis magnetic field data          |
| Bit 0         | DATAX_msb <5>  | Bit 5 of x-axis magnetic field data          |

Page 71 Confidential

**Register (0x44)** contains the LSB part of y-axis magnetic field data and the self-test result flag for the y-axis.

Table 76: LSB part of y-axis magnetic field, register (0x44)

| (0x44) Bit | Name          | Description                                      |
|------------|---------------|--------------------------------------------------|
| Bit 7      | DATAY_lsb <4> | Bit 4 of y-axis magnetic field data              |
| Bit 6      | DATAY_lsb <3> | Bit 3 of y-axis magnetic field data              |
| Bit 5      | DATAY_lsb <2> | Bit 2 of y-axis magnetic field data              |
| Bit 4      | DATAY_lsb <1> | Bit 1 of y-axis magnetic field data              |
| Bit 3      | DATAY_lsb <0> | Bit 0 of y-axis magnetic field data = y LSB      |
| Bit 2      | -             | (fixed to 0)                                     |
| Bit 1      | -             | (fixed to 0)                                     |
| Bit 0      | SelfTestY     | Self-test result flag for y-axis, default is "1" |

Register (0x45) contains the MSB part of y-axis magnetic field data.

Table 77: MSB part of y-axis magnetic field, register (0x45)

| (0x43) | Name           | Description                                  |
|--------|----------------|----------------------------------------------|
| Bit    |                |                                              |
| Bit 7  | DATAY_msb <12> | Bit 12 of y-axis magnetic field data = y MSB |
| Bit 6  | DATAY_msb <11> | Bit 11 of y-axis magnetic field data         |
| Bit 5  | DATAY_msb <10> | Bit 10 of y-axis magnetic field data         |
| Bit 4  | DATAY_msb <9>  | Bit 9 of y-axis magnetic field data          |
| Bit 3  | DATAY_msb <8>  | Bit 8 of y-axis magnetic field data          |
| Bit 2  | DATAY_msb <7>  | Bit 7 of y-axis magnetic field data          |
| Bit 1  | DATAY_msb <6>  | Bit 6 of y-axis magnetic field data          |
| Bit 0  | DATAY_msb <5>  | Bit 5 of y-axis magnetic field data          |

**Register (0x46)** contains the LSB part of z-axis magnetic field data and the self-test result flag for the z-axis.

Table 78: LSB part of z-axis magnetic field, register (0x44)

| (0x44) Bit | Name          | Description                                      |
|------------|---------------|--------------------------------------------------|
| Bit 7      | DATAZ_lsb <6> | Bit 6 of z-axis magnetic field data              |
| Bit 6      | DATAZ_lsb <5> | Bit 5 of z-axis magnetic field data              |
| Bit 5      | DATAZ_lsb <4> | Bit 4 of z-axis magnetic field data              |
| Bit 4      | DATAZ_lsb <3> | Bit 3 of z-axis magnetic field data              |
| Bit 3      | DATAZ_lsb <2> | Bit 2 of z-axis magnetic field data              |
| Bit 2      | DATAZ_lsb <1> | Bit 1 of z-axis magnetic field data              |
| Bit 1      | DATAZ_lsb <0> | Bit 0 of z-axis magnetic field data = z LSB      |
| Bit 0      | SelfTestZ     | Self-test result flag for z-axis, default is "1" |

Page 72 Confidential

**Register (0x47)** contains the MSB part of z-axis magnetic field data.

Table 79: MSB part of z-axis magnetic field, register (0x45)

| (0x45)<br>Bit | Name           | Description                                  |
|---------------|----------------|----------------------------------------------|
| Bit 7         | DATAZ_lsb <14> | Bit 14 of y-axis magnetic field data = z MSB |
| Bit 6         | DATAZ_lsb <13> | Bit 13 of y-axis magnetic field data         |
| Bit 5         | DATAZ_lsb <12> | Bit 12 of y-axis magnetic field data         |
| Bit 4         | DATAZ_lsb <11> | Bit 11 of y-axis magnetic field data         |
| Bit 3         | DATAZ_lsb <10> | Bit 10 of y-axis magnetic field data         |
| Bit 2         | DATAZ lsb <9>  | Bit 9 of y-axis magnetic field data          |
| Bit 1         | DATAZ_lsb <8>  | Bit 8 of y-axis magnetic field data          |
| Bit 0         | DATAZ lsb <7>  | Bit 7 of y-axis magnetic field data          |

Register (0x48) contains the LSB part of hall resistance and the Data Ready (DRDY) status bit.

Table 80: LSB part of hall resistance, register (0x46)

| (0x46) Bit | Name              | Description                          |
|------------|-------------------|--------------------------------------|
| Bit 7      | RHALL_lsb <5>     | Bit 5 of hall resistance             |
| Bit 6      | RHALL_lsb <4>     | Bit 4 of hall resistance             |
| Bit 5      | RHALL_lsb <3>     | Bit 3 of hall resistance             |
| Bit 4      | RHALL _lsb <2>    | Bit 2 of hall resistance             |
| Bit 3      | RHALL_lsb <1>     | Bit 1 of hall resistance             |
| Bit 2      | RHALL _lsb <0>    | Bit 0 of hall resistance = RHALL LSB |
| Bit 1      | -                 | (fixed to 0)                         |
| Bit 0      | Data Ready Status | Data ready (DRDY) status bit         |

Register (0x49) contains the MSB part of hall resistance.

Table 81: MSB part of hall resistance, register (0x47)

| (0x47) | Name           | Description                           |
|--------|----------------|---------------------------------------|
| Bit    |                |                                       |
| Bit 7  | RHALL_msb <13> | Bit 13 of hall resistance = RHALL MSB |
| Bit 6  | RHALL_msb <12> | Bit 12 of hall resistance             |
| Bit 5  | RHALL_msb <11> | Bit 11 of hall resistance             |
| Bit 4  | RHALL_msb <10> | Bit 10 of hall resistance             |
| Bit 3  | RHALL_msb <9>  | Bit 9 of hall resistance              |
| Bit 2  | RHALL_msb <8>  | Bit 8 of hall resistance              |
| Bit 1  | RHALL_msb <7>  | Bit 7 of hall resistance              |
| Bit 0  | RHALL_msb <6>  | Bit 6 of hall resistance              |

Page 73 Confidential

#### 6.5 Interrupt status register

**Register (0x4A)** contains the states of all magnetometer interrupts.

Table 82: Interrupt status, register (0x4A)

| (0x4A)<br>Bit | Name         | Description                                 |  |
|---------------|--------------|---------------------------------------------|--|
| Bit 7         | Data overrun | Data overrun status flag                    |  |
| Bit 6         | Overflow     | Overflow status flag                        |  |
| Bit 5         | High Int Z   | High-Threshold interrupt z-axis status flag |  |
| Bit 4         | High Int Y   | High-Threshold interrupt y-axis status flag |  |
| Bit 3         | High Int X   | High-Threshold interrupt x-axis status flag |  |
| Bit 2         | Low Int Z    | Low-Threshold interrupt z-axis status flag  |  |
| Bit 1         | Low Int Y    | Low-Threshold interrupt y-axis status flag  |  |
| Bit 0         | Low Int X    | Low-Threshold interrupt x-axis status flag  |  |

#### 6.6 Power and operation modes, self-test and data output rate control registers

**Register** (0x4B) contains control bits for power control, soft reset and interface SPI mode selection. This special control register is also accessible in suspend mode.

Soft reset is executed when both bits (register 0x4B bit7 and bit1) are set "1". Soft reset does not execute a full POR sequence, but all registers are reset except for the "trim" registers above register 0x54 and the power control register (0x4B). Soft reset always brings the device into sleep mode. When device is in the suspend mode, soft reset is ignored and the device remains in suspend mode. The two "Soft Reset" bits are reset to "0" automatically after soft reset was completed.

When SPI mode is selected, the "SPI3En" bit enables SPI 3-wire mode when set "1". When "SPI3En" is set "0" (default), 4-wire SPI mode is selected.

Setting the "Power Control bit" to "1" brings the device up from Suspend mode to Sleep mode, when "Power Control bit" is set "0" the device returns to Suspend mode (see chapter 4.3.2 for details of magnetometer power modes).

Table 83: Power control, soft reset and SPI mode control register (0x4B)

| (0x4B) | Name Description  |                                                             |  |
|--------|-------------------|-------------------------------------------------------------|--|
| Bit    |                   |                                                             |  |
| Bit 7  | Soft Reset '1'    | One of the soft reset trigger bits.                         |  |
| Bit 6  | -                 | (fixed to 0)                                                |  |
| Bit 5  | -                 | (fixed to 0)                                                |  |
| Bit 4  | -                 | (fixed to 0)                                                |  |
| Bit 3  | -                 | (fixed to 0)                                                |  |
| Bit 2  | SPI3en            | Enable bit for SPI3 mode                                    |  |
| Bit 1  | Soft Reset '1'    | oft Reset '1' One of the soft reset trigger bits.           |  |
| Bit 0  | Power Control bit | Power Control bit When set to "0", suspend mode is selected |  |



Page 74 Confidential

Register (0x4C) contains control bits for operation mode, output data rate and self-test.

The two "Adv. ST" bits control the on-chip advanced self-test (see chapter 4.5.2 for details of the magnetometer advanced self-test).

The three "Data rate" bits control the magnetometer output data rate according to below Table 85.

The two "Opmode" bits control the operation mode according to below Table 86 (see chapter 4.3.2 for a detailed description of magnetometer power modes).

Table 84: Operation mode, output data rate and self-test control register (0x4C)

| (0x4C)<br>Bit | Name          | Description                      |  |
|---------------|---------------|----------------------------------|--|
| Bit 7         | Adv. ST <1>   | Advanced self-test control bit 1 |  |
| Bit 6         | Adv. ST <0>   | Advanced self-test control bit 0 |  |
| Bit 5         | Data rate <2> | Data rate control bit 2          |  |
| Bit 4         | Data rate <1> | Data rate control bit 1          |  |
| Bit 3         | Data rate <0> | Data rate control bit 0          |  |
| Bit 2         | Opmode <1>    | Operation mode control bit 1     |  |
| Bit 1         | Opmode <0>    | Operation mode control bit 0     |  |
| Bit 0         | Self Test     | Normal self-test control bit     |  |

Three "Data rate" bits control the output data rate (ODR) of the BMC050 magnetometer part:

Table 85: Output data rate (ODR) setting (0x4C)

| (0x4C)<br>Data rate <2:0> | Magnetometer output data rate (ODR) |
|---------------------------|-------------------------------------|
| 000b                      | 10 (default)                        |
| 001b                      | 2                                   |
| 010b                      | 6                                   |
| 011b                      | 8                                   |
| 100b                      | 15                                  |
| 101b                      | 20                                  |
| 110b                      | 25                                  |
| 111b                      | 30                                  |

Two "Data rate" bits control the operation mode of the BMC050 magnetometer part:

Table 86: Operation mode setting (0x4C)

| (0x4C)<br>Opmode <1:0> | Magnetometer operation mode <sup>4</sup> |
|------------------------|------------------------------------------|
| 00b                    | Normal mode                              |
| 01b                    | Forced mode                              |
| 10b                    | Reserved, do not use                     |
| 11b                    | Sleep Mode                               |

<sup>&</sup>lt;sup>4</sup> See chapter 4.3.2 for a detailed description of magnetometer power modes.

BST-BMC050-DS000-10 | Revision 1.0 | October 2011

Bosch Sensortec



Page 75 Confidential

## 6.7 Interrupt and axis enable settings control registers

**Register** (0x4D) contains control bits for interrupt settings. (Also refer to chapter 4.9 for the details of magnetometer interrupt operation).

Table 87: Interrupt settings control register (0x4D)

| (0x4D)<br>Bit | Name            | Description                                                                                                       |  |
|---------------|-----------------|-------------------------------------------------------------------------------------------------------------------|--|
| Bit 7         | Data Overrun En | Enables data overrun indication in the "Data Overrun" flag (active high, default is "0" disabled)                 |  |
| Bit 6         | Overflow Int En | Overflow Int En  Activates mapping of Overflow flag status to the INT3 pin (active high, default is "0" disabled) |  |
| Bit 5         | High Int Z En   | Enables the z-axis detection for High-Threshold interrupts (active low, default is "1" disabled)                  |  |
| Bit 4         | High Int Y En   | Enables the y-axis detection for High-Threshold interrupts (active low, default is "1" disabled)                  |  |
| Bit 3         | High Int X En   | Enables the x-axis detection for High-Threshold interrupts (active low, default is "1" disabled)                  |  |
| Bit 2         | Low Int Z En    | Enables the z-axis detection for Low-Threshold interrupts (active low, default is "1" disabled)                   |  |
| Bit 1         | Low Int Y En    | Enables the y-axis detection for Low-Threshold interrupts (active low, default is "1" disabled)                   |  |
| Bit 0         | Low Int X En    | Enables the x-axis detection for Low-Threshold interrupts (active low, default is "1" disabled)                   |  |

Page 76 Confidential

**Register** (0x4E) contains control bits interrupt settings and axes enable bits. (Also refer to chapter 4.9 for the details of magnetometer interrupt operation). If a magnetic measurement channel is disabled, its last measured magnetic output values will remain in the data registers. If the Z channel is disabled, the resistance measurement will also be disabled and the resistance output value will be set to zero. If interrupts are set to trigger on an axis that has been disabled, these interrupts will still be asserted based on the last measured value.

Table 88: Interrupt settings and axes enable bits control register (0x4E)

| (0x4E)<br>Bit | Name               | Description                                                                                                                                                                                                          |  |
|---------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit 7         | Data Ready Pin En  | Enables data ready status mapping on DRDY pin (active high, default is "0" disabled)                                                                                                                                 |  |
| Bit 6         | Interrupt Pin En   | Enables interrupt status mapping on INT3 pin (active high, default is "0" disabled)                                                                                                                                  |  |
| Bit 5         | Channel Z          | Enable z-axis and resistance measurement (active low, default is "0" enabled)                                                                                                                                        |  |
| Bit 4         | Channel Y          | Enable y-axis (active low, default is "0" enabled)                                                                                                                                                                   |  |
| Bit 3         | Channel X          | Enable x-axis (active low, default is "0" enabled)                                                                                                                                                                   |  |
| Bit 2         | DR Polarity        | Data ready (DRDY) pin polarity ("0" is active low, "1" is active high, default is "1" active high)                                                                                                                   |  |
| Bit 1         | Interrupt Latch    | Interrupt latching ("0" means non-latched - interrupt pin is on as long as the condition is fulfilled, "1" means latched - interrupt pin is on until interrupt status register 0x4A is read, default is "1" latched) |  |
| Bit 0         | Interrupt Polarity | Interrupt pin INT3 polarity selection ("1" – is active high, "0" is active low, default is "1" active high)                                                                                                          |  |

**Register** (0x4F) contains the Low-Threshold interrupt threshold setting. (Also refer to chapter 4.9 for the details of magnetometer interrupt operation and the threshold setting).

Table 89: Low-threshold interrupt threshold setting control register (0x4F)

| (0x4F) | Name             | Description                                        |
|--------|------------------|----------------------------------------------------|
| Bit    |                  |                                                    |
| Bit 7  | LowThreshold <7> | Bit 7 of Low-Threshold interrupt threshold setting |
| Bit 6  | LowThreshold <6> | Bit 6 of Low-Threshold interrupt threshold setting |
| Bit 5  | LowThreshold <5> | Bit 5 of Low-Threshold interrupt threshold setting |
| Bit 4  | LowThreshold <4> | Bit 4 of Low-Threshold interrupt threshold setting |
| Bit 3  | LowThreshold <3> | Bit 3 of Low-Threshold interrupt threshold setting |
| Bit 2  | LowThreshold <2> | Bit 2 of Low-Threshold interrupt threshold setting |
| Bit 1  | LowThreshold <1> | Bit 1 of Low-Threshold interrupt threshold setting |
| Bit 0  | LowThreshold <0> | Bit 0 of Low-Threshold interrupt threshold setting |

Page 77 Confidential

**Register** (0x50) contains the High-Threshold interrupt threshold setting. (Also refer to chapter 4.9 for the details of magnetometer interrupt operation and the threshold setting).

Table 90: High-threshold interrupt threshold setting control register (0x4F)

| (0x50) | Name              | Description                                         |
|--------|-------------------|-----------------------------------------------------|
| Bit    |                   |                                                     |
| Bit 7  | HighThreshold <7> | Bit 7 of High-Threshold interrupt threshold setting |
| Bit 6  | HighThreshold <6> | Bit 6 of High-Threshold interrupt threshold setting |
| Bit 5  | HighThreshold <5> | Bit 5 of High-Threshold interrupt threshold setting |
| Bit 4  | HighThreshold <4> | Bit 4 of High-Threshold interrupt threshold setting |
| Bit 3  | HighThreshold <3> | Bit 3 of High-Threshold interrupt threshold setting |
| Bit 2  | HighThreshold <2> | Bit 2 of High-Threshold interrupt threshold setting |
| Bit 1  | HighThreshold <1> | Bit 1 of High-Threshold interrupt threshold setting |
| Bit 0  | HighThreshold <0> | Bit 0 of High-Threshold interrupt threshold setting |

#### 6.8 Number of repetitions control registers

**Register** (0x51) contains the number of repetitions for x/y-axis. Table 92 below shows the number of repetitions resulting out of the register configuration. The performed number of repetitions nXY can be calculated from unsigned register value as nXY = 1+2xREPXY as shown below, where b7-b0 are the bits 7 to 0 of register 0x51:

$$nXY = 1 + 2 \cdot (b7 \cdot 2^7 + b6 \cdot 2^6 + b5 \cdot 2^5 + b4 \cdot 2^4 + b3 \cdot 2^3 + b2 \cdot 2^2 + b1 \cdot 2^1 + b0 \cdot 2^0)$$
  
= 1 + 2 \cdot (REPXY)

Table 91: X/y-axis repetitions control register (0x51)

|       | Name      | Description                                   |  |
|-------|-----------|-----------------------------------------------|--|
|       |           |                                               |  |
| Bit 7 | REPXY <7> | Bit 7 of number of repetitions (valid for XY) |  |
| Bit 6 | REPXY <6> | Bit 6 of number of repetitions (valid for XY) |  |
| Bit 5 | REPXY <5> | Bit 5 of number of repetitions (valid for XY) |  |
| Bit 4 | REPXY <4> | Bit 4 of number of repetitions (valid for XY) |  |
| Bit 3 | REPXY <3> | Bit 3 of number of repetitions (valid for XY) |  |
| Bit 2 | REPXY <2> | Bit 2 of number of repetitions (valid for XY) |  |
| Bit 1 | REPXY <1> | Bit 1 of number of repetitions (valid for XY) |  |
| Bit 0 | REPXY <0> | Bit 0 of number of repetitions (valid for XY) |  |

Table 92: Numbers of repetition for x/y-axis depending on value of register (0x51)

| (0x51) register | (0x51) register value | Number of repetitions for x- and y- |
|-----------------|-----------------------|-------------------------------------|
| value (binary)  | (hex)                 | axis each                           |
| 0000000b        | 0x00h                 | 1                                   |
| 00000001b       | 0x01h                 | 3                                   |
| 00000010b       | 0x02h                 | 5                                   |
| 00000011b       | 0x03h                 | 7                                   |
| •••             |                       | •••                                 |
| 11111111b       | 0xFFh                 | 511                                 |

Page 78 Confidential

**Register** (0x52) contains the number of repetitions for z-axis. Table 94 below shows the number of repetitions resulting out of the register configuration. The performed number of repetitions nZ can be calculated from unsigned register value as nZ = 1+REPZ as shown below, where b7-b0 are the bits 7 to 0 of register 0x52:

$$nZ = 1 + 1 \cdot (b7 \cdot 2^7 + b6 \cdot 2^6 + b5 \cdot 2^5 + b4 \cdot 2^4 + b3 \cdot 2^3 + b2 \cdot 2^2 + b1 \cdot 2^1 + b0 \cdot 2^0)$$
  
= 1 + REPZ

Table 93: Z-axis repetitions control register (0x52)

| (0x52)<br>Bit | Name     | Description                                  |
|---------------|----------|----------------------------------------------|
| Bit 7         | REPZ <7> | Bit 7 of number of repetitions (valid for Z) |
| Bit 6         | REPZ <6> | Bit 6 of number of repetitions (valid for Z) |
| Bit 5         | REPZ <5> | Bit 5 of number of repetitions (valid for Z) |
| Bit 4         | REPZ <4> | Bit 4 of number of repetitions (valid for Z) |
| Bit 3         | REPZ <3> | Bit 3 of number of repetitions (valid for Z) |
| Bit 2         | REPZ <2> | Bit 2 of number of repetitions (valid for Z) |
| Bit 1         | REPZ <1> | Bit 1 of number of repetitions (valid for Z) |
| Bit 0         | REPZ <0> | Bit 0 of number of repetitions (valid for Z) |

Table 94: Numbers of repetition for z-axis depending on value of register (0x52)

| (0x52) register value (binary) | (0x52) register value (hex) | Number of repetitions for z-axis |
|--------------------------------|-----------------------------|----------------------------------|
| 00000000b                      | 0x00h                       | 1                                |
| 00000001b                      | 0x01h                       | 2                                |
| 00000010b                      | 0x02h                       | 3                                |
| 00000011b                      | 0x03h                       | 4                                |
| •••                            |                             |                                  |
| 11111111b                      | 0xFFh                       | 256                              |



Page 79 Confidential

## 7. Digital interfaces

The BMC050 supports two serial digital interface protocols for communication as a slave with a host device for each of the accelerometer and magnetometer part: SPI and I<sup>2</sup>C (accelerometer part and magnetometer part only operate either both in I<sup>2</sup>C mode or either both in SPI mode, mixed communication protocols are not possible because the interface pins are shared).

The active interface is selected by the state of the two "protocol select" pins, Pin#2 (PS1) and Pin#3 (PS2): "0" ("1") selects SPI (I<sup>2</sup>C). For details see chapter 4.2.

By default, SPI operates in the standard 4-wire configuration. It can be re-configured by software to work in 3-wire mode instead of standard 4-wire mode for both the accelerometer part and magnetometer part.

Both interfaces share the same pins. The mapping for each interface is given in the following table:

Table 95: Mapping of the interface pins

| Pin# | Name              | use w/<br>SPI | use w/ I <sup>2</sup> C                                                         | Description                                                                                                                              |
|------|-------------------|---------------|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 10   | SDO               | SDO           | Accelerometer and<br>magnetometer part<br>I <sup>2</sup> C address<br>selection | SPI: Data Output (4-wire mode) I <sup>2</sup> C: Used to set LSB of I <sup>2</sup> C address of accelerometer part and magnetometer part |
| 11   | SDx               | SDI           | SDA                                                                             | SPI: Data Input (4-wire mode) Data Input / Output<br>(3-wire mode)<br>I <sup>2</sup> C: Serial Data                                      |
| 5    | CSB1 <sup>5</sup> | CSB1          | Unused, do not connect                                                          | SPI: Chip Select 1 for accelerometer part (enable)                                                                                       |
| 6    | CSB2 <sup>5</sup> | CSB2          | Magnetometer part<br>I <sup>2</sup> C address<br>selection                      | SPI: Chip Select 2 for magnetometer part (enable) I <sup>2</sup> C: Used to set bit1 of I <sup>2</sup> C address of magnetometer part    |
| 15   | SCx               | SCK           | SCL                                                                             | SPI: Serial Clock<br>I <sup>2</sup> C: Serial Clock                                                                                      |

\_

<sup>&</sup>lt;sup>5</sup> note: CSB1 and CSB2 must be operated separately and cannot be tied together.

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

Table 96: Electrical specification of the interface pins

| Parameter                                                           | Symbol                | Condition                                                                        | Min | Тур | Max | Unit |
|---------------------------------------------------------------------|-----------------------|----------------------------------------------------------------------------------|-----|-----|-----|------|
| Pull-up Resistance<br>CSB1                                          | R <sub>up, CSB1</sub> | Internal Pull-up<br>Resistance to VDDIO                                          | 70  | 120 | 190 | kΩ   |
| Pull-up Resistance<br>CSB2                                          | R <sub>up, CSB2</sub> | Internal Pull-up<br>Resistance to VDDIO;<br>deactivated in I <sup>2</sup> C mode | 80  | 100 | 120 | kΩ   |
| Input Capacitance                                                   | $C_in$                |                                                                                  |     |     | 10  | pF   |
| I <sup>2</sup> C Bus Load<br>Capacitance (max.<br>drive capability) | C <sub>I2C_Load</sub> |                                                                                  |     |     | 400 | pF   |

### 7.1 Serial peripheral interface (SPI)

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

Table 97: SPI timing for BMC050 accelerometer and magnetometer part

| Parameter        | Symbol                 | Condition                             | Min | Max | Unit |
|------------------|------------------------|---------------------------------------|-----|-----|------|
| Clock Frequency  | $f_{SPI}$              | Max. Load on SDI or<br>SDO = 25pF     |     | 10  | MHz  |
| SCK Low Pulse    | t <sub>SCKL</sub>      |                                       | 20  |     | ns   |
| SCK High Pulse   | t <sub>SCKH</sub>      |                                       | 20  |     | ns   |
| SDI Setup Time   | t <sub>SDI setup</sub> |                                       | 20  |     | ns   |
| SDI Hold Time    | $t_{SDI\_hold}$        |                                       | 20  |     | ns   |
|                  |                        | Load = 25pF                           |     | 30  | ns   |
| SDO Output Delay | t <sub>SDO_OD</sub>    | Load = $250pF$ ,<br>$V_{DDIO} = 2.4V$ |     | 40  | ns   |
| CSB Setup Time   | t <sub>CSB setup</sub> |                                       | 20  |     | ns   |
| CSB Hold Time    | $t_{\text{CSB\_hold}}$ |                                       | 40  |     | ns   |

The following figure shows the definition of the SPI timings given in Table 97:



Figure 16: SPI timing diagram



Page 81 Confidential

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

Two configurations of the SPI interface are supported by the BMC050: 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 "1" to (0x34) "spi3" for the accelerometer part and writing "1" to (0x4B) "SPI3en" for the magnetometer part (after power control bit was set). 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 BMC050 also supports multiple-byte read operations.

Note: CSB1 and CSB2 pin are separate chip select lines for accelerometer and magnetometer part, which *must* be operated separately. Tying them together is strictly forbidden, since this will make the accelerometer and magnetometer outputs compete against each other.

In SPI 4-wire configuration CSB1 or CSB2 (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 Figure 17. During the entire write cycle SDO remains in high- impedance state.



Figure 17: 4-wire basic SPI write sequence (mode "11")

The basic read operation waveform for 4-wire configuration is depicted in Figure 18:



Figure 18: 4-wire basic SPI read sequence (mode "11")

The data bits are used as follows:

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

Bit1-7: Address AD(6:0).

Bit8-15: when in write mode, these are the data SDI, which will be written into the address. 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.

The principle of multiple read is shown in Figure 19:

|               |    | Control byte          | Data byte                  | Data byte                  | Data byte                  |               |
|---------------|----|-----------------------|----------------------------|----------------------------|----------------------------|---------------|
| Start         | RW | Register adress (02h) | Data register - adress 02h | Data register - adress 03h | Data register - adress 04h | Stop          |
| CSB<br>=<br>0 | 1  | 0 0 0 0 0 1 0         |                            | x x x x x x x x x          |                            | CSB<br>=<br>1 |

Figure 19: SPI multiple read

In SPI 3-wire configuration CSB1 or CSB2 (chip select low active), SCK (serial clock), and SDI (serial data input and 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 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 waveform (read or write access) for 3-wire configuration is depicted in Figure 20:

Page 83 Confidential



Figure 20: 3-wire basic SPI read or write sequence (mode "11")



Page 84 Confidential

#### 7.2 Inter-Integrated Circuit (I<sup>2</sup>C)

The I2C bus uses SCL (= SCx pin, serial clock) and SDA (= SDx pin, serial data input and output) signal lines. Both lines are connected to V<sub>DDIO</sub> externally via pull-up resistors so that they are pulled high when the bus is free.

The I<sup>2</sup>C interface of the BMC050 is compatible with the I<sup>2</sup>C Specification UM10204 Rev. 03 (19 June 2007), available at http://www.nxp.com. The BMC050 supports I2C standard mode and fast mode, only 7-bit address mode is supported.

The default I<sup>2</sup>C address of the BMC050's accelerometer part is 0011000b (0x18). It is used if the SDO pin is pulled to "GND". The alternative address 0011001b (0x19) is selected by pulling the SDO pin to "VDDIO".

The default I2C address of the BMC050's magnetometer part is 0x10. The five MSB are hardwired to "00100". In order to prevent bus conflicts bit0 can be inverted by setting '1' to SDO, and the bit 1 can be inverted by setting '1' to the CSB line according to below Table:

Accelerometer Magnetometer part I<sup>2</sup>C CSB2 pin SDO pin part I<sup>2</sup>C address address **GND** GND 0x18 0x10 **GND VDDIO** 0x19 0x11 **VDDIO GND** 0x18 0x12 **VDDIO VDDIO** 0x19 0x13

Table 98: BMC050 I2C addresses

The timing specification for I<sup>2</sup>C of the BMC050 is given in Table 99:

Table 99: I2C timings. Symbol Condition Min Max Parameter

| Farailletei                                    | Syllibol              | Condition | IVIIII | IVIAA | Oilit |
|------------------------------------------------|-----------------------|-----------|--------|-------|-------|
| Clock Frequency                                | $f_{SCL}$             |           |        | 400   | kHz   |
| SCL Low Period                                 | $t_{LOW}$             |           | 6      | 6     |       |
| SCL High Period                                | t <sub>HIGH</sub>     |           | 6      | 6     |       |
| SDA Setup Time                                 | t <sub>SUDAT</sub>    |           | 6      | 6     |       |
| SDA Hold Time                                  | $t_{HDDAT}$           |           | 6      | 6     |       |
| Setup Time for a repeated Start Condition      | t <sub>SUSTA</sub>    |           | 6      | 6     | μS    |
| Hold Time for a Sta<br>Condition               | rt t <sub>HDSTA</sub> |           | 6      | 6     | μ3    |
| Setup Time for a Sto<br>Condition              | t <sub>SUSTO</sub>    |           | 6      | 6     |       |
| Time before a new<br>Transmission can<br>start | t <sub>BUF</sub>      |           | 6      | 6     |       |

<sup>&</sup>lt;sup>6</sup> fully compliant to the I<sup>2</sup>C specification"UM10204 I<sup>2</sup>C-bus specification Rev.03 – 19 June 2007"



Page 85 Confidential

Figure 21 shows the definition of the I<sup>2</sup>C timings given in Table 99:



Figure 21: 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.

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

In the following diagrams these abbreviations are used:

| S     | Start                     |
|-------|---------------------------|
| Р     | Stop                      |
| ACKS  | Acknowledge by slave      |
| ACKM  | Acknowledge by master     |
| NACKM | Not acknowledge by master |
| RW    | Read / Write              |

A START immediately followed by a STOP (without SCK toggling from logic "1" to logic "0") 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.



Page 86 Confidential

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 (ACK = 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:



Figure 22: Example of an I2C write access

#### 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 (Sr). 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 (ACK = 0) to enable further data transfer. A NACKM (ACK = 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 in the latest I<sup>2</sup>C write command. By default the start address is set at 0x00. In this way repetitive multi-bytes reads from the same starting address are possible.

In order to prevent the  $I^2C$  slave of the device to lock-up the  $I^2C$  bus, a watchdog timer (WDT) is implemented in the accelerometer part of BMC050. The WDT observes internal  $I^2C$  signals and resets the  $I^2C$  interface if the bus is locked-up by the BMC050 accelerometer part. The activity and the timer period of the WDT can be configured through the bits (0x34)  $i2c_wdt_en$  and (0x34)  $i2c_wdt_sel$ .

Writing "1" ("0") to (0x34)  $i2c\_wdt\_en$  activates (de-activates) the WDT. Writing "0" ("1") to (0x34) i2c wdt se selects a timer period of 1 ms (50 ms).

Example of an I<sup>2</sup>C multiple read accesses:



Page 87 Confidential



Figure 23: Example of an I<sup>2</sup>C multiple read access



Page 88 Confidential

# 8. Pin-out and connection diagram

#### 8.1 Pin-out





Figure 24: Pin-out top view

Figure 25: Pin-out bottom view

The arrows indicate the pin1 marking.



Page 89 Confidential

Table 100: Pin description

| Pin  | Name              | I/O Type | Sensor      | Description                             |                             | Connect to     |                               |  |
|------|-------------------|----------|-------------|-----------------------------------------|-----------------------------|----------------|-------------------------------|--|
| FIII | Ivallie           | i/O Type | Selisui     | Description                             | SPI 4W                      | SPI 3W         | I <sup>2</sup> C              |  |
| 1    | INT2              | Out      | Acc         | Interrupt output #2                     | INT2 input or DNC if unused |                | if unused                     |  |
| 2    | PS1               | ln       | Acc         | Protocol select #1                      | GND                         | GND            | $V_{DDIO}$                    |  |
| 3    | PS2               | In       | Mag         | Protocol select #2                      | GND                         | GND            | $V_{DDIO}$                    |  |
| 4    | INT3              | Out      | Mag         | Interrupt output #3                     | INT3 ii                     | nput or DNC    | if unused                     |  |
| 5    | CSB1 <sup>7</sup> | ln       | Acc         | Chip Select #1                          | CSB1                        | CSB1           | NC (float) or $V_{DDIO}$      |  |
| 6    | CSB2 <sup>7</sup> | ln       | Mag         | Chip Select #2                          | CSB2                        | CSB2           | GND for<br>default<br>address |  |
| 7    | GND               | Supply   | Mag+Ac<br>c | Ground                                  |                             | GND            |                               |  |
| 8    | GND               | Supply   | Mag+Ac<br>c | Ground                                  | GND                         |                |                               |  |
| 9    | DRDY              | Out      | Mag         | Data ready                              | DRDY                        | input or DNC   | C if unused                   |  |
| 10   | SDO               | Out      | Mag+Ac<br>c | SPI: Data out                           | SDO/<br>MISO                | DNC<br>(float) | GND for<br>default<br>address |  |
| 11   | SDI               | In/Out   | Mag+Ac<br>c | SPI: Data in, I <sup>2</sup> C:<br>Data | SDI/MOSI                    | SDA            | SDA                           |  |
| 12   | GND               | Supply   | Mag+Ac<br>c | Ground                                  |                             | GND            |                               |  |
| 13   | VDD               | Supply   | Mag+Ac<br>c | Supply voltage V <sub>DD</sub>          |                             | $V_{DD}$       |                               |  |
| 14   | VDDIO             | Supply   | Mag+Ac<br>c | I/O voltage V <sub>DDIO</sub>           |                             |                |                               |  |
| 15   | SCK               | ln       | Mag+Ac<br>c | Serial clock                            | SCK                         | SCK            | SCL                           |  |
| 16   | INT1              | Out      | Acc         | Interrupt output #1                     | INT 1 i                     | nput or DNC    | if unused                     |  |

\_

 $<sup>^{\</sup>rm 7}$  Note: CSB1 and CSB2 must be operated separately and cannot be tied together.



## 8.2 Connection diagram 4-wire SPI



Figure 26: 4-wire SPI connection diagram

Note: the recommended value for  $C_1$ ,  $C_2$  is 100 nF. CSB1 and CSB2 must be operated separately.

## 8.3 Connection diagram 3-wire SPI



Figure 27: 3-wire SPI connection diagram

Note: the recommended value for  $C_1$ ,  $C_2$  is 100 nF. CSB1 and CSB2 must be operated separately.

## 8.4 Connection diagram I<sup>2</sup>C



Figure 28: I<sup>2</sup>C connection diagram

Note: the recommended value for  $C_1$ ,  $C_2$  is 100 nF.

Page 93 Confidential

# 9. Package

#### 9.1 Outline dimensions

The sensor housing is a standard LGA 3x3 16-lead package. Its dimensions are the following:



Figure 29: Package outline dimensions

Page 94 Confidential

#### 9.2 Sensing axes orientation

The magnetic and acceleration sensing axes of the BMC050 are matching.

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). If a positive magnetic field is applied in the indicated directions, the corresponding channel will deliver a positive acceleration signal.

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

- 0 g for the X acceleration channel, 0 µT for the X magnetic channel
- 0 g for the Y acceleration channel, 0 µT for the Y magnetic channel
- +1 g for the Z acceleration channel, -|B| for the Z magnetic channel



Figure 30: Orientation of sensing axes (acceleration and magnetic)

Please note that the planet's north pole is a magnetic south pole. This means that when the BMC050's X axis points towards the north pole, the measured field will be negative.

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 ±2g range setting and a top down gravity and magnetic vector as shown above.

Table 101: Output signals depending on sensor orientation

| Sensor Orientation<br>(gravity vector ↓ =<br>acceleration vector ↑,<br>magnetic vector ↓) | •                          |                           | •                          |                            | upright                   | अपेश्वांत्रप                 |
|-------------------------------------------------------------------------------------------|----------------------------|---------------------------|----------------------------|----------------------------|---------------------------|------------------------------|
| Output Signal X                                                                           | 0g / 0LSB<br>0 μT          | +1g/<br>256LSB<br>- Β  μΤ | 0g / 0LSB<br>0 μT          | -1g/-<br>256LSB<br>+ Β  μΤ | 0g / 0LSB<br>0μT          | 0g / 0LSB<br>0 μT            |
| Output Signal Y                                                                           | -1g/-<br>256LSB<br>+ Β  μΤ | 0g / 0LSB<br>0 μT         | +1g /<br>256LSB<br>- B  μT | 0g / 0LSB<br>0 μT          | 0g / 0LSB<br>0 μT         | 0g / 0LSB<br>0 μT            |
| Output Signal Z                                                                           | 0g / 0LSB<br>0 μT          | 0g / 0LSB<br>0 μT         | 0g / 0LSB<br>0 μT          | 0g / 0LSB<br>0 μT          | +1g/<br>256LSB<br>- Β  μΤ | -1g / -<br>256LSB<br>+ Β  μΤ |



Page 95 Confidential

#### 9.3 Android axes orientation

The Android coordinate system is shown in Figure 31. The origin is in the lower-left corner with respect to the screen, with the X axis horizontal and pointing right, the Y axis vertical and pointing up and the Z axis pointing outside the front face of the screen. In this system, coordinates behind the screen have negative Z values.



Figure 31: Android coordinate system

Attitude terms are defined in the following way (see Figure 32):

- Heading / Azimuth angle between the magnetic north direction and the Y axis, around the Z axis (0° to 360°). 0° = North, 90° = East, 180° = South, 270° = West.
- Pitch rotation around X axis (-180° to 180°), with positive values when the z-axis moves toward the y-axis.
- Roll rotation around Y axis (-90° to 90°), with positive values when the x-axis moves toward the z-axis.



Figure 32: Heading, pitch and roll in Android coordinate frame

Page 97 Confidential

## 9.4 Landing pattern recommendation

For the design of the landing pattern, we recommend the following dimensioning:



Figure 33: Landing patterns relative to the device pins, dimensions are in mm

Page 98 Confidential

## 9.5 Marking

#### 9.5.1 Mass production devices

Table 102: Marking of mass production samples

| Labeling | Name             | Symbol | Remark                                                                                            |
|----------|------------------|--------|---------------------------------------------------------------------------------------------------|
|          | Product number   | 124    |                                                                                                   |
|          | Sub-Con ID       | А      | Packaging sub-contractor identifier, coded alphanumerically                                       |
| AYWW CCC | Date code        | YWW    | Y: year, numerically coded:<br>9 = 2009, 0 = 2010, 1 = 2011,<br>WW: Calendar week, numerical code |
|          | Lot counter      | CCC    | Numerical counter                                                                                 |
|          | Pin 1 identifier | •      |                                                                                                   |

### 9.5.2 Engineering samples

Table 103: Marking of engineering samples

| Labeling     | Name             | Symbol | Remark                                                                                            |
|--------------|------------------|--------|---------------------------------------------------------------------------------------------------|
|              | Product number   | 050E   | BMC <u>050</u> Engineering sample                                                                 |
|              | Sub-Con ID       | А      | Packaging sub-contractor identifier, coded alphanumerically                                       |
| O50E AYWW Cx | Date code        | YWW    | Y: year, numerically coded:<br>9 = 2009, 0 = 2010, 1 = 2011,<br>WW: Calendar week, numerical code |
|              | Sample status    | Сх     | x = Numerical counter                                                                             |
|              | Pin 1 identifier | •      |                                                                                                   |

#### 9.6 Soldering guidelines

The moisture sensitivity level of the BMC050 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 (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.



Figure 34: Soldering profile



Page 100 Confidential

#### 9.7 Handling instructions

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

We recommend avoiding 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.

Page 101 Confidential

#### 9.8 Tape and reel specification

#### 9.8.1 Tape and reel dimensions

The following picture describes the dimensions of the tape used for shipping the BMC050 sensor device. The material of the tape is made of conductive polystyrene (IV).



Figure 35: Tape and reel dimensions in mm

Page 102 Confidential

#### 9.8.2 Orientation within the reel



Figure 36: Orientation of the BMC050 devices relative to the tape



Page 103 Confidential

#### 9.9 Environmental safety

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

Directive 2002/95/EC of the European Parliament and of the Council of 27 January 2003 on the restriction of the use of certain hazardous substances in electrical and electronic equipment.

#### 9.9.1 Halogen content

Results of chemical analysis indicate that the BMC050 contains less than 900ppm (by weight) of Fluorine, Chlorine, Iodine and Bromine. Therefore the BMC050 can be regarded as halogenfree. For more details on the analysis results please contact your Bosch Sensortec representative.

#### 9.9.2 Internal package structure

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

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 BMC050 product.



Page 104 Confidential

## 10. Legal disclaimer

#### 10.1 Engineering samples

Engineering Samples are marked with an asterisk (\*) or (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.

#### 10.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 security sensitive systems. Security sensitive systems are those for which a malfunction is expected to lead to bodily harm or significant property damage. In addition, they are not fit for use in products which interact with motor vehicle systems.

The resale and/or use of 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 must monitor the market for the purchased products, particularly with regard to product safety, and inform Bosch Sensortec without delay of all security relevant incidents.

#### 10.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.



Page 105 Confidential

# 11. Document history and modification

| Rev. No | Chapter | Description of modification/changes | Date       |
|---------|---------|-------------------------------------|------------|
| 0.1     |         | Document creation                   | 2010-08-12 |
| 0.3     |         | New revision                        | 2011-03-07 |
| 0.4     |         | New revision                        | 2011-03-29 |
| 0.5     |         | New revision                        | 2011-06-15 |
| 0.6     |         | New revision                        | 2011-07-28 |
| 0.7     |         | New revision                        | 2011-10-13 |
| 1.0     |         | Not longer under preliminary status | 2011-10-28 |

Bosch Sensortec GmbH Gerhard-Kindler-Strasse 8 72770 Reutlingen / Germany

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

Modifications reserved | Printed in Germany Specifications subject to change without notice Document number: BST-BMC050-DS000-10 Revision\_1.0\_102011