**Application note** 

#### **Document information**

| Information | Content                                                                                                                                                                                                                                                             |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Keywords    | FXLS8962AF                                                                                                                                                                                                                                                          |
| Abstract    | This document provides the needed information to deploy a self-test routine<br>for FXLS8962AF in a complete system. This document also discusses an<br>optional procedure to validate the embedded Sensor Data Change Detection<br>(SDCD) function using self-test. |



# 1 Introduction

The accelerometer self-test feature generates an artificial acceleration signal by deflecting the MEMS transducer proof mass with an electrostatic force. As a consequence, an artificially-induced acceleration is measured at the device output indicating proper operation of both MEMS transducer and ASIC signal chain.

The main objective of this document is to provide the user all the information needed to deploy a self-test routine for FXLS8962AF in a complete system. Such a procedure can be readily implemented in the host MCU handling the sensor and executed when appropriate. An appropriate execution time might be at system power-up prior to sensor initialization.

# 2 Applicable devices

This document applies to FXLS8962AF devices with PROD\_REV register value equal to 11h.

The PROD\_REV register contains the revision number, stored in BCD format, as MAJ.MIN with a range from 1.0 to 9.9.

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

#### Table 1. PROD REV - product revision register (address 12h) bit allocation

#### Table 2. PROD\_REV - product revision register (address 12h) bit descriptions

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

# 3 Accelerometer and self-test principle

The FXLS8962AF 3-axis inertial sensor measures acceleration through its inertial proof mass inside the MEMS transducer. When the device undergoes acceleration, the movement of the proof mass equates to a slight change in capacitance that is translated into a voltage and digitized inside the sensor mixed-signal chain.

In order to check the operation of the sensor (transducer and signal chain) without any applied acceleration, a self-test function is executed. The self-test function applies a voltage to the MEMS transducer electrodes, creating an electrostatic force that deflects the proof mass and causes an output response similar to a response seen during acceleration. The application of the self-test electrostatic force can be viewed as a step input, with the inertial proof mass following a first order response curve and settling to a final value after a finite amount of time (settling time).

The self-test procedure is performed in two steps for each axis. The two-step process moves the proof mass in a positive, then negative direction, which allows higher sensitivity and removes any constant acceleration or sensor offsets.

The device is not required to be at rest during the test sequence and may also be arbitrarily oriented. It is important to check that the output data registers do not become saturated at the maximum positive or negative value to ensure clipping is not occurring. Thus, during self-test, a higher full-scale range ( $\pm 4 g$  or higher) is selected to ensure proper results.

# 4 Self-test procedure

The self-test procedure relies on a serial communication interface between the sensor and a host MCU. The serial bus can be  $I^2C$  or SPI, as FXLS8962AF supports both types. In addition to the serial interface, an interrupt line is required between the host MCU and the sensor.

In order to activate the FXLS8962AF self-test feature, the SENS\_CONFIG1 register is accessed and programmed (address 15h). The SENS\_CONFIG1 full content description and bit fields details are shown in the data sheet.

A full-scale measurement range of  $\pm 4$  g or higher is recommended for self-test. Note that in  $\pm 16$  g mode, 1 g corresponds to 128 LSBs, or equivalently, 1 LSB  $\approx$  7.81 mg, in  $\pm 8$  g mode, 1 g corresponds to 256 LSBs, or equivalently, 1 LSB  $\approx$  3.91 mg and in  $\pm 4$  g mode, 1 g corresponds to 512 LSBs, or equivalently, 1 LSB  $\approx$  1.95 mg.

The default output data rate (ODR) for self-test is 3200 Hz (this *out-of-reset* value can be subsequently changed by use of the SELF\_TEST\_CONFIG2 register). For more details, see <u>Section 4.1.4 "SELF\_TEST\_CONFIG2 - self-test configuration register 2 (address 38h)"</u>. The self-test procedure detailed in this document uses an ODR of 100 Hz, which is realized by programming the SELF\_TEST\_CONFIG2 register with a value of 05h.

NXP recommends users minimize communication traffic on the device serial interface during the measurement phase of the sensor in order to reduce the susceptibility of the self-test response signal to induced noise. The most effective way to prevent induced noise during self-test is to employ data ready interrupts to synchronize the collection of data over serial interface and ensure digital communications do not coincide with the measurement phase of the self-test sequence.

When the BT\_MODE pin is connected to V<sub>DD</sub>, the data ready interrupt is signaled for TPULSE-MOT seconds (5 ms typ) and then is automatically cleared. As a result, the maximum recommended self-test ODR when the BT\_MODE pin is connected to V<sub>DD</sub> is 100 Hz.

When BT\_MODE pin is connected to GND, the data ready interrupt clears immediately after reading the data. Therefore, self-test ODR can be configured up to 3200 Hz.

**Note:** Only one axis can be tested at a time during self-test mode, because the signal chain processes only the selected axis. This is an important difference from normal operation, where all three axes are processed sequentially during a measurement cycle.

## 4.1 Register used in the self-test procedure

For self-test configuration, the user needs to program specific settings in the following registers. Note that after a POR, soft-reset, or exit from Hibernate mode, these settings will be overwritten by the default values as indicated by the register description table in the data sheet.

The following sections summarize the bit fields relevant to the self-test sequence. The data sheet contains the full descriptions of the registers.

| Name              | Address | Access | Comment                                                                                 | Accessibility                            |
|-------------------|---------|--------|-----------------------------------------------------------------------------------------|------------------------------------------|
| SENS_CONFIG1      | 15h     | R/W    | Full-scale range, self-test control, soft reset, Active mode enable                     | Read: always<br>Write: standby mode only |
| SENS_CONFIG4      | 18h     | R/W    | Pulse generation option for DRDY<br>event, output pin logic polarity and<br>driver type | Read: always<br>Write: standby mode only |
| SELF_TEST_CONFIG1 | 37h     | R/W    | Self-test idle phase duration                                                           | Read: always<br>Write: standby mode only |
| SELF_TEST_CONFIG2 | 38h     | R/W    | Self-test measurement phase decimation factor                                           | Read: always<br>Write: standby mode only |
| INT_EN            | 20h     | R/W    | Interrupt output enable register                                                        | Read: always<br>Write: standby mode only |

Table 3. Key register involved in sensor self-test

### 4.1.1 SENS\_CONFIG1 - sensor configuration register 1 (address 15h)

| Table 4. SENS_CONFIG1 - sensor configuration register 1 (address 15h) bit allocation |     |                  |     |        |       |          |     |        |
|--------------------------------------------------------------------------------------|-----|------------------|-----|--------|-------|----------|-----|--------|
| Bit                                                                                  | 7   | 6                | 5   | 4      | 3     | 2        | 1   | 0      |
| Name                                                                                 | RST | ST_AXIS_SEL[1:0] |     | ST_POL | SPI_M | FSR[1:0] |     | ACTIVE |
| Reset                                                                                | 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    |

Register reset value provided above assumes that BT\_MODE = GND.

As this register is thoroughly described in the sensor product data sheet, the following table mainly summarizes the bit fields relevant to the self-test sequence.

| Table 5. SENS_CONFIG1 - sensor configuration register 1 (address 15h) bit description |                  |                                                                                                                                                                                                                                                                 |  |  |
|---------------------------------------------------------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit                                                                                   | Name             | Description                                                                                                                                                                                                                                                     |  |  |
| 6 to 5                                                                                | ST_AXIS_SEL[1:0] | Self-test axis selection<br><b>00</b> — self-test function is disabled (reset value)<br><b>01</b> — self-test function is enabled for X-axis<br><b>10</b> — self-test function is enabled for Y-axis<br><b>11</b> — self-test function is enabled for Z-axis    |  |  |
| 4                                                                                     | ST_POL           | <ul> <li>Self-test displacement polarity</li> <li><b>0</b> — Proof mass displacement for the selected axis is in the positive direction (reset value)</li> <li><b>1</b> — Proof mass displacement for the selected axis is in the negative direction</li> </ul> |  |  |

AN5311 Application note

#### FXLS8962AF self-test procedure

| Bit    | Name     | Description                                                                                                                                                                                               |
|--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3      | SPI_M    | SPI interface mode selection; selects between 3- and 4-wire operating modes for the SPI interface:                                                                                                        |
|        |          | <b>0</b> — 4-wire interface mode is selected (reset value)                                                                                                                                                |
|        |          | 1 — 3-wire interface mode is selected                                                                                                                                                                     |
|        |          | Notes:                                                                                                                                                                                                    |
|        |          | <ul> <li>The state of this bit is only relevant when the SPI interface mode is selected<br/>(INTF_SEL = V<sub>DD</sub>).</li> </ul>                                                                       |
|        |          | <ul> <li>When INTF_SEL = V<sub>DD</sub> and SPI_M = 1, the SDA/SPI_MOSI pin becomes<br/>the bi-directional SPI_DATA pin; the SA0/MISO pin is unused and placed in a<br/>high-impedance state.</li> </ul>  |
|        |          | <ul> <li>4-wire mode is selected by default after a POR/BOR event or when exiting<br/>Hibernate mode.</li> </ul>                                                                                          |
|        |          | <ul> <li>If INTF_SEL = V<sub>DD</sub> and the SPI_MOSI and SPI_MISO lines are directly<br/>connected together on the PCB, 3-wire SPI mode is enabled regardless of<br/>the setting of this bit</li> </ul> |
| 2 to 1 | FSR[1:0] | Full-scale measurement range (FSR) selection                                                                                                                                                              |
|        |          | 00 — ±2 g; 0.98 mg/LSB (1024 LSB/g) nominal sensitivity (reset value)                                                                                                                                     |
|        |          | 01 — ±4 g; 1.95 mg/LSB (512 LSB/g) nominal sensitivity                                                                                                                                                    |
|        |          | 10 — ±8 g; 3.91 mg/LSB (256 LSB/g) nominal sensitivity                                                                                                                                                    |
|        |          | 11 — ±16 g; 7.81 mg/LSB (128 LSB/g) nominal sensitivity                                                                                                                                                   |
| 0      | ACTIVE   | Standby/Active mode selection                                                                                                                                                                             |

# 4.1.2 SENS\_CONFIG4 - sensor configuration register 4 (address 18h)

#### Table 6. SENS\_CONFIG4 - sensor configuration register 4 (address 18h) bit allocation

| Bit    | 7              | 6                | 5                | 4               | 3        | 2         | 1             | 0       |
|--------|----------------|------------------|------------------|-----------------|----------|-----------|---------------|---------|
| Name   | EXT_T<br>RIG_M | WAKE_S<br>DCD_WT | WAKE_S<br>DCD_OT | WAKE_<br>ORIENT | DRDY_PUL | INT2_FUNC | INT_P<br>P_OD | INT_POL |
| Reset  | 0              | 0                | 0                | 0               | 0        | 0         | 0             | 1       |
| Access | R/W            | R/W              | R/W              | R/W             | R/W      | R/W       | R/W           | R/W     |

#### Table 7. SENS\_CONFIG4 field descriptions

| Bit | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | DRDY_PUL | Pulse generation option for DRDY event<br>$0 - A SRC_DRDY$ event is output on the INTx pin as an active high or active<br>low signal depending on the polarity setting made in INT_POL. The INTx pin<br>will remain asserted until the host reads any of the OUT_X/Y/Z registers. (reset<br>value)<br>$1 - A 32 \ \mu s$ (nominal) duration pulse is output on the configured INTx pin once<br>per ODR cycle. The output pulse is either positive or negative, depending on<br>the INT_POL setting. Note: The pulsed output signal is OR'd with all of the<br>other interrupt events assigned to the INTx pin. Note: In Motion Detection mode<br>(BT_MODE = V <sub>DD</sub> ), the state of this bit is ignored and has no effect on device<br>operation. |

#### FXLS8962AF self-test procedure

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

# 4.1.3 SELF\_TEST\_CONFIG1 - self-test configuration register 1 (address 37h)

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

# Table 9. SELF TEST CONFIG1 (address 37h) bit description

|        | Table 5. OLLI_TEGT_CONTICT (address 571) bit description |                                                                                                                                                                                                         |  |  |  |  |
|--------|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bit    | Name                                                     | Description                                                                                                                                                                                             |  |  |  |  |
| 4 to 0 | ST_IDLE[4:0]                                             | Self-test Idle phase duration: The value contained in ST_IDLE<br>determines the Self-test Idle phase duration per the following equation:<br>ST_IDLE = $312.5 \ \mu s + (ST_IDLE[4:0] * 31.25) \ \mu s$ |  |  |  |  |

AN5311 Application note

FXLS8962AF self-test procedure

# 4.1.4 SELF\_TEST\_CONFIG2 - self-test configuration register 2 (address 38h)

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

#### Table 10. SELF\_TEST\_CONFIG2 - self-test configuration register1 (address 38h) bit allocation

| Table 11. | SELF TEST | CONFIG2 - se | If-test configuratio | n reaister1 | (address 38h) bit description |  |
|-----------|-----------|--------------|----------------------|-------------|-------------------------------|--|
|           |           |              |                      |             | (                             |  |

| Bit    | Name        | Description                                                                                                                                                                                                                                                     |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3 to 0 | ST_DEC[3:0] | Self-test measurement phase decimation factor This bit field selects the self-<br>test measurement phase decimation factor. The decimation selection ranges<br>from 1 to 4096. The default ST_DEC setting (00h), configures ODR for self-test<br>to be 3200 Hz. |

#### Table 12. Self-test measurement phase decimation settings

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

[1] The ST recurrence and period shown in this table correspond to ST\_IDLE = 0. Otherwise, the formula provided in note 1 shall be used.

#### Notes:

- During the self-test sequence, the accelerometer measurement period in μs (for each axis and each direction) is given by the following equation: ST\_PERIOD (μs) = 2 <sup>ST\_DEC[3:0]</sup> \* [312.5 + (ST\_IDLE[4:0] \* 31.25)] μs
- The user-selected ODR in SENS\_CONFIG3 register and power mode settings are ignored during self-test operation. The user-selected settings for ODR and power mode are applied after self-test is disengaged, for example, ST\_AXIS\_SEL[1:0] = 0b00.

#### 4.1.5 INT\_EN - interrupt output enable register (address 20h)

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

| Bit                                | 7           | 6      | 5              | 4              | 3             | 2       | 1            | 0               |
|------------------------------------|-------------|--------|----------------|----------------|---------------|---------|--------------|-----------------|
| Name                               | DRD<br>Y_EN | BUF_EN | SDCD_<br>OT_EN | SDCD_<br>WT_EN | ORIEN<br>T_EN | ASLP_EN | BOOT<br>_DIS | WAKE_<br>OUT_EN |
| Reset (BT_MODE = GND)              | 0           | 0      | 0              | 0              | 0             | 0       | 0            | 0               |
| Reset (BT_MODE = V <sub>DD</sub> ) | 0           | 0      | 1              | 0              | 0             | 0       | 0            | 0               |
| Access                             | R/W         | R/W    | R/W            | R/W            | R/W           | R/W     | R/W          | R/W             |

Table 13. INT\_EN - interrupt output enable register (address 20h) bit allocation

| Table 14   | INT | EN - interrupt o  | utnut enable red | nistor (addross  | 20h) bit description |
|------------|-----|-------------------|------------------|------------------|----------------------|
| 1 able 14. |     | _EN - Interrupt 0 | ulpul enable reg | Jister (auuress) |                      |

| Bit | Name       | Description                                                                                                                                                                                                                                     |
|-----|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | DRDY_EN    | Data ready interrupt output enable<br><b>0</b> — Interrupt is disabled (reset value)<br><b>1</b> — Interrupt is enabled and signaled on either the INT1 or INT2 output pins as<br>configured by the setting made in INT_PIN_SEL                 |
| 5   | SDCD_OT_EN | <ul> <li>SDCD outside of thresholds interrupt output enable</li> <li>0 — Interrupt is disabled (reset value)</li> <li>1 — Interrupt is routed to either the INT1 or INT2 output pin as configured by the setting made in INT_PIN_SEL</li> </ul> |

#### 4.1.6 Output data validity

Since the self-test output response takes time to settle to a final value after placing the device in ACTIVE mode, the following factors must be considered while collecting response data.

# Table 15. Valid output sample considerations After placing the device in ACTIVE mode

| Setting |                                                              | Valid sample number/    |
|---------|--------------------------------------------------------------|-------------------------|
| ST_IDLE | ST_DEC                                                       | data ready interrupt    |
| 00h     | 0 (self-test ODR = 3200 Hz)                                  | fourth sample and later |
| 00h     | 1 (self-test ODR = 1600 Hz)                                  | third sample and later  |
| 00h     | $1 < ST_DEC < 5$ (200 Hz $\leq$ self-test ODR $\leq$ 800 Hz) | second sample and later |
| 00h     | $ST_DEC \ge 5$ (self-test ODR $\le 100 \text{ Hz}$ )         | first sample and later  |

# 5 Self-test sequence per axis

#### Initial state

- 1. Enter Standby mode by setting SENS\_CONFIG1[ACTIVE] to 0 (address 15h)
- Set the self-test measurement phase decimation factor SELF\_TEST\_CONFIG2[ST\_DEC] to 05h (address 38h). In this procedure, Self-test ODR is set to 100 Hz.

#### Self-test measurement phase per axis

Complete the following procedure for each axis (i = X,Y,Z).

 When BT\_MODE = V<sub>DD</sub>, enable data ready interrupt by setting INT\_EN[DRDY\_EN] bit to 1. Interrupt is routed to INT1 line. INT2 line cannot be used, because only BOOT interrupt can be routed to INT2 line when BT\_MODE = V<sub>DD</sub>.

When BT\_MODE = GND, enable data ready interrupt by setting INT\_EN[DRDY\_EN] bit to 1. Interrupt is routed to INT1 line. INT2 line can also be used. Enable pulse generation option for the DRDY event by setting SENS\_CONFIG4[DRDY\_PUL] bit to 1.

- 2. Write **SENS\_CONFIG1** register (address 15h) with the following content
  - Enable self-test on the desired axis by setting ST\_AXIS\_SEL[1:0] to 0b01 for Xaxis, 0b10 for Y-axis or 0b11 for Z-axis
  - Select self-test positive polarity by setting ST\_POL to 0
  - Select FSR measurement range. In this example ±16 *g* range is selected by setting FSR[1:0] to 0b11
  - Select Active mode by setting ACTIVE to 1
  - Wait for DRDY interrupt.
- Upon reception of first data ready interrupt, enter Standby mode by setting SENS\_CONFIG1[ACTIVE] to 0. For valid samples/data ready interrupt for each selftest ODR, see <u>Table 15</u>.
- 4. Read the acceleration data in the output registers corresponding to the selected axis (X data at register addresses 04h and 05h, Y data at register addresses 06h and 07h, Z data at register addresses 08h and 09h). Store the output data as a temporary variable, such as ST\_OUTp(i).
- 5. Write SENS\_CONFIG1 register (address 15h) with the following content:
  - Enable self-test on the desired axis by setting ST\_AXIS\_SEL[1:0] to 0b01 for Xaxis, 0b10 for Y-axis or 0b11 for Z-axis
  - Select self-test negative polarity by setting ST\_POL to 1
  - Select Active mode by setting ACTIVE to 1
  - Wait for DRDY interrupt.

- Upon reception of first data ready interrupt, enter Standby mode by setting SENS\_CONFIG1[ACTIVE] to 0. For valid samples/data ready interrupt for each selftest ODR, see <u>Table 15</u>.
- 7. Read the acceleration data in the output registers corresponding to the selected axis (X data at register addresses 04h and 05h, Y data at register addresses 06h and 07h, Z data at register addresses 08h and 09h). Store the output data as a temporary variable, such as ST\_OUTm(i).

Assuming there was no output data clipping, such as the maximum positive value not equal to +2047 and maximum negative value not equal to –2048, the self-test output change (STOC) for each axis can be computed with the following equation:

$$STOC(i) = \frac{ST_OUTp(i) - ST_OUTm(i)}{2}$$

The STOC(i) value can be compared to the data sheet specification for a given axis and FSR *g* range. If STOC > 'W' LSB, the device passed self-test. The value of 'W' is based on the FSR range and axis under test (X or Y or Z). See <u>Table 30</u>.

As mentioned in the measurement procedure, it is important that the host MCU collects measurement data only in interrupt mode. Interrupt mode is enabled using the INT\_EN (address 20h) and INT\_PIN\_SEL (address 21h) registers.

Map the data ready interrupt to one of the INTx pins available on the device and wait for the event to be signaled to the host MCU before reading data. See DRDY\_EN field of the INT\_EN register (address 20h) and DRDY\_INT2 field of the INT\_PIN\_SEL register (address 21h). In that case, sensor data collection is handled very effectively by the host MCU with an interrupt service routine. In the case of BT\_MODE =  $V_{DD}$  (motion detect mode), INT2 pin function is reserved for boot output pulse, thus is not available for this purpose. Consequently, only INT1 pin can be used.

The user-selected ODR and power mode are overridden during self-test operation. They are restored when self-test is disengaged, such as when ST\_AXIS\_SEL[1:0] = 0b00 and ACTIVE is set back again to 1.

# 6 Self-test procedure results

The self-test-sequence was run on a sample set of parts (DUTs) and the outcome is presented hereafter.

| Axis |            | Data (g)   |                  |                                |                                      |
|------|------------|------------|------------------|--------------------------------|--------------------------------------|
|      | ST_POL = 0 | ST_POL = 1 | Self-test Offset | Self-test output change (STOC) | Self-test<br>opcode<br>change (STOC) |
| X    | 83         | -181       | -49              | 132                            | 1.03                                 |
| Y    | 101        | -151       | -25              | 126                            | 0.98                                 |
| Z    | 192        | 64         | 128              | 64                             | 0.50                                 |

Table 16. Self-test measurement results for DUT1

[1] For related data plots, see <u>Section 7 "Output data plots during self-test sequence"</u>.

Application note

#### FXLS8962AF self-test procedure

| Axis |            | Data ( <i>g</i> ) |                  |                                |                                |
|------|------------|-------------------|------------------|--------------------------------|--------------------------------|
|      | ST_POL = 0 | ST_POL = 1        | Self-test Offset | Self-test output change (STOC) | Self-test output change (STOC) |
| X    | 71         | -174              | -51              | 122                            | 0.95                           |
| Y    | 93         | -147              | -27              | 120                            | 0.94                           |
| Z    | 68         | -69               | 0                | 68                             | 0.53                           |

#### Table 17. Self-test measurement results for DUT2

#### Table 18. Self-test measurement results for DUT3

| Axis |            | Data ( <i>g</i> ) |                  |                                |      |
|------|------------|-------------------|------------------|--------------------------------|------|
|      | ST_POL = 0 | ST_POL = 1        | Self-test Offset | Self-test output change (STOC) |      |
| X    | 212        | -42               | 85               | 127                            | 0.99 |
| Y    | 96         | -150              | -27              | 123                            | 0.96 |
| Z    | 202        | 73                | 137              | 64                             | 0.5  |

**Note:** For all axes and for ST\_POL = 0, the output data is positive only when compared to the self-test offset. The opposite holds true for the ST\_POL = 1 case.

 $Self\text{-}test \ offset(i) = \frac{ST\_OUTp(i) + ST\_OUTm(i)}{2}$ 

AN5311 Application note

2 X-Axis Y-Axis 1.5 Z-Axis 1 ST\_POL=0 Amplitude(g) 0.5 0 -0.5 -1 ST\_POL=1 -1.5 1.5 2 0.5 1 2.5 3 Time(s) Figure 1. Self-test response for X-axis

# 7 Output data plots during self-test sequence

At the beginning of the Figure 1 plot, the sensor is operating in low-power active mode with the device in an approximately horizontal position. Therefore, X- and Y-axis data are close to 0 g and Z-axis data is close to 1 g.

Then a self-test sequence is engaged for X-axis with positive polarity (first transition), and later on with negative polarity (second transition).

## **NXP Semiconductors**

# AN5311

#### FXLS8962AF self-test procedure



At the beginning of the Figure 2 plot, self-test is still running for X-axis with negative polarity.

Then self-test is changed to Y-axis with positive polarity (first transition), and later on with negative polarity (second transition).

**Note:** The signal chain is only processing the selected axis during self-test. Therefore, the output data registers content for the two others axes is frozen (preserved and not updated). It is not recommended to make use of output data from those unselected axes.

#### FXLS8962AF self-test procedure



At the beginning of the <u>Figure 3</u> plot, self-test is still running for Y-axis with negative polarity.

Then self-test is changed to Z-axis with positive polarity (first transition), and later on with negative polarity (second transition).

Finally, at the end of the plot, the sensor normal operation is restored (third transition, low-power active mode), and the XYZ data reflect the DUT horizontal position such as prior to the self-test sequence.

#### FXLS8962AF self-test procedure



# 8 Sensor Data Change Detection block validation through self-test

Besides basic verification of MEMS transducer and ASIC signal chain, the self-test feature can also be utilized to verify some of the embedded features of the sensor. This section describes how to verify the SDCD block in the ASIC through self-test.

### 8.1 SDCD block validation principle

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

It incorporates a flexible digital window comparator block useful for implementing several different interrupt generation functions. The circuit may be operated in either relative or absolute modes and features user-programmable debounce times, polarity detection and interrupt generation logic.

Since self-test response is an inertial event caused by an electrostatic actuation force applied to the proof mass, this event can be detected by the SDCD block as a motion event. The generation of a motion detection interrupt in response to self-test stimulus verifies proper operation of the SDCD block. It is also to be noted that, indirectly, the interrupt capabilities of the sensor are also being validated.

The device's response to a self-test stimulus on a specific axis and polarity (direction) is a DC signal that does not vary with any physical acceleration applied to the device. Thus, the device need not be static while executing self test.

When this response signal is used as an input to the SDCD block in absolute comparison mode against a defined threshold (as shown in <u>Figure 5</u>), this inertial event caused by

the self-test stimulus is detected as an Outside-of Thresholds (OT) event, when the magnitude of the response signal is greater than the threshold. A corresponding motion detection interrupt will also be triggered for the event.



### 8.2 Registers used in the SDCD block validation procedure

Apart from the registers configured for self test (<u>Section 4.1</u>), the following SDCD registers require configuration.

| Name          | Address | Access | Comment                                                                                                                                                                                                                              | Accessibility                                                                                        |
|---------------|---------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| SDCD_CONFIG1  | 2Fh     | R/W    | Sensor Data Change Detection<br>function configuration register 1<br>– Event latch enable and individual<br>axis enable bits for OT and WT<br>logic function participation.                                                          | Read: always<br>Write: standby<br>mode only                                                          |
| SDCD_CONFIG2  | 30h     | R/W    | Sensor Data Change Detection<br>function configuration register 2<br>– SDCD function enable, reference<br>values initialization and update<br>behavior, relative/absolute<br>operating mode selection,<br>debounce counter behavior. | Read: always<br>Write<br>(REF_UPD<br>bit): always<br>Write (all other<br>bits): standby<br>mode only |
| SDCD_LTHS_LSB | 33h     | R/W    | Sensor Data Change Detection<br>lower threshold value LSB -<br>sdcd_lths[7:0]                                                                                                                                                        | Read: always<br>Write: standby<br>mode only                                                          |
| SDCD_LTHS_MSB | 34h     | R/W    | Sensor Data Change Detection<br>lower threshold value MSB -<br>sdcd_lths[11:8].                                                                                                                                                      | Read: always<br>Write: standby<br>mode only                                                          |
| SDCD_UTHS_LSB | 35h     | R/W    | Sensor Data Change Detection<br>upper threshold value LSB -<br>sdcd_uths[7:0]                                                                                                                                                        | Read: always<br>Write: standby<br>mode only                                                          |
| SDCD_UTHS_MSB | 36h     | R/W    | Sensor Data Change Detection<br>upper threshold value MSB -<br>sdcd_uths[11:8]                                                                                                                                                       | Read: always<br>Write: standby<br>mode only                                                          |
| INT_EN        | 20h     | R/W    | Interrupt output enable register                                                                                                                                                                                                     | Read: always<br>Write: standby<br>mode only                                                          |

#### Table 19. SDCD registers requiring configuration

As these registers are thoroughly described in the data sheet, the following tables mainly summarize the bit fields relevant to the validation procedure.

#### 8.2.1 SDCD\_CONFIG1 - SDCD function configuration register 1 (address 2Fh)

| able 20. SDCD_CONFIGT - SDCD function configuration register 1 (address 2FII) bit anocation |        |        |         |         |         |             |             |             |  |
|---------------------------------------------------------------------------------------------|--------|--------|---------|---------|---------|-------------|-------------|-------------|--|
| Bit                                                                                         | 7      | 6      | 5       | 4       | 3       | 2           | 1           | 0           |  |
| Name                                                                                        | OT_ELE | WT_ELE | X_OT_EN | Y_OT_EN | Z_OT_EN | X_W<br>T_EN | Y_W<br>T_EN | Z_W<br>T_EN |  |
| Reset (BT_MODE = GND)                                                                       | 0      | 0      | 0       | 0       | 0       | 0           | 0           | 0           |  |
| Reset (BT_MODE = V <sub>DD</sub> )                                                          | 0      | 0      | 1       | 1       | 1       | 0           | 0           | 0           |  |
| Access                                                                                      | R/W    | R/W    | R/W     | R/W     | R/W     | R/W         | R/W         | R/W         |  |

Table 20. SDCD CONFIG1 - SDCD function configuration register 1 (address 2Fh) bit allocation

#### Table 21. SDCD\_CONFIG1 - SDCD function configuration register 1 (address 2Fh) bit description

| Bit | Name    | Description                                                                                                                                                                                                                                                          |
|-----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | X_OT_EN | <ul> <li>SDCD function X-axis outside-of-thresholds condition</li> <li>0: X-axis data or delta is not used in the outside of thresholds condition evaluation.</li> <li>1: X-axis data or delta is used in the outside of thresholds condition evaluation.</li> </ul> |
| 4   | Y_OT_EN | <ul> <li>SDCD function Y-axis outside-of-thresholds condition</li> <li>O: Y-axis data or delta is not used in the outside of thresholds condition evaluation.</li> <li>1: Y-axis data or delta is used in the outside of thresholds condition evaluation.</li> </ul> |
| 3   | Z_OT_EN | <ul> <li>SDCD function Z-axis outside-of-thresholds condition</li> <li>O: Y-axis data or delta is not used in the outside of thresholds condition evaluation.</li> <li>1: Y-axis data or delta is used in the outside of thresholds condition evaluation.</li> </ul> |

#### 8.2.2 SDCD\_CONFIG2 - SDCD function configuration register 2 (address 30h)

#### Table 22. SDCD\_CONFIG2 - SDCD function configuration register 2 (address 30h) bit allocation

| Bit                                | 7           | 6      | 5        | 4            | 3            | 2              | 1    | 0           |
|------------------------------------|-------------|--------|----------|--------------|--------------|----------------|------|-------------|
| Read                               | SDC<br>D_EN | REF_UF | PDM[1:0] | OT_D<br>BCTM | WT_D<br>BCTM | WT_LO<br>G_SEL | MODE | REF_<br>UPD |
| Reset (BT_MODE = GND)              | 0           | 0      | 0        | 0            | 0            | 0              | 0    | 0           |
| Reset (BT_MODE = V <sub>DD</sub> ) | 1           | 1      | 0        | 1            | 1            | 0              | 0    | 0           |
| Access                             | R/W         | R/W    | R/W      | R/W          | R/W          | R/W            | R/W  | R/W         |

AN5311 Application note

#### FXLS8962AF self-test procedure

| Bit    | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | SDCD_EN  | SDCD function<br>0 (default after a POR or soft reset event when BT_MODE = GND): SDCD<br>function is disabled. All clocks and power for the function are turned off.<br>1 (default after a POR or soft reset event when BT_MODE = V <sub>DD</sub> and<br>MOT_DET = 1): SDCD function is enabled. When this bit is set, the 12-<br>bit reference values ( <b>REF_X/Y/Z</b> ) are initialized per the settings made in<br>REF_UPDM[1:0].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 6 to 5 | REF_UPDM | <ul> <li>SDCD internal reference values update mode</li> <li>00: The function stores the first 12-bit X/Y/Z decimated and trimmed input data (OUT_X/Y/Z[n=0]) as the internal REF_X/Y/Z values after the function is enabled (SDCD_EN is set to 1). The REF_X/Y/Z values are updated with the current 12-bit X/Y/Z decimated input data (OUT_X/Y/Z[n]) at the time the SDCD_OT_EA flag transitions from False to True.</li> <li>01: The function stores the first decimated and trimmed X/Y/Z acceleration input data (OUT_X/Y/Z[n=0]) as the internal REF_X/Y/Z values when the SDCD function is enabled; the REF_X/Y/Z values are then held constant and never updated until the SDCD function is disabled and subsequently reenabled, or asynchronously when the REF_UPD bit is set by the host.</li> <li>10: The function updates the SDCD_REF_X/Y/Z values with the current decimated and trimmed X/Y/Z acceleration input data after the function evaluation. This allows for acceleration slope detection with Data(n) to Data(n–1) always used as the input to the window comparator.</li> <li>11: The function uses a fixed value of 0 for each of the SDCD_REF_X/Y/Z registers, making the function operate in absolute comparison mode.</li> </ul> |
| 4      | OT_DBCTM | <ul> <li>SDCD outside-of-threshold event debounce counter behavior</li> <li>0 (default): Debounce counter is decremented by 1 when the current outside of thresholds result for the enabled axes is false. In this mode, the debounce counter de-bounces the outside of thresholds event in both directions, meaning that once the event flag has been set (after SDCD_OT_DBCNT ODR periods with the condition true), the condition must also remain false for at least SDCD_OT_DBCNT + 1 consecutive ODR periods before the next event detection cycle can begin.</li> <li>1: Debounce counter is cleared whenever the current outside of thresholds result for the enabled axes is false.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

#### Table 23. SDCD\_CONFIG2 - SDCD function configuration register 2 (address 30h) bit description

### 8.2.3 SDCD\_LTHS\_LSB - SDCD lower threshold value register LSB (address 33h)

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

The scaling for this register is always the same as the selected FSR's sensitivity.

| Table 24. SDCD_LTHS_LSB - SDCD lower threshold value register LSB (address 33h) bit allocation |                |     |     |     |     |     |     |     |
|------------------------------------------------------------------------------------------------|----------------|-----|-----|-----|-----|-----|-----|-----|
| Bit                                                                                            | 7              | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name                                                                                           | SDCD_LTHS[7:0] |     |     |     |     |     |     |     |
| Reset (BT_MODE = GND)                                                                          | 0              | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Reset (BT_MODE = V <sub>DD</sub> )                                                             | 1              | 1   | 0   | 0   | 0   | 0   | 0   | 0   |
| Access                                                                                         | R/W            | R/W | R/W | R/W | R/W | R/W | R/W | R/W |

# Table 24. SDCD LTHS LSB - SDCD lower threshold value register LSB (address 33h) bit allocation

Application note

# 8.2.4 SDCD\_LTHS\_MSB - SDCD lower threshold value register MSB (address 34h)

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

The scaling for this register is always the same as the selected FSR's sensitivity.

| Table 25. ODOD_ETTIO_MOD - ODOD Tower threshold value register mod (address 541) bit anocation |     |     |     |     |                 |     |     |     |
|------------------------------------------------------------------------------------------------|-----|-----|-----|-----|-----------------|-----|-----|-----|
| Bit                                                                                            | 7   | 6   | 5   | 4   | 3               | 2   | 1   | 0   |
| Name                                                                                           |     |     | _   |     | SDCD_LTHS[11:8] |     |     |     |
| Reset (BT_MODE = GND)                                                                          | 0   | 0   | 0   | 0   | 0               | 0   | 0   | 0   |
| Reset (BT_MODE = V <sub>DD</sub> )                                                             | 0   | 0   | 0   | 0   | 1               | 1   | 1   | 1   |
| Access                                                                                         | R/W | R/W | R/W | R/W | R/W             | R/W | R/W | R/W |

#### Table 25. SDCD\_LTHS\_MSB - SDCD lower threshold value register MSB (address 34h) bit allocation

#### 8.2.5 SDCD\_UTHS\_LSB - SDCD upper threshold value LSB (address 35h)

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

The scaling for this register is the same as the selected FSR sensitivity.

#### Table 26. SDCD\_UTHS\_LSB - SDCD upper threshold value LSB (address 35h) bit allocation

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

#### 8.2.6 SDCD\_UTHS\_MSB - SDCD upper threshold value MSB (address 36h)

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

The scaling for this register is always the same as the selected FSR's sensitivity.

| Table 27. Obob_0110_mob - Obob upper timeshold value mob (address 500) bit anocation |     |     |     |     |                 |     |     |     |
|--------------------------------------------------------------------------------------|-----|-----|-----|-----|-----------------|-----|-----|-----|
| Bit                                                                                  | 7   | 6   | 5   | 4   | 3               | 2   | 1   | 0   |
| Name                                                                                 |     | _   | _   |     | SDCD_UTHS[11:8] |     |     |     |
| Reset (BT_MODE = GND)                                                                | 0   | 0   | 0   | 0   | 0               | 0   | 0   | 0   |
| Reset (BT_MODE = V <sub>DD</sub> )                                                   | 0   | 0   | 0   | 0   | 0               | 0   | 0   | 0   |
| Access                                                                               | R/W | R/W | R/W | R/W | R/W             | R/W | R/W | R/W |

#### Table 27. SDCD UTHS MSB - SDCD upper threshold value MSB (address 36h) bit allocation

AN5311 Application note

#### 8.2.7 INT\_EN - interrupt output enable register (address 20h)

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

| Bit                                | 7           | 6      | 5              | 4              | 3             | 2       | 1            | 0               |
|------------------------------------|-------------|--------|----------------|----------------|---------------|---------|--------------|-----------------|
| Name                               | DRD<br>Y_EN | BUF_EN | SDCD_<br>OT_EN | SDCD_<br>WT_EN | ORIEN<br>T_EN | ASLP_EN | BOOT<br>_DIS | WAKE_<br>OUT_EN |
| Reset (BT_MODE = GND)              | 0           | 0      | 0              | 0              | 0             | 0       | 0            | 0               |
| Reset (BT_MODE = V <sub>DD</sub> ) | 0           | 0      | 1              | 0              | 0             | 0       | 0            | 0               |
| Access                             | R/W         | R/W    | R/W            | R/W            | R/W           | R/W     | R/W          | R/W             |

 Table 28. INT\_EN - interrupt output enable register (address 20h) bit allocation

#### Table 29. INT\_EN - interrupt output enable register (address 20h) bit description

| Bit | Name       | Description                                                                                                                                                                                                                                     |
|-----|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | DRDY_EN    | Data ready interrupt output enable<br><b>0</b> — Interrupt is disabled (reset value)<br><b>1</b> — Interrupt is enabled and signaled on either the INT1 or INT2 output pins as<br>configured by the setting made in INT_PIN_SEL                 |
| 5   | SDCD_OT_EN | <ul> <li>SDCD outside of thresholds interrupt output enable</li> <li>0 — Interrupt is disabled (reset value)</li> <li>1 — Interrupt is routed to either the INT1 or INT2 output pin as configured by the setting made in INT_PIN_SEL</li> </ul> |

### 8.3 Self-test sequence for SDCD block validation (BT\_MODE = V<sub>DD</sub>)

#### SDCD block validation phase per axis

Complete the following procedure for each axis (i = X, Y, Z).

The steps below refer to the serial commands as shown in Figure 6 and Figure 7.

- 1. Enter Standby mode by setting **SENS\_CONFIG1**[ACTIVE] to 0 (address 15h).
- 2. Configure registers.
  - a. Set the Self-test measurement phase decimation factor by setting **SELF\_TEST\_CONFIG2[**ST\_DEC] to 05h (address 38h). In this example, Self-test ODR is set to 100 Hz. Note that when BT\_MODE pin is connected to VDD, the data ready interrupt is signalled for T<sub>PULSE-MOT</sub> seconds (5 ms typ) and it clears itself automatically. Hence maximum recommended ODR when BT\_MODE pin is connected to VDD is 100 Hz.
  - b. Enable data ready interrupt by setting INT\_EN[DRDY\_EN] bit to 1. Interrupt is routed to INT1 line. INT2 line cannot be used, because only BOOT interrupt can be routed to INT2 line when BT\_MODE = V<sub>DD</sub>.
  - c. Write **SENS\_CONFIG1** register (address 15h) with the following content:
    - i. Self-test enabled on the desired axis by setting ST\_AXIS\_SEL[1:0] to 0b01 for X-axis, 0b10 for Y-axis or 0b11 for Z-axis
    - ii. Self-test positive polarity selected by setting ST\_POL to 0

- iii. Select FSR measurement range. In this example ±16 *g* range is selected by setting FSR[1:0] to 0b11
- iv. Active mode selected by setting ACTIVE to 1 Wait for DRDY interrupt.
- 3. Upon reception of the first data ready interrupt, put device in Standby mode by setting **SENS\_CONFIG1[**ACTIVE] to 0 (address 15h). Read the acceleration data in the output registers corresponding to the selected axis (X data at register addresses 04h and 05h, Y data at register addresses 06h and 07h, Z data at register addresses 08h and 09h). Store the output data as a temporary variable, such as ST\_OUTp(i).
- 4. Write SENS\_CONFIG1 register (address 15h) with the following content:
  - a. Self-test enabled on the desired axis by setting ST\_AXIS\_SEL[1:0] to 0b01 for Xaxis, 0b10 for Y-axis or 0b11 for Z-axis
  - b. Self-test negative polarity selected by setting ST\_POL to 1
  - c. Active mode selected by setting ACTIVE to 1

Wait for DRDY interrupt.

- 5. Upon reception of the first data ready interrupt, put device in Standby mode by setting **SENS\_CONFIG1[**ACTIVE] to 0 (address 15h). Read the acceleration data in the output registers corresponding to the selected axis (X data at register addresses 04h and 05h, Y data at register addresses 06h and 07h, Z data at register addresses 08h and 09h). Store the output data as a temporary variable, such as ST\_OUTm(i).
- 6. Measure self-test output change, self-test offset and configure registers.
  - a. Calculate Self-Test output change (STOC). If STOC > 'W' LSB, the device passed self-test. The value of 'W' is based on the FSR range and axis under test (X or Y or Z). See <u>Table 30</u>.
  - b. Calculate Self-Test Offset in LSBs (counts).
     Set SDCD thresholds based on Self-test Offset Value.
     SDCD Upper Threshold = Self-test Offset + 'W' LSBs.
     SDCD Lower Threshold = Self-test Offset 'W' LSBs.
  - c. Write the calculated threshold values into the appropriate registers SDCD\_LTHS\_LSB (33h), SDCD\_LTHS\_MSB (34h), SDCD\_UTHS\_LSB(35h), SDCD\_UTHS\_MSB (36h).
  - d. Write SDCD\_CONFIG1 register (address 2Fh) with the following content:
    - i. Enable SDCD function for OT event detection- X\_OT\_EN for X-axis, Y\_OT\_EN for Y-axis, Z\_OT\_EN for z-axis. Enable OT event only for the selected axis and disable for the other two axes.
  - e. Write SDCD\_CONFIG2 register (address 30h) with the following content:
    - i. Enable SDCD function in absolute mode by setting SDCD\_EN bit to 1 and REF\_UPDM[1:0] = 0b11.
    - ii. Set OT debounce counter behavior to clear by setting OT\_DBCTM bit to 1.
  - f. Disable data ready interrupt and enable OT interrupt by setting SDCD\_OT\_EN bit to 1 and DRDY\_EN bit to 0 in INT\_EN (20h) register. Let SDCD\_OT interrupt be routed to INT1 by default. INT2 line cannot be used, because only BOOT interrupt can be routed to INT2 line under BT\_MODE = V<sub>DD</sub>.
  - g. Write **SENS\_CONFIG1** register (address 15h) with the following content:
    - i. Self-test enabled on the desired axis by setting ST\_AXIS\_SEL[1:0] to 0b01 for X-axis, 0b10 for Y-axis or 0b11 for Z-axis
    - ii. Self-test positive polarity selected by setting ST\_POL to 0
    - iii. Active mode selected by setting ACTIVE to 1

Wait for motion detection interrupt. Self-test stimulus should cause an OT event and motion detection interrupt should be obtained on INT1.

- 7. Upon reception of motion detection interrupt, put device in Standby mode by setting **SENS\_CONFIG1** [ACTIVE] to 0 (address 15h).
- 8. Write SENS\_CONFIG1 register (address 15h) with the following content:
  - a. Self-test enabled on the desired axis by setting ST\_AXIS\_SEL[1:0] to 0b01 for Xaxis, 0b10 for Y-axis or 0b11 for Z-axis
  - b. Self-test negative polarity selected by setting ST\_POL to 1
  - c. Active mode selected by setting ACTIVE to 1
  - Wait for motion detection interrupt.
- 9. Upon reception of motion detection interrupt, put device in Standby mode by setting **SENS\_CONFIG1** [ACTIVE] to 0 (address 15h).
- 10.Disable self-test (ST\_AXIS\_SEL = 0b00). Place device back in Active mode by setting **SENS\_CONFIG1[**ACTIVE] to 1 (address 15h).

 Table 30.
 Self-test output change limits

| FSR range (axes)     | Value of 'W' (LSBs) |
|----------------------|---------------------|
| ±4 g mode (XY axes)  | 128                 |
| ±4 g mode (Z axes)   | 64                  |
| ±8 g mode (XY axes)  | 64                  |
| ±8 g mode (Z axes)   | 32                  |
| ±16 g mode (XY axes) | 32                  |
| ±16 g mode (Z axes)  | 16                  |



#### FXLS8962AF self-test procedure



Figure 7. Scope output for INT1/MOT\_DET line (BT\_MODE = V<sub>DD</sub>)

In BT\_MODE = V<sub>DD</sub>, DRDY interrupt and motion detection interrupt pulse width = 5 ms (T<sub>PULSE-MOT</sub> (typ)). The current interrupt pulse will be terminated when the device undergoes Active-Standby-Active transition before the pulse completion and thus may not span for entire 5 ms (T<sub>PULSE-MOT</sub> (typ)).

For example, command 5 in <u>Figure 6</u> puts the device in Active mode. The corresponding DRDY interrupt is terminated immediately.

#### 8.4 Self-test sequence for SDCD block validation (BT\_MODE = GND)

#### SDCD block validation phase per axis

Complete the following procedure for each axis (i = X, Y, Z).

The steps below refer to the serial commands as shown in Figure 8 and Figure 9.

- 1. Enter Standby mode by setting SENS\_CONFIG1[ACTIVE] to 0 (address 15h).
- 2. Configure registers.
  - a. Set the Self-test measurement phase decimation factor by setting SELF\_TEST\_CONFIG2[ST\_DEC] to 04h (address 38h). In this example, Self-test ODR is set to 200 Hz.
  - b. Enable data ready interrupt by setting **INT\_EN**[DRDY\_EN] bit to 1. Interrupt is routed to INT1 line. INT2 line can also be used.
  - c. Enable pulse generation option for DRDY event by setting **SENS\_CONFIG4**[DRDY\_PUL] bit to 1.
  - d. Write SENS\_CONFIG1 register (address 15h) with the following content

- i. Self-test enabled on the desired axis by setting ST\_AXIS\_SEL[1:0] to 0b01 for X-axis, 0b10 for Y-axis or 0b11 for Z-axis
- ii. Self-test positive polarity selected by setting ST\_POL to 0
- iii. Select FSR measurement range. In this example ±16 *g* range is selected by setting FSR[1:0] to 0b11
- iv. Active mode selected by setting ACTIVE to 1 Wait for DRDY interrupt.
- Upon reception of the first data ready interrupt, no action is required. Discard the data ready interrupt (no need to read the data -ignore this sample) (see <u>Section 4.1.6</u>). Since the pulse generation option is enabled for data ready interrupt (through DRDY\_PUL bit), the data ready interrupt clears itself after 32 μs.
- 4. Upon reception of second data ready interrupt, put device in Standby mode by setting **SENS\_CONFIG1[**ACTIVE] to 0 (address 15h). Read the acceleration data in the output registers corresponding to the selected axis (X data at register addresses 04h and 05h, Y data at register addresses 06h and 07h, Z data at register addresses 08h and 09h). Store the output data as a temporary variable, such as ST\_OUTp(i).
- 5. Write SENS\_CONFIG1 register (address 15h) with the following content:
  - a. Self-test enabled on the desired axis by setting ST\_AXIS\_SEL[1:0] to 0b01 for Xaxis, 0b10 for Y-axis or 0b11 for Z-axis
  - b. Self-test negative polarity selected by setting ST\_POL to 1
  - c. Active mode selected by setting ACTIVE to 1

Wait for DRDY interrupt.

- Upon reception of the first data ready interrupt, no action is required. Discard the data ready interrupt (no need to read the data -ignore this sample) (see <u>Section 4.1.6</u>). Since the pulse generation option is enabled for data ready interrupt (through DRDY\_PUL bit), the data ready interrupt clears itself after 32 μs.
- 7. Upon reception of second data ready interrupt, put device in Standby mode by setting **SENS\_CONFIG1[**ACTIVE] to 0 (address 15h). Read the acceleration data in the output registers corresponding to the selected axis (X data at register addresses 04h and 05h, Y data at register addresses 06h and 07h, Z data at register addresses 08h and 09h). Store the output data as a temporary variable, such as ST\_OUTm(i).
- 8. Measure self-test output change, self-test offset and configure registers.
  - a. Calculate Self-Test output change (STOC). If STOC > 'W' LSB, the device passed self-test. The value of 'W' is based on the FSR range and axis under test (X or Y or Z). See <u>Table 30</u>.
  - b. Calculate Self-test Offset in LSBs (counts).
     Set SDCD thresholds based on Self-test Offset Value.
     SDCD Upper Threshold = Self-test Offset + 'W' LSBs.
     SDCD Lower Threshold = Self-test Offset 'W' LSBs.
  - c. Write the calculated threshold values into the appropriate registers SDCD\_LTHS\_LSB (33h), SDCD\_LTHS\_MSB (34h), SDCD\_UTHS\_LSB(35h), SDCD\_UTHS\_MSB (36h).
  - d. Write SDCD\_CONFIG1 register (address 2Fh) with the following content:
    - Enable SDCD function for Outside-of-thresholds event detection- X\_OT\_EN for X-axis, Y\_OT\_EN for Y-axis, Z\_OT\_EN for Z-axis. Enable OT event only for the selected axis & disable for the other two axes.
  - e. Write SDCD\_CONFIG2 register (address 30h) with the following content:
    - i. Enable SDCD function in absolute mode by setting SDCD\_EN bit to 1 and REF\_UPDM[1:0] = 0b11.

- ii. Set Outside-of-thresholds debounce counter behavior to clear by setting OT\_DBCTM bit to 1.
- f. Disable data ready interrupt & enable OT interrupt by setting SDCD\_OT\_EN bit to 1 & DRDY\_EN bit to 0 in INT\_EN (20h) register. Let SDCD\_OT interrupt be routed to INT1. INT2 line can also be used.
- g. Write SENS\_CONFIG1 register (address 15h) with the following content:
  - i. Self-test enabled on the desired axis by setting ST\_AXIS\_SEL[1:0] to 0b01 for X-axis, 0b10 for Y-axis or 0b11 for Z-axis
  - ii. Self-test positive polarity selected by setting ST\_POL to 0
  - iii. Active mode selected by setting ACTIVE to 1

Wait for motion detection interrupt. Self-test stimulus should cause an OT event and motion detection interrupt should be obtained on INT1. Note that since the first sample (immediately after self-test stimulus) does not reflect a truly settled response, the motion detection interrupt may not be observed until the second sample.

- 9. Upon reception of motion detection interrupt, put device in Standby mode by setting **SENS\_CONFIG1** [ACTIVE] to 0 (address 15h).
- 10.Write SENS\_CONFIG1 register (address 15h) with the following content:
  - a. Self-test enabled on the desired axis by setting ST\_AXIS\_SEL[1:0] to 0b01 for Xaxis, 0b10 for Y-axis or 0b11 for Z-axis
  - b. Self-test negative polarity selected by setting ST\_POL to 1
  - c. Active mode selected by setting ACTIVE to 1

Wait for motion detection interrupt. Note that since the first sample (immediately after self-test stimulus) does not reflect a truly settled response, the motion detection interrupt may not be observed until the second sample.

- 11.Upon reception of motion detection interrupt, put device in Standby mode by setting **SENS\_CONFIG1** [ACTIVE] to 0 (address 15h).
- 12.Disable Self-test (ST\_AXIS\_SEL = 0b00). Place device back in Active mode by setting **SENS\_CONFIG1[**ACTIVE] to 1 (address 15h).





### 8.5 Example implementation

Following is a sample implementation of the validation sequence discussed in <u>Section 8.3</u> (with BT\_MODE =  $V_{DD}$ ). X-Axis is considered here. Full scale range is set to ±16 g. Self-test ODR is set to 100 Hz.

All values shown in the sample calculation are in counts (LSBs)

#### Step 1

Measure self-test response for both positive and negative stimulus.

#### Table 31. Self-test measurements for X-axis

| Self-test polarity | X (LSBs) | Y (LSBs) | Z (LSBs) |
|--------------------|----------|----------|----------|
| ST_POL = 0         | 132      | -6       | 125      |
| ST_POL = 1         | -98      | 6        | 125      |

#### Step 2

Calculate Self-test Offset

Self-test Offset = (132 + (-98)) / 2

= 17

#### Self-test Offset = 17 LSBs

Calculate Self-test output change (STOC)

FXLS8962AF self-test procedure

STOC = (132 - (-98)) / 2 = 115 **STOC = 115 LSBs Self-test has passed. Step 3** Set SDCD thresholds SDCD\_UTHS = Self-test Offset + 'W' LSBs (See <u>Table 30</u> for value of 'W')

= 17 + 32

= 49 LSBs

#### SDCD\_UTHS = 49 LSBs

SDCD\_LTHS = Self-test Offset - 'W' LSBs (See Table 30 for value of 'W')

= 17 – 32

= -15 LSBs

SDCD\_LTHS = -15 LSBs

Configure other SDCD parameters as discussed previously in Section 8.3

#### Step 4

After SDCD configuration, run self-test with ST\_POL = 0. Motion detection interrupt should be observed.

Step 5

Run self-test with ST\_POL = 1. Motion detection interrupt should be observed.

This completes SDCD block validation through self-test.

# 9 Summary and conclusion

The FXLS8962AF self-test feature provides a first level diagnostic for device functionality. An automated sequence can be performed quickly by the host MCU to ensure that sensor MEMS and ASIC signal chain are operating properly. The outcome of the sequence can be compared to sensor self-test specification as a pass/fail criteria or, even better, to part-specific self-test data baseline captured during end product manufacturing and stored in the host NVM for future reference in the field. Apart from basic signal chain verification, the self-test feature can also be utilized to validate some of the embedded functional blocks in the sensor such as the Sensor Data Change Detection Block.

# **10 Revision history**

| Rev | Date     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5.0 | 20171020 | Significant changes within document.<br>• Updated Section 1<br>• Added Section 2<br>• Updated Section 3<br>• Updated Section 4<br>- Updated Section 4.1.1<br>- Updated Section 4.1.2<br>- Added Section 4.1.5<br>- Added Section 4.1.6<br>• Updated Section 5<br>• Updated Section 6<br>• Updated Section 7<br>• Updated Section 8.1<br>- Updated Section 8.1<br>- Updated Section 8.2<br>- Updated Section 8.3<br>- Updated Section 8.4<br>- Updated Section 9 |
| 4.0 | 20170117 | <ul> <li>Updated <u>Section 4</u>.</li> <li>Added <u>Section 4.1.6</u></li> <li>Updated <u>Section 6</u></li> <li>Updated <u>Section 7</u></li> <li>Added <u>Section 8 "Sensor Data Change Detection block validation through self-test"</u></li> </ul>                                                                                                                                                                                                         |
| 3.0 | 20161101 | <ul> <li>Added <u>Table 18</u> for DUT3 self-test measurement results</li> <li>Updated <u>Figure 1</u></li> <li>Updated <u>Figure 2</u></li> <li>Updated <u>Figure 3</u></li> <li>Updated <u>Figure 4</u></li> </ul>                                                                                                                                                                                                                                            |
| 2.0 | 20161014 | <ul> <li>Updated <u>Section 4.1</u>: description, SELF_TEST_CONFIG1 (added)</li> <li>Added <u>Section 4.1.3</u></li> <li>Added <u>Section 4.1.4</u></li> <li>Updated <u>Section 5</u>: sequence</li> <li>Updated <u>Section 6</u>: description</li> </ul>                                                                                                                                                                                                       |
| 1.0 | 20160718 | Initial release                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

# AN5311 FXLS8962AF self-test procedure

# **11 Legal information**

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

# 11.2 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 NXF Semiconductors.

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

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

Applications — Applications that are described herein for any of these products are for illustrative purposes only. NXP Semiconductors makes no representation or warranty that such applications will be suitable for the specified use without further testing or modification. Customers are responsible for the design and operation of their applications and products using NXP Semiconductors products, and NXP Semiconductors accepts no liability for any assistance with applications or customer product design. It is customer's sole responsibility to determine whether the NXP Semiconductors products planned, as well as for the planned application and use of customer's third party customer(s). Customers should provide appropriate design and operating safeguards to minimize the risks associated with their applications and products. NXP Semiconductors does not accept any liability related to any default, damage, costs or problem which is based on any weakness or default in the customer's applications or products, or

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

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

Terms and conditions of commercial sale — NXP Semiconductors products are sold subject to the general terms and conditions of commercial sale, as published at 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.

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

Non-automotive qualified products - Unless this data sheet expressly states that this specific NXP Semiconductors product is automotive qualified, the product is not suitable for automotive use. It is neither qualified nor tested in accordance with automotive testing or application requirements. NXP Semiconductors accepts no liability for inclusion and/or use of nonautomotive qualified products in automotive equipment or applications. In the event that customer uses the product for design-in and use in automotive applications to automotive specifications and standards, customer (a) shall use the product without NXP Semiconductors' warranty of the product for such automotive applications, use and specifications, and (b) whenever customer uses the product for automotive applications beyond NXP Semiconductors' specifications such use shall be solely at customer's own risk, and (c) customer fully indemnifies NXP Semiconductors for any liability, damages or failed product claims resulting from customer design and use of the product for automotive applications beyond NXP Semiconductors' standard warranty and NXP Semiconductors' product specifications

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

### 11.3 Trademarks

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

NXP — is a trademark of NXP B.V.

# Contents

| 1     | Introduction                                                 |     |
|-------|--------------------------------------------------------------|-----|
| 2     | Applicable devices                                           |     |
| 3     | Accelerometer and self-test principle                        |     |
| 4     | Self-test procedure                                          |     |
| 4.1   | Register used in the self-test procedure                     | 4   |
| 4.1.1 | SENS_CONFIG1 - sensor configuration                          |     |
|       | register 1 (address 15h)                                     | 4   |
| 4.1.2 | SENS_CONFIG4 - sensor configuration                          |     |
|       | register 4 (address 18h)                                     | 5   |
| 4.1.3 | SELF_TEST_CONFIG1 - self-test                                |     |
|       | configuration register 1 (address 37h)                       | 6   |
| 4.1.4 | SELF_TEST_CONFIG2 - self-test                                |     |
|       | configuration register 2 (address 38h)                       | 7   |
| 4.1.5 | INT_EN - interrupt output enable register                    |     |
|       | (address 20h)                                                |     |
| 4.1.6 | Output data validity                                         | 8   |
| 5     | Self-test sequence per axis                                  |     |
| 6     | Self-test procedure results                                  |     |
| 7     | Output data plots during self-test sequence                  | .12 |
| 8     | Sensor Data Change Detection block                           |     |
|       | validation through self-test                                 | 15  |
| 8.1   | SDCD block validation principle                              | .15 |
| 8.2   | Registers used in the SDCD block validation                  |     |
|       | procedure                                                    | .16 |
| 8.2.1 | SDCD CONFIG1 - SDCD function                                 |     |
|       | configuration register 1 (address 2Fh)                       | .17 |
| 8.2.2 | SDCD CONFIG2 - SDCD function                                 |     |
|       | configuration register 2 (address 30h)                       | 17  |
| 8.2.3 | SDCD LTHS LSB - SDCD lower threshold                         |     |
|       | value register LSB (address 33h)                             | 18  |
| 8.2.4 | SDCD LTHS MSB - SDCD lower threshold                         |     |
|       | value register MSB (address 34h)                             | 19  |
| 8.2.5 | SDCD UTHS LSB - SDCD upper threshold                         |     |
|       | value LSB (address 35h)                                      | .19 |
| 8.2.6 | SDCD_UTHS_MSB - SDCD upper threshold                         |     |
|       | value MSB (address 36h)                                      | .19 |
| 8.2.7 | INT_EN - interrupt output enable register                    |     |
|       | (address 20h)                                                | 20  |
| 8.3   | Self-test sequence for SDCD block                            |     |
| 0.0   | Self-test sequence for SDCD block validation (BT_MODE = VDD) | 20  |
| 8.4   | Self-test sequence for SDCD block                            |     |
| ~. '  | validation (BT_MODE = GND)                                   | 23  |
| 8.5   | Example implementation                                       |     |
| 9.0   | Summary and conclusion                                       |     |
| 10    | Revision history                                             |     |
| 10    | Legal information                                            |     |
|       |                                                              | 23  |

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

#### © NXP B.V. 2017.

#### All rights reserved.

For more information, please visit: http://www.nxp.com For sales office addresses, please send an email to: salesaddresses@nxp.com

Date of release: 20 October 2017 Document identifier: AN5311