Product data sheet

## 1 General description

FXLS8471Q is a small, low-power, 3-axis, linear accelerometer in a 3 mm x 3 mm x 1 mm QFN package. FXLS8471Q has dynamically selectable acceleration full-scale ranges of  $\pm 2$   $g/\pm 4$   $g/\pm 8$  g and 14 bits of resolution. Output data rates (ODR) are programmable from 1.563 Hz to 800 Hz.  $1^2$ C and SPI serial digital interfaces are provided along with several user programmable event detection functions that can be used to reduce the overall system power consumption by off-loading the host processor. FXLS8471Q is guaranteed to operate over the extended temperature range of -40 °C to +105 °C.

#### 2 Features and benefits

- 1.95 V to 3.6 V VDD supply voltage, 1.62 V to 3.6 V VDDIO voltage
- ±2 g/±4 g/±8 g dynamically selectable acceleration full-scale ranges
- Output Data Rates (ODR) from 1.563 Hz to 800 Hz
- Low noise: typically 99 μg/Hz in low-noise mode @ 200-Hz bandwidth
- 14-bit ADC resolution: 0.244 mg/LSB in ±2 g full-scale range
- Embedded programmable acceleration event functions
  - Freefall and motion detection
  - Transient detection
  - Vector-Magnitude change detection
  - Pulse and tap detection (single and double)
  - Orientation detection (portrait/landscape)
- Programmable automatic ODR change using Auto-Wake and return to Sleep functions to save power
- 192-byte FIFO buffer, capable of storing up to 32 samples of X/Y/Z data
- Supports SPI interface at up to 1 MHz; I<sup>2</sup>C Normal (100 kHz) and Fast modes (400 kHz)
- · Integrated self-test function
- Integrated temperature sensor with 8-bit output resolution

## 3 Typical applications

#### Automotive convenience and security

- · Tilt sensing, orientation detection, vibration sensing
- · Navigation applications

#### **Industrial IOT**

- Asset tracking
- Equipment monitoring: vibration analysis, machine health



#### Medical

· Patient and activity monitors

#### **Consumer devices**

- Wearables
- · Portable electronics

## 4 Ordering information

**Table 1. Ordering information** 

| Type number | Temperature range | Package |                                                                                                 |           |  |  |  |
|-------------|-------------------|---------|-------------------------------------------------------------------------------------------------|-----------|--|--|--|
|             |                   | Name    | Description                                                                                     | Version   |  |  |  |
| FXLS8471Q   | -40 °C to +105 °C | VQFN16  | plastic, very thin quad flatpack; no leads; 16 terminals; 0.5 mm pitch; 3 mm x 3 mm x 1 mm body | SOT1676-1 |  |  |  |

## 5 Block Diagram



## 6 Pinning information

## 6.1 Pinning



## 6.2 Pin description

**Table 2. Pin Description** 

| Symbol                  | Pin | Description                                                                           |
|-------------------------|-----|---------------------------------------------------------------------------------------|
| VDDIO                   | 1   | Interface power supply                                                                |
| BYP                     | 2   | Internal regulator output bypass capacitor connection                                 |
| Reserved                | 3   | Test reserved, connect to GND                                                         |
| SCL/SCLK                | 4   | I <sup>2</sup> C Serial Clock/SPI Clock                                               |
| GND                     | 5   | Ground                                                                                |
| SDA/MOSI                | 6   | I <sup>2</sup> C Serial Data/SPI Master Out, Slave In                                 |
| SA0/MISO <sup>[1]</sup> | 7   | I <sup>2</sup> C address selection bit 0/SPI Master In, Slave Out                     |
| n.c.                    | 8   | Internally not connected                                                              |
| INT2                    | 9   | Interrupt 2                                                                           |
| SA1/CS_B                | 10  | I <sup>2</sup> C address selection bit 1 <sup>[2]</sup> /SPI Chip Select (active low) |
| INT1                    | 11  | Interrupt 1                                                                           |
| GND                     | 12  | Ground                                                                                |
| Reserved                | 13  | Test reserved, connect to GND                                                         |
| VDD                     | 14  | Power supply                                                                          |
| N/C                     | 15  | Internally not connected                                                              |
| RST                     | 16  | Reset input, active high. Connect to GND if unused                                    |

<sup>[1]</sup> The SA0 pin is also used to select the desired serial interface mode during POR and also after a hard/soft reset event. See Section 10.2.3 for more information

FXLS84710

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

<sup>[2]</sup> See  $\underline{\text{Table 4}}$  for  $I^2C$  address options selectable using the SA0 and SA1 pins.

#### 7 Orientation



### 8 Electrical connections

Device power is supplied through the VDD pin. Power supply decoupling capacitors (100 nF ceramic plus 4.7  $\mu$ F bulk) should be placed as close as possible to pin 14 of the device. The digital interface supply voltage (VDDIO) should be decoupled with a 100 nF ceramic capacitor placed as close as possible to pin 1 of the device.

The digital control signals SCL, SDA, SA0, SA1 and RST are not tolerant of voltages exceeding VDDIO + 0.3 V. If VDDIO is removed, these pins will clamp any logic signals through their internal ESD protection diodes.

The function and timing of the two interrupt pins (INT1 and INT2) are user programmable through the  $I^2C/SPI$  interface. The SDA and SCL  $I^2C$  connections are open drain and therefore require a pullup resistor as shown in the application diagram in Figure 4. The INT1 and INT2 pins may also be configured for open-drain operation. If they are configured for open drain, external pullup resistors are required.



## 9 Terminology

#### 9.1 Sensitivity

Sensitivity is represented in mg/LSB; the accelerometer sensitivity changes with the full-scale range selected by the user. Accelerometer sensitivity is 0.244 mg/LSB in 2 g mode, 0.488 mg/LSB in 4 g mode, and 0.976 mg/LSB in 8 g mode.

#### 9.2 Zero-g offset

Zero-*g* offset describes the deviation of an actual output signal from the ideal output signal while the sensor is stationary. A sensor stationary on a horizontal surface will measure 0 *g* in X-axis and 0 *g* in Y-axis, whereas the Z-axis will measure 1 *g*. A deviation from an ideal value in this case is called *Zero-g* offset. Offset is, to some extent, a result of stress on the MEMS sensor. Therefore, the offset can slightly change after mounting the sensor onto a printed circuit board, or after exposure to extensive mechanical stress.

### 9.3 Self-test

Self-test can be used to verify the transducer and signal chain functionality without the need to apply an acceleration stimulus. When the accelerometer self-test is activated, an electrostatic actuation force is applied to the sensor, simulating a small acceleration. In this case the sensor X, Y, and Z outputs will exhibit a change in DC levels related to the selected full-scale range (sensitivity). When self-test is activated, the device output level is given by the algebraic sum of the signals produced by the acceleration acting on the sensor and by the electrostatic self-test force.

## 10 Digital interfaces

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

Table 3 I<sup>2</sup>C slave timing values<sup>[1]</sup>

| Symbol              | Parameter                                                                             |         | I <sup>2</sup> C fast mode |     | Unit |  |
|---------------------|---------------------------------------------------------------------------------------|---------|----------------------------|-----|------|--|
|                     |                                                                                       |         | Min Max                    |     |      |  |
| f <sub>SCL</sub>    | SCL clock frequency                                                                   |         | 0                          | 400 | kHz  |  |
| t <sub>BUF</sub>    | Bus free time between stop and start condition                                        |         | 1.3                        | _   | μs   |  |
| t <sub>HD;STA</sub> | (Repeated) start hold time                                                            |         | 0.6                        | _   | μs   |  |
| t <sub>SU;STA</sub> | (Repeated) start setup time                                                           |         | 0.6                        | _   | μs   |  |
| t <sub>SU;STO</sub> | STOP condition setup time                                                             |         | 0.6                        | _   | μs   |  |
| t <sub>HD;DAT</sub> | SDA data hold time                                                                    | [2]     | 0.05                       | 0.9 | μs   |  |
| t <sub>VD;DAT</sub> | SDA valid time                                                                        | [2] [3] | _                          | 0.9 | μs   |  |
| t <sub>VD;ACK</sub> | SDA valid acknowledge time                                                            | [2] [4] | _                          | 0.9 | μs   |  |
| t <sub>SU;DAT</sub> | SDA setup time                                                                        |         | 100                        | _   | ns   |  |
| t <sub>LOW</sub>    | SCL clock low time                                                                    |         | 1.3                        | _   | μs   |  |
| t <sub>HIGH</sub>   | SCL clock high time                                                                   |         | 0.6                        | _   | μs   |  |
| t <sub>r</sub>      | SDA and SCL rise time                                                                 | [5]     | 20 + 0.1 C <sub>b</sub>    | 300 | ns   |  |
| t <sub>f</sub>      | SDA and SCL fall time                                                                 | [5]     | 20 + 0.1 C <sub>b</sub>    | 300 | ns   |  |
| t <sub>SP</sub>     | Pulse width of spikes on SDA and SCL that must be suppressed by internal input filter |         | 0                          | 50  | ns   |  |

- All values referred to VIH (min) and VIL (max) levels
- This device does not stretch the low period (t<sub>LOW</sub>) of the SCL signal.
- [2]  $t_{VD;DAT}$  = time for data signal from SCL low to SDA output.
- $t_{D,ACK}$  = time for acknowledgement signal from SCL low to SDA output (high or low, depending on which one is worse)  $C_b$  = total capacitance of one bus line in pF.



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

There are two signals associated with the I<sup>2</sup>C bus: the serial clock line (SCL) and the serial data line (SDA). The latter is a bidirectional line used for sending and receiving the data to/from the interface. External pullup resistors connected to VDDIO are required for SDA and SCL. When the bus is free both the lines are high. The I<sup>2</sup>C interface

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

is compliant with fast mode (400 kHz), and normal mode (100 kHz) I<sup>2</sup>C standards. Operation at frequencies higher than 400 kHz is possible, but depends on several factors including the pullup resistor values, and total bus capacitance (trace + device capacitance). See <u>Table 4</u> for more information.

A transaction on the bus is started through a start condition (ST) signal, which is defined as a high-to-low transition on the data line while the SCL line is held high. After the ST signal has been transmitted by the master, the bus is considered busy. The next byte of data transmitted contains the slave address in the first seven bits, and the eighth bit, the read/write bit, indicates whether the master is receiving data from the slave or transmitting data to the slave. 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 master. The ninth clock pulse, following the slave 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 can't receive another complete byte of data until it has performed some other function, it can hold the clock line, SCL low to force the transmitter into a wait state. Data transfer only continues when the receiver is ready for another byte and releases the data line. This delay action is called clock stretching. Not all receiver devices support clock stretching. Not all master devices recognize clock stretching. This device does not employ clock stretching.

A low to high transition on the SDA line while the SCL line is high is defined as a stop condition (SP) signal. A write or burst write is always terminated by the master issuing the SP signal. A master should properly terminate a read by not acknowledging a byte at the appropriate time in the protocol. A master may also issue a repeated start signal (SR) during a transfer

The slave addresses that may be assigned to the FXLS8471Q part are 1Ch, 1Dh, 1Eh, or 1Fh. The selection is made through the logic level of the SA1 and SA0 inputs, as shown in Table 4.

Table 4. I<sup>2</sup>C slave address

| SA1 | SA0 | Slave address |
|-----|-----|---------------|
| 0   | 0   | 1Eh           |
| 0   | 1   | 1Dh           |
| 1   | 0   | 1Ch           |
| 1   | 1   | 1Fh           |

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

#### Single-byte read

The master (or MCU) transmits a start condition (ST) to the FXLS8471Q, followed by the slave address, with the R/W bit set to "0" for a write, and the FXLS8471Q sends an acknowledgment. Then the master (or MCU) transmits the address of the register to read and the FXLS8471Q sends an acknowledgment. The master (or MCU) transmits a repeated start condition (SR), followed by the slave address with the R/W bit set to "1" for a read from the previously selected register. The FXLS8471Q then acknowledges and

FXLS8471Q

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

transmits the data from the requested register. The master does not acknowledge (NAK) the transmitted data, but transmits a stop condition to end the data transfer.

#### Multiple-byte read

When performing a multi-byte or burst read, the FXLS8471Q automatically increments the register address read 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 registers after each FXLS8471Q acknowledgment (AK) is received until a no acknowledge (NAK) occurs from the master followed by a stop condition (SP) signaling an end of transmission.

#### Single-byte write

To start a write command, the master transmits a start condition (ST) to the FXLS8471Q, followed by the slave address with the R/W bit set to "0" for a write, and the FXLS8471Q sends an acknowledgment. Then the master (or MCU) transmits the address of the register to write to, and the FXLS8471Q sends an acknowledgment. Then the master (or MCU) transmits the 8-bit data to write to the designated register and the FXLS8471Q sends an acknowledgment that it has received the data. Because this transmission is complete, the master transmits a stop condition (SP) to end the data transfer. The data sent to the FXLS8471Q is now stored in the appropriate register.

#### Multiple-byte write

The FXLS8471Q 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 FXLS8471Q acknowledgment (ACK) is received.



#### 10.2 SPI interface characteristics

SPI interface is a classical master/slave serial port. The FXLS8471Q is always considered as the slave and thus is never initiating the communication.

<u>Table 5</u> and <u>Figure 7</u> describe the timing requirements for correct operation.

Table 5. SPI timing

| Function                              | Symbol | Min  | Max | Unit |
|---------------------------------------|--------|------|-----|------|
| Operating Frequency                   | Of     | _    | 1   | MHz  |
| SCLK Period                           | tSCLK  | 1000 | _   | ns   |
| SCLK High time                        | tCLKH  | 500  | _   | ns   |
| SCLK Low time                         | tCLKL  | 500  | _   | ns   |
| CS_B lead time                        | tSCS   | 65   | _   | ns   |
| CS_B lag time                         | tHCS   | 65   | _   | ns   |
| MOSI data setup time                  | tSET   | 25   | _   | ns   |
| MOSI data hold time                   | tHOLD  | 75   | _   | ns   |
| MISO data valid (after SCLK low edge) | tDDLY  | _    | 500 | ns   |
| Width CS High                         | tWCS   | 100  | _   | ns   |



#### 10.2.1 General SPI operation

The CS\_B pin is driven low at the start of a SPI transaction, held low for the duration of the transaction, and driven high after the transaction is complete. During a transaction the master toggles the SPI clock (SCLK) and transmits data on the MOSI pin.

A write operation is initiated by transmitting a 1 for the R/W bit. Then the 8-bit register address, ADDR[7:0] is encoded in the first and second serialized bytes. Data to be written starts in the third serialized byte. The order of the bits is as follows:

Byte 0: R/W,ADDR[6],ADDR[5],ADDR[4],ADDR[3],ADDR[2],ADDR[1],ADDR[0],

Byte 1: ADDR[7],X,X,X,X,X,X,X,

Byte 2: DATA[7], DATA[6], DATA[5], DATA[4], DATA[3], DATA[2], DATA[1], DATA[0].

Multiple bytes of DATA can be transmitted. The X indicates a bit that is ignored by the part. The register address is auto-incremented, so that the next clock edges will latch the data for the next register. When desired, the rising edge on CS\_B stops the SPI communication.

The FXLS8471Q SPI configuration is as follows:

Polarity: rising/fallingPhase: sample/setupOrder: MSB first

Data is sampled during the rising edge of SCLK and set up during the falling edge of SCLK.

### 10.2.2 SPI READ/WRITE operations

A READ operation is initiated by transmitting a 0 for the R/W bit. Then the 8-bit register address, ADDR[7:0] is encoded in the first and second serialized bytes. Subsequent bits are ignored by the part. The read data is deserialized from the MISO pin.

Similarly a WRITE operation is initiated by transmitting a 1 for the R/W bit. After the first and second serialized bytes multiple-data bytes can be transmitted into consecutive registers, starting from the indicated register address in ADDR[7:0].

A SPI transaction is started by asserting the CS\_B pin (high-to-low transition), and ended by deasserting the CS\_B pin (low-to-high transition).

FXLS8471Q

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

| R/W bit followed by ADDR[6:0] ADDR[7] followed by 7 "don't care" bits | Data0 | Data1 | - | Datan |
|-----------------------------------------------------------------------|-------|-------|---|-------|
|-----------------------------------------------------------------------|-------|-------|---|-------|

(1) Data bytes must be transmitted to the slave (FXLS8471Q) using the MOSI pin by the master when R/W = 1. Data bytes will be transmitted by the slave (FXLS8471Q) to the master using the MISO pin when R/W = 0. The first two bytes are always transmitted by the master using the MOSI pin. That is, a transaction is always initiated by master.

aaa-03211

Figure 8. SPI single-burst read/write transaction diagram

The registers embedded inside FXLS8471Q are accessed through either an I<sup>2</sup>C, or a SPI serial interface. To enable either interface the VDDIO line must be connected to the interface supply voltage. If VDD is not present and VDDIO is present FXLS8471Q is in shutdown mode and communications on the interface are ignored. If VDDIO is held high, VDD can be powered off and the communications pins will be automatically placed in a high impedance state. This will allow communications to continue on the bus with other devices while the FXLS8471Q is powered down.

Table 6. Serial interface pin descriptions

| Pin Name | Pin Description                                                                                  |
|----------|--------------------------------------------------------------------------------------------------|
| VDDIO    | Digital interface power                                                                          |
| SA1/CS_B | I <sup>2</sup> C second least significant bit of device address/SPI chip select                  |
| SCL/SCLK | I <sup>2</sup> C/SPI serial clock                                                                |
| SDA/MOSI | 1 <sup>2</sup> C serial data/SPI master serial data out slave serial data in                     |
| SA0/MISO | I <sup>2</sup> C least significant bit of the device address/SPI master serial data in slave out |

### 10.2.3 I<sup>2</sup>C/SPI auto detection

FXLS8471Q employs an interface mode auto-detection circuit that will select either I<sup>2</sup>C or SPI interface mode based on the state of the SA0 pin during power up or when exiting reset. Once set for I<sup>2</sup>C or SPI operation, the device will remain in I<sup>2</sup>C or SPI mode until the device is reset or powered down and the auto-detection process is repeated. Note that when SPI interface mode is desired, care must be taken to ensure that no other slave device drives the common SA0/MISO pin during the 1 ms period after a hard or soft reset or power-up event.

Table 7. I<sup>2</sup>C/SPI auto detection

| SA0      | Interface mode   |
|----------|------------------|
| GND      | I <sup>2</sup> C |
| VDDIO    | I <sup>2</sup> C |
| Floating | SPI              |

## 10.2.4 Power supply sequencing and I<sup>2</sup>C/SPI mode auto-detection

FXLS8471Q does not have any specific power supply sequencing requirements between VDD and VDDIO voltage supplies to ensure correct power-up and operation. To ensure correct operation of the I<sup>2</sup>C/SPI auto-detection function, VDDIO should be applied before or at the same time as VDD. If this order cannot be maintained, the user should either pulse the RST line high or power cycle the VDD rail in order to force the auto-detect function to restart and correctly identify the desired interface. FXLS8471Q will indicate completion of the reset sequence by toggling the INT1 pin from logic high to low to high over a 500 ns period. If the INT1 pin was already low prior to the reset event, it will only go high, and not toggle.

FXLS8471Q

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

## 11 Absolute maximum ratings

Stresses above those listed as "absolute maximum ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device under these conditions is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

#### Table 8. Maximum ratings

|                      | 9                                                                              |                     |      |
|----------------------|--------------------------------------------------------------------------------|---------------------|------|
| Symbol               | Rating                                                                         | Value               | Unit |
| g <sub>max</sub>     | Maximum acceleration (all axes, 100 μs)                                        | 5000                | g    |
| VDD <sub>max</sub>   | Supply voltage, interface supply voltage                                       | -0.3 to +3.6        | V    |
| VDDIO <sub>max</sub> | Supply voltage, IO voltage                                                     | -0.3 to +3.6        | V    |
| VIN <sub>max</sub>   | Input voltage on any control pin (SA0/MISO, SA1/CS_B, SCL/SCLK, SDA/MOSI, RST) | -0.3 to VDDIO + 0.3 | V    |
| D <sub>drop</sub>    | Drop-test height                                                               | 1.8                 | m    |
| T <sub>STG</sub>     | Storage temperature range                                                      | -40 to +125         | °C   |

#### Table 9. ESD and latchup protection characteristics

| Symbol          | Rating                                           | Value | Unit |
|-----------------|--------------------------------------------------|-------|------|
| HBM             | Human body model                                 | ±2000 | V    |
| MM              | Machine model                                    | ±200  | V    |
| CDM             | Charge device model                              | ±500  | V    |
| I <sub>LU</sub> | Latchup current at T = 105 °C (per AEC-Q100-004) | ±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). Improper handling can cause permanent damage to the part.

### 12 Mechanical characteristics

#### **Table 10. Mechanical characteristics**

VDD = 1.8 to 3.3 V, VDDIO = 1.8 V, T = 25 °C, unless otherwise noted.

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

| Parameter                                                       |             | Test conditions                             | Symbol               | Min                | Тур   | Max                  | Unit   |  |
|-----------------------------------------------------------------|-------------|---------------------------------------------|----------------------|--------------------|-------|----------------------|--------|--|
| Measurement range <sup>[1]</sup>                                |             | ±2 g mode                                   | FSR                  |                    | ±2    |                      | g      |  |
|                                                                 |             | ±4 g mode                                   |                      |                    | ±4    |                      |        |  |
|                                                                 |             | ±8 g mode                                   |                      |                    | ±8    |                      |        |  |
| Sensitivity                                                     |             | ±2 g mode, –40°C to 105°C                   | SEN                  | 3686               | 4096  | 4506                 | LSB/g  |  |
|                                                                 |             |                                             |                      | 0.220              | 0.244 | 0.268                | mg/LSB |  |
|                                                                 |             | ±4 g mode, –40°C to 105°C                   | _                    | 1843               | 2048  | 2253                 | LSB/g  |  |
|                                                                 |             |                                             |                      | 0.439              | 0.488 | 0.537                | mg/LSB |  |
|                                                                 |             | ±8 g mode, –40°C to 105°C                   |                      | 922                | 1024  | 1126                 | LSB/g  |  |
|                                                                 |             |                                             |                      | 0.878              | 0.976 | 1.074                | mg/LSB |  |
| Sensitivity change with temperature <sup>[1]</sup>              |             | ±2 g, ±4 g, ±8 g modes                      | TCS                  |                    | ±0.01 |                      | %/°C   |  |
| Sensitivity accuracy                                            |             | @ 25°C                                      | SEN-TOL              | -10                | ±2.5  | +10                  | %SEN   |  |
| Zero- <i>g</i> level offset accuracy <sup>[2]</sup>             |             | ±2 g, ±4 g, ±8 g ranges, 25 °C              | OFF <sub>RT</sub>    |                    | ±20   |                      | mg     |  |
|                                                                 |             | ±2 <i>g</i> range, –40 °C to 105 °C         | OFF <sub>OT-2G</sub> | -80                |       | +80                  | 1      |  |
| Zero- $g$ level offset accuracy post-board mount <sup>[3]</sup> |             | ±2 g, ±4 g, ±8 g modes                      | OFF <sub>PBM</sub>   |                    | ±30   |                      | mg     |  |
| Zero- <i>g</i> level change versus temperature <sup>[1]</sup>   |             | –40°C to 85°C                               | TCO <sub>TR1</sub>   |                    | ±0.2  |                      | mg/°C  |  |
|                                                                 |             | –40°C to 105°C                              | TCO <sub>TR2</sub>   |                    | ±0.3  |                      |        |  |
| Cross-axis sensitivity                                          |             | Over ±1 <i>g</i> range in Normal mode       | CAS                  |                    | ±0.5  |                      | %FS    |  |
| Nonlinearity (deviation from straight line) <sup>[4][5]</sup>   |             | Over ±1 <i>g</i> range in Normal mode       | NL                   |                    | ±0.5  |                      | %FSR   |  |
| Self-Test output change <sup>[6]</sup>                          | X<br>Y<br>Z | ±2 <i>g</i> range, –40 °C to 105 °C         | STOC <sub>OT</sub>   | 192<br>270<br>1275 |       | 1000<br>1000<br>6000 | LSB    |  |
| Output noise density <sup>[4][7]</sup>                          |             | ODR = 400 Hz, normal mode                   | ND <sub>NM</sub>     |                    | 126   |                      | μg/√Hz |  |
|                                                                 |             | ODR = 400 Hz, low-noise mode <sup>[1]</sup> | ND <sub>LNM</sub>    |                    | 99    |                      | µg/√Hz |  |
| Operating temperature range                                     |             |                                             | Тор                  | -40                |       | +105                 | °C     |  |

Dynamic range is limited to  $\pm 4~g$  when in the low-noise mode.

Before board mount.

Post-board mount offset specifications are based on a 2-layer PCB design.

Determined through bench evaluation (small number of typical devices measured at room temperature).

After post-board mount corrections for sensitivity, cross axis and offset. Refer to AN4399 for more information.

<sup>[6]</sup> Self-test is only exercised along one direction for each sensitive axis.

Measured using earth's gravitational field (1 g) with the device oriented horizontally (+Z axis up) and stationary.

## 13 Electrical characteristics

#### **Table 11. Electrical characteristics**

 $VDD = 1.8 \text{ to } 3.3 \text{ V}, VDDIO = 1.8 \text{ V}, T = 25 ^{\circ}\text{C}, unless otherwise noted.}$ 

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

| •                                                                         | , ,                                                                           |                           |            |           |           |      |
|---------------------------------------------------------------------------|-------------------------------------------------------------------------------|---------------------------|------------|-----------|-----------|------|
| Parameter                                                                 | Test Conditions                                                               | Symbol                    | Min        | Тур       | Max       | Unit |
| Supply voltage                                                            |                                                                               | VDD                       | 1.95       | 3.3       | 3.6       | V    |
| Interface supply voltage                                                  |                                                                               | VDDIO                     | 1.62       | 3.3       | 3.6       | V    |
| I <sub>DD</sub> in low-power mode, 25 °C                                  | ODR = 12.5 Hz                                                                 | Idd <sub>LPM-RT</sub>     |            | 8         |           | μΑ   |
|                                                                           | ODR = 100 Hz                                                                  |                           |            | 35        |           |      |
|                                                                           | ODR = 400 Hz                                                                  |                           |            | 130       |           |      |
| I <sub>DD</sub> in normal mode, 25 °C                                     | ODR = 50 Hz                                                                   | Idd <sub>NM-RT</sub>      |            | 35        |           | μΑ   |
|                                                                           | ODR = 200 Hz                                                                  |                           |            | 130       |           |      |
|                                                                           | ODR = 800 Hz                                                                  |                           |            | 240       |           |      |
| I <sub>DD</sub> in normal mode, –40 °C to 105 °C                          | ODR = 400 Hz                                                                  | Idd <sub>NM-OT</sub>      |            |           | 150       | μΑ   |
|                                                                           | ODR = 800 Hz                                                                  |                           |            |           | 274       |      |
| Peak current during boot sequence                                         | VDD = 2.5 V; 25 °C; 1ms max duration, using the recommended bypass capacitors | Idd <sub>BOOT</sub>       |            |           | 3         | mA   |
| Value of capacitor on BYP pin                                             | -40°C to 105°C                                                                | C <sub>BYP</sub>          | 75         | 100       | 470       | nF   |
| Standby mode current, 25°C                                                | Standby mode                                                                  | Idd <sub>STBY-RT</sub>    |            | 2         |           | μA   |
| Standby mode current, -40 °C to 105 °C                                    | Standby mode; –40 to +105 °C                                                  | Idd <sub>STBY-OT</sub>    |            |           | 13.5      | μΑ   |
| Digital high-level input voltage RST pin                                  |                                                                               | VIH <sub>RST</sub>        | 1.04       |           |           | V    |
| Digital low-level input voltage RST pin                                   |                                                                               | VIL <sub>RST</sub>        |            |           | 0.68      | V    |
| Digital high-level input voltage SCL/SCLK, SDA/MOSI, SA0/MISO, SA1/CS_B   |                                                                               | VIH                       | 0.75*VDDIO |           |           | V    |
| Digital low-level input voltage<br>SCL/SCLK, SDA/MOSI, SA0/MISO, SA1/CS_B |                                                                               | VIL                       |            |           | 0.3*VDDIO | V    |
| High-level output voltage<br>INT1, INT2, SDA/MOSI                         | Ι <sub>Ο</sub> = 500 μΑ                                                       | VOH                       | 0.9*VDDIO  |           |           | V    |
| Low-level output voltage<br>INT1, INT2, SDA/MOSI                          | Ι <sub>Ο</sub> = 500 μΑ                                                       | VOL                       |            |           | 0.1*VDDIO | V    |
| SCL, SDA pin leakage                                                      | 25°C                                                                          |                           |            | 1.0       |           | nA   |
|                                                                           | –40°C to 105°C                                                                | _                         |            | 10        |           |      |
| SCL, SDA pin capacitance                                                  |                                                                               |                           |            | 3         |           | pf   |
| VDD rise time                                                             |                                                                               |                           | 0.001      |           | 1000      | ms   |
| Boot time <sup>[1]</sup>                                                  |                                                                               | T <sub>BOOT</sub>         |            |           | 1000      | μs   |
| Turn-on time 1 <sup>[2]</sup>                                             |                                                                               | $T_{POR \rightarrow ACT}$ |            | 2/ODR + 2 |           | ms   |
| Turn-on time 2 <sup>[3]</sup>                                             |                                                                               | $T_{STBY\rightarrow ACT}$ |            | 2/ODR + 1 |           | ms   |
| ODR accuracy                                                              |                                                                               |                           |            | ±2        |           | %    |
| Operating temperature range                                               |                                                                               | T <sub>OP</sub>           | -40        |           | +105      | °C   |

Time from VDDIO on and VDD > VDD min until  $I^2C/SPI$  interface ready for operation.

Time to obtain valid data from power-down mode to Active mode. Time to obtain valid data from Standby mode to Active mode.

## 14 Temperature sensor characteristics

#### **Table 12. Temperature characteristics**

VDD = 1.8 to 3.3 V, VDDIO = 1.8 V, unless otherwise noted.

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

| Parameter                                       | Test conditions | Symbol                  | Min | Тур         | Max | Unit   |
|-------------------------------------------------|-----------------|-------------------------|-----|-------------|-----|--------|
| Output data width                               | _               | n <sub>TEMP</sub>       |     | 8           |     | bits   |
| Measurement range                               | _               | FSR <sub>TEMP</sub>     |     | -40 to +125 |     | °C     |
| Sensitivity                                     | _               | SEN <sub>TEMP</sub>     |     | 0.96        |     | °C/LSB |
| Sensitivity tolerance                           | _               | SEN <sub>TOL-TEMP</sub> |     | ±2.5        |     | %      |
| Nominal ambient temperature at zero output code | TEMP_OUT = 00h  |                         |     | 25          |     | °C     |

## 15 Modes of operation



Figure 9. FXLS8471Q power mode transition diagram

Table 13. Mode of operation description

| Mode                   | I <sup>2</sup> C/SPI Bus state                                      | VDD     | VDDIO                                               | Function description                                                                                   |
|------------------------|---------------------------------------------------------------------|---------|-----------------------------------------------------|--------------------------------------------------------------------------------------------------------|
| OFF                    | Powered down                                                        | < 1.8 V | VDDIO can be > VDD                                  | The device is powered off. All analog and digital blocks are shutdown. I <sup>2</sup> C bus inhibited. |
| Standby                | I <sup>2</sup> C/SPI communication<br>with FXLS8471Q is<br>possible | ON      | VDDIO = High<br>VDD = High<br>Active bit is cleared | Only digital blocks are enabled. Analog subsystem is disabled. Internal clocks disabled.               |
| Active<br>(Wake/Sleep) | I <sup>2</sup> C/SPI communication<br>with FXLS8471Q is<br>possible | ON      | VDDIO = High<br>VDD = High<br>Active bit is set     | All blocks are enabled (digital and analog).                                                           |

All register contents are preserved when transitioning from Active to Standby mode, but some registers are reset when transitioning from Standby to Active. These registers are noted in <u>Table 1</u>. The Sleep and Wake modes are active modes. For more information on how to use the Sleep and Wake modes and configuring the device to transition between them, refer to <u>Section 16 "Embedded functionality"</u> or NXP application note AN4074.

## 16 Embedded functionality

FXLS8471Q is a low-power, digital output, 3-axis sensor with both I<sup>2</sup>C and SPI interfaces. Extensive embedded functionality is provided to detect inertial events at low power, with the ability to notify the host processor of an event using either of the two programmable interrupt pins. The embedded functionality includes:

- 8-bit or 14-bit acceleration data that includes high-pass filtered data, including the option to employ a high-pass filter on the output.
- Four different oversampling options for the output data. The oversampling settings allow the end user to optimize the resolution (noise) versus power trade-off in a given application.
- A low-noise mode that functions independently of the oversampling modes for even higher resolution
- Low-power, auto-wake/sleep function for conserving power in portable battery powered applications
- Pulse-detection circuit, which can be used to detect directional single and double taps
- Directional motion-event and free-fall-event detection with programmable threshold and debounce time
- Transient detection with programmable threshold and debounce time. Transient detection can employ either a high-pass filter or use the difference between reference and current sample values.
- Orientation detection with programmable hysteresis for smooth transitions between portrait/landscape orientations
- Vector-magnitude change event detection with programmable reference, threshold, and debounce time values

Many different configurations of the above functions are possible to suit the needs of the end application. Separate application notes are available to further explain the different configuration settings and potential use cases.

## 16.1 Factory calibration

FXLS8471Q is factory calibrated for sensitivity and offset on each axis. The trim values are stored in NonVolatile Memory (NVM). On startup, the trim parameters are read from NVM and applied to the internal compensation circuitry. After mounting the device to the PCB, the user can further adjust the accelerometer offsets through the OFF\_X/Y/Z registers. For more information on accelerometer calibration, refer to NXP application note AN4069.

#### 16.2 8-bit or 14-bit data

The measured acceleration data is stored in the OUT\_X\_MSB, OUT\_X\_LSB, OUT\_Y\_MSB, OUT\_Y\_LSB, OUT\_Z\_MSB, and OUT\_Z\_LSB registers as two's complement 14-bit numbers. The most significant 8-bits of each axis are stored in the OUT\_X/Y/Z\_MSB registers, so applications needing only 8-bit results simply read these three registers and ignore the OUT\_X/Y/Z\_LSB registers. To do this, the *f\_read* mode bit in CTRL\_REG1 must be set.

When the full-scale range is set to 2 g, the measurement range is -2~g to +1.999~g, and each count corresponds to 0.244 mg at  $\pm 14$ -bits resolution. When the full-scale is set to 8 g, the measurement range is -8~g to +7.996~g, and each count corresponds to 0.976 mg. The resolution is reduced by a factor of 64 if only the 8-bit results are used

FXLS8471C

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

(CTRL\_REG1[*f\_read*] = 1). For further information on the different data formats and modes, please refer to NXP application note AN4076.

### 16.3 Low-power modes versus high-resolution modes

FXLS8471Q can be optimized for lower power or higher resolution of the accelerometer output data. High resolution is achieved by setting the Inoise bit in register 2Ah. This improves the resolution (by lowering the noise), but be aware that the dynamic range becomes fixed at  $\pm 4~g$  when this bit is set. This will affect all internal embedded functions (scaling of thresholds, etc.) and reduce noise. Another method for improving the resolution of the data is through oversampling. One of the oversampling schemes of the output data can be activated when CTRL\_REG2[mods] = 0b, which improves the resolution of the output data without affecting the internal embedded functions or usable dynamic range.

There is a trade-off between low power and high resolution. Low power can be achieved when the oversampling rate is reduced. When CTRL\_REG2[mods] = 0b, the lowest power is achieved, at the expense of higher noise. In general, the lower the selected ODR and OSR, the lower the power consumption. For more information on how to configure the device in low-power or high-resolution modes and understand the benefits and trade-offs, please refer to NXP application note AN4075.

### 16.4 Auto-Wake and Auto-Sleep modes

FXLS8471Q can be configured to transition between sample rates (with their respective current consumptions) based on the status of the embedded interrupt event generators in the device. The advantage of using the auto-wake/sleep is that the system can automatically transition to a higher sample rate (higher current consumption) when needed but spends the majority of the time in the sleep mode (lower current) when the device does not require higher sampling rates. Auto-wake refers to the device being triggered by one of the interrupt event functions to transition to a higher sample rate. This may also interrupt the processor to transition from a sleep mode to a higher power mode.

Sleep mode occurs when none of the enabled interrupt event functions has detected an interrupt within the user-defined, time-out period. The device will then transition to the specified lower sample rate. It can also alert the processor to go into a lower power mode to save power during this period of inactivity. Refer to AN4074 for more detailed information on configuring the Auto-Wake/Sleep function.

#### 16.5 Free-fall and Motion event detection

The freefall/motion detection block can be configured to detect low-g (freefall) or high-g (motion) events utilizing the A\_FFMT\_CFG[a\_ffmt\_oae] bit.

In low-g detect mode (A\_FFMT\_CFG[a\_ffmt\_oae] = 0) a low-g condition will need to occur on all enabled axes (ex. X, Y and Z) for the A\_FFMT\_SRC[a\_ffmt\_ea] bit to be affected. And, in high-g detect mode (A\_FFMT\_CFG[a\_ffmt\_oae] = 1) a high-g condition occurring in any of the enabled axes (ex. X, Y or Z) will suffice to affect the A FFMT\_SRC[a\_ffmt\_ea] bit.

The detection threshold(s) are programed in register 17h (A\_FFMT\_THS) for common threshold operation, and 73h to 78h (A\_FFMT\_THS\_X/Y/Z) for individual axis threshold operation.

FXLS8471Q

A\_FFMT\_CFG[a\_ffmt\_ele] bit determines the behavior of A\_FFMT\_SRC[a\_ffmt\_ea] bit in response to the desired acceleration event (low-g/high-g). When A\_FFMT\_CFG[a\_ffmt\_ele] = 1, the freefall or motion event is latched and the A\_FFMT\_SRC[a\_ffmt\_ea] flag can only be cleared by reading the A\_FFMT\_SRC register. When A\_FFMT\_CFG[a\_ffmt\_ele] = 0, freefall or motion events are not latched, and the A\_FFMT\_SRC[a\_ffmt\_ea] bit reflects the real-time status of the event detection.

A\_FFMT\_THS[a\_ffmt\_dbcntm] bit determines the debounce filtering behavior of the logic that sets the A\_FFMT\_SRC[a\_ffmt\_ea] bit. See <u>Figure 17</u> for details.

It is possible to enable/disable each axis used in the freefall/motion detection function by configuring bits A\_FFMT\_CFG[a\_ffmt\_xefe], A\_FFMT\_CFG[a\_ffmt\_yefe], and A FFMT CFG[a ffmt zefe].

The freefall/motion detection function has the option to use a common 7-bit unsigned threshold for each of the X, Y, and Z axes, or individual unsigned 13-bit thresholds for each axis. When A\_FFMT\_THS\_X\_MSB[a\_ffmt\_ths\_xyz\_en] = 0, the 7-bit threshold value stored in register 17h is used as a common 7-bit threshold for the X, Y, and Z axes. When a\_ffmt\_ths\_xyz\_en = 1, each axis may be programmed with an individual 13-bit threshold (stored in the A\_FFMT\_X/Y/Z MSB and LSB registers).

#### 16.5.1 Free fall detection

The detection of free fall involves the monitoring of the X, Y, and Z axes for the condition where the acceleration magnitude is below a user-specified threshold for a user-definable amount of time. Typically, the usable threshold ranges are between  $\pm 100$  mg and  $\pm 500$  mg.

#### 16.5.2 Motion detection

Motion detection is often used to alert the main processor that the device is currently in use. When the acceleration exceeds a set threshold for a set amount of time, the motion interrupt is asserted. A motion can be a fast moving shake or a slow moving tilt. This will depend on the threshold and timing values configured for the event. The motion detection function can analyze static acceleration changes or faster jolts. The timing value is set by a configurable debounce counter. The debounce counter acts like a filter to indicate whether the condition exists for longer than a set amount of time (that is, 100 ms or longer). There is also directional data available in the source register to detect the direction of the motion that generated the interrupt. This is useful for applications such as directional shake or flick detection, and can also assist gesture detection algorithms by indicating that a motion gesture has started.

#### 16.6 Transient detection

FXLS8471Q integrates an acceleration transient detection function that incorporates a high-pass filter. Acceleration data goes through the high-pass filter, eliminating the DC tilt/offset and low frequency acceleration changes. The high-pass filter cutoff can be set by the user to four different frequencies which are dependent on the selected output data rate. A higher cutoff frequency ensures that DC and slowly changing acceleration data will be filtered out, allowing only the higher frequencies to pass. The transient detection feature can be used in the same manner as the motion detection by bypassing the high-pass filter. There is an option in the configuration register to do this. This adds more flexibility to cover the various customer use cases.

Many applications use the accelerometer's static acceleration readings (that is, tilt) which measure the change in acceleration due to gravity only. These functions benefit from acceleration data being filtered with a low-pass filter where high-frequency data is considered noise. However, there are many functions where the accelerometer must analyze dynamic acceleration. Functions such as tap, flick, shake and step counting are based on the analysis of the change in the dynamic acceleration. The transient detection function can be routed to either interrupt pin through bit 5 in CTRL\_REG5 register (2Eh). Registers 1Dh to 20h are used for configuring the transient detection function. The source register contains directional data to determine the direction of the transient acceleration, either positive or negative. For further information of the embedded transient detection function along with specific application examples and recommended configuration settings, refer to NXP application note AN4461.

#### 16.7 Pulse detection

FXLS8471Q has embedded single/double and directional pulse detection. This function employs several timers for programming the pulse width time and the latency between pulses. The detection thresholds are independently programmable for each axis. The acceleration data input to the pulse detection circuit can be put through both high and low-pass filters, allowing for greater flexibility in discriminating between pulse and tap events. The PULSE\_SRC register provides information on the axis, direction (polarity), and single/double event status for the detected pulse or tap. For more information on how to configure the device for pulse detection, refer to NXP application note AN4072.

#### 16.8 Orientation detection

FXLS8471Q has an embedded orientation detection algorithm with the ability to detect all six orientations. The transition angles and hysteresis are programmable, allowing for a smooth transition between portrait and landscape orientations.

The angle at which the device no longer detects the orientation change is referred to as the "Z-lockout angle". The device operates down to  $29^{\circ}$  from the flat position. All angles are accurate to  $\pm 2^{\circ}$ .

For further information on the orientation detection function refer to NXP application note AN4068.

### 16.9 Acceleration vector-magnitude detection

FXLS8471Q incorporates an acceleration vector-magnitude change detection block that can be configured to generate an interrupt when the acceleration magnitude exceeds a preset threshold for a programmed debounce time. The function can be configured to operate in absolute or relative modes, and can also act as a wake to sleep or sleep-to-wake transition source. This function is useful for detecting acceleration transients when operated in absolute mode, or for detecting changes in orientation when operated in relative mode. Refer to NXP application note AN4692.

## 17 Register Map

#### Table 14. Register address map

#### Auto-Increment addresses:

A. STATUS[f\_mode] = 00, CTRL\_REG1[f\_read] = 0

**B**. STATUS[f\_mode] > 00, CTRL\_REG1[f\_read] = 0

C. STATUS[f\_mode] = 00, CTRL\_REG1[f\_read] = 1

**D**. STATUS[f\_mode] > 00, CTRL\_REG1[f\_read] = 1

| Name                           | Туре | Register   | Auto-increment address |     |            | ess                                                                      | Default                                                             | Comment                                                                                                       |  |  |
|--------------------------------|------|------------|------------------------|-----|------------|--------------------------------------------------------------------------|---------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|--|--|
|                                |      | address    | Α                      | В   | С          | D                                                                        | hex<br>value                                                        |                                                                                                               |  |  |
| STATUS <sup>[1][2]</sup>       | R    | 00h        |                        | 01h |            | 00h                                                                      | Real-time, data-ready status or FIFO status (DR_STATUS or F_STATUS) |                                                                                                               |  |  |
| OUT_X_MSB <sup>[1][2]</sup>    | R    | 01h        | 02h                    | 01h | 03h        | 01h                                                                      | _                                                                   | [7:0] are 8 MSBs of 14-bit sample. Root pointer to XYZ FIFO data.                                             |  |  |
| OUT_X_LSB <sup>[1][2]</sup>    | R    | 02h        | 0:                     | 3h  | 0          | Oh                                                                       | _                                                                   | [7:2] are 6 LSBs of 14-bit sample                                                                             |  |  |
| OUT_Y_MSB <sup>[1][2]</sup>    | R    | 03h        | 04                     | 4h  | 05h        | 00h                                                                      | _                                                                   | [7:0] are 8 MSBs of 14-bit sample                                                                             |  |  |
| OUT_Y_LSB <sup>[1][2]</sup>    | R    | 04h        | 0:                     | 5h  | 0          | Oh                                                                       | _                                                                   | [7:2] are 6 LSBs of 14-bit sample                                                                             |  |  |
| OUT_Z_MSB <sup>[1][2]</sup>    | R    | 05h        | 0                      | 6h  | 0          | )h                                                                       | _                                                                   | [7:0] are 8 MSBs of 14-bit sample                                                                             |  |  |
| OUT_Z_LSB <sup>[1][2]</sup>    | R    | 06h        | 0                      | 0h  | 0          | Oh                                                                       | _                                                                   | [7:2] are 6 LSBs of 14-bit sample                                                                             |  |  |
| Reserved                       | _    | 07h to 08h |                        | _   | _          |                                                                          | _                                                                   | Reserved, do not modify                                                                                       |  |  |
| F_SETUP <sup>[1][3]</sup>      | R/W  | 09h        |                        | 0/  | <b>4</b> h |                                                                          | 00h                                                                 | FIFO setup                                                                                                    |  |  |
| TRIG_CFG                       | R/W  | 0Ah        |                        | Ol  | Bh         |                                                                          | 00h                                                                 | FIFO event trigger configuration register                                                                     |  |  |
| SYSMOD <sup>[1][2]</sup>       | R    | 0Bh        |                        | 00  | Ch         |                                                                          | 00h                                                                 | Current system mode                                                                                           |  |  |
| INT_SOURCE <sup>[1][2]</sup>   | R    | 0Ch        |                        | 10  | Ͻh         |                                                                          | 00h                                                                 | Interrupt status                                                                                              |  |  |
| WHO_AM_I <sup>[1]</sup>        | R    | 0Dh        |                        | Ol  | Εh         |                                                                          | 6Ah                                                                 | Device ID                                                                                                     |  |  |
| XYZ_DATA_CFG <sup>[1][4]</sup> | R/W  | 0Eh        |                        | OI  | Fh         |                                                                          | 00h                                                                 | Acceleration dynamic range and filter enable settings                                                         |  |  |
| HP_FILTER_CUTOFF[1][4]         | R/W  | 0Fh        |                        | 10  | 0h         |                                                                          | 00h                                                                 | Pulse detection high-pass and low-<br>pass filter enable bits. High-pass<br>filter cutoff frequency selection |  |  |
| PL_STATUS <sup>[1][2]</sup>    | R    | 10h        |                        | 1   | 1h         |                                                                          | 00h                                                                 | Landscape/Portrait orientation status                                                                         |  |  |
| PL_CFG <sup>[1][4]</sup>       | R/W  | 11h        |                        | 1:  | 2h         |                                                                          | 80h                                                                 | Landscape/Portrait configuration.                                                                             |  |  |
| PL_COUNT <sup>[1][3]</sup>     | R/W  | 12h        |                        | 1;  | 3h         |                                                                          | 00h                                                                 | Landscape/Portrait debounce counter                                                                           |  |  |
| PL_BF_ZCOMP <sup>[1][4]</sup>  | R/W  | 13h        |                        | 14  | 4h         |                                                                          | 00h                                                                 | Back/Front Trip angle threshold                                                                               |  |  |
| PL_THS_REG <sup>[1][4]</sup>   | R/W  | 14h        | 15h                    |     | 1Ah        | Portrait to Landscape Trip<br>Threshold angle and hysteresis<br>settings |                                                                     |                                                                                                               |  |  |
| A_FFMT_CFG <sup>[1][4]</sup>   | R/W  | 15h        | 16h                    |     | 00h        | Free-fall/Motion function configuration                                  |                                                                     |                                                                                                               |  |  |
| A_FFMT_SRC <sup>[1][2]</sup>   | R    | 16h        | 17h                    |     | 00h        | Free-fall/Motion event source register                                   |                                                                     |                                                                                                               |  |  |
| A_FFMT_THS <sup>[1][3]</sup>   | R/W  | 17h        |                        | 18  | 8h         |                                                                          | 00h                                                                 | Free-fall/Motion threshold register                                                                           |  |  |
| A_FFMT_COUNT <sup>[1][3]</sup> | R/W  | 18h        |                        | 19  | 9h         |                                                                          | 00h                                                                 | Free-fall/Motion debounce counter                                                                             |  |  |

| Name                            | Туре | Register   | Aut | o-incren | nent addr | ess                                                  | Default      | Comment                                                                                 |
|---------------------------------|------|------------|-----|----------|-----------|------------------------------------------------------|--------------|-----------------------------------------------------------------------------------------|
|                                 |      | address    | Α   | В        | С         | D                                                    | hex<br>value |                                                                                         |
| Reserved                        | _    | 19h to 1Ch |     | _        | _         |                                                      | _            | Reserved, do not modify                                                                 |
| TRANSIENT_CFG <sup>[1][4]</sup> | R/W  | 1Dh        | 1Eh |          | 00h       | Transient function configuration                     |              |                                                                                         |
| TRANSIENT_SRC <sup>[1][2]</sup> | R    | 1Eh        |     | 1        | -h        |                                                      | 00h          | Transient event status register                                                         |
| TRANSIENT_THS[1][3]             | R/W  | 1Fh        |     | 2        | Oh        |                                                      | 00h          | Transient event threshold                                                               |
| TRANSIENT_COUNT[1][3            | R/W  | 20h        |     | 2        | 1h        |                                                      | 00h          | Transient debounce counter                                                              |
| PULSE_CFG <sup>[1][4]</sup>     | R/W  | 21h        |     | 2        | 2h        |                                                      | 00h          | Pulse function configuration                                                            |
| PULSE_SRC <sup>[1][2]</sup>     | R    | 22h        |     | 2        | 3h        |                                                      | 00h          | Pulse function source register                                                          |
| PULSE_THSX <sup>[1][3]</sup>    | R/W  | 23h        |     | 2        | 4h        |                                                      | 00h          | X-axis pulse threshold                                                                  |
| PULSE_THSY <sup>[1][3]</sup>    | R/W  | 24h        |     | 2        | 5h        |                                                      | 00h          | Y-axis pulse threshold                                                                  |
| PULSE_THSZ <sup>[1][3]</sup>    | R/W  | 25h        |     | 2        | 6h        |                                                      | 00h          | Z-axis pulse threshold                                                                  |
| PULSE_TMLT <sup>[1][4]</sup>    | R/W  | 26h        |     | 2        | 7h        |                                                      | 00h          | Time limit for pulse detection                                                          |
| PULSE_LTCY <sup>[1][4]</sup>    | R/W  | 27h        |     | 2        | 3h        |                                                      | 00h          | Latency time for second pulse detection                                                 |
| PULSE_WIND <sup>[1][4]</sup>    | R/W  | 28h        |     | 2        | 9h        |                                                      | 00h          | Window time for second pulse detection                                                  |
| ASLP_COUNT <sup>[1][4]</sup>    | R/W  | 29h        |     | 2.       | Ah        |                                                      | 00h          | In activity counter setting for Auto-<br>Sleep                                          |
| CTRL_REG1 <sup>[1][4]</sup>     | R/W  | 2Ah        |     | 2        | 3h        |                                                      | 00h          | System ODR, accelerometer OSR, operating mode                                           |
| CTRL_REG2 <sup>[1][4]</sup>     | R/W  | 2Bh        |     | 20       | Ch        |                                                      | 00h          | Self-Test, Reset, accelerometer OSR and Sleep mode settings                             |
| CTRL_REG3 <sup>[1][4]</sup>     | R/W  | 2Ch        |     | 21       | Oh        |                                                      | 00h          | Sleep mode interrupt wake enable, interrupt polarity, push-pull/opendrain configuration |
| CTRL_REG4 <sup>[1][4]</sup>     | R/W  | 2Dh        |     | 2        | Ξh        |                                                      | 00h          | Interrupt enable register                                                               |
| CTRL_REG5[1][4]                 | R/W  | 2Eh        |     | 2        | -h        |                                                      | 00h          | Interrupt pin (INT1/INT2) map                                                           |
| OFF_X[1][4]                     | R/W  | 2Fh        |     | 3        | )h        |                                                      | 00h          | X-axis accelerometer offset adjust                                                      |
| OFF_Y <sup>[1][4]</sup>         | R/W  | 30h        |     | 3        | 1h        |                                                      | 00h          | Y-axis accelerometer offset adjust                                                      |
| OFF_Z[1][4]                     | R/W  | 31h        |     | 3        | 2h        |                                                      | 00h          | Z-axis accelerometer offset adjust                                                      |
| Reserved                        | R/W  | 32h to 50h |     | _        | _         |                                                      | _            | Reserved, do not modify                                                                 |
| TEMP_OUT                        | R    | 51h        |     | -        | _         |                                                      | _            | Temperature sensor output data                                                          |
| Reserved                        | R/W  | 52h to 5Ah |     | -        | _         |                                                      | _            | Reserved, do not modify                                                                 |
| CTRL_REG6                       | R/W  | 5Bh        |     | 50       | Ch        |                                                      | 00h          | Temperature sensor enable/disable control                                               |
| CTRL_REG7                       | R/W  | 5Ch        |     | 51       | Oh        |                                                      | 00h          | Temperature sensor auto-<br>increment address range inclusion<br>enable/disable         |
| Reserved                        | R/W  | 5Dh to 5Eh | _   |          | _         | Reserved, do not modify                              |              |                                                                                         |
| A_VECM_CFG                      | R/W  | 5Fh        | 60h |          | 00h       | Acceleration vector-magnitude configuration register |              |                                                                                         |
| A_VECM_THS_MSB                  | R/W  | 60h        |     | 6        | 1h        |                                                      | 00h          | Acceleration vector-magnitude threshold MSB                                             |
| A_VECM_THS_LSB                  | R/W  | 61h        |     | 6        | 2h        |                                                      | 00h          | Acceleration vector-magnitude threshold LSB                                             |

| Name             | Туре | Register   | Auto-increment address |       | Default | Comment                                                  |                           |                                                          |     |                           |
|------------------|------|------------|------------------------|-------|---------|----------------------------------------------------------|---------------------------|----------------------------------------------------------|-----|---------------------------|
|                  |      | address    | Α                      | A B C |         | D                                                        | hex<br>value              |                                                          |     |                           |
| A_VECM_CNT       | R/W  | 62h        |                        | 63    | Bh      |                                                          | 00h                       | Acceleration vector-magnitude debounce count             |     |                           |
| A_VECM_INITX_MSB | R/W  | 63h        |                        | 64    | 1h      |                                                          | 00h                       | Acceleration vector-magnitude X-axis reference value MSB |     |                           |
| A_VECM_INITX_LSB | R/W  | 64h        |                        | 65    | 5h      |                                                          | 00h                       | Acceleration vector-magnitude X-axis reference value LSB |     |                           |
| A_VECM_INITY_MSB | R/W  | 65h        |                        | 66    | 6h      |                                                          | 00h                       | Acceleration vector-magnitude Y-axis reference value MSB |     |                           |
| A_VECM_INITY_LSB | R/W  | 66h        | 67h                    |       | 00h     | Acceleration vector-magnitude Y-axis reference value LSB |                           |                                                          |     |                           |
| A_VECM_INITZ_MSB | R/W  | 67h        |                        | 68    | Bh      |                                                          | 00h                       | Acceleration vector-magnitude Z-axis reference value MSB |     |                           |
| A_VECM_INITZ_LSB | R/W  | 68h        |                        | 69    | 9h      |                                                          | 00h                       | Acceleration vector-magnitude Z-axis reference value LSB |     |                           |
| Reserved         | _    | 69h to 72h |                        | _     | _       |                                                          | _                         | Reserved, do not modify                                  |     |                           |
| A_FFMT_THS_X_MSB | R/W  | 73h        |                        | 74    | 1h      |                                                          | 00h                       | X-axis FMT threshold MSB                                 |     |                           |
| A_FFMT_THS_X_LSB | R/W  | 74h        |                        | 75    | 5h      |                                                          | 00h                       | X-axis FFMT threshold LSB                                |     |                           |
| A_FFMT_THS_Y_MSB | R/W  | 75h        |                        | 76    | 3h      |                                                          | 00h                       | Y-axis FFMT threshold MSB                                |     |                           |
| A_FFMT_THS_Y_LSB | R/W  | 76h        | 77h                    |       | 00h     | Y-axis FFMT threshold LSB                                |                           |                                                          |     |                           |
| A_FFMT_THS_Z_MSB | R/W  | 77h        | 78h                    |       |         | 00h                                                      | Z-axis FFMT threshold MSB |                                                          |     |                           |
| A_FFMT_THS_Z_LSB | R/W  | 78h        | 79h                    |       | 79h     |                                                          | 79h                       |                                                          | 00h | Z-axis FFMT threshold LSB |
| Reserved         | _    | 79h to FFh |                        | _     | _       |                                                          | _                         | Reserved, do not modify                                  |     |                           |

- Register contents are preserved when transitioning from Active to Standby mode.
- [1] [2] Register contents are reset when transitioning from Standby to Active mode.

Note: The auto-increment addressing is only enabled when registers are read using burst-read mode when the device is configured for I<sup>2</sup>C or SPI. The auto-increment address is automatically reset to 00h in 12°C mode when a stop condition is detected. In SPI mode there is no stop condition and the auto-increment address is not automatically reset to 00h.

<sup>[3]</sup> Register contents can be modified anytime in Standby or Active mode. A write to this register will cause a reset of the corresponding internal system debounce counter.

Modification of this register's contents can only occur when device is in Standby mode, except the FS[1:0] bit fields in CTRL REG1 register.

## 18 Register descriptions by functional block

### 18.1 Device configuration registers

### 18.1.1 STATUS register (address 00h)

Table 15. STATUS register (address 00h) bit allocation

| Tubio To. OT | able 16. GTAT GG Toglotor (addition of the allocation |                       |   |   |   |   |   |   |
|--------------|-------------------------------------------------------|-----------------------|---|---|---|---|---|---|
| Bit          | 7                                                     | 6                     | 5 | 4 | 3 | 2 | 1 | 0 |
| Symbol       |                                                       | DR_STATUS or F_STATUS |   |   |   |   |   |   |
| Reset        | 0                                                     | 0                     | 0 | 0 | 0 | 0 | 0 | 0 |
| Access       | R                                                     | R                     | R | R | R | R | R | R |

Table 16. STATUS register (address 00h) bit description

| Field                 | Description              |
|-----------------------|--------------------------|
| F_SETUP[f_mode] = 00h | register 00h → DR_STATUS |
| F_SETUP[f_mode] > 00h | register 00h → F_STATUS  |

The STATUS register aliases allow for the contiguous burst read of both status and current acceleration sample/FIFO data using the auto-increment addressing mechanism in both 8- and 14-bit modes.

### 18.1.2 DR\_STATUS register (address 00h)

Data-Ready Status when F\_SETUP[f\_mode] = 00h

This STATUS register provides the acquisition status information on a per-sample basis, and reflects real-time updates to the OUT\_X, OUT\_Y, and OUT\_Z registers.

When the FIFO subsystem data output register driver is disabled (F\_SETUP[ $f_mode$ ] = 00h), this register indicates the real-time status information of the accelerometer X, Y, and Z axes sample data.

Table 17. DR\_STATUS register (address 00h) bit allocation

| Bit    | 7     | 6   | 5   | 4   | 3     | 2   | 1   | 0   |
|--------|-------|-----|-----|-----|-------|-----|-----|-----|
| Symbol | zyxow | ZOW | yow | xow | zyxdr | zdr | ydr | xdr |
| Reset  | 0     | 0   | 0   | 0   | 0     | 0   | 0   | 0   |
| Access | R     | R   | R   | R   | R     | R   | R   | R   |

Table 18. DR\_STATUS register (address 00h) bit description

| Bit | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | zyxow  | X-, Y-, Z-axis data overwrite  0 — No data overwrite has occurred (reset value)  1 — Previous X, Y, Z data was overwritten by new X, Y, Z data before it was completely read zyxow is set to 1 whenever new data is acquired before completing the retrieval of the previous set. This event occurs when the content of at least one acceleration data register (that is, OUT_X, OUT_Y, and OUT_Z) has been overwritten. zyxow is cleared when the high-bytes of the acceleration data (OUT_X_MSB, OUT_Y_MSB, and OUT_Z_MSB) are read. |

FXLS8471C

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

| Bit | Symbol | Description                                                                                                                                                                                                                                                                                                                                                             |
|-----|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | ZOW    | Z-axis data overwrite  0 — No data overwrite has occurred (reset value)  1 — Previous Z-axis data was overwritten by new Z-axis data before it was read zow is set to 1 whenever a new Z-axis acquisition is completed before the retrieval of the previous data. When this occurs the previous data is overwritten. zow is cleared anytime OUT_Z_MSB register is read. |
| 5   | yow    | Y-axis data overwrite  0 — No data overwrite has occurred (reset value)  1 — Previous Y-axis data was overwritten by new Y-axis data before it was read yow is set to 1 whenever a new Y-axis acquisition is completed before the retrieval of the previous data. When this occurs the previous data is overwritten, yow is cleared anytime OUT_Y_MSB register is read. |
| 4   | xow    | X-axis data overwrite  0 — No data overwrite has occurred (reset value)  1 — Previous X-axis data was overwritten by new X-axis data before it was read xow is set to 1 whenever a new X-axis acquisition is completed before the retrieval of the previous data. When this occurs the previous data is overwritten, xow is cleared anytime OUT_X_MSB register is read. |
| 3   | zyxdr  | <ul> <li>X-, Y-, Z-axis new data ready</li> <li>0 — No new set of data ready (reset value)</li> <li>1 — New set of data is ready</li> <li>zyxdr signals that a new acquisition for any of the enabled channels is available. zyxdr is cleared when the high-bytes of the acceleration data (OUT_X_MSB, OUT_Y_MSB, OUT_Z_MSB) are read.</li> </ul>                       |
| 2   | zdr    | Z-axis new data available  0 — No new Z-axis data is ready (reset value)  1 — New Z-axis data is ready  zdr is set to 1 whenever a new Z-axis data acquisition is completed. zdr is cleared anytime the OUT_Z_MSB register is read.                                                                                                                                     |
| 1   | ydr    | Y-axis new data available  0 — No new Y-axis data ready (reset value)  1 — New Y-axis data is ready  ydr is set to 1 whenever a new Y-axis data acquisition is completed. ydr is cleared anytime the OUT_Y_  MSB register is read.                                                                                                                                      |
| 0   | xdr    | X-axis new data available  0 — No new X-axis data ready (reset value)  1 — New X-axis data is ready  xdr is set to 1 whenever a new X-axis data acquisition is completed. xdr is cleared anytime the OUT_X_  MSB register is read.                                                                                                                                      |

### 18.1.3 F\_STATUS register (address 00h)

FIFO Status when F\_SETUP[f\_mode] = 00h.

If the FIFO subsystem data output register driver is enabled, the status register indicates the current status information of the FIFO subsystem.

Table 19. F\_STATUS register (address 00h) bit allocation

| Bit    | 7     | 6           | 5 | 4 | 3     | 2     | 1 | 0 |
|--------|-------|-------------|---|---|-------|-------|---|---|
| Symbol | f_ovf | f_wmrk_flag |   |   | f_cnt | [5:0] |   |   |
| Reset  | 0     | 0           | 0 | 0 | 0     | 0     | 0 | 0 |
| Access | R     | R           | R | R | R     | R     | R | R |

FXLS8471Q

Table 20. FIFO flag event descriptions

| f_ovf | f_wmrk_flag | Event description                                                                                                                                                                    |
|-------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | Х           | No FIFO overflow events detected.                                                                                                                                                    |
| 1     | Х           | FIFO overflow event detected.                                                                                                                                                        |
| X     | 0           | No FIFO watermark event detected.                                                                                                                                                    |
| X     | 1           | A FIFO Watermark event was detected indicating that a FIFO sample count greater than watermark value has been reached.  If F_SETUP[f_mode] = 11h, a FIFO trigger event was detected. |

The f\_ovf and f\_wmrk\_flag flags remain asserted while the event source is still active, but the user can clear the FIFO interrupt bit in the interrupt source register (INT\_SOURCE) by reading the F\_STATUS register. In this case, the INT\_SOURCE[src\_fifo] bit will be set again when the next data sample enters the FIFO.

Therefore, the f\_ovf bit will remain asserted while the FIFO has overflowed and the f\_wmrk\_flag bit will remain asserted while the f\_cnt value is equal to or greater than then f\_wmrk value.

Table 21. F\_STATUS register (address 00h) bit description

| Bit    | Symbol     | Description                                                                                                                                                                                                                                               |
|--------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5 to 0 | f_cnt[5:0] | These bits indicate the number of acceleration samples currently stored in the FIFO buffer. Count 00 0000 indicates that the FIFO is empty. <b>00 0000</b> — FIFO sample counter (reset value) <b>00 0001 to 10 0000</b> — 1 to 32 samples stored in FIFO |

#### 18.1.4 TRIG\_CFG register (address 0Ah)

FIFO trigger configuration register. After the interrupt flag of the enabled event in TRIG\_CFG is set, the FIFO (when configured in Trigger mode) is gated at the time of the interrupt event preventing the further collection of data samples. This allows the host processor to analyze the data leading up to the event detection (up to 32 samples). For detailed information on how to utilize the FIFO and the various trigger events, see NXP application note AN4073.

Table 22. TRIG\_CFG register (address 0Ah) bit allocation

| Bit    | 7   | 6   | 5          | 4           | 3          | 2         | 1           | 0   |
|--------|-----|-----|------------|-------------|------------|-----------|-------------|-----|
| Symbol | _   | _   | trig_trans | trig_Indprt | trig_pulse | trig_ffmt | trig_a_vecm | _   |
| 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 23. TRIG\_CFG register (address 0Ah) bit description

| Bit | Symbol      | Description                                                                                                                                                                                                   |
|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | trig_trans  | Transient interrupt FIFO trigger enable <b>0</b> — Transient interrupt FIFO trigger disabled (reset value) <b>1</b> — Transient interrupt FIFO trigger enabled                                                |
| 4   | trig_Indprt | Landscape/Portrait orientation interrupt FIFO trigger enable  1 — Landscape/Portrait orientation interrupt FIFO trigger disabled (reset value)  Landscape/Portrait orientation interrupt FIFO trigger enabled |

FXLS8471Q

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

| Bit | Symbol      | Description                                                                                                                                                                                  |
|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | trig_pulse  | Pulse interrupt FIFO trigger enable  O — Pulse interrupt FIFO trigger disabled (reset value)  1 — Pulse interrupt FIFO trigger enabled                                                       |
| 2   | trig_ffmt   | Free-fall/motion interrupt FIFO trigger enable  O — Free-fall/motion interrupt FIFO trigger disabled (reset value)  1 — Free-fall/motion interrupt FIFO trigger enabled                      |
| 1   | trig_a_vecm | Acceleration vector-magnitude FIFO trigger enable <b>0</b> — Acceleration vector-magnitude FIFO trigger disabled (reset value) <b>1</b> — Acceleration vector-magnitude FIFO trigger enabled |

#### 18.1.5 SYSMOD register (address 0Bh)

The SYSMOD register indicates the current device operating mode. Applications using the Auto-Sleep/Auto-Wake mechanism can use this register to synchronize their application with the device operating mode. The system mode register also indicates the status of the FIFO gate error flag and the time elapsed since the FIFO gate error flag was asserted.

Table 24. SYSMOD register (address 0Bh) bit allocation

| Bit    | 7     | 6 | 5        | 4 | 3 | 2 | 1 | 0       |
|--------|-------|---|----------|---|---|---|---|---------|
| Symbol | fgerr |   | fgt[4:0] |   |   |   |   | od[1:0] |
| Reset  | 0     | 0 | 0        | 0 | 0 | 0 | 0 | 0       |
| Access | R     | R | R        | R | R | R | R | R       |

Table 25. SYSMOD register (address 0Bh) bit description

|        | abio 201 O Tomos Togloto. (addition of 211) bit accomption |                                                                                                                                                                                                                                                                |  |  |  |  |  |
|--------|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bit    | Symbol                                                     | Description                                                                                                                                                                                                                                                    |  |  |  |  |  |
| 7      | fgerr                                                      | FIFO gate error  0 — No FIFO gate error detected (reset value)  1 — FIFO gate error was detected Emptying the FIFO buffer clears the <i>fgerr</i> bit in the SYSMOD register.  See Section 18.1.10 for more information on configuring the FIFO Gate function. |  |  |  |  |  |
| 6 to 2 | fgt[4:0]                                                   | Number of ODR time units since fgerr was asserted. Reset when fgerr is cleared                                                                                                                                                                                 |  |  |  |  |  |
| 1 to 0 | sysmod[1:0]                                                | System mode  00 — Standby mode (reset value)  01 — Wake mode  10 — Sleep mode                                                                                                                                                                                  |  |  |  |  |  |

### 18.1.6 INT\_SOURCE register (address 0Ch)

Interrupt source register. The bits that are set (logic '1') indicate which function has asserted its interrupt and conversely bits that are cleared (logic '0') indicate which function has not asserted its interrupt.

Reading the INT\_SOURCE register does not clear any interrupt status bits, except for src\_a\_vecm. See <u>Table 26</u> and <u>Table 27</u>. The respective interrupt flag bits are reset by reading the appropriate source register for the function that generated the interrupt.

Table 26. INT\_SOURCE register (address 0Ch) bit allocation

| Bit    | 7        | 6        | 5         | 4          | 3         | 2        | 1          | 0        |
|--------|----------|----------|-----------|------------|-----------|----------|------------|----------|
| Symbol | src_aslp | src_fifo | src_trans | src_Indprt | src_pulse | src_ffmt | src_a_vecm | src_drdy |
| Reset  | 0        | 0        | 0         | 0          | 0         | 0        | 0          | 0        |
| Access | R        | R        | R         | R          | R         | R        | R          | R        |

### Table 27. INT\_SOURCE register (address 0Ch) bit description

| Bit | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | src_aslp   | Auto-Sleep/Wake interrupt status  0 — No Wake-to-Sleep or Sleep-to-Wake system mode transition interrupt event has occurred  1 — An interrupt event that can cause a Wake to Sleep or Sleep to Wake system mode transition has occurred  The "Wake-to-Sleep" transition occurs when a period of inactivity that exceeds the user-specified time limit (ASLP_COUNT) has been detected, thus causing the system to transition to a user-specified low ODR setting.  A "Sleep-to-Wake" transition occurs when the user-specified interrupt event has awakened the system, thus causing the system to transition to the user-specified higher ODR setting.  Reading the SYSMOD register will clear the src_aslp bit. |
| 6   | src_fifo   | FIFO interrupt status  0 — No FIFO interrupt event has occurred  1 — A FIFO interrupt event such as an overflow or watermark (F_STATUS[f_cnt] = F_STATUS[f_wmrk]) event has occurred  This bit is cleared by reading the F_STATUS register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 5   | src_trans  | Transient interrupt status  0 — No transient event has occurred  1 — An acceleration transient value greater than user-specified threshold has occurred  This bit is asserted whenever TRANSIENT_SRC[ea] is asserted and the functional block interrupt has been enabled.  This bit is cleared by reading the TRANSIENT_SRC register.                                                                                                                                                                                                                                                                                                                                                                            |
| 4   | src_Indprt | Landscape/Portrait orientation interrupt status  0 — No change in orientation status was detected  1 — An interrupt was generated due to a change in the device orientation status  This bit is asserted whenever PL_STATUS[newlp] is asserted and the functional block interrupt has been enabled.  This bit is cleared by reading the PL_STATUS register.                                                                                                                                                                                                                                                                                                                                                      |
| 3   | src_pulse  | Pulse interrupt status  0 — No pulse event was detected  1 — An interrupt was generated due to single- and/or double-pulse event  This bit is asserted whenever PULSE_SRC[ea] is asserted and the functional block interrupt has been enabled.  This bit is cleared by reading the PULSE_SRC register.                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2   | src_ffmt   | Free-fall/motion interrupt status  0 — No free-fall or motion event was detected  1 — The free-fall/motion function interrupt is active  This bit is asserted whenever PULSE_SRC[ea] is asserted and the functional block interrupt has been enabled.  This bit is cleared by reading the A_FFMT_SRC register.                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1   | src_a_vecm | Accelerometer vector-magnitude interrupt status  0 — No interrupt has been generated  1 — An interrupt was generated due to acceleration vector-magnitude function This bit is cleared by reading this register (INT_SOURCE).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Bit | Symbol   | Description                                                                                                                                                                                     |
|-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | src_drdy | Data-ready interrupt status                                                                                                                                                                     |
|     |          | <b>0</b> — No data available to read                                                                                                                                                            |
|     |          | 1 —This bit indicates that new accelerometer data is available to read.                                                                                                                         |
|     |          | The <i>src_drdy</i> interrupt flag is cleared by reading the OUT_X, OUT_Y, and OUT_Z registers. This data can be retrieved using a 6-byte burst read starting from the address 01h (OUT_X_MSB). |

### 18.1.7 WHO\_AM\_I register (address 0Dh)

Table 28. WHO\_AM\_I register (address 0Dh) bit allocation

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

Table 29. WHO\_AM\_I register (address 0Dh) bit description

| Bit    | Symbol        | Description       |
|--------|---------------|-------------------|
| 7 to 0 | who_am_i[7:0] | Device identifier |

### 18.1.8 CTRL\_REG1 register (address 2Ah)

**Note:** Except for Standby mode selection, the device must be in Standby mode to change any of the other bit fields within CTRL\_REG1 (address 2Ah).

Table 30. CTRL REG1 register (address 2Ah) bit allocation

| Bit    | 7       | 6        | 5   | 4       | 3   | 2      | 1      | 0      |
|--------|---------|----------|-----|---------|-----|--------|--------|--------|
| Symbol | aslp_ra | ate[1:0] |     | dr[2:0] |     | Inoise | f_read | active |
| 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 31. CTRL\_REG1 register (address 2Ah) bit description

| Bit    | Symbol         | Description                                                                                                                                                                                                                                           |
|--------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 6 | aslp_rate[1:0] | Configures the auto-wake sample frequency when the device is in Sleep mode.  See <u>Table 32</u> and <u>Table 34</u> for more information.                                                                                                            |
| 5 to 3 | dr[2:0]        | Output data rate selection See <u>Table 33</u> and <u>Table 35</u> for more information.                                                                                                                                                              |
| 2      | Inoise         | Reduced noise and full-scale range mode (analog gain times 2). <b>0</b> — Normal mode <b>1</b> — Reduced noise mode; Note that the FSR setting is restricted to a ±4 g in this mode (Inoise = 1).                                                     |
| 1      | f_read         | Fast-read mode  0 — Normal mode  1 — Fast-read mode  Data format is limited to the 8-bit MSB for accelerometer output data. The auto-address pointer will skip over the LSB address for each axes sample data when performing a burst read operation. |
| 0      | active         | Standby/Active 0 — Standby mode 1 — Active mode                                                                                                                                                                                                       |

FXLS8471Q

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

Table 32. Sleep mode poll rate description - CTRL\_REG6 = 00h

| aslp_rate[1:0] | Frequency (Hz) |
|----------------|----------------|
| 00             | 50             |
| 01             | 12.5           |
| 10             | 6.25           |
| 11             | 1.56           |

It is important to note that when the device is in Auto-Sleep mode, the system ODR and data rate for all the system functional blocks is overridden by the sleep data rate set by the aslp rate field.

Table 33 shows the various system output data rates (ODR) that can be selected using the dr[2:0] bits.

Table 33. System output data rate selection - CTRL REG6 = 00h

| dr[2:0] | ODR (Hz) | Period (ms) |
|---------|----------|-------------|
| 000     | 800.0    | 1.25        |
| 001     | 400.0    | 2.5         |
| 010     | 200.0    | 5           |
| 011     | 100.0    | 10          |
| 100     | 50.0     | 20          |
| 101     | 12.5     | 80          |
| 110     | 6.25     | 160         |
| 111     | 1.5625   | 640         |

The *active* bit selects between Standby mode and Active mode. The default value is 0 (Standby mode) on reset.

The *Inoise* bit selects between normal full dynamic range mode and a high sensitivity, low-noise mode. In low-noise mode the maximum signal that can be measured is ±4 g.

**Note:** In low-noise mode, a threshold value set above 4 g will not be reached, even if the physical input acceleration exceeds this value.

The  $f\_read$  bit selects between normal and fast-read modes where the auto-increment counter will also skip over each axis's LSB data bytes when  $f\_read = 1$ . All of the acceleration data MSBs can be read out with a single 3-byte burst read starting at the OUT\_X\_MSB register when  $f\_read = 1$ .

**Note:** The f\_read bit can only be changed while F\_SETUP[f\_mode] = 0.

When temperature measurements are desired, the host must set CTRL\_REG6 to the value 03h, which enables the measurement. This will cause the ODR to divide by a factor of 2 as shown in <u>Table 34</u> and <u>Table 35</u>.

Table 34. Sleep mode poll rate description - CTRL\_REG6 = 03h

| Table of the croop in case point and accompany |                |
|------------------------------------------------|----------------|
| aslp_rate[1:0]                                 | Frequency (Hz) |
| 00                                             | 25             |
| 01                                             | 6.25           |
| 10                                             | 3.125          |
| 11                                             | 0.781          |

Table 35. System output data rate selection – CTRL\_REG6 = 03h

| dr[2:0] | ODR (Hz) | Period (ms) |
|---------|----------|-------------|
| 000     | 400.0    | 2.5         |
| 001     | 200.0    | 5           |
| 010     | 100.0    | 10          |
| 011     | 50.0     | 20          |
| 100     | 25       | 40          |
| 101     | 6.25     | 160         |
| 110     | 3.125    | 320         |
| 111     | 0.781    | 1280        |

## 18.1.9 CTRL\_REG2 register (address 2Bh)

Table 36. CTRL REG2 register (address 2Bh) bit allocation

| Bit    | 7   | 6   | 5   | 4    | 3      | 2    | 1    | 0      |  |
|--------|-----|-----|-----|------|--------|------|------|--------|--|
| Symbol | st  | rst | _   | smod | s[1:0] | slpe | mods | s[1: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 37. CTRL\_REG2 register (address 2Bh) bit description

| Bit | Symbol | Description                                                                                                                                                                                                                                                           |
|-----|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | st     | Self-test enable                                                                                                                                                                                                                                                      |
|     |        | 0 — Self-Test disabled                                                                                                                                                                                                                                                |
|     |        | 1 — Self-Test enabled                                                                                                                                                                                                                                                 |
|     |        | The <i>st</i> bit activates the accelerometer self-test function. When <i>st</i> is set to 1, a change will occur in the device output levels for each axis, allowing the host application to check the functionality of the transducer and measurement signal chain. |

| Bit    | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6      | rst        | Software reset  0 — Device reset disabled  1 — Device reset enabled  The rst bit is used to initiate a software reset. The reset mechanism can be enabled in both Standby and Active modes. When the rst bit is set, the boot mechanism resets all functional block registers and loads the respective internal registers with their default values. After setting the rst bit, the system will automatically transition to Standby mode. Therefore, if the system was already in Standby mode, the reboot process will immediately begin; otherwise, if the system was in Active mode the boot mechanism will automatically transition the system from Active mode to Standby mode, only then can the reboot process begin. A system reset can also be initiated by pulsing the external RST pin high.  Note: The current revision of FXLS8471Q silicon, as identified by a WHO_AM_I value of 6Ah, has an errata associated with the software reset mechanism when the device is operated in SPI mode. Refer to Section 22 for further information and a suggested workaround.  The I <sup>2</sup> C and SPI communication systems are also reset to avoid corrupted data transactions. The host application should allow 1 ms between issuing a software (setting rst bit) or hardware (pulsing RST pin) reset and attempting communications with the device over the I <sup>2</sup> C or SPI interfaces. When the SPI interface mode is desired and multiple devices are present on the bus, make sure that the bus is quiet (all slave device MISO pins are high-z) during this 1 ms period to ensure the device does not inadvertently enter I <sup>2</sup> C mode. See Section 10.2.3 for further information about the interface mode auto-detection circuit. At the end of the boot process, the rst bit is automatically cleared in hardware. |
| 4 to 3 | smods[1:0] | Accelerometer sleep mode OSR mode selection  This setting, along with the CTRL_REG1[aslp_rate] ODR setting determines the sleep mode power and noise for acceleration measurements. See <a href="Table 38">Table 38</a> and <a href="Table 39">Table 39</a> for more information.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2      | slpe       | Auto-Sleep mode  0 — Auto-Sleep is not enabled  1 — Auto-Sleep is enabled  When SLPE = 1, a transition between Sleep mode and Wake mode results in a FIFO flush and a reset of internal functional block counters. All functional block status information is preserved except where otherwise indicated. For further information, refer to Section 18.1.10.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1 to 0 | mods[1:0]  | Accelerometer wake mode OSR mode selection. This setting, along with the ODR selection (CTRL_REG1[dr]) determines the wake mode power and noise for acceleration measurements. See <u>Table 38</u> and <u>Table 39</u> for more information.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

Table 38. CTRL\_REG2[smods/mods] oversampling modes

| smods[1:0]/mods[1:0] | Power mode           |
|----------------------|----------------------|
| 00                   | Normal               |
| 01                   | Low Noise, Low Power |
| 10                   | High Resolution      |
| 11                   | Low Power            |

Table 39. Oversampling ratio versus oversampling mode

|          | Accelerometer OSR |                         |                 |           |  |  |
|----------|-------------------|-------------------------|-----------------|-----------|--|--|
| ODR (Hz) | Normal            | Low Noise, Low<br>Power | High Resolution | Low Power |  |  |
| 1.5625   | 128               | 32                      | 1024            | 16        |  |  |
| 6.25     | 32                | 8                       | 256             | 4         |  |  |
| 12.5     | 16                | 4                       | 128             | 2         |  |  |
| 50       | 4                 | 4                       | 32              | 2         |  |  |

FXLS8471Q

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

|          | Accelerometer OSR |                         |                 |           |  |  |
|----------|-------------------|-------------------------|-----------------|-----------|--|--|
| ODR (Hz) | Normal            | Low Noise, Low<br>Power | High Resolution | Low Power |  |  |
| 100      | 4                 | 4                       | 16              | 2         |  |  |
| 200      | 4                 | 4                       | 8               | 2         |  |  |
| 400      | 4                 | 4                       | 4               | 2         |  |  |
| 800      | 2                 | 2                       | 2               | 2         |  |  |

## 18.1.10 CTRL\_REG3 - interrupt control register (address 2Ch)

Table 40. CTRL\_REG3 [interrupt control register] (address 2Ch) bit allocation

| / · · · / · · · / · · · · · · · · |           |            |             |            |           |                 |      |       |
|-----------------------------------|-----------|------------|-------------|------------|-----------|-----------------|------|-------|
| Bit                               | 7         | 6          | 5           | 4          | 3         | 2               | 1    | 0     |
| Symbol                            | fifo_gate | wake_trans | wake_Indprt | wake_pulse | wake_ffmt | wake_<br>a_vecm | ipol | pp_od |
| 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 41. CTRL\_REG3 [Interrupt control register] (address 2Ch) bit descriptions

| Bit | Symbol      | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | fifo_gate   | FIFO gate <b>0</b> — FIFO gate is bypassed. FIFO is flushed upon the system mode transitioning from Waketo-Sleep mode or from Sleep-to-Wake mode.                                                                                                                                                                                                                                                      |
|     |             | <b>1</b> — The FIFO input buffer is blocked from accepting new samples when transitioning from "Wake-to-Sleep" mode or from "Sleep-to-Wake" mode until the FIFO is flushed. <sup>[1]</sup> Although the system transitions from "Wake-to-Sleep" or from "Sleep-to-Wake" the contents of the FIFO buffer are preserved. New data samples are ignored until the FIFO is emptied by the host application. |
|     |             | If the <i>fifo_gate</i> bit is set to logic '1' and the FIFO buffer is not emptied before the arrival of the next sample, then the SYSMOD[ <i>fgerr</i> ] will be asserted. The SYSMOD[ <i>fgerr</i> ] bit remains asserted as long as the FIFO buffer remains unemptied.                                                                                                                              |
|     |             | Emptying the FIFO buffer clears the SYS_MOD[fgerr] register.                                                                                                                                                                                                                                                                                                                                           |
| 6   | wake_tran   | 0 — Transient function is disabled in Sleep mode                                                                                                                                                                                                                                                                                                                                                       |
|     |             | <b>1</b> — Transient function is enabled in Sleep mode and can generate an interrupt to wake the system                                                                                                                                                                                                                                                                                                |
| 5   | wake_Indprt | 0 — Orientation function is disabled Sleep mode.                                                                                                                                                                                                                                                                                                                                                       |
|     |             | <b>1</b> — Orientation function is enabled in Sleep mode and can generate an interrupt to wake the system                                                                                                                                                                                                                                                                                              |
| 4   | wake_pulse  | 0 — Pulse function is disabled in Sleep mode                                                                                                                                                                                                                                                                                                                                                           |
|     |             | <b>1</b> — Pulse function is enabled in Sleep mode and can generate an interrupt to wake the system                                                                                                                                                                                                                                                                                                    |
| 3   | wake_ffmt   | 0 — Free-fall/motion function is disabled in Sleep mode                                                                                                                                                                                                                                                                                                                                                |
|     |             | <b>1</b> — Free-fall/motion function is enabled in Sleep mode and can generate an interrupt to wake the system                                                                                                                                                                                                                                                                                         |
| 2   | wake_a_vecm | Acceleration vector-magnitude function is disabled in Sleep mode                                                                                                                                                                                                                                                                                                                                       |
|     |             | <b>1</b> — Acceleration vector-magnitude function is enabled in Sleep mode and can generate an interrupt to wake the system                                                                                                                                                                                                                                                                            |

| Bit | Symbol | Description                                                                                                                                                                                                                                                                             |
|-----|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | ipol   | INT1/INT2 interrupt logic polarity <b>0</b> — Active low (reset value) <b>1</b> — Active high  The <i>ipol</i> bit selects the logic polarity of the interrupt signals output on the INT1 and INT2 pins.                                                                                |
| 0   | pp_od  | INT1/INT2 push-pull or open-drain output mode selection  0 — Push-pull (reset value)  1 — Open-drain  The open-drain configuration can be used for connecting multiple interrupt signals on the same interrupt line but will require an external pullup resistor to function correctly. |

<sup>[1]</sup> The FIFO contents are flushed whenever the system ODR changes in order to prevent the mixing of FIFO data from different ODR periods.

#### 18.1.11 CTRL\_REG4 - interrupt enable register (address 2Dh)

The corresponding functional block interrupt enable bit allows the functional block to route its event detection flag to the system's interrupt controller. The interrupt controller routes the enabled interrupt signals to either the INT1 or INT2 pins depending on the settings made in CTRL\_REG5.

Table 42. CTRL\_REG4 [Interrupt enable register] (address 2Dh) bit allocation

| Bit    | 7           | 6           | 5            | 4                 | 3                | 2           | 1                 | 0           |
|--------|-------------|-------------|--------------|-------------------|------------------|-------------|-------------------|-------------|
| Symbol | int_en_aslp | int_en_fifo | int_en_trans | int_en_<br>Indprt | int_en_<br>pulse | int_en_ffmt | int_en_<br>a_vecm | int_en_drdy |
| 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 43. CTRL\_REG4 [Interrupt enable register] (address 2Dh) bit descriptions

| Bit | Symbol        | Description                                                                                                                                               |
|-----|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | int_en_aslp   | Sleep interrupt enable  0 — Auto-Sleep/Wake interrupt disabled  1 — Auto-Sleep/Wake interrupt enabled                                                     |
| 6   | int_en_fifo   | FIFO interrupt enable <b>0</b> — FIFO interrupt disabled <b>1</b> — FIFO interrupt enabled                                                                |
| 5   | int_en_trans  | Transient interrupt enable  0 — Transient interrupt disabled  1 — Transient interrupt enabled                                                             |
| 4   | int_en_Indprt | Orientation interrupt enable <b>0</b> — Orientation (Landscape/Portrait) interrupt disabled <b>1</b> — Orientation (Landscape/Portrait) interrupt enabled |
| 3   | int_en_pulse  | Pulse interrupt enable  0 — Pulse detection interrupt disabled  1 — Pulse detection interrupt enabled                                                     |

| Bit | Symbol        | Description                                                                                                                                                           |
|-----|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | int_en_ffmt   | Free-fall/motion interrupt enable <b>0</b> — Free-fall/motion interrupt disabled <b>1</b> — Free-fall/motion interrupt enabled                                        |
| 1   | int_en_a_vecm | Acceleration vector-magnitude interrupt enable <b>0</b> — Acceleration vector-magnitude interrupt disabled <b>1</b> — Acceleration vector-magnitude interrupt enabled |
| 0   | int_en_drdy   | Data-ready interrupt enable <b>0</b> — Data-ready interrupt disabled <b>1</b> — Data-ready interrupt enabled                                                          |

## 18.1.12 CTRL\_REG5 - interrupt routing configuration register (address 2Eh)

Table 44. CTRL\_REG5 [Interrupt Routing Configuration Register] (address 2Eh) bit allocation

|        | _            |              | 3                 | 3                  | <b>4</b> (        | ,            |                    |              |
|--------|--------------|--------------|-------------------|--------------------|-------------------|--------------|--------------------|--------------|
| Bit    | 7            | 6            | 5                 | 4                  | 3                 | 2            | 1                  | 0            |
| Symbol | int_cfg_aslp | int_cfg_fifo | int_cfg_<br>trans | int_cfg_<br>Indprt | int_cfg_<br>pulse | int_cfg_ffmt | int_cfg_<br>a_vecm | int_cfg_drdy |
| 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 45. CTRL\_REG5 [Interrupt Routing Configuration Register] (address 2Eh) bit descriptions

| Bit | Symbol         | Description                                                                                                                           |
|-----|----------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 7   | int_cfg_aslp   | Sleep interrupt routing  0 — Interrupt is routed to INT2 pin  1 — Interrupt is routed to INT1 pin                                     |
| 6   | int_cfg_fifo   | FIFO interrupt routing  0 — Interrupt is routed to INT2 pin  1 — Interrupt is routed to INT1 pin                                      |
| 5   | int_cfg_trans  | Transient detection interrupt routing  0 — Interrupt is routed to INT2 pin  1 — Interrupt is routed to INT1 pin                       |
| 4   | int_cfg_Indprt | Orientation detection interrupt routing <b>0</b> — Interrupt is routed to INT2 pin <b>1</b> — Interrupt is routed to INT1 pin         |
| 3   | int_cfg_pulse  | Pulse detection interrupt routing  0 — Interrupt is routed to INT2 pin  1 — Interrupt is routed to INT1 pin                           |
| 2   | int_cfg_ffmt   | Free-fall/motion detection interrupt routing <b>0</b> — Interrupt is routed to INT2 pin <b>1</b> — Interrupt is routed to INT1 pin    |
| 1   | int_cfg_a_vecm | Acceleration vector-magnitude interrupt routing <b>0</b> — Interrupt is routed to INT2 pin <b>1</b> — Interrupt is routed to INT1 pin |

| Bit | Symbol       | Description                                                                                        |
|-----|--------------|----------------------------------------------------------------------------------------------------|
| 0   | int_cfg_drdy | INT1/INT2 configuration.  0 — Interrupt is routed to INT2 pin  1 — Interrupt is routed to INT1 pin |



The system's interrupt controller uses the corresponding bit field in the CTRL\_REG5 register to determine the routing for the INT1 and INT2 interrupt pins. For example, if the <code>int\_cfg\_drdy</code> bit value is logic '0' the functional block's interrupt is routed to INT2, and if the bit value is logic '1' then the interrupt is routed to INT1. All interrupt signals routed to either INT1 or INT2 are logically OR'ed together as illustrated in <a href="Figure 11">Figure 11</a>, thus one or more functional blocks can assert an interrupt pin simultaneously; therefore, a host application responding to an interrupt should read the INT\_SOURCE register to determine the source(s) of the interrupt(s).



### 18.1.13 CTRL\_REG6 - register (address 5Bh)

Table 46. CTRL\_REG6 register (address 5Bh) bit allocation

| Bit    | 7        | 6        | 5        | 4        | 3        | 2        | 1     | 0      |
|--------|----------|----------|----------|----------|----------|----------|-------|--------|
| Symbol | reserved | reserved | reserved | reserved | reserved | reserved | adc_i | n[1: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 47. CTRL\_REG6 register (address 5Bh) bit descriptions

| Bit    | Symbol | Description                                                                                                                                                                                                                                                                                       |
|--------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 to 1 |        | ADC measurement selection <b>00</b> — Only acceleration inputs (X,Y,Z) are scanned and converted by the ADC (reset value) <b>01</b> — Reserved – do not use <b>10</b> — Reserved – do not use <b>11</b> — Both acceleration and temperature (X,Y,Z,T) inputs are scanned and converted by the ADC |

### 18.1.14 CTRL\_REG7 - register (address 5Ch)

#### Table 48. CTRL REG7 register (address 5Ch) bit allocation

| Bit    | 7        | 6        | 5          | 4        | 3        | 2        | 1        | 0        |
|--------|----------|----------|------------|----------|----------|----------|----------|----------|
| Symbol | reserved | reserved | iainc_mode | reserved | reserved | reserved | reserved | reserved |
| 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 49. CTRL\_REG7 register (address 5Ch) bit descriptions

| Bit | Symbol    | Description                                                                                                                                                                                                                                                            |
|-----|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | ainc_mode | Measurement data read-out addressing control                                                                                                                                                                                                                           |
|     |           | <b>0</b> — Disable secondary output data auto-increment mode (reset value)                                                                                                                                                                                             |
|     |           | 1 — Enable secondary output data auto-increment mode                                                                                                                                                                                                                   |
|     |           | When the temperature sensor is enabled, and the application makes use of the internal drdy flag to produce a data read interrupt, a "dummy" read of register 33h is required to properly clear the drdy event flag and allow the following interrupt cycle to proceed. |
|     |           | With ainc_mode = 1 and fast-read mode disabled (CTRL_REG1[f_read] = 0), the                                                                                                                                                                                            |
|     |           | register read address pointer will automatically advance to register 33h during a burst read operation after reading                                                                                                                                                   |
|     |           | register 06h (OUT_Z_LSB), allowing the data ready flag to be automatically cleared when reading the acceleration data without the need to perform a second, dedicated read cycle on address 33h.                                                                       |
|     |           | <b>Note:</b> Regardless of the selected auto-increment mode, the value read from register 33h is always a "don't care" value and can be safely discarded.                                                                                                              |

## 18.2 Auto-Sleep trigger register

## 18.2.1 ASLP\_COUNT register (address 29h)

The ASLP\_COUNT register sets the minimum time period of event flag inactivity required to initiate a change from the current active mode ODR value specified in CTRL\_REG1[dr] to the Sleep mode ODR value specified in CTRL\_REG1[ $aslp\_rate$ ], provided that CTRL\_REG2[slpe] = 1.

See <u>Table 53</u> for functional blocks that can be monitored for inactivity in order to trigger the return-to-sleep event.

Table 50. ASLP\_COUNT register (address 29h) bit allocation

| Bit    | 7             | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|--------|---------------|-----|-----|-----|-----|-----|-----|-----|--|--|
| Symbol | aslp_cnt[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 51. ASLP COUNT register (address 29h) bit description

| Bit    | Symbol        | Description                      |
|--------|---------------|----------------------------------|
| 7 to 0 | aslp_cnt[7:0] | See <u>Table 52</u> for details. |

Table 52. ASLP\_COUNT relationship with ODR

| Output data rate | Maximum inactivity time (s) | ODR time step (ms) | ASLP_COUNT step (ms) |
|------------------|-----------------------------|--------------------|----------------------|
| 800              | 81                          | 1.25               | 320                  |
| 400              | 81                          | 2.5                | 320                  |
| 200              | 81                          | 5                  | 320                  |
| 100              | 81                          | 10                 | 320                  |
| 50               | 81                          | 20                 | 320                  |
| 12.5             | 81                          | 80                 | 320                  |
| 6.25             | 81                          | 160                | 320                  |
| 1.56             | 163                         | 640                | 640                  |
| 0.781            | 163                         | 1280               | 640                  |

Table 53. Sleep/Wake mode gates and triggers

| Table 33. Sleep/wake mode gates and triggers |                                                |                            |  |  |  |  |  |  |
|----------------------------------------------|------------------------------------------------|----------------------------|--|--|--|--|--|--|
| Interrupt source                             | Event restarts time and delays Return-to-Sleep | Event will Wake-from-Sleep |  |  |  |  |  |  |
| SRC_FIFO                                     | Yes                                            | No                         |  |  |  |  |  |  |
| SRC_TRANS                                    | Yes                                            | Yes                        |  |  |  |  |  |  |
| SRC_LNDPRT                                   | Yes                                            | Yes                        |  |  |  |  |  |  |
| SRC_PULSE                                    | Yes                                            | Yes                        |  |  |  |  |  |  |

FXLS8471Q

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

| Interrupt source | Event restarts time and delays Return-to-Sleep | Event will Wake-from-Sleep |
|------------------|------------------------------------------------|----------------------------|
| SRC_FFMT         | Yes                                            | Yes                        |
| SRC_ASLP         | No <sup>[1]</sup>                              | No <sup>[1]</sup>          |
| SRC_DRDY         | No                                             | No                         |
| SRC_AVECM        | Yes                                            | Yes                        |

<sup>[1]</sup> If the *fifo\_gate* bit is set to logic '1', the assertion of the SRC\_ASLP interrupt does not prevent the system from transitioning to Sleep or from Wake mode; instead it prevents the FIFO buffer from accepting new sample data until the host application flushes the FIFO buffer.

The interrupt sources listed in <u>Table 53</u> affect the auto-sleep, return to sleep and wake from sleep mechanism only if they have been previously enabled. The functional block event flags that are bypassed while the system is in Auto-Sleep mode are temporarly disabled and are automatically re-enabled when the device returns from Auto-Sleep mode (that is, wakes up), except for the data ready function. See Section <u>Section 18.1.10</u> "CTRL REG3 - interrupt control register (address 2Ch)" for more information.

If any of the interrupt sources listed under the Return-to-Sleep column is asserted before the sleep counter reaches the value specified in ASLP\_COUNT, then all sleep mode transitions are terminated and the internal sleep counter is reset. If none of the interrupts listed under the Return-to-Sleep column are asserted within the time limit specified by the ASLP\_COUNT register, the system will transition to the Sleep mode and use the ODR value specified in CTRL REG1[aslp\_rate].

If any of the interrupt sources listed under the "Wake-from-Sleep" column are asserted, then the system will transition out of the low sample rate Auto-Sleep mode to the user-specified fast sample rate, provided that the user-specified wake event function is enabled in register CTRL REG3.

If the Auto-Sleep interrupt is enabled, a transition from Active mode to Sleep mode, and vice-versa, will generate an interrupt.

If CTRL\_REG3[fifo\_gate] = 1, transitioning to Auto-Sleep mode will preserve the FIFO contents, set SYSMOD[fgerr] (FIFO Gate error), and stop new acquisitions. The system will wait for the FIFO buffer to be emptied by the host application before new samples can be acquired.



#### 18.3 Temperature register

#### 18.3.1 TEMP OUT register (address 51h)

When the temperature sensor measurement is enabled (**CTRL\_REG6** = 03h), this register contains the 8-bit two's complement temperature output value, which is updated at the ODR interval along with the acceleration data. With the temperature sensor enabled, if the application uses the drdy flag to trigger a data read operation, a dummy read of register 33h must also be made to clear the drdy flag for the next interrupt cycle.

When the **TEMP\_OUT** register contains the value 00h, the measured temperature is nominally 25 °C. The measurement range is from –40 to 125 °C. As the offset is not factory trimmed, a variation in output from ideal, and device-to-device, will be observed for a given input temperature. The sensitivity is nominally 0.96 °C/LSB and is also not factory trimmed. Please see <u>Table 12</u> for further information on the temperature sensor performance characteristics.

If absolute accuracy is important in the end application, NXP suggests performing a post-assembly single-point calibration and correcting the offset error within the host software.

Note that the temperature sensor ADC measurement is only performed when **CTRL\_REG6** = 03h; this configuration value can be programmed along with the other **CTRL\_REG**x parameters before entering the Active measurement mode.

Enabling the temperature sensor output will result in the selected ODR being reduced by a factor of 2, making the maximum nominal ODR 400 Hz and minimum 0.781 Hz.

It is suggested to read the **TEMP\_OUT** register immediately after the **OUT\_X/Y/Z** registers using a single byte read operation.

Table 54. TEMP OUT register (address 51h) bit allocation

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

#### 18.4 Output data registers

# 18.4.1 OUT\_X\_MSB, OUT\_X\_LSB, OUT\_Y\_MSB, OUT\_Y\_LSB, OUT\_Z\_MSB, OUT\_Z\_LSB registers (addresses 01h to 06h)

These registers contain the X-axis, Y-axis, and Z-axis 14-bit left-justified sample data expressed as two's complement numbers.

The sample data output registers store the current sample data if the FIFO buffer function is disabled. However, if the FIFO buffer function is enabled, the sample data output registers then point to the head of the FIFO buffer, which contains up to the previous 32 X, Y, and Z data samples.

The data is read out in the following order.

- Xmsb, Xlsb, Ymsb, Ylsb, Zmsb, Zlsb for CTRL\_REG1[f\_read] = 0
- Xmsb, Ymsb, Zmsb for CTRL\_REG1[f\_read] = 1.

FXLS8471Q

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

If the CTRL\_REG1[f\_read] bit is set, auto-increment will skip over the LSB registers. This will shorten the data acquisition from 6 bytes to 3 bytes. If the LSB registers are directly addressed, the LSB information can still be read regardless of the CTRL\_REG1[f\_read] register setting.

If the FIFO data output register driver is enabled (F\_SETUP[f\_mode] > 00), register 01h points to the head of the FIFO buffer, while registers 02h, 03h, 04h, 05h, 06h return a value of zero when read directly.

The DR\_STATUS registers, OUT\_X\_MSB, OUT\_X\_LSB, OUT\_Y\_MSB, OUT\_Y\_LSB, OUT\_Z\_MSB, and OUT\_Z\_LSB are located in the auto-incrementing address range of 00h to 06h, allowing all of the acceleration data to be read in a single-burst read of 6 bytes starting at the OUT\_X\_MSB register.

Table 55. OUT X MSB register (address 01h) bit allocation

| · · · · · · · · · · · · · · · · · · · |   |          |   |   |   |   |   |   |  |  |  |
|---------------------------------------|---|----------|---|---|---|---|---|---|--|--|--|
| Bit                                   | 7 | 6        | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| Symbol                                |   | xd[13:6] |   |   |   |   |   |   |  |  |  |
| Reset                                 | _ | _        | _ | _ | _ | _ | _ | _ |  |  |  |
| Access                                | R | R        | R | R | R | R | R | R |  |  |  |

#### Table 56. OUT\_X\_LSB register (address 02h) bit allocation

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

#### Table 57. OUT\_Y\_MSB register (address 03h) bit allocation

| Bit    | 7 | 6        | 5 | 4 | 3 | 2 | 1 | 0            |  |  |  |
|--------|---|----------|---|---|---|---|---|--------------|--|--|--|
| Symbol |   | yd[13:6] |   |   |   |   |   |              |  |  |  |
| Reset  | _ | _        | _ | _ | _ | _ | _ | <del>_</del> |  |  |  |
| Access | R | R        | R | R | R | R | R | R            |  |  |  |

#### Table 58. OUT\_Y\_LSB register (address 04h) bit allocation

| Bit    | 7 | 6       | 5 | 4 | 3 | 2 | 1 | 0            |
|--------|---|---------|---|---|---|---|---|--------------|
| Symbol |   | yd[5:0] |   |   |   |   |   |              |
| Reset  | _ | _       | _ | _ | _ | _ | _ | <del>_</del> |
| Access | R | R       | R | R | R | R | R | R            |

#### Table 59. OUT Z MSB register (address 05h) bit allocation

| Bit    | 7 | 6        | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|--------|---|----------|---|---|---|---|---|---|--|--|--|
| Symbol |   | zd[13:6] |   |   |   |   |   |   |  |  |  |
| Reset  | _ | _        | _ | _ | _ | _ | _ | _ |  |  |  |
| Access | R | R        | R | R | R | R | R | R |  |  |  |

FXLS8471Q

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

Table 60. OUT\_Z\_LSB register (address 06h) bit allocation

|        |         | • |   |   |   |   |   |   |
|--------|---------|---|---|---|---|---|---|---|
| Bit    | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Symbol | zd[5:0] |   |   |   |   |   |   | _ |
| Reset  | _       | _ | _ | _ | _ | _ | _ | _ |
| Access | R       | R | R | R | R | R | R | R |

## 18.5 FIFO registers

## 18.5.1 F\_SETUP register (address 09h)

Table 61. F SETUP register (address 09h) bit allocation

| Bit    | 7           | 6   | 5           | 4   | 3   | 2   | 1   | 0   |  |  |
|--------|-------------|-----|-------------|-----|-----|-----|-----|-----|--|--|
| Symbol | f_mode[1:0] |     | f_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 62. F SETUP register (address 09h) bit descriptions

| Bit    | Symbol                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 6 | f_mode[1:0] <sup>[1][2][3]</sup> | FIFO buffer operating mode <b>00</b> — FIFO is disabled. (reset value) <b>01</b> — FIFO contains the most recent samples when overflowed (circular buffer). Oldest sample is discarded to be replaced by new sample. <b>10</b> — FIFO stops accepting new samples when overflowed. <b>11</b> — FIFO trigger mode.  The FIFO is flushed whenever the FIFO is disabled, during an automatic ODR change (Auto-Wake/Sleep), or on a transition from Standby mode to Active mode.  Disabling the FIFO (f_mode = 0b00) resets the F_STATUS[f_ovf], F_STATUS[f_wmrk_flag], F_STATUS[f_cnt] status flags to zero.  A FIFO overflow event (that is, F_STATUS[f_cnt] = 32) will assert the F_STATUS[f_ovf] flag. |
| 5 to 0 | f_wmrk[5:0] <sup>[2]</sup>       | FIFO sample count watermark  00 0000 — FIFO watermark event flag generation is disabled (reset value)  These bits set the number of FIFO samples required to trigger a watermark interrupt. A  FIFO watermark event flag F_STATUS[f_wmk_flag] is raised when FIFO sample count  F_STATUS[f_cnt] value is equal to or greater than the f_wmrk watermark.  Setting the f_wmrk to 0b00 0000 will disable the FIFO watermark event flag generation.  This field is also used to set the number of pretrigger samples in trigger mode (f_mode = 0b).                                                                                                                                                        |

This bit field can be written in Active mode.

A FIFO sample count exceeding the watermark event does not stop the FIFO from accepting new data.

The FIFO update rate is dictated by the selected system ODR. In Active mode, the ODR is set by CTRL\_REG1[dr] and when Auto-Sleep is active, the ODR is set by CTRL\_REG1[aslp\_rate] bit fields.

When data is read from the FIFO buffer, the oldest sample data in the buffer is returned and also deleted from the head of the FIFO, while the FIFO sample count is decremented

FXLS8471C

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

<sup>[2]</sup> This bit field can be written in Standby mode.

<sup>[3]</sup> The FIFO mode (f\_mode) cannot be switched between operational modes (01, 10 and 11).

by one. It is assumed that the host application will use the  $I^2C$  or SPI burst read transactions to dump the FIFO contents. If the FIFO X, Y, and Z data is not completely read in one burst read transaction, the next read will start at the next FIFO location X-axis data. If the Y or Z data is not read out in the same burst transaction as the X-axis data, it will be lost.

In Trigger mode, the FIFO is operated as a circular buffer and will contain up to the 32 most recent acceleration data samples. The oldest sample is discarded and replaced by the current sample, until a FIFO trigger event occurs. After a trigger event occurs, the FIFO will continue to accept samples only until overflowed, after which point the newest sample data is discarded. For more information on using the FIFO buffer and the various FIFO operating modes, refer to NXP application note AN4073.

# 18.6 Sensor data configuration registers

#### 18.6.1 XYZ DATA CFG register (address 0Eh)

The XYZ\_DATA\_CFG register is used to configure the desired acceleration full-scale range, and also to select whether the output data is passed through the high-pass filter.

Table 63. XYZ\_DATA\_CFG register (address 0Eh) bit allocation

| Bit    | 7   | 6   | 5   | 4       | 3   | 2   | 1    | 0    |
|--------|-----|-----|-----|---------|-----|-----|------|------|
| Symbol | _   | _   | _   | hpf_out | _   | _   | fs[1 | 1: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 64. XYZ\_DATA\_CFG register (address 0Eh) bit descriptions

| Bit    | Symbol  | Description                                                                                                                                            |
|--------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4      | hpf_out | Enable high-pass filter on acceleration output data <b>0</b> — High-pass filter is disabled (reset value) <b>1</b> — Output data is high-pass filtered |
| 1 to 0 | fs[1:0] | Accelerometer full-scale range selection. See <u>Table 65</u> .                                                                                        |

Table 65. Accelerometer full-scale range selection

| fs[1:0] | Sensitivity   | Full-scale range |
|---------|---------------|------------------|
| 00      | ±0.244 mg/LSB | ±2 g             |
| 01      | ±0.488 mg/LSB | ±4 g             |
| 10      | ±0.976 mg/LSB | ±8 g             |
| 11      | Reserved      | _                |

## 18.7 High-pass filter register

#### 18.7.1 HP\_FILTER\_CUTOFF register (address 0Fh)

High-pass filter cutoff frequency setting register.

FXLS8471Q

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

Table 66. HP\_FILTER\_CUTOFF register (address 0Fh) bit allocation

|        |     |     |                   | ,                |     |     |      |      |
|--------|-----|-----|-------------------|------------------|-----|-----|------|------|
| Bit    | 7   | 6   | 5                 | 4                | 3   | 2   | 1    | 0    |
| Symbol | _   | _   | pulse_<br>hpf_byp | pulse_<br>lpf_en | _   | _   | sel[ | 1: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 67. HP\_FILTER\_CUTOFF register (address 0Fh) bit descriptions

| Bit    | Symbol        | Description                                                                                                                        |
|--------|---------------|------------------------------------------------------------------------------------------------------------------------------------|
| 5      | pulse_hpf_byp | Bypass high-pass filter for pulse processing function  1 — HPF enabled for pulse processing  1 — HPF bypassed for pulse processing |
| 4      | pulse_lpf_en  | Enable low-pass filter for pulse processing function  O — LPF disabled for pulse processing  LPF enabled for pulse processing      |
| 1 to 0 | sel[1:0]      | HPF cutoff frequency selection See <u>Table 59</u> .                                                                               |

## Table 68. HP\_FILTER\_CUTOFF

|          | High-pass cutoff frequency (Hz) |       |                    |           |               |       |                    |           |  |  |
|----------|---------------------------------|-------|--------------------|-----------|---------------|-------|--------------------|-----------|--|--|
| ODR (Hz) | sel[1:0] =                      | 0b00  |                    |           | sel[1:0] = 0b |       |                    |           |  |  |
|          | Normal                          | LPLN  | High<br>Resolution | Low Power | Normal        | LPLN  | High<br>Resolution | Low Power |  |  |
| 800      | 16                              | 16    | 16                 | 16        | 8             | 8     | 8                  | 8         |  |  |
| 400      | 16                              | 16    | 16                 | 8         | 8             | 8     | 8                  | 4         |  |  |
| 200      | 8                               | 8     | 16                 | 4         | 4             | 4     | 8                  | 2         |  |  |
| 100      | 4                               | 4     | 16                 | 2         | 2             | 2     | 8                  | 1         |  |  |
| 50       | 2                               | 2     | 16                 | 1         | 1             | 1     | 8                  | 0.5       |  |  |
| 12.5     | 2                               | 0.5   | 16                 | 0.25      | 1             | 0.25  | 8                  | 0.125     |  |  |
| 6.25     | 2                               | 0.25  | 16                 | 0.125     | 1             | 0.125 | 8                  | 0.063     |  |  |
| 1.56     | 2                               | 0.063 | 16                 | 0.031     | 1             | 0.031 | 8                  | 0.016     |  |  |
| ODR (Hz) | sel[1:0] =                      | 0b    |                    | 1         | sel[1:0] = 0b |       |                    |           |  |  |
|          | Normal                          | LPLN  | High<br>Resolution | Low Power | Normal        | LPLN  | High<br>Resolution | Low Power |  |  |
| 800      | 4                               | 4     | 4                  | 4         | 2             | 2     | 2                  | 2         |  |  |
| 400      | 4                               | 4     | 4                  | 2         | 2             | 2     | 2                  | 1         |  |  |
| 200      | 2                               | 2     | 4                  | 1         | 1             | 1     | 2                  | 0.5       |  |  |
| 100      | 1                               | 1     | 4                  | 0.5       | 0.5           | 0.5   | 2                  | 0.25      |  |  |
| 50       | 0.5                             | 0.5   | 4                  | 0.25      | 0.25          | 0.25  | 2                  | 0.125     |  |  |
| 12.5     | 0.5                             | 0.125 | 4                  | 0.063     | 0.25          | 0.063 | 2                  | 0.031     |  |  |

FXLS8471Q

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

|          | High-pass of                | utoff frequen | cy (Hz)   |        |               |                    |           |       |
|----------|-----------------------------|---------------|-----------|--------|---------------|--------------------|-----------|-------|
| ODR (Hz) | sel[1:0] = 0h               | 000           |           |        | sel[1:0] = 0b |                    |           |       |
|          | Normal LPLN High Resolution |               | Low Power | Normal | LPLN          | High<br>Resolution | Low Power |       |
| 6.25     | 0.5                         | 0.063         | 4         | 0.031  | 0.25          | 0.031              | 2         | 0.016 |
| 1.56     | 0.5                         | 0.016         | 4         | 0.008  | 0.25          | 0.008              | 2         | 0.004 |

## 18.8 Portrait/Landscape detection registers

The FXLS8471Q is capable of detecting six orientations: Landscape Left, Landscape Right, Portrait Up, and Portrait Down with Z-lockout feature as well as Face Up and Face Down orientation as shown in <u>Figure 13</u>, <u>Figure 14</u> and <u>Figure 15</u>. For more details on the meaning of the different user-configurable settings and for example code, refer to NXP application note AN4068.







## 18.8.1 PL\_STATUS register (address 10h)

This status register can be read to get updated information on any change in orientation by reading bit 7, or the specifics of the orientation by reading the other bits. For further understanding of Portrait Up, Portrait Down, Landscape Left, Landscape Right, Back and Front orientations, see <a href="Figure 3">Figure 3</a>. The interrupt is cleared when reading the PL\_STATUS register.

Table 69. PL\_STATUS register (address 10h) bit allocation

|        | _     | •  | , |   |   |      |       |       |
|--------|-------|----|---|---|---|------|-------|-------|
| Bit    | 7     | 6  | 5 | 4 | 3 | 2    | 1     | 0     |
| Symbol | newlp | lo | _ | _ | _ | lapo | [1:0] | bafro |
| Reset  | 0     | 0  | 0 | 0 | 0 | 0    | 0     | 0     |
| Access | R     | R  | R | R | R | R    | R     | R     |

Table 70. PL\_STATUS register (address 10h) bit descriptions

| Bit    | Symbol                   | Description                                                                                                                                                                                                                                                                                                                   |
|--------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | newlp                    | Landscape/Portrait status change flag.  0 — No change  1 — BAFRO and/or LAPO and/or Z-tilt lockout value has changed                                                                                                                                                                                                          |
| 6      | lo                       | <ul> <li>Z-tilt angle lockout.</li> <li>0 — Lockout condition has not been detected.</li> <li>1 — Z-tilt lockout trip angle has been exceeded. Lockout condition has been detected.</li> </ul>                                                                                                                                |
| 2 to 1 | lapo[1:0] <sup>[1]</sup> | Landscape/Portrait orientation.  00 — Portrait up: equipment standing vertically in the normal orientation  01 — Portrait down: equipment standing vertically in the inverted orientation  10 — Landscape right: equipment is in landscape mode to the right  11 — Landscape left: equipment is in landscape mode to the left |
| 0      | bafro                    | Back or front orientation. <b>0</b> — Front: equipment is in the front facing orientation <b>1</b> — Back: equipment is in the back facing orientation                                                                                                                                                                        |

<sup>[1]</sup> The default power-up state is bafro(Undefined), lapo(Undefined), and no lockout for orientation function.

The *newlp* 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* occurs. The *newlp* bit is cleared anytime the PL\_STATUS register is read. *lapo*, *bafro* and *lo* continue to change when *newlp* is set. 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*.

#### 18.8.2 PL\_CFG register (address 11h)

This register enables the Portrait/Landscape function and sets the behavior of the debounce counter.

Table 71. PL\_CFG register (address 11h) bit allocation

|        |        |       | ,   |     |     |     |     |     |
|--------|--------|-------|-----|-----|-----|-----|-----|-----|
| Bit    | 7      | 6     | 5   | 4   | 3   | 2   | 1   | 0   |
| Symbol | dbcntm | pl_en | _   | _   | _   | _   | _   | _   |
| 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 72. PL\_CFG register (address 11h) bit descriptions

| Bit | Symbol | Description                                                                                                                                                                                      |
|-----|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | dbcntm | Debounce counter mode selection  1 — Decrements debounce whenever condition of interest is no longer valid.  1 — Clears counter whenever condition of interest is no longer valid. (reset value) |
| 6   | pl_en  | Portrait/Landscape detection enable <b>0</b> — Portrait/Landscape detection is disabled. (reset value) <b>1</b> — Portrait/Landscape detection is enabled.                                       |

#### 18.8.3 PL\_COUNT register (address 12h) register

This register sets the debounce count for the orientation state transition. The minimum debounce latency is determined by the system ODR value and the value of the PL\_COUNT register. Any change to the system ODR or a transition from active-to-standby (or vice-versa) resets the internal debounce counters.

Table 73. PL\_COUNT register (address 12h) bit allocation

| Table 70. 1 E_000111 Toglotor (addition 1211) bit allocation |            |     |     |     |     |     |     |     |
|--------------------------------------------------------------|------------|-----|-----|-----|-----|-----|-----|-----|
| Bit                                                          | 7          | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Symbol                                                       | dbnce[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 74. PL\_COUNT register (address 12h) bit descriptions

| Bit    | Symbol     | Description                                                                        |
|--------|------------|------------------------------------------------------------------------------------|
| 7 to 0 | dbnce[7:0] | Sets the debounce count for the orientation state transition See <u>Table 75</u> . |

FXLS84710

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

Table 75. PL\_Count Relationship with the ODR

| ODR (Hz) | Max time range (s) |       |                 |           | Time step (ms) |      |                 |           |
|----------|--------------------|-------|-----------------|-----------|----------------|------|-----------------|-----------|
|          | Normal             | LPLN  | High resolution | Low power | Normal         | LPLN | High resolution | Low power |
| 800      | 0.319              | 0.319 | 0.319           | 0.319     | 1.25           | 1.25 | 1.25            | 1.25      |
| 400      | 0.638              | 0.638 | 0.638           | 0.638     | 2.5            | 2.5  | 2.5             | 2.5       |
| 200      | 1.28               | 1.28  | 0.638           | 1.28      | 5              | 5    | 2.5             | 5         |
| 100      | 2.55               | 2.55  | 0.638           | 2.55      | 10             | 10   | 2.5             | 10        |
| 50       | 5.1                | 5.1   | 0.638           | 5.1       | 20             | 20   | 2.5             | 20        |
| 12.5     | 5.1                | 20.4  | 0.638           | 20.4      | 20             | 80   | 2.5             | 80        |
| 6.25     | 5.1                | 20.4  | 0.638           | 40.8      | 20             | 80   | 2.5             | 160       |
| 1.56     | 5.1                | 20.4  | 0.638           | 40.8      | 20             | 80   | 2.5             | 160       |

# 18.8.4 PL\_BF\_ZCOMP register (address 13h)

Back/Front and Z-tilt angle compensation register

Table 76. PL\_BF\_ZCOMP register (address 13h) bit allocation

| Bit    | 7    | 6     | 5   | 4   | 3   | 2   | 1          | 0   |
|--------|------|-------|-----|-----|-----|-----|------------|-----|
| Symbol | bkfr | [1:0] | _   | _   | _   |     | zlock[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 77. PL\_BF\_ZCOMP register (address 13h) bit descriptions

| Bit    | Symbol     | Description                                                                                                                                                                                                               |
|--------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 6 | bkfr[1:0]  | Back/front trip angle threshold. See <u>Table 79</u> for more information.<br>Default: $0b \rightarrow \pm 70^{\circ}$ . Step size is $5^{\circ}$ .<br>Range: $\pm (65^{\circ}$ to $80^{\circ}$ ).                        |
| 2 to 0 | zlock[2:0] | Z-lock angle threshold. Range is from approximately 13° to 44°. Step size is approximately 4°. See Table 78 for more information. Default value: $04h \rightarrow \sim 28$ °. Maximum value: $07h \rightarrow \sim 44$ °. |

Table 78. Z-lockout angle definitions

| zlock[2:0] | Resultant angle (min) for positions between Landscape and Portrait | Resultant angle (max) for ideal<br>Landscape or Portrait |
|------------|--------------------------------------------------------------------|----------------------------------------------------------|
| 000        | 13.6°                                                              | 14.5°                                                    |
| 001        | 17.1°                                                              | 18.2°                                                    |
| 010        | 20.7°                                                              | 22.0°                                                    |
| 011        | 24.4°                                                              | 25.9°                                                    |
| 100        | 28.1°                                                              | 30.0°                                                    |

FXLS8471Q

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

| zlock[2:0] | Resultant angle (min) for positions between Landscape and Portrait | Resultant angle (max) for ideal<br>Landscape or Portrait |
|------------|--------------------------------------------------------------------|----------------------------------------------------------|
| 101        | 32.0°                                                              | 34.2°                                                    |
| 110        | 36.1°                                                              | 38.7°                                                    |
| 111        | 40.4°                                                              | 43.4°                                                    |

#### Table 79. Back/Front orientation 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°    |

## 18.8.5 PL\_THS\_REG register (address 14h)

Portrait to landscape trip threshold register.

Table 80. PL\_THS\_REG register (address 14h) bit allocation

| Bit    | 7           | 6   | 5   | 4   | 3   | 2        | 1   | 0   |
|--------|-------------|-----|-----|-----|-----|----------|-----|-----|
| Symbol | pl_ths[4:0] |     |     |     |     | hys[2:0] |     |     |
| Reset  | 0           | 0   | 0   | 1   | 1   | 0        | 1   | 0   |
| Access | R/W         | R/W | R/W | R/W | R/W | R/W      | R/W | R/W |

Table 81. PL\_BF\_ZCOMP register (address 13h) bit descriptions

| Bit    | Symbol      | Description           |
|--------|-------------|-----------------------|
| 7 to 3 | pl_ths[4:0] | See <u>Table 82</u> . |
| 2 to 0 | hys[2:0]    | See <u>Table 83</u> . |

Table 82. Threshold angle lookup table

| pl_ths[4:0] | Threshold angle |
|-------------|-----------------|
| 0 0111      | 15°             |
| 0 1001      | 20°             |
| 0 1100      | 30°             |
| 0 1101      | 35°             |
| 0 1111      | 40°             |
| 1 0000      | 45°             |
| 1 0011      | 55°             |
| 1 0100      | 60°             |
| 1 0111      | 70°             |

FXLS8471Q

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

| pl_ths[4:0] | Threshold angle |
|-------------|-----------------|
| 1 1001      | 75°             |

Table 83. Trip angles versus hysteresis settings

| hys[2:0] | Landscape to Portrait trip angle | Portrait to Landscape trip angle |
|----------|----------------------------------|----------------------------------|
| 000      | 45°                              | 45°                              |
| 001      | 49°                              | 41°                              |
| 010      | 52°                              | 38°                              |
| 011      | 56°                              | 34°                              |
| 100      | 59°                              | 31°                              |
| 101      | 62°                              | 28°                              |
| 110      | 66°                              | 24°                              |
| 111      | 69°                              | 21°                              |

Table 84. Portrait/Landscape ideal orientation definitions

| Symbol | Description             |
|--------|-------------------------|
| PU     | y ~ -1 g, x ~ 0         |
| PD     | y ~ +1 g, x ~ 0         |
| LR     | $y \sim 0, x \sim +1 g$ |
| LL     | $y \sim 0, x \sim -1 g$ |

#### 18.9 Free-fall and Motion event detection

The freefall/motion detection block can be configured to detect low-g (freefall) or high-g (motion) events utilizing the A FFMT CFG[a ffmt oae] bit.

In low-g detect mode (A\_FFMT\_CFG[a\_ffmt\_oae] = 0) a low-g condition will need to occur on all enabled axes (ex. X, Y and Z) for the A\_FFMT\_SRC[a\_ffmt\_ea] bit to be affected. And, in high-g detect mode (A\_FFMT\_CFG[a\_ffmt\_oae] = 1) a high-g condition occurring in any of the enabled axes (ex. X, Y or Z) will suffice to affect the A FFMT\_SRC[a\_ffmt\_ea] bit.

The detection threshold(s) are programed in register 17h (A\_FFMT\_THS) for common threshold operation, and 73h to 78h (A\_FFMT\_THS\_X/Y/Z) for individual axis threshold operation.

A\_FFMT\_CFG[a\_ffmt\_ele] bit determines the behavior of A\_FFMT\_SRC[a\_ffmt\_ea] bit in response to the desired acceleration event (low-g/high-g). When A\_FFMT\_CFG[a\_ffmt\_ele] = 1, the freefall or motion event is latched and the A\_FFMT\_SRC[a\_ffmt\_ea] flag can only be cleared by reading the A\_FFMT\_SRC register. When A\_FFMT\_CFG[a\_ffmt\_ele] = 0, freefall or motion events are not latched, and the A\_FFMT\_SRC[a\_ffmt\_ea] bit reflects the real-time status of the event detection.

A\_FFMT\_THS[a\_ffmt\_dbcntm] bit determines the debounce filtering behavior of the logic that sets the A\_FFMT\_SRC[a\_ffmt\_ea] bit. See <a href="Figure 17">Figure 17</a> for details.

It is possible to enable/disable each axis used in the freefall/motion detection function by configuring bits A\_FFMT\_CFG[a\_ffmt\_xefe], A\_FFMT\_CFG[a\_ffmt\_yefe], and A\_FFMT\_CFG[a\_ffmt\_zefe].

The freefall/motion detection function has the option to use a common 7-bit unsigned threshold for each of the X, Y, and Z axes, or individual unsigned 13-bit thresholds for each axis. When A\_FFMT\_THS\_X\_MSB[a\_ffmt\_ths\_xyz\_en] = 0, the 7-bit threshold value stored in register 17h is used as a common 7-bit threshold for the X, Y, and Z axes. When a\_ffmt\_ths\_xyz\_en = 1, each axis may be programmed with an individual 13-bit threshold (stored in the A\_FFMT\_X/Y/Z MSB and LSB registers).

#### 18.9.1 A\_FFMT\_CFG register (address 15h)

Free-fall/motion configuration register.

Table 85. A\_FFMT\_CFG register (address 15h) bit allocation

| Bit    | 7          | 6          | 5           | 4           | 3           | 2   | 1   | 0   |
|--------|------------|------------|-------------|-------------|-------------|-----|-----|-----|
| Symbol | a_ffmt_ele | a_ffmt_oae | a_ffmt_zefe | a_ffmt_yefe | a_ffmt_xefe | _   | _   | _   |
| 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 86. A\_FFMT\_CFG register (address 15h) bit descriptions

| Bit | Symbol      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | a_ffmt_ele  | <ul> <li>0 — Event flag latch disabled (reset value)</li> <li>1 — Event flag latch enabled</li> <li>a_ffmt_ele denotes whether the enabled event flag will be latched in the A_FFMT_SRC register or the event flag status in the A_FFMT_SRC will indicate the real-time status of the event. If a_ffmt_ele bit is set to a logic '1', then the event flags are frozen when the a_ffmt_ea bit gets set, and are cleared by reading the A_FFMT_SRC source register.</li> </ul>   |
| 6   | a_ffmt_oae  | Motion detect/free-fall detect logic selection. <b>0</b> — Free-fall flag (logical AND combination of low- <i>g</i> X-, Y-, Z-axis event flags) (reset value) <b>1</b> — Motion flag (logical OR combination of high- <i>g</i> X-, Y-, Z event flags)  a_ffmt_oae bit allows the selection between motion (logical OR combination of high- <i>g</i> X-, Y-, Z-axis event flags) and free-fall (logical AND combination of low- <i>g</i> X-, Y-, Z-axis event flags) detection. |
| 5   | a_ffmt_zefe | <ul> <li>0 — Event detection disabled (reset value)</li> <li>1 — Raise event flag on measured Z-axis acceleration above/below threshold.</li> <li>a_ffmt_zefe enables the detection of a high- or low-g event when the measured acceleration data on Z-axis is above/below the threshold set in the A_FFMT_THS register. If a_ffmt_ele is set to logic '1', new event flags are blocked from updating the A_FFMT_SRC register.</li> </ul>                                      |
| 4   | a_ffmt_yefe | <ul> <li>0 — Event detection disabled (reset value)</li> <li>1 — Raise event flag on measured Y-axis acceleration above/below threshold.</li> <li>a_ffmt_yefe enables the detection of a high- or low-g event when the measured acceleration data on Y-axis is above/below the threshold set in the A_FFMT_THS register. If a_ffmt_ele bit is set to logic '1', new event flags are blocked from updating the A_FFMT_SRC register.</li> </ul>                                  |

| Bit | Symbol      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | a_ffmt_xefe | <ul> <li>0 — Event detection disabled (reset value)</li> <li>1 — Raise event flag on measured X-axis acceleration above/below threshold.</li> <li>a_ffmt_xefe enables the detection of a high- or low-g event when the measured acceleration data on X-axis is above/below the threshold set in the A_FFMT_THS register. If a_ffmt_ele bit is set to logic '1', new event flags are blocked from updating the A_FFMT_SRC register.</li> </ul> |

## 18.9.2 A\_FFMT\_SRC register (address 16h)

Freefall/motion source register. Read-only register.

The free-fall/motion source register keeps track of the acceleration event that is triggering (or has triggered, in case of A\_FFMT\_CFG[a\_ffmt\_ele] = 1) the event flag. In particular A\_FFMT\_SRC[a\_ffmt\_ea] is set to a logic '1' when the logical combination of acceleration event flags specified in A\_FFMT\_CFG register is true. This bit is used in combination with the values in CTRL\_REG4[int\_en\_ffmt] and CTRL\_REG5[int\_cfg\_ffmt] register bits to generate the free-fall/motion interrupts.

Table 87. A\_FFMT\_SRC register (address 16h) bit allocation

| Bit    | 7         | 6 | 5          | 4          | 3          | 2          | 1          | 0          |
|--------|-----------|---|------------|------------|------------|------------|------------|------------|
| Symbol | a_ffmt_ea | _ | a_ffmt_zhe | a_ffmt_zhp | a_ffmt_yhe | a_ffmt_yhp | a_ffmt_xhe | a_ffmt_xhp |
| Reset  | 0         | 0 | 0          | 0          | 0          | 0          | 0          | 0          |
| Access | R         | R | R          | R          | R          | R          | R          | R          |

Table 88. A\_FFMT\_SRC register (address 16h) bit descriptions

| Bit | Symbol     | Description                                                                                                                                                                                                                                       |
|-----|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | a_ffmt_ea  | Event active flag  0 — No event flag has been asserted (reset value)  1 — One or more event flag has been asserted. See the description of the A_FFMT_CFG[a_ffmt_oae] bit to determine the effect of the 3-axis event flags on the a_ffmt_ea bit. |
| 5   | a_ffmt_zhe | <ul> <li>Z-high event flag</li> <li>0 — Event detected (reset value)</li> <li>1 — Z-high event has been detected</li> <li>This bit always reads zero if the a_ffmt_zefe control bit is set to zero</li> </ul>                                     |
| 4   | a_ffmt_zhp | <ul> <li>Z-high event polarity flag</li> <li>O — Z event was positive g (reset value)</li> <li>1 — Z event was negative g</li> <li>This bit always reads zero if the a_ffmt_zefe control bit is set to zero</li> </ul>                            |
| 3   | a_ffmt_yhe | Y-high event flag  0 — No event detected (reset value)  1 — Y-high event has been detected  This bit always reads zero if the a_ffmt_yefe control bit is set to zero                                                                              |
| 2   | a_ffmt_yhp | Y-high event polarity flag <b>0</b> — Y event detected was positive <i>g</i> (reset value) <b>1</b> — Y event was negative <i>g</i> This bit always reads zero if the <i>a_ffmt_yefe</i> control bit is set to zero                               |

| Bit | Symbol     | Description                                                                                                                                                                                                                  |
|-----|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | a_ffmt_xhe | X-high event flag  0 — No event detected (reset value)  1 — X-high event has been detected  This bit always reads zero if the a_ffmt_xefe control bit is set to zero                                                         |
| 0   | a_ffmt_xhp | X-high event polarity flag. Default value: 0 <b>0</b> — X event was positive <i>g</i> (reset value) <b>1</b> — X event was negative <i>g</i> This bit always reads zero if the <i>a_ffmt_xefe</i> control bit is set to zero |

# 18.9.3 A\_FFMT\_THSxxxxxx registers (addresses 17h, 73h to 78h)

Free-fall/motion detection threshold registers.

Table 89. A\_FFMT\_THS register (address 17h) bit allocation

| Bit    | 7             | 6   | 5        | 4   | 3   | 2   | 1   | 0   |
|--------|---------------|-----|----------|-----|-----|-----|-----|-----|
| Symbol | a_ffmt_dbcntm |     | ths[6: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 90. A\_FFMT\_THS register (address 17h) bit descriptions

| Bit    | Symbol        | Description                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | a_ffmt_dbcntm | The fucntion uses a_ffmt_dbcntm to set the acceleration FFMT debounce counter clear mode independent of the value of the a_ffmt_ths_xyz_en.  a_ffmt_dbcntm bit configures the way in which the debounce counter is reset when the inertial event of interest is momentarily not true.                                                                                                                                  |
|        |               | When a_ffmt_dbcntm bit is a logic '1', the debounce counter is cleared to 0 whenever the inertial event of interest is no longer true (part b, Figure 17) while if the a_ffmt_dbcntm bit is set to logic '0' the debounce counter is decremented by 1 whenever the inertial event of interest in longer true (part c, Figure 17) until the debounce counter reaches 0 or the inertial event of interest become active. |
|        |               | The decrementing of the debounce counter acts to filter out irregular or spurious events, which might impede the correct detection of desired inertial events.                                                                                                                                                                                                                                                         |
| 6 to 0 | ths[6:0]      | Free-fall/motion detection threshold  000 0000 — (reset value)                                                                                                                                                                                                                                                                                                                                                         |
|        |               | Resolution is fixed at 63 mg/LSB, irrespective of the device full-scale range selection.                                                                                                                                                                                                                                                                                                                               |

## Table 91. A\_FFMT\_THS\_X\_MSB register (address 73h) bit allocation

| Bit    | 7                 | 6                  | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-------------------|--------------------|-----|-----|-----|-----|-----|-----|
| Symbol | a_ffmt_ths_xyz_en | a_ffmt_ths_x[12:6] |     |     |     |     |     |     |
| 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 |

FXLS8471C

Table 92. A FFMT THS X MSB register (address 73h) bit descriptions

| Bit    | Symbol             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | a_ffmt_ths_xyz_en  | For a_ffmt_ths_xyz_en = 0, the function uses the ffmt_ths[6:0] value located in register 17h[6:0] as a common threshold for the X-, Y-, and Z-axis acceleration detection. The common unsigned 7-bit acceleration threshold has a fixed resolution of 63 mg/LSB, with a range of 0 to 127 counts.  For a_ffmt_ths_xyz_en = 1 the function ignores the common 7-bit G_FFMT_THS value located in register 17h when executing the FFMT function, and the following independent threshold values are used for each axis:  A_FFMT_THS_X_MSB and A_FFMT_THS_X_LSB are used for the X-axis acceleration threshold, |
|        |                    | A_FFMT_THS_Y_MSB and A_FFMT_THS_Y_LSB for the Y-axis acceleration threshold, A_FFMT_THS_Z_MSB and A_FFMT_THS_Z_LSB for the Z-axis acceleration threshold. The A_FFMT_THS_X/Y/Z thresholds are 13-bit unsigned values that have the same resolution as the accelerometer output data determined by XYZ_DATA_CFG fs [1:0]. The a_ffmt_ths_xyz_en and a_ffmt_trans_ths_en bits must not be enabled simultaneously, as incorrect function operation will result.                                                                                                                                                |
| 6 to 0 | a_ffmt_ths_x[12:6] | 7-bit MSB of X-axis acceleration threshold                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

#### Table 93. A\_FFMT\_THS\_X\_LSB register (address 74h) bit allocation

| Bit    | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|-----|-----|-----|-----|
| Symbol |     | _   | _   |     |     |     |     |     |
| Reset  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Access | R/W |

## Table 94. A\_FFMT\_THS\_X\_LSB register (address 74h) bit descriptions

| Bit    | Symbol            | Description                                |
|--------|-------------------|--------------------------------------------|
| 5 to 0 | a_ffmt_ths_x[5:0] | 6-bit LSB of X-axis acceleration threshold |

#### Table 95. A FFMT THS Y MSB register (address 75h) bit allocation

| Bit    | 7                       | 6   | 5                  | 4   | 3   | 2   | 1   | 0   |  |  |
|--------|-------------------------|-----|--------------------|-----|-----|-----|-----|-----|--|--|
| Symbol | a_ffmt_<br>trans_ths_en |     | a_ffmt_ths_y[12:6] |     |     |     |     |     |  |  |
| 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 96. A\_FFMT\_THS\_Y\_MSB register (address 75h) bit descriptions

| Bit     | Symbol              | Description                                                                                                   |
|---------|---------------------|---------------------------------------------------------------------------------------------------------------|
| 7       | a_ffmt_trans_ths_en | The a_ffmt_trans_ths_en bits must not be enabled simultaneously, as incorrect function operation will result. |
| 12 to 6 | a_ffmt_ths_y[12:6]  | 7-bit MSB of X-axis acceleration threshold                                                                    |

FXLS84710

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

Table 97. A\_FFMT\_THS\_Y\_LSB register (address 76h) bit allocation

| Bit    | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|-----|-----|-----|-----|
| Symbol |     |     | _   | _   |     |     |     |     |
| Reset  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Access | R/W |

Table 98. A\_FFMT\_THS\_Y\_LSB register (address 76h) bit descriptions

| Bit    | Symbol            | Description                                |
|--------|-------------------|--------------------------------------------|
| 5 to 0 | a_ffmt_ths_y[5:0] | 6-bit LSB of Y-axis acceleration threshold |

Table 99. A\_FFMT\_THS\_Z\_MSB register (address 77h) bit allocation

| Bit    | 7            | 6   | 5                  | 4   | 3   | 2   | 1   | 0   |  |
|--------|--------------|-----|--------------------|-----|-----|-----|-----|-----|--|
| Symbol | <del>_</del> |     | a_ffmt_ths_z[12:6] |     |     |     |     |     |  |
| 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 100. A\_FFMT\_THS\_Z\_MSB register (address 77h) bit descriptions

| Bit     | Symbol             | Description                                |
|---------|--------------------|--------------------------------------------|
| 12 to 6 | a_ffmt_ths_z[12:6] | 7-bit LSB of Z-axis acceleration threshold |

Table 101. A\_FFMT\_THS\_Z\_LSB register (address 78h) bit allocation

| Bit    | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|-----|-----|-----|-----|
| Symbol |     | _   | _   |     |     |     |     |     |
| Reset  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Access | R/W |

Table 102. A FFMT THS Z LSB register (address 78h) bit descriptions

| Bit    | Symbol            | Description                                |
|--------|-------------------|--------------------------------------------|
| 5 to 0 | a_ffmt_ths_z[5:0] | 6-bit LSB of Z-axis acceleration threshold |



FXLS8471Q

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

A\_FFMT\_THS contains the unsigned 7-bit threshold value used by the free-fall/ motion detection functional block and is used to detect either low-*g* (free fall) or high-*g* (motion) events depending on the setting of G\_FFMT\_CFG[*f\_ffmt\_oae*]. If *g\_ffmt\_oae* = 0, the event is detected when the absolute value of all the enabled axes are below the threshold value. When *g\_ffmt\_oae* = 1, the event is detected when the absolute value of any of the enabled axes is above the threshold value. See Figure 16 for an illustration of the free-fall/motion event detection thresholds. If A\_FFMT\_THS\_X\_MSB[a\_ffmt\_ths\_xyz\_en] = 1, the behavior is identical, except that each axis can be programmed with an individual 13-bit threshold (stored in the A\_FFMT\_X/Y/Z\_MSB\_and\_LSB\_registers).

#### 18.9.4 A\_FFMT\_COUNT register (address 18h)

The debounce count register for free-fall/motion detection events sets the number of debounce counts for acceleration sample data matching the user-programmed conditions for either a free-fall or motion detection event required before the interrupt is triggered.

Table 103. A FFMT COUNT register (address 18h) bit allocation

| Bit    | 7   | 6                 | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|--------|-----|-------------------|-----|-----|-----|-----|-----|-----|--|--|
| Symbol |     | a_ffmt_count[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 104. A\_FFMT\_COUNT register (address 18h) bit description

| Bit    | Symbol | Description                                                                                                                                                                                                                                         |
|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 0 |        | a_ffmt_count defines the minimum number of debounce sample counts required for the detection of a free-fall or motion event. A_FFMT_THS[ffmt_dbcntm] determines the behavior of the counter when the condition of interest is momentarily not true. |

When the internal debounce counter reaches the A\_FFMT\_COUNT value a free-fall/motion event flag is set. The debounce counter will never increase beyond the A\_FFMT\_COUNT value. The time step used for the debounce sample count depends on the ODR chosen. See Table 105.

Table 105. A\_FFMT\_COUNT relationship with the ODR

| ODR (Hz) | Max time ra | nge (s) |                 |           | Time step (ms) |      |                 |      |
|----------|-------------|---------|-----------------|-----------|----------------|------|-----------------|------|
|          | Normal      | LPLN    | High resolution | Low power | Normal         | LPLN | High resolution | LP   |
| 800      | 0.319       | 0.319   | 0.319           | 0.319     | 1.25           | 1.25 | 1.25            | 1.25 |
| 400      | 0.638       | 0.638   | 0.638           | 0.638     | 2.5            | 2.5  | 2.5             | 2.5  |
| 200      | 1.28        | 1.28    | 0.638           | 1.28      | 5              | 5    | 2.5             | 5    |
| 100      | 2.55        | 2.55    | 0.638           | 2.55      | 10             | 10   | 2.5             | 10   |
| 50       | 5.1         | 5.1     | 0.638           | 5.1       | 20             | 20   | 2.5             | 20   |
| 12.5     | 5.1         | 20.4    | 0.638           | 20.4      | 20             | 80   | 2.5             | 80   |
| 6.25     | 5.1         | 20.4    | 0.638           | 40.8      | 20             | 80   | 2.5             | 160  |
| 1.56     | 5.1         | 20.4    | 0.638           | 40.8      | 20             | 80   | 2.5             | 160  |

FXLS8471Q

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

For example, an ODR of 100 Hz and an A\_ FFMT\_COUNT value of 15h would result in a minimum debounce response time of 150 ms.



Figure 17. Behavior of the A\_FFMT debounce counter in relation to the a\_ffmt\_dbcntm setting

#### 18.10 Accelerometer vector-magnitude function registers

The accelerometer vector-magnitude function is an inertial-event detection function available to assist host software algorithms in detecting motion events.

If  $\sqrt{(a_x_{out} - a_x_{ref})^2 + (a_y_{out} - a_y_{ref})^2 + (a_z_{out} - a_z_{ref})^2} > A_v_{ext}^2 > A_v_{ext$ 

a\_x\_out, a\_y\_out, and a\_z\_out are the current accelerometer output values, and a\_x\_ref, a\_y\_ref, and a\_z\_ref are the reference values stored internally in the ASIC for each axis or in A\_VECM\_INIT\_X/Y/Z registers if A\_VECM\_CFG[a\_vecm\_initm] is set.

Note that the x\_ref, y\_ref, and z\_ref values are not directly visible to the host application through the register interface. Refer to NXP application note AN4458.

FXLS8471Q

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

# 18.10.1 A\_VECM\_CFG register (address 5Fh)

## Table 106. A\_VECM\_CFG register (address 5Fh) bit allocation

| Bit    | 7   | 6          | 5            | 4           | 3         | 2   | 1   | 0   |
|--------|-----|------------|--------------|-------------|-----------|-----|-----|-----|
| Symbol | _   | a_vecm_ele | a_vecm_initm | a_vecm_updm | a_vecm_en | _   | _   | _   |
| 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 107. A\_VECM\_CFG register (address 5Fh) bit descriptions

| Bit | Symbol       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | a_vecm_ele   | Control bit a_vecm_ele defines the event latch enable mode. Event latching is disabled for a_vecm_ele = 0. In this case, the vector-magnitude interrupt flag is in updated real time and is cleared when the condition for triggering the interrupt is no longer true. The setting and clearing of the event flag is controlled by the A_VECM_CNT register's programmed debounce time.  For a_vecm_ele = 1, the interrupt flag is latched in and held until the host application reads the INT_SOURCE register (0Ch). |
| 5   | a_vecm_initm | Control bit a_vecm_initm defines how the initial reference values (x_ref, y_ref, and z_ref) are chosen.  For a_vecm_initm = 0 the function uses the current x/y/z accelerometer output data at the time when the vector magnitude function is enabled.                                                                                                                                                                                                                                                                |
|     |              | For a_vecm_initm = 1 the function uses the data from A_VECM_INIT_X/Y/Z registers as the initial reference values.                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4   | a_vecm_updm  | Control bit a_vecm_updm defines how the reference values are updated once the vector-magnitude function has been triggered.                                                                                                                                                                                                                                                                                                                                                                                           |
|     |              | For <i>a_vecm_updm</i> = 0, the function updates the reference value with the current x, y, and z accelerometer output data values.                                                                                                                                                                                                                                                                                                                                                                                   |
|     |              | For a_vecm_updm = 1, the function does not update the reference values when the interrupt is triggered. Instead the function continues to use the reference values that were loaded when the function was enabled. If both a_vecm_initm and a_vecm_updm are set to logic '1', the host software can manually update the reference values in real time by writing to the A_VECM_INITX/Y/Z registers.                                                                                                                   |
| 3   | a_vecm_en    | The accelerometer vector-magnitude function is enabled by setting <code>a_vecm_en</code> = 1, and disabled by clearing this bit (reset value). The reference values are loaded with either the current X/Y/Z acceleration values or the values stored in the A_VECM_INIT_X/Y/Z registers, depending on the state of the <code>a_vecm_initm</code> bit.                                                                                                                                                                |
|     |              | <b>Note:</b> The vector-magnitude function will only perform correctly up to a maximum ODR of 400 Hz.                                                                                                                                                                                                                                                                                                                                                                                                                 |

# 18.10.2 A\_VECM\_THS\_MSB register (address 60h)

## Table 108. A\_VECM\_THS\_MSB register (address 60h) bit allocation

| Bit    | 7             | 6   | 5   | 4   | 3   | 2           | 1   | 0   |
|--------|---------------|-----|-----|-----|-----|-------------|-----|-----|
| Symbol | a_vecm_dbcntm |     | _   |     | a_  | vecm_ths[12 | :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 |

FXLS8471C

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

#### Table 109. A VECM THS MSB register (address 60h) bit descriptions

| Bit    | Symbol           | Description                                                                                                                                               |
|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | a_vecm_dbcntm    | Control bit a_vecm_dbcntm defines how the debounce timer is reset when the condition for triggering the interrupt is no longer true.                      |
|        |                  | <b>0</b> — The debounce counter is decremented by 1 when the vector-magnitude result is below the programmed threshold value.                             |
|        |                  | <b>1</b> — The debounce counter is cleared when the vector-magnitude result is below the programmed threshold value.                                      |
| 4 to 0 | a_vecm_ths[12:8] | Five MSBs of the 13-bit unsigned A_VECM_THS value. The threshold resolution is equal to the selected accelerometer resolution as set in XYZ_DATA_CFG[fs]. |

### 18.10.3 A\_VECM\_THS\_LSB register (address 61h)

#### Table 110. A VECM THS LSB register (address 61h) bit allocation

| Bit    | 7   | 6               | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-----|-----------------|-----|-----|-----|-----|-----|-----|
| Symbol |     | a_vecm_ths[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 111. A\_VECM\_THS\_LSB bit description

| Bit    | Symbol          | Description                                     |
|--------|-----------------|-------------------------------------------------|
| 7 to 0 | a_vecm_ths[7:0] | Vector-magnitude function debounce count value. |

## 18.10.4 A\_VECM\_CNT register (address 62h)

#### Table 112. A VECM CNT register (address 62h) bit allocation

|        |     | - 5 (           |     |     |     |     |     |     |
|--------|-----|-----------------|-----|-----|-----|-----|-----|-----|
| Bit    | 7   | 6               | 5   | 4   | 3   | 2   | 1   | 0   |
| Symbol |     | a_vecm_cnt[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 113. A\_VECM\_CNT bit description

| Bit    | Symbol          | Description                                     |
|--------|-----------------|-------------------------------------------------|
| 7 to 0 | a_vecm_cnt[7:0] | Vector-magnitude function debounce count value. |

The debounce timer period is determined by the ODR selected in CTRL\_REG1 (and CTRL\_REG6, as enabling the temperature sensor output effectively halves the ODR selected in CTRL\_REG1); it is equal to the number indicated in A\_VECM\_CNT register multiplied by the ODR period, i.e., 1/ODR. For example, a value of 16 in A\_VECM\_CNT with an effective ODR of 400 Hz will result in a debounce period of 40 ms.

FXLS84710

## 18.10.5 A\_VECM\_INITX\_MSB register (address 63h)

## Table 114. A\_VECM\_INITX\_MSB register (address 63h) bit allocation

| Bit    | 7   | 6   | 5                  | 4   | 3   | 2   | 1   | 0   |
|--------|-----|-----|--------------------|-----|-----|-----|-----|-----|
| Symbol | _   | _   | a_vecm_initx[13: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 115. A\_VECM\_INITX\_MSB register (address 63h) bit description

| Bit    | Symbol | Description                                                                                                                                                                                                                                   |
|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5 to 0 | I .    | Most significant 6 bits of the signed 14-bit initial X-axis value to be used as ref_x when A_VECM_CFG[a_vecm_initm] = 1. The resolution is determined by the settings made in XYZ_DATA_CFG[fs], and is equal to the accelerometer resolution. |

## 18.10.6 A\_VECM\_INITX\_LSB register (address 64h)

#### Table 116. A VECM INITX LSB register (address 64h) bit allocation

| Bit    | 7   | 6                 | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-----|-------------------|-----|-----|-----|-----|-----|-----|
| Symbol |     | a_vecm_initx[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 117. A\_VECM\_INITX\_LSB register (address 64h) bit description

| Bit    | Symbol | Description                                                                                                                                                                                                               |
|--------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 0 |        | LSB of the signed 14-bit initial X-axis value to be used as ref_x when A_VECM_CFG[a_vecm_initm] = 1. The resolution is determined by the settings made in XYZ_DATA_CFG[fs], and is equal to the accelerometer resolution. |

## 18.10.7 A\_VECM\_INITY\_MSB register (address 65h)

#### Table 118. A VECM INITY MSB register (address 65h) bit allocation

|        |     |     | (                  | , , , , , , , , , , , , , , , , , , , , |     |     |     |     |
|--------|-----|-----|--------------------|-----------------------------------------|-----|-----|-----|-----|
| Bit    | 7   | 6   | 5                  | 4                                       | 3   | 2   | 1   | 0   |
| Symbol | _   | _   | a_vecm_inity[13: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 119. A\_VECM\_INITY\_MSB register (address 65h) bit description

|        | · · · · · · · · · · · · · · · · · · · |                                                                                                                                                                                                                                               |  |  |  |  |  |  |
|--------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Bit    | Symbol                                | Description                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| 5 to 0 | a_vecm_inity[13:8]                    | Most significant 6 bits of the signed 14-bit initial Y-axis value to be used as ref_y when A_VECM_CFG[a_vecm_initm] = 1. The resolution is determined by the settings made in XYZ_DATA_CFG[fs], and is equal to the accelerometer resolution. |  |  |  |  |  |  |

FXLS84710

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

## 18.10.8 A\_VECM\_INITY\_LSB register (address 66h)

#### Table 120. A VECM INITY LSB register (address 66h) bit allocation

|        |     |                   | (   | <b>/</b> 1010 01110 001 |     |     |     |     |
|--------|-----|-------------------|-----|-------------------------|-----|-----|-----|-----|
| Bit    | 7   | 6                 | 5   | 4                       | 3   | 2   | 1   | 0   |
| Symbol |     | a_vecm_inity[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 121. A\_VECM\_INITY\_LSB register (address 66h) bit description

| Bit    | Symbol | Description                                                                                                                                                                                                               |
|--------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 0 |        | LSB of the signed 14-bit initial Y-axis value to be used as ref_y when A_VECM_CFG[a_vecm_initm] = 1. The resolution is determined by the settings made in XYZ_DATA_CFG[fs], and is equal to the accelerometer resolution. |

## 18.10.9 A\_VECM\_INITZ\_MSB register (address 67h)

#### Table 122. A VECM INITZ MSB register (address 67h) bit allocation

| Bit    | 7   | 6   | 5   | 4   | 3        | 2          | 1   | 0   |
|--------|-----|-----|-----|-----|----------|------------|-----|-----|
| Symbol |     |     |     |     | a_vecm_i | nitz[13: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 123. A VECM INITZ MSB register (address 67h) bit description

| Bit    | Symbol      | Description                                                                                                                                                                                                                                   |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5 to 0 | initz[13:8] | Most significant 6 bits of the signed 14-bit initial Z-axis value to be used as ref_z when A_VECM_CFG[a_vecm_initm] = 1. The resolution is determined by the settings made in XYZ_DATA_CFG[fs], and is equal to the accelerometer resolution. |

## 18.10.10 A\_VECM\_INITZ\_LSB register (address 68h)

#### Table 124. A VECM INITZ LSB register (address 68h) bit allocation

| - anio 12 ii / L v Z o iii _ ii ii z _ z o gioto: (aaai ooo oo ii) bit aii oo aatoii |     |                   |     |     |     |     |     |     |
|--------------------------------------------------------------------------------------|-----|-------------------|-----|-----|-----|-----|-----|-----|
| Bit                                                                                  | 7   | 6                 | 5   | 4   | 3   | 2   | 1   | 0   |
| Symbol                                                                               |     | a_vecm_initz[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 125. A\_VECM\_INITZ\_LSB bit description

| Bit    | Symbol | Description                                                                                                                                                                                                               |
|--------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 0 |        | LSB of the signed 14-bit initial Z-axis value to be used as ref_z when A_VECM_CFG[a_vecm_initm] = 1. The resolution is determined by the settings made in XYZ_DATA_CFG[fs], and is equal to the accelerometer resolution. |

FXLS84710

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

# 18.11 Transient (AC) acceleration detection registers

The transient detection function is similar to the free-fall/motion detection function with the exception that a high-pass filter can be used to eliminate the DC offset from the acceleration data. There is an option to disable the high-pass filter, which causes the transient detection function to work in a similar manner to the motion detection function.

The transient detection function can be configured to signal an interrupt when the high-pass filtered acceleration delta values for any of the enabled axes exceeds the threshold programmed in TRANSIENT\_THS for the debounce time programmed in TRANSIENT\_COUNT. For more information on how to use and configure the transient detection function refer to NXP application note AN4461.

## 18.11.1 TRANSIENT\_CFG register (address 1Dh)

Table 126. TRANSIENT\_CFG register (address 1Dh) bit allocation

|        | _   | 3   |     | ,        |           |           |           |              |
|--------|-----|-----|-----|----------|-----------|-----------|-----------|--------------|
| Bit    | 7   | 6   | 5   | 4        | 3         | 2         | 1         | 0            |
| Symbol | _   | _   | _   | tran_ele | tran_zefe | tran_yefe | tran_xefe | tran_hpf_byp |
| 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 127. TRANSIENT\_CFG register (address 1Dh) bit descriptions

| Bit | Symbol       | Description                                                                                                                                                                                                                                                                                                     |
|-----|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4   | tran_ele     | Transient event flag latch  O — Event flag latch disabled; the transient interrupt flag reflects the real-time status of the function. (reset value)  1 — Event flag latch enabled; the transient interrupt event flag is latched and a read of the TRANSIENT_SRC register is required to clear the event flag. |
| 3   | tran_zefe    | <ul> <li>Z-axis transient event flag</li> <li>O — Z-axis event detection disabled (reset value)</li> <li>1 — Z-axis event detection enabled. Raise event flag on Z-axis acceleration value greater than threshold.</li> </ul>                                                                                   |
| 2   | tran_yefe    | Y-axis transient event flag enable <b>0</b> — Y-axis event detection disabled (reset value) <b>1</b> — Y-axis event detection enabled. Raise event flag on Y-axis acceleration value greater than threshold.                                                                                                    |
| 1   | tran_xefe    | X-axis transient event flag enable  0 — X-axis event detection disabled (reset value)  1 — X-axis event detection enabled. Raise event flag on X-axis acceleration value greater than threshold.                                                                                                                |
| 0   | tran_hpf_byp | Transient function high-pass filter bypass  0 — High-pass filter is applied to accelerometer data input to the transient function. (reset value)  1 — High-pass filter is not applied to accelerometer data input to the transient function.                                                                    |

## 18.11.2 TRANSIENT\_SRC register (address 1Eh)

Transient event flag source register. This register provides the event status of the enabled axes and polarity (directional) information.

Table 128. TRANSIENT SRC register (address 1Eh) bit allocation

|        | _ | - 5 (   |          |           |          |           |          |            |
|--------|---|---------|----------|-----------|----------|-----------|----------|------------|
| Bit    | 7 | 6       | 5        | 4         | 3        | 2         | 1        | 0          |
| Symbol | _ | tran_ea | tran_zef | tran_zpol | tran_yef | tran_ypol | tran_xef | trans_xpol |
| Reset  | 0 | 0       | 0        | 0         | 0        | 0         | 0        | 0          |
| Access | R | R       | R        | R         | R        | R         | R        | R          |

Table 129. TRANSIENT SRC register (address 1Eh) bit descriptions

| Bit | Symbol    | Description                                                                                                                                                                                                                                    |
|-----|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | tran_ea   | Transient event active flag  0 — No transient event active flag has been asserted. (reset value)  1 — One or more transient event active flags has been asserted.                                                                              |
| 5   | tran_zef  | Z-axis transient event active flag <b>0</b> — Z-axis event flag is not active. (reset value) <b>1</b> — Z-axis event flag is active; Z-axis acceleration has exceeded the programmed threshold for the debounce time specified in TRANS_COUNT. |
| 4   | tran_zpol | <ul> <li>Z-axis event flag polarity</li> <li>Z-axis event was above positive threshold value. (reset value)</li> <li>Z-axis event was below negative threshold value.</li> </ul>                                                               |
| 3   | tran_yef  | Y-axis transient event active flag <b>0</b> — Y-axis event flag is not active. (reset value) <b>1</b> — Y-axis event flag is active; Y-axis acceleration has exceeded the programmed threshold for the debounce time specified in TRANS_COUNT. |
| 2   | tran_ypol | Y-axis event flag polarity. <b>0</b> — Y-axis event was above positive threshold value. (reset value) <b>1</b> — Y-axis event was below negative threshold value.                                                                              |
| 1   | tran_xef  | X-axis transient event active flag <b>0</b> — X-axis event flag is not active. (reset value) <b>1</b> — X-axis event flag is active; X-axis acceleration has exceeded the programmed threshold for the debounce time specified in TRANS_COUNT. |
| 0   | tran_xpol | <ul> <li>X-axis event flag polarity.</li> <li>0 — X-axis event was above positive threshold value. (reset value)</li> <li>1 — X-axis event was below negative threshold value.</li> </ul>                                                      |

When TRANSIENT\_CFG[tran\_ele] = 1, the TRANSIENT\_SRC event flag(s) and polarity bits are latched when the interrupt event is triggered, allowing the host application to determine which event flag(s) originally triggered the interrupt. When TRANSIENT\_CFG[tran\_ele] = 0, events that occur after the event that originally triggered the interrupt will update the flag and polarity bits. However, once set, the flags can only be cleared by reading the TRANSIENT\_SRC register.

## 18.11.3 TRANSIENT\_THS register (address 1Fh)

The TRANSIENT\_THS register determines the debounce counter behavior and also sets the transient event detection threshold. It is possible to use A\_FFMT\_THS\_X/Y/Z MSB and LSB registers to set transient acceleration thresholds for individual axes using the a\_ffmt\_trans\_ths\_en bit in A\_FFMT\_THS\_Y\_MSB register.

Table 130. TRANSIENT\_THS register (address 1Fh) bit allocation

| Bit    | 7         | 6   | 5           | 4   | 3   | 2   | 1   | 0   |
|--------|-----------|-----|-------------|-----|-----|-----|-----|-----|
| Symbol | tr_dbcntm |     | tr_ths[6: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 131. TRANSIENT THS register (address 1Fh) bit descriptions

| Bit    | Symbol      | Description                                                                                                                                                                                                                            |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | tr_dbcntm   | Debounce counter mode selection.                                                                                                                                                                                                       |
|        |             | <b>0</b> — Decrements debounce counter when the transient event condition is not true during the current ODR period. (reset value)                                                                                                     |
|        |             | <b>1</b> — Clears debounce counter when the transient event condition is not true during the current ODR period.                                                                                                                       |
| 6 to 0 | tr_ths[6:0] | Transient event threshold This register has a resolution of 63 mg/LSB regardless of the full-scale range setting made in XYZ_DATA_CFG[ $fs$ ]. If CTRL_REG1[ $Inoise$ ] = 1, the maximum acceleration measurement range is $\pm 4~g$ . |

The tr\_ths[6:0] value is a 7-bit unsigned number, with a fixed resolution of 63 mg/LSB corresponding to a  $\pm 8~g$  measurement range. The resolution does not change with the full-scale range setting made in XYZ\_DATA\_CFG[fs]. If CTRL\_REG1[Inoise] = 1, the measurement range is fixed at  $\pm 4~g$ , regardless of the settings made in XYZ\_DATA\_CFG.

#### 18.11.4 TRANSIENT\_COUNT register (address 20h)

The TRANSIENT\_COUNT register sets the minimum number of debounce counts needed to trigger the transient event interrupt flag when the measured acceleration value exceeds the threshold set in TRANSIENT\_THS for any of the enabled axes.

Table 132. TRANSIENT COUNT register (address 20h) bit allocation

| Bit    | 7   | 6             | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-----|---------------|-----|-----|-----|-----|-----|-----|
| Symbol |     | tr_count[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 133. TRANSIENT\_COUNT register (address 20h) bit description

| Bit    | Symbol        | Description                              |
|--------|---------------|------------------------------------------|
| 7 to 0 | tr_count[7:0) | Transient function debounce count value. |

FXLS8471Q

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

The time step for the transient detection debounce counter is set by the value of the system ODR and power mode as shown in <u>Table 134</u>.

Table 134. TRANSIENT\_COUNT relationship with the ODR

| ODR (Hz) | Max time | range (s) |                 |           | Time step (ms) |      |                 |           |
|----------|----------|-----------|-----------------|-----------|----------------|------|-----------------|-----------|
|          | Normal   | LPLN      | High resolution | Low power | Normal         | LPLN | High resolution | Low power |
| 800      | 0.319    | 0.319     | 0.319           | 0.319     | 1.25           | 1.25 | 1.25            | 1.25      |
| 400      | 0.638    | 0.638     | 0.638           | 0.638     | 2.5            | 2.5  | 2.5             | 2.5       |
| 200      | 1.28     | 1.28      | 0.638           | 1.28      | 5              | 5    | 2.5             | 5         |
| 100      | 2.55     | 2.55      | 0.638           | 2.55      | 10             | 10   | 2.5             | 10        |
| 50       | 5.1      | 5.1       | 0.638           | 5.1       | 20             | 20   | 2.5             | 20        |
| 12.5     | 5.1      | 20.4      | 0.638           | 20.4      | 20             | 80   | 2.5             | 80        |
| 6.25     | 5.1      | 20.4      | 0.638           | 40.8      | 20             | 80   | 2.5             | 160       |
| 1.56     | 5.1      | 20.4      | 0.638           | 40.8      | 20             | 80   | 2.5             | 160       |

An ODR of 100 Hz and a TRANSIENT\_COUNT value of 15, when accelerometer OSR is set to normal using CTRL\_REG2, would result in minimum debounce response time of 150 ms.

## 18.12 Pulse detection registers

## 18.12.1 PULSE\_CFG register (address 21h)

This register configures the pulse event detection function.

Table 135. PULSE\_CFG register (address 21h) bit allocation

| Bit    | 7       | 6       | 5          | 4          | 3          | 2          | 1          | 0          |
|--------|---------|---------|------------|------------|------------|------------|------------|------------|
| Symbol | pls_dpa | pls_ele | pls_zdpefe | pls_zspefe | pls_ydpefe | pls_yspefe | pls_xdpefe | pls_xspefe |
| 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 136. PULSE\_CFG register (address 21h) bit descriptions

| Bit | Symbol  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | pls_dpa | Double-pulse abort <b>0</b> — Double-pulse detection is not aborted if the start of a pulse is detected during the time period specified by the PULSE_LTCY register. (reset value) <b>1</b> — Setting the <i>pls_dpa</i> bit momentarily suspends the double-tap detection, if the start of a pulse is detected during the time period specified by the PULSE_LTCY register and the pulse ends before the end of the time period specified by the PULSE_LTCY register. |
| 6   | pls_ele | Pulse event flag latch  • — Event flag latch disabled (reset value)  • — Event flag latch enabled  When enabled, a read of the PULSE_SRC register is needed to clear the event flag.                                                                                                                                                                                                                                                                                   |

FXLS8471Q

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

| Bit | Symbol     | Description                                                                                                                                                                  |
|-----|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | pls_zdpefe | Event flag enable on double-pulse event on Z-axis  O — Event detection disabled (reset value)  1 — Raise event flag on detection of double-pulse event on Z-axis             |
| 4   | pls_zspefe | Event flag enable on single-pulse event on Z-axis <b>0</b> — Event detection disabled (reset value) <b>1</b> — Raise event flag on detection of single-pulse event on Z-axis |
| 3   | pls_ydpefe | Event flag enable on double-pulse event on Y-axis  O — Event detection disabled (reset value)  1 — Raise event flag on detection of double-pulse event on Y-axis             |
| 2   | pls_yspefe | Event flag enable on single-pulse event on Y-axis  O — Event detection disabled (reset value)  1 — Raise event flag on detection of single-pulse event on Z-axis             |
| 1   | pls_xdpefe | Event flag enable on double-pulse event on X-axis  O — Event detection disabled (reset value)  1 — Raise event flag on detection of double-pulse event on X-axis             |
| 0   | pls_xspefe | Event flag enable on single-pulse event on X-axis  O — Event detection disabled (reset value)  1 — Raise event flag on detection of single-pulse event on X-axis             |

## 18.12.2 PULSE\_SRC register (address 22h)

This register indicates the status bits for the pulse detection function.

Table 137. PULSE\_SRC register (address 22h) bit allocation

| Bit    | 7          | 6           | 5           | 4           | 3           | 2            | 1            | 0            |
|--------|------------|-------------|-------------|-------------|-------------|--------------|--------------|--------------|
| Symbol | pls_src_ea | pls_src_axz | pls_src_axy | pls_src_axx | pls_src_dpe | pls_src_polz | pls_src_poly | pls_src_polx |
| Reset  | 0          | 0           | 0           | 0           | 0           | 0            | 0            | 0            |
| Access | R          | R           | R           | R           | R           | R            | R            | R            |

Table 138. PULSE\_SRC register (address 22h) bit descriptions

| Bit | Symbol      | Description                                                                                                                |
|-----|-------------|----------------------------------------------------------------------------------------------------------------------------|
| 7   | pls_src_ea  | Event active flag  0 — No interrupt has been generated (reset value)  1 — One or more interrupt events have been generated |
| 6   | pls_src_axz | Z-axis event flag  0 — No interrupt. (reset value)  1 — Z-axis event has occurred                                          |
| 5   | pls_src_axy | Y-axis event flag  0 — No interrupt. (reset value)  1 — Y-axis event has occurred                                          |
| 4   | pls_src_axx | X-axis event flag  0 — No interrupt. (reset value)  1 — X-axis event has occurred                                          |

FXLS8471Q

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

| Bit | Symbol       | Description                                                                                                                                                             |
|-----|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | pls_src_dpe  | Double pulse on first event <b>0</b> — Single-pulse event triggered interrupt (reset value) <b>1</b> — Double-pulse event triggered interrupt                           |
| 2   | pls_src_polz | Pulse polarity of Z-axis event  O — Pulse event that triggered interrupt was positive (reset value)  1 — Pulse event that triggered interrupt was negative              |
| 1   | pls_src_poly | Pulse polarity of Y-axis event  O — Pulse event that triggered interrupt was positive (reset value)  1 — Pulse event that triggered interrupt was negative              |
| 0   | pls_src_polx | Pulse polarity of X-axis event. <b>0</b> — Pulse event that triggered interrupt was positive (reset value) <b>1</b> — Pulse event that triggered interrupt was negative |

# 18.12.3 PULSE\_THSX register (address 23h)

The PULSE\_THSX register defines the threshold used by the system to start the pulse-event detection procedure. Threshold values are unsigned 7-bit numbers with a fixed resolution of 0.063 g/LSB, corresponding to an 8 g acceleration full-scale range. The full-scale range is fixed at 8 g for the pulse detection function, regardless of the settings made in XYZ\_DATA\_CFG[fs].

Table 139. PULSE THSX register (address 23h) bit allocation

| Bit    | 7   | 6   | 5   | 4   | 3             | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|---------------|-----|-----|-----|
| Symbol | _   |     |     |     | pls_thsx[6: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 140. PULSE\_THSX register (address 23h) bit description

| Bit    | Symbol        | Description                |
|--------|---------------|----------------------------|
| 6 to 0 | pls_thsx[6:0] | Pulse threshold for X-axis |

#### 18.12.4 PULSE\_THSY register (address 24h)

The PULSE\_THSY register defines the threshold used by the system to start the pulse-event detection procedure. Threshold values are unsigned 7-bit numbers with a fixed resolution of 0.063 *g*/LSB, corresponding to an 8 *g* acceleration full-scale range. The full-scale range is fixed at 8 *g* for the pulse detection function, regardless of the settings made in XYZ\_DATA\_CFG[fs].

Table 141. PULSE\_THSY register (address 24h) bit allocation

| 14510 1411 1 | <u></u> | rogiotor (ada | 1000 2-111) 1510 | anooanon |     |     |     |     |  |
|--------------|---------|---------------|------------------|----------|-----|-----|-----|-----|--|
| Bit          | 7       | 6             | 5                | 4        | 3   | 2   | 1   | 0   |  |
| Symbol       | _       |               | pls_thsy[6: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 |  |

FXLS8471Q

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

Table 142. PULSE\_THSY register (address 24h) bit description

| Bit    | Symbol        | Description                |
|--------|---------------|----------------------------|
| 6 to 0 | pls_thsy[6:0] | Pulse threshold for Y-axis |

# 18.12.5 PULSE\_THSZ register (address 25h)ULSE\_THSZ register (address 25h) bit allocation

The PULSE\_THSZ register defines the threshold used by the system to start the pulse-event detection procedure. Threshold values are unsigned 7-bit numbers with a fixed resolution of 0.063 g/LSB, corresponding to an 8 g acceleration full-scale range. The full-scale range is fixed at 8 g for the pulse detection function, regardless of the settings made in XYZ\_DATA\_CFG[fs].

| Bit    | 7   | 6   | 5             | 4   | 3   | 2   | 1   | 0   |
|--------|-----|-----|---------------|-----|-----|-----|-----|-----|
| Symbol | _   |     | pls_thsz[6: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 143. PULSE\_THSZ register (address 25h) bit description

| Bit    | Symbol        | Description                |
|--------|---------------|----------------------------|
| 6 to 0 | pls_thsz[6:0] | Pulse threshold for Z-axis |

#### 18.12.6 PULSE\_TMLT register (address 26h)

#### Table 144. PULSE\_TMLT register (address 26h) bit allocation

| Bit    | 7   | 6   | 5   | 4      | 3        | 2   | 1   | 0   |
|--------|-----|-----|-----|--------|----------|-----|-----|-----|
| Symbol |     |     |     | pls_tm | nlt[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 145. PULSE\_TMLT register (address 26h) bit description

| Bit    | Symbol        | Description                                                                                                                                                                                                                                        |
|--------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 0 | pls_tmlt[7:0] | pls_tmlt[7:0] defines the maximum time interval that can elapse between the start of the acceleration on the selected channel exceeding the specified threshold and the end when the channel acceleration goes back below the specified threshold. |

Minimum time step for the pulse-time limit is defined in <u>Table 146</u> and <u>Table 147</u>. Maximum time for a given ODR is "Minimum time step x 255".

FXLS8471Q

Table 146. Time step for PULSE\_TMLT with HP\_FILTER\_CUTOFF[pls\_hpf\_en] = 1

| ODR (Hz) | Max time | range (s) |                 |           | Time step (ms) |      |                 |           |  |
|----------|----------|-----------|-----------------|-----------|----------------|------|-----------------|-----------|--|
|          | Normal   | LPLN      | High resolution | Low power | Normal         | LPLN | High resolution | Low power |  |
| 800      | 0.319    | 0.319     | 0.319           | 0.319     | 1.25           | 1.25 | 1.25            | 1.25      |  |
| 400      | 0.638    | 0.638     | 0.638           | 0.638     | 2.5            | 2.5  | 2.5             | 2.5       |  |
| 200      | 1.28     | 1.28      | 0.638           | 1.28      | 5              | 5    | 2.5             | 5         |  |
| 100      | 2.55     | 2.55      | 0.638           | 2.55      | 10             | 10   | 2.5             | 10        |  |
| 50       | 5.1      | 5.1       | 0.638           | 5.1       | 20             | 20   | 2.5             | 20        |  |
| 12.5     | 5.1      | 20.4      | 0.638           | 20.4      | 20             | 80   | 2.5             | 80        |  |
| 6.25     | 5.1      | 20.4      | 0.638           | 40.8      | 20             | 80   | 2.5             | 160       |  |
| 1.56     | 5.1      | 20.4      | 0.638           | 40.8      | 20             | 80   | 2.5             | 160       |  |

Table 147. Time step for PULSE\_TMLT with HP\_FILTER\_CUTOFF[pls\_hpf\_en] = 0

| ODR (Hz) | Max time i | range (s) |                 |           | Time step (ms) |       |                 |           |  |
|----------|------------|-----------|-----------------|-----------|----------------|-------|-----------------|-----------|--|
|          | Normal     | LPLN      | High resolution | Low power | Normal         | LPLN  | High resolution | Low power |  |
| 800      | 0.159      | 0.159     | 0.159           | 0.159     | 0.625          | 0.625 | 0.625           | 0.625     |  |
| 400      | 0.159      | 0.159     | 0.159           | 0.319     | 0.625          | 0.625 | 0.625           | 1.25      |  |
| 200      | 0.319      | 0.319     | 0.159           | 0.638     | 1.25           | 1.25  | 0.625           | 2.5       |  |
| 100      | 0.638      | 0.638     | 0.159           | 1.28      | 2.5            | 2.5   | 0.625           | 5         |  |
| 50       | 1.28       | 1.28      | 0.159           | 2.55      | 5              | 5     | 0.625           | 10        |  |
| 12.5     | 1.28       | 5.1       | 0.159           | 10.2      | 5              | 20    | 0.625           | 40        |  |
| 6.25     | 1.28       | 5.1       | 0.159           | 10.2      | 5              | 20    | 0.625           | 40        |  |
| 1.56     | 1.28       | 5.1       | 0.159           | 10.2      | 5              | 20    | 0.625           | 40        |  |

An ODR setting of 400 Hz, when the accelerometer OSR is set to normal using CTRL REG2, results in a maximum pulse-time limit of (0.625 ms \* 255) = 159 ms.

# 18.12.7 PULSE\_LTCY register (address 27h)

Table 148. PULSE\_LTCY register (address 27h) bit allocation

| Bit    | 7   | 6   | 5   | 4       | 3       | 2   | 1   | 0   |
|--------|-----|-----|-----|---------|---------|-----|-----|-----|
| Symbol |     |     |     | pls_ltd | cy[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 149. PULSE\_LTCY register (address 27h) bit description

| Bit    | Symbol | Description                                                                                                                                              |
|--------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 0 |        | pls_ltcy[7:0] defines the time interval that starts after the first pulse detection where the pulse-detection function ignores the start of a new pulse. |

FXLS8471Q

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

Minimum time step for the pulse latency is defined in <u>Table 150</u> and <u>Table 151</u>. Maximum time is "(time step @ ODR and power mode) x 255".

Table 150. Time step for PULSE\_LTCY with HP\_FILTER\_CUTOFF[pls\_hpf\_en] = 1

| ODR (Hz) | Max time I | range (s) |                 |           | Time step (ms) |      |                 |           |  |
|----------|------------|-----------|-----------------|-----------|----------------|------|-----------------|-----------|--|
|          | Normal     | LPLN      | High resolution | Low power | Normal         | LPLN | High resolution | Low power |  |
| 800      | 0.638      | 0.638     | 0.638           | 0.638     | 2.5            | 2.5  | 2.5             | 2.5       |  |
| 400      | 1.276      | 1.276     | 1.276           | 1.276     | 5              | 5    | 5               | 5         |  |
| 200      | 2.56       | 2.56      | 1.276           | 2.56      | 10             | 10   | 5               | 10        |  |
| 100      | 5.1        | 5.1       | 1.276           | 5.1       | 20             | 20   | 5               | 20        |  |
| 50       | 10.2       | 10.2      | 1.276           | 10.2      | 40             | 40   | 5               | 40        |  |
| 12.5     | 10.2       | 40.8      | 1.276           | 40.8      | 40             | 160  | 5               | 160       |  |
| 6.25     | 10.2       | 40.8      | 1.276           | 81.6      | 40             | 160  | 5               | 320       |  |
| 1.56     | 10.2       | 40.8      | 1.276           | 81.6      | 40             | 160  | 5               | 320       |  |

Table 151. Time step for PULSE\_LTCY with HP\_FILTER\_CUTOFF[pls\_hpf\_en] = 0

| ODR (Hz) | Max time | range (s) |                 |           | Time step (ms) |      |                 |           |  |
|----------|----------|-----------|-----------------|-----------|----------------|------|-----------------|-----------|--|
|          | Normal   | LPLN      | High resolution | Low power | Normal         | LPLN | High resolution | Low power |  |
| 800      | 0.318    | 0.318     | 0.318           | 0.318     | 1.25           | 1.25 | 1.25            | 1.25      |  |
| 400      | 0.318    | 0.318     | 0.318           | 0.638     | 1.25           | 1.25 | 1.25            | 2.5       |  |
| 200      | 0.638    | 0.638     | 0.318           | 1.276     | 2.5            | 2.5  | 1.25            | 5         |  |
| 100      | 1.276    | 1.276     | 0.318           | 2.56      | 5              | 5    | 1.25            | 10        |  |
| 50       | 2.56     | 2.56      | 0.318           | 5.1       | 10             | 10   | 1.25            | 20        |  |
| 12.5     | 2.56     | 10.2      | 0.318           | 20.4      | 10             | 40   | 1.25            | 80        |  |
| 6.25     | 2.56     | 10.2      | 0.318           | 20.4      | 10             | 40   | 1.25            | 80        |  |
| 1.56     | 2.56     | 10.2      | 0.318           | 20.4      | 10             | 40   | 1.25            | 80        |  |

# 18.12.8 PULSE\_WIND register (address 28h)

Table 152. PULSE\_WIND register (address 28h) bit allocation

| Bit    | 7   | 6             | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|--------|-----|---------------|-----|-----|-----|-----|-----|-----|--|--|
| Symbol |     | pls_wind[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 153. PULSE\_WIND register (address 28h) bit description

| Bit    | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 0 |        | <i>pls_wind</i> [7:0] defines the maximum interval of time that can elapse after the end of the latency interval in which the start of the second pulse event must be detected provided the device has been configured for double pulse detection. The detected second pulse width must be shorter than the time limit constraint specified by the PULSE_TMLT register, but the end of the double pulse need not finish within the time specified by the PULSE_WIND register. |

The time step for the pulse-window counter varies with the selected ODR and power modes as defined in <u>Table 154</u> and <u>Table 155</u>. The maximum time value is equal to "(time step @ ODR and power mode) x 255".

Table 154. Time step for PULSE\_WIND with HP\_FILTER\_CUTOFF[pls\_hpf\_en] = 1

| ODR (Hz) | Max time i | range (s) |                 |           | Time step (ms) |      |                 |           |  |
|----------|------------|-----------|-----------------|-----------|----------------|------|-----------------|-----------|--|
|          | Normal     | LPLN      | High resolution | Low power | Normal         | LPLN | High resolution | Low power |  |
| 800      | 0.638      | 0.638     | 0.638           | 0.638     | 2.5            | 2.5  | 2.5             | 2.5       |  |
| 400      | 1.276      | 1.276     | 1.276           | 1.276     | 5              | 5    | 5               | 5         |  |
| 200      | 2.56       | 2.56      | 1.276           | 2.56      | 10             | 10   | 5               | 10        |  |
| 100      | 5.1        | 5.1       | 1.276           | 5.1       | 20             | 20   | 5               | 20        |  |
| 50       | 10.2       | 10.2      | 1.276           | 10.2      | 40             | 40   | 5               | 40        |  |
| 12.5     | 10.2       | 40.8      | 1.276           | 40.8      | 40             | 160  | 5               | 160       |  |
| 6.25     | 10.2       | 40.8      | 1.276           | 81.6      | 40             | 160  | 5               | 320       |  |
| 1.56     | 10.2       | 40.8      | 1.276           | 81.6      | 40             | 160  | 5               | 320       |  |

Table 155. Time step for PULSE WIND with HP FILTER CUTOFF[pls hpf en] = 0

| ODR (Hz) | Max time | range (s) |                 |           | Time step (ms) |      |                 |           |  |
|----------|----------|-----------|-----------------|-----------|----------------|------|-----------------|-----------|--|
|          | Normal   | LPLN      | High resolution | Low power | Normal         | LPLN | High resolution | Low power |  |
| 800      | 0.318    | 0.318     | 0.318           | 0.318     | 1.25           | 1.25 | 1.25            | 1.25      |  |
| 400      | 0.318    | 0.318     | 0.318           | 0.638     | 1.25           | 1.25 | 1.25            | 2.5       |  |
| 200      | 0.638    | 0.638     | 0.318           | 1.276     | 2.5            | 2.5  | 1.25            | 5         |  |
| 100      | 1.276    | 1.276     | 0.318           | 2.56      | 5              | 5    | 1.25            | 10        |  |
| 50       | 2.56     | 2.56      | 0.318           | 5.1       | 10             | 10   | 1.25            | 20        |  |
| 12.5     | 2.56     | 10.2      | 0.318           | 20.4      | 10             | 40   | 1.25            | 80        |  |
| 6.25     | 2.56     | 10.2      | 0.318           | 20.4      | 10             | 40   | 1.25            | 80        |  |
| 1.56     | 2.56     | 10.2      | 0.318           | 20.4      | 10             | 40   | 1.25            | 80        |  |

## 18.13 Offset correction registers

The 8-bit two's complement offset correction registers are used to remove the sensor zero-*g* offset on the X, Y, and Z axes after device board mount. The resolution of the offset registers is 2 mg per LSB, with an effective offset adjustment range of –256 mg to +254 mg for each axis. The acceleration vectors represented in these registers will be

FXLS8471C

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

added to the acceleration vectors acquired by the ASIC from the transducer prior to being written to the output data registers (registers 01h through 06h). For example, to correct for an offset of 60 mg, a value representing -60 mg (= -60 mg/2 mg/LSB = -30 LSB), which is E2h in 8-bit two's complement representation, should be written to the offset register.

For more information on how to calibrate the 0  $\it g$  offset, refer to NXP application note AN4069.

**Note:** Accelerometer offset registers can only be modified when the device is in standby mode. See M\_CTRL\_REG1 register (address 5Bh).

#### 18.13.1 OFF\_X register (address 2Fh)

#### Table 156. OFF X register (address 2Fh) bit allocation

|        |     |            |     | T   |     | l   |     | 1   |  |  |
|--------|-----|------------|-----|-----|-----|-----|-----|-----|--|--|
| Bit    | 7   | 6          | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
| Symbol |     | 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 157. OFF X register (address 2Fh) bit description

| Bit    | Symbol     | Description                                                                   |
|--------|------------|-------------------------------------------------------------------------------|
| 7 to 0 | off_x[7:0] | X-axis offset correction value expressed as an 8-bit two's complement number. |

#### 18.13.2 OFF\_Y register (address 30h)

#### Table 158. OFF Y register (address 30h) bit allocation

| Table 100. Of 1_1 Togloter (database only bit uncounter |     |            |     |     |     |     |     |     |  |  |
|---------------------------------------------------------|-----|------------|-----|-----|-----|-----|-----|-----|--|--|
| Bit                                                     | 7   | 6          | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
| Symbol                                                  |     | 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 159. OFF\_Y register (address 30h) bit description

| Bit    | Symbol     | Description                                                                   |
|--------|------------|-------------------------------------------------------------------------------|
| 7 to 0 | off_y[7:0] | Y-axis offset correction value expressed as an 8-bit two's complement number. |

## 18.13.3 OFF\_Z register (address 31h)

#### Table 160. OFF Z register (address 31h) bit allocation

| Table 100. Of 1_2 register (address 5111) bit allocation |     |            |     |     |     |     |     |     |  |  |  |
|----------------------------------------------------------|-----|------------|-----|-----|-----|-----|-----|-----|--|--|--|
| Bit                                                      | 7   | 6          | 5   | 4   | 3   | 2   | 1   | 0   |  |  |  |
| Symbol                                                   |     | 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 |  |  |  |

FXLS8471C

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

Table 161. OFF\_Z register (address 31h) bit description

| Bit    | Symbol     | Description                                                                   |
|--------|------------|-------------------------------------------------------------------------------|
| 7 to 0 | off_z[7:0] | Z-axis offset correction value expressed as an 8-bit two's complement number. |

# 19 Mounting guidelines for the Quad Flat No-Lead (QFN) package

Printed Circuit Board (PCB) layout is a critical portion of the total design. The footprint for the surface mount packages must be the correct size to ensure proper solder connection interface between the PCB and the package. With the correct footprint, the packages will self align when subjected to a solder reflow process.

These guidelines are for soldering and mounting the Quad Flat No-Lead (QFN) package inertial sensors to PCBs. The purpose is to minimize the stress on the package after board mounting. The FXLS8471Q uses the QFN package platform. This section describes suggested methods of soldering these devices to the PCB for consumer applications.

NXP application note AN1902, "Quad Flat Pack No-Lead (QFN) Micro Dual Flat Pack No-Lead (DFN)" discusses the QFN package used by the FXLS8471Q, PCB design guidelines for using QFN packages and temperature profiles for reflow soldering.

#### 19.1 Overview of soldering considerations

Information provided here is based on experiments executed on QFN devices. As they cannot represent exact conditions present at a customer site, the information provided herein should be used for guidance only and further 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 will self-align during the solder reflow process.

The QFN package is compliant with the RoHS standards. Refer to NXP application note AN4077 for more information.

#### 19.2 Halogen content

This package is designed to be Halogen free, exceeding most industry and customer standards. Halogen free means that no homogeneous material within the assembled package will 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.3 PCB mounting recommendations

- The PCB land should be designed with Non-Solder Mask Defined (NSMD) as shown in Figure 18.
- No additional via pattern underneath package.
- PCB land pad is 0.8 mm by 0.3 mm as shown in Figure 18.
- Solder mask opening = PCB land pad edge + 0.113 mm larger all around.
- Stencil opening = PCB land pad 0.015 mm smaller all around = 0.77 mm by 0.27 mm.
- Stencil thickness is 100 or 125  $\mu m$ .
- Do not place any components or vias at a distance less than 2 mm from the package land area. This might cause additional package stress if it is too close to the package land area.

FXLS8471C

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

- Signal traces connected to pads should be as symmetric as possible. Put dummy traces on the NC pads in order to have same length of exposed trace for all pads.
- Use a standard pick and place process and equipment. Do not use a hand soldering process.
- Do not use a screw down or stacking to fix the PCB into an enclosure as this could bend the PCB, putting stress on the package.
- The PCB should be rated for the multiple lead-free reflow condition with a maximum 260 °C temperature.
- No copper traces or fills on component mounting layer directly under the package. This will cause planarity issues with board mount. NXP QFN 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-Aq-Cu) solder paste soldering processes. Reflow profiles applicable to those processes can be used successfully for soldering the devices.



package footprint

All information provided in this document is subject to legal disclaimers

© NXP B.V. 2019. All rights reserved

### 20 Thermal characteristics

#### **Table 162. Thermal characteristics**

| Rating                                                    | Description                                | Symbol             | Value | Unit |
|-----------------------------------------------------------|--------------------------------------------|--------------------|-------|------|
| Junction-to-ambient, natural convection <sup>[1][2]</sup> | Single-layer board                         | $R_{\theta JA}$    | 163   | °C/W |
| Junction-to-ambient, natural convection <sup>[1][3]</sup> | Four-layer board (two signals, two planes) |                    | 70    |      |
| Junction-to-board <sup>[4]</sup>                          | _                                          | $R_{\theta JB}$    | 33    | °C/W |
| Junction-to-case (top) <sup>[5]</sup>                     | _                                          | $R_{\theta JCTop}$ | 84    | °C/W |
| Junction-to-package (top) <sup>[6]</sup>                  | Natural convection                         | $\Psi_{JT}$        | 6     | °C/W |

Junction temperature is a function of die size, on-chip power dissipation, package thermal resistance, mounting site (board) temperature, ambient temperature, air flow, power dissipation of other components on the board, and board thermal resistance.

Per JEDEC JESD51-2 with the single-layer board (JESD51-3) horizontal.

Per JEDEC JESD51-6 with the board (JESD51-7) horizontal.

Thermal resistance between the die and the printed circuit board per JEDEC JESD51-8. Board temperature is measured on the top surface of the board [4] near the package.

Thermal resistance between the die and the case top surface as measured by the cold plate method (MIL SPEC-883 Method 1012.1).

<sup>[5]</sup> 

Thermal characterization parameter indicating the temperature difference between package top and the junction temperature per JEDEC JESD51-2. When Greek letters are not available, the thermal characterization parameter is written as Psi-JT. [6]

# 21 Package information

### This drawing is located at

https://www.nxp.com/packages/SOT1676-1.





#### NOTES:

- 1. ALL DIMENSIONS ARE IN MILLIMETERS.
- 2. INTERPRET DIMENSIONS AND TOLERANCES PER ASME Y14.5M-1994.
- 3. THIS IS NON JEDEC REGISTERED PACKAGE.

4. COPLANARITY APPLIES TO ALL LEADS.

5. MIN. METAL GAP SHOULD BE 0.2MM.

| © NXP SEMICONDUCTORS N.V.<br>ALL RIGHTS RESERVED                                      | MECHANICAL OUTLINE |          | PRINT VERSION NO  | OT TO | SCALE  | E   |
|---------------------------------------------------------------------------------------|--------------------|----------|-------------------|-------|--------|-----|
| TITLE: QUAD FLAT NO LEAD  COL PACKAGE (QFN-COL)  16 TERMINAL, 0.5 PITCH (3 X 3 X 1.0) |                    | DOCUMEN  | T NO: 98ASA00063D |       | REV:   | В   |
|                                                                                       |                    | STANDAR  | D: NON JEDEC      |       |        |     |
|                                                                                       |                    | SOT1676- | -1                | 05 .  | JAN 20 | )16 |

Figure 19. Package outline

# 22 Appendix A — Chip errata

# 22.1 SPI Mode soft-reset using CTRL\_REG2 (2Bh), bit 6

### 22.1.1 Description

Following a soft-reset command, issued by setting CTRL\_REG2[*rst*] = 1, certain device-specific parameters do not get updated correctly from NVM, causing inaccurate data output and incorrect WHO\_AM\_I (0Dh) register content. This behavior happens only in SPI mode and not in I<sup>2</sup>C mode.

#### 22.1.2 Workaround

Avoid using soft-reset in SPI mode by alternately utilizing the hardware RESET pin.

# 23 Revision history

#### Table 163. Revision history

| Document ID     | Release date                                                                                                                                                                        | Data sheet status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Change notice | Supersedes      |  |  |  |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-----------------|--|--|--|
| FXLS8471Q v.3.0 | 20190613                                                                                                                                                                            | Product data sheet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |               | FXLS8471Q v.2.0 |  |  |  |
| Modifications   | <ul> <li>Section 11, rev</li> <li>Table 9: Revi</li> <li>Removed</li> <li>Revised t</li> <li>(per AEC</li> <li>Revised t</li> <li>Revised the f</li> <li>Section 21, Fig</li> </ul> | <ul> <li>Section 1, Section 2: Removed "AEC-Q100, Grade 2 qualified" from each section.</li> <li>Section 11, revised as follows: <ul> <li>Table 9: Revised I<sub>LU</sub> as follows:</li> <li>Removed the rating "Latchup current at T = 85 °C" and associated value "±100."</li> <li>Revised the rating "Latchup current at T = 105 °C" to "Latchup current at T = 105 °C (per AEC-Q100-004)."</li> <li>Revised the value from "±TBD" to "±100."</li> <li>Revised the first caution icon folllowing Table 9.</li> </ul> </li> <li>Section 21, Figure 19: Revised package outline drawing from SOT1680-1 (98ASA00318D) to SOT1676-1 (98ASA00063D).</li> </ul> |               |                 |  |  |  |
| FXLS8471Q v.2.0 | 20181120                                                                                                                                                                            | Product data sheet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | _             | FXLS8471Q v.1.5 |  |  |  |
| FXLS8471Q v.1.5 | 2015 June                                                                                                                                                                           | Product data sheet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | _             | FXLS8471Q v.1.4 |  |  |  |
| FXLS8471Q v.1.4 | 2015 March                                                                                                                                                                          | Product data sheet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | _             | FXLS8471Q v.1.3 |  |  |  |
| FXLS8471Q v.1.3 | 2015 January                                                                                                                                                                        | Product data sheet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | _             | FXLS8471Q v.1.2 |  |  |  |
| FXLS8471Q v.1.2 | 2014 November                                                                                                                                                                       | Product data sheet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | _             | FXLS8471Q v.1.1 |  |  |  |
| FXLS8471Q v.1.1 | 2013 August                                                                                                                                                                         | Product data sheet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | _             | FXLS8471Q v.1.0 |  |  |  |
| FXLS8471Q v.1.0 | 2013 August                                                                                                                                                                         | Product data sheet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | _             | _               |  |  |  |

### 24 Legal information

#### 24.1 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".
- 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="http://www.nxp.com">http://www.nxp.com</a>.

### 24.2 Definitions

Draft — The document is a draft version only. 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 herein 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.

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

 $\ensuremath{\mathbf{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

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 http://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.

Suitability for use in automotive applications — This NXP Semiconductors product has been qualified for use in automotive applications. Unless otherwise agreed in writing, the product is 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

FXLS8471Q

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

© NXP B.V. 2019. All rights reserved.

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.

**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.

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

#### 24.4 Trademarks

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

**I<sup>2</sup>C-bus** — logo is a trademark of NXP B.V.

NXP — is a trademark of NXP B.V.

# **Tables**

| Tab. 1.   | Ordering information2                         | Tab. 36.  |                                           |
|-----------|-----------------------------------------------|-----------|-------------------------------------------|
| Tab. 2.   | Pin Description3                              |           | allocation30                              |
| Tab. 3.   | I2C slave timing values6                      | Tab. 37.  | CTRL_REG2 register (address 2Bh) bit      |
| Tab. 4.   | I2C slave address7                            |           | description30                             |
| Tab. 5.   | SPI timing9                                   | Tab. 38.  | CTRL_REG2[smods/mods] oversampling        |
| Tab. 6.   | Serial interface pin descriptions11           |           | modes31                                   |
| Tab. 7.   | I2C/SPI auto detection11                      | Tab. 39.  | Oversampling ratio versus oversampling    |
| Tab. 8.   | Maximum ratings12                             |           | mode 31                                   |
| Tab. 9.   | ESD and latchup protection characteristics 12 | Tab. 40.  | CTRL_REG3 [interrupt control register]    |
| Tab. 10.  | Mechanical characteristics                    |           | (address 2Ch) bit allocation 32           |
| Tab. 11.  | Electrical characteristics14                  | Tab. 41.  | CTRL REG3 [Interrupt control register]    |
| Tab. 12.  | Temperature characteristics15                 |           | (address 2Ch) bit descriptions 32         |
| Tab. 13.  | Mode of operation description15               | Tab. 42.  | CTRL_REG4 [Interrupt enable register]     |
| Tab. 14.  | Register address map20                        |           | (address 2Dh) bit allocation              |
| Tab. 15.  | STATUS register (address 00h) bit             | Tab. 43.  |                                           |
|           | allocation23                                  |           | (address 2Dh) bit descriptions            |
| Tab. 16.  | STATUS register (address 00h) bit             | Tab. 44.  | · · · · · · · · · · · · · · · · · · ·     |
|           | description                                   |           | Configuration Register] (address 2Eh) bit |
| Tab. 17.  | DR_STATUS register (address 00h) bit          |           | allocation                                |
| 140. 17.  | allocation                                    | Tab. 45.  |                                           |
| Tab. 18.  | DR_STATUS register (address 00h) bit          | 145. 40.  | Configuration Register] (address 2Eh) bit |
| 140. 10.  | description23                                 |           | descriptions                              |
| Tab. 19.  | F_STATUS register (address 00h) bit           | Tab. 46.  |                                           |
| 1 ab. 19. |                                               | 1ab. 40.  |                                           |
| Tab 20    | allocation                                    | Tob 47    | allocation                                |
| Tab. 20.  | FIFO flag event descriptions                  | Tab. 47.  | _ ` ` ` /                                 |
| Tab. 21.  | F_STATUS register (address 00h) bit           | T-1- 40   | descriptions                              |
| T 1 00    | description                                   | Tab. 48.  |                                           |
| Tab. 22.  | TRIG_CFG register (address 0Ah) bit           | T 1 40    | allocation                                |
| T 1 00    | allocation                                    | Tab. 49.  |                                           |
| Tab. 23.  | TRIG_CFG register (address 0Ah) bit           |           | descriptions                              |
|           | description                                   | Tab. 50.  | _ ` ` ` /                                 |
| Tab. 24.  | SYSMOD register (address 0Bh) bit             |           | allocation                                |
|           | allocation                                    | Tab. 51.  | ASLP_COUNT register (address 29h) bit     |
| Tab. 25.  | SYSMOD register (address 0Bh) bit             |           | description37                             |
|           | description26                                 | Tab. 52.  | ASLP_COUNT relationship with ODR37        |
| Tab. 26.  | INT_SOURCE register (address 0Ch) bit         | Tab. 53.  |                                           |
|           | allocation27                                  | Tab. 54.  | TEMP_OUT register (address 51h) bit       |
| Tab. 27.  | INT_SOURCE register (address 0Ch) bit         |           | allocation39                              |
|           | description27                                 | Tab. 55.  | OUT_X_MSB register (address 01h) bit      |
| Tab. 28.  | WHO_AM_I register (address 0Dh) bit           |           | allocation40                              |
|           | allocation                                    | Tab. 56.  | OUT_X_LSB register (address 02h) bit      |
| Tab. 29.  | WHO_AM_I register (address 0Dh) bit           |           | allocation40                              |
|           | description                                   | Tab. 57.  | OUT_Y_MSB register (address 03h) bit      |
| Tab. 30.  | CTRL_REG1 register (address 2Ah) bit          |           | allocation40                              |
|           | allocation                                    | Tab. 58.  | OUT_Y_LSB register (address 04h) bit      |
| Tab. 31.  | CTRL REG1 register (address 2Ah) bit          |           | allocation40                              |
|           | description                                   | Tab. 59.  |                                           |
| Tab. 32.  | Sleep mode poll rate description - CTRL_      | 145.00.   | allocation                                |
| 140. 02.  | REG6 = 00h29                                  | Tab. 60.  | OUT_Z_LSB register (address 06h) bit      |
| Tab. 33.  | System output data rate selection - CTRL_     | 1 ab. 00. | allocation41                              |
| 1 ab. 55. | REG6 = 00h29                                  | Tab 61    |                                           |
| Tob 24    |                                               | Tab. 61.  | F_SETUP register (address 09h) bit        |
| Tab. 34.  | Sleep mode poll rate description – CTRL_      | T-1- 00   | allocation                                |
| T-L 05    | REG6 = 03h                                    | Tab. 62.  | F_SETUP register (address 09h) bit        |
| Tab. 35.  | System output data rate selection – CTRL_     | T 1 00    | descriptions                              |
|           | REG6 = 03h30                                  | Tab. 63.  | XYZ_DATA_CFG register (address 0Eh) bit   |
|           |                                               |           | allocation42                              |
|           |                                               |           |                                           |

| Tab. 64. | XYZ_DATA_CFG register (address 0Eh) bit descriptions     | Tab. 97.  | A_FFMT_THS_Y_LSB register (address 76h) bit allocation   | E / |
|----------|----------------------------------------------------------|-----------|----------------------------------------------------------|-----|
| Tab 65   |                                                          | Tab 00    |                                                          | 54  |
| Tab. 65. | Accelerometer full-scale range selection42               | Tab. 90.  | A_FFMT_THS_Y_LSB register (address 76h) bit descriptions | E 1 |
| Tab. 66. | HP_FILTER_CUTOFF register (address                       | Tab. 99.  |                                                          | 54  |
| Tab 67   | 0Fh) bit allocation43 HP_FILTER_CUTOFF register (address | Tab. 99.  | A_FFMT_THS_Z_MSB register (address 77h) bit allocation   | 5.1 |
| Tab. 67. |                                                          | Tab 100   | A_FFMT_THS_Z_MSB_register (address                       | 54  |
| Tah 60   | 0Fh) bit descriptions43 HP_FILTER_CUTOFF43               | Tab. 100. | 77h) bit descriptions                                    | 5.1 |
| Tab. 68. |                                                          | Tab 101   |                                                          | 54  |
| Tab. 69. | PL_STATUS register (address 10h) bit                     | Tab. 101. | A_FFMT_THS_Z_LSB register (address                       | E 1 |
| Tab 70   | allocation                                               | Tab 100   | 78h) bit allocation                                      | 54  |
| Tab. 70. | PL_STATUS register (address 10h) bit                     | Tab. 102. | A_FFMT_THS_Z_LSB register (address                       | - 4 |
| T-1- 74  | descriptions                                             | T-1- 400  | 78h) bit descriptions                                    | 54  |
| Tab. 71. | PL_CFG register (address 11h) bit                        | Tab. 103. | A_FFMT_COUNT register (address 18h) bit                  |     |
| T-6 70   | allocation                                               | T-b 101   | allocation                                               | ວວ  |
| Tab. 72. | PL_CFG register (address 11h) bit                        | Tab. 104. | A_FFMT_COUNT register (address 18h) bit                  |     |
| T-1- 70  | descriptions                                             | T-1- 405  | description                                              |     |
| Tab. 73. | PL_COUNT register (address 12h) bit                      |           | A_FFMT_COUNT relationship with the ODR.                  | 55  |
| T-1- 74  | allocation                                               | Tab. 106. | A_VECM_CFG register (address 5Fh) bit                    |     |
| Tab. 74. | PL_COUNT register (address 12h) bit                      | T   407   | allocation                                               | 57  |
| T   75   | descriptions                                             | Tab. 107. | A_VECM_CFG register (address 5Fh) bit                    |     |
| Tab. 75. | PL_Count Relationship with the ODR                       | T   100   | descriptions                                             | 57  |
| Tab. 76. | PL_BF_ZCOMP register (address 13h) bit                   | Tab. 108. | A_VECM_THS_MSB register (address 60h)                    |     |
| <b>-</b> | allocation                                               | T   100   | bit allocation                                           | 57  |
| Tab. 77. | PL_BF_ZCOMP register (address 13h) bit                   | Tab. 109. | A_VECM_THS_MSB register (address 60h)                    |     |
|          | descriptions                                             |           | bit descriptions                                         | 58  |
| Tab. 78. | Z-lockout angle definitions                              | Tab. 110. | A_VECM_THS_LSB register (address 61h)                    |     |
| Tab. 79. | Back/Front orientation definitions                       |           | bit allocation                                           |     |
| Tab. 80. | PL_THS_REG register (address 14h) bit                    |           | A_VECM_THS_LSB bit description                           | 58  |
|          | allocation                                               | Tab. 112. | A_VECM_CNT register (address 62h) bit                    |     |
| Tab. 81. | PL_BF_ZCOMP register (address 13h) bit                   |           | allocation                                               |     |
|          | descriptions                                             |           | A_VECM_CNT bit description                               | 58  |
| Tab. 82. | Threshold angle lookup table48                           | Tab. 114. | A_VECM_INITX_MSB register (address                       |     |
| Tab. 83. | Trip angles versus hysteresis settings49                 |           | 63h) bit allocation                                      | 59  |
| Tab. 84. | Portrait/Landscape ideal orientation                     | Tab. 115. | A_VECM_INITX_MSB register (address                       |     |
|          | definitions                                              |           | 63h) bit description                                     | 59  |
| Tab. 85. | A_FFMT_CFG register (address 15h) bit                    | Tab. 116. | A_VECM_INITX_LSB register (address                       |     |
|          | allocation50                                             |           | 64h) bit allocation                                      | 59  |
| Tab. 86. | A_FFMT_CFG register (address 15h) bit                    | Tab. 117. | A_VECM_INITX_LSB register (address                       |     |
|          | descriptions50                                           |           | 64h) bit description                                     | 59  |
| Tab. 87. | A_FFMT_SRC register (address 16h) bit                    | Tab. 118. | A_VECM_INITY_MSB register (address                       |     |
|          | allocation51                                             |           | 65h) bit allocation                                      | 59  |
| Tab. 88. | A_FFMT_SRC register (address 16h) bit                    | Tab. 119. | A_VECM_INITY_MSB register (address                       |     |
|          | descriptions51                                           |           | 65h) bit description                                     | 59  |
| Tab. 89. | A_FFMT_THS register (address 17h) bit                    | Tab. 120. | A_VECM_INITY_LSB register (address                       |     |
|          | allocation 52                                            |           | 66h) bit allocation                                      | 60  |
| Tab. 90. | A_FFMT_THS register (address 17h) bit                    | Tab. 121. | A_VECM_INITY_LSB register (address                       |     |
|          | descriptions52                                           |           | 66h) bit description                                     | 60  |
| Tab. 91. | A_FFMT_THS_X_MSB register (address                       | Tab. 122. | A_VECM_INITZ_MSB register (address                       |     |
|          | 73h) bit allocation52                                    |           | 67h) bit allocation                                      | 60  |
| Tab. 92. | A_FFMT_THS_X_MSB register (address                       | Tab. 123. | A_VECM_INITZ_MSB register (address                       |     |
|          | 73h) bit descriptions53                                  |           | 67h) bit description                                     | 60  |
| Tab. 93. | A_FFMT_THS_X_LSB register (address                       | Tab. 124. | A_VECM_INITZ_LSB register (address                       |     |
|          | 74h) bit allocation53                                    |           | 68h) bit allocation                                      | 60  |
| Tab. 94. | A_FFMT_THS_X_LSB register (address                       | Tab. 125. | A_VECM_INITZ_LSB bit description                         | 60  |
|          | 74h) bit descriptions53                                  | Tab. 126. | TRANSIENT_CFG register (address 1Dh)                     |     |
| Tab. 95. | A_FFMT_THS_Y_MSB register (address                       |           | bit allocation                                           | 61  |
|          | 75h) bit allocation53                                    | Tab. 127. | TRANSIENT_CFG register (address 1Dh)                     |     |
| Tab. 96. | A_FFMT_THS_Y_MSB register (address                       |           | bit descriptions                                         | 61  |
|          | 75h) bit descriptions53                                  |           |                                                          |     |

**NXP Semiconductors** 

# **FXLS8471Q**

# 3-Axis, Linear Accelerometer

| Tab. 128. | TRANSIENT_SRC register (address 1Eh)                  |      | Tab. 144. | PULSE_TMLT register (address 26h) bit             |      |
|-----------|-------------------------------------------------------|------|-----------|---------------------------------------------------|------|
| T-L 100   | bit allocation                                        | 62   | Tab 445   | allocation                                        | . 67 |
| 1ab. 129. | TRANSIENT_SRC register (address 1Eh) bit descriptions | 62   | 1ab. 145. | PULSE_TMLT register (address 26h) bit description | 67   |
| Tab 130   | TRANSIENT_THS register (address 1Fh) bit              | 02   | Tab 146   | Time step for PULSE_TMLT with HP_                 | . 01 |
| 145. 100. | allocation                                            | . 63 | 145. 110. | FILTER_CUTOFF[pls_hpf_en] = 1                     | .68  |
| Tab. 131. | TRANSIENT_THS register (address 1Fh) bit              |      | Tab. 147. | Time step for PULSE_TMLT with HP_                 |      |
|           | descriptions                                          | 63   |           | FILTER_CUTOFF[pls_hpf_en] = 0                     | 68   |
| Tab. 132. | TRANSIENT_COUNT register (address                     |      | Tab. 148. | PULSE_LTCY register (address 27h) bit             |      |
|           | 20h) bit allocation                                   | 63   |           | allocation                                        | . 68 |
| Tab. 133. | TRANSIENT_COUNT register (address                     |      | Tab. 149. | PULSE_LTCY register (address 27h) bit             |      |
|           | 20h) bit description                                  | 63   |           | description                                       | . 68 |
| Tab. 134. | TRANSIENT_COUNT relationship with the                 |      | Tab. 150. | Time step for PULSE_LTCY with HP_                 |      |
|           | ODR                                                   | . 64 |           | FILTER_CUTOFF[pls_hpf_en] = 1                     | 69   |
| Tab. 135. | PULSE_CFG register (address 21h) bit                  |      | Tab. 151. | Time step for PULSE_LTCY with HP_                 |      |
|           | allocation                                            | 64   |           | FILTER_CUTOFF[pls_hpf_en] = 0                     | 69   |
| Tab. 136. | PULSE_CFG register (address 21h) bit                  |      | Tab. 152. | PULSE_WIND register (address 28h) bit             |      |
|           | descriptions                                          | 64   |           | allocation                                        | . 69 |
| Tab. 137. | PULSE_SRC register (address 22h) bit                  |      | Tab. 153. | PULSE_WIND register (address 28h) bit             |      |
|           | allocation                                            | 65   |           | description                                       | . 70 |
| Tab. 138. | PULSE_SRC register (address 22h) bit                  |      | Tab. 154. | Time step for PULSE_WIND with HP_                 |      |
|           | descriptions                                          | 65   |           | FILTER_CUTOFF[pls_hpf_en] = 1                     | 70   |
| Tab. 139. | PULSE_THSX register (address 23h) bit                 |      | Tab. 155. | Time step for PULSE_WIND with HP_                 |      |
|           | allocation                                            | 66   |           | FILTER_CUTOFF[pls_hpf_en] = 0                     | 70   |
| Tab. 140. | PULSE_THSX register (address 23h) bit                 |      | Tab. 156. | OFF_X register (address 2Fh) bit allocation       |      |
|           | description                                           | 66   |           | OFF_X register (address 2Fh) bit                  |      |
| Tab. 141. | PULSE_THSY register (address 24h) bit                 |      |           | description                                       | .71  |
|           | allocation                                            | 66   | Tab. 158. | OFF_Y register (address 30h) bit allocation       | .71  |
| Tab. 142. | PULSE_THSY register (address 24h) bit                 |      | Tab. 159. | OFF_Y register (address 30h) bit description .    | 71   |
|           | description                                           | 67   | Tab. 160. | OFF_Z register (address 31h) bit allocation       | . 71 |
| Tab. 143. | PULSE_THSZ register (address 25h) bit                 |      | Tab. 161. | OFF_Z register (address 31h) bit description      | 72   |
|           | description                                           | 67   | Tab. 162. | Thermal characteristics                           | . 74 |
|           |                                                       |      | Tab. 163. | Revision history                                  | 79   |
|           |                                                       |      |           |                                                   |      |
| Figure    | es                                                    |      |           |                                                   |      |
| Fig. 1.   | Block diagram                                         | 2    | Fig. 12.  | Auto-sleep state transition diagram               | 38   |
| Fig. 2.   | Pinning                                               |      | Fig. 13.  | Illustration of Z-tilt angle lockout transition   |      |
| Fig. 3.   | Product orientation and axis orientation              |      | Fig. 14.  | Illustration of landscape to portrait transition  |      |
| Fig. 4.   | Electrical connection                                 |      | Fig. 15.  | Illustration of portrait to landscape transition  |      |
| Fig. 5.   | I2C slave timing diagram                              |      | Fig. 16.  | A_FFMT_THS high and low-g level                   |      |
| Fig. 6.   | I2C timing diagram                                    |      | Fig. 17.  | Behavior of the A FFMT debounce counter           |      |
| Fig. 7.   | SPI timing diagram                                    |      | <b>J</b>  | in relation to the a_ffmt_dbcntm setting          | 56   |
| Fig. 8.   | SPI single-burst read/write transaction               |      | Fig. 18.  | Recommended PCB land pattern, solder              |      |
| <b>J</b>  | diagram                                               | 11   | <b>J</b>  | mask, and stencil opening near package            |      |
| Fig. 9.   | FXLS8471Q power mode transition diagram .             |      |           | footprint                                         | 73   |
| Fig. 10.  | Interrupt controller block diagram                    |      | Fig. 19.  | Package outline                                   |      |
| Fia. 11.  | INT1/INT2 event flag logic example                    |      | <b>5</b>  | •                                                 | -    |

# **Contents**

| 1                                                                                                                                                                          | General description                      | 1                                                                          | 18.1.11                                                                                                                                                                   | CTRL_REG4 - interrupt enable register       |                                                                            |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|----------------------------------------------------------------------------|
| 2                                                                                                                                                                          | Features and benefits                    |                                                                            |                                                                                                                                                                           | (address 2Dh)                               | 33                                                                         |
| 3                                                                                                                                                                          | Typical applications                     |                                                                            | 18.1.12                                                                                                                                                                   | CTRL_REG5 - interrupt routing configuration |                                                                            |
| 4                                                                                                                                                                          | Ordering information                     |                                                                            |                                                                                                                                                                           | register (address 2Eh)                      | . 34                                                                       |
| 5                                                                                                                                                                          | Block Diagram                            |                                                                            | 18.1.13                                                                                                                                                                   | CTRL_REG6 - register (address 5Bh)          |                                                                            |
| 6                                                                                                                                                                          | Pinning information                      |                                                                            | 18.1.14                                                                                                                                                                   | CTRL_REG7 - register (address 5Ch)          |                                                                            |
| 6.1                                                                                                                                                                        | Pinning                                  |                                                                            | 18.2                                                                                                                                                                      | Auto-Sleep trigger register                 |                                                                            |
| 6.2                                                                                                                                                                        | Pin description                          |                                                                            | 18.2.1                                                                                                                                                                    | ASLP_COUNT register (address 29h)           |                                                                            |
| 7                                                                                                                                                                          | Orientation                              |                                                                            | 18.3                                                                                                                                                                      | Temperature register                        | . 39                                                                       |
| 8                                                                                                                                                                          | Electrical connections                   |                                                                            | 18.3.1                                                                                                                                                                    | TEMP_OUT register (address 51h)             |                                                                            |
| 9                                                                                                                                                                          | Terminology                              | 5                                                                          | 18.4                                                                                                                                                                      | Output data registers                       |                                                                            |
| 9.1                                                                                                                                                                        | Sensitivity                              |                                                                            | 18.4.1                                                                                                                                                                    | OUT X MSB, OUT X LSB, OUT Y MSB,            |                                                                            |
| 9.2                                                                                                                                                                        | Zero-g offset                            |                                                                            |                                                                                                                                                                           | OUT_Y_LSB, OUT_Z_MSB, OUT_Z_LSB             |                                                                            |
| 9.3                                                                                                                                                                        | Self-test                                |                                                                            |                                                                                                                                                                           | registers (addresses 01h to 06h)            | 39                                                                         |
| 10                                                                                                                                                                         | Digital interfaces                       |                                                                            | 18.5                                                                                                                                                                      | FIFO registers                              |                                                                            |
| 10.1                                                                                                                                                                       | I2C interface characteristics            | 6                                                                          | 18.5.1                                                                                                                                                                    | F_SETUP register (address 09h)              |                                                                            |
| 10.1.1                                                                                                                                                                     | General I2C operation                    |                                                                            | 18.6                                                                                                                                                                      | Sensor data configuration registers         |                                                                            |
| 10.1.2                                                                                                                                                                     | I2C read/write operations                |                                                                            | 18.6.1                                                                                                                                                                    | XYZ_DATA_CFG register (address 0Eh)         |                                                                            |
| 10.2                                                                                                                                                                       | SPI interface characteristics            |                                                                            | 18.7                                                                                                                                                                      | High-pass filter register                   |                                                                            |
| 10.2.1                                                                                                                                                                     | General SPI operation                    |                                                                            | 18.7.1                                                                                                                                                                    | HP_FILTER_CUTOFF register (address          |                                                                            |
| 10.2.2                                                                                                                                                                     | SPI READ/WRITE operations                |                                                                            |                                                                                                                                                                           | 0Fh)                                        | 42                                                                         |
| 10.2.3                                                                                                                                                                     | I2C/SPI auto detection                   |                                                                            | 18.8                                                                                                                                                                      | Portrait/Landscape detection registers      |                                                                            |
| 10.2.4                                                                                                                                                                     | Power supply sequencing and I2C/SPI mode |                                                                            | 18.8.1                                                                                                                                                                    | PL STATUS register (address 10h)            |                                                                            |
|                                                                                                                                                                            | auto-detection                           | 11                                                                         | 18.8.2                                                                                                                                                                    | PL_CFG register (address 11h)               |                                                                            |
| 11                                                                                                                                                                         | Absolute maximum ratings                 |                                                                            | 18.8.3                                                                                                                                                                    | PL_COUNT register (address 12h) register    |                                                                            |
| 12                                                                                                                                                                         | Mechanical characteristics               |                                                                            | 18.8.4                                                                                                                                                                    | PL_BF_ZCOMP register (address 13h)          |                                                                            |
| 13                                                                                                                                                                         | Electrical characteristics               |                                                                            | 18.8.5                                                                                                                                                                    | PL_THS_REG register (address 14h)           |                                                                            |
| 14                                                                                                                                                                         | Temperature sensor characteristics       |                                                                            | 18.9                                                                                                                                                                      | Free-fall and Motion event detection        |                                                                            |
| 15                                                                                                                                                                         | Modes of operation                       |                                                                            | 18.9.1                                                                                                                                                                    | A_FFMT_CFG register (address 15h)           |                                                                            |
|                                                                                                                                                                            |                                          |                                                                            |                                                                                                                                                                           |                                             |                                                                            |
| 16                                                                                                                                                                         | Embedded functionality                   | 16                                                                         | 18.9.2                                                                                                                                                                    |                                             | . 51                                                                       |
| <b>16</b><br>16.1                                                                                                                                                          | Embedded functionality                   |                                                                            | 18.9.2<br>18.9.3                                                                                                                                                          | A_FFMT_SRC register (address 16h)           | . 51                                                                       |
|                                                                                                                                                                            | Embedded functionality                   | 16                                                                         |                                                                                                                                                                           |                                             |                                                                            |
| 16.1                                                                                                                                                                       | Factory calibration8-bit or 14-bit data  | 16                                                                         |                                                                                                                                                                           | A_FFMT_SRC register (address 16h)           | 52                                                                         |
| 16.1<br>16.2                                                                                                                                                               | Factory calibration                      | 16<br>16                                                                   | 18.9.3                                                                                                                                                                    | A_FFMT_SRC register (address 16h)           | 52                                                                         |
| 16.1<br>16.2                                                                                                                                                               | Factory calibration                      | 16<br>16<br>17                                                             | 18.9.3<br>18.9.4                                                                                                                                                          | A_FFMT_SRC register (address 16h)           | . 52<br>. 55                                                               |
| 16.1<br>16.2<br>16.3                                                                                                                                                       | Factory calibration                      | 16<br>16<br>17<br>17                                                       | 18.9.3<br>18.9.4                                                                                                                                                          | A_FFMT_SRC register (address 16h)           | . 52<br>. 55<br>. 56                                                       |
| 16.1<br>16.2<br>16.3                                                                                                                                                       | Factory calibration                      | 16<br>16<br>17<br>17<br>17                                                 | 18.9.3<br>18.9.4<br>18.10                                                                                                                                                 | A_FFMT_SRC register (address 16h)           | 52<br>.55<br>.56                                                           |
| 16.1<br>16.2<br>16.3<br>16.4<br>16.5                                                                                                                                       | Factory calibration                      | 16<br>16<br>17<br>17<br>17                                                 | 18.9.3<br>18.9.4<br>18.10<br>18.10.1                                                                                                                                      | A_FFMT_SRC register (address 16h)           | 52<br>.55<br>.56<br>.57                                                    |
| 16.1<br>16.2<br>16.3<br>16.4<br>16.5<br>16.5.1                                                                                                                             | Factory calibration                      | 16<br>17<br>17<br>17<br>18<br>18                                           | 18.9.3<br>18.9.4<br>18.10<br>18.10.1<br>18.10.2                                                                                                                           | A_FFMT_SRC register (address 16h)           | 52<br>.55<br>.56<br>.57<br>.57                                             |
| 16.1<br>16.2<br>16.3<br>16.4<br>16.5<br>16.5.1<br>16.5.2                                                                                                                   | Factory calibration                      | 16<br>17<br>17<br>17<br>18<br>18                                           | 18.9.3<br>18.9.4<br>18.10<br>18.10.1<br>18.10.2<br>18.10.3                                                                                                                | A_FFMT_SRC register (address 16h)           | 52<br>.55<br>.56<br>.57<br>.57                                             |
| 16.1<br>16.2<br>16.3<br>16.4<br>16.5<br>16.5.1<br>16.5.2<br>16.6                                                                                                           | Factory calibration                      | 16<br>17<br>17<br>17<br>18<br>18<br>18                                     | 18.9.3<br>18.9.4<br>18.10<br>18.10.1<br>18.10.2<br>18.10.3<br>18.10.4                                                                                                     | A_FFMT_SRC register (address 16h)           | 52<br>.55<br>.56<br>.57<br>.57                                             |
| 16.1<br>16.2<br>16.3<br>16.4<br>16.5<br>16.5.1<br>16.5.2<br>16.6<br>16.7                                                                                                   | Factory calibration                      | 16<br>17<br>17<br>17<br>18<br>18<br>18<br>19                               | 18.9.3<br>18.9.4<br>18.10<br>18.10.1<br>18.10.2<br>18.10.3<br>18.10.4                                                                                                     | A_FFMT_SRC register (address 16h)           | 52<br>.55<br>.56<br>.57<br>.57                                             |
| 16.1<br>16.2<br>16.3<br>16.4<br>16.5<br>16.5.1<br>16.5.2<br>16.6<br>16.7<br>16.8                                                                                           | Factory calibration                      | 16 17 17 17 18 18 18 19 19 19                                              | 18.9.3<br>18.9.4<br>18.10<br>18.10.1<br>18.10.2<br>18.10.3<br>18.10.4<br>18.10.5                                                                                          | A_FFMT_SRC register (address 16h)           | 52<br>. 55<br>. 57<br>. 57<br>. 58<br>58                                   |
| 16.1<br>16.2<br>16.3<br>16.4<br>16.5<br>16.5.1<br>16.5.2<br>16.6<br>16.7<br>16.8<br>16.9                                                                                   | Factory calibration                      | 16 17 17 17 18 18 18 19 19 19 20 23                                        | 18.9.3<br>18.9.4<br>18.10<br>18.10.1<br>18.10.2<br>18.10.3<br>18.10.4<br>18.10.5                                                                                          | A_FFMT_SRC register (address 16h)           | 52<br>55<br>56<br>57<br>58<br>58                                           |
| 16.1<br>16.2<br>16.3<br>16.4<br>16.5<br>16.5.1<br>16.5.2<br>16.6<br>16.7<br>16.8<br>16.9<br><b>17</b>                                                                      | Factory calibration                      | 16 17 17 17 18 18 18 19 19 19 20 23                                        | 18.9.3<br>18.9.4<br>18.10<br>18.10.1<br>18.10.2<br>18.10.3<br>18.10.4<br>18.10.5                                                                                          | A_FFMT_SRC register (address 16h)           | 52<br>55<br>56<br>57<br>58<br>58                                           |
| 16.1<br>16.2<br>16.3<br>16.4<br>16.5<br>16.5.1<br>16.5.2<br>16.6<br>16.7<br>16.8<br>16.9<br><b>17</b>                                                                      | Factory calibration                      | 16 17 17 17 18 18 18 19 19 19 20 23 23                                     | 18.9.3<br>18.9.4<br>18.10<br>18.10.1<br>18.10.2<br>18.10.3<br>18.10.4<br>18.10.5                                                                                          | A_FFMT_SRC register (address 16h)           | 52<br>55<br>56<br>57<br>58<br>58<br>59                                     |
| 16.1<br>16.2<br>16.3<br>16.4<br>16.5<br>16.5.1<br>16.5.2<br>16.6<br>16.7<br>16.8<br>16.9<br><b>17</b><br><b>18</b><br>18.1<br>18.1.1<br>18.1.2                             | Factory calibration                      | 16 17 17 17 18 18 18 19 19 19 20 23 23 23                                  | 18.9.3<br>18.9.4<br>18.10<br>18.10.1<br>18.10.2<br>18.10.3<br>18.10.4<br>18.10.5<br>18.10.6                                                                               | A_FFMT_SRC register (address 16h)           | 52<br>55<br>56<br>57<br>58<br>58<br>59                                     |
| 16.1<br>16.2<br>16.3<br>16.4<br>16.5<br>16.5.1<br>16.5.2<br>16.6<br>16.7<br>16.8<br>16.9<br>17<br>18<br>18.1<br>18.1.1<br>18.1.2<br>18.1.3                                 | Factory calibration                      | 16 17 17 17 18 18 18 19 19 19 20 23 23 23 23                               | 18.9.3<br>18.9.4<br>18.10<br>18.10.1<br>18.10.2<br>18.10.3<br>18.10.4<br>18.10.5<br>18.10.6                                                                               | A_FFMT_SRC register (address 16h)           | 52<br>55<br>56<br>57<br>58<br>58<br>59<br>59                               |
| 16.1<br>16.2<br>16.3<br>16.4<br>16.5<br>16.5.1<br>16.5.2<br>16.6<br>16.7<br>16.8<br>16.9<br>17<br>18<br>18.1<br>18.1.1<br>18.1.2<br>18.1.3<br>18.1.4                       | Factory calibration                      | 16 17 17 17 18 18 18 19 19 20 23 23 23 23 24 25                            | 18.9.3<br>18.9.4<br>18.10.1<br>18.10.2<br>18.10.3<br>18.10.4<br>18.10.5<br>18.10.6<br>18.10.7<br>18.10.8<br>18.10.9                                                       | A_FFMT_SRC register (address 16h)           | 52<br>55<br>56<br>57<br>58<br>58<br>59<br>59                               |
| 16.1<br>16.2<br>16.3<br>16.4<br>16.5<br>16.5.1<br>16.5.2<br>16.6<br>16.7<br>16.8<br>16.9<br>17<br>18<br>18.1<br>18.1.1<br>18.1.2<br>18.1.3<br>18.1.4<br>18.1.5             | Factory calibration                      | 16 17 17 17 18 18 18 19 19 20 23 23 23 23 24 25 26                         | 18.9.3<br>18.9.4<br>18.10.1<br>18.10.2<br>18.10.3<br>18.10.4<br>18.10.5<br>18.10.6<br>18.10.7<br>18.10.8<br>18.10.9<br>18.10.10                                           | A_FFMT_SRC register (address 16h)           | 52<br>55<br>56<br>57<br>58<br>58<br>59<br>59                               |
| 16.1<br>16.2<br>16.3<br>16.4<br>16.5<br>16.5.1<br>16.5.2<br>16.6<br>16.7<br>16.8<br>16.9<br>17<br>18<br>18.1<br>18.1.1<br>18.1.2<br>18.1.3<br>18.1.4<br>18.1.5<br>18.1.6   | Factory calibration                      | 16 17 17 17 18 18 18 19 19 20 23 23 23 23 24 25 26                         | 18.9.3<br>18.9.4<br>18.10.1<br>18.10.2<br>18.10.3<br>18.10.4<br>18.10.5<br>18.10.6<br>18.10.7<br>18.10.8<br>18.10.9                                                       | A_FFMT_SRC register (address 16h)           | 52<br>55<br>56<br>57<br>58<br>59<br>59<br>59                               |
| 16.1<br>16.2<br>16.3<br>16.4<br>16.5<br>16.5.1<br>16.5.2<br>16.6<br>16.7<br>16.8<br>16.9<br>17<br>18<br>18.1.1<br>18.1.2<br>18.1.3<br>18.1.4<br>18.1.5<br>18.1.6<br>18.1.7 | Factory calibration                      | 16 17 17 17 18 18 18 19 19 20 23 23 23 23 24 25 26 26 28                   | 18.9.3<br>18.9.4<br>18.10.1<br>18.10.2<br>18.10.3<br>18.10.4<br>18.10.5<br>18.10.6<br>18.10.7<br>18.10.8<br>18.10.9<br>18.10.10<br>18.11                                  | A_FFMT_SRC register (address 16h)           | 52<br>55<br>56<br>57<br>58<br>59<br>59<br>59<br>60                         |
| 16.1<br>16.2<br>16.3<br>16.4<br>16.5<br>16.5.1<br>16.5.2<br>16.6<br>16.7<br>16.8<br>16.9<br>17<br>18<br>18.1.1<br>18.1.2<br>18.1.3<br>18.1.4<br>18.1.5<br>18.1.6<br>18.1.7 | Factory calibration                      | 16 17 17 17 18 18 18 19 19 20 23 23 23 23 24 25 26 26 28 28                | 18.9.3<br>18.9.4<br>18.10.1<br>18.10.2<br>18.10.3<br>18.10.4<br>18.10.5<br>18.10.6<br>18.10.7<br>18.10.8<br>18.10.9<br>18.10.10<br>18.11.1                                | A_FFMT_SRC register (address 16h)           | 52<br>55<br>56<br>57<br>58<br>58<br>59<br>59<br>59<br>60                   |
| 16.1<br>16.2<br>16.3<br>16.4<br>16.5<br>16.5.1<br>16.5.2<br>16.6<br>16.7<br>16.8<br>16.9<br>17<br>18<br>18.1.1<br>18.1.2<br>18.1.3<br>18.1.4<br>18.1.5<br>18.1.6<br>18.1.7 | Factory calibration                      | 16 17 17 17 18 18 18 19 19 20 23 23 23 23 24 25 26 26 28 28                | 18.9.3<br>18.9.4<br>18.10<br>18.10.1<br>18.10.2<br>18.10.3<br>18.10.4<br>18.10.5<br>18.10.6<br>18.10.7<br>18.10.8<br>18.10.9<br>18.10.10<br>18.11.1<br>18.11.1<br>18.11.1 | A_FFMT_SRC register (address 16h)           | 52<br>55<br>57<br>57<br>58<br>58<br>59<br>59<br>59<br>60<br>60<br>61<br>61 |
| 16.1<br>16.2<br>16.3<br>16.4<br>16.5<br>16.5.1<br>16.5.2<br>16.6<br>16.7<br>16.8<br>16.9<br>17<br>18<br>18.1.1<br>18.1.2<br>18.1.3<br>18.1.4<br>18.1.5<br>18.1.6<br>18.1.7 | Factory calibration                      | 16 17 17 17 18 18 18 19 19 19 20 23 23 23 23 23 23 23 24 25 26 26 28 28 30 | 18.9.3<br>18.9.4<br>18.10.1<br>18.10.2<br>18.10.3<br>18.10.4<br>18.10.5<br>18.10.6<br>18.10.7<br>18.10.8<br>18.10.9<br>18.10.10<br>18.11.1                                | A_FFMT_SRC register (address 16h)           | 52<br>55<br>57<br>57<br>58<br>58<br>59<br>59<br>59<br>60<br>60<br>61<br>61 |

| 18.11. <del>4</del> | TRANSIENT_COUNT register (address          |      |
|---------------------|--------------------------------------------|------|
|                     | 20h)                                       |      |
| 18.12               | Pulse detection registers                  |      |
| 18.12.1             | PULSE_CFG register (address 21h)           |      |
| 18.12.2             | PULSE_SRC register (address 22h)           |      |
| 18.12.3             |                                            |      |
| 18.12.4             | PULSE_THSY register (address 24h)          | . 66 |
| 18.12.5             | PULSE_THSZ register (address 25h)ULSE_     |      |
|                     | THSZ register (address 25h) bit allocation |      |
| 18.12.6             | PULSE_TMLT register (address 26h)          | 67   |
| 18.12.7             | PULSE_LTCY register (address 27h)          | 68   |
| 18.12.8             | PULSE_WIND register (address 28h)          |      |
| 18.13               | Offset correction registers                | . 70 |
| 18.13.1             | OFF_X register (address 2Fh)               | 71   |
| 18.13.2             | OFF_Y register (address 30h)               | 71   |
| 18.13.3             | OFF_Z register (address 31h)               | . 71 |
| 19                  | Mounting guidelines for the Quad Flat No-  |      |
|                     | Lead (QFN) package                         |      |
| 19.1                | Overview of soldering considerations       |      |
| 19.2                | Halogen content                            | . 72 |
| 19.3                | PCB mounting recommendations               |      |
| 20                  | Thermal characteristics                    |      |
| 21                  | Package information                        |      |
| 22                  | Appendix A — Chip errata                   | . 78 |
| 22.1                | SPI Mode soft-reset using CTRL_REG2        |      |
|                     | (2Bh), bit 6                               | 78   |
| 22.1.1              | Description                                | 78   |
| 22.1.2              | Workaround                                 |      |
| 23                  | Revision history                           | . 79 |
| 24                  | Legal information                          | . 80 |

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