# FXLS8971CF

### 3-Axis Low-g Accelerometer

Rev. 2.1 — 7 March 2024

Product data sheet



### 1 General description

FXLS8971CF is a compact 3-axis MEMS accelerometer designed for use in a wide range of industrial and medical IOT applications that require ultra-low-power wake-up on motion as well as good performance over temperature. The part supports both high-performance and low-power operating modes, allowing maximum flexibility to meet the resolution and power needs for various unique use cases. A number of advanced, integrated digital features enable designers to reduce the overall system power consumption and simplify host data collection.

FXLS8971CF is available in a 3 mm x 3 mm x 1.25 mm 12-pin QFN package with 0.65 mm pitch and wettable flanks. The device is qualified to industrial standards over the extended –40 °C to +105 °C temperature range. The combination of sensor performance, system power-saving features, and extended over-temperature-range performance makes FXLS8971CF an ideal accelerometer for motion and position sensing in the IOT and industrial segments.

### 2 Features and benefits

- ±2/4/8/16 g user-selectable, full-scale measurement ranges
- 12-bit acceleration data
- 8-bit temperature sensor data
- Low noise: 230 µg/√Hz typical in high performance mode
- · Low-power capability:
  - ≤ 1  $\mu$ A I<sub>DD</sub> for ODRs up to 6.25 Hz
  - < 4  $\mu$ A I<sub>DD</sub> for ODRs up to 50 Hz
- Post-board mount zero-g Offset and TCO performance of ±30 mg (typ) and ±0.15 mg/°C (typ), respectively
- Selectable ODRs from 0.78 to 3200 Hz in both low power and high performance modes
- Flexible performance mode allowing custom ODRs with programmable decimation (resolution) and idle-time settings
- 144 byte output data buffer (FIFO/LIFO) capable of storing up to 32 12-bit X/Y/Z data triplets
- Flexible Sensor Data Change Detection (SDCD) function for realizing motion or no motion, high-g/low-g, freefall, and other inertial events
- Autonomous orientation detection function (Portrait/Landscape/Up/Down)
- Self-governed low-power motion-detection mode with one wire interface option
- 12-bit vector magnitude calculation
- · Trigger input for synchronizing data collection with an external system
- I<sup>2</sup>C interface frequencies up to 1 MHz; 3- and 4-wire SPI interface with clock frequencies up to 4 MHz
- · Bidirectional, robust self-test diagnostic: Device motion or orientation does not impact the result.



### 3 Applications

#### 3.1 Industrial IOT

- · Asset tracking
- · Equipment monitoring
- · Smart metering / tamper detection
- · Tilt measurement, orientation detection, vibration sensing
- Surveillance
- · Point of sale devices
- Indoor localization

#### 3.2 Medical

- · Patient activity monitors
- · Drug delivery
- · Clinical care
- Smart inhalers

#### 3.3 Consumer devices

- · Connected home
- Wearables
- Portable electronics
- · Tilt sensing
- · Mobile accessories

## 4 Ordering information

#### Table 1. Ordering information

| Type number | Package |                                                                                               |               |  |  |  |  |
|-------------|---------|-----------------------------------------------------------------------------------------------|---------------|--|--|--|--|
|             | Name    | Description                                                                                   | Version       |  |  |  |  |
| FXLS8971CF  | PQFN12  | Plastic, quad flat package, no leads; 12 terminals; 0.65 mm pitch; 3 mm x 3 mm x 1.25 mm body | SOT2197-1(SC) |  |  |  |  |

### 4.1 Ordering options

#### Table 2. Ordering options

| Part number  | Temperature range | Package description | Shipping               |
|--------------|-------------------|---------------------|------------------------|
| FXLS8971CFR1 | –40 °C to +105 °C | QFN-12              | Tape and reel (1.25 k) |

FXLS8971CF

### 5 Block diagram



## 6 Pinning information

### 6.1 Pinning



### 6.2 Pinning description

Table 3. Pin descriptions

| Symbol                    | Pin | Description                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $V_{DD}$                  | 1   | Sensor and digital interface supply voltage: 1.71 VDC to 3.6 VDC.                                                                                                                                                                                                                                                                                                                                                        |
| BT_MODE                   | 2   | Device boot mode selection. <sup>[1]</sup> GND: Default operating mode enabled V <sub>DD</sub> : Motion Detection mode enabled                                                                                                                                                                                                                                                                                           |
| SA0 / SPI_MISO            | 3   | Mode-dependent Multifunction serial interface pin. [2] INTF_SEL = V <sub>DD</sub> :  • SPI_MISO: In 4-wire SPI mode this pin functions as the serial data output. INTF_SEL = GND:  • SA0: This pin selects the least significant bit of the device I <sup>2</sup> C secondary address.                                                                                                                                   |
| SDA / SPI_MOSI / SPI_DATA | 4   | <ul> <li>Mode-dependent Multifunction serial interface pin. [2]</li> <li>INTF_SEL = V<sub>DD</sub>:</li> <li>SPI_MOSI: In 4-wire SPI mode this pin functions as the serial data input.</li> <li>SPI_DATA [3]: In 3-wire SPI mode, this pin functions as the bidirectional serial data input/output.</li> <li>INTF_SEL = GND:</li> <li>SDA: This pin functions as the I<sup>2</sup>C Serial Data input/output.</li> </ul> |
| SCL / SCLK                | 5   | Mode-dependent Multifunction serial interface pin. [2] INTF_SEL = V <sub>DD</sub> : • SPI serial clock input (3- and 4-wire modes) INTF_SEL = GND: • I <sup>2</sup> C serial clock input                                                                                                                                                                                                                                 |

Table 3. Pin descriptions...continued

| Symbol                     | Pin | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INT2 / EXT_TRIG / BOOT_OUT | 6   | Mode-dependent multifunction I/O pin 2. <sup>[2]</sup> BT_MODE = V <sub>DD</sub> : Open-drain <sup>[4]</sup> output signaling the device boot process has completed. This pin is typically connected to MOT_DET in a wired-AND configuration; a pull-up resistor is required. BT_MODE = GND: Programmable interrupt output pin 2 <sup>[5]</sup> / External measurement trigger input. This pin should be left unconnected if unused in the application circuit.                                                                                                                                                                  |
| SPI_CS_B / WAKE_UP         | 7   | SPI chip select input, active low / Hibernate mode wake-up pin. [6] The WAKE_UP function is only available when BT_MODE = GND.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| INT1 / MOT_DET             | 8   | Mode-dependent multifunction I/O pin 1. [7] BT_MODE = GND: Programmable interrupt output pin 1. [5] This pin should be left unconnected if unused in the application circuit. BT_MODE = $V_{DD}$ : MOT_DET multifunction I/O. [4] The host MCU sets this pin high through a pull-up resistor to enable motion detection, and drives it low for greater than $T_{MOT-HIB}$ ms to disable motion detection and enter Hibernate mode. FXLS8971CF will pulse the line low for $T_{PULSE-MOT}$ ms after motion is detected. This line may also be used to select the motion detection threshold. See Section 14 for more information. |
| INTF_SEL                   | 9   | Device interface mode selection pin.  V <sub>DD</sub> : SPI interface mode <sup>[3]</sup> GND: I <sup>2</sup> C interface mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| GND                        | 10  | Supply return connection.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| NC                         | 11  | No connection.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| NC                         | 12  | No connection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

- BT\_MODE state is latched after POR.
  Under Hibernate mode, pin configuration is High Impedance.
  3-wire SPI mode may be selected in SENS\_CONFIG1[SPI\_M]; 3-wire operation is also possible by directly connecting the SPI\_MISO and SPI\_MOSI pins together on the PCB.
- An external pull-up resistor is required on this pin when BT\_MODE = V<sub>DD</sub>.

  This pin is configurable as either an input or output (push-pull or open-drain/open-source output type), but defaults to a push-pull output after POR, or after exiting Hibernate mode.
- Under Hibernate mode, pin configuration is High Impedance (when BT\_MODE =  $V_{DD}$ ) and CMOS Input (when BT\_MODE = GND). Under Hibernate mode, pin configuration is High Impedance (when BT\_MODE = GND) and CMOS Input (when BT\_MODE =  $V_{DD}$ ).

#### 6.3 Orientation



### 7 Limiting values

The limiting values are the absolute maximum ratings the device can be exposed to without damage. Functional operation at absolute maximum rating is not guaranteed.

Although this device contains circuitry to protect against damage due to high static voltage or electrostatic fields, it is advised that normal precautions be taken to avoid application of any voltage higher than the maximum-rated voltage.

Table 4. Device absolute maximum ratings

| Symbol                 | Rating                                         | Min  | Max     | Unit |
|------------------------|------------------------------------------------|------|---------|------|
| ACC <sub>max-2k</sub>  | Maximum applied acceleration, 0.5 ms duration  | _    | 2,000   | g    |
| ACC <sub>max-10k</sub> | Maximum applied acceleration, 0.1 ms duration  | _    | 10,000  | g    |
| VDD <sub>MAX</sub>     | Maximum sensor supply voltage                  | 0    | +3.6    | V    |
| VIN <sub>MAX</sub>     | Maximum voltage level applied to any input pin | -0.3 | VDD+0.3 | V    |
| T <sub>OP</sub>        | Operating temperature range                    | -40  | +105    | °C   |
| T <sub>STG</sub>       | Storage temperature range                      | -40  | +125    | °C   |

Table 5. ESD and latch-up-protection characteristics

| Symbol           | Rating                          | Min   | Unit |
|------------------|---------------------------------|-------|------|
| V <sub>HBM</sub> | Human Body Model                | ±2000 | V    |
| V <sub>CDM</sub> | Charged Device Model            | ±500  | V    |
| I <sub>LU</sub>  | Latch-up current at T = +105 °C | ±100  | mA   |

#### CAUTION



This device is sensitive to mechanical shock. Improper handling can cause permanent damage to the part or cause the part to otherwise fail.

#### **CAUTION**



This device is sensitive to ElectroStatic Discharge (ESD). Observe precautions for handling electrostatic sensitive devices.

Such precautions are described in the ANSI/ESD S20.20, IEC/ST 61340-5, JESD625-A or equivalent standards.

### 8 Recommended operating conditions

Table 6. Nominal operating conditions

| Symbol   | Parameter                   | Min  | Тур | Max  | Unit |
|----------|-----------------------------|------|-----|------|------|
| $V_{DD}$ | Supply voltage              | 1.71 | 3.0 | 3.6  | V    |
| Тор      | Operating temperature range | -40  | +25 | +105 | °C   |

### 9 Mechanical characteristics

Table 7. Accelerometer sensor performance parameters

 $V_{DD}$  = 3.0 V, T = 25 °C , unless otherwise noted.

Typical values represent mean or mean  $\pm 1~\sigma$  values, depending on the specific parameter.

| Symbol             | Parameter                                                                               | Conditions                             | Min    | Тур    | Max        | Unit           |
|--------------------|-----------------------------------------------------------------------------------------|----------------------------------------|--------|--------|------------|----------------|
| n <sub>ACC</sub>   | Output data width                                                                       | _                                      | _      | 12     | _          | bits           |
| FSR                | Full-scale measurement range                                                            | ±2 g mode                              | _      | ±2     | _          | g              |
|                    |                                                                                         | ±4 g mode                              | _      | ±4     | _          |                |
|                    |                                                                                         | ±8 <i>g</i> mode                       | _      | ±8     | _          |                |
|                    |                                                                                         | ±16 <i>g</i> mode                      | _      | ±16    | _          |                |
| SEN                | Nominal sensitivity                                                                     | ±2 g mode                              | _      | 0.98   | _          | mg/LSB         |
|                    |                                                                                         | ±4 g mode                              | _      | 1.95   | _          |                |
|                    |                                                                                         | ±8 g mode                              | _      | 3.91   | _          |                |
|                    |                                                                                         | ±16 <i>g</i> mode                      | _      | 7.81   | _          |                |
|                    |                                                                                         | ±2 g mode                              | _      | 1024   | _          | LSB/g          |
|                    |                                                                                         | ±4 g mode                              | _      | 512    | _          |                |
|                    |                                                                                         | ±8 <i>g</i> mode                       | _      | 256    | _          |                |
|                    |                                                                                         | ±16 <i>g</i> mode                      | _      | 128    | _          |                |
| SEN <sub>TOL</sub> | Sensitivity tolerance                                                                   | –40 °C to +105 °C                      | -10    | ±2.5   | 10         | %SEN           |
| TCS <sub>PBM</sub> | Temperature coefficient of sensitivity, post board mount, FSR $\leq$ ± 4 $g^{[1][2]}$   | –40 °C to +105 °C,<br>delta from 25 °C | -0.023 | ±0.005 | 0.023      | %/°C           |
| OFF <sub>PBM</sub> | Zero- $g$ offset, post-board mount, FSR $\leq \pm 8 g^{[1][2]}$                         | –40 °C to +105 °C                      | -120   | ±30    | 120        | mg             |
| TCO <sub>PBM</sub> | Zero- $g$ offset temperature coefficient, post-board mount, FSR $\leq \pm 4 g^{[1][2]}$ | –40 °C to +105 °C,<br>delta from 25°C  | -0.8   | 0.20   | 0.8        | m <i>g</i> /°C |
| CAS                | Cross-axis sensitivity <sup>[3]</sup>                                                   | ±2/4 g mode                            | _      | ±0.5   | _          | %              |
| STOC               | Self-test output change <sup>[4]</sup>                                                  | ±4 g mode, X axis                      | -206   | -139   | -81        | LSB            |
|                    |                                                                                         | ±4 g mode, Y axis                      | 78     | 137    | 207        |                |
|                    |                                                                                         | ±4 g mode, Z axis                      | -727   | -448   | -120       |                |
|                    |                                                                                         | ±8 g mode, X axis                      | -103   | -69    | -40        |                |
|                    |                                                                                         | ±8 g mode, Y axis                      | 38     | 68     | 103        |                |
|                    |                                                                                         | ±8 g mode, Z axis                      | -355   | -223   | <b>-71</b> |                |
|                    |                                                                                         | ±16 g mode, X axis                     | -52    | -35    | -19        |                |
|                    |                                                                                         | ±16 g mode, Y axis                     | 19     | 34     | 52         |                |
|                    |                                                                                         | ±16 g mode, Z axis                     | -178   | -112   | -35        |                |
| STOF               | Self-test offset <sup>[4]</sup>                                                         | ±4 g mode                              | -1600  | _      | +1600      | LSB            |
|                    |                                                                                         | ±8 <i>g</i> mode                       | -800   | _      | +800       |                |
|                    |                                                                                         | ±16 <i>g</i> mode                      | -400   | _      | +400       |                |
| BW <sub>MAX</sub>  | Maximum signal bandwidth                                                                | ODR = 3200 Hz                          | _      | 1600   | _          | Hz             |

FXLS8971CF

Product data sheet

All information provided in this document is subject to legal disclaimers.

© 2024 NXP B.V. All rights reserved.

Table 7. Accelerometer sensor performance parameters...continued

 $V_{DD}$  = 3.0 V, T = 25 °C , unless otherwise noted.

Typical values represent mean or mean  $\pm 1$   $\sigma$  values, depending on the specific parameter.

| Symbol                                                                                           | Parameter                                                                                                 | Conditions | Min | Тур  | Max | Unit    |
|--------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|------------|-----|------|-----|---------|
| ODR <sub>MAX</sub>                                                                               | Maximum ODR                                                                                               | _          | _   | 3200 | _   | Hz      |
| NSD <sub>HPM</sub>                                                                               | Noise Spectral Density, High<br>Performance Mode, FSR $\leq \pm 4~g$ , 25<br>Hz $\leq$ ODR $\leq$ 3200 Hz | XY axes    | _   | 217  | _   | μg/√ Hz |
|                                                                                                  |                                                                                                           | Z axis     | _   | 257  | _   |         |
| NRMS <sub>LPM</sub> Noise RMS, Low-Power Mode, FSR ≤ ±4 <i>g</i> , all ODR ranges <sup>[5]</sup> |                                                                                                           | XY axes    | _   | 7.8  | _   | mg      |
| $\leq \pm 4 g$ , all ODR ranges <sup>10</sup>                                                    | Z axis                                                                                                    | _          | 9.4 | _    |     |         |

Determined with post board mount data using a standard lead-free reflow profile and NXP recommended landing pattern on a 10-layer FR4 PCB with 1.6 [1] mm (63 mil) overall thickness.

### 9.1 Typical performance

Device typical performance characteristics are illustrated in the charts shown in Figure 4, Figure 5, and Figure 6. They represent post-board mount measurements on a three lot sample set.

Offset drift is computed from the 25 °C room temperature offset.

Similarly, offset and sensitivity temperature coefficients (resp. TCO and TCS) are computed with the 105 °C data or 40 °C data compared to the 25 °C data. They are referred to as TCO or TCS "Hot" (25 °C to 105 °C) and "Cold" (-40 °C to 25 °C).

Based on characterization data on limited number of parts from 3 lots. Limits provided with 4 sigma margin and 99% confidence level.

See Cross-axis sensitivity in Section 20 "Glossary".

<sup>[3]</sup> [4] See Self-Test in Section 20 "Glossary"

In low-power mode, higher ODR settings result in a lower noise density figure.







### 10 Electrical characteristics

Table 8. Electrical characteristics

 $V_{DD}$  = 3.0 V , T = 25 °C, unless otherwise noted.

Typical values represent mean or mean  $\pm 1~\sigma$  values, depending on the specific parameter.

| Symbol              | Parameter                                                                                                                    | Conditions                    | Min                   | Тур   | Max | Unit |
|---------------------|------------------------------------------------------------------------------------------------------------------------------|-------------------------------|-----------------------|-------|-----|------|
| $V_{DD}$            | Supply voltage                                                                                                               | _                             | 1.71                  | 3.0   | 3.6 | V    |
| IDD <sub>HPM</sub>  | Average current draw in High Performance mode                                                                                | ODR independent,<br>T = 25 °C | _                     | 146.9 | _   | μA   |
| IDD <sub>LPM</sub>  | Average current draw in low-power mode                                                                                       | ODR = 3200 Hz,<br>T = 25 °C   | _                     | 146.9 | _   |      |
|                     |                                                                                                                              | ODR = 1600 Hz,<br>T = 25 °C   | _                     | 73.9  | _   |      |
|                     |                                                                                                                              | ODR = 800 Hz,<br>T = 25 °C    | _                     | 37.5  | _   |      |
|                     |                                                                                                                              | ODR = 400 Hz,<br>T = 25 °C    | _                     | 19.4  | _   |      |
|                     |                                                                                                                              | ODR = 200 Hz,<br>T = 25 °C    | _                     | 10.4  | _   |      |
|                     |                                                                                                                              | ODR = 100 Hz,<br>T = 25 °C    | _                     | 5.04  | _   |      |
|                     |                                                                                                                              | ODR = 50 Hz,<br>T = 25 °C     | _                     | 2.75  | _   | μA   |
|                     |                                                                                                                              | ODR = 25 Hz,<br>T = 25 °C     | _                     | 1.6   | _   |      |
|                     |                                                                                                                              | ODR = 12.5 Hz,<br>T = 25 °C   | _                     | 1.21  | _   |      |
|                     |                                                                                                                              | ODR = 6.25 Hz,<br>T = 25 °C   | _                     | 0.84  | _   |      |
|                     |                                                                                                                              | ODR = 3.125 Hz,<br>T = 25 °C  | _                     | 0.65  | _   |      |
|                     |                                                                                                                              | ODR = 1.563 Hz,<br>T = 25 °C  | _                     | 0.56  | _   |      |
|                     |                                                                                                                              | ODR = 0.781 Hz,<br>T = 25 °C  | _                     | 0.51  | _   |      |
| IDD <sub>STBY</sub> | Supply current draw in Standby mode                                                                                          | T = 25 °C                     | _                     | 0.46  |     | μA   |
| IDD <sub>HIB</sub>  | Supply current draw in Hibernate mode                                                                                        | T = 25 °C                     | _                     | 15    | _   | nA   |
| VIH                 | High-level input voltage: SCL/SCLK, SDA/SPI_MOSI/SPI_ DATA, SA0, INTF_SEL, BT_MODE, SPI_CS_B/WAKE_UP, MOT_DET, EXT_TRIG pins | _                             | 0.7 * V <sub>DD</sub> | _     | _   | V    |

Table 8. Electrical characteristics...continued

 $V_{DD}$  = 3.0 V , T = 25 °C, unless otherwise noted.

Typical values represent mean or mean  $\pm 1~\sigma$  values, depending on the specific parameter.

| Symbol                    | Parameter                                                                                                                   | Conditions                                                                           | Min                   | Тур  | Max                   | Unit |
|---------------------------|-----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|-----------------------|------|-----------------------|------|
| VIL                       | Low-level input voltage: SCL/SCLK, SDA/SPI_MOSI/SPI_ DATA, SA0, INTF_SEL, BT_MODE, SPI_CS_B/WAKE_UP, MOT_DET, EXT_TRIG pins | _                                                                                    | _                     | _    | 0.3 * V <sub>DD</sub> | V    |
| VOH                       | High-level output voltage: INT1/MOT_<br>DET, INT2/BOOT_OUT, SPI_MISO,<br>SPI_DATA pins                                      | Ιο = 500 μΑ                                                                          | 0.9 * V <sub>DD</sub> | _    | _                     | V    |
| VOL                       | Low-level output voltage: INT1/MOT_<br>DET, INT2/BOOT_OUT, SPI_MISO,<br>SPI_DATA pins                                       | Ιο = 500 μΑ                                                                          | _                     | _    | 0.1 * V <sub>DD</sub> | V    |
| VOL <sub>SDA, SCL</sub>   | Low-level output voltage on SDA and SCL pins                                                                                | Io = 5 mA                                                                            | _                     | _    | 0.4                   | V    |
| T <sub>PULSE-MOT</sub>    | Motion detected interrupt pulse width                                                                                       | BT_MODE = V <sub>DD</sub>                                                            | 4.55                  | 5    | 5.56                  | ms   |
| T <sub>MOT-HIB</sub>      | MOT_DET pin low time before entering Hibernate mode <sup>[1]</sup>                                                          | BT_MODE = V <sub>DD</sub>                                                            | 0.91                  | 1    | 6.8                   | ms   |
| T <sub>PULSE-WIN</sub>    | Motion detection threshold setting pulse window                                                                             | BT_MODE = V <sub>DD</sub> ,<br>MOT_DET = HIGH                                        | 4.55                  | 5    | 5.56                  | ms   |
| T <sub>PULSE-THRES1</sub> | Motion detection threshold selection 1  – Pulse width range                                                                 | BT_MODE = V <sub>DD</sub>                                                            | 562.5                 | 625  | 883                   | μs   |
| T <sub>PULSE-THRES2</sub> | Motion detection threshold selection 2  – Pulse width range                                                                 | BT_MODE = V <sub>DD</sub>                                                            | 1125                  | 1250 | 1570                  | μs   |
| T <sub>PULSE-THRES3</sub> | Motion detection threshold selection 3  – Pulse width range                                                                 | BT_MODE = V <sub>DD</sub>                                                            | 2250                  | 2500 | 2950                  | μs   |
| T <sub>PULSE-DRDY</sub>   | DRDY interrupt output pulse width                                                                                           | BT_MODE = GND                                                                        | 29                    | 32   | 35.6                  | μs   |
| T <sub>PULSE-BOOT1</sub>  | BOOT interrupt output pulse width                                                                                           | BT_MODE = GND                                                                        | 58                    | 64   | 71.2                  | μs   |
| T <sub>PULSE-BOOT2</sub>  |                                                                                                                             | BT_MODE = V <sub>DD</sub>                                                            | 9                     | 10   | 11.2                  | ms   |
| ODR <sub>TOL</sub>        | Output Data Rate frequency tolerance                                                                                        | _                                                                                    | -10                   | ±2.5 | 10                    | %ODR |
| T <sub>FLT-MOT_DET</sub>  | MOT_DET pin deglitch filter time                                                                                            | BT_MODE = V <sub>DD</sub>                                                            | _                     | 10   | _                     | μs   |
| T <sub>FLT-WAKE_UP</sub>  | MOT_DET, WAKE_UP pin deglitch filter time (transition out of Hibernate                                                      | BT_MODE =<br>GND, SPI_CS_<br>B / WAKE_UP pin                                         | _                     | 400  | _                     | ns   |
| 7 E1 7W W.E_01            | mode)                                                                                                                       | BT_MODE = V <sub>DD</sub> ,<br>MOT_DET pin                                           | _                     | 850  | _                     |      |
| T <sub>BOOT1</sub>        | Time needed to enter Standby mode after POR or soft reset                                                                   | BT_MODE = GND                                                                        | _                     | _    | 1                     | ms   |
| T <sub>BOOT2</sub>        | Time needed to enter Motion<br>Detection mode after POR or soft<br>reset                                                    | BT_MODE = V <sub>DD</sub> ,<br>MOT_DET = 1                                           | _                     | _    | 17.7                  | ms   |
| IDD <sub>BOOT</sub>       | Boot sequence peak current draw                                                                                             | T = -40 °C to<br>+105 °C; with<br>no decoupling<br>capacitors on V <sub>DD</sub> pin | _                     | _    | 5                     | mA   |

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

© 2024 NXP B.V. All rights reserved.

Table 8. Electrical characteristics...continued

 $V_{DD}$  = 3.0 V , T = 25 °C, unless otherwise noted.

Typical values represent mean or mean  $\pm 1~\sigma$  values, depending on the specific parameter.

| Symbol          | Parameter                                                            | Conditions | Min | Тур                                                                 | Max  | Unit |
|-----------------|----------------------------------------------------------------------|------------|-----|---------------------------------------------------------------------|------|------|
| T <sub>ON</sub> | Transition time (Standby mode to Active mode with valid data output) | _          | _   | 0.5285 +<br>(DEC - 1)<br>× 998.4 /<br>(ODR ×<br>DEC) <sup>[2]</sup> | _    | ms   |
| T <sub>OP</sub> | Operating temperature range                                          | _          | -40 | _                                                                   | +105 | °C   |

<sup>[1]</sup> Max spec covers the situation where an interrupt pulse is issued by the sensor at the same time the host MCU drives MOT\_DET low to signal a hibernate command. In that case, their durations add up.

### 11 Temperature sensor characteristics

Table 9. Temperature sensor performance parameters

 $V_{DD}$  = 3.0 V, T = 25 °C, unless otherwise noted.

Typical values represent mean or mean  $\pm 1$   $\sigma$  values, depending on the specific parameter.

| Symbol                  | Parameter                              | Conditions        | Min | Тур         | Max | Unit   |
|-------------------------|----------------------------------------|-------------------|-----|-------------|-----|--------|
| n <sub>TEMP</sub>       | Output data width                      | _                 | _   | 8           | _   | bits   |
| FSR <sub>TEMP</sub>     | Measurement range                      | _                 | _   | -40 to +105 | _   | °C     |
| SEN <sub>TEMP</sub>     | Sensitivity                            | _                 | _   | 1           | _   | °C/LSB |
| SEN <sub>TOL-TEMP</sub> | Sensitivity tolerance                  | _                 | _   | ±2.5        | _   | %      |
| OFF <sub>TEMP</sub>     | Nominal zero-output offset temperature | Output Code = 00h | _   | 25          | _   | °C     |

# 12 I<sup>2</sup>C digital interface

The registers embedded within FXLS8971CF may be accessed using an  $I^2C$  interface when the INTF\_SEL pin is tied to GND. If the  $V_{DD}$  supply is not present, the device is in shutdown mode and any communications on the interface are ignored. When the device is on a common  $I^2C$ -bus with other secondary devices, the  $V_{DD}$  supply pin must be left unconnected (high-impedance) when the device supply is turned off to ensure that the internal ESD protection diodes do not become forward biased and prevent the bus from functioning normally (clamping).

The  $I^2C$  secondary interface port of FXLS8971CF is compliant with the following three operating modes as defined in UM10204<sup>[3]</sup>:

- Fast-mode Plus (Fm+) at 1000 kHz
- Fast-mode (Fm) at 400 kHz
- Standard-mode (Sm) at 100 kHz

Table 10. I<sup>2</sup>C serial interface pin description

| and the state of the state part |                                                              |  |  |  |  |  |  |
|---------------------------------|--------------------------------------------------------------|--|--|--|--|--|--|
| Pin Name                        | Pin Description                                              |  |  |  |  |  |  |
| SCL                             | I <sup>2</sup> C serial clock (pull-up resistor is required) |  |  |  |  |  |  |
| SDA                             | I <sup>2</sup> C serial data (pull-up resistor is required)  |  |  |  |  |  |  |

FXLS8971CF

All information provided in this document is subject to legal disclaimers

© 2024 NXP B.V. All rights reserved

<sup>[2]</sup> DEC = decimation factor. The selected ODR and operating mode determines the decimation factor. See <u>Section 15.3.3</u> for more information on setting or determining the measurement decimation factor. In LPM, the DEC factor is fixed at 1, making the time to first sample output fixed at 528.5 μs (typ), independent of the selected ODR.

## 12.1 I<sup>2</sup>C interface characteristics

The  $I^2C$  secondary address (7-bit format) is set to 18h when SA0 = 0, and 19h when SA0 = 1.

Table 11. FXLS8971CF I<sup>2</sup>C read and write addresses

| SA0 | I <sup>2</sup> C write address | I <sup>2</sup> C read address |
|-----|--------------------------------|-------------------------------|
| 0   | 30h (0011 0000b)               | 31h (0011 0001b)              |
| 1   | 32h (0011 0010b)               | 33h (0011 0011b)              |

Table 12. I<sup>2</sup>C secondary timing values for Standard-mode (Sm), Fast-mode (Fm), and Fast-mode Plus (Fm +)

| Parameter                                                                      | Symbol              | I <sup>2</sup> C Sta | indard-<br>de <sup>[1]</sup> | I <sup>2</sup> C Fast-m | node <sup>[1]</sup> | I <sup>2</sup> C Fast-mod | Unit                |     |
|--------------------------------------------------------------------------------|---------------------|----------------------|------------------------------|-------------------------|---------------------|---------------------------|---------------------|-----|
|                                                                                |                     | Min                  | Max                          | Min                     | Max                 | Min                       | Max                 |     |
| SCL clock frequency                                                            | f <sub>SCL</sub>    | 0                    | 100                          | 0                       | 400                 | 0                         | 1000                | kHz |
| Bus free time between STOP and START conditions                                | t <sub>BUF</sub>    | 4.7                  | _                            | 1.3                     | _                   | 0.5                       | _                   | μs  |
| Repeated START hold time                                                       | t <sub>HD;STA</sub> | 4                    | _                            | 0.6                     | _                   | 0.26                      | _                   | μs  |
| Repeated START setup time                                                      | t <sub>SU;STA</sub> | 4.7                  | _                            | 0.6                     | _                   | 0.26                      | _                   | μs  |
| STOP condition setup time                                                      | t <sub>SU;STO</sub> | 4                    | _                            | 0.6                     | _                   | 0.26                      | _                   | μs  |
| SDA valid time <sup>[3]</sup>                                                  | t <sub>VD;DAT</sub> | _                    | 3.45 <sup>[4]</sup>          | _                       | 0.9 <sup>[4]</sup>  | _                         | 0.45 <sup>[4]</sup> | μs  |
| SDA valid acknowledge time <sup>[5]</sup>                                      | t <sub>VD;ACK</sub> | _                    | 3.45 <sup>[4]</sup>          | _                       | 0.9 <sup>[4]</sup>  | _                         | 0.45 <sup>[4]</sup> | μs  |
| SDA setup time                                                                 | t <sub>SU;DAT</sub> | 250                  | _                            | 100 <sup>[6]</sup>      | _                   | 50                        | _                   | ns  |
| SCL clock low time                                                             | t <sub>LOW</sub>    | 4.7                  | _                            | 1.3                     | _                   | 0.50                      | _                   | μs  |
| SCL clock high time                                                            | t <sub>HIGH</sub>   | 4.0                  | _                            | 0.6                     | _                   | 0.26                      | _                   | μs  |
| SDA and SCL risetime                                                           | t <sub>r</sub>      | _                    | 1000                         | 20                      | 300                 | _                         | 120                 | ns  |
| SDA and SCL fall time <sup>[7][8]</sup>                                        | t <sub>f</sub>      | _                    | 300                          | _                       | 300                 | _                         | 120                 | ns  |
| Pulse width of spikes<br>on SDA and SCL<br>(suppressed by the input<br>filter) | t <sub>SP</sub>     | 0                    | 50                           | 0                       | 50                  | 0                         | 50                  | ns  |

<sup>[1]</sup> All values referred to VIH(min) and VIL(max) levels.

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

© 2024 NXP B.V. All rights reserved.

<sup>[2]</sup> Should be backward compatible with Fast mode.

<sup>[3]</sup> t<sub>VD;DAT</sub> referred to the time for data signal from SCL LOW to SDA output (HIGH or LOW, depending on which one is worse).

<sup>4]</sup> The maximum t<sub>HD:DAT</sub> could be 3.45 μs and 0.9 μs for Standard-mode and Fast-mode respectively, but must be less than the maximum of t<sub>VD:DAT</sub> or t<sub>VD:DACK</sub> by a transition time.

<sup>[5]</sup>  $t_{VD;ACK}$  = time for ACK signal from SCL LOW to SDA output (HIGH or LOW, depending on which one is worse).

<sup>[6]</sup> A Fast-mode I<sup>2</sup>C device can be used in a Standard mode I<sup>2</sup>C system, but the requirement t<sub>SU;DAT</sub> 250 ns must then be met. Also the acknowledge timing must meet this set-up time.

<sup>[7]</sup> The maximum t<sub>f</sub> for the SDA and SCL bus lines is specified at 300 ns. The maximum fall time for the SDA output stage t<sub>f</sub> is specified at 250 ns. The maximum fall time allows series protection resistors to be connected in between the SDA and the SCL pins and the SDA/SCL bus lines without exceeding the maximum specified t<sub>f</sub>.

[8] In Fast-mode Plus, fall time is specified the same for both output stage and bus timing. If series resistors are used, designers should allow for this specified fall time when considering bus timing.



### 12.1.1 General I<sup>2</sup>C operation

There are two signals associated with the  $I^2$ C-bus: the Serial Clock Line (SCL) and the Serial Data line (SDA). SDA is a bidirectional signal used for sending and receiving the data to/from the interface. External pull-up resistors connected to  $V_{DD}$  are required for SDA and SCL. When the  $I^2$ C-bus is free, SCL and SDA are high.

The maximum practical operating frequency for I<sup>2</sup>C in a given system implementation depends on several factors including the pull-up resistor and voltage values and total bus capacitance (PCB trace + parasitic device capacitances).

The primary starts a transaction on the bus through a start condition (ST) signal, which is defined as a HIGH-to-LOW transition on SDA line while the SCL line is held HIGH. After the primary transmits the ST signal, the bus is considered busy. The next byte of data transmitted contains the secondary address in the first seven bits, and the eighth bit, the read/write bit, indicates whether the primary is receiving data from the secondary or transmitting data to the secondary. When an address is sent, each device in the system compares the first seven bits after the ST condition with its own address. If they match, the device considers itself addressed by the primary. The ninth clock pulse, following the secondary address byte (and each subsequent byte) is the acknowledge (ACK). The transmitter must release the SDA line during the ACK period. The receiver must then pull the data line low so that it remains stable low during the high period of the acknowledge clock period.

The number of bytes per transfer is unlimited. If a receiver cannot receive another complete byte of data until it has performed some other function, it can hold the SCL line low to force the transmitter into a wait state. Data transfer only continues when the receiver is ready for another byte and releases the clock line. This delay action is called clock stretching. Not all primary devices support clock stretching. This device implements clock stretching—the SCL line may be stretched (pulled low) for up to 1 µs when needed during a read operation. When applied, clock stretching occurs after the ACK issued by the I<sup>2</sup>C bus primary.

A LOW-to-HIGH transition on the SDA line while the SCL line is high is defined as a stop condition (SP) signal. The primary issuing the SP signal always terminates a write or burst write. A primary should properly terminate

FXLS8971C

All information provided in this document is subject to legal disclaimers.

© 2024 NXP B.V. All rights reserved.

a read by not acknowledging a byte at the appropriate time in the protocol, followed by the SP signal. A primary may also issue a repeated start signal (SR) during a transfer.

### 12.1.2 I<sup>2</sup>C read/write operations

#### 12.1.2.1 Single-byte read

The primary transmits a start condition (ST) to FXLS8971CF, followed by the secondary address, with the R/W bit set to '0' for a write, and the FXLS8971CF sends an acknowledgment. Then the primary transmits the address of the register to read and the FXLS8971CF sends an acknowledgment. The primary transmits a repeated start condition (SR), followed by the secondary address with the R/W bit set to '1' for a read from the previously selected register. The FXLS8971CF then acknowledges and transmits the data from the requested register. The primary does not acknowledge (NAK) the transmitted data and then transmits a stop condition to end the data transfer.

#### 12.1.2.2 Multiple-byte read

When performing a multi-byte or *burst* read, FXLS8971CF automatically increments the register read address pointer after a read command is received. Therefore, after following the steps of a single-byte read, multiple bytes of data can be read from sequential register addresses after each FXLS8971CF acknowledgment (ACK) is received. Data can be read until the primary issues a no acknowledge (NAK), followed by a stop condition (SP) signaling the end of the transfer.

#### 12.1.2.3 Single-byte write

To start a write command, the primary transmits a start condition (ST) to the FXLS8971CF, followed by the secondary address with the R/W bit set to '0' for a write, and the FXLS8971CF sends an acknowledgment. Then the primary transmits the address of the register to write to, and the FXLS8971CF sends an acknowledgment. Then the primary transmits the 8-bit data to write to the designated register and the FXLS8971CF sends an acknowledgment signaling it has received the data. Since this transmission is complete, the primary transmits a stop condition (SP) to end the data transfer. The data sent to the FXLS8971CF is now stored in the appropriate register.

#### 12.1.2.4 Multiple-byte write

FXLS8971CF automatically increments the register address write pointer after a write command is received. Therefore, after following the steps of a single-byte write, multiple bytes of data can be written to sequential registers after each acknowledgment (ACK) is received.

### 12.1.2.5 I<sup>2</sup>C data sequence diagrams

| <si< th=""><th colspan="9"><single byte="" read=""></single></th></si<>                                                                                                                                                    | <single byte="" read=""></single> |         |        |        |             |      |        |             |            |          |        |          |         |       |        |       |           |        |      |     |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|---------|--------|--------|-------------|------|--------|-------------|------------|----------|--------|----------|---------|-------|--------|-------|-----------|--------|------|-----|
| Primary                                                                                                                                                                                                                    |                                   | ST      | Devi   | ice Ad | dress[6:0]  | W    |        | Register Ad | dress[7:0] |          | SR     | Device A | ddress  | [6:0] | R      |       |           |        | NACK | SP  |
| Secondary                                                                                                                                                                                                                  |                                   |         |        |        |             |      | 101/   |             |            | ACK      |        |          |         |       |        | ACK   | DATAG     | 7.01   |      |     |
| Secondary                                                                                                                                                                                                                  |                                   |         |        |        |             |      | ACK    |             |            | ACK      |        |          |         |       |        | ACK   | DATA[     | 7:0]   |      |     |
| <m< td=""><td>ultipl</td><td>e Byte</td><td>Rea</td><td>d&gt;</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></m<>    | ultipl                            | e Byte  | Rea    | d>     |             |      |        |             |            |          |        |          |         |       |        |       |           |        |      |     |
| Primary                                                                                                                                                                                                                    |                                   | ST      | Devi   | ice Ad | dress[6:0]  | W    |        | Register Ad | dress[7:0] |          | SR     | Device A | ddress  | [6:0] | R      |       |           |        | ACK  |     |
|                                                                                                                                                                                                                            |                                   |         |        |        |             |      |        |             |            |          |        |          |         |       | _      |       | cont      | nued - |      | - ¬ |
| Secondary                                                                                                                                                                                                                  |                                   |         |        |        |             |      | ACK    |             |            | ACK      |        |          |         |       |        | ACK   | DATA[     | 7:0]   |      | į   |
| r                                                                                                                                                                                                                          |                                   |         |        |        |             |      |        |             |            |          |        |          |         |       |        |       |           |        |      |     |
| Primary                                                                                                                                                                                                                    |                                   |         |        | ACK    |             |      | ACK    |             | NACK S     | Р        |        |          |         |       |        |       |           |        |      |     |
| Secondary                                                                                                                                                                                                                  | D                                 | ata[7:  | 0]     |        | Data[7:0    |      |        | Data[7:0]   |            |          |        |          |         |       |        |       |           |        |      |     |
| <si< td=""><td>ingle</td><td>Byte \</td><td>//rite</td><td>&gt;</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></si<> | ingle                             | Byte \  | //rite | >      |             |      |        |             |            |          |        |          |         |       |        |       |           |        |      |     |
| Primary                                                                                                                                                                                                                    |                                   | ST      | Devi   | ice Ad | dress[6:0]  | W    |        | Register Ad | dress[7:0] |          | Da     | ata[7:0] |         | SP    |        |       |           |        |      |     |
| Secondary                                                                                                                                                                                                                  |                                   |         |        |        |             |      | ACK    |             |            | ACK      |        |          | ACK     |       |        |       |           |        |      |     |
|                                                                                                                                                                                                                            | <u> </u>                          |         |        |        |             |      |        |             |            |          |        |          |         |       |        |       |           |        |      |     |
| <m< td=""><td>ultipl</td><td>e Byte</td><td>Write</td><td>e&gt;</td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td><td></td></m<>  | ultipl                            | e Byte  | Write  | e>     |             |      |        |             |            |          |        |          |         |       |        |       |           |        |      |     |
| Primary                                                                                                                                                                                                                    |                                   | ST      | Devi   | ice Ad | dress[6:0]  | W    |        | Register Ad | dress[7:0] |          | Da     | ata[7:0] |         | Dat   | a[7:0] |       | SP        |        |      |     |
| Secondary                                                                                                                                                                                                                  |                                   |         |        |        |             |      | ACK    |             |            | ACK      |        |          | ACK     |       |        | AC    | к         |        |      |     |
| l ec                                                                                                                                                                                                                       | gend                              |         |        |        |             |      |        |             |            |          |        |          |         |       |        |       |           |        |      |     |
| ST: Start                                                                                                                                                                                                                  |                                   | مدنئنام | c      | D. Cta | p Condition | ,    | \CK. A | cknowledge  | NACK: N    | ام ۸ ماد | البدمة | adaa \\/ | : Write | _ ^   | CD.    | Danas | ated Star | t Cand | tion |     |
| ST. Start                                                                                                                                                                                                                  | Con                               | aillon  | 3      | P. 510 | p Condition | F    | ACK: A | cknowledge  | NACK: I    | NO ACK   | nowie  | eage vv. | . write | - 0   | SK.    | Repea |           |        |      |     |
|                                                                                                                                                                                                                            | 2                                 |         |        |        |             |      |        |             |            |          |        |          |         |       |        |       | á         | aa-040 | 837  |     |
| Figure 8                                                                                                                                                                                                                   | . I <sup>2</sup> (                | Da      | ta S   | eque   | nce Diag    | ıran | ns     |             |            |          |        |          |         |       |        |       |           |        |      |     |

#### 13 SPI interface

The SPI interface is a classic primary/secondary serial port. FXLS8971CF is always considered to be the secondary device and therefore never initiates communication with the host processor.

The SPI interface of FXLS8971CF is compatible with interface mode 00, corresponding to CPOL = 0 and CPHA = 0.

For CPOL = 0, the idle value of the clock is zero, and the active value of the clock is 1. For CPHA = 0, data is captured on the rising edge (low to high transition) of the clock, and data is propagated on the falling edge (high to low transition) of the clock.

#### 13.1 General SPI operation

The SPI\_CS\_B pin is driven low at the start of a transaction, held low during the transfer, and then driven high again after the transaction is completed. During a transaction, the primary toggles the clock (SCLK). The SCLK polarity is defined as having an idle value that is low, and an active phase that is high (CPOL = 0). Serial input and output data is captured on the rising edge of the clock and propagated on the falling edge (CPHA = 0). Single-byte read and single-byte write operations are completed in 24 SCLK cycles; multiple-byte reads and

FXLS8971CI

All information provided in this document is subject to legal disclaimers.

© 2024 NXP B.V. All rights reserved.

writes are completed in additional multiples of 8 SCLK cycles per read or written byte. The first SCLK cycle latches the R/W (Read/Write) bit to select whether the desired operation is a read (R/W = 1) or a write (R/W = 0). The following seven SCLK cycles are used to latch the register read or write address.

**Note:** 4-wire SPI interface mode is the default out of POR or after a soft reset. In order to select 3-wire SPI interface mode, set the **SENS\_CONFIG1[SPI\_M]** = 1.

### 13.2 SPI write operations with 3- or 4-wire mode

A write operation is initiated by transmitting a 0 for the R/W bit. Then, the 7-bit register write address, A[6:0], is transmitted in MSB first order. Following this first byte, a second byte of 0s or 1s (don't care condition) transfers, followed by the actual data to write in the third group of 8 SCLK cycles (clock pulses 17 through 24) in MSB first order. Figure 9 shows the bus protocol for a single-byte register write operation in either 3- or 4-wire SPI mode.



Multiple-byte write operations are performed similarly to the single-byte write sequence, but with additional data bytes transferred over additional 8 SCLK cycle periods. FXLS8971CF auto-increments the register write address so that every eighth clock edge latches the address for the next register write address. When the desired number of bytes has been written, a rising edge on the SPI\_CS\_B pin terminates the transaction. Figure 10 shows the bus protocol for multiple-byte register write operations in either 3- or 4-wire SPI mode.



### 13.3 SPI read operations with 4-wire mode

A register read operation is initiated by transmitting a 1 for the R/W bit. Then, the 7-bit register read address, A[6:0] is encoded in the first byte. Following this first byte, a second byte of 0s or 1s (don't care condition) transfers. After this transfer completes, the next 8 SCLK cycles (pulses 17 through 24) output the selected register content on the SPI\_MISO line in MSB first order. Figure 11 shows the bus protocol for a single-byte read operation.

FXLS8971CF



Multiple-byte read operations are performed similarly to single-byte reads with additional bytes read out in multiples of eight SCLK cycles. FXLS8971CF auto-increments the register read address so that every eighth clock edge latches the address of the next sequential register read address. When the desired number of bytes has been read, a rising edge on SPI\_CS\_B terminates the transaction.



### 13.4 SPI read operations with 3-wire mode

FXLS8971CF can be configured to operate in 3-wire software enabled SPI mode. In this mode, the SPI\_MISO pin is left unconnected and the SPI\_MOSI pin becomes a bidirectional input/output pin (SPI\_DATA). Read operations in 3-wire mode are the same as write operations in 3- and 4-wire modes, except that at the end of the address cycle (falling edge of clock pulse 16), the SPI\_DATA pin automatically switches from an input to an output and with bit D7 as the current output state.



FXLS8971CF



### 13.5 SPI timing specifications (4-wire mode and 3-wire hardwired modes)

Table 13 and Figure 15 specify and illustrate the minimum and maximum timing parameter values for correct SPI interface functionality when FXLS8971CF is operated in 4-wire and 3-wire hardwired SPI modes. FXLS8971CF only supports SPI mode 00, corresponding to CPOL = 0, and CPHA = 0. In this mode, the active state of the clock is high and the idle state is low. Data is latched on the rising edge of the clock and propagated on the falling edge. All timing specifications shown in Table 13 were determined under the following conditions: 10 pF capacitor and 1 kΩ pull-up resistor present on all SPI signals, 105 °C, 1.8 V.

Table 13. Secondary timing values

| Label  | Description                                                     | Specifi | Specifications |     |  |
|--------|-----------------------------------------------------------------|---------|----------------|-----|--|
|        |                                                                 | Min.    | Max.           |     |  |
| fSCLK  | SCLK frequency                                                  | 0       | 4              | MHz |  |
| tSCLK  | SCLK Period                                                     | 250     | _              | ns  |  |
| tSCLKH | SCLK high time                                                  | 100     | _              | ns  |  |
| tSCLKL | SCLK low time                                                   | 100     | _              | ns  |  |
| tHZ    | Hold time for SPI_MISO signal (transition back to high-z state) | _       | 15             | ns  |  |
| tSCS   | Setup time for SPI_CS_B signal                                  | 125     | _              | ns  |  |
| tHCS   | Hold time for SPI_CS_B signal                                   | 240     | _              | ns  |  |
| tWCS   | Inactive time for SPI_CS_B signal                               | 600     | _              | ns  |  |
| tSET   | Data setup time for SPI_MOSI signal                             | 10      | _              | ns  |  |
| tHOLD  | Data hold time for SPI_MOSI signal                              | 10      | _              | ns  |  |
| tDDLY  | Setup time for SPI_MISO signal (transition out of high-z state) | _       | 50             | ns  |  |



### 13.6 SPI timing specifications (software enabled 3-wire mode)

Table 14 and Figure 16 specify and illustrate the minimum and maximum timing parameter values for correct SPI interface functionality when FXLS8971CF is operated in 3-wire (software enabled) SPI mode. FXLS8971CF only supports SPI mode '00', corresponding to CPOL = 0, and CPHA = 0. In this mode, the active state of the clock is high and the idle state is low. Data is latched on the rising edge of the clock and propagated on the falling edge. All timing specifications shown in Table 14 were determined under the following conditions: 10 pF capacitor and 1 kΩ pull-up resistor present on all SPI signals, 105 °C, 1.8 V.

**Note:** When FXLS8971CF is operated in 3-wire SPI mode - by setting **SENS\_CONFIG1**[SPI\_M] = 1 - the SA0/SPI\_MISO pin is always placed in a high impedance (high-z) state, with the SPI\_MISO pin output driver disabled (tri-stated).

Table 14. Secondary timing values

| Label  | Description                                                           | Specifi | cations | Unit |
|--------|-----------------------------------------------------------------------|---------|---------|------|
|        |                                                                       | Min.    | Max.    |      |
| fSCLK  | SCLK frequency                                                        | 0       | 4       | MHz  |
| tSCLK  | SCLK Period                                                           | 250     | _       | ns   |
| tSCLKH | SCLK high time                                                        | 100     | _       | ns   |
| tSCLKL | SCLK low time                                                         | 100     | _       | ns   |
| tSCS   | Setup time for SPI_CS_B signal                                        | 125     | _       | ns   |
| tHCS   | Hold time for SPI_CS_B signal                                         | 240     | _       | ns   |
| tHZ    | Hold time for SPI_DATA signal transition back to high-impedance state | _       | 25      | ns   |
| tWCS   | Inactive time for SPI_CS_B signal                                     | 600     | _       | ns   |
| tSET   | Data setup time for SPI_DATA signal                                   | 10      | _       | ns   |
| tHOLD  | Data hold time for SPI_DATA signal                                    | 10      | _       | ns   |
| tDDLY  | Data setup time for SPI_DATA signal (output phase)                    | _       | 50      | ns   |



## 14 Operating modes

Table 15. FXLS8971CF operating modes descriptions

| Mode <sup>[1]</sup> | I <sup>2</sup> C/SPI<br>bus state | $V_{DD}$ | Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------------|-----------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OFF                 | Unavailable                       | < 1.71 V | Communication with FXLS8971CF is not possible, but communications with other devices on the same I <sup>2</sup> C/SPI bus is possible provided the V <sub>DD</sub> supply pin is left floating/unconnected and not connected to GND.                                                                                                                                                                                                               |
|                     |                                   |          | If V <sub>DD</sub> is not left floating/unconnected, the ESD protection diodes on the interface pins could become forward biased and clamp the bus, preventing normal operation.                                                                                                                                                                                                                                                                   |
|                     |                                   |          | As soon as the supply reaches 1.71 V, the device BOOT process begins.                                                                                                                                                                                                                                                                                                                                                                              |
| BOOT                | Unavailable                       | ≥ 1.71 V | BT_MODE = GND:                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                     |                                   |          | In this phase, the device is initialized and any default configuration parameters are loaded from OTP memory. When this phase is complete, the SRC_BOOT bit is set and a $T_{\text{PULSE-BOOT1}}~\mu s$ pulse may be signaled on either one of the INT1/2 pins (defaults enabled on the INT1 pin after POR).                                                                                                                                       |
|                     |                                   |          | BT_MODE = V <sub>DD</sub> :                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                     |                                   |          | In this phase, the device is initialized and any default configuration parameters are loaded from OTP memory, along with any default Motion Detection function specific parameters. When the default configuration parameters are loaded from OTP memory, the SRC_BOOT bit is set and a boot pulse, T <sub>PULSE-BOOT2</sub> , can be signaled on the INT2 pin. By default, the boot pulse is routed to INT2 pin and cannot be routed to INT1 pin. |

Table 15. FXLS8971CF operating modes descriptions...continued

| Mode <sup>[1]</sup>                          | I <sup>2</sup> C/SPI<br>bus state | $V_{DD}$ | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------------------------------------|-----------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Hibernate <sup>[2]</sup>                     | Unavailable                       | ≥ 1.71 V | The wake-up detection circuit is active, but all other analog and digital blocks are disabled to minimize the current drawn on the $V_{DD}$ pin. $I^2C$ and SPI interfaces are not available, and all previously written register settings are lost.<br><b>BT_MODE = GND:</b> The host must toggle the SPI_CS_B / WAKE-UP pin (low-to-high or high-to-low) in order to initiate a transition back into Standby mode before attempting communications with the device. The host must wait $T_{BOOT1}$ ms for the boot process to complete. <b>BT_MODE = V_{DD:</b> The INT1/MOT_DET pin is set high (level sensitive) through an external pull-up resistor; the device then exits Hibernate mode and starts the BOOT process. The host must wait $T_{BOOT2}$ ms for the boot process to complete and the motion detection process to begin. Communication with the device over the $I^2C$ or SPI interfaces is possible after the BOOT process completes. |
| Standby                                      | Available                         | ≥ 1.71 V | Sensor and analog blocks are disabled; I <sup>2</sup> C and SPI interfaces are available.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Active <sup>[3][4]</sup><br>(WAKE/<br>SLEEP) | Available                         | ≥ 1.71 V | Sensor and analog blocks are enabled when needed (power cycled). $I^2C$ and SPI interfaces are available.<br><b>BT_MODE = GND:</b> FXLS8971CF can automatically transition between the Active SLEEP and WAKE sub-modes when activity/inactivity is detected. Setting <b>ASLP_COUNT</b> $\geq$ 1 enables the Auto-WAKE/SLEEP mode. <b>BT_MODE = V_DD:</b> The Auto-WAKE/SLEEP function is not typically used in this mode (defaults to disabled), but the host may enable Auto-WAKE/SLEEP by configuring it through the register interface.                                                                                                                                                                                                                                                                                                                                                                                                               |
| Active <sup>[5]</sup><br>(EXT_<br>TRIG)      | Available                         | ≥ 1.71 V | All blocks are enabled when needed (power cycled). I <sup>2</sup> C and SPI interfaces are able to respond to read and write commands.  BT_MODE = GND:  SENS_CONFIG4[INT2_FUNC] = 1  FXLS8971CF automatically transitions between EXT_TRIG and Active mode upon receiving a trigger signal (low-to-high transition) on the EXT_TRIG/INT2 pin. Once the measurement cycle has completed, FXLS8971CF automatically transitions back to the EXT_TRIG state and waits for the next trigger event.  BT_MODE = V_DD:  External trigger mode is not available; SENS_CONFIG4 [INT2_FUNC] shall not be written to with any value other than 0.                                                                                                                                                                                                                                                                                                                    |

<sup>[1]</sup> All register contents are preserved when transitioning from Active to Standby mode. Some registers are reset when transitioning from Standby to Active. The behavior of all registers is noted in <u>Table 20</u>.

<sup>[2]</sup> Exiting Hibernate mode causes all register settings to initialize to their default values. Entering Hibernate mode is equivalent to removing the V<sub>DD</sub> supply; the device state, sensor data, and host programmed register contents are lost when this mode is entered.

<sup>[3]</sup> The SLEEP and WAKE modes are Active measurement modes. For more information on how to use the SLEEP and WAKE modes and how to transition between these modes, see Table 16.

<sup>[4]</sup> The SLEEP and WAKE modes each feature independent power mode and ODR settings for the HPM and LPM modes. FPM may also be independently enabled for either WAKE or SLEEP modes, allowing for user programmable idle times and measurement decimation factors. These features allow for the creation of custom ODRs and also realizing the optimal trade-off between resolution (noise) and power dissipation in a given application or use case.

<sup>[5]</sup> The EXT\_TRIG mode may be used to synchronize the collection of acceleration and temperature data with an external system, or to create custom ODRs using an MCU output compare/PWM/GPIO pin.



Table 16. Operating modes transition criteria

| Callout | Current<br>mode | Next mode | Transition criteria                                                                                                                                                                                                                                                                                                                                                                            |
|---------|-----------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1       | OFF             | воот      | Apply V <sub>DD</sub> ≥ V <sub>DD</sub> min                                                                                                                                                                                                                                                                                                                                                    |
| 2       | ВООТ            | Standby   | BOOT_MODE = GND: Wait T <sub>BOOT1</sub> ms after applying V <sub>DD</sub> ≥ VDD <sub>min</sub> ; FXLS8971CF enters Standby mode and waits for I <sup>2</sup> C/SPI commands. BT_MODE = V <sub>DD</sub> : Wait T <sub>BOOT2</sub> ms after setting the INT1 / MOT_DET pin high. FXLS8971CF automatically transitions into WAKE (SENS_CONFIG1[ACTIVE] bit is automatically set, see callout 7). |
| 3       | Standby         | Hibernate | BOOT_MODE = GND:  Set SENS_CONFIG5[HIBERNATE_EN] = 1; the device may then be woken up only by toggling the SPI_CS_B / WAKE_UP pin.  BOOT_MODE = V <sub>DD</sub> :  The host MCU drives the MOT_DET pin low for ≥ T <sub>MOT-HIB</sub> ms to enter Hibernate mode. The device remains in Hibernate mode as long as the MOT_DET pin remains low. <sup>[1]</sup>                                  |
| 4       | Hibernate       | воот      | BT_MODE = GND: The host MCU must toggle the SPI_CS_B / WAKE_UP pin BT_MODE = V_DD:  FXLS8971CF exits Hibernate mode and begins the BOOT sequence when the MOT_DET pin is pulled high.                                                                                                                                                                                                          |
| 5       | Standby         | EXT_TRIG  | BT_MODE = GND: Enable the EXT_TRIG input function by setting SENS_CONFIG4[INT2_FUNC] = 1. BT_MODE = V <sub>DD</sub> : The EXT_TRIG function is not available when BT_MODE = V <sub>DD</sub> ; this transition is not possible                                                                                                                                                                  |
|         | EXT_TRIG        | Standby   | BT_MODE = GND: Disable the EXT_TRIG input function by setting SENS_CONFIG4[INT2_FUNC] = 0. BT_MODE = V <sub>DD</sub> : The EXT_TRIG function is not available when BT_MODE = V <sub>DD</sub> ; this transition is not possible                                                                                                                                                                 |
| 6       | EXT_TRIG        | WAKE      | BT_MODE = GND: To initiate an ADC conversion, signal a low to high state transition on the INT2/EXT_TRIG pin. BT_MODE = V <sub>DD</sub> : The EXT_TRIG function is not available when BT_MODE = V <sub>DD</sub> ; this transition is not possible                                                                                                                                              |
|         | WAKE            | EXT_TRIG  | BT_MODE = GND:  FXLS8971CF automatically returns to the EXT_TRIG state once the previously triggered measurement has completed.  BT_MODE = V <sub>DD</sub> :  The EXT_TRIG function is not available when BT_MODE = V <sub>DD</sub> ; this transition is not possible                                                                                                                          |

Table 16. Operating modes transition criteria...continued

| Callout | Current<br>mode | Next mode | Transition criteria                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------|-----------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7       | Standby         | WAKE      | BT_MODE = GND:  Set SENS_CONFIG1[ACTIVE] = 1  BT_MODE = V <sub>DD</sub> :  The SENS_CONFIG1[ACTIVE] bit is set automatically after the BOOT process completes when the INT1/MOT_DET pin is held high.  The host may also manually set this bit using the I <sup>2</sup> C or SPI interfaces to resume motion detection mode after changing the device configuration (after entering Standby mode from WAKE mode via register command) |
|         | WAKE            | Standby   | BT_MODE = GND: Set SENS_CONFIG1[ACTIVE] = 0 BT_MODE = $V_{DD}$ : The SENS_CONFIG1[ACTIVE] bit clears automatically when the INT1/MOT_DET pin is brought low for $\geq T_{MOT\_HIB}$ ms; The host may also manually clear this bit using the I <sup>2</sup> C or SPI interfaces in order to change the default device configuration.                                                                                                   |
| 8       | WAKE            | SLEEP     | When ASLP_CNT ≥ 1, the device transitions to the SLEEP mode when none of the configured AWS interrupt sources clear the Auto-Wake/Sleep timer before it expires (host programmed ASLP_CNT value is reached), allowing the device to conserve energy by automatically using a lower ODR and/or power (performance) mode.                                                                                                               |
|         | SLEEP           | WAKE      | One or more of the configured AWS event sources triggers the exit from SLEEP mode and entry into WAKE.                                                                                                                                                                                                                                                                                                                                |

[1] The host may also set **SENS\_CONFIG5[**HIBERNATE\_EN**]** = 1 to enter Hibernate mode, but a logic state transition on the SPI\_CS\_B / WAKE\_UP pin does not cause the device to exit Hibernate mode when BT\_MODE = V<sub>DD</sub>.



Table 17. BOOT2 sequence and One-wire motion protocol phase descriptions

| Protocol phase | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1              | $V_{DD}$ supply is not present ( $V_{DD}$ < $VDD_{min}$ ); MCU and FXLS8971CF are both OFF; all IO pins are floating/high-z.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2              | $V_{DD} \ge VDD_{min}$ ; MCU and FXLS8971CF are turned on; FXLS8971CF performs the BOOT sequence. During this phase, the MOT_DET input and BOOT_OUT open-drain output functions are enabled. FXLS8971CF turns on the BOOT_OUT output for $T_{PULSE-BOOT2}$ ms.  *Note: The BOOT_OUT pulse is not observable in the wired-AND configuration as it is assumed the host MCU has not yet enabled the pull-up resistor on the MOT_DET and BOOT_OUT pins (one pull-up resistor for both pins).                                                                                                                                                                                                                                                                                                             |
| 3              | If the MCU has not yet asserted the MOT_DET pin, FXLS8971CF enters Hibernate mode directly after the BOOT sequence. During this phase, FXLS8971CF MOT_DET pin input function remains enabled, waiting for the MOT_DET pin to go high, which triggers an exit from this mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 4              | The MCU asserts the MOT_DET pin high by enabling the pull-up; FXLS8971CF exits Hibernate mode and performs the BOOT sequence. Anytime within $T_{PULSE-WIN}$ ms after the BOOT_OUT pulse rising edge (measured from the VOL point), the host MCU may pulse the MOT_DET line low to signal the desired motion detection threshold selection. If no pulse is seen within this window, the default $T_{PULSE-THRES0}$ threshold value is used. The available pulse selections are shown in Table 18. The pulse is only recognized if it begins and ends within the $T_{PULSE-WIN}$ ms period after the BOOT_OUT pulse rising edge, and also conforms to the min and max values as shown in Table 18. If an invalid pulse width is observed, it is ignored and the default threshold value used instead. |
| 5              | Motion detection phase: FXLS8971CF continually scans for motion at the preconfigured ODR. If the motion threshold and debounce criteria are met, a T <sub>PULSE-MOT</sub> ms pulse is signaled on the MOT_DET pin (Open-Drain output is turned on). During this phase, the host may also communicate with FXLS8971CF over the I <sup>2</sup> C or SPI interfaces.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 6              | Hibernate mode: When motion detection is no longer needed, the host MCU drives MOT_DET low forcing FXLS8971CF into Hibernate mode to conserve power. FXLS8971CF delays the entry into Hibernate mode for T <sub>MOT-HIB</sub> ms after the MOT_DET pin is brought low to debounce the line.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

Table 18. One-wire motion protocol threshold selections

| Selection                           | Min pulse (µs) | Nom pulse (µs) | Max pulse (µs) | Upper threshold counts (mg) <sup>[1]</sup> | Lower threshold counts (mg) <sup>[1]</sup> |
|-------------------------------------|----------------|----------------|----------------|--------------------------------------------|--------------------------------------------|
| T <sub>PULSE-THRES0</sub> (default) | _              | 0              | _              | 64 (125)                                   | -64 ( <del>-</del> 125)                    |
| T <sub>PULSE-THRES1</sub>           | 562.5          | 625            | 883            | 32 (62)                                    | -32 (-62)                                  |
| T <sub>PULSE-THRES2</sub>           | 1125           | 1250           | 1570           | 96 (187)                                   | -96 (-187)                                 |
| T <sub>PULSE-THRES3</sub>           | 2250           | 2500           | 2950           | 128 (250)                                  | -128 (-250)                                |

<sup>[1]</sup> Threshold mg values assume the default  $\pm 4~g$  FSR is used (sensitivity of 1.95 mg/LSB, typical)



Table 19. BOOT1 sequence description (BT\_MODE = GND)

| Protocol phase | Description                                                                                                                                                                                                                                                                                  |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1              | $V_{DD}$ supply is not present ( $V_{DD}$ < $VDD_{min}$ ); MCU and FXLS8971CF are both off; all IO pins are floating/high-z.                                                                                                                                                                 |
| 2              | $V_{DD} \ge VDD_{min}$ ; MCU and FXLS8971CF are turned on; FXLS8971CF performs the BOOT sequence and provides the BOOT_OUT output pulse for $T_{PULSE-BOOT1}$ ms.                                                                                                                            |
| 3              | FXLS8971CF enters standby mode directly after the BOOT sequence.                                                                                                                                                                                                                             |
| 4              | When the MCU sends a serial command to set <b>SENS_CONFIG5[</b> HIBERNATE_EN <b>]</b> bit to 1, FXLS8971CF enters Hibernate mode. NOTE: The device enters into Hibernate mode 1us (typ) after the SPI_CS_B line is de-asserted for the corresponding HIBERNATE_EN serial command.            |
| 5              | To wake up the device from Hibernate mode, the MCU toggles the SPI_CS_B/WAKE UP pin (see T <sub>FLT-WAKE</sub> _UP deglitch filter time for transition out of Hibernate mode); FXLS8971CF performs the BOOT sequence and provides the BOOT_OUT output pulse for T <sub>PULSE-BOOT1</sub> ms. |
| 6              | FXLS8971CF enters standby mode directly after the BOOT sequence.                                                                                                                                                                                                                             |
| 7              | When the MCU sends a serial command to set <b>SENS_ CONFIG1</b> [ACTIVE] bit to 1, FXLS8971CF enters active mode.                                                                                                                                                                            |

# 15 Register descriptions

### 15.1 Complete register map

Table 20. Register address map

| Name                         | Туре | Register | Auto-increment Address |                             | Default                                       | Comment                                                                                                                                                                                                                                                            |  |
|------------------------------|------|----------|------------------------|-----------------------------|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                              |      | Address  | F_READ = 0             | F_READ = 1                  | Values<br>BT_MODE =<br>GND/[V <sub>DD</sub> ] |                                                                                                                                                                                                                                                                    |  |
| INT_STATUS [1] [2]           | R    | 00h      |                        | /04h/06h/<br>/0Eh/10h       | 01h                                           | Interrupt and system status event flags.                                                                                                                                                                                                                           |  |
| TEMP_OUT [1]                 | R    | 01h      | 02h/04h/06h/08         | 8h/ 0Ch/0Eh/10h             | _                                             | Temperature output data – temp_out[7:0]. When SENS_CONFIG2[AINC_TEMP] = 0 the auto-increment mechanism skips this register.                                                                                                                                        |  |
| VECM_LSB [1] [3]             | R    | 02h      | 03h                    | 04h/06h/08h/0<br>Ch/0Eh/10h | _                                             | 12-bit unsigned vector magnitude LSB/MSB: VECM[7:0] (LSB) when <b>SENS_CONFIG2</b> [LE_BE] = 0, and VECM[11:4] (MSB) when <b>SENS_ CONFIG2</b> [LE_BE] = 1. This register is skipped over by the auto-increment mechanism when <b>SENS_ CONFIG5</b> [VECM_EN] = 0. |  |
| VECM_MSB [1] [3]             | R    | 03h      | 04h/06h/08h,           | /0Ch/0Eh/10h                | _                                             | 12-bit unsigned vector magnitude MSB/LSB: VECM[11:8] (MSB) when <b>SENS_CONFIG2</b> [LE_BE] = 0, and VECM[3:0] (LSB) when <b>SENS_ CONFIG2</b> [LE_BE] = 1. This register is skipped over by the auto-increment mechanism when <b>SENS_ CONFIG5</b> [VECM_EN] = 0. |  |
| OUT_X_LSB <sup>[1] [3]</sup> | R    | 04h      | 05h                    | 06h/08h/00h                 | _                                             | LSB/MSB of current 12-bit X-axis accelerometer output data – x_data_out[7:0] when SENS_CONFIG2[LE_BE] = 0 and x_data_out[11:4] when SENS_CONFIG2[LE_BE] = 1. When SENS_CONFIG5[X_DIS] = 1, this register is skipped over by the auto-increment mechanism.          |  |
| OUT_X_MSB <sup>[1] [3]</sup> | R    | 05h      | 06h/08h/00h            |                             | _                                             | MSB/LSB of current 12-bit X-axis accelerometer output data – x_data_out[11:8] when SENS_CONFIG2[LE_BE] = 0 and x_data_out[3:0] when SENS_CONFIG2[LE_BE] = 1. When SENS_CONFIG5[X_DIS] = 1, this register is skipped over by the auto-increment mechanism.          |  |
| OUT_Y_LSB <sup>[1] [3]</sup> | R    | 06h      | 07h                    | 08h/00h                     | _                                             | LSB/MSB of current 12-bit Y-axis accelerometer output data – y_data_out[7:0] when SENS_CONFIG2[LE_BE] = 0 and y_data_out[11:4] when SENS_CONFIG2[LE_BE] = 1. When SENS_CONFIG5[Y_DIS] = 1, this register is skipped over by the auto-increment mechanism.          |  |
| OUT_Y_MSB <sup>[1] [3]</sup> | R    | 07h      | 08h                    | /00h                        | _                                             | MSB/LSB of current 12-bit Y-axis accelerometer output data – y_data_out[11:8] when SENS_ CONFIG2[LE_BE] = 0 and y_data_out[3:0] when SENS_CONFIG2[LE_BE] = 1. When SENS_ CONFIG5[Y_DIS] = 1, this register is skipped over by the auto-increment mechanism.        |  |
| OUT_Z_LSB <sup>[1] [3]</sup> | R    | 08h      | 09h                    | 00h                         | _                                             | LSB/MSB of current 12-bit Z-axis accelerometer output data – z_data_out[7:0] when SENS_ CONFIG5[LE_BE] = 0 and z_data_out[11:4] when SENS_CONFIG2[LE_BE] = 1. When SENS_ CONFIG5[Z_DIS] = 1, this register is skipped over by the auto-increment mechanism.        |  |
| OUT_Z_MSB <sup>[1] [3]</sup> | R    | 09h      | 00h                    |                             | _                                             | MSB/LSB of current 12-bit Z-axis accelerometer output data – z_data_out[11:8] when SENS_CONFIG2[LE_BE] = 0 and z_data_out[3:0] when SENS_CONFIG2[LE_BE] = 1. When SENS_CONFIG5[Z_DIS] = 1, this register is skipped over by the auto-increment mechanism.          |  |
| Reserved registers           |      |          |                        |                             |                                               |                                                                                                                                                                                                                                                                    |  |
| RESERVED_REG1                |      | 0Ah      | 01                     | Bh                          | 00h                                           | Factory reserved register address 1                                                                                                                                                                                                                                |  |
|                              |      |          |                        |                             |                                               | ·                                                                                                                                                                                                                                                                  |  |

Table 20. Register address map...continued

| Name                           | Type         | Register | Auto-increm | nent Address | Default                                 | Comment                                                                                                                                                                                                                                   |  |
|--------------------------------|--------------|----------|-------------|--------------|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                |              | Address  | F_READ = 0  | F_READ = 1   | Values BT_MODE = GND/[V <sub>DD</sub> ] |                                                                                                                                                                                                                                           |  |
| Output Buffer Configuratio     | n and Statu  | s        |             |              |                                         |                                                                                                                                                                                                                                           |  |
| BUF_STATUS <sup>[1][2]</sup>   | R            | 0Bh      | 0Ch/0       | Eh/10h       | 00h                                     | Buffer watermark and overflow status flags; stored sample count (buf_cnt[5:0])                                                                                                                                                            |  |
| BUF_X_LSB <sup>[1][3][4]</sup> | R            | 0Ch      | 0Dh         | 0Eh/10h/0Ch  | _                                       | Head/Tail sample of output buffer X-axis LSB - buf_x_out[7:0] when SENS_CONFIG2[LE_BE] = 0 and buf_x_out[11:4] when SENS_CONFIG2[LE_BE] = 1. When SENS_CONFIG5[X_DIS] = 1, this register is skipped over by the auto-increment mechanism. |  |
| BUF_X_MSB <sup>[1][3][4]</sup> | R            | 0Dh      | 0Eh/1       | 0h/0Ch       | _                                       | Head/Tail sample of output buffer X-axis MSB - buf_x_out[11:8] when SENS_CONFIG2[LE_BE] = 0 and buf_x_out[3:0] when SENS_CONFIG2[LE_BE] = 1. When SENS_CONFIG5[X_DIS] = 1, this register is skipped over by the auto-increment mechanism. |  |
| BUF_Y_LSB <sup>[1][3][4]</sup> | R            | 0Eh      | 0Fh         | 10h/0Ch/0Eh  | _                                       | Head/Tail sample of output buffer Y-axis LSB - buf_y_out[7:0] when SENS_CONFIG2[LE_BE] = 0 and buf_y_out[11:4] when SENS_CONFIG2[LE_BE] = 1. When SENS_CONFIG5[Y_DIS] = 1, this register is skipped over by the auto-increment mechanism. |  |
| BUF_Y_MSB <sup>[1][3][4]</sup> | R            | 0Fh      | 10h/0Ch/0Eh |              | _                                       | Head/Tail sample of output buffer Y-axis MSB - buf_Y_out[11:8] when SENS_CONFIG2[LE_BE] = 0 and buf_y_out[3:0] when SENS_CONFIG2[LE_BE] = 1. When SENS_CONFIG5[Y_DIS] = 1, this register is skipped over by the auto-increment mechanism. |  |
| BUF_Z_LSB <sup>[1][3][4]</sup> | R            | 10h      | 11h         | 0Ch/0Eh/10h  | _                                       | Head/Tail sample of output buffer Z-axis LSB - buf_z_out[7:0] when SENS_CONFIG2[LE_BE] = 0 and buf_z_out[11:4] when SENS_CONFIG2[LE_BE] = 1. When SENS_CONFIG5[Z_DIS] = 1, this register is skipped over by the auto-increment mechanism. |  |
| BUF_Z_MSB <sup>[1][3][4]</sup> | R            | 11h      | 0Ch/0Eh/10h |              | _                                       | Head/Tail sample of output buffer Z-axis MSB - buf_Z_out[11:8] when SENS_CONFIG2[LE_BE] = 0 and buf_z_out[3:0] when SENS_CONFIG2[LE_BE] = 1. When SENS_CONFIG5[Z_DIS] = 1, this register is skipped over by the auto-increment mechanism. |  |
| Device identification          |              | T        | T           |              |                                         |                                                                                                                                                                                                                                           |  |
| PROD_REV                       | R            | 12h      | 1:          | 3h           | 14h                                     | Product revision number in BCD format [maj.min] with range 1.0 to 9.9                                                                                                                                                                     |  |
| WHO_AM_I <sup>[1]</sup>        | R            | 13h      | 1           | 4h           | 83h                                     | 8-bit NXP unique sensor product ID.                                                                                                                                                                                                       |  |
| System status register         |              |          |             |              |                                         |                                                                                                                                                                                                                                           |  |
| SYS_MODE [1] [2]               | R            | 14h      | 1:          | 5h           | 00h/[01h]                               | Current system operating mode, buffer gate error flag, and buffer gate error sample count                                                                                                                                                 |  |
| Device configuration and c     | ontrol regis | ters     |             |              |                                         |                                                                                                                                                                                                                                           |  |
| SENS_CONFIG1 [1] [5]           | R/W          | 15h      | 1           | 6h           | 00h/[03h]                               | Full-scale range selection, self-test axis, and polarity selection, soft reset, Active mode enable.                                                                                                                                       |  |
| SENS_CONFIG2 [1] [5]           | R/W          | 16h      | 1           | 7h           | 00h                                     | WAKE and SLEEP power mode selections, little/big endian output mode, auto-increment control, fast read enable.                                                                                                                            |  |
| SENS_CONFIG3 [1] [5]           | R/W          | 17h      | 18h         |              | 00h/[C0h]                               | WAKE and SLEEP mode ODR and decimation selections                                                                                                                                                                                         |  |
| SENS_CONFIG4 [1] [5]           | R/W          | 18h      | 19h         |              | 01h                                     | Auto-WAKE/SLEEP interrupt source enable bits, interrupt output pin logic polarity, and driver type, external trigger input function enable                                                                                                |  |
| SENS_CONFIG5 [1] [5]           | R/W          | 19h      | 1,          | Ah           | 00h/[00h]                               | Auto-increment mechanism disable bits for X/Y/Z axis data; Hibernate mode enable                                                                                                                                                          |  |
| WAKE_IDLE_LSB [1] [5]          | R/W          | 1Ah      | 11          | Bh           | 00h                                     | LSB of 12-bit user programmable WAKE mode idle time - wake_idle[7:0]                                                                                                                                                                      |  |
| WAKE_IDLE_MSB [1] [5]          | R/W          | 1Bh      | 10          | Ch           | 00h                                     | MSB of 12-bit user programmable WAKE mode idle time - wake_idle[11:8]                                                                                                                                                                     |  |

Table 20. Register address map...continued

| Name                             | Type       | Register      | Auto-increment Address |            | Default<br>Values | Comment                                                                                                                                                                                                                                                                    |  |
|----------------------------------|------------|---------------|------------------------|------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                  |            | Address       | F_READ = 0             | F_READ = 0 |                   |                                                                                                                                                                                                                                                                            |  |
| SLEEP_IDLE_LSB [1] [5]           | R/W        | 1Ch           | 1Dh                    |            | 00h               | LSB of 12-bit user programmable SLEEP mode idle time - sleep_idle[7:0]                                                                                                                                                                                                     |  |
| SLEEP_IDLE_MSB [1] [5]           | R/W        | 1Dh           | 11                     | Eh         | 00h               | MSB of 12-bit user programmable SLEEP mode idle time - sleep_idle[11:8]                                                                                                                                                                                                    |  |
| ASLP_COUNT_LSB [1] [5]           | R/W        | 1Eh           | 1                      | Fh         | 00h               | LSB of inactivity time-out count value used for transitioning into Auto-SLEEP mode: aslp_count[7:0]. In order to enable the Auto-WAKE/SLEEP feature, the value written to this register must be ≥ 1.                                                                       |  |
| ASLP_COUNT_MSB [1] [5]           | R/W        | 1Fh           | 2                      | 0h         | 00h               | MSB of inactivity time-out count value used for transitioning into Auto-SLEEP mode: aslp_count[11:8]                                                                                                                                                                       |  |
| INT_EN [1] [5]                   | R/W        | 20h           | 2                      | 1h         | 00h/[20h]         | Interrupt output enable register                                                                                                                                                                                                                                           |  |
| INT_PIN_SEL [1] [5]              | R/W        | 21h           | 2                      | 2h         | 00h               | Interrupt output routing register (INT1, INT2 pins)                                                                                                                                                                                                                        |  |
| Zero-g offset compensation       | registers  |               |                        |            |                   |                                                                                                                                                                                                                                                                            |  |
| OFF_X [1] [5]                    | R/W        | 22h           | 2                      | 3h         | 00h               | X-Axis acceleration zero- <i>g</i> offset: x_off[7:0]                                                                                                                                                                                                                      |  |
| OFF_Y [1] [5]                    | R/W        | 23h           | 2                      | 4h         | 00h               | Y-Axis acceleration zero-g offset: y_off[7:0]                                                                                                                                                                                                                              |  |
| OFF_Z [1] [5]                    | R/W        | 24h           | 2                      | 5h         | 00h               | Z-Axis acceleration zero-g offset: z_off[7:0]                                                                                                                                                                                                                              |  |
| Output Buffer Configuration      |            |               |                        |            |                   |                                                                                                                                                                                                                                                                            |  |
| RESERVED_REG2                    | _          | 25h           | 2                      | 6h         | 00h               | Factory reserved register address 2                                                                                                                                                                                                                                        |  |
| BUF_CONFIG1 [1] [5]              | R/W        | 26h           | 27h                    |            | 00h               | Output data buffer operating mode, trigger source selection, and data collection mode.                                                                                                                                                                                     |  |
| BUF_CONFIG2 [1] [5]              | R/W        | 27h           | 28h                    |            | 00h               | Output data buffer flush, gate control, and watermark level (buf_wmrk[5:0]).  *The BUF_FLUSH bit may be set at any time in either STANDBY, ACTIVE, OR EXT_TRIG modes.                                                                                                      |  |
| Orientation detection function   | n configu  | ration and st | atus                   |            |                   | <del>-</del>                                                                                                                                                                                                                                                               |  |
| ORIENT_STATUS [1] [2]            | R          | 28h           | 2                      | 9h         | 00h               | Orientation event status                                                                                                                                                                                                                                                   |  |
| ORIENT_CONFIG [1] [5]            | R/W        | 29h           | 2.                     | Ah         | 80h               | Orientation detection function configuration.                                                                                                                                                                                                                              |  |
| ORIENT_DBCOUNT [1] [5]           | R/W        | 2Ah           | 21                     | Bh         | 00h               | Orientation detection change debounce counter                                                                                                                                                                                                                              |  |
| ORIENT_BF_ZCOMP [1] [5]          | R/W        | 2Bh           | 20                     | Ch         | 44h               | Back/Front orientation state change threshold angle.                                                                                                                                                                                                                       |  |
| ORIENT_THS_REG [1] [5]           | R/W        | 2Ch           | 21                     | Dh         | 84h               | Orientation detection state change threshold angle (Portrait/Landscape) and hysteresis settings.                                                                                                                                                                           |  |
| Sensor data change detection     | n function | configuration | on and status          |            | 1                 | ı                                                                                                                                                                                                                                                                          |  |
| SDCD_INT_SRC1 [1] [2]            | R          | 2Dh           | 2                      | Eh         | 00h               | Sensor Data Change Detection function outside-of-thresholds event flags source register.                                                                                                                                                                                   |  |
| SDCD_INT_SRC2 [1] [2]            | R          | 2Eh           | 2                      | Fh         | 00h               | Sensor Data Change Detection function within thresholds event flags source register.                                                                                                                                                                                       |  |
| SDCD_CONFIG1 [1] [5]             | R/W        | 2Fh           | 30h                    |            | 00h/[38h]         | Sensor Data Change Detection function configuration register 1 – Enables event latch and individual axis bits for OT and WT logic function functions.                                                                                                                      |  |
| SDCD_CONFIG2 [1] [5]             | R/W        | 30h           | 31h                    |            | 00h/[D8h]         | Sensor Data Change Detection function configuration register 2 – SDCD function enable, reference values initialization, and update behavior, relative/absolute operating mode selection, debounce counter behavior.  Note: Only the REF_UPD bit may be set in Active mode. |  |
| SDCD_OT_DBCNT [1] [5]            | R/W        | 31h           | 3:                     | 2h         | 00h/[00h]         | Sensor Data Change Detection outside of thresholds condition debounce count value sdcd_ot_dbcnt[7:0]                                                                                                                                                                       |  |
| SDCD_WT_DBCNT <sup>[1] [5]</sup> | R/W        | 32h           | 3                      | 3h         | 00h/[00h]         | Sensor Data Change Detection within thresholds condition debounce count value – sdcd_wt_dbcnt[7:0]                                                                                                                                                                         |  |

Table 20. Register address map...continued

| Name                                | Type | Register | Auto-increment Address |            | Default                                 | Comment                                                                  |           |                                                                           |
|-------------------------------------|------|----------|------------------------|------------|-----------------------------------------|--------------------------------------------------------------------------|-----------|---------------------------------------------------------------------------|
|                                     |      | Address  | F_READ = 0             | F_READ = 1 | Values BT_MODE = GND/[V <sub>DD</sub> ] |                                                                          |           |                                                                           |
| SDCD_LTHS_LSB [1] [5]               | R/W  | 33h      | 34                     | 34h        |                                         | Sensor Data Change Detection lower threshold value LSB - sdcd_lths[7:0]  |           |                                                                           |
| SDCD_LTHS_MSB [1] [5]               | R/W  | 34h      | 35h                    |            | 35h                                     |                                                                          | 00h/[0Fh] | Sensor Data Change Detection lower threshold value MSB - sdcd_lths[11:8]. |
| SDCD_UTHS_LSB [1] [5]               | R/W  | 35h      | 36                     | 36h        |                                         | Sensor Data Change Detection upper threshold value LSB - sdcd_uths[7:0]  |           |                                                                           |
| SDCD_UTHS_MSB [1] [5]               | R/W  | 36h      | 37                     | 37h        |                                         | Sensor Data Change Detection upper threshold value MSB - sdcd_uths[11:8] |           |                                                                           |
| SELF_TEST_CONFIG1 [1] [5]           | R/W  | 37h      | 38                     | Bh         | 00h                                     | Self-Test Idle phase duration:                                           |           |                                                                           |
| SELF_TEST_CONFIG2 [1] [5]           | R/W  | 38h      | 39h                    |            | 00h                                     | Self-Test measurement phase decimation factor                            |           |                                                                           |
| reserved register 12                | R/W  | 39h      | 3,4                    | 3Ah        |                                         | Factory reserved register; do not modify                                 |           |                                                                           |
| reserved register 13 <sup>[1]</sup> | R    | 3Ah      | 00h                    |            | _                                       | Factory reserved register                                                |           |                                                                           |

<sup>[1]</sup> Register contents are preserved when a transition from ACTIVE to STANDBY mode occurs. All register contents are lost when a transition from Hibernate mode or a POR/BOR event occurs.

### 15.2 Data and status read registers

### 15.2.1 INT\_STATUS register (address 00h)

Table 21. INT STATUS register (address 00h) bit allocation

| Bit    | 7        | 6       | 5       | 4               | 3               | 2              | 1        | 0        |
|--------|----------|---------|---------|-----------------|-----------------|----------------|----------|----------|
| Name   | SRC_DRDY | SRC_OVF | SRC_BUF | SRC_<br>SDCD_OT | SRC_<br>SDCD_WT | SRC_<br>ORIENT | SRC_ASLP | SRC_BOOT |
| Reset  | 0        | 0       | 0       | 0               | 0               | 0              | 0        | 1        |
| Access | R        | R       | R       | R               | R               | R              | R        | R        |

<sup>[2]</sup> Register contents are reset when a transition from STANDBY to ACTIVE or EXT\_TRIG mode occurs.

The byte order and L/R justification of these registers is user programmable between little-endian right justified and big-endian (left justified) modes. The default mode is little-endian, right justified. The byte order and justification is controlled by **SENS\_CONFIG3**[LE\_BE].

<sup>[4]</sup> The output data buffer contents become obsolete whenever a transition from STANDBY-to-ACTIVE or STANDBY-to-EXT\_TRIG modes occurs.

Register contents can only be modified while the device is in STANDBY mode; the only exceptions are the SENS\_CONFIG1[ACTIVE], SENS\_CONFIG1[RST] and BUF\_CONFIG1[BUF\_FLUSH] bits that may be set at any time in STANDBY, ACTIVE, or EXT\_TRIG modes. The ACTIVE bit state cannot be modified while in EXT\_TRIG operating mode.

Table 22. INT\_STATUS register (address 00h) bit description

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>SRC_DRDY    | <ul> <li>Output data-ready event flag</li> <li>0: A new set of XYZ acceleration and temperature data is not available.</li> <li>1: A new set of XYZ acceleration and temperature data is available.</li> <li>Notes:</li> <li>• The SRC_DRDY flag is cleared whenever one or more of the VECM, and OUT_X/Y/Z registers are read.</li> <li>• Whenever BUF_CONFIG1[BUF_MODE1:0]] &gt; 00b (buffer enabled), SRC_DRDY is held at logic '0'.</li> <li>• When BT_MODE=GND, SRC_DRDY bit and the signaled interrupt are cleared whenever one or more of the VECM, and OUT_X/Y/Z registers are read.</li> <li>• When BT_MODE=V<sub>DD</sub>, SRC_DRDY bit is cleared whenever one or more of the VECM, and OUT_X/Y/Z registers are read. However the data ready interrupt is signaled for T<sub>PULSE-MOT</sub> seconds (5 ms typ) and it clears itself automatically. The current data ready interrupt pulse is terminated when the device transitions into STANDBY mode before its completion and therefore may not span for entire T<sub>PULSE-MOT</sub> seconds.</li> </ul> |
| 6<br>SRC_OVF     | Output data overflow event flag 0: No overflow condition detected. 1: A new set of XYZ acceleration and temperature output data latches into OUT_X/Y/Z and TEMP_OUT registers before the previous set is completely read by the host.  Notes:  SRC_OVF is not set if at least one of the OUT_X/Y/Z registers was read before the new data set arrives.  Whenever the INT_STATUS register is read, SRC_OVF is cleared.  Whenever BUF_CONFIG1[BUF_MODE[1:0]] > 00b (buffer enabled), SRC_OVF is held at logic '0'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 5<br>SRC_BUF     | Output data buffer status event flag  0: No output buffer event status flags are active  1: One or more output buffer status event flags are active (BUF_WMRK   BUF_OVF   BUF_GATE_ERR); reading the BUF_STATUS register provides more information on the BUF_WMRK or BUF_OVF event flags that are currently active. Reading the SYS_MODE register provides information on the BUF_GATE_ERR flag status.  Notes:  • The SRC_BUF flag is only active when BUF_CONFIG1[BUF_MODE[1:0]] > 00b.  • The BUF_WMRK event flag will not participate in SRC_BUF interrupt generation in triggered mode (the BUF_WMRK flag is asserted after the buffer is triggered, but it will not signal an external interrupt as with the other buffer operating modes). If it is required to know when the trigger event has taken place, the host may use the SDCD or ORIENT interrupts, as appropriate, to indicate when the buffer is triggered. When the buffer is full, the SRC_BUF flag is set and an external interrupt is signaled on the INT1 or INT2 pins, if configured.          |
| 4<br>SRC_SDCD_OT | SDCD outside of thresholds condition event flag (copy of SDCD_INT_SRC1[OT_EA] flag)  0: SDCD outside of thresholds event is not detected (SDCD_INT_SRC1[OT_EA] = 0).  1: SDCD outside of thresholds event is detected (SDCD_INT_SRC1[OT_EA] = 1). The SRC_SDCD_OT event flag is cleared by reading the SDCD_INT_SRC1 register when SDCD_CONFIG1[OT_ELE] = 1, otherwise this flag is cleared automatically by the function when the event condition becomes false.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3<br>SRC_SDCD_WT | SDCD within thresholds condition event flag (copy of SDCD_INT_SRC2[WT_EA] flag)  0: No SDCD within thresholds event has been detected (SDCD_INT_SRC2[WT_EA] = 0).  1: An SDCD within thresholds event has been detected (SDCD_INT_SRC2[WT_EA] = 1). The SRC_SDCD_WT event flag is cleared by reading the SDCD_INT_SRC2 register when SDCD_CONFIG1[WT_ELE] = 1, otherwise the function clears this flag automatically when the event condition becomes false.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

Table 22. INT\_STATUS register (address 00h) bit description...continued

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2<br>SRC_ORIENT | Orientation change event flag The SRC_ORIENT flag is asserted whenever the ORIENT_STATUS[NEW_ORIENT] bit is asserted and a change in orientation has been detected. Reading the ORIENT_STATUS register clears this event flag. 0: An orientation change event has not occurred 1: An orientation change event has occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1<br>SRC_ASLP   | Auto-WAKE/SLEEP event status flag  0: A WAKE-to-SLEEP or SLEEP-to-WAKE system operating mode transition has not occurred.  1: A WAKE-to-SLEEP or a SLEEP-to-WAKE system operating mode transition has occurred.  Reading the SYS_MODE register allows the host processor to determine if the transition direction was from WAKE-to-SLEEP or SLEEP-to-WAKE:  • A WAKE-to-SLEEP transition is observed when no configured interrupt event occurs for a time period (number of ODR periods) that equals the user-specified inactivity time limit programmed in the ASLP_COUNT_LSB and ASLP_COUNT_MSB registers. On expiry of configured time period with no user specified activity, the system transitions to the user-specified SLEEP power mode (SENS_CONFIG2[sleep_pm]) and ODR (or decimation and idle time settings when Flexible Performance mode is selected).  • A SLEEP-to-WAKE transition occurs when a configured interrupt event flag becomes active. The interrupt event flag transitions to the user-specified WAKE power mode (SENS_CONFIG2[wake_pm]) and ODR (or decimation and idle time settings when Flexible Performance mode is selected).  Notes:  • The SRC_ASLP event flag is cleared by reading the SYS_MODE register. |
|                 | • The SRC_ASLP event flag is enabled when <b>ASLP_COUNT</b> ≥ 1 which also enables the Auto-WAKE/SLEEP function. The SRC_ASLP flag is only operational when <b>INT_EN[</b> ALSP_EN <b>]</b> = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0<br>SRC_BOOT   | O: Boot sequence in process/not complete.  1: Boot sequence completed; FXLS8971CF is now ready to accept commands over the I <sup>2</sup> C or SPI interfaces.  This flag is automatically set to 1 upon completion of the boot process and remains set until a POR, soft reset, or exit from Hibernate mode event occurs.  When BT_MODE = GND: Boot interrupt is generated in INT1/MOT_DET pin by default. This event flag may be configured to generate an interrupt on either the INT1 or INT2 pin depending on the mapping selected in INT_PIN_SEL. When this event flag is enabled as an interrupt output, either the INT1 or INT2 (depending on the setting made in INT_PIN_SEL register) pin is pulsed once with a width of TBOOT1 µs when the boot process completes.  When BT_MODE = VDD: The INT2/BOOT_OUT pin is pulsed once with a duration of TBOOT2 ms when the boot process completes. The pulse is active low (open-drain output); an external pull-up resistor is required.  Notes:  • When BT_MODE = GND, after a POR or exiting Hibernate mode, the polarity of the BOOT pulse                                                                                                                                             |
|                 | <ul> <li>When BT_MODE = GND, after a POR or exiting Riberhate mode, the polarity of the BOOT pulse is default Active High because any I<sup>2</sup>C write to the SENS_CONFIG4[INT_POL] fails until the boot process has completed.</li> <li>After a Soft Reset, the INT_POL, INT_PP_OD, and INT_PIN_SEL register settings are not reset and maintain their previous values. As a result, an I<sup>2</sup>C or SPI write to the SENS_CONFIG4[(INT_PP_OD and INT_POL bits)] and INT_PIN_SEL[BOOT_INT2] bits before the Soft Reset determines the logic polarity, output driver type, and INT1/2 pin mapping of the subsequent Boot pulse.</li> <li>It is not possible to observe the state of the SRC_BOOT bit at '0' over the I<sup>2</sup>C or SPI interfaces as read and write operations fails until the boot process has completed.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                            |

### 15.2.2 TEMP\_OUT register (address 01h)

Table 23. TEMP OUT register (address 01h) bit allocation

| Bit    | 7 | 6             | 5 | 4 | 3 | 2 | 1 | 0 |  |
|--------|---|---------------|---|---|---|---|---|---|--|
| Name   |   | TEMP_OUT[7:0] |   |   |   |   |   |   |  |
| Reset  | _ | _             | _ | _ | _ | _ | _ | _ |  |
| Access | R | R             | R | R | R | R | R | R |  |

The **TEMP\_OUT** register contains the 8-bit, 2's complement temperature value. When this register contains the value 00h, the measured temperature is 25 °C (typ). This register is updated on every ODR cycle.

#### 15.2.3 VECM\_LSB register (address 02h)

This register contains the LSB of the 12-bit, unsigned vector magnitude result (acceleration vector modulus); The result is only calculated when **SENS\_CONFIG5[VECM\_EN] = 1**.

Note: Whenever the VECM\_LSB or VECM\_MSB registers are read the SRC\_DRDY event flag is also cleared.

The byte order of the vector magnitude output data is programmable via SENS\_CONFIG2[LE\_BE] and defaults to little-endian mode.

Table 24. VECM\_LSB register (address 02h) bit allocation

| Bit    | 7 | 6         | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|--------|---|-----------|---|---|---|---|---|---|--|--|
| Name   |   | VECM[7:0] |   |   |   |   |   |   |  |  |
| Reset  | 0 | 0         | 0 | 0 | 0 | 0 | 0 | 0 |  |  |
| Access | R | R         | R | R | R | R | R | R |  |  |

Table 25. VECM\_LSB register (address 02h) bit description

| Field     | Description                                                   |
|-----------|---------------------------------------------------------------|
| 7 to 0    | LSB of the 12-bit unsigned acceleration vector modulus result |
| VECM[7:0] |                                                               |

#### 15.2.4 VECM\_MSB register (address 03h)

This register contains the MSB of the 12-bit, unsigned vector magnitude result (acceleration vector modulus); The result is only calculated when **SENS\_CONFIG5[VECM\_EN]** = 1.

**Note:** Whenever the VECM\_LSB or VECM\_MSB registers are read the SRC\_DRDY event flag is also cleared.

The byte order of the vector magnitude output data is programmable via **SENS\_CONFIG2[**LE\_BE**]** and defaults to little-endian mode.

Table 26. VECM\_MSB register (address 03h) bit allocation

| Bit    | 7 | 6 | 5 | 4 | 3          | 2 | 1 | 0 |
|--------|---|---|---|---|------------|---|---|---|
| Name   | _ | _ | _ | _ | VECM[11:8] |   |   |   |
| Reset  | 0 | 0 | 0 | 0 | 0          | 0 | 0 | 0 |
| Access | R | R | R | R | R          | R | R | R |

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

© 2024 NXP B.V. All rights reserved.

Table 27. VECM\_MSB register (address 03h) bit description

| Field                | Description                                                   |
|----------------------|---------------------------------------------------------------|
| 3 to 0<br>VECM[11:8] | MSB of the 12-bit unsigned acceleration vector modulus result |

# 15.2.5 OUT\_X\_LSB, OUT\_X\_MSB, OUT\_Y\_LSB, OUT\_Y\_MSB, OUT\_Z\_LSB, OUT\_Z\_MSB registers (addresses 04h to 09h)

These registers contain the 12-bit X-axis, Y-axis, and Z-axis output acceleration data in 2's complement format.

The output data is latched into the **OUT X/Y/Z** registers along with the assertion of the SRC DRDY event flag.

When **SENS\_CONFIG2**[F\_READ] = 1, the auto-increment mechanism skips the MSB registers in a burst read transaction. This operation shortens the output data size from 6 bytes to 3 bytes per XYZ sample read.

The byte order of the output data is programmable via **SENS\_CONFIG2**[LE\_BE] and defaults to little-endian mode.

When **SENS\_CONFIG2**[F\_READ] = 1, the MSB of each axis's data is stored at the LSB address, regardless of the setting made in **SENS\_CONFIG2**[LE\_BE].

In little-endian mode, the output data registers are arranged with the LSB of each axis's data stored at the lower address. The upper nibble (MSB) is stored at the next address, in right justified format. In little-endian mode, the MSB is sign extended to form a 16-bit 2's complement value.

In big-endian mode (**SENS\_CONFIG2**[LE\_BE] = 1), the output data registers are arranged with the MSB of each axis's data stored at the lower register address. The lower nibble is stored at the next address, and is left justified. The big-endian option allows a big-endian processor to directly read the output data into an array without the need to perform byte swaps. The host software must right shift the data by 4 bits (or divide by 16) in order to obtain the correct scaling of the output data. The sign extension of the data must be done explicitly, depending on the C compiler used.

#### Notes:

- There is a ~40 µs delay between the ADC acquisitions of the accelerometer X,Y,Z, and temperature data. The temperature data is acquired first, followed by the X, Y, and Z axes acceleration data. All data is latched into the output registers at the same time instant, coincident with the SRC\_DRDY event flag being asserted. Whenever any of the **OUT X/Y/Z** registers is read the SRC\_DRDY event flag is cleared.
- SX means sign extension, which is the logic level of the most significant bit of the 12-bit OUT\_X/Y/Z register data, also known as OUT X/Y/Z[11].

Table 28. OUT\_X\_LSB and OUT\_X\_MSB register (addresses 04h to 05h) with SEN\_CONFIG2[LE\_BE] = 0 bit allocation

| anoodtion | 1  |            |    | I  | I |       |         |   |  |  |  |  |
|-----------|----|------------|----|----|---|-------|---------|---|--|--|--|--|
| Bit       | 7  | 6          | 5  | 4  | 3 | 2     | 1       | 0 |  |  |  |  |
| Name      |    | OUT_X[7:0] |    |    |   |       |         |   |  |  |  |  |
| Reset     | _  | _          | _  | _  | _ | _     | _       | _ |  |  |  |  |
| Access    | R  | R          | R  | R  | R | R     | R       | R |  |  |  |  |
|           |    |            |    |    |   |       |         |   |  |  |  |  |
| Bit       | 7  | 6          | 5  | 4  | 3 | 2     | 1       | 0 |  |  |  |  |
| Name      | SX | SX         | SX | SX |   | OUT_X | X[11:8] |   |  |  |  |  |
| Reset     | _  | _          | _  | _  | _ | _     | _       | _ |  |  |  |  |
| Access    | R  | R          | R  | R  | R | R     | R       | R |  |  |  |  |

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

Table 29. OUT\_Y\_LSB and OUT\_Y\_MSB register (addresses 06h to 07h) with SEN\_CONFIG2[LE\_BE] = 0 bit allocation

| allocation |    |    |    |      |        |       |         |   |
|------------|----|----|----|------|--------|-------|---------|---|
| Bit        | 7  | 6  | 5  | 4    | 3      | 2     | 1       | 0 |
| Name       |    |    |    | OUT_ | Y[7:0] |       |         |   |
| Reset      | _  | _  | _  | _    | _      | _     | _       | _ |
| Access     | R  | R  | R  | R    | R      | R     | R       | R |
|            |    |    |    |      |        |       |         |   |
| Bit        | 7  | 6  | 5  | 4    | 3      | 2     | 1       | 0 |
| Name       | SX | SX | SX | SX   |        | OUT_\ | Y[11:8] |   |
| Reset      | _  | _  | _  | _    | _      | _     | _       | _ |
| Access     | R  | R  | R  | R    | R      | R     | R       | R |

Table 30. OUT\_Z\_LSB and OUT\_Z\_MSB register (addresses 08h to 09h) with SEN\_CONFIG2[LE\_BE] = 0 bit allocation

| ocation |            |    |        |        |        |        |         |   |  |  |
|---------|------------|----|--------|--------|--------|--------|---------|---|--|--|
| it      | 7          | 6  | 5      | 4      | 3      | 2      | 1       | 0 |  |  |
| ame     | OUT_Z[7:0] |    |        |        |        |        |         |   |  |  |
| eset    | _          | _  | _      | _      | _      | _      | _       | _ |  |  |
| ccess   | R          | R  | R      | R      | R      | R      | R       | R |  |  |
| Ì       |            |    |        |        |        |        |         |   |  |  |
| it      | 7          | 6  | 5      | 4      | 3      | 2      | 1       | 0 |  |  |
| ame     | SX         | SX | SX     | SX     |        | OUT_2  | Z[11:8] |   |  |  |
| eset    | _          | _  | _      | _      | _      | _      | _       | _ |  |  |
| ccess   | R          | R  | R      | R      | R      | R      | R       | R |  |  |
|         | —<br>R     | R  | —<br>R | —<br>R | —<br>R | —<br>R | —<br>R  |   |  |  |

Table 31. OUT\_X\_LSB and OUT\_X\_MSB register (addresses 04h to 05h) with SEN\_CONFIG2[LE\_BE] = 1 bit allocation

|        |   |             | 1      |   |   |   |   |   |  |  |  |
|--------|---|-------------|--------|---|---|---|---|---|--|--|--|
| Bit    | 7 | 6           | 5      | 4 | 3 | 2 | 1 | 0 |  |  |  |
| Name   |   | OUT_X[11:4] |        |   |   |   |   |   |  |  |  |
| Reset  | _ | _           | _      | _ | _ | _ | _ | _ |  |  |  |
| Access | R | R           | R      | R | R | R | R | R |  |  |  |
|        |   |             |        |   |   |   |   |   |  |  |  |
| Bit    | 7 | 6           | 5      | 4 | 3 | 2 | 1 | 0 |  |  |  |
| Name   |   | OUT_        | X[3:0] |   | 0 | 0 | 0 | 0 |  |  |  |
| Reset  | _ | _           | _      | _ | _ | _ | _ | _ |  |  |  |
| Access | R | R           | R      | R | R | R | R | R |  |  |  |

Table 32. OUT\_Y\_LSB and OUT\_Y\_MSB register (addresses 06h to 07h) with SEN\_CONFIG2[LE\_BE] = 1 bit allocation

| anocation |   |      |        |      |         |   |   |   |
|-----------|---|------|--------|------|---------|---|---|---|
| Bit       | 7 | 6    | 5      | 4    | 3       | 2 | 1 | 0 |
| Name      |   |      |        | OUT_ | Y[11:4] |   |   |   |
| Reset     | _ | _    | _      | _    | _       | _ | _ | _ |
| Access    | R | R    | R      | R    | R       | R | R | R |
|           |   |      |        |      |         |   |   |   |
| Bit       | 7 | 6    | 5      | 4    | 3       | 2 | 1 | 0 |
| Name      |   | OUT_ | Y[3:0] |      | 0       | 0 | 0 | 0 |
| Reset     | _ | _    | _      | _    | _       | _ | _ | _ |
| Access    | R | R    | R      | R    | R       | R | R | R |

Table 33. OUT\_Z\_LSB and OUT\_Z\_MSB register (addresses 08h to 09h) with SEN\_CONFIG2[LE\_BE] = 1 bit allocation

| anocation |   |      |        |       |         |   |   |   |
|-----------|---|------|--------|-------|---------|---|---|---|
| Bit       | 7 | 6    | 5      | 4     | 3       | 2 | 1 | 0 |
| Name      |   |      |        | OUT_2 | Z[11:4] |   |   |   |
| Reset     | _ | _    | _      | _     | _       | _ | _ | _ |
| Access    | R | R    | R      | R     | R       | R | R | R |
|           |   |      |        |       |         |   |   |   |
| Bit       | 7 | 6    | 5      | 4     | 3       | 2 | 1 | 0 |
| Name      |   | OUT_ | Z[3:0] |       | 0       | 0 | 0 | 0 |
| Reset     | _ | _    | _      | _     | _       | _ | _ | _ |
| Access    | R | R    | R      | R     | R       | R | R | R |
|           |   |      |        |       |         |   |   |   |

## 15.2.6 BUF\_STATUS register (address 0Bh)

The content stored at this register address depends on whether the output data buffer is enabled or not. When **BUF\_CONFIG1**[BUF\_MODE[1:0]] = 00b, the output data buffer is disabled and this register always contains the value 00h.

When **BUF\_CONFIG1**[BUF\_MODE[1:0]] > 00b, the **BUF\_STATUS** register content as shown in <u>Table 34</u> and Table 35.

Table 34. BUF\_STATUS register (address 0Bh) bit allocation

| Bit    | 7            | 6       | 5 | 4            | 3 | 2 | 1 | 0 |  |
|--------|--------------|---------|---|--------------|---|---|---|---|--|
| Name   | BUF_<br>WMRK | BUF_OVF |   | BUF_CNT[5:0] |   |   |   |   |  |
| Reset  | 0            | 0       | 0 | 0            | 0 | 0 | 0 | 0 |  |
| Access | R            | R       | R | R            | R | R | R | R |  |

Table 35. BUF\_STATUS register (address 0Bh) bit description

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7            | Buffer Watermark Event Flag:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| BUF_WMRK     | 0: The buffer watermark level programmed in BUF_CONFIG2[BUF_WMRK[5:0]] has not been equaled or exceeded                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|              | 1: The buffer watermark level programmed in BUF_CONFIG2[BUF_WMRK[5:0]] has been equaled or exceeded.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|              | This event flag may be cleared in one of the following ways:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|              | 1. The host must read out enough samples from the output buffer for <b>BUF_STATUS</b> [BUF_CNT[5:0]] to go below the value set in <b>BUF_CONFIG2</b> [BUF_WMRK[5:0]].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|              | 2. The host must flush the buffer by setting <b>BUF_CONFIG2</b> [BUF_FLUSH] = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|              | 3. The host must set <b>BUF_CONFIG1</b> [BUF_MODE[1:0]] = 00b to disable the buffer, which also clears its contents.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|              | The watermark interrupt may be used to enable an efficient DMA-based transfer of the buffer contents to the host processor. For example, if the watermark level is set at 16 samples and the interrupt is enabled and routed to one of the INT1 or INT2 pins, the event may be used to trigger a single burst read operation of 1 (BUF_STATUS) + (16 samples * 2 bytes/sample * 3 (axes)) = 97 bytes to completely empty the buffer and clear the buffer status flags (when SENS_CONFIG2[F_READ] = 0), or 49 bytes when SENS_CONFIG2[F_READ] = 1.  Note: Using a DMA operation to handle the burst read operation can allow the processor to sleep or perform other tasks while the required number of samples is collected as a background activity. |
| 6            | Buffer Overflow Event flag:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| BUF_OVF      | 0: Buffer overflow event has not occurred. The number of samples stored in the buffer is less than or equal to 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|              | 1: Buffer overflow event has occurred                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|              | To clear this bit, the host must do one of the following:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|              | 1. At least one sample must be read in order to clear the BUF_OVF flag.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|              | 2. Flush the output buffer by setting <b>BUF_CONFIG2[</b> BUF_FLUSH <b>]</b> = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|              | 3. Disable the output buffer by setting <b>BUF_CONFIG1</b> [BUF_MODE[1:0]] = 00b, which resets <b>BUF_STATUS</b> [BUF_CNT[5:0]] to zero, but does not clear the buffer contents.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 5 to 0       | This field contains the count of the number of acceleration data triplets (samples) currently                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| BUF_CNT[5:0] | stored in the output data buffer (from 0-32). If the buffer is full (contains 32 samples), and an additional data triplet is received, the count remains at 32, and the BUF_OVF event flag is asserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

# 15.2.7 BUF\_X\_LSB, BUF\_X\_MSB, BUF\_Y\_LSB, BUF\_Y\_MSB, BUF\_Z\_LSB, BUF\_Z\_MSB (addresses 0Ch to 11h)

These registers contain either the buffer Head or Tail output acceleration sample data in 2's complement format. The tail (oldest) sample is stored when the FIFO read out mode is selected, and the head (newest) sample is stored when the LIFO read out mode is selected. **BUF CONFIG1**[BUF TYPE] controls the read out mode.

The byte order of the output data is programmable via **SENS\_CONFIG2**[LE\_BE], and defaults to little-endian mode.

In little-endian mode, the output data buffer registers are arranged with the LSB of each axes data stored at the lower address. The upper nibble (MSB) is stored at the next address, and is right justified. In little-endian mode, the buffer output data is also sign extended to avoid the need for the host software to do sign extension of the output data on a per sample (per axis) basis.

In big-endian mode (with **SENS\_CONFIG2[**LE\_BE**]** = 1), the output buffer data registers are arranged with the MSB of each axis data stored at the lower register address. The lower nibble(LSB) is stored at the next address,

FXLS8971C

and is left justified. The lower 4 bits of the LSB are always read as '0'. The host software must right shift the data by 4 bits (or divide the value by 16) in order to obtain the correct scaling of the acceleration data.

If **SENS\_CONFIG2**[F\_READ] = 1, the auto increment mechanism skips over the MSB registers. This operation shortens the output data size from 6 bytes to 3 bytes per XYZ sample. When **SENS\_CONFIG2**[F\_READ] = 1, the MSB of each axes data is stored at the LSB address, regardless of the setting made in **SENS\_CONFIG2**[LE\_BE]. The output data size may also be reduced using the X/Y/Z\_DIS bits located in the **SENS\_CONFIG5** register. These bits can be used to selectively disable each axis from being read out using the auto-increment mechanism. For example, setting X\_DIS causes the auto-increment mechanism to skip over the **BUF\_X** LSB and MSB registers, thereby shortening the number of bytes to be read from 6 to 4, or from 3 to 2 when F READ = 1.

**Note:** Reading the **BUF\_STATUS** register is not required in order to clear the BUF\_WMRK event flag - if the host has mapped more than the BUF\_WMRK event flag to the same interrupt pin, the **BUF\_STATUS** register should be used to confirm that a BUF\_WMRK event was the source of the interrupt before initiating the burst read operation.

Table 36. BUF\_X\_LSB and BUF\_X\_MSB registers (addresses 0Ch, 0Dh) with SENS\_CONFIG2[LE\_BE] = 0 bit allocation

| allocation |    |            |    |    |   |       |         |   |  |  |  |
|------------|----|------------|----|----|---|-------|---------|---|--|--|--|
| Bit        | 7  | 6          | 5  | 4  | 3 | 2     | 1       | 0 |  |  |  |
| Name       |    | BUF_X[7:0] |    |    |   |       |         |   |  |  |  |
| Reset      | _  | _          | _  | _  | _ | _     | _       | _ |  |  |  |
| Access     | R  | R          | R  | R  | R | R     | R       | R |  |  |  |
|            |    |            |    |    |   |       |         |   |  |  |  |
| Bit        | 7  | 6          | 5  | 4  | 3 | 2     | 1       | 0 |  |  |  |
| Name       | SX | SX         | SX | SX |   | BUF_X | K[11:8] |   |  |  |  |
| Reset      | _  | _          | _  | _  | _ | _     | _       | _ |  |  |  |
| Access     | R  | R          | R  | R  | R | R     | R       | R |  |  |  |

Table 37. BUF\_Y\_LSB and BUF\_Y\_MSB registers (addresses 0Eh, 0Fh) with SENS\_CONFIG2[LE\_BE] = 0 bit allocation

| Bit    | 7  | 6          | 5  | 4  | 3 | 2     | 1       | 0 |  |  |  |  |
|--------|----|------------|----|----|---|-------|---------|---|--|--|--|--|
| Name   |    | BUF_Y[7:0] |    |    |   |       |         |   |  |  |  |  |
| Reset  | _  | _          | _  | _  | _ | _     | _       | _ |  |  |  |  |
| Access | R  | R          | R  | R  | R | R     | R       | R |  |  |  |  |
|        |    |            |    |    |   |       |         |   |  |  |  |  |
| Bit    | 7  | 6          | 5  | 4  | 3 | 2     | 1       | 0 |  |  |  |  |
| Name   | SX | SX         | SX | SX |   | BUF_\ | Y[11:8] |   |  |  |  |  |
| Reset  | _  | _          | _  | _  | _ | _     | _       | _ |  |  |  |  |
| Access | R  | R          | R  | R  | R | R     | R       | R |  |  |  |  |

Table 38. BUF\_Z\_LSB and BUF\_Z\_MSB registers (addresses 10h, 11h) with SENS\_CONFIG2[LE\_BE] = 0 bit allocation

| anocation |    |    |    |      |        |       |         |   |
|-----------|----|----|----|------|--------|-------|---------|---|
| Bit       | 7  | 6  | 5  | 4    | 3      | 2     | 1       | 0 |
| Name      |    |    |    | BUF_ | Z[7:0] |       |         |   |
| Reset     | _  | _  | _  | _    | _      | _     | _       | _ |
| Access    | R  | R  | R  | R    | R      | R     | R       | R |
|           |    |    |    |      |        |       |         |   |
| Bit       | 7  | 6  | 5  | 4    | 3      | 2     | 1       | 0 |
| Name      | SX | SX | SX | SX   |        | BUF_Z | Z[11:8] |   |
| Reset     | _  | _  | _  | _    | _      | _     | _       | _ |
| Access    | R  | R  | R  | R    | R      | R     | R       | R |

Table 39. BUF\_X\_LSB and BUF\_X\_MSB registers (addresses 0Ch, 0Dh) with SENS\_CONFIG2[LE\_BE] = 1 bit allocation

| 7           | 6    | 5            | 4                        | 3                                     | 2                                                | 1                                                     | 0                        |  |  |
|-------------|------|--------------|--------------------------|---------------------------------------|--------------------------------------------------|-------------------------------------------------------|--------------------------|--|--|
| BUF_X[11:4] |      |              |                          |                                       |                                                  |                                                       |                          |  |  |
| _           | _    | _            | _                        | _                                     | _                                                | _                                                     | _                        |  |  |
| R           | R    | R            | R                        | R                                     | R                                                | R                                                     | R                        |  |  |
|             |      |              |                          |                                       |                                                  |                                                       |                          |  |  |
| 7           | 6    | 5            | 4                        | 3                                     | 2                                                | 1                                                     | 0                        |  |  |
|             | BUF_ | X[3:0]       |                          | 0                                     | 0                                                | 0                                                     | 0                        |  |  |
| _           | _    | _            | _                        | _                                     | _                                                | _                                                     | _                        |  |  |
| R           | R    | R            | R                        | R                                     | R                                                | R                                                     | R                        |  |  |
|             | 7 —  | R R 7 6 BUF_ | R R R  7 6 5  BUF_X[3:0] | BUF_X  R R R R  R BUF_X[3:0]  — — — — | BUF_X[11:4]   R R R R R  7 6 5 4 3  BUF_X[3:0] 0 | BUF_X[11:4]  R R R R R R  7 6 5 4 3 2  BUF_X[3:0] 0 0 | BUF_X[11:4]  R R R R R R |  |  |

Table 40. BUF\_Y\_LSB and BUF\_Y\_MSB registers (addresses 0Eh, 0Fh) with SENS\_CONFIG2[LE\_BE] = 1 bit allocation

| Bit    | 7           | 6    | 5      | 4 | 3 | 2 | 1 | 0 |  |  |
|--------|-------------|------|--------|---|---|---|---|---|--|--|
| Name   | BUF_Y[11:4] |      |        |   |   |   |   |   |  |  |
| Reset  | _           | _    | _      | _ | _ | _ | _ | _ |  |  |
| Access | R           | R    | R      | R | R | R | R | R |  |  |
|        |             |      |        |   |   |   |   |   |  |  |
| Bit    | 7           | 6    | 5      | 4 | 3 | 2 | 1 | 0 |  |  |
| Name   |             | BUF_ | Y[3:0] |   | 0 | 0 | 0 | 0 |  |  |
| Reset  | _           | _    | _      | _ | _ | _ | _ | _ |  |  |
| Access | R           | R    | R      | R | R | R | R | R |  |  |

Table 41. BUF\_Z\_LSB and BUF\_Z\_MSB registers (addresses 10h, 11h) with SENS\_CONFIG2[LE\_BE] = 1 bit allocation

| anocation |   |             |        |   |   |   |   |   |  |  |  |
|-----------|---|-------------|--------|---|---|---|---|---|--|--|--|
| Bit       | 7 | 6           | 5      | 4 | 3 | 2 | 1 | 0 |  |  |  |
| Name      |   | BUF_Z[11:4] |        |   |   |   |   |   |  |  |  |
| Reset     | _ | _           | _      | _ | _ | _ | _ | _ |  |  |  |
| Access    | R | R           | R      | R | R | R | R | R |  |  |  |
|           |   |             |        |   |   |   |   |   |  |  |  |
| Bit       | 7 | 6           | 5      | 4 | 3 | 2 | 1 | 0 |  |  |  |
| Name      |   | BUF_        | Z[3:0] |   | 0 | 0 | 0 | 0 |  |  |  |
| Reset     | _ | _           | _      | _ | _ | _ | _ | _ |  |  |  |
| Access    | R | R           | R      | R | R | R | R | R |  |  |  |

## 15.2.8 PROD\_REV register (address 12h)

The register contains the product revision number. The revision number is stored in BCD format, as MAJ.MIN with a range from 1.0 to 9.9, with the initial silicon revision reporting revision 1.0 (10h).

Table 42. PROD\_REV register (address 12h) bit allocation

| Bit    | 7                 | 6 | 5 | 4 | 3                 | 2 | 1 | 0 |  |
|--------|-------------------|---|---|---|-------------------|---|---|---|--|
| Name   | PROD_REV_MAJ[3:0] |   |   |   | PROD_REV_MIN[3:0] |   |   |   |  |
| Reset  | 0                 | 0 | 0 | 1 | 0                 | 1 | 0 | 0 |  |
| Access | R                 | R | R | R | R                 | R | R | R |  |

Table 43. PROD\_REV register (address 12h) bit description

| Field                       | Description                                                                          |
|-----------------------------|--------------------------------------------------------------------------------------|
| 7 to 4<br>PROD_REV_MAJ[3:0] | Product revision info, major product revision value with range 1 to 9 in BCD format. |
| 3 to 0<br>PROD_REV_MIN[3:0] | Product revision info, minor product revision value with range 0 to 9 in BCD format. |

## 15.2.9 WHO\_AM\_I register (address 13h)

This register contains the NXP unique sensor product identifier and is factory programmed to 83h for FXLS8971CF.

Table 44. WHO\_AM\_I register (address 13h) bit allocation

| Bit    | 7 | 6             | 5 | 4 | 3 | 2 | 1 | 0 |
|--------|---|---------------|---|---|---|---|---|---|
| Name   |   | WHO_AM_I[7:0] |   |   |   |   |   |   |
| Reset  | 1 | 0             | 0 | 0 | 0 | 0 | 1 | 1 |
| Access | R | R             | R | R | R | R | R | R |

## 15.2.10 SYS\_MODE register (address 14h)

The **SYS\_MODE** register indicates the current device operating mode. Applications using the Auto-WAKE/SLEEP mechanism should use this register to synchronize their application with FXLS8971CF operating mode transitions. This register also indicates the status of the buffer gate error flag and the buffer gate count.

Table 45. SYS\_MODE register (address 14h) bit allocation

|                                    | ` `                  |   |                  |          |        |   |        |          |
|------------------------------------|----------------------|---|------------------|----------|--------|---|--------|----------|
| Bit                                | 7                    | 6 | 5                | 4        | 3      | 2 | 1      | 0        |
| Name                               | BUF_<br>GATE_<br>ERR |   | BUF <sub>-</sub> | _GATE_CN | Γ[4:0] |   | SYS_MO | ODE[1:0] |
| Reset (BT_MODE = GND)              | 0                    | _ | _                | _        | _      | _ | 0      | 0        |
| Reset (BT_MODE = V <sub>DD</sub> ) | 0                    | _ | _                | _        | _      | _ | 0      | 1        |
| Access                             | R                    | R | R                | R        | R      | R | R      | R        |

Table 46. SYS\_MODE register (address 14h) bit description

| Field                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>BUF_GATE_ERR        | Buffer gate error flag:  0: A buffer gate error has not been detected  1: A buffer gate error was detected.  If BUF CONFIG1[BUF _GATE] = 1 and the output buffer is not emptied before the arrival of the next XYZ acceleration sample, the BUF _GATE_ERR flag is asserted. The BUF GATE_ERR flag remains asserted as long as the output buffer remains un-emptied.  The BUF GATE_ERR flag may be cleared in one of the following ways:  1. Reading out the entire contents of the output buffer such that BUF _STATUS[BUF_CNT[5:0]] = 0.  2. Flushing (clearing) the output buffer contents by setting BUF_CONFIG2[BUF _FLUSH] = 1.  3. Disabling the output buffer by setting BUF _CONFIG1[BUF MODE[1:0]] = 00b, which clears BUF_CNT.  4. Transitioning FXLS8971CF from Standby to Active mode. |
| 6 to 2 BUF_GATE_CNT[4:0] | The BUF_GATE_CNT field contains the number of OOR periods that have elapsed since the BUF_GATE_ERR flag was asserted.  This buf_gate_cnt field is reset to 0 after any of the following actions:  1. The host reads out the entire contents of the output buffer such that BUF STATUS[BUF_CNT[5:0]] = 0.  2. The host flushes (clears) the output buffer by setting BUF_CONFIG2[BUF_FLUSH] = 1.  3. Disable the output buffer by setting BUF CONFIG1[BUF_MODE[1:0]] = 00b, which also clears the buffer contents.  4. Transitioning FXLS8971CF from Standby to Active mode. which also clears the buffer contents.                                                                                                                                                                                 |
| 1 to 0<br>SYS_MODE[1:0]  | The current system operating mode  00b: Standby mode (default mode after a POR or soft reset event when BT_MODE = GND)  01b: WAKE mode (default mode after a POR or soft reset event when BT_MODE = V_DD and MOT_DET = 1)  10b: SLEEP mode  11b: EXT_TRIG mode (this mode is unavailable when BT_MODE = V_DD)  Notes:  • When external trigger mode is enabled (with SENS_CONFIG4[INT2_FUNC] = 1), while the device is waiting for a trigger event to occur, SYS_MODE[1:0] is set to 11b. When the trigger                                                                                                                                                                                                                                                                                         |

Table 46. SYS\_MODE register (address 14h) bit description...continued

|       | <del></del>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|       | <ul> <li>is received, SYS_MODE[1:0] is set to 01b while the measurement is being made, and then change back to 11b and remain there until the next trigger signal is received.</li> <li>When INT_EN[WAKE_OUT_EN] = 1, and SYS_MODE[1:0] = 01b (WAKE), the device outputs either a logic '1' or '0' on either the INT1 or INT2 pins, depending on the settings made in INT_PIN_SEL[WAKE_OUT_INT2] and SENS_CONFIG4[INT_POL].</li> <li>When entering the WAKE, SLEEP, or EXT_TRIG modes, the internal debounce counters for the ORIENT, SDCD_WT, and SDCD_OT event functions are automatically reset.</li> </ul> |

# 15.3 Sensor main configuration registers

# 15.3.1 SENS\_CONFIG1 register (address 15h)

Table 47. SENS\_CONFIG1 register (address 15h) bit allocation

|                                    | ,   |         |           |        |       |     |       |        |
|------------------------------------|-----|---------|-----------|--------|-------|-----|-------|--------|
| Bit                                | 7   | 6       | 5         | 4      | 3     | 2   | 1     | 0      |
| Name                               | RST | ST_AXIS | _SEL[1:0] | ST_POL | SPI_M | FSR | [1:0] | ACTIVE |
| Reset (BT_MODE = GND)              | 0   | 0       | 0         | 0      | 0     | 0   | 0     | 0      |
| Reset (BT_MODE = V <sub>DD</sub> ) | 0   | 0       | 0         | 0      | 0     | 0   | 1     | 1      |
| Access                             | R/W | R/W     | R/W       | R/W    | R/W   | R/W | R/W   | R/W    |

Table 48. SENS CONFIG1 register (address 15h) bit description

| Field                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>RST                   | The RST bit may be used to initiate a software reset. The reset mechanism can be triggered in Standby, Active (WAKE or SLEEP), and EXT_TRIG operating modes. When the RST bit is set, the boot mechanism resets all functional blocks and loads the internal registers with their default values (The INT_POL, INT_PP_OD, and BOOT_DIS bits are not reset and maintains their current values as long as power is not removed from the $V_{DD}$ pin and Hibernate mode is not enabled). The host application should allow $T_{BOOT1}$ or $T_{BOOT2}$ ms between issuing a reset command and attempting communications with FXLS8971CF over the $I^2$ C/SPI interfaces. Alternatively, the host can wait for the active edge on the $T_{BOOT1/2}$ pulse event signaled on the configured INTx pin.  0: No device reset pending  1: Write '1' to trigger the soft reset sequence |
|                            | <ul> <li>Notes:</li> <li>The I<sup>2</sup>C and SPI interface blocks are also reset to avoid corrupted data transactions.</li> <li>The reset sequence does not start until the host I<sup>2</sup>C controller issues the SP (stop) condition, or the SPI primary releases the SPI_CS_B pin.</li> <li>The host always reads back this bit as '0'.</li> <li>There is a delay of 300 μs to 500 μs between setting the RST bit and the commencement of the reset sequence.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                             |
| 6 to 5<br>ST_AXIS_SEL[1:0] | Self-test axis selection This bit field selects the transducer axis to test using the Self-Test function. The ST_POL bit allows either positive or negative self-test displacements to be applied. The host system may use the self-test function to verify the functionality of both the transducer and signal measurement chain without the need to apply an external acceleration stimulus.  Notes:  The data output from the two axes that are not selected by ST_AXIS_SEL during the self-test sequence are not meaningful and should be ignored.                                                                                                                                                                                                                                                                                                                        |

Table 48. SENS\_CONFIG1 register (address 15h) bit description...continued

| Field              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | NXP recommends minimizing the communication traffic on the device serial interface during the measurement phase in order to reduce the susceptibility of the self-test response signal to induced noise. NXP strongly recommends operating the self-test in interrupt mode.  Ob: (default): Self-test function is disabled  Ob: Self-test function is enabled for X-axis  Self-test function is enabled for Y-axis  Self-test function is enabled for Z-axis                                                                                                                                                                                                                                                                                                                                      |
| 4<br>ST_POL        | Self-test displacement polarity 0 (default): Proof mass displacement for the selected axis is in the positive direction. 1: Proof mass displacement for the selected axis is in the negative direction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 3<br>SPI_M         | SPI interface mode selection; selects between 3- and 4-wire operating modes for the SPI interface:  0 (default): 4-wire interface mode is selected  1: 3-wire interface mode is selected  Notes:  • The state of this bit is only relevant when the SPI interface mode is selected (INTF_SEL = V <sub>DD</sub> ).  • When INTF_SEL = V <sub>DD</sub> and SPI_M = 1, the SDA/SPI_MOSI pin becomes the bidirectional SPI_DATA pin; the SA0/MISO pin is unused and placed in a high-impedance state.  • 4-wire mode is selected by default after a POR/BOR event or when exiting Hibernate mode.  • If INTF_SEL = V <sub>DD</sub> and the SPI_MOSI and SPI_MISO lines are directly connected together on the PCB, 3-wire SPI mode is enabled regardless of the setting of this bit                   |
| 2 to 1<br>FSR[1:0] | Full-scale measurement range (FSR) selection 00b: ±2 g; 0.98 mg/LSB (1024 LSB/g) nominal sensitivity 01b (default): ±4 g; 1.95 mg/LSB (512 LSB/g) nominal sensitivity 10b: ±8 g; 3.91 mg/LSB (256 LSB/g) nominal sensitivity 11b: ±16 g; 7.81 mg/LSB (128 LSB/g) nominal sensitivity                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0<br>ACTIVE        | Standby/Active mode selection This bit selects between Standby mode and Active mode.  Note:  • When INT2_FUNC = 1, the Active bit becomes read only via the I²C or SPI interface as the INT2 pin logic state directly controls the device operating mode. The INT2_FUNC may only be enabled (set to 1) when ACTIVE = 0. Similarly, the ACTIVE bit may only be set if INT2_FUNC = 0.  0: FXLS8971CF is placed in Standby mode and draws the minimum amount of current on the V <sub>DD</sub> pin (I <sub>DD-STBY</sub> ). Standby mode is the default mode after a POR or soft reset event.  1: FXLS8971CF is placed in Active mode and draws an I <sub>DD</sub> corresponding to the selected ODR in HPM, the selected ODR in LPM, or the user-selected decimation and idle time settings in FPM. |

# 15.3.2 SENS\_CONFIG2 register (address 16h)

Table 49. SENS\_CONFIG2 register (address 16h) bit allocation

|        |       | ,       |               |     |       |     |               |        |
|--------|-------|---------|---------------|-----|-------|-----|---------------|--------|
| Bit    | 7     | 6       | 5             | 4   | 3     | 2   | 1             | 0      |
| Name   | WAKE_ | PM[1:0] | SLEEP_PM[1:0] |     | LE_BE | _   | AINC_<br>TEMP | F_READ |
| Reset  | 0     | 0       | 0             | 0   | 0     | 0   | 0             | 0      |
| Access | R/W   | R/W     | R/W           | R/W | R/W   | R/W | R/W           | R/W    |

Table 50. SENS\_CONFIG2 register (address 16h) bit description

| Field                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 6<br>WAKE_PM[1:0]  | WAKE power mode selection 00b: Low-power mode is selected; <b>SENS_CONFIG3[</b> 7:4 <b>]</b> bits are interpreted as WAKE_ODR[3:0] and sets the ODR and decimation factor as per Table 52.                                                                                                                                                                                                                                                                                                                                                      |
|                         | 01b: High performance mode is selected; <b>SENS_CONFIG3[</b> 7:4 <b>]</b> bits are interpreted as WAKE_ODR[3:0] and set the ODR and decimation factor as per <u>Table 53</u> .                                                                                                                                                                                                                                                                                                                                                                  |
|                         | 1xb: Flexible performance mode is selected; <b>SENS_CONFIG3</b> [7:4] bits are interpreted as WAKE_DEC[3:0], which sets the measurement decimation factor. The effective ODR (and measurement current) is determined by the combination of the decimation factor and the 12-bit measurement idle time programmed in the <b>WAKE_IDLE_MSB</b> and <b>WAKE_IDLE_LSB</b> registers. See <u>Table 54</u> for the selectable decimation factors. <b>Note:</b> In motion detection mode with BT_MODE=VDD, use of HPM or FPM mode is not advised. Only |
|                         | the default LPM mode should be used. Only                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 5 to 4<br>SLEEP_PM[1:0] | SLEEP power mode selection  00b: Low-power mode is selected; <b>SENS_CONFIG3[</b> 3:0] bits are interpreted as SLEEP_ODR[3:0] and sets the ODR and decimation factor as per Table 52.                                                                                                                                                                                                                                                                                                                                                           |
|                         | 01b: High performance mode is selected; <b>SENS_CONFIG3[</b> 3:0 <b>]</b> bits are interpreted as SLEEP_ODR[3:0] and set the ODR and decimation factor as per <u>Table 53</u> .                                                                                                                                                                                                                                                                                                                                                                 |
|                         | 1xb: Flexible performance mode is selected; <b>SENS_CONFIG3</b> [3:0] bits are interpreted as SLEEP_DEC[3:0], which sets the measurement decimation factor. The effective ODR (and measurement current) is determined by the combination of the decimation factor and the 12-bit measurement idle time programmed in the <b>SLEEP_IDLE_MSB</b> and <b>SLEEP_IDLE_LSB</b> registers. See <u>Table 54</u> for the selectable decimation factors.                                                                                                  |
|                         | <b>Note:</b> In motion detection mode with $BT\_MODE=V_{DD}$ , use of HPM or FPM mode is not advised. Only the default LPM mode should be used.                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3                       | Little/Big-endian output mode selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| LE_BE                   | 0: Little-endian output mode is selected; the output data LSBs are stored at the lower logical address and the MSBs (nibbles) are right-justified.                                                                                                                                                                                                                                                                                                                                                                                              |
|                         | 1: Big-endian output mode is selected; the output data MSBs are stored at the lower logical address and the LSBs (nibbles) are left justified.                                                                                                                                                                                                                                                                                                                                                                                                  |
|                         | <b>Note:</b> The output data format selection applies only to the data read from the <b>OUT_X/Y/Z</b> , <b>VECM</b> , and <b>BUF_X/Y/Z</b> registers. All other multi-byte fields within the device are fixed in little-endian right justified format.                                                                                                                                                                                                                                                                                          |
| 1                       | Temperature output data auto-increment control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| AINC_TEMP               | 0 (default): <b>TEMP_OUT</b> register content is not included in auto-increment address range.  1: <b>TEMP_OUT</b> register content is included in auto-increment address range.                                                                                                                                                                                                                                                                                                                                                                |
| 0                       | Fast-read mode selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| F_READ                  | When this bit is set, the output data format is limited to the most significant byte of the 12-bit sample. The MSB data is always stored in the lower address, regardless of the setting made in <b>SENS_CONFIG1</b> [LE_BE]. The auto-increment address pointer automatically skips over the higher address for each axis' sample when performing a burst read operation of the current output data or buffered data when the F_READ bit is set.                                                                                               |
|                         | 0: Normal read mode 1: Fast-read mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                         | 1: Fast-read mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

# 15.3.3 SENS\_CONFIG3 register (address 17h)

The SENS\_CONFIG3 register is used to set the WAKE and SLEEP ODRs when operating in low-power mode or High Performance Mode, and the decimation factor for WAKE and SLEEP modes in Flexible Power Mode.

#### Notes:

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

- In motion detection mode with BT\_MODE=V<sub>DD</sub>, use of HPM or FPM mode is not advised. Only the default LPM mode should be used.
- When BT\_MODE=VDD, maximum recommended ODR is 100 Hz. When the data ready interrupt is enabled, the interrupt line (INT1) will pulse low for TPULSE-MOT seconds (5 ms typ) for every ODR period. Therefore, for higher ODRs, the host does not observe DRDY interrupt pulse at every ODR period.

Table 51. SENS CONFIG3 register (address 17h) bit allocation

| Bit                                | 7                             | 6   | 5   | 4   | 3   | 2       | 1   | 0   |
|------------------------------------|-------------------------------|-----|-----|-----|-----|---------|-----|-----|
| Name                               | WAKE_ODR[3:0] / WAKE_DEC[3:0] |     |     |     |     | EC[3:0] |     |     |
| Reset (BT_MODE = GND)              | 0                             | 0   | 0   | 0   | 0   | 0       | 0   | 0   |
| Reset (BT_MODE = V <sub>DD</sub> ) | 1                             | 1   | 0   | 0   | 0   | 0       | 0   | 0   |
| Access                             | R/W                           | R/W | R/W | R/W | R/W | R/W     | R/W | R/W |

In HPM and LPM modes, a decimation factor is implicit, as specified in Table 52 and Table 53, respectively.

In FPM, the decimation factor for WAKE and SLEEP modes is specified via the same bit-fields (see <u>Table 54</u> for the available settings), and along with the WAKE and SLEEP idle time parameter determines the effective ODR.

For example, if **SENS\_CONFIG2**[WAKE\_PM] = 10b, selecting FPM in the WAKE operating mode, the SENS\_CONFIG3 upper nibble is interpreted as the decimation factor for WAKE mode (WAKE\_DEC[3:0]) per Table 54. If a value of 0110b is chosen, for example, a decimation factor of 64 is selected. If WAKE\_IDLE[11:0] is set to 256 (decimal), the effective ODR would be 1 / ((256+1) \* (312.5 µs) \* 64) = 0.195 Hz.

The effective ODR is determined in a similar manner for the SLEEP operating mode using the SLEEP\_DEC[3:0] and the SLEEP IDLE[11:0] values.

When operating in HPM or LPM with ODR = 3200 Hz, or in FPM with IDLE\_TIME = 0, the first data sample is produced after a time delay greater than 1 ODR period using <u>Equation 1</u>.

$$T_{DELAY}(s) = 0.9984 \times \frac{(DEC - 1)}{ODR \times DEC} + 528.5 \,\mu s$$
 (1)

**Note:** The IDLE\_TIME refers to either WAKE\_IDLE[11:0] or SLEEP\_IDLE[11:0], depending on current operating mode.

After this initial delay, all subsequent data samples are made available at the ODR rate. For all other operating modes and settings the first sample is produced within 1 ODR period.

#### Notes:

- When the device transitions from WAKE to SLEEP or from SLEEP to WAKE modes there is a 500 μs
   (nominal) delay between the last acquisition at the WAKE/SLEEP mode ODR and the first acquisition at the
   SLEEP/WAKE mode ODR.
- The ODR may only be changed in Standby mode, with **SENS\_CONFIG1[**ACTIVE**]** = 0 and **SENS\_CONFIG4[**INT2\_FUNC**]** = 0.

Table 52. WAKE and SLEEP low-power mode ODR and decimation settings

| ODR[3] | ODR[2] | ODR[1] | ODR[0] | ODR Selection<br>(Hz) | Decimation<br>selection<br>(samples) |
|--------|--------|--------|--------|-----------------------|--------------------------------------|
| 0      | 0      | 0      | 0      | 3200                  | 1                                    |
| 0      | 0      | 0      | 1      | 1600                  | 1                                    |
| 0      | 0      | 1      | 0      | 800                   | 1                                    |

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

Table 52. WAKE and SLEEP low-power mode ODR and decimation settings ...continued

| ODR[3] | ODR[2] | ODR[1] | ODR[0] | ODR Selection<br>(Hz) | Decimation<br>selection<br>(samples) |
|--------|--------|--------|--------|-----------------------|--------------------------------------|
| 0      | 0      | 1      | 1      | 400                   | 1                                    |
| 0      | 1      | 0      | 0      | 200                   | 1                                    |
| 0      | 1      | 0      | 1      | 100                   | 1                                    |
| 0      | 1      | 1      | 0      | 50                    | 1                                    |
| 0      | 1      | 1      | 1      | 25                    | 1                                    |
| 1      | 0      | 0      | 0      | 12.5                  | 1                                    |
| 1      | 0      | 0      | 1      | 6.25                  | 1                                    |
| 1      | 0      | 1      | 0      | 3.125                 | 1                                    |
| 1      | 0      | 1      | 1      | 1.563                 | 1                                    |
| 1      | 1      | 0      | 0      | 0.781                 | 1                                    |
| 1      | 1      | 0      | 1      | 0.781                 | 1                                    |
| 1      | 1      | 1      | 0      | 0.781                 | 1                                    |
| 1      | 1      | 1      | 1      | 0.781                 | 1                                    |

Table 53. WAKE and SLEEP High Performance mode ODR and decimation settings

| ODR[3] | ODR[2] | ODR[1] | ODR[0] | ODR selection<br>(Hz) | Decimation selection (samples) |
|--------|--------|--------|--------|-----------------------|--------------------------------|
| 0      | 0      | 0      | 0      | 3200                  | 1                              |
| 0      | 0      | 0      | 1      | 1600                  | 2                              |
| 0      | 0      | 1      | 0      | 800                   | 4                              |
| 0      | 0      | 1      | 1      | 400                   | 8                              |
| 0      | 1      | 0      | 0      | 200                   | 16                             |
| 0      | 1      | 0      | 1      | 100                   | 32                             |
| 0      | 1      | 1      | 0      | 50                    | 64                             |
| 0      | 1      | 1      | 1      | 25                    | 128                            |
| 1      | 0      | 0      | 0      | 12.5                  | 256                            |
| 1      | 0      | 0      | 1      | 6.25                  | 512                            |
| 1      | 0      | 1      | 0      | 3.125                 | 1024                           |
| 1      | 0      | 1      | 1      | 1.563                 | 2048                           |
| 1      | 1      | 0      | 0      | 0.781                 | 4096                           |
| 1      | 1      | 0      | 1      | 0.781                 | 4096                           |
| 1      | 1      | 1      | 0      | 0.781                 | 4096                           |
| 1      | 1      | 1      | 1      | 0.781                 | 4096                           |

Table 54. WAKE and SLEEP decimation settings in Flexible Power mode

| DEC[3] | DEC[2] | DEC[1] | DEC[0] | Decimation selection (samples) | Measurement time (ms) |
|--------|--------|--------|--------|--------------------------------|-----------------------|
| 0      | 0      | 0      | 0      | 1                              | 0.3125                |
| 0      | 0      | 0      | 1      | 2                              | 0.625                 |
| 0      | 0      | 1      | 0      | 4                              | 1.25                  |
| 0      | 0      | 1      | 1      | 8                              | 2.5                   |
| 0      | 1      | 0      | 0      | 16                             | 5                     |
| 0      | 1      | 0      | 1      | 32                             | 10                    |
| 0      | 1      | 1      | 0      | 64                             | 20                    |
| 0      | 1      | 1      | 1      | 128                            | 40                    |
| 1      | 0      | 0      | 0      | 256                            | 80                    |
| 1      | 0      | 0      | 1      | 512                            | 160                   |
| 1      | 0      | 1      | 0      | 1024                           | 320                   |
| 1      | 0      | 1      | 1      | 2048                           | 640                   |
| 1      | 1      | 0      | 0      | 4096                           | 1280                  |
| 1      | 1      | 0      | 1      | 4096                           | 1280                  |
| 1      | 1      | 1      | 0      | 4096                           | 1280                  |
| 1      | 1      | 1      | 1      | 4096                           | 1280                  |

## 15.3.4 SENS\_CONFIG4 register (address 18h)

Table 55. SENS\_CONFIG4 register (address 18h) bit allocation

| Bit    | 7              | 6                | 5                | 4               | 3        | 2         | 1             | 0       |
|--------|----------------|------------------|------------------|-----------------|----------|-----------|---------------|---------|
| Name   | EXT_<br>TRIG_M | WAKE_<br>SDCD_WT | WAKE_<br>SDCD_OT | WAKE_<br>ORIENT | DRDY_PUL | INT2_FUNC | INT_<br>PP_OD | INT_POL |
| Reset  | 0              | 0                | 0                | 0               | 0        | 0         | 0             | 1       |
| Access | R/W            | R/W              | R/W              | R/W             | R/W      | R/W       | R/W           | R/W     |

Table 56. SENS CONFIG4 register (address 18h) bit description

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | External trigger function acquisition mode.                                                                                                                                                                                                                                                                                                                                                          |
| EXT_TRIG_M | 0 (default): Each positive going trigger edge causes a single ADC acquisition to be made. When the number of acquisitions specified by the current operating mode decimation setting have been triggered, the final decimated output is stored in the <b>OUT_X/Y/Z</b> registers or the buffer depending on the setting made in <b>BUF_CONFIG1</b> [BUF_MODE[1:0]].                                  |
|            | 1: Each positive going trigger edge causes multiple ADC acquisitions. The number of acquisitions are specified by the current operating mode decimation setting <sup>[1]</sup> . Once the specified number of acquisitions have been made, the final decimated output is stored in the <b>OUT_X/Y/Z</b> registers or the buffer depending on the setting made in <b>BUF_CONFIG1</b> [BUF_MODE[1:0]]. |
|            | Notes:                                                                                                                                                                                                                                                                                                                                                                                               |
|            | The EXT_TRIG_M setting only applies when INT2_FUNC = 1.                                                                                                                                                                                                                                                                                                                                              |

Table 56. SENS\_CONFIG4 register (address 18h) bit description...continued

| Description      The SRC_DRDY event flag is asserted after the specified number of measurements have completed and the final decimated output result is available. Note that the SRC_DRDY flag is only asserted when BUF_CONFIG1[BUF_MODE[1:0]] = 00b      In LPM, this bit has no effect as the decimation factor is fixed at 1.                                                                                                                                                                                                                                                                                     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| completed and the final decimated output result is available. Note that the SRC_DRDY flag is only asserted when <b>BUF_CONFIG1[</b> BUF_MODE[1:0] <b>]</b> = 00b                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| • In LPM, this bit has no effect as the decimation factor is fixed at 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| SDCD within thresholds event Auto-WAKE/SLEEP transition source enable 0 (default): SDCD within thresholds event is not used to prevent entry into/trigger an exit from SLEEF mode.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 1: SDCD within thresholds event is used to prevent entry into/trigger an exit from SLEEP mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| SDCD outside of thresholds event Auto-WAKE/SLEEP transition source enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0 (default): SDCD outside of thresholds event is not used to prevent entry into/trigger an exit from SLEEP mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1: SDCD outside of thresholds event is used to prevent entry into/trigger an exit from SLEEP mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Orientation change event Auto-WAKE/SLEEP transition source enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0 (default): Orientation change condition is not used as an event to prevent entry into /trigger an exit from SLEEP mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1: Orientation change condition is used as an event to prevent entry into/trigger an exit from SLEEP mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Pulse generation option for DRDY event                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0 (default): A SRC_DRDY event is output on the INTx pin as an active high or active low signal depending on the polarity setting made in INT_POL. The INTx pin remains asserted until the host reads any of the OUT_X/Y/Z registers.                                                                                                                                                                                                                                                                                                                                                                                  |
| 1: A 32 µs (nominal) duration pulse is output on the configured INTx pin once per ODR cycle. The output pulse is either positive or negative, depending on the INT_POL setting.  Notes:                                                                                                                                                                                                                                                                                                                                                                                                                               |
| The pulsed output signal is OR'd with all of the other interrupt events assigned to the INTx pin.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <ul> <li>In Motion Detection mode (BT_MODE = V<sub>DD</sub>), the state of this bit is ignored and has no effect on device operation.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| INT2 output / EXT_TRIG input pin selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0 (default): INT2/EXT_TRIG pin is configured for the INT2 output function. The logic polarity and output driver type are specified in the INT_POL and INT_PP_OD registers. Interrupt signals are selectively routed to this output pin using the INT_PIN_SEL register.                                                                                                                                                                                                                                                                                                                                                |
| 1: INT2/EXT_TRIG pin is configured as the EXT_TRIG input function. A positive edge (low-to-high) transition on the EXT_TRIG pin is used to trigger either a single measurement of the acceleration and temperature data using the current decimation settings when EXT_TRIG_M = 1 or a single acquisitio of the current acceleration and temperature data when EXT_TRIG_M = 0. This function is useful for realizing low frequency or asynchronous ODRs initiated by the host system, for example, by using ar MCU timer output pin. When this function is enabled, it is reflected in the SYS_MODE register.  Notes: |
| <ul> <li>When the EXT_TRIG function is enabled, any bits set to '1' in the INT_PIN_SEL register (mapping an event flag to the INT2 output pin) are ignored as the pin becomes a dedicated high-impedance input pin for the external trigger function.</li> <li>The INT2_FUNC bit setting is ignored when BT_MODE = V<sub>DD</sub> as the external trigger function is no available in this mode.</li> </ul>                                                                                                                                                                                                           |
| INT1 and INT2 pins output driver selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0 (default): INTx output pin driver is push-pull type.  1: INTx output pin driver is open-drain/open-source type. An external pull-up/pull-down resistor is required.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Notes:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <ul> <li>If a user operation sets INT_PP_OD before issuing a soft reset command, the setting is maintained<br/>through the reset sequence (only lost when V<sub>DD</sub> supply is removed or Hibernate mode is enabled).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

Table 56. SENS\_CONFIG4 register (address 18h) bit description...continued

| Field   | Description                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | • The INT_PP_OD bit setting is ignored when BT_MODE = V <sub>DD</sub> as the INT1/MOT_DET and INT2/BOOT_OUT output driver type is fixed to open-drain.                                                                                                                                                                                                                                                                                  |
| 0       | Interrupt logic polarity on INT1 and INT2 pins                                                                                                                                                                                                                                                                                                                                                                                          |
| INT_POL | Selects the polarity of the interrupt output signal on the INT1 and INT2 pins.                                                                                                                                                                                                                                                                                                                                                          |
|         | 0: Active low: interrupt events are signaled with a logical '0' level. If DRDY_PUL=1, a SRC_DRDY event pulse is negative going. The inactive state of the INTx pins is logic '1' (V <sub>DD</sub> ).                                                                                                                                                                                                                                    |
|         | 1 (default): Active high: interrupt events are signaled with a logical '1' level. If DRDY_PUL=1, a SRC_DRDY event pulse is positive going. The inactive state of the INTx pins is logic '0' (GND).                                                                                                                                                                                                                                      |
|         | Notes:                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|         | <ul> <li>If a user operation sets INT_POL before issuing a soft reset command, the setting is maintained through the reset sequence (only lost if V<sub>DD</sub> supply is removed or Hibernate mode is enabled).</li> <li>The INT_POL bit setting is ignored when BT_MODE = V<sub>DD</sub> as the INT1/MOT_DET and INT2/BOOT_OUT interrupt logic polarity is fixed at active low (external pull-up resistors are required).</li> </ul> |

<sup>[1]</sup> In order to acquire all the measurements specified by the decimation setting, only one trigger event is needed.

Table 57. INTx pin behavior as a function of INT\_PP\_OD and INT\_POL bit settings (valid only when BT\_MODE = Vpp)

| INTx pin configuration                          | INT_PP_OD | INT_POL | INTx pin asserted value | INTx pin<br>deasserted value |
|-------------------------------------------------|-----------|---------|-------------------------|------------------------------|
| CMOS output                                     | 0         | 0       | 0                       | 1                            |
| CMOS output                                     | 0         | 1       | 1                       | 0                            |
| External pull-up resistor added (open-drain)    | 1         | 0       | 0                       | High-Z <sup>[1]</sup>        |
| External pull-down resistor added (open source) | 1         | 1       | 1                       | High-Z <sup>[1]</sup>        |

<sup>[1]</sup> High-Z means high impedance condition, with the state of the INTx pin defined by the external pull-up or pull-down resistor.

Table 58. INTx pin behavior as a function of INT\_PP\_OD and INT\_POL bit settings (valid only when BT\_MODE =  $V_{DD}$ )

| ♥ DD/                                        |           |         |                         |                              |
|----------------------------------------------|-----------|---------|-------------------------|------------------------------|
| INTx pin configuration                       | INT_PP_OD | INT_POL | INTx pin asserted value | INTx pin<br>deasserted value |
| External pull-up resistor added (open-drain) | X         | X       | 0                       | 1                            |

## 15.3.5 SENS\_CONFIG5 register (address 19h)

Table 59. SENS CONFIG5 register (address 19h) bit allocation

| <u> </u>                           |     |     |     |         |       |       |       |                  |
|------------------------------------|-----|-----|-----|---------|-------|-------|-------|------------------|
| Bit                                | 7   | 6   | 5   | 4       | 3     | 2     | 1     | 0                |
| Name                               | _   | _   | _   | VECM_EN | X_DIS | Y_DIS | Z_DIS | HIBERNATE_<br>EN |
| Reset (BT_MODE = GND)              | 0   | 0   | 0   | 0       | 0     | 0     | 0     | 0                |
| Reset (BT_MODE = V <sub>DD</sub> ) | 0   | 0   | 0   | 0       | 0     | 0     | 0     | 0                |
| Access                             | R/W | R/W | R/W | R/W     | R/W   | R/W   | R/W   | R/W              |

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

Table 60. SENS\_CONFIG5 register (address 19h) bit description

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4<br>VECM_EN      | Vector Magnitude calculation enable: 0 (default): 12-bit vector magnitude result is not calculated on every ODR cycle. The VECM_LSB and VECM_MSB registers are not included in auto-increment address range. 1: 12-bit vector magnitude result is calculated on every ODR cycle. The VECM_LSB and VECM_MSB registers are included in auto-increment address range.  Note: The vector magnitude result may also be used as an input to the SDCD function when SDCD_CONFIG2[MODE] = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3<br>X_DIS        | X-axis auto-increment disable: 0 (default): X-axis measurement is included in the auto-increment address range for both buffered and non-buffered modes (default). 1: X-axis measurement is excluded from the auto-increment address range.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2<br>Y_DIS        | Y-axis auto-increment disable: 0 (default): Y-axis measurement is included in the auto-increment address range for both buffered and non-buffered modes (default). 1: Y-axis measurement is excluded from the auto-increment address range.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1<br>Z_DIS        | Z-axis auto-increment disable: 0 (default): Z-axis measurement is included in the auto-increment address range for both buffered and non-buffered modes (default). 1: Z-axis measurement is excluded from the auto-increment address range.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0<br>HIBERNATE_EN | Hibernate mode enable:  0: Hibernate mode not enabled; device is operating per the mode selected in WAKE_PM/SLEEP_PM[1:0]  1: Commands device to enter Hibernate mode; all RAM register contents are lost.  Notes:  • When BT_MODE = GND:  When Hibernate Mode is selected, FXLS8971CF is completely shut down (similar to removing the VDD supply), with all register contents lost. To exit Hibernate Mode, a positive or negative going edge must be applied to the SPI_CS_B/WAKE_UP pin (logic level must toggle from the state applied at the time this bit was set). The host must then wait TBOOT1 ms for the part to re-enter Standby mode before attempting communications over the I²C or SPI interfaces.  • When BT_MODE = VDD:  Hibernate mode is automatically entered/exited based on the level input to the MOT_DET pin. The part directly enters Active mode with the preconfigured motion detection settings when MOT_DET is pulled high. The host must wait TBOOT2 ms for the boot process to complete and the motion detection process to begin. When MOT_DET is brought low, the part automatically enters Hibernate mode to conserve power. |

## 15.3.6 WAKE\_IDLE\_LSB register (address 1Ah)

This register, along with WAKE\_IDLE\_MSB, sets the unsigned 12-bit WAKE mode idle time (off time).

**Note:** The contents of this register are only meaningful when **SENS CONFIG2**[WAKE PM[1:0]] = 1xb.

The counter period is nominally 312.5  $\mu$ s/LSB, providing a range of 312.5  $\mu$ s to 1.28 seconds. The idle time + measurement time (set by the WAKE mode decimation factor) forms the measurement period (ODR<sup>-1</sup>) as described in the <u>Section 15.3.3</u> register description.

Table 61. WAKE IDLE LSB register (address 1Ah) bit allocation

|        |     |                | ,   |     |     |     |     |     |
|--------|-----|----------------|-----|-----|-----|-----|-----|-----|
| Bit    | 7   | 6              | 5   | 4   | 3   | 2   | 1   | 0   |
| Name   |     | WAKE_IDLE[7:0] |     |     |     |     |     |     |
| Reset  | 0   | 0              | 0   | 0   | 0   | 0   | 0   | 0   |
| Access | R/W | R/W            | R/W | R/W | R/W | R/W | R/W | R/W |

## 15.3.7 WAKE\_IDLE\_MSB register (address 1Bh)

Flexible Power Mode WAKE idle time MSB. The contents of this register are only meaningful when **SENS\_CONFIG2[**WAKE\_PM[1:0]] = 1xb.

Table 62. WAKE IDLE MSB register (address 1Bh) bit allocation

| Bit    | 7   | 6   | 5   | 4   | 3               | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|-----------------|-----|-----|-----|
| Name   | 0   | 0   | 0   | 0   | WAKE_IDLE[11:8] |     |     |     |
| Reset  | 0   | 0   | 0   | 0   | 0               | 0   | 0   | 0   |
| Access | R/W | R/W | R/W | R/W | R/W             | R/W | R/W | R/W |

#### 15.3.8 SLEEP\_IDLE\_LSB register (address 1Ch)

Flexible Power Mode SLEEP idle time LSB. The contents of this register are only meaningful when **SENS\_CONFIG2**[SLEEP\_PM[1:0]] = 1xb. This register, along with SLEEP\_IDLE\_MSB, sets the unsigned 12-bit SLEEP mode idle-time (off-time). The counter time period is 312.5  $\mu$ s/LSB, providing a range of 312.5  $\mu$ s to 1.28 seconds. The idle time + measurement time (set by the SLEEP mode decimation factor) forms the measurement period (ODR<sup>-1</sup>).

Table 63. SLEEP\_IDLE\_LSB register (address 1Ch) bit allocation

| Bit    | 7   | 6               | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-----|-----------------|-----|-----|-----|-----|-----|-----|
| Name   |     | SLEEP_IDLE[7:0] |     |     |     |     |     |     |
| Reset  | 0   | 0               | 0   | 0   | 0   | 0   | 0   | 0   |
| Access | R/W | R/W             | R/W | R/W | R/W | R/W | R/W | R/W |

#### 15.3.9 SLEEP\_IDLE\_MSB register (address 1Dh)

Flexible Power Mode SLEEP idle time MSB (nibble). The contents of this register are useful only when **SENS\_CONFIG2**[SLEEP\_PM[1:0]] = 1xb.

Table 64. SLEEP\_IDLE\_MSB register (address 1Dh) bit allocation

| Bit    | 7   | 6   | 5   | 4   | 3   | 2          | 1          | 0   |
|--------|-----|-----|-----|-----|-----|------------|------------|-----|
| Name   | 0   | 0   | 0   | 0   |     | SLEEP_IDLE | TIME[11:8] |     |
| Reset  | 0   | 0   | 0   | 0   | 0   | 0          | 0          | 0   |
| Access | R/W | R/W | R/W | R/W | R/W | R/W        | R/W        | R/W |

#### 15.3.10 ASLP\_COUNT\_LSB, ASLP\_COUNT\_MSB registers (addresses 1Eh to 1Fh)

The **ASLP\_COUNT** value sets the minimum number of ODR periods needed to transition from WAKE to SLEEP mode when no event activity is detected. See <u>Section 15.3.4</u> for events that may be monitored for inactivity in order to trigger the transition to SLEEP mode when the internal counter reaches the **ASLP COUNT** value.

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

The sleep counter period corresponds to the selected WAKE mode ODR period when operating in LPM and HPM, and to the effective ODR set by the WAKE decimation (measurement time) and WAKE idle time (off-time) settings when the device operates in FPM. The auto-WAKE/SLEEP feature is only enabled when the value written to ASLP\_CNT is > 0.

**SENS\_CONFIG2**[WAKE\_PM] sets the WAKE power mode; **SENS\_CONFIG3**[WAKE\_ODR] sets the ODR. When operating in Flexible Performance Mode, **SENS\_CONFIG3**[WAKE\_DEC] and **WAKE\_IDLE**[11:0] values set the effective ODR.

**SENS\_CONFIG2**[SLEEP\_PM] sets the SLEEP power mode; **SENS\_CONFIG3**[SLEEP\_ODR] sets the ODR. When operating in Flexible Performance Mode, **SENS\_CONFIG3**[SLEEP\_DEC] and **SLEEP\_IDLE**[11:0] values set the effective ODR.

The functions used to detect inactivity and enter SLEEP mode upon expiry of the **ASLP\_COUNT** timer (see <u>Table 69</u>) are selected in **SENS\_CONFIG4** and **BUF\_CONFIG2**. The same functions used to enter SLEEP are also used to exit this mode when activity is detected except for the SRC\_BUF event flag, which can only be used to prevent/delay a transition from WAKE to SLEEP if the host system is reading data from the buffer (and clearing SRC\_BUF). A transition from SLEEP to WAKE mode occurs as soon as one of the enabled detection events becomes active. See <u>Table 70</u> for the corresponding Interrupt event sources.

Table 65. ASLP COUNT LSB register (address 1Eh) bit allocation

| Bit    | 7   | 6               | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-----|-----------------|-----|-----|-----|-----|-----|-----|
| Name   |     | ASLP_COUNT[7:0] |     |     |     |     |     |     |
| Reset  | 0   | 0 0 0 0 0 0 0   |     |     |     |     | 0   |     |
| Access | R/W | R/W             | R/W | R/W | R/W | R/W | R/W | R/W |

Table 66. ASLP COUNT LSB register (address 1Eh) bit description

| Field | Description                                                                                                                     |
|-------|---------------------------------------------------------------------------------------------------------------------------------|
|       | LSB of the 12-bit unsigned count value used for inactivity detection. The selected WAKE mode ODR determines the counter period. |

Table 67. ASLP\_COUNT\_MSB register (address 1Fh) bit allocation

| Bit    | 7   | 6   | 5   | 4   | 3   | 2       | 1         | 0   |
|--------|-----|-----|-----|-----|-----|---------|-----------|-----|
| Name   | _   | _   | _   | _   |     | ASLP_CO | UNT[11:8] |     |
| Reset  | 0   | 0   | 0   | 0   | 0   | 0       | 0         | 0   |
| Access | R/W | R/W | R/W | R/W | R/W | R/W     | R/W       | R/W |

Table 68. ASLP COUNT MSB register (address 1Fh) bit description

| Field | Description                                                                                                                              |
|-------|------------------------------------------------------------------------------------------------------------------------------------------|
|       | MSB (nibble) of the 12-bit unsigned count value used for inactivity detection. The selected WAKE mode ODR determines the counter period. |

FXLS8971CF

Table 69. ASLP\_COUNT timer period

| WAKE mode ODR (Hz) | WAKE mode<br>ODR Period (ms) | ASLP_COUNT Period (ms) | Max Inactivity Times |
|--------------------|------------------------------|------------------------|----------------------|
| 3200               | 0.3125                       | 0.3125                 | 1.28                 |
| 1600               | 0.625                        | 0.625                  | 2.56                 |
| 800                | 1.25                         | 1.25                   | 5.12                 |
| 400                | 2.5                          | 2.5                    | 10.24                |
| 200                | 5                            | 5                      | 20.48                |
| 100                | 10                           | 10                     | 40.96                |
| 50                 | 20                           | 20                     | 81.92                |
| 25                 | 40                           | 40                     | 163.84               |
| 12.5               | 80                           | 80                     | 327.68               |
| 6.25               | 160                          | 160                    | 655.36               |
| 3.125              | 320                          | 320                    | 1310.72              |
| 1.563              | 640                          | 640                    | 2621.44              |
| 0.781              | 1280                         | 1280                   | 5242.54              |

Table 70. Auto-WAKE/SLEEP Interrupt Event Sources

| add 10. Auto Wateroller intorrupt Evolt Gourge |                                        |                                                               |  |  |  |  |  |
|------------------------------------------------|----------------------------------------|---------------------------------------------------------------|--|--|--|--|--|
| Interrupt Event<br>Source                      | Event flag can clear auto-sleep timer? | Event flag can transition the device from SLEEP to WAKE mode? |  |  |  |  |  |
| SRC_DRDY                                       | No                                     | No                                                            |  |  |  |  |  |
| SRC_OVF                                        | No                                     | No                                                            |  |  |  |  |  |
| SRC_BUF                                        | Yes <sup>[1]</sup>                     | No                                                            |  |  |  |  |  |
| SRC_SDCD_OT                                    | Yes                                    | Yes                                                           |  |  |  |  |  |
| SRC_SDCD_WT                                    | Yes                                    | Yes                                                           |  |  |  |  |  |
| SRC_ORIENT                                     | Yes                                    | Yes                                                           |  |  |  |  |  |
| SRC_ASLP                                       | No <sup>[2]</sup>                      | No <sup>[2]</sup>                                             |  |  |  |  |  |
| SRC_BOOT                                       | No                                     | No                                                            |  |  |  |  |  |

<sup>[1]</sup> When BUF\_CONFIG2[WAKE\_SRC\_BUF] = 1, clearing the SRC\_BUF event flag resets the auto-sleep timer and prevent FXLS8971CF from entering SLEEP mode. When BUF\_CONFIG2[WAKE\_SRC\_BUF] = 0 (default), FXLS8971CF enters SLEEP mode regardless of the state of the BUF\_WMRK or BUF\_OVF event flags.

#### 15.3.11 INT\_EN register (address 20h)

This register is used to enable and disable the various interrupt event generators embedded within the device.

#### Note:

- When  $BT\_MODE = V_{DD}$ , the  $INT1/MOT\_DET$  pin signals any mapped (and enabled) interrupts with a  $T_{PULSE-MOT}$  ms active low pulse (open-drain output with external pull-up).
- Any enabled interrupt is signaled with a T<sub>PULSE-MOT</sub> ms pulse at the ODR rate until the respective interrupt source flag is cleared.

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

<sup>[2]</sup> If the BUF\_GATE bit is set to logic '1', it prevents the output buffer from accepting new data after a WAKE-to-SLEEP or SLEEP-to-WAKE operating mode transition until the host first empties the buffer contents. The BUF\_GATE bit is useful for preventing acceleration data from different WAKE and SLEEP mode ODRs from being mixed within the buffer.

• The INT2/BOOT\_OUT pin only signals the boot process complete interrupt, signaled by a T<sub>PULSE-BOOT2</sub> ms active low pulse (open-drain with external pull-up). Any other interrupt sources mapped to the INT2/BOOT\_OUT pin are ignored.

Table 71. INT\_EN register (address 20h) bit allocation

| Bit                                | 7       | 6      | 5              | 4              | 3             | 2       | 1            | 0               |
|------------------------------------|---------|--------|----------------|----------------|---------------|---------|--------------|-----------------|
| Name                               | DRDY_EN | BUF_EN | SDCD_<br>OT_EN | SDCD_<br>WT_EN | ORIENT_<br>EN | ASLP_EN | BOOT_<br>DIS | WAKE_<br>OUT_EN |
| Reset (BT_MODE = GND)              | 0       | 0      | 0              | 0              | 0             | 0       | 0            | 0               |
| Reset (BT_MODE = V <sub>DD</sub> ) | 0       | 0      | 1              | 0              | 0             | 0       | 0            | 0               |
| Access                             | R/W     | R/W    | R/W            | R/W            | R/W           | R/W     | R/W          | R/W             |

Table 72. INT\_EN register (address 20h) bit description

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>DRDY_EN    | Data-ready interrupt output enable 0 (default): Interrupt is disabled. 1: Interrupt is enabled and signaled on either the INT1 or INT2 output pins as configured by the setting made in INT_PIN_SEL.  Note: When BT_MODE = GND, SRC_DRDY bit and the signaled interrupt are cleared whenever one or more of the VECM, and OUT_X/Y/Z registers are read. When BT_MODE = V_DD, SRC_DRDY bit is cleared whenever one or more of the VECM, and OUT_X/Y/Z registers are read. However the data ready interrupt is signaled for TPULSE-MOT s (5 ms typ) and it clears itself automatically. The current data ready interrupt pulse is terminated when the device transitions into STANDBY mode before its completion and therefore may not span for entire TPULSE-MOTs. |
| 6<br>BUF_EN     | Output data buffer interrupt output enable 0 Interrupt is not routed to the INTx output pins (default) 1: Interrupt is routed to either the INT1 or INT2 output pins as configured by the setting made in INT_PIN_SEL.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5<br>SDCD_OT_EN | SDCD outside of thresholds interrupt output enable 0 (default): Interrupt is disabled. 1: Interrupt is routed to either the INT1 or INT2 output pin as configured by the setting made in INT_PIN_SEL.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 4<br>SDCD_WT_EN | SDCD within thresholds interrupt output enable 0 (default): Interrupt is disabled. 1: Interrupt is routed to either the INT1 or INT2 output pins as configured by the setting made in INT_PIN_SEL.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3<br>ORIENT_EN  | Orientation interrupt output enable 0 (default): Interrupt is disabled. 1: Interrupt is enabled and signaled on either the INT1 or INT2 output pins as determined by the setting made in INT_PIN_SEL.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2<br>ASLP_EN    | Auto-WAKE/SLEEP interrupt output enable 0 (default): Interrupt is disabled. 1: Interrupt is enabled and signaled on either the INT1 or INT2 output pins as determined by the setting made in INT_PIN_SEL.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1<br>BOOT_DIS   | Boot interrupt output disable 0 (default): Boot interrupt is enabled and routed to either the INT1 or INT2 output pin as determined by the setting made in INT_PIN_SEL. This interrupt is pulsed, with the polarity of the pulse determined by the setting made in SENS_CONFIG4[INT_POL].                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

Table 72. INT\_EN register (address 20h) bit description...continued

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 1: Interrupt is disabled and not routed to the INTx output pins.                                                                                                                                                                                                                                                                                                                                                                                                               |
|             | When BT_MODE = GND:                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|             | The SRC_BOOT interrupt is signaled on the INTx pin selected in <b>INT_PIN_SEL</b> and pulsed for a duration of T <sub>PULSE-BOOT1</sub> µs when the BOOT process completes.                                                                                                                                                                                                                                                                                                    |
|             | When BT_MODE = V <sub>DD</sub> :                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|             | This bit is ignored and the SRC_BOOT interrupt is internally enabled and mapped to the INT2/BOOT_OUT pin (fixed settings). The INT2/BOOT_OUT pin is pulsed low for a duration of T <sub>PULSE-BOOT2</sub> ms during the BOOT sequence.                                                                                                                                                                                                                                         |
|             | <b>Note:</b> The BOOT_DIS bit holds the user programmed value until the V <sub>DD</sub> supply is removed or Hibernate mode is entered; this setting is, however, maintained across a soft reset operation.                                                                                                                                                                                                                                                                    |
| 0           | WAKE power state output enable                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| WAKE_OUT_EN | 0 (default): The device does not signal the WAKE operating mode on the INTx output pin.                                                                                                                                                                                                                                                                                                                                                                                        |
|             | 1: The device signals that it is currently in WAKE mode via the INT1 or INT2 pin. Whenever <b>SYS_MODE[</b> sys_mode] = 01b, the INT1 or INT2 pin (as selected in INT_PIN_SEL) is held high or low, depending on the setting made in <b>SENS_CONFIG4[</b> INT_POL]. The logic state is maintained as long as the device remains in WAKE mode. When the device leaves WAKE mode and enters SLEEP or EXT_TRIG mode, the selected interrupt pin assumes the opposite logic state. |
|             | <b>Note:</b> If the host system is utilizing the WAKE_OUT function to control an external load switch or LDO enable signal, other enabled interrupts should not be mapped to the same pin that is assigned to the WAKE_OUT function in order to prevent unintended operation of the load switch or LDO.                                                                                                                                                                        |

## 15.3.12 INT\_PIN\_SEL register (address 21h)

This register may be used to control the routing of event flags to either the INT1 or INT2 output pins.

#### Notes:

- When the INT2 pin is configured for the external trigger function, for example, when **SENS\_CONFIG4**[INT2\_FUNC] = 1, a logic '1' value in any of these bit fields is ignored.
- When BT\_MODE =  $V_{DD}$ , the only interrupt that may be mapped to the INT2/BOOT\_OUT pin is the SRC\_BOOT interrupt; setting any of the other bits in this register to '1' effectively unroutes the respective interrupt source from both the INT1 and INT2 pins.

Table 73. INT\_PIN\_SEL register (address 21h) bit allocation

| Bit    | 7             | 6        | 5                | 4                | 3               | 2         | 1             | 0                 |
|--------|---------------|----------|------------------|------------------|-----------------|-----------|---------------|-------------------|
| Name   | DRDY_<br>INT2 | BUF_INT2 | SDCD_<br>OT_INT2 | SDCD_<br>WT_INT2 | ORIENT_<br>INT2 | ASLP_INT2 | BOOT_<br>INT2 | WAKE_<br>OUT_INT2 |
| Reset  | 0             | 0        | 0                | 0                | 0               | 0         | 0             | 0                 |
| Access | R/W           | R/W      | R/W              | R/W              | R/W             | R/W       | R/W           | R/W               |

Table 74. INT\_PIN\_SEL register (address 21h) bit description

| Field          | Description                                                                                                                                                                                                                                                                  |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>DRDY_INT2 | Data-ready interrupt routing  0: If data-ready interrupt routing is enabled, the interrupt signal is routed to INT1 pin.  1: If data-ready interrupt routing is enabled, the interrupt signal is routed to INT2 pin.                                                         |
| 6<br>BUF_INT2  | Output buffer interrupt routing (BUF_OVF   BUF_WMRK   BUF_GATE_ERR):  0: If output buffer interrupt routing is enabled, the interrupt signal is routed to INT1 pin. (default)  1: If output buffer interrupt routing is enabled, the interrupt signal is routed to INT2 pin. |

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

Table 74. INT\_PIN\_SEL register (address 21h) bit description...continued

| Field              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5<br>SDCD_OT_INT2  | SDCD outside of thresholds event interrupt routing  0: If SDCD outside of thresholds event interrupt routing is enabled, the interrupt signal is routed to INT1 pin.  1: If SDCD outside of thresholds event interrupt routing is enabled, the interrupt signal is routed to INT2 pin.                                                                                                                                                                                                                                                          |
| 4<br>SDCD_WT_INT2  | SDCD within thresholds event interrupt routing  0: If SDCD within thresholds event interrupt routing is enabled, the interrupt signal is routed to INT1 pin.  1: If SDCD within thresholds event interrupt routing is enabled, the interrupt signal is routed to INT2 pin.                                                                                                                                                                                                                                                                      |
| 3<br>ORIENT_INT2   | ORIENT event interrupt routing 0: If ORIENT event interrupt routing is enabled, the interrupt signal is routed to INT1 pin. 1: If ORIENT event interrupt routing is enabled, the interrupt signal is routed to INT2 pin.                                                                                                                                                                                                                                                                                                                        |
| 2<br>ASLP_INT2     | Auto-WAKE/SLEEP event interrupt routing  0: If Auto-WAKE/SLEEP event interrupt routing is enabled, the interrupt signal is routed to INT1 pin.  1: If Auto-WAKE/SLEEP event interrupt routing is enabled, the interrupt signal is routed to INT2 pin.                                                                                                                                                                                                                                                                                           |
| 1<br>BOOT_INT2     | BOOT event interrupt routing  If a user operation sets BOOT_INT2 before issuing a soft reset command, the setting is maintained through the reset sequence (the setting is lost if $V_{DD}$ supply is removed).  0: If BOOT event interrupt routing is enabled, the interrupt signal is routed to INT1 pin.  1: If BOOT event interrupt routing is enabled, the interrupt signal is routed to INT2 pin.  Note: When BT_MODE = $V_{DD}$ , this bit is ignored; the BOOT interrupt is internally mapped to the INT2/BOOT_OUT pin (fixed setting). |
| 0<br>WAKE_OUT_INT2 | WAKE power state interrupt routing 0: If WAKE power state interrupt routing is enabled, the WAKE power state output is routed to INT1 pin. 1: If WAKE power state interrupt routing is enabled, the WAKE power state output is routed to INT2 pin.                                                                                                                                                                                                                                                                                              |

#### 15.3.13 OFF\_X, OFF\_Y, OFF\_Z registers (addresses 22h to 24h)

Registers 22h to 24h (OFF\_X/Y/Z) can be used to realign the zero-*g* position of the X-, Y-, and Z-axes after PCB assembly. The registers are 8 bit, 2's complement providing an offset adjustment range of –128 to 127.

<u>Equation 2</u> determines the effective offset value in mg, set by each of the OFF\_X/Y/Z registers. The equation is an X-axis example, with the other axes offsets set in an identical manner.

Of f set 
$$(mg) = OFF_X \times \left(2 \times Sensitivity\left(\frac{mg}{LSB}\right)\right)$$
 (2)

For example, writing the value +16 (10h) into the OFF\_X register in the  $\pm 4~g$  FSR results in an effective X-axis offset of 16 LSB \* 2 \* 1.95 mg/LSB = 62.4 mg.

Table 75. OFF\_X register (addresses 22h) bit allocation

|        |     | `          | ,   |     |     |     |     |     |
|--------|-----|------------|-----|-----|-----|-----|-----|-----|
| Bit    | 7   | 6          | 5   | 4   | 3   | 2   | 1   | 0   |
| Name   |     | OFF_X[7:0] |     |     |     |     |     |     |
| Reset  | 0   | 0          | 0   | 0   | 0   | 0   | 0   | 0   |
| Access | R/W | R/W        | R/W | R/W | R/W | R/W | R/W | R/W |

#### Table 76. OFF\_Y register (addresses 23h) bit allocation

| Bit    | 7   | 6          | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-----|------------|-----|-----|-----|-----|-----|-----|
| Name   |     | OFF_Y[7:0] |     |     |     |     |     |     |
| Reset  | 0   | 0          | 0   | 0   | 0   | 0   | 0   | 0   |
| Access | R/W | R/W        | R/W | R/W | R/W | R/W | R/W | R/W |

#### Table 77. OFF\_Z register (addresses 24h) bit allocation

|        |     | Ī          | · · |     |     |     |     |     |
|--------|-----|------------|-----|-----|-----|-----|-----|-----|
| Bit    | 7   | 6          | 5   | 4   | 3   | 2   | 1   | 0   |
| Name   |     | OFF_Z[7:0] |     |     |     |     |     |     |
| Reset  | 0   | 0          | 0   | 0   | 0   | 0   | 0   | 0   |
| Access | R/W | R/W        | R/W | R/W | R/W | R/W | R/W | R/W |

## 15.3.14 BUF\_CONFIG1 register (address 26h)

The BUF\_CONFIG1 register controls the output buffer read order, data collection mode and trigger event sources.

Table 78. BUF\_CONFIG1 register (address 26h) bit allocation

|        |          | ٠ ,    | ,        |          |                  |                  |     |                 |
|--------|----------|--------|----------|----------|------------------|------------------|-----|-----------------|
| Bit    | 7        | 6      | 5        | 4        | 3                | 2                | 1   | 0               |
| Name   | BUF_TYPE | BUF_MC | DDE[1:0] | BUF_GATE | TRIG_<br>SDCD_WT | TRIG_<br>SDCD_OT | _   | TRIG_<br>ORIENT |
| Reset  | 0        | 0      | 0        | 0        | 0                | 0                | 0   | 0               |
| Access | R/W      | R/W    | R/W      | R/W      | R/W              | R/W              | R/W | R/W             |

Table 79. BUF\_CONFIG1 register (address 26h) bit description

| Field         | Description                                                                                                                                                           |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7             | Buffer data read out order:                                                                                                                                           |
| BUF_TYPE      | 0: First In First Out (FIFO). Default                                                                                                                                 |
|               | In FIFO mode, the oldest sample data is read out first, followed by the more recent sample data.                                                                      |
|               | 1: First In Last Out (LIFO).                                                                                                                                          |
|               | In LIFO mode, the newest data sample is read out first, followed by the older sample data.                                                                            |
|               | <b>Note:</b> It is not possible to change the buffer operating mode without first clearing the <b>SENS_CONFIG1</b> [ACTIVE] and <b>SENS_CONFIG4</b> [INT2_FUNC] bits. |
| 6 to 5        | Buffer data collection mode:                                                                                                                                          |
| BUF_MODE[1:0] | 00: Buffer is disabled.                                                                                                                                               |

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

Table 79. BUF\_CONFIG1 register (address 26h) bit description...continued

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | 01: Stream Mode: buffer always contains the most recent 32 samples when overflowed. The oldest sample data is replaced with new data when the buffer becomes full and a new sample arrives.  10: Stop Mode: buffer stops accepting new samples when full.                                                                                                                                                                                                                                                                                                                                                                                                     |
|                   | 11: Trigger mode: The buffer will operate in circular mode until the trigger event occurs, collecting up to <b>BUF_CONFIG2</b> [BUF_WMRK[5:0]] samples; after a configured trigger event occurs the buffer continues to accept up to (32- <b>BUF_CONFIG2</b> [BUF_WMRK[5:0]]) samples, set the BUF_OVF flag, and stop collecting further samples. Trigger mode allows acceleration data to be collected both before and after the trigger event, with the maximum number of pre-trigger samples defined by the <b>BUF_CONFIG2</b> [BUF_WMRK[5:0]] setting.  *Note: The BUF_OVF flag is cleared and the triggered mode re-armed once the host flushes or reads |
|                   | all the buffer contents.  The available trigger sources are the SDCD within- and outside-of-thresholds events, and orientation change event. These trigger sources are enabled in this register via the TRIG_SDCD_WT, TRIG_SDCD_OT, and TRIG_ORIENT bits.                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4                 | Output data buffer gate enable:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| BUF_GATE          | 0: Buffer gate is bypassed (default). Output data buffer is automatically flushed when FXLS8971CF transitions from WAKE to SLEEP or SLEEP to WAKE modes. This operation prevents acceleration data from two different ODRs rates becoming mixed in the output buffer.                                                                                                                                                                                                                                                                                                                                                                                         |
|                   | 1: The Output data buffer input gate is enabled when transitioning from WAKE to SLEEP or SLEEP to WAKE modes; the entire buffer contents must be read out or flushed ( <b>BUF_CONFIG2</b> [BUF_FLUSH] = 1) to allow the further collection of sample data. Any new samples that arrive before the buffer has been read out or flushed are discarded, and the BUF_GATE_ERR bit in the <b>SYS_MODE</b> register is asserted. <b>SYS_MODE</b> [BUF_GATE_CNT] maintains a count of the number of samples discarded since the BUF_GATE_ERR flag was asserted.                                                                                                      |
|                   | Although FXLS8971CF still transitions from WAKE to SLEEP or SLEEP to WAKE, the contents of the FIFO buffer are preserved, and any new data samples are not stored in the buffer until it is either emptied of flushed by the host application.                                                                                                                                                                                                                                                                                                                                                                                                                |
|                   | Notes:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                   | <ul> <li>The BUF_GATE_ERR flag remains asserted as long as the buffer remains un-emptied.</li> <li>When triggered buffer mode (BUF_MODE = 11b) is selected and ASLP_COUNT ≥ 1, the BUF_GATE setting is ignored.</li> <li>The BUF_GATE bit in 1: Trigger source is enabled, when set, holds the last data set stored in the</li> </ul>                                                                                                                                                                                                                                                                                                                         |
|                   | buffer before transitioning to the SLEEP or WAKE modes. After the buffer is flushed, FXLS8971CF will start accepting new sample data into the buffer at the current operating mode ODR.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3<br>TRIG_SDCD_WT | SDCD within thresholds event buffer trigger enable: 0: Trigger source is disabled (default). 1: Trigger source is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2<br>TRIG_SDCD_OT | SDCD outside of thresholds event buffer trigger enable: 0: Trigger source is disabled (default). 1: Trigger source is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0<br>TRIG_ORIENT  | Orientation change event buffer trigger enable: 0: Trigger source is disabled (default). 1: Trigger source is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

The buffer contents are flushed whenever the buffer is disabled (by setting BUF\_MODE = 00b), when **BUF\_CONFIG2**[BUF\_FLUSH] is set, or after an automatic power mode change when transitioning from WAKE-to-SLEEP or SLEEP-to-WAKE with **BUF\_CONFIG1**[BUF\_GATE] = 0. The buffer contents are also automatically flushed on a transition from STANDBY to ACTIVE or STANDBY to EXT\_TRIG mode. The buffer may be prevented from being flushed when transitioning from WAKE-to-SLEEP or SLEEP-to-WAKE by setting **BUF\_CONFIG1**[BUF\_GATE] = 1.

FXLS8971C

Disabling the buffer clears the **BUF\_STATUS**[BUF\_OVF] and **BUF\_STATUS**[BUF\_WMRK] event flags. Disabling the buffer also clears the **BUF\_STATUS**[BUF\_CNT] field. The **SYS\_MODE**[BUF\_GATE\_ERR] and **SYS\_MODE**[buf\_gate\_cnt] fields are also reset when the buffer is disabled, flushed, or when the host reads out all the content.

Notes for using triggered operating mode with Auto-WAKE/SLEEP mode enabled:

- When BUF\_MODE = 11b, ASLP\_COUNT ≥ 1, and the ACTIVE bit is set, FXLS8971CF immediately enters
  the WAKE mode. After ASLP\_COUNT ODR periods, the buffer is flushed and the part enters SLEEP mode.
  The buffer collects up to BUF\_CONFIG2[BUF\_WMRK] samples at the SLEEP mode ODR before the trigger
  event occurs (in stream mode).
- 2. After the trigger event, FXLS8971CF enters WAKE mode and remain there regardless of the setting made in ASLP\_COUNT, ignore any subsequent triggers, and collects (32 BUF\_WMRK[5:0]) samples at the WAKE mode ODR, set the BUF\_OVF flag, and cease collecting more data until the host flushes the buffer or reads out all of the contents. Once the buffer is emptied or flushed, the triggered mode is re-armed, but FXLS8971CF must first re-enter SLEEP mode (which will happen after ASLP\_COUNT WAKE ODR periods) before a second set of data can be collected.
- 3. The **BUF\_CONFIG1**[BUF\_GATE] setting is ignored and has no effect. The buffer contents are automatically flushed when FXLS8971CF transitions from WAKE to SLEEP.
- 4. The interrupt events that prevent FXLS8971CF from entering SLEEP mode also prevents the operation of the triggered mode (which requires FXLS8971CF to first enter the SLEEP mode).

#### 15.3.15 BUF\_CONFIG2 register (address 27h)

Table 80. BUF CONFIG2 register (address 27h) bit allocation

| Bit    | 7             | 6                | 5             | 4   | 3   | 2   | 1   | 0   |
|--------|---------------|------------------|---------------|-----|-----|-----|-----|-----|
| Name   | BUF_<br>FLUSH | WAKE_<br>SRC_BUF | BUF_WMRK[5:0] |     |     |     |     |     |
| Reset  | 0             | 0                | 0             | 0   | 0   | 0   | 0   | 0   |
| Access | R/W           | R/W              | R/W           | R/W | R/W | R/W | R/W | R/W |

Table 81. BUF\_CONFIG2 register (address 27h) bit description

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7            | Buffer flush enable:                                                                                                                                                                                                                                                                                                                                                                                                         |
| BUF_FLUSH    | 0: No pending buffer flush operation, or buffer flush completed                                                                                                                                                                                                                                                                                                                                                              |
|              | 1: Buffer flush enable: all buffer contents and related event flags are cleared. The <b>SYS_MODE[</b> BUF_GATE_ERR <b>]</b> and <b>SYS_MODE[</b> BUF_GATE_CNT[4:0] <b>]</b> fields are also cleared.                                                                                                                                                                                                                         |
|              | The BUF_FLUSH bit is self-cleared within one internal clock cycle, and as such is not observable in a logic high state through the I <sup>2</sup> C or SPI interfaces.                                                                                                                                                                                                                                                       |
| 6            | Buffer WAKE-to-SLEEP transition source enable:                                                                                                                                                                                                                                                                                                                                                                               |
| WAKE_SRC_BUF | 0: (BUF_WMRK   BUF_OVF) event flag condition is ignored by the auto-WAKE/SLEEP function (default).                                                                                                                                                                                                                                                                                                                           |
|              | 1: (BUF_WMRK   BUF_OVF) event flag condition is used by the auto-WAKE/SLEEP function.                                                                                                                                                                                                                                                                                                                                        |
|              | FXLS8971CF enters SLEEP mode if the host system does not clear any of these flags before the auto-sleep timer expires (the <b>ASLP_COUNT</b> register sets the period). If the host clears the BUF_WMRK and BUF_OVF flags by flushing or reading out the buffered data (one or more samples), the auto-sleep timer resets and FXLS8971CF remains in the WAKE mode, regardless of the setting made in <b>INT_EN[</b> BUF_EN]. |
|              | Note: The WAKE_SRC_BUF setting is only relevant when BUF_CONFIG1[BUF_MODE] = 01b (Stream mode) or 10b (Stop mode).                                                                                                                                                                                                                                                                                                           |

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

Table 81. BUF\_CONFIG2 register (address 27h) bit description...continued

| Field                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5 to 0<br>BUF_WMRK[5:0] | Buffer sample count watermark: This field sets the minimum number of buffer samples required to trigger a watermark interrupt. A buffer watermark event flag BUF_STATUS[BUF_WMRK] is raised whenever BUF_ STATUS[BUF_CNT] > BUF_CONFIG2[BUF_WMRK[5:0]]. Setting BUF_WMRK = 0 disables the buffer watermark event flag generation. This field is also used to set the maximum number of pre-trigger samples to collect in triggered operating mode when BUF_CONFIG1[BUF_MODE] = 11b. |

# 15.4 Orientation detection settings registers

## 15.4.1 ORIENT\_STATUS register (address 28h)

The ORIENT\_STATUS register is used to determine the status of an Orientation change event, which is signaled when **INT\_STATUS**[SRC\_ORIENT] = 1. For information on the physical device orientations that correspond to the portrait up, portrait down, landscape left, landscape right, back, and front orientation states, see <u>Section 6.3</u>.

Table 82. ORIENT\_STATUS register (address 28h) bit allocation

| Bit    | 7              | 6  | 5 | 4 | 3 | 2    | 1      | 0     |
|--------|----------------|----|---|---|---|------|--------|-------|
| Name   | NEW_<br>ORIENT | LO |   | _ |   | LAPO | D[1:0] | BAFRO |
| Reset  | 0              | 0  | 0 | 0 | 0 | 0    | 0      | 0     |
| Access | R              | R  | R | R | R | R    | R      | R     |

Table 83. ORIENT\_STATUS register (address 28h) bit description

| Field      | Description                                                                                                                                                                                                                                    |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | Orientation status change flag                                                                                                                                                                                                                 |
| NEW_ORIENT | 0: No change in orientation detected                                                                                                                                                                                                           |
|            | 1: BAFRO and/or LAPO and/or Z-tilt lockout value has changed                                                                                                                                                                                   |
|            | Notes:                                                                                                                                                                                                                                         |
|            | The NEW_ORIENT bit is set to 1 after the first orientation detection after a Standby to Active transition and whenever a change in LO, BAFRO, or LAPO status occurs. The NEW_ORIENT bit is cleared anytime the ORIENT_STATUS register is read. |
|            | The Auto-WAKE/SLEEP timer is reset (cleared) on the rising edge of this flag.                                                                                                                                                                  |
| 6          | Z-tilt angle lockout                                                                                                                                                                                                                           |
| LO         | 0: Lockout condition has not been detected.                                                                                                                                                                                                    |
|            | 1: Z-tilt lockout trip angle has been exceeded. Lockout condition has been detected.                                                                                                                                                           |
|            | <b>Note:</b> The LO bit continues to update with orientation changes even after the <b>NEW_ORIENT</b> flag is set.                                                                                                                             |
| 2 to 1     | Landscape/Portrait orientation                                                                                                                                                                                                                 |
| LAPO[1:0]  | 00: Portrait up: The device is oriented vertically in the upward direction.                                                                                                                                                                    |
|            | 01: Portrait down: The device is oriented vertically in the downward direction.                                                                                                                                                                |
|            | 10: Landscape right: The device is oriented horizontally to the right.                                                                                                                                                                         |
|            | 11: Landscape left: The device is oriented horizontally to the left.                                                                                                                                                                           |
|            | Note: The LAPO[1:0] field continues to update with orientation changes even after the NEW_ORIENT flag is set.                                                                                                                                  |

FXLS8971C

Product data sheet

All information provided in this document is subject to legal disclaimers.

Table 83. ORIENT\_STATUS register (address 28h) bit description...continued

| Field | Description                                                                                                                  |
|-------|------------------------------------------------------------------------------------------------------------------------------|
| 0     | Back or front orientation                                                                                                    |
| BAFRO | 0: Front: The device is in the front-facing orientation.                                                                     |
|       | 1: Back: The device is in the back-facing orientation.                                                                       |
|       | <b>Note:</b> The <b>BAFRO</b> bit continues to update with orientation changes even after the <b>NEW_ORIENT</b> flag is set. |

#### Notes:

- The BAFRO and LAPO fields are reset to 0 after a POR or soft reset event. These bits are also automatically cleared after a transition from STANDBY to ACTIVE or STANDBY to EXT\_TRIG modes.
- The current orientation is locked if the absolute value of the acceleration experienced on any of the three axes is greater than 1.25 g.

#### 15.4.2 ORIENT\_CONFIG register (address 29h)

This register is used to enable the orientation detection function and set the behavior of the orientation transition debounce counter.

Table 84. ORIENT CONFIG register (address 29h) bit allocation

|        |                   | <u> </u>          |     |     | 1   |     |     |     |
|--------|-------------------|-------------------|-----|-----|-----|-----|-----|-----|
| Bit    | 7                 | 6                 | 5   | 4   | 3   | 2   | 1   | 0   |
| Name   | ORIENT_<br>DBCNTM | ORIENT_<br>ENABLE |     |     | _   | _   |     |     |
| Reset  | 1                 | 0                 | 0   | 0   | 0   | 0   | 0   | 0   |
| Access | R/W               | R/W               | R/W | R/W | R/W | R/W | R/W | R/W |

Table 85. ORIENT CONFIG register (address 29h) bit description

| Description                                                                                                                                                                                                                          |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Orientation debounce counter mode selection                                                                                                                                                                                          |
| O: Orientation debounce counter is decremented whenever the current orientation is different than the previous one.  1: Orientation debounce counter is cleared whenever the current orientation is different than the previous one. |
| Orientation detection function enable 0 (default): Orientation detection function is disabled.                                                                                                                                       |
|                                                                                                                                                                                                                                      |

# 15.4.3 ORIENT\_DBCOUNT register (address 2Ah)

The **ORIENT\_DBCOUNT** register sets the debounce count used for validating an orientation state change. The selected ODR in LPM and HPM modes, and the effective ODR when operating in FPM determine the debounce counter period. Calculate the minimum debounce latency time by ODR<sup>-1</sup> \* **ORIENT\_DBCOUNT**[7:0]. For example, with an ODR of 100 Hz and debounce count value of 10, the new orientation must be maintained for 100 ms before it is recognized as a valid orientation and **ORIENT\_STATUS[**NEW\_ORIENT] is asserted. A transition from Standby to Active, a transition from Active to Standby, or a change in the auto-WAKE/SLEEP mode resets the internal orientation debounce counter.

FXLS8971CI

All information provided in this document is subject to legal disclaimers.

Table 86. ORIENT DBCOUNT register (address 2Ah) bit allocation

|        | _   |                     | 1   | ,   |     |     |     |     |
|--------|-----|---------------------|-----|-----|-----|-----|-----|-----|
| Bit    | 7   | 6                   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name   |     | ORIENT_DBCOUNT[7:0] |     |     |     |     |     |     |
| Reset  | 0   | 0                   | 0   | 0   | 0   | 0   | 0   | 0   |
| Access | R/W | R/W                 | R/W | R/W | R/W | R/W | R/W | R/W |

Table 87. ORIENT\_DBCOUNT register (address 2Ah) bit description

| Field                   | Description                                                                                                                                                                                                                                                              |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 0                  | 8-bit unsigned orientation debounce counter value                                                                                                                                                                                                                        |
| ORIENT_<br>DBCOUNT[7:0] | A new orientation must be maintained for the minimum number of ODR periods specified in order for the orientation to be considered valid before asserting the <b>ORIENT_STATUS[</b> NEW_ORIENT] event flag.  ORIENT_CONFIG[ORIENT_DBCNTM] controls the counter behavior. |
|                         | The selected ODR in LPM and HPM modes and the effective ODR when operating in FPM determines the debounce counter period. Calculate the minimum debounce latency time by:  Debounce_time = (ODR <sup>-1</sup> * ORIENT_DBCOUNT)                                          |
|                         | <b>Note:</b> If the applied acceleration is greater than 1.25 g on any axis, the debounce counter is held at the current value (frozen).                                                                                                                                 |

#### 15.4.4 ORIENT\_BF\_ZCOMP register (address 2Bh)

Orientation back/front and Z-tilt angle compensation register

Table 88. ORIENT BF ZCOMP register (address 2Bh) bit allocation

| Bit    | 7        | 6         | 5            | 4   | 3   | 2   | 1          | 0     |
|--------|----------|-----------|--------------|-----|-----|-----|------------|-------|
| Name   | ORIENT_I | BKFR[1:0] | <del>-</del> |     |     | ORI | ENT_ZLOCK[ | [2:0] |
| Reset  | 0        | 1         | 0            | 0   | 0   | 1   | 0          | 0     |
| Access | R/W      | R/W       | R/W          | R/W | R/W | R/W | R/W        | R/W   |

Table 89. ORIENT\_BF\_ZCOMP register (address 2Bh) bit description

| Field       | Description                                                                                                           |
|-------------|-----------------------------------------------------------------------------------------------------------------------|
| <del></del> | Back-up/Front-up trip angle threshold Default: 01b; Step size is ~5°/ LSB. Range: ±65° to ±80°. Default value of ±75° |
|             | Z-lockout angle threshold<br>Range of ~13° to 44°. Step size is ~4°. Default value of 28.1°                           |

Table 90. ORIENT\_ZLOCK lockout angles

|     | Resultant angle (min) for positions between Landscape and Portrait | Resultant angle (max) for ideal Landscape or Portrait |
|-----|--------------------------------------------------------------------|-------------------------------------------------------|
| 000 | 13.6°                                                              | 14.5°                                                 |
| 001 | 17.1°                                                              | 18.2°                                                 |

(LS8971CF All information provided in this document is subject to legal disclaimers.

Table 90. ORIENT\_ZLOCK lockout angles...continued

| ORIENT_ZLOCK[2:0] | Resultant angle (min) for positions between Landscape and Portrait | Resultant angle (max) for ideal Landscape o<br>Portrait |  |  |
|-------------------|--------------------------------------------------------------------|---------------------------------------------------------|--|--|
| 010               | 20.7°                                                              | 22.0°                                                   |  |  |
| 011               | 24.4°                                                              | 25.9°                                                   |  |  |
| 100               | 28.1°                                                              | 30.0°                                                   |  |  |
| 101               | 32.0°                                                              | 34.2°                                                   |  |  |
| 110               | 36.1°                                                              | 38.7°                                                   |  |  |
| 111               | 40.4°                                                              | 43.4°                                                   |  |  |

Table 91. ORIENT Back/Front orientation transition angle definitions

| BKFR[1:0] | Back-to-Front Transition | Front-to-Back Transition |
|-----------|--------------------------|--------------------------|
| 00        | Z < 80° or Z > 280°      | Z > 100° and Z < 260°    |
| 01        | Z < 75° or Z > 285°      | Z > 105° and Z < 255°    |
| 10        | Z < 70° or Z > 290°      | Z > 110° and Z < 250°    |
| 11        | Z < 65° or Z > 295°      | Z > 115° and Z < 245°    |

## 15.4.5 ORIENT\_THS register (address 2Ch)

Orientation change trip thresholds configuration

Table 92. ORIENT\_THS register (address 2Ch) bit allocation

| Bit    | 7               | 6   | 5   | 4   | 3   | 2               | 1   | 0   |
|--------|-----------------|-----|-----|-----|-----|-----------------|-----|-----|
| Name   | ORIENT_THS[4:0] |     |     |     |     | ORIENT_HYS[2:0] |     |     |
| Reset  | 1               | 0   | 0   | 0   | 0   | 1               | 0   | 0   |
| Access | R/W             | R/W | R/W | R/W | R/W | R/W             | R/W | R/W |

Table 93. Orientation change trip angles look-up table

| ORIENT_THS[4:0] value | Threshold angle (approx.) |
|-----------------------|---------------------------|
| 00h                   | 0.0°                      |
| 01h                   | 1.8°                      |
| 02h                   | 3.8°                      |
| 03h                   | 5.9°                      |
| 04h                   | 8.1°                      |
| 05h                   | 10.5°                     |
| 06h                   | 13.0°                     |
| 07h                   | 15.6°                     |
| 08h                   | 18.4°                     |
| 09h                   | 21.4°                     |
| 0Ah                   | 24.4°                     |

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

Table 93. Orientation change trip angles look-up table...continued

| ORIENT_THS[4:0] value | Threshold angle (approx.) |
|-----------------------|---------------------------|
| 0Bh                   | 27.6°                     |
| 0Ch                   | 31.0°                     |
| 0Dh                   | 34.4°                     |
| 0Eh                   | 37.9°                     |
| 0Fh                   | 41.4°                     |
| 10h                   | 45.0°                     |
| 11h                   | 48.6°                     |
| 12h                   | 52.1°                     |
| 13h                   | 55.6°                     |
| 14h                   | 59.0°                     |
| 15h                   | 62.4°                     |
| 16h                   | 65.6°                     |
| 17h                   | 68.6°                     |
| 18h                   | 71.6°                     |
| 19h                   | 74.4°                     |
| 1Ah                   | 77.0°                     |
| 1Bh                   | 79.5°                     |
| 1Ch                   | 81.9°                     |
| 1Dh                   | 84.1°                     |
| 1Eh                   | 86.2°                     |
| 1Fh                   | 88.2°                     |

Table 94. Resultant trip angle (threshold angle ± hysteresis angle)

| ORIENT_HYS[2:0] | Landscape-to-Portrait trip angle | Portrait-to-Landscape trip angle |
|-----------------|----------------------------------|----------------------------------|
| 0               | 45°                              | 45°                              |
| 1               | 49°                              | 41°                              |
| 2               | 52°                              | 38°                              |
| 3               | 56°                              | 34°                              |
| 4               | 59°                              | 31°                              |
| 5               | 62°                              | 28°                              |
| 6               | 66°                              | 24°                              |
| 7               | 69°                              | 21°                              |

**Note:** In <u>Table 94</u>, the default threshold angle of 45° is considered for calculating the resultant trip angle.

Table 95. Orientation change ideal orientation angle definitions

| Orientation | X/Y axis g-levels |
|-------------|-------------------|
| PU          | y ~ -1 g, x ~ 0   |
| PD          | y ~ +1 g, x ~ 0   |
| LR          | y ~ 0, x ~ +1 g   |
| LL          | y ~ 0, x ~ -1 g   |

# 15.5 Sensor Data Change Detection (SDCD) registers

The Sensor Data Change Detection (SDCD) function is an inertial event detection function available to assist host software algorithms in detecting various inertial events such as motion/no-motion, high-g/low-g, tap/double tap, and transient acceleration events.



#### 15.5.1 SDCD\_INT\_SRC1 register (address 2Dh)

This register contains the SDCD outside-of-thresholds event status flags. If mapped to one of the INT1 or INT2 pins, the OT\_EA flag may be used to signal interrupts to a host processor.

Table 96. SDCD\_INT\_SRC1 register (address 2Dh) bit allocation

| Bit    | 7     | 6 | 5       | 4        | 3       | 2        | 1       | 0        |
|--------|-------|---|---------|----------|---------|----------|---------|----------|
| Name   | OT_EA | _ | X_OT_EF | X_OT_POL | Y_OT_EF | Y_OT_POL | Z_OT_EF | Z_OT_POL |
| Reset  | 0     | 0 | 0       | 0        | 0       | 0        | 0       | 0        |
| Access | R     | R | R       | R        | R       | R        | R       | R        |

FXLS8971CF

Table 97. SDCD INT SRC1 register (address 2Dh) bit description

| Field                           | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>OT_EA                      | SDCD outside-of-thresholds event active flag 0 (default): Event flag has not been asserted; the data for all enabled axes is within the window defined by SDCD_UTHS and SDCD_LTHS registers.                                                                                                                                                                                                           |
|                                 | 1: One or more of the enabled axes sensor data (absolute mode) or deltas (relative mode) sits on or outside of (for example, (data or delta) ≤ SDCD_LTHS or (data or delta) ≥ SDCD_UTHS) the upper or lower thresholds specified in the SDCD_UTHS and SDCD_LTHS registers. The OT_EA flag is set whenever (X_OT_EF   Y_OT_EF   Z_OT_EF) evaluates to true for a number of ODR periods ≥ SDCD_OT_DBCNT. |
|                                 | Notes:                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                 | • The axes selected for participation in the over thresholds condition evaluation are enabled via the X/Y/Z_OT_EN bits in the SDCD_CONFIG1 register. If none of the X/Y/Z_OT_EN bits are set, then the SDCD_OT function is effectively disabled.                                                                                                                                                       |
|                                 | • When SENS_CONFIG4[WAKE_SDCD_OT] = 1, the Auto-WAKE/SLEEP timer is reset on every ODR cycle when the OT_EA flag is asserted (set), which prevents the device from transitioning into SLEEP mode. This flag must be de-asserted (cleared) in order for FXLS8971CF to transition to SLEEP mode.                                                                                                         |
| 5                               | X-axis data or delta-outside-of-upper-and-lower-thresholds event flag; enabled if X_OT_EN = 1                                                                                                                                                                                                                                                                                                          |
| X_OT_EF                         | <ul> <li>0: X-axis data or delta is &lt; SDCD_UTHS value and &gt; SDCD_LTHS value.</li> <li>1: X-axis data or delta is either ≥ SDCD_UTHS value or ≤ SDCD_LTHS value; the X_OT_POL flag may be used to determine which threshold has been met or crossed.</li> </ul>                                                                                                                                   |
| 4                               | X-axis outside-of-thresholds polarity flag                                                                                                                                                                                                                                                                                                                                                             |
| X_OT_POL <sup>[1][2]</sup>      | X-axis data or delta was ≤ lower threshold value     X-axis data or delta was ≥ upper threshold value                                                                                                                                                                                                                                                                                                  |
| 3<br>Y_OT_EF                    | Y-axis data or delta-outside-of-upper-and-lower-thresholds event flag; enabled if Y_OT_EN = 1 0: Y-axis data or delta is < SDCD_UTHS value and > SDCD_LTHS value. 1: Y-axis data or delta is either ≥ SDCD_UTHS value or ≤ SDCD_LTHS value; the Y_OT_POL flag may be used to determine which threshold has been met or crossed.                                                                        |
| 2<br>Y_OT_POL <sup>[1][2]</sup> | Y-axis outside-of-thresholds polarity flag 0: Y-axis data or delta was equal to or below lower threshold value 1: Y-axis data or delta was equal to or above upper threshold value                                                                                                                                                                                                                     |
| 1<br>Z_OT_EF <sup>[1][2]</sup>  | Z-axis data or delta-outside-of-upper-and-lower-thresholds event flag; enabled if Z_OT_EN = 1 0: Z-axis data or delta is < SDCD_UTHS value and > SDCD_LTHS value 1: Z-axis data or delta is either ≥ SDCD_UTHS value or ≤ SDCD_LTHS value; the Z_OT_POL flag may be used to determine which threshold has been met or crossed                                                                          |
| 0<br>Z_OT_POL                   | Z-axis outside-of-thresholds polarity flag 0: Z-axis data or delta was equal to or below lower threshold value 1: Z-axis data or delta was equal to or above upper threshold value                                                                                                                                                                                                                     |

This flag is only meaningful if X/Y/Z\_OT\_EF = 1; their individual states are latched when the X/Y/Z\_OT\_EF flags are set, regardless of the state of SDCD\_ CONFIG1[OT\_ELE].

When SDCD\_CONFIG1[OT\_ELE] = 0, these flags are updated when X/Y/Z\_OT\_EF = 1 and the SDCD\_OT\_DBCNT value is reached.

## 15.5.2 SDCD\_INT\_SRC2 register (address 2Eh)

This register contains the SDCD within-thresholds event status flags. The WT\_EA flag may be used to signal interrupts to a host processor are mapped to one of the INT1 or INT2 pins.

Table 98. SDCD\_INT\_SRC2 register (address 2Eh) bit allocation

| Bit    | 7     | 6 | 5       | 4 | 3       | 2 | 1       | 0 |
|--------|-------|---|---------|---|---------|---|---------|---|
| Name   | WT_EA | _ | X_WT_EF | _ | Y_WT_EF | _ | Z_WT_EF | _ |
| Reset  | 0     | 0 | 0       | 0 | 0       | 0 | 0       | 0 |
| Access | R     | R | R       | R | R       | R | R       | R |

Table 99. SDCD\_INT\_SRC2 register (address 2Eh) bit description

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 7<br>WT_EA   | SDCD within-thresholds event active flag 0 (default): Event flag has not been asserted; none of the input data (absolute mode) or deltas (relative mode) for the enabled axes is within the window defined by the SDCD_UTHS and SDCD_ LTHS registers.                                                                                                                                                                 |  |  |  |  |
|              | 1: All, or at least one of, (depending on the LOGIC function selected in SDCD_CONFIG2[WT_LOG_SEL]) the enabled axes sensor data (absolute mode) or deltas (relative mode) sits within both the upper and lower thresholds specified in the SDCD_UTHS and SDCD_LTHS registers (for example, > SDCD_LTHS, and < SDCD_UTHS). This flag is set whenever the condition is true for a number of ODR cycles ≥ SDCD_WT_DBCNT. |  |  |  |  |
|              | Notes:                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|              | • The axes selected for participation in the within thresholds condition evaluation are enabled via the X/Y/Z_WT_EN bits in the SDCD_CONFIG1 register. The logic mode for the function is set in the SDCD_CONFIG2 register. If none of the X/Y/Z_WT_EN bits are set then the SDCD_WT function is effectively disabled.                                                                                                |  |  |  |  |
|              | • When SENS_CONFIG4[WAKE_SDCD_WT] = 1, the Auto-WAKE/SLEEP timer is reset on every ODR cycle when the WT_EA flag is asserted (set), which prevents the device from transitioning into SLEEP mode. This flag must be de-asserted (cleared) in order for FXLS8971CF to transition to SLEEP mode.                                                                                                                        |  |  |  |  |
| 5<br>X_WT_EF | <ul> <li>X-axis data or delta inside of upper and lower thresholds event flag; This flag is only valid if</li> <li>X_WT_EN = 1:</li> <li>X-axis data or delta is ≥ SDCD_UTHS value or ≤ SDCD_LTHS value.</li> </ul>                                                                                                                                                                                                   |  |  |  |  |
|              |                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|              | 1: X-axis data or delta is < SDCD_UTHS and > SDCD_LTHS value.  Notes:                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|              | • The SDCD_CONFIG1[WT_ELE] bit determines the behavior of this bit. If WT_ELE = 1, the flag is latched when WT_EA goes high, and remains set until it is cleared by reading the SDCD_INT_SRC2 register. If the host wishes to know the state of this event flag, it must be read prior to reading the SDCD_INT_SRC2 register.                                                                                         |  |  |  |  |
|              | • If WT_ELE = 0, the X/Y/Z_WT_EF flags are updated if WT_EA = 1 and the SDCD_WT_DBCNT value is reached. If WT_ELE = 0, the X/Y/Z_WT_EF flags are updated even if WT_EA = 0 when the SDCD_WT_DBCNT value is set to 0.                                                                                                                                                                                                  |  |  |  |  |
| 3<br>Y_WT_EF | Y-axis data or delta inside of upper and lower thresholds event flag; This flag is only valid if Y_WT_EN = 1:                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|              | 0: Y-axis data or delta is ≥ <b>SDCD_UTHS</b> value or ≤ <b>SDCD_LTHS</b> value.                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
|              | 1: Y-axis data or delta is < SDCD_UTHS and > SDCD_LTHS value.                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|              | Notes:  • The SDCD_CONFIG1[WT_ELE] bit determines the behavior of this bit. If WT_ELE = 1, the flag is latched when WT_EA goes high, and remains set until it is cleared by reading the SDCD_INT_SRC2 register. If the host wishes to know the state of this event flag, it must be read prior to reading the SDCD_INT_SRC2 register.                                                                                 |  |  |  |  |
|              | • If WT_ELE = 0, the X/Y/Z_WT_EF flags are updated if WT_EA = 1 and the SDCD_WT_DBCNT value is reached. If WT_ELE = 0, the X/Y/Z_WT_EF flags are updated even if WT_EA = 0 when the SDCD_WT_DBCNT value is set to 0.                                                                                                                                                                                                  |  |  |  |  |

Table 99. SDCD\_INT\_SRC2 register (address 2Eh) bit description...continued

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>Z_WT_EF | Z-axis data or delta inside of upper and lower thresholds event flag; This flag is only valid if Z_WT_EN = 1:  0: Z-axis data or delta is ≥ SDCD_UTHS value or ≤ SDCD_LTHS value.  1: Z-axis data or delta is < SDCD_UTHS and > SDCD_LTHS value.  Notes:  • The SDCD_CONFIG1[WT_ELE] bit determines the behavior of this bit. If WT_ELE = 1, the flag is latched when WT_EA goes high, and remains set until it is cleared by reading the SDCD_INT_SRC2 register. If the host wishes to know the state of this event flag, it must be read prior to reading the SDCD_INT_SRC2 register. |
|              | • If WT_ELE = 0, the X/Y/Z_WT_EF flags are updated if WT_EA = 1 and the SDCD_WT_DBCNT value is reached. If WT_ELE = 0, the X/Y/Z_WT_EF flags are updated even if WT_EA = 0 when the SDCD_WT_DBCNT value is set to 0.                                                                                                                                                                                                                                                                                                                                                                    |

## 15.5.3 SDCD\_CONFIG1 register (address 2Fh)

Table 100. SDCD\_CONFIG1 register (address 2Fh) bit allocation

| Bit                                | 7      | 6      | 5       | 4       | 3       | 2       | 1       | 0       |
|------------------------------------|--------|--------|---------|---------|---------|---------|---------|---------|
| Name                               | OT_ELE | WT_ELE | X_OT_EN | Y_OT_EN | Z_OT_EN | X_WT_EN | Y_WT_EN | Z_WT_EN |
| Reset (BT_MODE = GND)              | 0      | 0      | 0       | 0       | 0       | 0       | 0       | 0       |
| Reset (BT_MODE = V <sub>DD</sub> ) | 0      | 0      | 1       | 1       | 1       | 0       | 0       | 0       |
| Access                             | R/W    | R/W    | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     |

Table 101. SDCD\_CONFIG1 register (address 2Fh) bit description

| Field   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7       | SDCD outside-of-thresholds event latch                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| OT_ELE  | 0 (default): Outside of thresholds event flag latching is disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|         | 1: Outside of thresholds event flag latching is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|         | With outside-of-thresholds event latching enabled, the X/Y/Z_OT_EF flags can only be cleared by reading the <b>SDCD_INT_SRC1</b> register. When OT_ELE is set, the outside-of-thresholds event condition (OT_EA) flag is only asserted when the event condition transitions from False to True. For example, once the OT_EA flag is set, the event condition must become False before a subsequent True event is recognized. With outside-of-thresholds event latching disabled, the X/Y/Z_OT_EF flags are updated in real time and may be cleared by the function prior to the host system reading <b>SDCD_INT_SRC1</b> if the event condition becomes false before the read occurs. |
| 6       | SDCD within-thresholds event latch                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| WT_ELE  | 0 (default): Within thresholds event flag latching is disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|         | 1: Within thresholds event flag latching is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|         | With within-thresholds event latching enabled, the X/Y/Z_WT_EF flags can only be cleared by reading the SDCD_INT_SRC2 register. When within-thresholds event latching is disabled, the X/Y/Z_WT_EF flags are updated in real time and may be cleared by the function prior to the host system reading the SDCD_INT_SRC2 register, if the event condition becomes false before the read occurs. When WT_ELE is set, the within-thresholds event condition (WT_EA) flag is only asserted when the event condition transitions from False to True. For example, once the WT_EA flag is set, the event condition must become False before a subsequent True event will be recognized      |
| 5       | SDCD function X-axis outside-of-thresholds condition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| X_OT_EN | 0: X-axis data or delta is not used in the outside of thresholds condition evaluation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|         | 1: X-axis data or delta is used in the outside of thresholds condition evaluation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

FXLS8971CF

Table 101. SDCD CONFIG1 register (address 2Fh) bit description...continued

| Field   | Description                                                                            |
|---------|----------------------------------------------------------------------------------------|
| 4       | SDCD function Y-axis outside-of-thresholds condition                                   |
| Y_OT_EN | 0: Y-axis data or delta is not used in the outside of thresholds condition evaluation. |
|         | 1: Y-axis data or delta is used in the outside of thresholds condition evaluation.     |
| 3       | SDCD function Z-axis outside-of-thresholds condition                                   |
| Z_OT_EN | 0: Z-axis data or delta is not used in the outside of thresholds condition evaluation. |
|         | 1: Z-axis data or delta is used in the outside of thresholds condition evaluation.     |
| 2       | SDCD function X-axis within-thresholds condition                                       |
| X_WT_EN | 0: X-axis data or delta is not used in the within thresholds condition evaluation.     |
|         | 1: X-axis data or delta is used in the within thresholds condition evaluation.         |
| 1       | SDCD function Y-axis within-thresholds condition                                       |
| Y_WT_EN | 0: Y-axis data or delta is not used in the within thresholds condition evaluation.     |
|         | 1: Y-axis data or delta is used in the within thresholds condition evaluation.         |
| 0       | SDCD function Z-axis within-thresholds condition                                       |
| Z_WT_EN | 0: Z-axis data or delta is not used in the within thresholds condition evaluation.     |
|         | 1: Z-axis data or delta is used in the within thresholds condition evaluation.         |

# 15.5.4 SDCD\_CONFIG2 register (address 30h)

Table 102. SDCD\_CONFIG2 register (address 30h) bit allocation

| Bit                                | 7       | 6             | 5   | 4            | 3            | 2              | 1    | 0       |
|------------------------------------|---------|---------------|-----|--------------|--------------|----------------|------|---------|
| Name                               | SDCD_EN | REF_UPDM[1:0] |     | OT_<br>DBCTM | WT_<br>DBCTM | WT_<br>LOG_SEL | MODE | REF_UPD |
| Reset (BT_MODE = GND)              | 0       | 0             | 0   | 0            | 0            | 0              | 0    | 0       |
| Reset (BT_MODE = V <sub>DD</sub> ) | 1       | 1             | 0   | 1            | 1            | 0              | 0    | 0       |
| Access                             | R/W     | R/W           | R/W | R/W          | R/W          | R/W            | R/W  | R/W     |

Table 103. SDCD\_CONFIG2 register (address 30h) bit description

| Field    | Description                                                                                                                                                                                                                                                                                                                                                     |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7        | SDCD function                                                                                                                                                                                                                                                                                                                                                   |
| SDCD_EN  | 0 (default after a POR or soft reset event when BT_MODE = GND): SDCD function is disabled. All clocks and power for the function are turned off.                                                                                                                                                                                                                |
|          | 1 (default after a POR or soft reset event when BT_MODE = $V_{DD}$ and MOT_DET = 1): SDCD function is enabled. When this bit is set, the 12-bit reference values ( <b>REF_X/Y/Z</b> ) are initialized per the settings made in REF_UPDM[1:0].                                                                                                                   |
| 6 to 5   | SDCD internal reference values update mode                                                                                                                                                                                                                                                                                                                      |
| REF_UPDM | 00b: The function stores the first 12-bit X/Y/Z decimated and trimmed input data (OUT_X/Y/Z[n=0]) as the internal REF_X/Y/Z values after the function is enabled (SDCD_EN is set to 1). The REF_X/Y/Z values are updated with the current 12-bit X/Y/Z decimated input data (OUT_X/Y/Z[n]) whenever the SDCD_OT_EA flag is true.                                |
|          | 01b: The function stores the first decimated and trimmed X/Y/Z acceleration input data (OUT_X/Y/Z[n=0]) as the internal REF_X/Y/Z values when the SDCD function is enabled; the REF_X/Y/Z values are then held constant and never updated until the SDCD function is disabled and subsequently reenabled, or asynchronously when the host sets the REF_UPD bit. |

Table 103. SDCD\_CONFIG2 register (address 30h) bit description...continued

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|            | 10b: The function updates the SDCD_REF_X/Y/Z values with the current decimated and trimmed X/Y/Z acceleration input data after the function evaluation. This operation allows for acceleration slope detection with Data(n) to Data(n–1) always used as the input to the window comparator.  11b: The function uses a fixed value of 0 for each of the SDCD_REF_X/Y/Z registers, making the function operate in absolute comparison mode.                                          |  |  |  |  |  |  |  |
| 4          | SDCD outside-of-threshold event debounce counter behavior                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
| OT_DBCTM   | 0 (default): Debounce counter decrements by 1 when the current outside of thresholds result for the enabled axes is false. In this mode, the debounce counter de-bounces the outside of thresholds event in both directions, meaning that once the event flag has been set (after SDCD_OT_DBCNT ODR periods with the condition true), the condition must also remain false for at least SDCD_OT_DBCNT + 1 consecutive ODR periods before the next event detection cycle can begin. |  |  |  |  |  |  |  |
|            | 1: Debounce counter is cleared whenever the current outside of thresholds result for the enabled axes is false.                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
| 3          | SDCD within-thresholds event debounce counter behavior                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
| WT_DBCTM   | 0 (default): Debounce counter decrements by 1 when the current within thresholds result for the enabled axes is false. In this mode, the debounce counter de-bounces the event in both directions, meaning that once the event flag has been set (after SDCD_WT_DBCNT ODR periods with the condition true), the condition must also remain false for at least SDCD_WT_DBCNT + 1 consecutive ODR periods before the next event detection cycle can begin.                           |  |  |  |  |  |  |  |
|            | 1: Debounce counter is cleared whenever the SDCD within thresholds result for the enabled axes is false.                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |
| 2          | SDCD within-thresholds event logic selection                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |
| WT_LOG_SEL | 0 (default): Function uses the logical AND of the enabled axes.                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
|            | 1: Function uses the logical OR of the enabled axes.                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
| 1          | SDCD input data mode                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
| MODE       | 0 (default): Function uses X, Y, Z acceleration data for the window comparison.                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
|            | 1: Function uses Vector magnitude data for the window comparison on the X-axis channel only; all other SDCD channels are disabled and ignored by the function.                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |
|            | <b>Note:</b> The SENS_CONFIG5[VECM_EN] bit must also be set in order for the SDCD function to operate correctly when MODE is set to 1.                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
| 0          | SDCD synchronous X/Y/Z reference values update bit                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |
| REF_UPD    | 0: No reference update pending or reference update has completed.                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |
|            | 1: Triggers a synchronous update of the internal X/Y/Z reference registers.                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
|            | When the REF_UPD bit is set, it forces a synchronous update of the internal REF_X/Y/Z registers. If REF_UPDM[1:0] = 11b (absolute mode), no update occurs and the REF_X/Y/Z values remain fixed at 000h. The actual update of the internal reference values with the X/Y/Z acceleration data may be delayed by up to 1 ODR period after this bit is set. See Figure 21 for further details.  Notes:                                                                                |  |  |  |  |  |  |  |
|            | <ul> <li>This bit is self-cleared after the REF_X/Y/Z registers are updated. The host may not be able to observe a value of '1' as the operation can complete before the next l<sup>2</sup>C or SPI read cycle occurs.</li> <li>This bit can be written at any time in either Active or Standby mode.</li> </ul>                                                                                                                                                                   |  |  |  |  |  |  |  |



### 15.5.5 SDCD\_OT\_DBCNT register (address 31h)

Debounce count threshold register for SDCD outside-of-thresholds condition event detection.

The timer count period is equal to the selected ODR period in LPM and HPM modes, and to the effective ODR period (measurement + idle time) in FPM.

This register sets the minimum number of debounce counts needed to recognize the SDCD outside-of-threshold function event condition as true.

A transition from Standby to Active, Active to Standby, or Auto-WAKE/SLEEP mode change resets the internal counter.

Table 104. SDCD\_OT\_DBCNT register (address 31h) bit allocation

| able 104. Obob_01_bbotti register (addition of in) bit allocation |     |                    |     |     |     |     |     |     |
|-------------------------------------------------------------------|-----|--------------------|-----|-----|-----|-----|-----|-----|
| Bit                                                               | 7   | 6                  | 5   | 4   | 3   | 2   | 1   | 0   |
| Name                                                              |     | SDCD_OT_DBCNT[7:0] |     |     |     |     |     |     |
| Reset (BT_MODE = GND)                                             | 0   | 0                  | 0   | 0   | 0   | 0   | 0   | 0   |
| Reset (BT_MODE = V <sub>DD</sub> )                                | 0   | 0                  | 0   | 0   | 0   | 0   | 0   | 0   |
| Access                                                            | R/W | R/W                | R/W | R/W | R/W | R/W | R/W | R/W |

Table 105. SDCD\_OT\_DBCNT register (address 31h) bit description

| Field                            | Description                                                                                                                                                                                                                                                                                                                         |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 0<br>SDCD_OT_<br>DBCNT[7:0] | This value defines the minimum number of debounce counts required for the detection of an outside-of-thresholds condition. The OT_DBCNTM bit determines the behavior of the counter when the condition of interest is false. The time step for the counter is the same as the selected ODR period (or effective ODR period in FPM). |

### 15.5.6 SDCD\_WT\_DBCNT register (address 32h)

Debounce count threshold register for SDCD within-thresholds condition event detection.

The timer count period is equal to the selected ODR period in LPM and HPM modes, and to the effective ODR period (measurement + idle time) in FPM.

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

This register sets the minimum number of debounce counts needed to recognize the SDCD within-threshold condition as true.

A transition from Standby to Active, Active to Standby, or a change in an Auto-WAKE/SLEEP mode change resets the internal counter.

Table 106. SDCD\_WT\_DBCNT register (address 32h) bit allocation

| Bit                                | 7   | 6                  | 5   | 4   | 3   | 2   | 1   | 0   |
|------------------------------------|-----|--------------------|-----|-----|-----|-----|-----|-----|
| Name                               |     | SDCD_WT_DBCNT[7:0] |     |     |     |     |     |     |
| Reset (BT_MODE = GND)              | 0   | 0                  | 0   | 0   | 0   | 0   | 0   | 0   |
| Reset (BT_MODE = V <sub>DD</sub> ) | 0   | 0                  | 0   | 0   | 0   | 0   | 0   | 0   |
| Access                             | R/W | R/W                | R/W | R/W | R/W | R/W | R/W | R/W |

Table 107. SDCD\_WT\_DBCNT register (address 32h) bit description

| Field | Description                                                                                                                                                                                                                                                                                                                                                    |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | The SDCD_WT_DBCNT value defines the minimum number of debounce sample counts required for the detection of an SDCD_WT condition event. The WT_DBCNTM bit determines the behavior of the counter when the condition of interest is momentarily not true. The time step for the counter is the same as the selected ODR period (or effective ODR period in FPM). |

#### 15.5.7 SDCD\_LTHS\_LSB register (address 33h)

Sensor Data Change Detection function 12-bit 2's complement lower threshold least significant byte. **SDCD\_LTHS[**11:0**]** must always be set to a lower value than **SDCD\_UTHS[**11:0**]** to ensure that the SDCD circuit functions correctly and produces meaningful results.

The scaling for this register is always the same as the selected FSR sensitivity. See <u>Section 9</u> for the sensitivity values corresponding to each of the selectable FSRs.

Table 108. SDCD\_LTHS\_LSB register (address 33h) bit allocation

| Bit                                | 7   | 6              | 5   | 4   | 3   | 2   | 1   | 0   |
|------------------------------------|-----|----------------|-----|-----|-----|-----|-----|-----|
| Name                               |     | SDCD_LTHS[7:0] |     |     |     |     |     |     |
| Reset (BT_MODE = GND)              | 0   | 0              | 0   | 0   | 0   | 0   | 0   | 0   |
| Reset (BT_MODE = V <sub>DD</sub> ) | 1   | 1              | 0   | 0   | 0   | 0   | 0   | 0   |
| Access                             | R/W | R/W            | R/W | R/W | R/W | R/W | R/W | R/W |

Table 109. SDCD\_LTHS\_LSB register (address 33h) bit description

| Field          | Description                                                    |
|----------------|----------------------------------------------------------------|
| 7 to 0         | LSB of the signed 12-bit 2's complement lower threshold value. |
| SDCD_LTHS[7:0] |                                                                |

### 15.5.8 SDCD\_LTHS\_MSB register (address 34h)

Sensor Data Change Detection function 12-bit 2's complement lower threshold most significant byte (nibble). **SDCD\_LTHS[**11:0**]** must always be set to a lower value than **SDCD\_UTHS[**11:0**]** to ensure that the SDCD circuit functions correctly and produces meaningful results.

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

The scaling for this register is always the same as the selected FSR sensitivity. See <u>Section 9</u> for the sensitivity values corresponding to each of the selectable FSRs.

Table 110. SDCD\_LTHS\_MSB register (address 34h) bit allocation

| Bit                                | 7   | 6   | 5   | 4   | 3               | 2   | 1   | 0   |
|------------------------------------|-----|-----|-----|-----|-----------------|-----|-----|-----|
| Name                               | _   | _   | _   | _   | SDCD_LTHS[11:8] |     |     |     |
| Reset (BT_MODE = GND)              | 0   | 0   | 0   | 0   | 0               | 0   | 0   | 0   |
| Reset (BT_MODE = V <sub>DD</sub> ) | 0   | 0   | 0   | 0   | 1               | 1   | 1   | 1   |
| Access                             | R/W | R/W | R/W | R/W | R/W             | R/W | R/W | R/W |

Table 111. SDCD\_LTHS\_MSB register (address 34h) bit description

| Field           | Description                                                            |
|-----------------|------------------------------------------------------------------------|
| 3 to 0          | MSB (nibble) of the signed 12-bit 2's complement lower-threshold value |
| SDCD_LTHS[11:8] |                                                                        |

#### 15.5.9 SDCD UTHS LSB register (address 35h)

Sensor Data Change Detection function 12-bit 2's complement upper-threshold least significant byte. **SDCD\_UTHS[**11:0**]** must always be set to a higher value than **SDCD\_LTHS[**11:0**]** to ensure that the SDCD circuit functions correctly and produces meaningful results.

The scaling for this register is the same as the selected FSR sensitivity. See <u>Section 9</u> for the sensitivity values corresponding to each of the selectable FSRs.

Table 112. SDCD\_UTHS\_LSB register (address 35h) bit allocation

| Bit                                | 7   | 6              | 5   | 4   | 3   | 2   | 1   | 0   |
|------------------------------------|-----|----------------|-----|-----|-----|-----|-----|-----|
| Name                               |     | SDCD_UTHS[7:0] |     |     |     |     |     |     |
| Reset (BT_MODE = GND)              | 0   | 0              | 0   | 0   | 0   | 0   | 0   | 0   |
| Reset (BT_MODE = V <sub>DD</sub> ) | 0   | 1              | 0   | 0   | 0   | 0   | 0   | 0   |
| Access                             | R/W | R/W            | R/W | R/W | R/W | R/W | R/W | R/W |

Table 113. SDCD\_UTHS\_LSB register (address 35h) bit description

|                | ==                                                            |
|----------------|---------------------------------------------------------------|
| Field          | Description                                                   |
| 7 to 0         | LSB of the signed 12 bit 2's complement upper-threshold value |
| SDCD_UTHS[7:0] |                                                               |

### 15.5.10 SDCD\_UTHS\_MSB register (address 36h)

Sensor Data Change Detection function 12-bit 2's complement upper-threshold most-significant byte (nibble). **SDCD\_UTHS[**11:0**]** must always be set to a higher value than **SDCD\_LTHS[**11:0**]** to ensure that the SDCD circuit functions correctly and produces meaningful results.

The scaling for this register is always the same as the selected FSR sensitivity. See <u>Section 9</u> for the sensitivity values corresponding to each of the selectable FSRs.

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

Table 114. SDCD UTHS MSB register (address 36h) bit allocation

| Bit                                | 7   | 6   | 5   | 4   | 3               | 2   | 1   | 0   |
|------------------------------------|-----|-----|-----|-----|-----------------|-----|-----|-----|
| Name                               | _   | _   | _   | _   | SDCD_UTHS[11:8] |     |     |     |
| Reset (BT_MODE = GND)              | 0   | 0   | 0   | 0   | 0               | 0   | 0   | 0   |
| Reset (BT_MODE = V <sub>DD</sub> ) | 0   | 0   | 0   | 0   | 0               | 0   | 0   | 0   |
| Access                             | R/W | R/W | R/W | R/W | R/W             | R/W | R/W | R/W |

#### Table 115. SDCD\_UTHS\_MSB register (address 36h) bit description

| Field           | Description                                                            |
|-----------------|------------------------------------------------------------------------|
| 3 to 0          | MSB (nibble) of the signed 12-bit 2's complement upper-threshold value |
| SDCD_UTHS[11:8] |                                                                        |

### 15.6 Self-test configuration registers

### 15.6.1 SELF\_TEST\_CONFIG1 register (address 37h)

Table 116. SELF TEST CONFIG1 register (address 37h) bit allocation

|        |     |     | •   | ,   |     |              |     |     |
|--------|-----|-----|-----|-----|-----|--------------|-----|-----|
| Bit    | 7   | 6   | 5   | 4   | 3   | 2            | 1   | 0   |
| Name   | _   | _   | _   |     |     | ST_IDLE[4:0] |     |     |
| Reset  | 0   | 0   | 0   | 0   | 0   | 0            | 0   | 0   |
| Access | R/W | R/W | R/W | R/W | R/W | R/W          | R/W | R/W |

### Table 117. SELF\_TEST\_CONFIG1 register (address 37h) bit description

| Field             | Description                                                                                                                        |     |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------|-----|
| 4 to 0<br>ST_IDLE | Self-Test Idle phase duration: The value contained in ST_IDLE determines the Self-Test Idle phase duration per <u>Equation 3</u> . |     |
|                   | $ST_{IDLE}$ (µs) = 312.5+ (ST_IDLE[4:0]×31.25)                                                                                     | (3) |

### 15.6.2 SELF\_TEST\_CONFIG2 register (address 38h)

### Table 118. SELF\_TEST\_CONFIG2 register (address 38h) bit allocation

| Bit    | 7   | 6   | 5   | 4   | 3   | 2     | 1      | 0   |
|--------|-----|-----|-----|-----|-----|-------|--------|-----|
| Name   | _   | _   | _   | _   |     | ST_DE | C[3:0] |     |
| Reset  | 0   | 0   | 0   | 0   | 0   | 0     | 0      | 0   |
| Access | R/W | R/W | R/W | R/W | R/W | R/W   | R/W    | R/W |

### Table 119. SELF\_TEST\_CONFIG2 register (address 38h) bit description

| Field  | Description                                   |
|--------|-----------------------------------------------|
| 3 to 0 | Self-Test measurement phase decimation factor |

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

Table 119. SELF\_TEST\_CONFIG2 register (address 38h) bit description

| Field  | Description                                                                   |
|--------|-------------------------------------------------------------------------------|
| ST_DEC | This bit field selects the Self-Test measurement phase decimation factor.     |
|        | The decimation selection ranges from 1 to 4096 as shown in <u>Table 120</u> . |

Table 120. Self-Test measurement phase decimation settings

| ST_DEC[3] | ST_DEC[2] | ST_DEC[1] | ST_DEC[0] | Decimation<br>selection<br>(Number of<br>samples | Self-Test<br>measurement<br>period<br>(ms) | Self-Test ODR<br>(Hz) |
|-----------|-----------|-----------|-----------|--------------------------------------------------|--------------------------------------------|-----------------------|
| 0         | 0         | 0         | 0         | 1                                                | 0.3125                                     | 3200                  |
| 0         | 0         | 0         | 1         | 2                                                | 0.625                                      | 1600                  |
| 0         | 0         | 1         | 0         | 4                                                | 1.25                                       | 800                   |
| 0         | 0         | 1         | 1         | 8                                                | 2.5                                        | 400                   |
| 0         | 1         | 0         | 0         | 16                                               | 5                                          | 200                   |
| 0         | 1         | 0         | 1         | 32                                               | 10                                         | 100                   |
| 0         | 1         | 1         | 0         | 64                                               | 20                                         | 50                    |
| 0         | 1         | 1         | 1         | 128                                              | 40                                         | 25                    |
| 1         | 0         | 0         | 0         | 256                                              | 80                                         | 12.5                  |
| 1         | 0         | 0         | 1         | 512                                              | 160                                        | 6.25                  |
| 1         | 0         | 1         | 0         | 1024                                             | 320                                        | 3.125                 |
| 1         | 0         | 1         | 1         | 2048                                             | 640                                        | 1.563                 |
| 1         | 1         | 0         | 0         | 4096                                             | 1280                                       | 0.78125               |
| 1         | 1         | 0         | 1         | 4096                                             | 1280                                       | 0.78                  |
| 1         | 1         | 1         | 0         | 4096                                             | 1280                                       | 0.781                 |
| 1         | 1         | 1         | 1         | 4096                                             | 1280                                       | 0.781                 |

#### Notes:

• During the self-test sequence, the accelerometer measurement period in μs (for each axis and each direction) is given by Equation 4.

$$ST_{PERIOD}$$
 (µs)=  $2^{ST\_DEC[30]} \times [312.5 + (ST\_IDLE[4:0] \times 31.25)]$  (4)

• The user-selected ODR and power mode settings are ignored during self-test operation. The user-selected settings for ODR and power mode are applied after self-test is disengaged, for example, SENSCONFIG1[...]ST\_AXIS\_SEL[1:0] = 00b.

## 16 Application information

### 16.1 System connections

FXLS8971CF connects to a host processor through an I<sup>2</sup>C or SPI interface. <u>Figure 22</u> to <u>Figure 27</u> show the recommended circuit connections.

### 16.2 Recommendation for reading data registers

When operating in active mode the sensor stores the acceleration measurement in the associated LSB and MSB Data registers. Assuming Fast Mode Read is not used, it is important to ensure the coherency between MSB and LSB data bytes for a given axis when the host MCU reads those two registers, in order words, they both need to correspond to the same measurement sample.

As mentioned in the registers description, the output data is latched into the OUT\_X/Y/Z registers along with the assertion of the SRC\_DRDY event flag. Moreover, when the host MCU initiates a data register read transaction on the secondary interface (Start condition in I<sup>2</sup>C mode or SPI\_CS transition to low level in SPI mode), the content of all data registers is locked till the transaction is completed. There are actually shadow registers to prevent that data registers are updated when a new sample becomes available.

If the MCU performs single byte read transactions, the coherency between MSB and LSB data bytes cannot be granted as they will be associated to two distinct transactions. Consequently it is highly recommended to use multiple bytes for data reading, in order to at least collect both MSB and LSB data bytes with a unique read transaction. Obviously, the MCU can collect all three axes data simultaneously (6 bytes) with a multiple bytes data reading, and this will also ensure that the XYZ data triplet corresponds to the same timestamp.

**Note:** This constraint is mostly valid for asynchronous data reading. It is quite lightened if the host MCU configures the sensor data ready interrupt to perform synchronous (interrupt driven) data reading, as this provides an adequate trigger to read the samples. The synchronous reading scheme is also recommended to avoid unnecessary traffic on the secondary interface, such as polling status registers.

Those considerations applies to normal Data output registers OUT\_X/Y/Z, but also to BUFF\_X/Y/Z registers and VECM registers.

### 16.3 Typical application circuits

X7R or X5R ceramic capacitors are recommended for  $V_{DD}$  supply decoupling. A 1  $\mu$ F capacitor in parallel with a 0.1  $\mu$ F is recommended as a starting point per the NXP EMC test standard. These capacitors should be placed as close to the  $V_{DD}$  supply pin as practical. The values of the capacitors can be changed to suit the EMC performance requirements of the application.



Notes:

All information provided in this document is subject to legal disclaimers.

- Resistors R1 and R2 are not needed if the interrupt output driver type is configured for push-pull operation (default). In order to avoid their residual current consumption in default state (no interrupt asserted), NXP recommends connecting them either to GND or VDD according to INT\_POL choice (1 or 0 respectively).
- If either the INT1 or INT2 pins are not used in the application, leave them unconnected.
- The required pull-up resistor values for R3 and R4 are dependent on several factors including the I<sup>2</sup>C clock frequency, bus pull-up voltage, and the total parasitic trace + device capacitances. A suggested starting point is 4.7 kΩ for Standard and Fast modes.
- The external trigger function can be used to initiate a single shot measurement of the XYZ acceleration and temperature data. This mode is useful for synchronizing measurements with an external system or for creating user-specific ODRs. The measurement is triggered on the rising edge of the EXT\_TRIG signal.







#### Notes:

All information provided in this document is subject to legal disclaimers

- The external trigger function can be used to trigger a single shot measurement of the XYZ acceleration and temperature data. This mode is useful for synchronizing measurements with an external system or for creating user-specific ODRs. The measurement is triggered on the rising edge of the EXT\_TRIG signal.
- Resistors R1 and R2 are not needed if the interrupt output driver type is configured for push-pull operation (default). A suggested range for open-drain configuration is 10 k $\Omega$  to 100 k $\Omega$ .
- If the INT1 pin, INT2 pin, or both pins are not used in the application, leave the unused pins unconnected.
- The SPI CS B pin also serves as a signal to wake the device from Hibernate mode.
- See Section 13.2 and Section 13.4 for more details on 3-wire SPI mode.





Figure 27. Typical Application Circuit #6 - Motion detection mode (with SPI 3-wire interface, software enabled)

#### Notes:

- External resistor R2 is not needed if the BOOT\_OUT and MOT\_DET pins are tied together (wired AND configuration).
- A suggested pull-up resistance range is 1 M $\Omega$  to 2.5 M $\Omega$  for both R1 and R2 to minimize the power dissipated in the resistor when the line is pulsed low. When BT MODE is set to  $V_{DD}$  (enabling motion detection mode), both the MOT DET and BOOT OUT pins become open-drain output driver types. MOT DET also functions as a CMOS input and is used by the host system to power-manage FXLS8971CF.
- When BT MODE = V<sub>DD</sub>, the default motion detection parameters are automatically loaded into the device after a POR/BOR event occurs; no configuration via I<sup>2</sup>C or SPI is needed if the default parameters are used in the application.
- See Section 13.2 and Section 13.4 for more details on 3-wire SPI mode. In motion detection mode with BT MODE=V<sub>DD</sub>, use of HPM or FPM mode is not advised. Only the default LPM mode should be used.

FXLS8971CF

### 16.4 Power supply considerations

NXP recommends that  $V_{DD}$  be sourced from a low noise linear supply regulator (LDO). When using a switch mode supply, the recommended minimum voltage is 1.8 V (nominal), providing headroom for supply noise and ripple rejection. This headroom ensures that the device meets its performance specifications while also preventing a BOR/POR event from occurring when operated on a noisy supply rail.

FXLS8971CF contains a POR generator. This circuit resets the digital logic and restores all register content to the default values shown in <u>Table 20</u> after applying  $V_{DD} \ge 1.71 \text{ V}$ , or after a soft reset command is issued by setting **SENS\_CONFIG1[**RST**]** = 1.

**Note:** The host system must wait for a nominal time period of  $T_{BOOT1/2}$  ms after applying  $V_{DD} \ge 1.71$  V, or after issuing a soft reset command, to allow enough time for FXLS8971CF to complete its internal boot sequence and be ready for communication over the  $I^2$ C or SPI interfaces.

When the BT\_MODE pin is low, with **INT\_EN[**BOOT\_DIS**]** = 0, the host system can wait until the active edge of a  $T_{PULSE-BOOT_1}$  µs pulse is observed on the INTx pin (determined by **INT\_PIN\_SEL[**BOOT\_INT2**]**) indicating completion of the boot sequence. When the BT\_MODE pin is logic high, the INT2 pin is configured as an opendrain output (BOOT\_OUT) that pulses low for  $T_{PULSE-BOOT_2}$  ms after the boot sequence completes.

## 17 Package outline

The FXLS8971CF uses a twelve-pin QFN package, case number 98ASA01979D.

### 17.1 Package description





PQFN-12 I/O STEP-CUT WETTABLE FLANK 3 X 3 X 1.25 PKG, 0.65 PITCH

SOT2197-1(SC)

#### NOTES:

- 1. ALL DIMENSIONS ARE IN MILLIMETERS.
- 2. DIMENSIONING AND TOLERANCING PER ASME Y14.5M-1994.

3. PIN 1 FEATURE SHAPE, SIZE AND LOCATION MAY VARY.

4. COPLANARITY APPLIES TO LEADS AND DIE ATTACH FLAG.

5. MIN. METAL GAP FOR LEAD TO EXPOSED PAD SHALL BE 0.2 MM.

© NXP B.V. ALL RIGHTS RESERVED

DATE: 17 JAN 2024

| MECHANICAL OUTLINE         | STANDARD: | DRAWING NUMBER: | REVISION: |  |
|----------------------------|-----------|-----------------|-----------|--|
| PRINT VERSION NOT TO SCALE | NON-JEDEC | 98ASA01979D     | В         |  |

Figure 30. FXLS8971CF package outline notes

### 17.2 Burr specification

The assembly site specifies burrs to 0.076 mm maximum.

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

## 18 Soldering information

### 18.1 Printed circuit board layout and device mounting

Printed circuit board (PCB) layout and device mounting are critical to the overall performance of the design. The footprint for the surface mount packages must be the correct size as a base for a proper solder connection between the PCB and the package. The correct size of the surface mount package footprint, along with the recommended soldering materials and techniques, optimize assembly and minimize the stress on the package after board mounting.

NXP application note AN1902<sup>[1]</sup> discusses the QFN package used by the FXLS8971CF.

### 18.1.1 Overview of soldering considerations

The information provided here is based on experiments executed on QFN devices. They do not represent exact conditions present at a customer site. Therefore, information herein should be used as guidance only, and process and design optimizations are recommended to develop an application-specific solution. It should be noted that with the proper PCB footprint and solder stencil designs, the package self-aligns during the solder reflow process.

### 18.1.2 Halogen content

This package is Halogen free, exceeding most industry and customer standards. Halogen Free means that no homogeneous material within the assembly package shall contain chlorine (CI) in excess of 700 ppm or 0.07 % weight/weight or bromine (Br) in excess of 900 ppm or 0.09 % weight/weight.

## 19 Mounting information

### 19.1 PCB mounting recommendations

- No additional via, copper layer, solder mask, metal pattern underneath package on the mounted layer of the PCB.
- Do not place any components or vias within 2 mm of the package land area as it may cause additional package stress if placed too close to the package land area.
- Signal traces connected to pads should be as symmetric as possible. To have the same length of exposed trace for all pads, put dummy traces on NC pads .
- Use a standard pick-and-place process and equipment. Do not use a hand soldering process.
- Customers are advised to be cautious about the proximity of screw-down holes to the sensor, and the location of any press fit to the assembled PCB when in an enclosure. It is important that the assembled PCB remain flat after assembly to keep electronic operation of the device optimal.
- The PCB should be rated for the multiple lead-free reflow condition with a maximum 260 °C temperature.
- NXP sensors are compliant with Restrictions on Hazardous Substances (RoHS), having halide-free molding compound (green) and lead-free terminations. These terminations are compatible with tin-lead (Sn-Pb) as well as tin-silver-copper (Sn-Ag-Cu) solder paste soldering processes. Reflow profiles applicable to those processes can be used successfully for soldering the devices.

FXLS8971CI



FXLS8971CF



FXLS8971CF



#### Note:

To achieve optimum sensor performance over Temperature, it is important that no solder flux residues got trapped between the PCB and the bottom of the sensor package.

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

A proper flux cleaning process is desirable after reflow soldering.

Cleaning effectiveness can be facilitated by maximizing the gap between sensor and PCB. This is achieved by removing any copper trace and Solder mask under sensor package, as well as using a thick solder paste stencil.

## 20 Glossary

Table 121. Glossary

| Term                                                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Cross-axis sensitivity                                           | Cross-axis sensitivity is the ratio of the measured acceleration for an axis to the input acceleration along each axis orthogonal to the measured axis. Cross-axis sensitivity leads to undesirable nonorthogonality of X, Y, and Z axes in the frame of reference of the assembled device when mapping to other frames of reference. Cross-axis sensitivity is expressed as a percentage of the orthogonal input acceleration with six separate cross-axis sensitivity terms known as Sxy, Sxz, Syx, Syz, Szx, and Szy.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Noise density and RMS-<br>integrated noise                       | Noise density is defined as the noise per unit of square root bandwidth and is typically expressed in units of $mg/\sqrt{Hz}$ or $\mu g/\sqrt{Hz}$ for a consumer grade accelerometer. Noise is measured with the device held stationary in a 1 $g$ field and isolated from environmental noise and mechanical vibration. The RMS noise at a given ODR can be estimated as follows: $N_{rms} = ND * \sqrt{BW}$ For example, in the ±2 $g$ FSR, operating in HPM with an ODR of 400 Hz, the estimated RMS noise would be: $N_{rms} = 230 \ \mu g/\sqrt{Hz} * \sqrt{(400/2)} \ Hz = 3.25 \ mg (~ 3.3 \ LSB)$ .                                                                                                                                                                                                                                                                                                                                                   |
| Output data rate,<br>decimation factor, and<br>power consumption | The Output Data Rate (ODR) defines the rate at which acceleration data is output from FXLS8971CF. Depending on the operating mode and ODR that is selected, different decimation factors (oversampling ratios) are applied. The decimated output data is supplied at the ODR rate, even though multiple samples of the sensor data may have been used to calculate this average result. In FXLS8971CF lowest power mode, the decimation factor is always 1, leading to the best power performance at the expense of the poorest noise (resolution) performance. In high performance mode, the decimation factor is automatically increased to the maximum possible value for a given ODR, resulting in the best noise (resolution) performance at the expense of the poorest power consumption. In motion detection mode with BT_MODE=V <sub>DD</sub> , use of HPM or FPM mode is not advised. Only the default LPM mode should be used.                       |
| Primary                                                          | Device that initiates and drives the communication with secondary devices.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Secondary                                                        | Device or devices that responds to communication initiated by primary device.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Self-Test                                                        | The integrated self-test function can be used to verify correct transducer and signal chain operation without the need to apply an external acceleration stimulus. When the self-test function is activated for each axis, an electrostatic actuation force is applied to the proof mass, simulating a small change in acceleration. The self-test function of the device is independently exercisable for each axis, along with a selectable displacement direction (polarity). The device need not be static while exercising the self-test function as it is insensitive to any external physical acceleration. During a self-test sequence, 2 parameters are computed for each axis, namely STOC and STOF. STOC is the half difference between Self-Test output for positive direction (ST_POL=0) and Self-Test output for negative direction (ST_POL=1), whereas STOF is the half sum between the same Pafer to ANI3103[2] for more details on self-test. |
|                                                                  | is the half sum between the same. Refer to AN13193 <sup>[2]</sup> for more details on self-test.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Sensitivity                                                      | The accelerometer sensitivity, also known as <i>scale-factor</i> , represents the change in acceleration input corresponding to 1 LSB change in output and is typically measured in either mg/LSB or LSB/g.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Zero-g offset                                                    | The accelerometer zero- <i>g</i> offset describes the deviation of the sensor output from the ideal 0 <i>g</i> value when no motion or gravity is acting on it. With an accelerometer stationary and placed on a level, horizontal surface, the ideal output is 0 <i>g</i> for the X and Y axes. Likewise,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

Table 121. Glossary...continued

| Term | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | if the accelerometer is placed on a vertical plane, the ideal output is 0 g for the Z-axis. The deviation of each output from the ideal value is called <i>zero-g offset</i> . Offset is, to some extent, a result of stress on the sensor and how well the sensor is leveled when soldered to the board. Therefore, the zero-g offset can change after mounting the sensor onto a printed circuit board or exposing it to extensive mechanical stress.  For applications that require increased precision, any residual post-board mount offset may be removed using the <b>OFF_X/Y/Z</b> registers, or alternatively, in the host application software. |

### 21 References

- [1] AN1902 Assembly Guidelines for QFN and DFN Packages, <a href="https://www.nxp.com/docs/en/application-note/AN1902.pdf">https://www.nxp.com/docs/en/application-note/AN1902.pdf</a>
- [2] AN13193 Self-test procedure for FXLS896xAF and FXLS897xCF, <a href="https://www.nxp.com/docs/en/application-note/AN13193.pdf">https://www.nxp.com/docs/en/application-note/AN13193.pdf</a>
- [3] UM10204 I<sup>2</sup>C-bus specification and user manual, <a href="https://www.nxp.com/docs/en/user-guide/UM10204.pdf">https://www.nxp.com/docs/en/user-guide/UM10204.pdf</a>

## 22 Revision history

Table 122. Revision history

| Document ID      | Release date     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FXLS8971CF v.2.1 | 7 March 2024     | <ul> <li>FXLS8971CF v.2.1 supercedes FXLS8971CF v.2</li> <li>FXLS8971CF v.2.1 is a product data sheet, revised the data sheet status from "Preliminary" to "Product".</li> <li>Section 4.1, Table 2, revised "Tape and reel (1.5 k)" to "Tape and reel (1.25 k)" in the "Shipping" column.</li> <li>Section 6.1, Figure 2, revised the image.</li> <li>Section 16.2, revised "slave" to "secondary" in two locations to conform to NXP's Inclusive Language Initiative.</li> <li>Section 17.1, Figure 28, Figure 29, and Figure 30, updated the images to the current SOT release.</li> <li>Section 19.1, Figure 31, Figure 32, and Figure 33, updated the images to the current SOT release and removed "— Preliminary" from the figure title.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| FXLS8971CF v.2   | 19 December 2023 | <ul> <li>FXLS8971CF v.2 supercedes FXLS8971CF v.1.1</li> <li>FXLS8971CF v.2 is a preliminary data sheet, revised the data sheet status from "Objective" to "Preliminary".</li> <li>Section 7, Table 5, I<sub>LU</sub>: removed "(per AEC-Q100-004)" from the rating column.</li> <li>Section 9, revised as follows:  Section 9, Table 7, revised as follows:  SEN<sub>TOL</sub>: revised the Min and Max values from "—" to "-10" and "+10", respectively and replaced "—" in the condition field with "–40 °C to +105 °C".</li> <li>TCS: revised as a follows:  Symbol: revised the symbol name from "TCS" to "TCS<sub>PBM</sub>".  Parameter: revised the parameter adding ", post board mount, FSR ≤ ± 4 g" and inserted a second footnote.  Condition: inserted ", delta from 25 °C" to the condition.  Min value: revised the Min value from "—" to "-0.023".  Typ value: revised the Typ value from "±0.01" to "±0.005".  Max value: revised the Max value from "—" to "0.023".</li> <li>OFF<sub>PBM</sub>: revised as follows:  Conditions: revised "XY axes" to "–40 °C to +105 °C".  Min value: revised the Min value from "—" to "120".  Canditions: revised the Max value from "—" to "120".  Conditions, Min, Typ, Max: removed Z axis in the condition field and removed the associated Min, Typ, and Max values.</li> <li>TCO<sub>PBM</sub>:  Parameter: inserted ", delta from 25°C, FSR ≤ ± 4 g" and footnote 2.  Conditions: revised "At At A</li></ul> |

Table 122. Revision history...continued

| Document ID      | Release date     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  |                  | <ul> <li>landing pattern on a 2-layer FR4 PCB with 1.2 mm (47 mil) overall thickness." to "Determined with post board mount data using a standard lead-free reflow profile and NXP recommended landing pattern on a 10-layer FR4 PCB with 1.6 mm (63 mil) overall thickness."</li> <li>Footnote 2: revised footnote from "Based on characterization data on limited number of parts from 3 lots" to "Based on characterization data on limited number of parts from 3 lots. Limits provided with 4 sigma margin and 99% confidence level."</li> <li>Section 9.1, inserted new section, content and images.</li> <li>Section 10, Table 8, revsied as follows: <ul> <li>IDD<sub>HPM</sub>: revised the Typ value from "150" to "146.9".</li> <li>IDD<sub>LPM</sub>: revised all Typ values from "150, 75, 38, 20, 11, 5.3, 3.1, 1.8, 1.4, 1.0, 0.80, 0.70, and 0.65." to "146.9, 73.9, 37.5, 19.4, 10.4, 5.04, 2.75, 1.6, 1.21, 0.84, 0.65, 0.56, and 0.51".</li> <li>IDD<sub>STBY</sub>: revised Typ value from "0.60" to "0.46".</li> </ul> </li> <li>Section 15.3.3, Table 52 and Table 53, removed the columns titled "Noise RMS (mg)" and "l<sub>DD</sub> (μA)" and the associated footnotes.</li> <li>Section 16.3, Figure 22, Figure 23, Figure 25, Figure 26, and Figure 27, updated the graphic registration number, no content change to the images.</li> <li>Section 16.3, Figure 24, revised "C2 0.1 μF" to "C1 0.1 μF" and updated the graphic registration number.</li> <li>Section 19.1, inserted note at the end of the section.</li> <li>Section 20, Cross-axis sensitivity: Removed "The cross-axis sensitivity specification represents the maximum of these six terms." from the description.</li> </ul> |
| FXLS8971CF v.1.1 | 20 December 2022 | <ul> <li>FXLS8971CF v.1.1 supercedes FXLS8971CF v.1.</li> <li>FXLS8971CF v.1.1 is an objective data sheet.</li> <li><u>Section 2</u>, Post-board mount feature, revised "±0.25 mg/°C (typ)" to "–0.15 mg/°C (typ)."</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| FXLS8971CF v.1   | 28 November 2022 | <ul><li>FXLS8971CF v.1 is an objective data sheet.</li><li>Initial release.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

## Legal information

#### Data sheet status

| Document status <sup>[1][2]</sup> | Product status <sup>[3]</sup> | Definition                                                                            |
|-----------------------------------|-------------------------------|---------------------------------------------------------------------------------------|
| Objective [short] data sheet      | Development                   | This document contains data from the objective specification for product development. |
| Preliminary [short] data sheet    | Qualification                 | This document contains data from the preliminary specification.                       |
| Product [short] data sheet        | Production                    | This document contains the product specification.                                     |

- [1] Please consult the most recently issued document before initiating or completing a design.
- [2] The term 'short data sheet' is explained in section "Definitions".
- [3] The product status of device(s) described in this document may have changed since this document was published and may differ in case of multiple devices. The latest product status information is available on the Internet at URL <a href="https://www.nxp.com">https://www.nxp.com</a>.

#### **Definitions**

**Draft** — A draft status on a document indicates that the content is still under internal review and subject to formal approval, which may result in modifications or additions. NXP Semiconductors does not give any representations or warranties as to the accuracy or completeness of information included in a draft version of a document and shall have no liability for the consequences of use of such information.

Short data sheet — A short data sheet is an extract from a full data sheet with the same product type number(s) and title. A short data sheet is intended for quick reference only and should not be relied upon to contain detailed and full information. For detailed and full information see the relevant full data sheet, which is available on request via the local NXP Semiconductors sales office. In case of any inconsistency or conflict with the short data sheet, the full data sheet shall prevail.

Product specification — The information and data provided in a Product data sheet shall define the specification of the product as agreed between NXP Semiconductors and its customer, unless NXP Semiconductors and customer have explicitly agreed otherwise in writing. In no event however, shall an agreement be valid in which the NXP Semiconductors product is deemed to offer functions and qualities beyond those described in the Product data sheet.

#### **Disclaimers**

Limited warranty and liability — Information in this document is believed to be accurate and reliable. However, NXP Semiconductors does not give any representations or warranties, expressed or implied, as to the accuracy or completeness of such information and shall have no liability for the consequences of use of such information. NXP Semiconductors takes no responsibility for the content in this document if provided by an information source outside of NXP Semiconductors.

In no event shall NXP Semiconductors be liable for any indirect, incidental, punitive, special or consequential damages (including - without limitation - lost profits, lost savings, business interruption, costs related to the removal or replacement of any products or rework charges) whether or not such damages are based on tort (including negligence), warranty, breach of contract or any other legal theory.

Notwithstanding any damages that customer might incur for any reason whatsoever, NXP Semiconductors' aggregate and cumulative liability towards customer for the products described herein shall be limited in accordance with the Terms and conditions of commercial sale of NXP Semiconductors.

Right to make changes — NXP Semiconductors reserves the right to make changes to information published in this document, including without limitation specifications and product descriptions, at any time and without notice. This document supersedes and replaces all information supplied prior to the publication hereof.

Suitability for use — NXP Semiconductors products are not designed, authorized or warranted to be suitable for use in life support, life-critical or safety-critical systems or equipment, nor in applications where failure or malfunction of an NXP Semiconductors product can reasonably be expected to result in personal injury, death or severe property or environmental damage. NXP Semiconductors and its suppliers accept no liability for inclusion and/or use of NXP Semiconductors products in such equipment or applications and therefore such inclusion and/or use is at the customer's own risk.

**Applications** — Applications that are described herein for any of these products are for illustrative purposes only. NXP Semiconductors makes no representation or warranty that such applications will be suitable for the specified use without further testing or modification.

Customers are responsible for the design and operation of their applications and products using NXP Semiconductors products, and NXP Semiconductors accepts no liability for any assistance with applications or customer product design. It is customer's sole responsibility to determine whether the NXP Semiconductors product is suitable and fit for the customer's applications and products planned, as well as for the planned application and use of customer's third party customer(s). Customers should provide appropriate design and operating safeguards to minimize the risks associated with their applications and products.

NXP Semiconductors does not accept any liability related to any default, damage, costs or problem which is based on any weakness or default in the customer's applications or products, or the application or use by customer's third party customer(s). Customer is responsible for doing all necessary testing for the customer's applications and products using NXP Semiconductors products in order to avoid a default of the applications and the products or of the application or use by customer's third party customer(s). NXP does not accept any liability in this respect.

Limiting values — Stress above one or more limiting values (as defined in the Absolute Maximum Ratings System of IEC 60134) will cause permanent damage to the device. Limiting values are stress ratings only and (proper) operation of the device at these or any other conditions above those given in the Recommended operating conditions section (if present) or the Characteristics sections of this document is not warranted. Constant or repeated exposure to limiting values will permanently and irreversibly affect the quality and reliability of the device.

Terms and conditions of commercial sale — NXP Semiconductors products are sold subject to the general terms and conditions of commercial sale, as published at https://www.nxp.com/profile/terms, unless otherwise agreed in a valid written individual agreement. In case an individual agreement is concluded only the terms and conditions of the respective agreement shall apply. NXP Semiconductors hereby expressly objects to applying the customer's general terms and conditions with regard to the purchase of NXP Semiconductors products by customer.

No offer to sell or license — Nothing in this document may be interpreted or construed as an offer to sell products that is open for acceptance or the grant, conveyance or implication of any license under any copyrights, patents or other industrial or intellectual property rights.

FXLS8971CF

All information provided in this document is subject to legal disclaimers.

**Quick reference data** — The Quick reference data is an extract of the product data given in the Limiting values and Characteristics sections of this document, and as such is not complete, exhaustive or legally binding.

**Export control** — This document as well as the item(s) described herein may be subject to export control regulations. Export might require a prior authorization from competent authorities.

Suitability for use in non-automotive qualified products — Unless this document expressly states that this specific NXP Semiconductors product is automotive qualified, the product is not suitable for automotive use. It is neither qualified nor tested in accordance with automotive testing or application requirements. NXP Semiconductors accepts no liability for inclusion and/or use of non-automotive qualified products in automotive equipment or applications.

In the event that customer uses the product for design-in and use in automotive applications to automotive specifications and standards, customer (a) shall use the product without NXP Semiconductors' warranty of the product for such automotive applications, use and specifications, and (b) whenever customer uses the product for automotive applications beyond NXP Semiconductors' specifications such use shall be solely at customer's own risk, and (c) customer fully indemnifies NXP Semiconductors for any liability, damages or failed product claims resulting from customer design and use of the product for automotive applications beyond NXP Semiconductors' standard warranty and NXP Semiconductors' product specifications.

**Translations** — A non-English (translated) version of a document, including the legal information in that document, is for reference only. The English version shall prevail in case of any discrepancy between the translated and English versions.

Security — Customer understands that all NXP products may be subject to unidentified vulnerabilities or may support established security standards or specifications with known limitations. Customer is responsible for the design and operation of its applications and products throughout their lifecycles to reduce the effect of these vulnerabilities on customer's applications and products. Customer's responsibility also extends to other open and/or proprietary technologies supported by NXP products for use in customer's applications. NXP accepts no liability for any vulnerability. Customer should regularly check security updates from NXP and follow up appropriately. Customer shall select products with security features that best meet rules, regulations, and standards of the intended application and make the ultimate design decisions regarding its products and is solely responsible for compliance with all legal, regulatory, and security related requirements concerning its products, regardless of any information or support that may be provided by NXP.

NXP has a Product Security Incident Response Team (PSIRT) (reachable at <a href="PSIRT@nxp.com">PSIRT@nxp.com</a>) that manages the investigation, reporting, and solution release to security vulnerabilities of NXP products.

**NXP B.V.** — NXP B.V. is not an operating company and it does not distribute or sell products.

#### **Trademarks**

Notice: All referenced brands, product names, service names, and trademarks are the property of their respective owners.

NXP — wordmark and logo are trademarks of NXP B.V.

## **Tables**

| Tab. 1.  | Ordering information                          | 2   | Tab. 32.         | OUT_Y_LSB and OUT_Y_MSB register        |      |
|----------|-----------------------------------------------|-----|------------------|-----------------------------------------|------|
| Tab. 2.  | Ordering options                              |     |                  | (addresses 06h to 07h) with SEN         |      |
| Tab. 3.  | Pin descriptions                              |     |                  | CONFIG2[LE_BE] = 1 bit allocation       | 39   |
| Tab. 4.  | Device absolute maximum ratings               |     | Tab. 33.         | OUT_Z_LSB and OUT_Z_MSB register        |      |
| Tab. 5.  | ESD and latch-up-protection characteristics . |     |                  | (addresses 08h to 09h) with SEN_        |      |
| Tab. 6.  | Nominal operating conditions                  |     |                  | CONFIG2[LE_BE] = 1 bit allocation       | 30   |
| Tab. 7.  | Accelerometer sensor performance              |     | Tab. 34.         | BUF_STATUS register (address 0Bh) bit   | . 00 |
| 1ab. 1.  |                                               | 0   | 1ab. 54.         | allocation                              | 20   |
| T-6 0    | parameters                                    |     | T-1- 05          |                                         | . ა9 |
| Tab. 8.  | Electrical characteristics                    | 12  | Tab. 35.         | BUF_STATUS register (address 0Bh) bit   | 40   |
| Tab. 9.  | Temperature sensor performance                |     |                  | description                             | . 40 |
|          | parameters                                    |     | Tab. 36.         | BUF_X_LSB and BUF_X_MSB registers       |      |
| Tab. 10. | I2C serial interface pin description          | 14  |                  | (addresses 0Ch, 0Dh) with SENS_         |      |
| Tab. 11. | FXLS8971CF I2C read and write                 |     |                  | CONFIG2[LE_BE] = 0 bit allocation       | 41   |
|          | addresses                                     | 15  | Tab. 37.         | BUF_Y_LSB and BUF_Y_MSB registers       |      |
| Tab. 12. | I2C secondary timing values for Standard-     |     |                  | (addresses 0Eh, 0Fh) with SENS_         |      |
|          | mode (Sm), Fast-mode (Fm), and Fast-          |     |                  | CONFIG2[LE_BE] = 0 bit allocation       | 41   |
|          | mode Plus (Fm+)                               | 15  | Tab. 38.         | BUF_Z_LSB and BUF_Z_MSB registers       |      |
| Tab. 13. | Secondary timing values                       |     |                  | (addresses 10h, 11h) with SENS_         |      |
| Tab. 14. | Secondary timing values                       |     |                  | CONFIG2[LE_BE] = 0 bit allocation       | 42   |
| Tab. 15. | FXLS8971CF operating modes                    |     | Tab. 39.         | BUF_X_LSB and BUF_X_MSB registers       | –    |
| 100. 10. | descriptions                                  | 23  | 145. 00.         | (addresses 0Ch, 0Dh) with SENS_         |      |
| Tab. 16. | Operating modes transition criteria           |     |                  | CONFIG2[LE BE] = 1 bit allocation       | 12   |
|          |                                               | 20  | Tob 40           |                                         | .42  |
| Tab. 17. | BOOT2 sequence and One-wire motion            | 00  | Tab. 40.         | BUF_Y_LSB and BUF_Y_MSB registers       |      |
| T-1- 40  | protocol phase descriptions                   | 28  |                  | (addresses 0Eh, 0Fh) with SENS_         | 40   |
| Tab. 18. | One-wire motion protocol threshold            | 00  | <b>T</b> 1 44    | CONFIG2[LE_BE] = 1 bit allocation       | . 42 |
|          | selections                                    | 28  | Tab. 41.         | BUF_Z_LSB and BUF_Z_MSB registers       |      |
| Tab. 19. | BOOT1 sequence description (BT_MODE           |     |                  | (addresses 10h, 11h) with SENS_         |      |
|          | = GND)                                        |     |                  | CONFIG2[LE_BE] = 1 bit allocation       | 43   |
| Tab. 20. | Register address map                          | 30  | Tab. 42.         | PROD_REV register (address 12h) bit     |      |
| Tab. 21. | INT_STATUS register (address 00h) bit         |     |                  | allocation                              | . 43 |
|          | allocation                                    | 33  | Tab. 43.         | PROD_REV register (address 12h) bit     |      |
| Tab. 22. | INT_STATUS register (address 00h) bit         |     |                  | description                             | 43   |
|          | description                                   | 34  | Tab. 44.         | WHO_AM_I register (address 13h) bit     |      |
| Tab. 23. | TEMP_OUT register (address 01h) bit           |     |                  | allocation                              | . 43 |
|          | allocation                                    | 36  | Tab. 45.         | SYS_MODE register (address 14h) bit     |      |
| Tab. 24. | VECM LSB register (address 02h) bit           |     |                  | allocation                              | . 44 |
|          | allocation                                    | 36  | Tab. 46.         | SYS_MODE register (address 14h) bit     |      |
| Tab. 25. | VECM_LSB register (address 02h) bit           | 00  | 145. 10.         | description                             | 44   |
| 140. 20. | description                                   | 36  | Tab. 47.         | SENS_CONFIG1 register (address 15h) bit |      |
| Tab. 26. | VECM_MSB register (address 03h) bit           | 30  | 1ab. 47.         | allocation                              | 15   |
| 1ab. 20. | allocation                                    | 36  | Tab. 48.         | SENS_CONFIG1 register (address 15h) bit | . 43 |
| Tab 27   |                                               | 30  | 1ab. 40.         |                                         | 15   |
| Tab. 27. | VECM_MSB register (address 03h) bit           | 0.7 | T-1- 40          | description                             | . 45 |
| T 1 00   | description                                   | 31  | Tab. 49.         | SENS_CONFIG2 register (address 16h) bit | 40   |
| Tab. 28. | OUT_X_LSB and OUT_X_MSB register              |     |                  | allocation                              | . 46 |
|          | (addresses 04h to 05h) with SEN_              |     | Tab. 50.         | SENS_CONFIG2 register (address 16h) bit |      |
|          | CONFIG2[LE_BE] = 0 bit allocation             | 37  |                  | description                             | . 47 |
| Tab. 29. | OUT_Y_LSB and OUT_Y_MSB register              |     | Tab. 51.         | SENS_CONFIG3 register (address 17h) bit |      |
|          | (addresses 06h to 07h) with SEN_              |     |                  | allocation                              | . 48 |
|          | CONFIG2[LE_BE] = 0 bit allocation             | 38  | Tab. 52.         | WAKE and SLEEP low-power mode ODR       |      |
| Tab. 30. | OUT_Z_LSB and OUT_Z_MSB register              |     |                  | and decimation settings                 | . 48 |
|          | (addresses 08h to 09h) with SEN_              |     | Tab. 53.         | WAKE and SLEEP High Performance         |      |
|          | CONFIG2[LE BE] = 0 bit allocation             | 38  |                  | mode ODR and decimation settings        | 49   |
| Tab. 31. | OUT X LSB and OUT X MSB register              |     | Tab. 54.         | WAKE and SLEEP decimation settings in   |      |
|          | (addresses 04h to 05h) with SEN_              |     | <del>-</del> ··· | Flexible Power mode                     | . 50 |
|          | CONFIG2[LE_BE] = 1 bit allocation             | 38  | Tab. 55.         | SENS_CONFIG4 register (address 18h) bit |      |
|          |                                               |     |                  | allocation                              | .50  |
|          |                                               |     |                  |                                         | . 55 |

# FXLS8971CF

| Tab. 56.              | SENS_CONFIG4 register (address 18h) bit    |      | Tab. 85.                | ORIENT_CONFIG register (address 29h)       |      |
|-----------------------|--------------------------------------------|------|-------------------------|--------------------------------------------|------|
|                       | description                                | 50   |                         | bit description                            | 64   |
| Tab. 57.              | INTx pin behavior as a function of INT_PP_ |      | Tab. 86.                | ORIENT_DBCOUNT register (address           |      |
|                       | OD and INT_POL bit settings (valid only    |      |                         | 2Ah) bit allocation                        | 65   |
|                       | when BT_MODE = VDD)                        | 52   | Tab. 87.                | ORIENT_DBCOUNT register (address           |      |
| Tab. 58.              | INTx pin behavior as a function of INT_PP_ |      |                         | 2Ah) bit description                       | 65   |
|                       | OD and INT_POL bit settings (valid only    |      | Tab. 88.                | ORIENT_BF_ZCOMP register (address          |      |
|                       | when BT_MODE = VDD)                        | 52   |                         | 2Bh) bit allocation                        | 65   |
| Tab. 59.              | SENS_CONFIG5 register (address 19h) bit    |      | Tab. 89.                | ORIENT_BF_ZCOMP register (address          |      |
|                       | allocation                                 | 52   |                         | 2Bh) bit description                       | 65   |
| Tab. 60.              | SENS_CONFIG5 register (address 19h) bit    | 0_   | Tab. 90.                | ORIENT_ZLOCK lockout angles                |      |
| 1ab. 00.              | description                                | 53   | Tab. 91.                | ORIENT Back/Front orientation transition   | 00   |
| Tab. 61.              | WAKE_IDLE_LSB register (address 1Ah)       | 00   | 1ab. 51.                | angle definitions                          | 66   |
| 1ab. 01.              | bit allocation                             | 5/   | Tab. 92.                | ORIENT_THS register (address 2Ch) bit      | . 00 |
| Tob 62                | WAKE_IDLE_MSB register (address 1Bh)       | 54   | 140. 92.                | allocation                                 | 66   |
| Tab. 62.              |                                            | E 4  | T-6 00                  |                                            | 00   |
| T-1- 00               | bit allocation                             | 54   | Tab. 93.                | Orientation change trip angles look-up     | 00   |
| Tab. 63.              | SLEEP_IDLE_LSB register (address 1Ch)      | - 4  | T 1 04                  | table                                      | 66   |
| T 1 04                | bit allocation                             | 54   | Tab. 94.                | Resultant trip angle (threshold angle ±    | ~-   |
| Tab. 64.              | SLEEP_IDLE_MSB register (address 1Dh)      |      |                         | hysteresis angle)                          | 67   |
|                       | bit allocation                             | 54   | Tab. 95.                | Orientation change ideal orientation angle |      |
| Tab. 65.              | ASLP_COUNT_LSB register (address 1Eh)      |      |                         | definitions                                | 68   |
|                       | bit allocation                             | 55   | Tab. 96.                | SDCD_INT_SRC1 register (address 2Dh)       |      |
| Tab. 66.              | ASLP_COUNT_LSB register (address 1Eh)      |      |                         | bit allocation                             | 68   |
|                       | bit description                            | 55   | Tab. 97.                | SDCD_INT_SRC1 register (address 2Dh)       |      |
| Tab. 67.              | ASLP_COUNT_MSB register (address           |      |                         | bit description                            | 69   |
|                       | 1Fh) bit allocation                        | 55   | Tab. 98.                | SDCD_INT_SRC2 register (address 2Eh)       |      |
| Tab. 68.              | ASLP_COUNT_MSB register (address           |      |                         | bit allocation                             | 70   |
|                       | 1Fh) bit description                       | . 55 | Tab. 99.                | SDCD_INT_SRC2 register (address 2Eh)       |      |
| Tab. 69.              | ASLP_COUNT timer period                    |      |                         | bit description                            | 70   |
| Tab. 70.              | Auto-WAKE/SLEEP Interrupt Event            |      | Tab. 100.               | SDCD_CONFIG1 register (address 2Fh) bit    |      |
|                       | Sources                                    | 56   |                         | allocation                                 | 71   |
| Tab. 71.              | INT_EN register (address 20h) bit          |      | Tab. 101.               | SDCD_CONFIG1 register (address 2Fh) bit    |      |
|                       | allocation                                 | . 57 |                         | description                                | . 71 |
| Tab. 72.              | INT_EN register (address 20h) bit          | • .  | Tab 102                 | SDCD_CONFIG2 register (address 30h) bit    |      |
| 145. 12.              | description                                | 57   | 145. 162.               | allocation                                 | 72   |
| Tab. 73.              | INT_PIN_SEL register (address 21h) bit     | • .  | Tab 103                 | SDCD_CONFIG2 register (address 30h) bit    |      |
| 100. 10.              | allocation                                 | 58   | 145. 100.               | description                                | 72   |
| Tab. 74.              | INT PIN SEL register (address 21h) bit     | 00   | Tab 104                 | SDCD_OT_DBCNT register (address 31h)       | 12   |
| 1ab. 1 <del>1</del> . | description                                | 58   | 1ab. 10 <del>-1</del> . | bit allocation                             | 7/   |
| Tab. 75.              | OFF_X register (addresses 22h) bit         | 50   | Tab 105                 | SDCD_OT_DBCNT register (address 31h)       | , –  |
| 1ab. 75.              | allocation                                 | 60   | 1ab. 105.               | bit description                            | 7/   |
| Tob 76                | OFF_Y register (addresses 23h) bit         | 00   | Tab 106                 | SDCD_WT_DBCNT register (address 32h)       | / 4  |
| Tab. 76.              |                                            | 60   | 1ab. 100.               |                                            | 75   |
| Tab 77                | allocation                                 | 60   | Tab 107                 | bit allocation                             | 73   |
| Tab. 77.              | OFF_Z register (addresses 24h) bit         | 60   | 1ab. 107.               | SDCD_WT_DBCNT register (address 32h)       | 75   |
| T-1- 70               | allocation                                 | 60   | T-1- 400                | bit description                            | /5   |
| Tab. 78.              | BUF_CONFIG1 register (address 26h) bit     | 00   | 1ab. 108.               | SDCD_LTHS_LSB register (address 33h)       | 7.   |
| T . TO                | allocation                                 | 60   | T 1 100                 | bit allocation                             | 75   |
| Tab. 79.              | BUF_CONFIG1 register (address 26h) bit     |      | lab. 109.               | SDCD_LTHS_LSB register (address 33h)       |      |
|                       | description                                | 60   |                         | bit description                            | 75   |
| Tab. 80.              | BUF_CONFIG2 register (address 27h) bit     |      | Tab. 110.               | SDCD_LTHS_MSB register (address 34h)       |      |
|                       | allocation                                 | 62   |                         | bit allocation                             | 76   |
| Tab. 81.              | BUF_CONFIG2 register (address 27h) bit     |      | Tab. 111.               | SDCD_LTHS_MSB register (address 34h)       |      |
|                       | description                                | 62   |                         | bit description                            | 76   |
| Tab. 82.              | ORIENT_STATUS register (address 28h)       |      | Tab. 112.               | SDCD_UTHS_LSB register (address 35h)       |      |
|                       | bit allocation                             | 63   |                         | bit allocation                             | 76   |
| Tab. 83.              | ORIENT_STATUS register (address 28h)       |      | Tab. 113.               | SDCD_UTHS_LSB register (address 35h)       |      |
|                       | bit description                            | 63   |                         | bit description                            | 76   |
| Tab. 84.              | ORIENT_CONFIG register (address 29h)       |      | Tab. 114.               | SDCD_UTHS_MSB register (address 36h)       |      |
|                       | bit allocation                             | 64   |                         | bit allocation                             | 77   |
|                       |                                            |      |                         |                                            |      |

# FXLS8971CF

| Tab. 116<br>Tab. 117          | SDCD_UTHS_MSB register (address 36h) bit description                       | Tab. 120. | SELF_TEST_CONFIG2 register (address 38h) bit description                             | 78<br>90 |
|-------------------------------|----------------------------------------------------------------------------|-----------|--------------------------------------------------------------------------------------|----------|
| Figur                         | es                                                                         |           |                                                                                      |          |
| Fig. 1.<br>Fig. 2.<br>Fig. 3. | Block Diagram                                                              | Fig. 18.  | BOOT2 sequence and One-wire motion-<br>detection protocol diagram (BT_MODE =<br>VDD) | 27       |
|                               | response to ±1 g (gravity) stimulus6                                       | Fig. 19.  | BOOT1 sequence (BT_MODE = GND)                                                       |          |
| Fig. 4.                       | Offset drift vs. temperature10                                             | Fig. 20.  | SDCD Function Block Diagram                                                          |          |
| Fig. 5.                       | XYZ_TCO histograms11                                                       | Fig. 21.  | SDCD REF_UPD timing diagram                                                          |          |
| Fig. 6.                       | XYZ_TCS histograms11                                                       | Fig. 22.  | Typical Application Circuit #1 – I2C mode                                            | 79       |
| Fig. 7.                       | I2C secondary timing diagram for<br>Standard-mode, Fast-mode and Fast-mode | Fig. 23.  | Typical Application Circuit #2 – SPI 4-wire mode                                     | 80       |
|                               | Plus                                                                       | Fig. 24.  | Typical Application Circuit #3 – SPI 3-                                              |          |
| Fig. 8.                       | I2C Data Sequence Diagrams 18                                              |           | wire mode (software enabled; SENS_                                                   |          |
| Fig. 9.                       | SPI single-byte write protocol diagram (3-                                 |           | CONFIG1[SPI_M] = 1)                                                                  | 80       |
|                               | or 4-wire mode), R/W = 019                                                 | Fig. 25.  | Typical Application Circuit #4 – SPI 3-wire                                          |          |
| Fig. 10.                      | SPI multiple-byte write protocol diagram (3-                               |           | mode (hardwired; SENS_CONFIG1[SPI_                                                   |          |
|                               | or 4-wire mode), R/W = 019                                                 |           | M] = X)                                                                              | 80       |
| Fig. 11.                      | SPI single-byte read protocol diagram (4-                                  | Fig. 26.  | Typical Application Circuit #5 – Motion                                              |          |
|                               | wire mode), R/W = 120                                                      |           | detection mode (no serial interface)                                                 | 81       |
| Fig. 12.                      | SPI multiple-byte read protocol diagram (4-                                | Fig. 27.  | Typical Application Circuit #6 - Motion                                              |          |
|                               | wire mode), R/W = 120                                                      |           | detection mode (with SPI 3-wire interface,                                           |          |
| Fig. 13.                      | SPI single-byte read protocol diagram (3-                                  |           | software enabled)                                                                    |          |
|                               | wire mode)20                                                               | Fig. 28.  | FXLS8971CF package outline                                                           |          |
| Fig. 14.                      | SPI multiple-byte read protocol diagram (3-                                | Fig. 29.  | FXLS8971CF package outline detail                                                    |          |
|                               | wire mode)21                                                               | Fig. 30.  | FXLS8971CF package outline notes                                                     | 85       |
| Fig. 15.                      | SPI timing diagram (4-wire mode)22                                         | Fig. 31.  | PCB design guidelines - Solder mask                                                  |          |
| Fig. 16.                      | SPI timing diagram (3-wire mode)23                                         |           | opening patttern                                                                     | 87       |
| Fig. 17.                      | Operating modes transition diagram25                                       | Fig. 32.  | PCB design guideline - I/O pads and                                                  |          |
|                               |                                                                            |           | solderable area                                                                      |          |
|                               |                                                                            | Fig. 33.  | PCB footprint guidelines                                                             | 89       |
|                               |                                                                            |           |                                                                                      |          |

## **Contents**

|          |                                               |     | 456     |                                              |
|----------|-----------------------------------------------|-----|---------|----------------------------------------------|
| 1        | General description                           |     | 15.3.1  | SENS_CONFIG1 register (address 15h) 45       |
| 2        | Features and benefits                         |     | 15.3.2  | SENS_CONFIG2 register (address 16h) 46       |
| 3        | Applications                                  |     | 15.3.3  | SENS_CONFIG3 register (address 17h) 47       |
| 3.1      | Industrial IOT                                |     | 15.3.4  | SENS_CONFIG4 register (address 18h) 50       |
| 3.2      | Medical                                       |     | 15.3.5  | SENS_CONFIG5 register (address 19h) 52       |
| 3.3      | Consumer devices                              |     | 15.3.6  | WAKE_IDLE_LSB register (address 1Ah) 53      |
| 4        | Ordering information                          | 2   | 15.3.7  | WAKE_IDLE_MSB register (address 1Bh) 54      |
| 4.1      | Ordering options                              | 2   | 15.3.8  | SLEEP_IDLE_LSB register (address 1Ch) 54     |
| 5        | Block diagram                                 | 3   | 15.3.9  | SLEEP_IDLE_MSB register (address 1Dh) 54     |
| 6        | Pinning information                           | 4   | 15.3.10 | ASLP_COUNT_LSB, ASLP_COUNT_MSB               |
| 6.1      | Pinning                                       | 4   |         | registers (addresses 1Eh to 1Fh)54           |
| 6.2      | Pinning description                           | 4   | 15.3.11 | INT_EN register (address 20h)56              |
| 6.3      | Orientation                                   | 6   | 15.3.12 | INT_PIN_SEL register (address 21h)58         |
| 7        | Limiting values                               | 6   | 15.3.13 | OFF_X, OFF_Y, OFF_Z registers                |
| 8        | Recommended operating conditions              |     |         | (addresses 22h to 24h) 59                    |
| 9        | Mechanical characteristics                    |     | 15.3.14 | BUF_CONFIG1 register (address 26h)60         |
| 9.1      | Typical performance                           |     | 15.3.15 | BUF_CONFIG2 register (address 27h)62         |
| 10       | Electrical characteristics                    |     | 15.4    | Orientation detection settings registers63   |
| 11       | Temperature sensor characteristics            |     | 15.4.1  | ORIENT_STATUS register (address 28h)63       |
| 12       | I2C digital interface                         |     | 15.4.2  | ORIENT_CONFIG register (address 29h) 64      |
| 12.1     | I2C interface characteristics                 |     | 15.4.3  | ORIENT_DBCOUNT register (address             |
| 12.1.1   | General I2C operation                         |     |         | 2Ah)                                         |
| 12.1.2   | I2C read/write operations                     |     | 15.4.4  | ORIENT_BF_ZCOMP register (address            |
| 12.1.2.1 | Single-byte read                              |     | 10.1.1  | 2Bh)                                         |
| 12.1.2.2 | Multiple-byte read                            |     | 15.4.5  | ORIENT_THS register (address 2Ch)            |
| 12.1.2.3 | Single-byte write                             |     | 15.5    | Sensor Data Change Detection (SDCD)          |
| 12.1.2.4 | Multiple-byte write                           |     | 10.0    | registers                                    |
| 12.1.2.4 | I2C data sequence diagrams                    |     | 15.5.1  | SDCD INT SRC1 register (address 2Dh)68       |
| 13       | SPI interface                                 |     | 15.5.1  | SDCD_INT_SRC2 register (address 2Eh)69       |
| 13.1     | General SPI operation                         |     | 15.5.2  | SDCD_CONFIG1 register (address 2Fh)71        |
| 13.1     |                                               |     | 15.5.4  |                                              |
| 13.2     | SPI write operations with 3- or 4-wire mode . |     |         | SDCD_CONFIG2 register (address 30h)72        |
|          | SPI read operations with 4-wire mode          |     | 15.5.5  | SDCD_OT_DBCNT register (address 31h) 74      |
| 13.4     | SPI read operations with 3-wire mode          | 20  | 15.5.6  | SDCD_WT_DBCNT register (address 32h)74       |
| 13.5     | SPI timing specifications (4-wire mode and    | 24  | 15.5.7  | SDCD_LTHS_LSB register (address 33h)75       |
| 12.6     | 3-wire hardwired modes)                       | ∠ ۱ | 15.5.8  | SDCD_LTHS_MSB register (address 34h) 75      |
| 13.6     | SPI timing specifications (software enabled   | 22  | 15.5.9  | SDCD_UTHS_LSB register (address 35h) 76      |
| 4.4      | 3-wire mode)                                  |     | 15.5.10 | SDCD_UTHS_MSB register (address 36h) 76      |
| 14       | Operating modes                               |     | 15.6    | Self-test configuration registers            |
| 15       | Register descriptions                         |     | 15.6.1  | SELF_TEST_CONFIG1 register (address          |
| 15.1     | Complete register map                         |     | 45.00   | 37h)77                                       |
| 15.2     | Data and status read registers                |     | 15.6.2  | SELF_TEST_CONFIG2 register (address          |
| 15.2.1   | INT_STATUS register (address 00h)             |     |         | 38h)                                         |
| 15.2.2   | TEMP_OUT register (address 01h)               |     | 16      | Application information 79                   |
| 15.2.3   | VECM_LSB register (address 02h)               |     | 16.1    | System connections79                         |
| 15.2.4   | VECM_MSB register (address 03h)               | 36  | 16.2    | Recommendation for reading data registers 79 |
| 15.2.5   | OUT_X_LSB, OUT_X_MSB, OUT_Y_LSB,              |     | 16.3    | Typical application circuits79               |
|          | OUT_Y_MSB, OUT_Z_LSB, OUT_Z_MSB               |     | 16.4    | Power supply considerations82                |
|          | registers (addresses 04h to 09h)              |     | 17      | Package outline83                            |
| 15.2.6   | BUF_STATUS register (address 0Bh)             | 39  | 17.1    | Package description 83                       |
| 15.2.7   | BUF_X_LSB, BUF_X_MSB, BUF_Y_LSB,              |     | 17.2    | Burr specification85                         |
|          | BUF_Y_MSB, BUF_Z_LSB, BUF_Z_MSB               |     | 18      | Soldering information 86                     |
|          | (addresses 0Ch to 11h)                        | 40  | 18.1    | Printed circuit board layout and device      |
| 15.2.8   | PROD_REV register (address 12h)               |     |         | mounting 86                                  |
| 15.2.9   | WHO_AM_I register (address 13h)               |     | 18.1.1  | Overview of soldering considerations86       |
| 15.2.10  | SYS_MODE register (address 14h)               |     | 18.1.2  | Halogen content 86                           |
| 15.3     |                                               |     |         |                                              |
| 10.0     | Sensor main configuration registers           |     | 19      | Mounting information86                       |

### **NXP Semiconductors**

# FXLS8971CF

### 3-Axis Low-g Accelerometer

| 19.1 | PCB mounting recommendations | 86 |
|------|------------------------------|----|
| 20   | Glossary                     |    |
| 21   | References                   | 91 |
| 22   | Revision history             | 92 |
|      | Legal information            |    |

Please be aware that important notices concerning this document and the product(s) described herein, have been included in section 'Legal information'.

## **X-ON Electronics**

Largest Supplier of Electrical and Electronic Components

Click to view similar products for Accelerometers category:

Click to view products by NXP manufacturer:

Other Similar products are found below:

3022-100-N FXLS93230AESR2 ADXL367BCCZ-RL7 BMI325 LIS3DHHTR 805M1-0200-01 810M1-0025X AIS328DQTR 805-0500 805-0500-01 805M1-0020 810M1-0100X 805-0050 805M1-0200 805M1-0020-01 SCA3300-D01-1 MXP7205VW MXA2500EL MC3413 MXC6244AU ADXL1002BCPZ-RL7 ADXL372BCCZ-RL7 787-500 787AM8 793-6 997-M4 HV101 HV200 PC420AR-10 PC420VP-50 PC420VR-10 786A 786A-IS 787A 787A-IS HT787A PC420VP-10 ADXL325BCPZ-RL7 ADXL335BCPZ-RL7 ADXL345BCCZ ADXL350BCEZ-RL7 MMA8653FCR1 KX132-1211 KXTJ3-1057 LIS2DTW12TR G-Link-200-40G G-Link-200-8G G-Link-200-OEM-40G MC3630 MC3635