# LIS2DS12: always-on 3D accelerometer ### Introduction This document is intended to provide usage information and application hints related to ST's LIS2DS12 motion sensor. The LIS2DS12 is a 3D digital accelerometer system-in-package with a digital $I^2C/SPI$ serial interface standard output, performing at 150 $\mu$ A in high-resolution mode and no more than 80 $\mu$ A in low-power mode. Thanks to the ultra-low noise performance of the accelerometer, the device combines always-on low-power features with superior sensing precision for an optimal motion experience for the consumer. Furthermore, the accelerometer features smart sleep-to-wakeup (activity) and return-to-sleep (inactivity) functions that allow advanced power saving. The device has a dynamic user-selectable full-scale acceleration range of $\pm 2/\pm 4/\pm 8/\pm 16~g$ and is capable of measuring accelerations with output data rates from 1 Hz to 6400 Hz. The LIS2DS12 can be configured to generate interrupt signals by using hardware recognition of free-fall events, 6D orientation, tap and double-tap sensing, activity or inactivity, and wake-up events The LIS2DS12 can be configured to work as a sensor hub. The LIS2DS12 is compatible with the requirements of the leading OSs, offering real and virtual sensors. It has been designed to implement in hardware significant motion, tilt, and pedometer functions. The LIS2DS12 has an integrated 256-level first-in, first-out (FIFO) buffer allowing the user to store data in order to limit intervention by the host processor. The LIS2DS12 is available in a small thin plastic land grid array package (LGA) and it is guaranteed to operate over an extended temperature range from -40 °C to +85 °C. The ultra-small size and weight of the SMD package make it an ideal choice for handheld portable applications such as smartphones, IoT connected devices, and wearables or any other application where reduced package size and weight are required. # 1 Pin description Figure 1. Pin connections - 1. When the sensor hub is used, this pin is the I<sup>2</sup>C data master line (MSDA). - 2. When the sensor hub is used, this pin is the I<sup>2</sup>C clock master line (MSCL). Table 1. Pin description | Pin# | Name | Function | | | | | |-------------------|--------|-------------------------------------------------------------------|--|--|--|--| | 1 | SCL | I <sup>2</sup> C serial clock (SCL) | | | | | | ' | SPC | SPI serial port clock (SPC) | | | | | | | | SPI enable | | | | | | 2(1) | CS | I <sup>2</sup> C/SPI mode selection | | | | | | 2(') | 03 | (1: SPI idle mode / I <sup>2</sup> C communication enabled; | | | | | | | | 0: SPI communication mode / I <sup>2</sup> C disabled) | | | | | | 3(2) | SDO | SPI serial data output (SDO) | | | | | | 3(-) | SA0 | I <sup>2</sup> C less significant bit of the device address (SA0) | | | | | | | SDA | I <sup>2</sup> C serial data (SDA) | | | | | | 4 | SDI | SPI serial data input (SDI) | | | | | | | SDO | 3-wire interface serial data output (SDO) | | | | | | 5 | NC | Internally not connected. Can be tied to Vdd, Vdd_IO or GND. | | | | | | 6 | GND | 0 V supply | | | | | | 7 | RES | Connect to GND | | | | | | 8 | GND | 0 V supply | | | | | | 9 | Vdd | Power supply | | | | | | 10 | Vdd_IO | Power supply for I/O pins | | | | | | 11 <sup>(3)</sup> | INT2 | Interrupt pin 2 | | | | | | 12 | INT1 | Interrupt pin 1 | | | | | - 1. CS has an active pull-up and can be left unconnected. - 2. When the sensor hub is used, this pin is the I<sup>2</sup>C data master line (MSDA), is internally set to 0 and can be internally pulled up through the TUD\_EN bit of FUNC\_CTRL (3Fh). - 3. When the sensor hub is used, this pin is the I<sup>2</sup>C clock master line (MSCL) and can be internally pulled up through the TUD\_EN bit of FUNC\_CTRL (3Fh). AN4748 - Rev 5 page 2/56 # Registers Table 2. Registers | Register name | Address | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |----------------|---------|----------------------|----------------|------------------|-----------------------|--------------------|-------------------|-----------------|------------------| | SENSORHUB1_REG | 06h | SHub1_7 | SHub1_6 | SHub1_5 | SHub1_4 | SHub1_3 | SHub1_2 | SHub1_1 | SHub1_0 | | SENSORHUB2_REG | 07h | SHub2_7 | SHub2_6 | SHub2_5 | SHub2_4 | SHub2_3 | SHub2_2 | SHub2_1 | SHub2_0 | | SENSORHUB3_REG | 08h | SHub3_7 | SHub3_6 | SHub3_5 | SHub3_4 | SHub3_3 | SHub3_2 | SHub3_1 | SHub3_0 | | SENSORHUB4_REG | 09h | SHub4_7 | SHub4_6 | SHub4_5 | SHub4_4 | SHub4_3 | SHub4_2 | SHub4_1 | SHub4_0 | | SENSORHUB5_REG | 0Ah | SHub5_7 | SHub5_6 | SHub5_5 | SHub5_4 | SHub5_3 | SHub5_2 | SHub5_1 | SHub5_0 | | SENSORHUB6_REG | 0Bh | SHub6_7 | SHub6_6 | SHub6_5 | SHub6_4 | SHub6_3 | SHub6_2 | SHub6_1 | SHub6_0 | | Module_8bit | 0Ch | MODULE_7 | MODULE_6 | MODULE_5 | MODULE_4 | MODULE_3 | MODULE_2 | MODULE_1 | MODULE_0 | | WHO_AM_I | 0Fh | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | | CTRL1 | 20h | ODR3 | ODR2 | ODR1 | ODR0 | FS1 | FS0 | HF_ODR | BDU | | CTRL2 | 21h | воот | SOFT_<br>RESET | 0 | FUNC_CFG_E<br>N | FDS_SLOPE | IF_ADD_INC | I2C_<br>DISABLE | SIM | | CTRL3 | 22h | ST2 | ST1 | TAP_X_EN | TAP_Y_EN | TAP_Z_EN | LIR | H_LACTIVE | PP_OD | | CTRL4 | 23h | INT1_MASTER<br>_DRDY | INT1_S_TAP | INT1_WU | INT1_FF | INT1_TAP | INT1_6D | INT1_FTH | INT1_DRD | | CTRL5 | 24h | DRDY<br>_PULSED | INT2_BOOT | INT2_<br>ON_INT1 | INT2_TILT | INT2_<br>SIG_MOT | INT2_<br>STEP_DET | INT2_FTH | INT2_DRD | | FIFO_CTRL | 25h | FMODE2 | FMODE1 | FMODE0 | INT_STEP_<br>COUNT_OV | MODULE<br>_TO_FIFO | 0 | 0 | IF_CS_PU<br>_DIS | | OUT_T | 26h | Temp7 | Temp6 | Temp5 | Temp4 | Temp3 | Temp2 | Temp1 | Temp0 | | STATUS | 27h | FIFO_THS | WU_IA | SLEEP<br>_STATE | DOUBLE _TAP | SINGLE<br>_TAP | 6D_IA | FF_IA | DRDY | | OUTX_L | 28h | XL_7 | XL_6 | XL_5 | XL_4 | XL_3 | XL_2 | 0 | 0 | | OUTX_H | 29h | XH_7 | XH_6 | XH_5 | XH_4 | XH_3 | XH_2 | XH_1 | XH_0 | | OUTY_L | 2Ah | YL_7 | YL_6 | YL_5 | YL_4 | YL_3 | YL_2 | 0 | 0 | | H_YTUC | 2Bh | YH_7 | YH_6 | YH_5 | YH_4 | YH_3 | YH_2 | YH_1 | YH_0 | | OUTZ_L | 2Ch | ZL_7 | ZL_6 | ZL_5 | ZL_4 | ZL_3 | ZL_2 | 0 | 0 | | OUTZ_H | 2Dh | ZH_7 | ZH_6 | ZH_5 | ZH_4 | ZH_3 | ZH_2 | ZH_1 | ZH_0 | | FIFO_THS | 2Eh | FTH7 | FTH6 | FTH5 | FTH4 | FTH3 | FTH2 | FTH1 | FTH0 | | Register name | Address | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |-------------------------|---------|---------------------------|----------|-----------------|--------------------|-----------------|----------------|------------------|----------------------| | FIFO_SRC | 2Fh | FTH | FIFO_OVR | DIFF8 | 0 | 0 | 0 | 0 | 0 | | FIFO_SAMPLES | 30h | DIFF7 | DIFF6 | DIFF5 | DIFF4 | DIFF3 | DIFF2 | DIFF1 | DIFF0 | | TAP_6D_THS | 31h | 4D_EN | 6D_THS1 | 6D_THS0 | TAP_THS4 | TAP_THS3 | TAP_THS2 | TAP_THS1 | TAP_THS0 | | INT_DUR | 32h | LAT3 | LAT2 | LAT1 | LAT0 | QUIET1 | QUIET0 | SHOCK1 | SHOCK0 | | WAKE_UP_THS | 33h | SINGLE_<br>DOUBLE_<br>TAP | SLEEP_ON | WU_THS5 | WU_THS4 | WU_THS3 | WU_THS2 | WU_THS1 | WU_THS0 | | WAKE_UP_DUR | 34h | FF_DUR5 | WU_DUR1 | WU_DUR0 | INT1_FSS7 | SLEEP_<br>DUR3 | SLEEP_<br>DUR2 | SLEEP_<br>DUR1 | SLEEP_<br>DUR0 | | FREE_FALL | 35h | FF_DUR4 | FF_DUR3 | FF_DUR2 | FF_DUR1 | FF_DUR0 | FF_THS2 | FF_THS1 | FF_THS0 | | STATUS_DUP | 36h | OVR | WU_IA | SLEEP<br>_STATE | DOUBLE _TAP | SINGLE_<br>TAP | 6D_IA | FF_IA | DRDY | | WAKE_UP_SRC | 37h | 0 | 0 | FF_IA | SLEEP_<br>STATE_IA | WU_IA | x_wu | Y_WU | Z_WU | | TAP_SRC | 38h | 0 | TAP_IA | SINGLE<br>_TAP | DOUBLE _TAP | TAP_SIGN | X_TAP | Y_TAP | Z_TAP | | 6D_SRC | 39h | 0 | 6D_IA | ZH | ZL | YH | YL | XH | XL | | STEP_<br>COUNTER_MINTHS | 3Ah | RST_NSTEP | PEDO4g | SC_MTHS5 | SC_MTHS4 | SC_MTHS3 | SC_MTHS2 | SC_MTHS1 | SC_MTHS0 | | STEP_<br>COUNTER_L | 3Bh | nSTEP_L7 | nSTEP_L6 | nSTEP_L5 | nSTEP_L4 | nSTEP_L3 | nSTEP_L2 | nSTEP_L1 | nSTEP_L0 | | STEP_<br>COUNTER_H | 3Ch | nSTEP_H7 | nSTEP_H6 | nSTEP_H5 | nSTEP_H4 | nSTEP_H3 | nSTEP_H2 | nSTEP_H1 | nSTEP_H0 | | FUNC_CK_GATE | 3Dh | TILT_INT | FS_SRC1 | FS_SRC0 | SIG_MOT_<br>DETECT | RST_SIG_<br>MOT | RST_PEDO | STEP_<br>DETECT | CK_GATE_<br>FUNC | | FUNC_SRC | 3Eh | 0 | 0 | 0 | 0 | 0 | RST_TILT | MODULE_<br>READY | SENSORHUB_<br>END_OP | | FUNC_CTRL | 3Fh | 0 | 0 | MODULE_<br>ON | TILT_ON | TUD_EN | MASTER_<br>ON | SIG_MOT_<br>ON | STEP_CNT<br>_ON | # 2.1 Advanced configuration registers The advanced configuration registers are used to configure specific device functions such as the pedometer and sensor hub. To switch to the advanced configuration register page, the FUNC\_CFG\_EN bit must be set to '1' in CTRL2 (21h). To go back to the standard register page, the FUNC\_CFG\_EN bit must be set to '0' in register 3Fh. Note: All modifications to the content of the advanced configuration registers have to be performed with the accelerometer sensor in power-down mode. **Table 3. Advanced configuration registers** | Register name | Address | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |----------------------|---------|---------------------|-----------------------------|-------------------|-------------------|------------------------------|-------------------------------|--------------------------------|--------------------| | PEDO_DEB_REG | 2Bh | DEB_TIME4 | DEB_TIME3 | DEB_TIME2 | DEB_TIME1 | DEB_TIME0 | DEB_STEP2 | DEB_STEP1 | DEB_STEP0 | | SLV0_ADD | 30h | Slave0_add6 | Slave0_add5 | Slave0_add4 | Slave0_add3 | Slave0_add2 | Slave0_add1 | Slave0_add0 | rw_0 | | SLV0_SUBADD | 31h | Slave0_reg7 | Slave0_reg6 | Slave0_reg5 | Slave0_reg4 | Slave0_reg3 | Slave0_reg2 | Slave0_reg1 | Slave0_reg0 | | SLV0_CONFIG | 32h | - | - | - | - | - | Slave0_<br>numop2 | Slave0_<br>numop1 | Slave0_<br>numop0 | | DATAWRITE_SLV0 | 33h | Slave0_<br>dataw7 | Slave0_<br>dataw6 | Slave0_<br>dataw5 | Slave0_<br>dataw4 | Slave0_<br>dataw3 | Slave0_<br>dataw2 | Slave0_<br>dataw1 | Slave0_<br>dataw0 | | SM_THS | 34h | SM_THS_7 | SM_THS_6 | SM_THS_5 | SM_THS_4 | SM_THS_3 | SM_THS_2 | SM_THS_1 | SM_THS_0 | | STEP_COUNT_<br>DELTA | 3Ah | STEP_<br>COUNT_D7 | STEP_<br>COUNT_D6 | STEP_<br>COUNT_D5 | STEP_<br>COUNT_D4 | STEP_<br>COUNT_D3 | STEP_<br>COUNT_D2 | STEP_<br>COUNT_D1 | STEP_<br>COUNT_D0 | | CTRL2 | 3Fh | BOOT <sup>(1)</sup> | SW_<br>RESET <sup>(1)</sup> | 0 | FUNC_<br>CFG_EN | FDS_<br>SLOPE <sup>(1)</sup> | IF_ADD_<br>INC <sup>(1)</sup> | I2C_<br>DISABLE <sup>(1)</sup> | SIM <sup>(1)</sup> | <sup>1.</sup> Read-only bit # 3 Operating modes The LIS2DS12 device provides two power modes: high-resolution (HR)/high-frequency mode (HF) and low-power (LP) mode. After the power supply is applied, the LIS2DS12 performs a 20 ms boot procedure to load the trimming parameters. After the boot is completed, the accelerometer is automatically configured in power-down mode. Referring to the LIS2DS12 datasheet, the output data rate (ODR) and high-frequency (HF\_ODR) bits of CTRL1 register are used to select the power mode and the output data rate of the accelerometer sensor (Table 4. Accelerometer ODR and power mode selection). Table 4. Accelerometer ODR and power mode selection | ODR [3:0] | HF_ODR | Mode | ODR selection [Hz] | Resolution (bit number) | |-----------|--------|------------|--------------------|-------------------------| | 0000 | 0 | Power-down | Power-down | - | | 1000 | 0 | LP | 1 | 10 | | 1001 | 0 | LP | 12.5 | 10 | | 1010 | 0 | LP | 25 | 10 | | 1011 | 0 | LP | 50 | 10 | | 1100 | 0 | LP | 100 | 10 | | 1101 | 0 | LP | 200 | 10 | | 1110 | 0 | LP | 400 | 10 | | 1111 | 0 | LP | 800 | 10 | | 0001 | 0 | HR | 12.5 | 14 | | 0010 | 0 | HR | 25 | 14 | | 0011 | 0 | HR | 50 | 14 | | 0100 | 0 | HR | 100 | 14 | | 0101 | 0 | HR | 200 | 14 | | 0110 | 0 | HR | 400 | 14 | | 0111 | 0 | HR | 800 | 14 | | 0101 | 1 | HF | 1600 | 12 | | 0110 | 1 | HF | 3200 | 12 | | 0111 | 1 | HF | 6400 | 12 | The output data have different resolution and are left-aligned. For example in case of the 10-bit resolution the output data are the 10 most significant bits of OUT\_H & OUT\_L concatenation, and the raw value has to be right-shifted by 6. Table 5. Power consumption shows the typical values of LIS2DS12 power consumption for the different operating modes. **Table 5. Power consumption** | ODR [Hz] | HR/HF (μA) | LP (μA) | |----------|------------|---------| | 1 | 150 | 2.5 | | 12.5 | 150 | 4 | AN4748 - Rev 5 page 6/56 | ODR [Hz] | HR/HF (μA) | LP (μA) | |----------|------------|---------| | 25 | 150 | 5.5 | | 50 | 150 | 8 | | 100 | 150 | 12.5 | | 200 | 150 | 22 | | 400 | 150 | 41 | | 800 | 150 | 80 | | 1600 | 150 | - | | 3200 | 150 | - | | 6400 | 150 | - | # 3.1 Power-down When the accelerometer is in power-down, almost all internal blocks of the device are switched off to minimize power consumption. Digital interfaces (I<sup>2</sup>C and SPI) are still active to allow communication with the device. The content of the configuration registers is preserved and the output data registers are not updated, keeping the last data sampled in memory before going into power-down. # 3.2 High-resolution/high-frequency mode In HR/HF mode, all accelerometer circuitry is always on and data are generated at the data rate selected through the ODR bits. Data interrupt generation is active. HR mode works with a 14-bit resolution, while HF with a 12-bit resolution (see Table 4. Accelerometer ODR and power mode selection). # 3.3 Low-power mode In low-power mode the accelerometer circuitry is periodically turned on/off with a duty cycle that is a function of the selected ODR. This mode differs from HR/HF mode in the available output data rates. In low-power mode we have same data rates as HR mode (from 12.5 Hz to 800 Hz, but with a lower consumption) plus the 1 Hz case. Data interrupt generation is active. LP mode works with a 10-bit resolution (see Table 4. Accelerometer ODR and power mode selection). AN4748 - Rev 5 page 7/56 ### 3.4 Accelerometer bandwidth The accelerometer sampling chain (Figure 2. Accelerometer sampling chain) is represented by a cascade of a few blocks: an ADC converter, a digital low-pass filter and a digital slope filter. Figure 2. Accelerometer sampling chain The digital signal is filtered by a low-pass digital filter (LPF) whose cutoff frequency depends on the selected accelerometer ODR, as shown in Table 6. Accelerometer LPF1 cutoff frequency. Mode **ODR** selection [Hz] LPF cutoff [Hz] LP 1 3200 LP 12.5 3200 LP 25 3200 LP 50 3200 LP 100 3200 LP 200 3200 LP 400 3200 LP 800 3200 HR 12.5 5.5 HR 25 11 HR 50 22 HR 100 44 HR 200 88 HR 400 177 HR 800 355 HF 1600 710 HF 3200 1420 HF 6400 2840 Table 6. Accelerometer LPF1 cutoff frequency AN4748 - Rev 5 page 8/56 The selection of the signal (LPF or HPF) which is sent to the OUT registers is determined by the FDS\_SLOPE bit of CTRL2 register. When it is logic '1', the HPF signal is selected, LPF otherwise. The signal that is sent to the digital functions (wakeup, double-tap, activity/inactivity and 6D orientation) is always the HPF signal. Anti-aliasing filtering is guaranteed by the ADC sampling frequency and the digital LPF cutoff frequency. Anti-aliasing filtering is available in HR/HF mode only. When the accelerometer is in LP mode, the circuitry is periodically turned on/off (reducing power consumption) with a fixed on-time and a period that is a function of the selected ODR. For this reason the LPF cutoff is fixed to 3.2 kHz, so the user must take care to select the proper ODR value Vs application sampling frequency in order to avoid aliasing (based on the noise characteristics of the system in use). #### 3.4.1 Accelerometer slope filter As shown in Figure 3. Accelerometer slope filter, the LIS2DS12 device embeds a digital slope filter which is used for wakeup and single/double-tap features. The slope filter output data is computed using the following formula: $$slope(t_n) = [acc(t_n) - acc(t_{n-1})]/2$$ An example of a slope data signal is illustrated in Figure 3. Accelerometer slope filter. Figure 3. Accelerometer slope filter Slope filter bandwidth is ~ ODR/4 and its data is available in the output registers <u>and FIFO</u> by setting the FDS\_SLOPE bit of CTRL2 (21h) to '1'. AN4748 - Rev 5 page 9/56 # 4 Reading output data # 4.1 Startup sequence Once the device is powered up, it automatically downloads the calibration coefficients from the embedded flash to the internal registers. When the boot procedure is completed, i.e. after approximately 20 milliseconds, the accelerometer automatically enters power-down. To turn on the accelerometer and gather acceleration data, it is necessary to select one of the operating modes through the CTRL1 register. The following general-purpose sequence can be used to configure the accelerometer: ``` Write CTRL1 = 60h // Acc = 400 Hz (high-resolution mode) Write CTRL4 = 01h // Acc data-ready interrupt on INT1 ``` # 4.2 Using the status register The device is provided with a STATUS register which should be polled to check when a new set of data is available. The DRDY bit is set to 1 when a new set of data is available from the accelerometer output. For the accelerometer, the reads should be performed as follows: - 1. Read STATUS - 2. If DRDY = 0, then go to 1 - 3. Read OUTX L - 4. Read OUTX\_H - 5. Read OUTY\_L - 6. Read OUTY H - 7. Read OUTZ L - 8. Read OUTZ H - 9. Data processing - 10. Go to 1 AN4748 - Rev 5 page 10/56 # 4.3 Using the data-ready signal The device can be configured to have one HW signal to determine when a new set of measurement data is available for reading. For the accelerometer sensor, the data-ready signal is represented by the DRDY bit of the STATUS register. The signal can be driven to the INT1 pin by setting to 1 the INT1\_DRDY bit of the CTRL4 register and to the INT2 pin by setting to 1 the INT2\_DRDY bit of the CTRL5 register. The data-ready signal rises to 1 when a new set of data has been generated and it is available for reading. In DRDY latched mode (DRDY\_PULSED bit = 0 in CTRL5 register), which is the default condition, the signal gets reset when the higher part of one of the channels has been read (29h, 2Bh, 2Dh). In DRDY pulsed mode (DRDY\_PULSED = 1) the pulse duration is about 75 µs. Figure 4. Data-ready signal # 4.4 Using the block data update (BDU) feature If reading the accelerometer data is particularly slow and cannot be synchronized (or it is not required) with either the DRDY event bit in the STATUS register or with the DRDY signal driven to the INT1/INT2 pins, it is strongly recommended to set the BDU (block data update) bit to 1 in the CTRL1 (20h) register. This feature avoids reading values (most significant and least significant parts of output data) related to different samples. In particular, when the BDU is activated, the data registers related to each channel always contain the most recent output data produced by the device, but, in case the read of a given pair (i.e. OUTX\_H and OUTX\_L, OUTY\_H and OUTY\_L, OUTZ\_H and OUTZ\_L) is initiated, the refresh for that pair is blocked until both MSB and LSB parts of the data are read. Note: BDU only guarantees that the LSB part and MSB part have been sampled at the same moment. For example, if the reading speed is too slow, X and Y can be read at T1 and Z sampled at T2. # 4.5 Understanding output data The measured acceleration data are sent to the OUTX\_H, OUTX\_L, OUTY\_H, OUTY\_L, OUTZ\_H, and OUTZ\_L registers. These registers contain, respectively, the most significant part and the least significant part of the acceleration signals acting on the X, Y, and Z axes. The complete output data for the X, Y, Z channels is given by the concatenation OUTX\_H & OUTX\_L, OUTY\_H & OUTY L, OUTZ H & OUTZ L and it is expressed as a two's complement number. Acceleration data is represented as 16-bit numbers, called LSB, but has different resolution according to the selected operating mode (LP/HR/HF). See Table 4. Accelerometer ODR and power mode selection. After calculating the LSB, it must be multiplied by the proper sensitivity parameter to obtain the corresponding value in mg. AN4748 - Rev 5 page 11/56 # 4.5.1 Example of output data Hereafter there is a simple example of how to use the LSB data and transform it into mg. The values are given under the hypothesis of perfect device calibration (i.e. no offset, no gain error,....). Get raw data from the sensor (HR mode, ODR 200 Hz): ``` OUTX_H: FDh OUTY_L: 74h OUTY_H: 00h OUTZ_L: F8h OUTZ_H: 42h Do registers concatenation: OUTX_H & OUTX_L: FD5Ch OUTY_H & OUTY_L: 0074h OUTZ_H & OUTZ_L: 42F8h Apply sensitivity (e.g. 0.061 at full scale ±2 g): X: -676 * 0.061 = -41 mg ``` Y: +116 \* 0.061 = +7 mg Z: +17144 \* 0.061 = +1046 mg AN4748 - Rev 5 page 12/56 # 5 Interrupt generation and embedded functions In the LIS2DS12 device the interrupt generation is based on accelerometer data, so, for interrupt-generation purposes, the accelerometer sensor has to be set in an active operating mode (not in power-down). The interrupt generator can be configured to detect: - Free-fall; - Wake-up; - 6D/4D orientation detection: - Single-tap and double-tap sensing; - Activity/Inactivity detection. In addition, the LIS2DS12 can efficiently run the sensor-related features specified in the leading OSs, saving power and enabling faster reaction time. In particular, it has been designed to implement in hardware: - Significant motion; - Tilt - · Pedometer functions; All these interrupt signals, together with FIFO interrupt signals and sensor data ready, can be independently driven to the INT1 and INT2 interrupt pins or checked by reading the dedicated source register bits. Note: When the MODULE\_ON bit is set to 1, the embedded functions (pedometer, tilt and significant motion) are not available. The H\_LACTIVE bit of the CTRL3 register must be used to select the polarity of the interrupt pins also when the DRDY signal is routed to them. If this bit is set to 0 (default value), the interrupt pins are active high and they change from low to high level when the related interrupt condition is verified. Otherwise, if the H\_LACTIVE bit is set to 1 (active low), the interrupt pins are normally at high level and they change from high to low when interrupt condition is reached. The PP\_OD bit of CTRL3 allows changing the behavior of the interrupt pins also when the DRDY signal is routed to them from push-pull to open drain. If the PP\_OD bit is set to 0, the interrupt pins are in push-pull configuration (low-impedance output for both high and low level). When the PP\_OD bit is set to 1, only the interrupt active state is a low-impedance output. The LIR bit of CTRL3 allows applying the latched mode to the interrupt signals (not affecting the DRDY signal). When the LIR bit is set to 1, once the interrupt pin is asserted, it must be reset by reading the related interrupt source register. If the LIR bit is set to 0, the interrupt signal is automatically reset when the interrupt condition is no longer verified or after a certain amount of time in function of the type of interrupt. AN4748 - Rev 5 page 13/56 # 5.1 Interrupt pin configuration The device is provided with two pins that can be activated to generate either data ready or interrupt signals. The functionality of these pins is selected through the CTRL4 register for the INT1 pin, and through the CTRL5 register for the INT2 pin. Hereafter the description of these interrupt control registers; the default value of their bits is equal to 0, which corresponds to 'disable'. In order to enable the routing of a specific interrupt signal on the pin, the related bit has to be set to 1. b7 b5 b4 b6 b3 b2 b1 b0 INT1\_ INT1\_ INT1\_ INT1\_ INT1\_ INT1\_ INT1\_ INT1\_ **MASTER** S\_TAP WU FF TAP FTH **DRDY** 6D DRDY Table 7. CTRL4 register - INT1\_MASTER\_DRDY: Manages the Master DRDY signal on the INT1 pin. - INT1\_S\_TAP: Single-tap event recognition is routed on the INT1 pin. - INT1 WU: Wakeup event recognition is routed on the INT1 pin. - INT1\_FF: Free-fall event recognition is routed on the INT1 pin. - INT1\_TAP: Tap event recognition is routed on the INT1 pin. - INT1\_6D: 6D event recognition is routed on the INT1 pin. - INT1\_FTH: FIFO threshold event is routed on the INT1 pin. - INT1\_DRDY: Accelerometer data-ready is routed on the INT1 pin. Table 8. CTRL5 register | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | |--------|-------|---------|-------|----------|-----------|-------|-------| | DRDY_ | INT2_ | INT2_ON | INT2_ | INT2_SIG | INT2_STEP | INT2_ | INT2_ | | PULSED | воот | _INT1 | TILT | _MOT | _DET | FTH | DRDY | - DRDY\_PULSED: Data-ready interrupt mode selection: latched mode / pulsed mode. - INT2\_BOOT: Boot state routed on the INT2 pin. - INT2\_ON\_INT1: All INT2 signals are routed also to the INT1 pin. - INT2\_TILT: Tilt event recognition is routed on the INT2 pin. - INT2\_SIG\_MOT: Significant motion event recognition is routed on the INT2 pin. - INT2 STEP DET: Step event recognition is routed on the INT2 pin. - INT2 FTH: FIFO threshold event is routed on the INT2 pin. - INT2 DRDY: Accelerometer data-ready on the INT2 pin. AN4748 - Rev 5 page 14/56 ### 5.2 Event status If multiple interrupt signals are routed on the same pin (INTx), the logic level of this pin is the "OR" combination of the selected interrupt signals. In order to know which event has generated the interrupt condition, the application should read the proper status register, which also will clear the event. As indicated below, the STATUS register is duplicated at address 36h in order to allow a multiple read of consecutive registers (36h/37h/38h/39h). - STATUS (27h) or STATUS DUP (36h) - WAKE\_UP\_SRC (37h) - TAP\_SRC (38h) - 6D SRC (39h) - FUNC CK GATE (3Dh). # 5.3 Free-fall interrupt Free-fall detection refers to a specific register configuration that allows recognizing when the device is in free-fall: the acceleration measured along all the axes goes to zero. In a real case a "free-fall zone" is defined around the zero-g level where all the accelerations are small enough to generate the interrupt. Configurable threshold and duration parameters are associated to free-fall event detection: the threshold parameter defines the free-fall zone amplitude; the duration parameter defines the minimum duration of the free-fall interrupt event to be recognized (Figure 5. Free-fall interrupt). Figure 5. Free-fall interrupt The free-fall event signal can be routed to the INT1 pin by setting to 1 the INT1\_FF bit of the CTRL4 register; it can also be checked by reading the FF\_IA bit of the WAKE\_UP\_SRC register. If latch mode is disabled (LIR bit of CTRL3 is set to 0), the interrupt signal is automatically reset when the free-fall condition is no longer verified. If latch mode is enabled and the free-fall interrupt signal is driven to the interrupt pins, once a free-fall event has occurred and the interrupt pin is asserted, it must be reset by reading the WAKE\_UP\_SRC register. If the latch mode is enabled, but the interrupt signal is not driven to the interrupt pins, the latch feature does not take effect (the FF\_IA bit in WAKE\_UP\_SRC is reset when the free-fall condition is no longer verified). The register used to configure the threshold parameter is named FREE\_FALL; the unsigned threshold value is related to the value of the FF\_THS[2:0] field value as indicated in Table 9. Free-fall threshold LSB value and is expressed in units of 31.25 mg. The LSB values given in this table are valid for any accelerometer full-scale value. AN4748 - Rev 5 page 15/56 Table 9. Free-fall threshold LSB value | FREE_FALL - FF_THS[2:0] | Threshold LSB value | |-------------------------|---------------------| | 000 | 5 | | 001 | 7 | | 010 | 8 | | 011 | 10 | | 100 | 11 | | 101 | 13 | | 110 | 15 | | 111 | 16 | Duration time is measured in N/ODR, where N is the content of the FF\_DUR[5:0] field of the FREE\_FALL / WAKE UP DUR registers and ODR is the accelerometer data rate. A basic SW routine for free-fall event recognition is given below. ``` // Turn on the accelerometer 1. Write 60h in CTRL1 // ODR = 400 \text{ Hz}, FS = \pm 2 g 2. Write 00h in WAKE UP DUR // Set event duration (FF_DUR5 = 0) // Set FF threshold (FF_THS[2:0] = 011b) 3. Write 33h in FREE FALL // Set six sample event duration (FF_DUR[5:0] = 000110b) 4. Write 10h in CTRL4 // FF interrupt driven to INT1 pin 5 Write 04h in CTRL3 // Latch interrupt ``` The sample code exploits a threshold set to $\sim$ 310 mg (31.25 mg \* 10) for free-fall recognition and the event is notified by hardware through the INT1 pin. The FF\_DUR[5:0] field of FREE\_FALL / WAKE\_UP\_DUR registers is configured like this to ignore events that are shorter than 6/ODR = 6/400 Hz = 15 msec in order to avoid false detections. # 5.4 Wake-up interrupt In the LIS2DS12 device the wake-up feature is implemented using the slope filter (see Section 3.4.1 Accelerometer slope filter for more details), as illustrated in Figure 3. Accelerometer slope filter. The wake-up interrupt signal is generated if a certain number of consecutive slope filtered data exceed the configured threshold (Figure 6. Wake-up interrupt). The unsigned threshold value is defined using the WU\_THS[5:0] bits of the WAKE\_UP\_THS register; the value of 1 LSB of these 6 bits depends on the selected accelerometer full scale: 1 LSB = FS/64. The threshold is applied to both positive and negative data: for a wake-up interrupt generation at least one of the three axes must be bigger than the threshold. The duration parameter defines the minimum duration of the wake-up event to be recognized; its value is set using the WU\_DUR[1:0] bits of the WAKE\_UP\_DUR register: 1 LSB corresponds to 1\*ODR time, where ODR is the accelerometer output data rate. It is important to appropriately define the duration parameter to avoid unwanted wake-up interrupts due to spurious spikes of the input signal. This interrupt signal can be driven to the INT1 interrupt pin by setting to 1 the INT1\_WU bit of the CTRL4 register; it can also be checked by reading the WU\_IA bit of the WAKE\_UP\_SRC register. The X\_WU, Y\_WU, Z\_WU bits of the WAKE\_UP\_SRC register indicate which axis has triggered the wake-up event. If latch mode is disabled (LIR bit of CTRL3 is set to 0), the interrupt signal is automatically reset when the filtered data falls below the threshold. If latch mode is enabled and the wake-up interrupt signal is driven to the interrupt AN4748 - Rev 5 page 16/56 pins, once a wake-up event has occurred and the interrupt pin is asserted, it must be reset by reading the WAKE\_UP\_SRC register. If the latch mode is enabled but the interrupt signal is not driven to the interrupt pins, the latch feature does not take effect (the WU\_IA bit in WAKE\_UP\_SRC is reset when the free-fall condition is no longer verified). Figure 6. Wake-up interrupt The example code which implements the SW routine for the wake-up event recognition is given below. 1. Write 60h in CTRL1 // Turn on the accelerometer // ODR = 400 Hz, FS = $\pm 2 g$ 2. Write 00h in WAKE\_UP\_DUR // No duration 3. Write 02h in WAKE\_UP\_THS // Set wake-up threshold 4. Write 20h in CTRL4 // Wake-up interrupt driven to INT1 pin Since the duration time is set to zero, the wake-up interrupt signal is generated for each X, Y, Z slope data exceeding the configured threshold. The WU\_THS field of the WAKE\_UP\_THS register is set to 000010b, therefore the wake-up threshold is 62.5 mg (= 2 \* FS / 64). AN4748 - Rev 5 page 17/56 ### 5.5 6D/4D orientation detection The LIS2DS12 device provides the capability to detect the orientation of the device in space, enabling easy implementation of energy-saving procedures and automatic image rotation for mobile devices. #### 5.5.1 6D orientation detection Six orientations of the device in space can be detected; the interrupt signal is asserted when the device switches from one orientation to another. The interrupt is not re-asserted as long as the position is maintained. 6D interrupt is generated when only one axis exceeds a selected threshold and the acceleration values measured from the other two axes are lower than the threshold: the ZH, ZL, YH, YL, XH, XL bits of the 6D\_SRC register indicate which axis has triggered the 6D event. In more detail: Table 10. 6D\_SRC register | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | |----|-------|----|----|----|----|----|----| | 0 | 6D_IA | ZH | ZL | YH | YL | XH | XL | - 6D IA is set high when the device switches from one orientation to another. - ZH (YH, XH) is set high when the face perpendicular to the Z (Y,X) axis is almost flat and the acceleration measured on the Z (Y,X) axis is positive and in the module bigger than the threshold. - ZL (YL, XL) is set high when the face perpendicular to the Z (Y,X) axis is almost flat and the acceleration measured on the Z (Y,X) axis is negative and in the module bigger than the threshold. The 6D\_THS[1:0] bits of the TAP\_6D\_THS register are used to select the threshold value used to detect the change in device orientation. The threshold values given in Table 11. Threshold for 4D/6D function are valid for each accelerometer full-scale value. Table 11. Threshold for 4D/6D function | 6D_THS[1:0] | Threshold value [degrees] | |-------------|---------------------------| | 00 | 80 | | 01 | 70 | | 10 | 60 | | 11 | 50 | This interrupt signal can be driven to the INT1 interrupt pin by setting to 1 the INT1\_6D bit of the CTRL4 register; it can also be checked by reading the 6D\_IA bit of the 6D\_SRC register. If latch mode is disabled (LIR bit of CTRL3 is set to 0), the interrupt signal is active only for 1/ODR[s] then it is automatically deasserted (ODR is the accelerometer output data rate). If latch mode is enabled and the 6D interrupt signal is driven to the interrupt pins, once an orientation change has occurred and the interrupt pin is asserted, a reading of the 6D\_SRC register clears the request and the device is ready to recognize a different orientation. If the latch mode is enabled, but the interrupt signal is not driven to the interrupt pins, the latch feature does not take effect. Referring to the six possible cases illustrated in Figure 7. 6D recognized orientations, the content of the 6D\_SRC register for each position is shown in Table 12. 6D SRC register for 6D positions. AN4748 - Rev 5 page 18/56 Figure 7. 6D recognized orientations Table 12. 6D\_SRC register for 6D positions | Case | 6D_IA | ZH | ZL | YH | YL | XH | XL | |------|-------|----|----|----|----|----|----| | (a) | 1 | 0 | 0 | 0 | 1 | 0 | 0 | | (b) | 1 | 0 | 0 | 0 | 0 | 0 | 1 | | (c) | 1 | 0 | 0 | 0 | 0 | 1 | 0 | | (d) | 1 | 0 | 0 | 1 | 0 | 0 | 0 | | (e) | 1 | 1 | 0 | 0 | 0 | 0 | 0 | | (f) | 1 | 0 | 1 | 0 | 0 | 0 | 0 | Hereafter an example which implements the SW routine for 6D orientation detection: 1. Write 60h in CTRL1 // Turn on the accelerometer // ODR = 400 Hz, FS = $\pm 2 g$ 2. Write 40h in TAP\_6D\_THS // Set 6D threshold (6D\_THS[1:0] = 10b = 60 degrees) 3. Write 04h in CTRL4 // 6D interrupt driven to INT1 pin AN4748 - Rev 5 page 19/56 #### 5.5.2 4D orientation detection The 4D direction function is a subset of the 6D function especially defined to be implemented in mobile devices for portrait and landscape computation. It can be enabled by setting the 4D\_EN bit of the TAP\_6D\_THS register to 1. In this configuration, the Z-axis position detection is disabled, therefore reducing position recognition to cases (a), (b), (c), and (d) of Table 12. 6D\_SRC register for 6D positions. # 5.6 Single-tap and double-tap recognition The single-tap and double-tap recognition functions featured in the LIS2DS12 help to create a man-machine interface with little software loading. The device can be configured to output an interrupt signal on a dedicated pin when tapped in any direction. If the sensor is exposed to a single input stimulus, it generates an interrupt request on the interrupt pin INT1. A more advanced feature allows the generation of an interrupt request when a double input stimulus with programmable time between the two events is recognized, enabling a mouse button-like function. In the LIS2DS12 device the single-tap and double-tap recognition functions use the slope between two consecutive acceleration samples to detect the tap events; the slope data is computed using the following formula: $$slope(t_n) = [acc(t_n) - acc(t_{n-1})] / 2$$ This function can be fully programmed by the user in terms of expected amplitude and timing of the slope data by means of a dedicated set of registers. Single and double-tap recognition is meaningful only for ODR ≥ 400 Hz. AN4748 - Rev 5 page 20/56 ### 5.6.1 Single tap If the device is configured for single-tap event detection, an interrupt is generated when the slope data on the selected channel exceed the programmed threshold, and return below it within the shock time window. In the single-tap case, if the LIR bit of the CTRL3 register is set to 0, the interrupt is kept high for the duration of the guiet window. In order to enable the latch feature on the single-tap interrupt signal, the LIR bit of CTRL3 has to be set to 1: the interrupt is kept high until the TAP\_SRC register is read. The SINGLE\_DOUBLE\_TAP bit of WAKE\_UP\_THS has to be set to 0 in order to enable single-tap recognition only. In case (a) of Figure 8. Single-tap event recognition the single-tap event has been recognized, while in case (b) the tap has not been recognized because the slope data fall under the threshold after the shock time window has expired. Figure 8. Single-tap event recognition AN4748 - Rev 5 page 21/56 #### 5.6.2 Double tap If the device is configured for double-tap event detection, an interrupt is generated when, after a first tap, a second tap is recognized. The recognition of the second tap occurs only if the event satisfies the rules defined by the shock, the latency and the quiet time windows. In particular, after the first tap has been recognized, the second tap detection procedure is delayed for an interval defined by the quiet time. This means that after the first tap has been recognized, the second tap detection procedure starts only if the slope data exceed the threshold after the quiet window but before the latency window has expired. In case (a) of Figure 9. Double-tap event recognition (LIR bit = 0), a double-tap event has been correctly recognized, while in case (b) the interrupt has not been generated because the slope data exceed the threshold after the latency window interval has expired. Once the second tap detection procedure is initiated, the second tap is recognized with the same rule as the first: the slope data must return below the threshold before the shock window has expired. It is important to appropriately define the quiet window to avoid unwanted taps due to spurious bouncing of the input signal. In the double-tap case, if the LIR bit of the CTRL3 register is set to 0, the interrupt is kept high for the duration of the quiet window. If the LIR bit is set to 1, the interrupt is kept high until the TAP\_SRC register is read. Figure 9. Double-tap event recognition (LIR bit = 0) ### 5.6.3 Single-tap and double-tap recognition configuration The LIS2DS12 device can be configured to output an interrupt signal when tapped (once or twice) in any direction: the TAP\_X\_EN, TAP\_Y\_EN and TAP\_Z\_EN bits of the CTRL3 register must be set to 1 to enable the tap recognition on X, Y, Z directions, respectively. Configurable parameters for tap recognition functionality are the tap threshold and the shock, quiet and latency time windows. Valid ODRs are 400 Hz, 800 Hz and 1600 Hz. AN4748 - Rev 5 page 22/56 The TAP\_THS[4:0] bits of the TAP\_6D\_THS register are used to select the unsigned threshold value used to detect the tap event. The value of 1 LSB of these 5 bits depends on the selected accelerometer full scale: 1 LSB = FS/32. The unsigned threshold is applied to both positive and negative slope data. The shock time window defines the maximum duration of the overthreshold event: the acceleration must return below the threshold before the shock window has expired, otherwise the tap event is not detected. The SHOCK[1:0] bits of the INT\_DUR register are used to set the shock time window value: the default value of these bits is 00b and corresponds to 4/ODR time, where ODR is the accelerometer output data rate. If the SHOCK[1:0] bits are set to a different value, 1 LSB corresponds to 8/ODR time. In the double-tap case, the quiet time window defines the time after the first tap recognition in which there must not be any overthreshold. When the latch mode is disabled (LIR bit of CTRL3 is set to 0), the quiet time also defines the length of the interrupt pulse (in both single and double-tap case). The QUIET[1:0] bits of the INT\_DUR register are used to set the quiet time window value: the default value of these bits is 00b and corresponds to 2/ODR time, where ODR is the accelerometer output data rate. If the QUIET[1:0] bits are set to a different value, 1 LSB corresponds to 4/ODR time. In the double-tap case, the latency time window defines the maximum time between two consecutive detected taps. The latency time period starts just after the completion of the quiet time of the first tap. The LAT[3:0] bits of the INT\_DUR register are used to set the latency time window value: the default value of these bits is 0000b and corresponds to 16/ODR time, where ODR is the accelerometer output data rate. If the LAT[3:0] bits are set to a different value, 1 LSB corresponds to 32/ODR time. Figure 10. Single and double-tap recognition (LIR bit = 0) illustrates a single-tap event (a) and a double-tap event (b). These interrupt signals can be driven to the INT1 interrupt pin by setting to 1 the INT1\_S\_TAP bit of the CTRL4 register for the single-tap case, and setting to 1 the INT1\_TAP bit of the CTRL4 register for the double-tap case No single/double-tap interrupt is generated if the accelerometer is in inactivity status (see Section 5.7 Activity/Inactivity recognition for more details). Figure 10. Single and double-tap recognition (LIR bit = 0) The tap interrupt signals can also be checked by reading the TAP\_SRC (38h) register, described in Table 13. TAP SRC register. AN4748 - Rev 5 page 23/56 | <b>Table</b> | 13. | <b>TAP</b> | SRC | register | |--------------|-----|------------|-----|----------| |--------------|-----|------------|-----|----------| | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | |----|--------|----------------|----------------|--------------|-------|-------|-------| | 0 | TAP_IA | SINGLE<br>_TAP | DOUBLE<br>_TAP | TAP<br>_SIGN | X_TAP | Y_TAP | Z_TAP | - TAP\_IA is set high when a single-tap or double-tap event has been detected. - SINGLE TAP is set high when a single tap has been detected. - DOUBLE TAP is set high when a double tap has been detected. - TAP\_SIGN indicates the acceleration sign when the tap event is detected. It is set low in case of positive sign and it is set high in case of negative sign. - X\_TAP (Y\_TAP, Z\_TAP) is set high when the tap event has been detected on the X (Y, Z) axis Single and double-tap recognition works independently. Setting the SINGLE\_DOUBLE\_TAP bit of WAKE\_UP\_THS to 0, only the single-tap recognition is enabled: double-tap recognition is disabled and cannot be detected. When the SINGLE\_DOUBLE\_TAP is set to 1, both single and double-tap recognition are enabled. If the latch mode is enabled and the interrupt signal is driven to the interrupt pins, the value assigned to SINGLE\_DOUBLE\_TAP also affects the behavior of the interrupt signal: when it is set to 0, the latch mode is applied to the single-tap interrupt signal; when it is set to 1, the latch mode is applied to the double-tap interrupt signal only. The latched interrupt signal is kept high until the TAP\_SRC register is read. If the latch mode is enabled but the interrupt signal is not driven to the interrupt pins, the latch feature does not take effect. #### 5.6.4 Single-tap example Hereafter an example code which implements the SW routine for single-tap detection. | 1. | Write 60h in CTRL1 | // Turn on the accelerometer | |----|--------------------------|----------------------------------------------------| | 1. | Wille GOITHI CTALT | // ODR = 400 Hz, FS = $\pm 2 g$ | | 2. | Write 38h in CTRL3 | // Enable tap detection on X, Y, Z-axis | | 3. | Write 09h in TAP_6D_THS | // Set tap threshold | | 4. | Write 06h in INT_DUR | // Set quiet and shock time windows | | 5. | Write 00h in WAKE_UP_THS | // Only single tap enabled (SINGLE_DOUBLE_TAP = 0) | | 6. | Write 40h in CTRL4 | // Single-tap interrupt driven to INT1 pin | In this example the TAP\_THS field of the TAP\_6D\_THS register is set to 01001b, therefore the tap threshold is 562.5 mg (= 9 \* FS / 32). The SHOCK field of the INT\_DUR register is set to 10b: an interrupt is generated when the slope data exceeds the programmed threshold, and returns below it within 40 ms (= 2 \* 8 / ODR) corresponding to the shock time window. The QUIET field of the INT\_DUR register is set to 01b: since the latch mode is disabled, the interrupt is kept high for the duration of the quiet window, therefore 10 ms (= 1 \* 4 / ODR). AN4748 - Rev 5 page 24/56 ### 5.6.5 Double-tap example The example code which implements the SW routine for single-tap detection is given below. | | W'' OOL : OTPLA | // Turn on the accelerometer | |----|--------------------------|--------------------------------------------------------| | 1. | Write 60h in CTRL1 | // ODR = 400 Hz, FS = $\pm 2 g$ | | 2. | Write 38h in TAP_CFG | // Enable tap detection on X, Y, Z-axis | | 3. | Write 0Ch in TAP_6D_THS | // Set tap threshold | | 4. | Write 7Fh into INT_DUR | // Set duration, quiet and shock time windows | | 5. | Write 80h in WAKE_UP_THS | // Single & double-tap enabled (SINGLE_DOUBLE_TAP = 1) | | 6. | Write 08h in CTRL4 | // Double-tap interrupt driven to INT1 pin | In this example the TAP\_THS field of the TAP\_6D\_THS register is set to 01100b, therefore the tap threshold is 750 mg (= 12 \* FS / 32). For interrupt generation, during the first and the second tap the slope data must return below the threshold before the shock window has expired. The SHOCK field of the INT\_DUR register is set to 11b, therefore the shock time is 60 ms (= 3 \* 8 / ODR). For interrupt generation, after the first tap recognition there must not be any slope data overthreshold during the quiet time window. Furthermore, since the latch mode is disabled, the interrupt is kept high for the duration of the quiet window. The QUIET field of the INT\_DUR register is set to 11b, therefore the quiet time is 30 ms (= 3 \* 4 / ODR). For the maximum time between two consecutive detected taps, the LAT field of the INT\_DUR register is set to 0111b, therefore the duration time is 560 ms (= 7 \* 32 / ODR). AN4748 - Rev 5 page 25/56 ### 5.7 Activity/Inactivity recognition The activity/inactivity recognition function allows reducing system power consumption and developing new smart applications. When the activity/inactivity recognition function is activated, the LIS2DS12 device is able to automatically enter low-power mode and decrease the accelerometer sampling rate to 12.5 Hz, increasing back the accelerometer ODR and bandwidth as soon as the wake-up interrupt event has been detected. With this feature the system may be efficiently switched from low-power consumption to full performance and vice-versa depending on user-selectable acceleration events, thus ensuring power saving and flexibility. The activity/inactivity recognition function is enabled by setting to 1 the SLEEP\_ON bit of the WAKE\_UP\_THS register. The activity/inactivity recognition function uses the slope between two consecutive acceleration samples to detect the activity/inactivity event; the slope data is computed using the following formula: $$slope(t_n) = [acc(t_n) - acc(t_{n-1})] / 2$$ This function can be fully programmed by the user in terms of expected amplitude and timing of the slope data by means of a dedicated set of registers (Figure 11. Activity/Inactivity recognition). The unsigned threshold value is defined using the WK\_THS[5:0] bits in the WAKE\_UP\_THS register; the value of 1 LSB of these 6 bits depends on the selected accelerometer full scale: 1 LSB = 1 / 64 of FS. The threshold is applied to both positive and negative slope data. When a certain number of consecutive X,Y,Z slope data is smaller than the configured threshold, the ODR [3:0] bits of the CTRL1 register are bypassed (inactivity) and the accelerometer is internally set to 12.5 Hz although the content of CTRL1 is left untouched. The duration of the inactivity status to be recognized is defined by the SLEEP\_DUR[3:0] bits of the WAKE\_UP\_DUR register: 1 LSB corresponds to 512/ODR time, where ODR is the accelerometer output data rate. When the inactivity status is detected, no interrupt is generated to the application processor (SLEEP\_STATE\_IA bit of the WAKE\_UP\_SRC register cannot be routed on the pin). When a single sample of slope data on one axis becomes bigger than the threshold, the CTRL1 register settings are immediately restored (activity). The wake-up interrupt event can be delayed in function of the value of the WU\_DUR[1:0] bits of the WAKE\_UP\_DUR register: 1 LSB corresponds to 1/ODR time, where ODR is the accelerometer output data rate. In order to generate the interrupt at the same time as the Inactivity/Activity event, WU\_DUR[1:0] have to be set to 0. When the wake-up event is detected, the interrupt is set high for 1/ODR period, then it is automatically deasserted (the WU\_IA event on the pin must be routed by setting the INT1\_WU bit of CTRL4 register to 1). AN4748 - Rev 5 page 26/56 Figure 11. Activity/Inactivity recognition The code provided below is a basic routine for activity/inactivity detection implementation. | 4 | Write 50h in CTRL1 | // Turn on the accelerometer | |------|----------------------------|---------------------------------------------------| | 1. | Write 50H III CTRL1 | // ODR = 200 Hz, $FS = \pm 2 g$ | | 2. | Write 42h in WAKE UP DUR | // Set duration for inactivity detection | | Z. V | Wille 42ITIII WAKE_OF_DOK | // Set duration for wake-up detection | | 3. | Write 42h in WAKE UP THS | // Set activity/inactivity threshold | | 3. | Wille 42ITIII WAKE_UF_ITIS | // Enable activity/inactivity detection | | 4. | Write 20h in CTRL4 | // Activity (wakeup) interrupt driven to INT1 pin | In this example the WU\_THS field of the WAKE\_UP\_THS register is set to 000010b, therefore the activity/inactivity threshold is 62.5 mg (= 2 \* FS / 64). Before inactivity detection, the X,Y,Z slope data must be smaller than the configured threshold for a period of time defined by the SLEEP\_DUR field of the WAKE\_UP\_DUR register: this field is set to 0010b, corresponding to $5.12\,s$ (= 2\*512/ODR). After this period of time has elapsed, the accelerometer ODR is internally set to $12.5\,Hz$ . The activity status is detected and the CTRL1 register settings immediately restored if the slope data of (at least) one axis are bigger than the threshold and the wake-up interrupt was notified after an interval defined by the $WU_DUR$ field of the WAKE\_UP\_DUR register: this field is set to 10b, corresponding to 10 ms (= 2 \* 1 / ODR). AN4748 - Rev 5 page 27/56 #### 5.8 Boot status After the device is powered up, the LIS2DS12 performs a 20 ms boot procedure to load the trimming parameters. After the boot is completed the accelerometer is automatically configured in power-down mode. After power-up, the trimming parameters can be re-loaded by setting to 1 the BOOT bit of the CTRL2 register. No toggle of the device power lines is required and the content of the device control registers is not modified, so the device operating mode doesn't change after boot. If the reset to the default value of the control registers is required, it can be performed by setting to 1 the SW RESET bit of the CTRL2 register. The boot status signal can be driven to the INT2 interrupt pin by setting to 1 the INT2\_BOOT bit of the CTRL5 register: the signal goes to '1' while a boot is taking place, and returns to '0' when it is done. To return the device to the power-down default settings, follow these steps from ANY operating mode: - 1. Set SW RESET bit to '1' - 2. Wait until SW\_RESET bit returns to '0' - 3. Set BOOT bit to '1' - 4. Wait 20 ms ### 5.9 Embedded functions The LIS2DS12 device implements in hardware the sensor-related functions specified in the leading OSs; specific IP blocks with negligible power consumption and high-level performance implement the following functions: - · Pedometer functions (step detector and step counter) - Significant motion - Tilt #### 5.9.1 Pedometer functions: step detector and step counter A specific IP block of the LIS2DS12 device is dedicated to pedometer functions: the step detector and the step counter. Pedometer functions work at 25 Hz, so the accelerometer ODR must be set at a value of 25 Hz or higher. The max step frequency that can be detected is around 3 Hz. In order to enable the pedometer functions the STEP\_CNT\_ON bit of the FUNC\_CTRL register must be set to 1. When the pedometer is enabled, the MODULE\_8BIT (0Ch) register is also available and contains the computation of the acceleration intensity ( $\sqrt{(x^2 + y^2 + z^2)}$ ) with maximum update frequency 25 Hz. The step detector functionality generates an interrupt every time a step is recognized. Instead of generating an interrupt every time a step is recognized, it is possible to generate it if at least one step is detected within a certain time period. This time period is defined by setting a value higher than 00h in the bits [0:7] of the STEP\_COUNT\_DELTA register in the advanced configuration registers (1 LSB of the value of the STEP\_COUNT\_DELTA register corresponds to 1.6384 seconds). In case of interspersed step sessions, 7 consecutive steps have to be detected before the first interrupt generation (debounce functionality) in order to avoid false step detections. The number of debounce steps can be modified through the DEB\_STEP [2:0] bits of register PEDO\_DEB\_REG in the advanced configuration registers. 1LSB corresponds to 1 step. The debounce functionality restarts after a period of time (debouncing time) that can be modified through the DEB\_TIME[4:0] bits of register PEDO\_DEB\_REG in the advanced configuration registers. 1LSB corresponds to 80 ms, default value = 13 (13 \*80 ms = 1040 ms). This interrupt signal can be driven to the INT2 interrupt pin by setting to 1 the INT2\_STEP\_DET bit of the CTRL5 register; it can also be checked by reading the STEP\_DETECT bit of the FUNC\_CK\_GATE register. The step counter indicates the number of steps detected by the step detector algorithm after the pedometer function has been enabled. The step count is given by the concatenation of the STEP\_COUNTER\_H and STEP\_COUNTER\_L registers and it is represented as a 16-bit unsigned number. The step count is not reset to zero when the accelerometer is configured in power-down or the pedometer is disabled; it can be reset to zero by setting the RST\_NSTEP bit of the STEP\_COUNTER\_MINTHS register to 1. The step counter overflow condition (count reaches 2<sup>16</sup>) can be driven to the INT2 pin by setting to 1 the INT2 STEP COUNT OV bit (bit #4) of FIFO CTRL (25h). AN4748 - Rev 5 page 28/56 If latch mode is disabled (LIR bit of CTRL3 is set to 0), the interrupt signal generated by the pedometer functions is pulsed: the duration of the pulse observed on the interrupt pins is about 60 µs. If latch mode is enabled (LIR bit of CTRL3 is set to 1) and the interrupt signal is driven to the interrupt pins, once a step has occurred, a reading of the FUNC\_CK\_GATE register clears the request on both the pins and the device is ready to recognize the next step. If latch mode is enabled but the event is not driven to the interrupt pins, the STEP\_DETECT bit of the FUNC\_CK\_GATE register is pulsed, with a fixed duration of 1/25 Hz. As default, the step counter works at $\pm 2~g$ full scale, independently of the configured device full scale, but it can be configured to $\pm 4~g$ by setting to 1 the PEDO4g bit of the STEP\_COUNTER\_MINTHS register provided that the full scale set in CTRL1 register is at least $\pm 4~g$ . The PEDO4g bit of the STEP\_COUNTER\_MINTHS register impacts the Module\_8bit (0Ch) register: if PEDO4g is set to 1 the conversion factor is 31.25 (mg/lsb), else 15.625 (mg/lsb). It is also possible to set the "minimum threshold", i.e. the value at which the threshold for step recognition asymptotically tends if no steps are detected and below which it cannot descend. This configuration is in the SC\_MTHS[5:0] field of the STEP\_COUNTER\_MINTHS register. The value of 1 LSB of these 6 bits depends on the selected step counter full scale $(\pm 2 g \text{ or } \pm 4 g)$ : 1 LSB = FS / 64. Figure 12. Minimum threshold Hereafter a basic SW routine which shows how to enable the pedometer functions: Write 20h in CTRL1 Write 20h in CTRL1 // ODR = 25 Hz, FS = ±2 g Write 01h in FUNC\_CTRL Write 04h in CTRL5 // Step detector interrupt driven to INT2 pin The interrupt signal is generated when a step is recognized and the step count is available by reading the STEP\_COUNTER\_H / STEP\_COUNTER\_L registers. AN4748 - Rev 5 page 29/56 #### 5.9.2 Significant motion The significant motion functionality can be used in location-based applications in order to receive a notification indicating when the user is changing location. The significant motion function generates an interrupt when a 'significant motion', that could be due to a change in user location, is detected. To be considered significant, a motion should be at least 5 steps. In the LIS2DS12 device this function has been implemented in hardware using the accelerometer and works at 25 Hz, so the accelerometer ODR must be set at a value of 25 Hz or higher. In order to enable significant motion detection, the SIGN\_MOT\_ON bit of the FUNC\_CTRL register must be set to 1. When the significant motion detection is enabled, the Module\_8bit (0Ch) register is also available and contains the computation of the acceleration intensity ( $\sqrt{(x^2 + y^2 + z^2)}$ ) with maximum update frequency 25 Hz. As default, the significant motion detection works at $\pm 2~g$ full scale, independently of the configured device full scale, but it can be configured to $\pm 4~g$ by setting the PEDO4g bit of the STEP\_COUNTER\_MINTHS register to 1, provided that the full scale set in the CTRL1 register is at least $\pm 4~g$ . The PEDO4g bit of the STEP\_COUNTER\_MINTHS register impacts the Module\_8bit (0Ch) register: if PEDO4g is set to 1, the conversion factor is 31.25 (mg/lsb), else 15.625 (mg/lsb). The significant motion interrupt signal can be driven to the INT2 interrupt pin by setting to 1 the INT2\_SIG\_MOT bit of the CTRL5 register; it can also be checked by reading the SIG\_MOT\_DETECT bit of the FUNC\_CK\_GATE register. If latch mode is disabled (LIR bit of CTRL3 is set to 0), the interrupt signal generated by the significant motion function is pulsed: the duration of the pulse observed on the interrupt pins is about 60 $\mu$ s; the duration of the pulse observed on the SIG\_MOT\_DETECT bit of the FUNC\_CK\_GATE register is 1/25 Hz. If latch mode is enabled (LIR bit of CTRL3 is set to 1) and the interrupt signal is driven to the interrupt pin, once a 'significant motion' is detected, a reading of the FUNC\_CK\_GATE register clears the request on INT2 and the SIG\_MOT\_DETECT bit of the FUNC\_CK\_GATE register, and the device is ready to recognize the next event. If latch mode is enabled but the interrupt signal is not driven to the interrupt pins, the SIG\_MOT\_DETECT bit of the FUNC\_CK\_GATE register is pulsed, with a fixed duration of 1/25 Hz. The user can configure the significant motion minimum threshold, which is the number of steps to be performed by the user upon a change of location before the significant motion interrupt is generated. For this purpose the SM\_THS register (34h) of the advanced configuration registers may be used: | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |----------|----------|----------|----------|----------|----------|----------|----------| | SM_THS_7 | SM_THS_6 | SM_THS_5 | SM_THS_4 | SM_THS_3 | SM_THS_2 | SM_THS_1 | SM_THS_0 | Please note that the SMD threshold is effective when its value (SM\_THS\_[7:0] bits of SM\_THS (34h) register) is equal to or higher than the Pedometer Debounce threshold (DEB\_STEP[2:0] bits of the PEDO\_DEB\_REG (2Bh) advanced register). The following table indicates a possible scenario for the SMD threshold value. Table 14. SMD threshold | Configurations | SM_THS_[7:0] | DEB_STEP[2:0] | |----------------------------------------------------------------------------------|--------------|---------------| | Pedometer debounce not active | V | | | Pedometer debounce is active and SMD threshold is ≥ pedometer debounce threshold | V | | | Pedometer debounce is active and SMD threshold is < pedometer debounce threshold | | √ | AN4748 - Rev 5 page 30/56 When the pedometer debounce is active and the SMD threshold is lower than the default (=6), the bits DEB\_STEP[2:0] of the PEDO\_DEB\_REG register have to be decreased accordingly. NOTE: An excessive reduction of the pedometer debounce threshold can cause the pedometer to report false step detections! Hereafter a basic SW routine which shows how to enable the significant motion detection function: | 1. | Write 20h in CTRL1 | // Turn on the accelerometer | |----|------------------------------|-------------------------------------------------------------------------| | 1. | Wille 2011 III CTRLT | // ODR = 25 Hz, FS = $\pm 2 g$ | | 2. | Write 02h in FUNC_CTRL | // Enable significant motion algorithm | | 3. | Set 10h bit in CTRL2 | // Enable access of the advanced configuration registers: | | 5. | Set for bit in CTAL2 | // write bit #4 of reg 21h to 1, keep the other bits unchanged | | 4. | Set threshold in SM_THS[7:0] | // Write threshold in 34h of the advanced configuration registers. | | 4. | | // 1LSB = 1 step. Default value = 6. | | | | // Disable access of the advanced configuration registers. | | 5. | Write 00h in CTRL2 | // write bit #4 of reg 3Fh to 0. | | | | // Please note that all the bits but the 4 <sup>th</sup> are read only. | | 6. | Write 08h in CTRL5 | // Significant motion interrupt driven to INT2 pin | #### 5.9.3 Tilt The tilt function allows detecting when an activity change occurs (e.g. when phone is in a front pocket and the user goes from sitting to standing or standing to sitting): in the LIS2DS12 device it has been implemented in hardware. In order to enable tilt detection the TILT ON bit of the FUNC CTRL register must be set to 1. If the device is configured for tilt event detection, an interrupt is generated when the device is tilted by an angle greater than 35 degrees from the start position. The start position is defined as the position of the device when tilt detection is enabled or the position of the device when the last tilt interrupt was generated. After this function is enabled, for the generation of the first tilt interrupt the device should be continuously tilted by an angle greater than 35 degrees from the start position for a period of time of at least 2 seconds. After the first tilt interrupt is generated, the tilt interrupt signal is set high as soon as the device is tilted by an angle greater than 35 degrees from the position of the device corresponding to the last interrupt detection (no need to wait 2 seconds). This interrupt signal can be driven to the INT2 pin by setting to 1 the INT2\_TILT bit of the CTRL5 register; it can also be checked by reading the TILT\_INT bit of the FUNC\_CK\_GATE register. If latch mode is disabled (LIR bit of CTRL3 is set to 0), the interrupt signal generated by the tilt function is pulsed: the duration of the pulse observed on the interrupt pins is about 60 $\mu$ s; the duration of the pulse observed on the TILT\_INT bit of the FUNC\_CK\_GATE register is 1/25 Hz. If latch mode is enabled (LIR bit of CTRL3 is set to 1) and the interrupt signal is driven to the interrupt pins, once a tilt is detected, a reading of the FUNC\_CK\_GATE register clears the request on the INT2 pin and the TILT\_INT bit of FUNC\_CK\_GATE register, and the device is ready to recognize the next tilt event. If latch mode is enabled but the interrupt signal is not driven to the interrupt pins, the TILT\_INT bit of the FUNC\_CK\_GATE register is pulsed, with a fixed duration of 1/25 Hz. The tilt function works at 25 Hz independently of the device ODR. Hereafter a basic SW routine which shows how to enable the tilt detection function: | 1. | Write 20h in CTDI 1 | // Turn on the accelerometer | |----|------------------------|-----------------------------------------------| | | Write 20h in CTRL1 | // ODR = 25 Hz, FS = $\pm 2 g$ | | 2. | Write 10h in FUNC_CTRL | // Enable tilt detection | | 3. | Write 10h in CTRL5 | // Tilt detector interrupt driven to INT2 pin | AN4748 - Rev 5 page 31/56 ### 5.10 Sensor hub The sensor hub functionality allows connecting one external sensor to the I<sup>2</sup>C master interface of the LIS2DS12 device. External sensor data does not go into FIFO and must be read directly from the sensor hub registers. The sensor has to be connected to the SDx/SCx pins of the device. Pull-up resistors can be internally enabled through TUD\_EN in FUNC\_CTRL (3Fh) or added externally. If the accelerometer is in power-down mode, the sensor hub doesn't work. The sensor hub I<sup>2</sup>C activity is triggered by the accelerometer ODR. When the sensor hub is enabled, it continuously generates the configured I<sup>2</sup>C read/write transaction on the bus each time the trigger is activated. The trigger will not exceed 100 Hz frequency even if the accelerometer ODR is set to a higher value. ### 5.10.1 Sensor hub pin description When the sensor hub is enabled, some of the standard pins are automatically multiplexed to perform different functions. | Pin number | | Pin name | Sensor hub function | Description | | |------------|----|------------|---------------------|------------------------------------|--| | | 3 | SDO<br>SA0 | MSDA | I <sup>2</sup> C master data line | | | | 11 | INT2 | MSCL | I <sup>2</sup> C master clock line | | Table 15. Sensor hub pin description As summarized in Table 15. Sensor hub pin description, the sensor hub uses pin 3 as the I<sup>2</sup>C master data line and pin 11 as the I<sup>2</sup>C master clock line which necessitates the following restrictions: - 1. When the LIS2DS12 device is connected to the application processor through the SPI bus, then SPI 3-wire must be used (SDO is not available). The SIM bit in CTRL2 (21h) has to be set to 1. - 2. When the LIS2DS12 device is connected to the application processor through the I<sup>2</sup>C bus, then the SA0 pin is not available (not used by the sensor hub) and it internally defaults to '0'. As a consequence, when the sensor hub is enabled, only one and not two LIS2DS12 devices can be attached to the application processor (with I<sup>2</sup>C 7-bit address format 1Eh). ### 5.10.2 Configuring the sensor hub The user can configure the sensor hub by providing the slave device address, the address of the register to be accessed, if the operation is a read or a write and the number of bytes to read (for a read operation) or the byte to write (for a write operation). The advanced configuration registers (accessible when the FUNC\_CFG\_EN bit of the CTRL2 register is set to 1) used to configure the I<sup>2</sup>C slave interface associated to the external sensor are described hereafter. | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | |---------|---------|---------|---------|---------|---------|--------|------| | Slave0_ | Slave0_ | Slave0_ | Slave0_ | Slave0_ | Slave0_ | Slave0 | nu 0 | | add6 | add5 | add4 | add3 | add2 | add1 | add0 | rw_0 | Table 16. SLV0\_ADD (30h) register - Slave0 add[6:0] bits are used to indicate the I<sup>2</sup>C slave address of the external sensor - The rw\_0 bit configures the read/write operation to be performed on the external sensor (0: write operation; 1: read operation). The read/write operation is executed when the next sensor hub trigger event occurs. AN4748 - Rev 5 page 32/56 ### Table 17. SLV0\_SUBADD (31h) register | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | |---------|---------|---------|---------|---------|---------|---------|---------| | Slave0_ | reg7 | reg6 | reg5 | reg4 | reg3 | reg2 | reg1 | reg0 | • Slave0\_reg[7:0] bits are used to indicate the address of the external sensor register to be written (if the rw\_0 bit of the SLV0\_ADD register is set to 0) or to be read (if the rw\_0 bit of the SLV0\_ADD register is set to 1). Table 18. SLV0\_CONFIG (32h) register | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | |----|----|----|----|----|---------|---------|---------| | | | | | | Slave0_ | Slave0_ | Slave0_ | | _ | - | - | - | - | numop2 | numop1 | numop0 | Slave0\_numop[2:0] bits are dedicated to defining the number of consecutive read operations to be performed on the first external sensor starting from the register address indicated in the SLV0\_SUBADD register. Table 19. DATAWRITE\_SLV0 (33h) register | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | |---------|---------|---------|---------|---------|---------|---------|---------| | Slave0_ | dataw7 | dataw6 | dataw5 | dataw4 | dataw3 | dataw2 | dataw1 | dataw0 | Slave\_dataw[7:0] bits are dedicated, when the rw\_0 bit of SLV0\_ADD register is set to 0 (write operation), to indicating the data to be written to the external sensor at the address specified in the SLV0\_SUBADD register. The LIS2DS12 device provides optional internal pull-ups on the $I^2C$ clock and data lines for proper $I^2C$ functionality. To enable the internal pull-ups the user has to set the TUD\_EN bit of the FUNC\_CTRL register. Table 20. FUNC\_CTRL (3Fh) register | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | |----|----|--------|------|-----|--------|---------|--------| | | | MODULE | TILT | TUD | MASTER | SIG_MOT | STEP_ | | - | - | _ON | _ON | _ON | _ON | _ON | CNT_ON | AN4748 - Rev 5 page 33/56 #### 5.10.3 Enabling the sensor hub The sensor hub functionality is turned on by setting the MASTER ON bit in register FUNC CTRL to logic '1'. Table 21. FUNC CTRL (3Fh) register | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | |----|----|--------|------|-----|--------|--------|--------| | | _ | MODULE | TILT | TUD | MASTER | SIG_ | STEP_ | | _ | - | _ON | _ON | _ON | _ON | MOT_ON | CNT_ON | As soon as the sensor bub is enabled, it starts generating I<sup>2</sup>C transactions on the bus in accordance to user configuration in the advanced configuration registers. It loops on a given configuration until the sensor hub is disabled (MASTER\_ON to logic '0'). At the beginning of each loop the sensor hub sets the SENSORHUB\_END\_OP bit of the FUNC\_SRC register to logic '0'. Then it initiates the I<sup>2</sup>C transaction and at the end of it, sets the SENSORHUB\_END\_OP bit to logic '1'. Table 22. FUNC\_SRC (3Eh) register | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | |----|----|----|----|----|------|---------|-----------| | | | | | | RST_ | MODULE_ | SENSORHUB | | - | - | - | - | - | TILT | READY | _END_OP | Moreover, the bit that indicates when a sensor hub operation has been completed can optionally be routed on INT1 by setting to '1' the INT1\_MASTER\_DRDY bit of CTRL4 register. Table 23. CTRL4 (23h) register | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | |--------------------------|----------------|-------------|-------------|--------------|-------------|--------------|---------------| | INT1_<br>MASTER_<br>DRDY | INT1_<br>S_TAP | INT1_<br>WU | INT1_<br>FF | INT1_<br>TAP | INT1_<br>6D | INT1_<br>FTH | INT1_<br>DRDY | # 5.10.4 Reading samples from the sensor hub Once the auxiliary I<sup>2</sup>C master is enabled, for the external sensor it reads a number of registers equal to the value of the Slave0\_numop field, starting from the register address specified in the SLV0\_SUBADD register. Read data are consecutively stored (in the same order they are read) in the registers starting from SENSORHUB1\_REG. So, a maximum of 6 bytes can be read. Table 24. Sensor hub registers | Register name | Addr | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 | |----------------|------|---------|---------|---------|---------|---------|---------|---------|---------| | SENSORHUB1_REG | 06h | SHub1_7 | SHub1_6 | SHub1_5 | SHub1_4 | SHub1_3 | SHub1_2 | SHub1_1 | SHub1_0 | | SENSORHUB2_REG | 07h | SHub2_7 | SHub2_6 | SHub2_5 | SHub2_4 | SHub2_3 | SHub2_2 | SHub2_1 | SHub2_0 | | SENSORHUB3_REG | 08h | SHub3_7 | SHub3_6 | SHub3_5 | SHub3_4 | SHub3_3 | SHub3_2 | SHub3_1 | SHub3_0 | | SENSORHUB4_REG | 09h | SHub4_7 | SHub4_6 | SHub4_5 | SHub4_4 | SHub4_3 | SHub4_2 | SHub4_1 | SHub4_0 | | SENSORHUB5_REG | 0Ah | SHub5_7 | SHub5_6 | SHub5_5 | SHub5_4 | SHub5_3 | SHub5_2 | SHub5_1 | SHub5_0 | | SENSORHUB6_REG | 0Bh | SHub6_7 | SHub6_6 | SHub6_5 | SHub6_4 | SHub6_3 | SHub6_2 | SHub6_1 | SHub6_0 | AN4748 - Rev 5 page 34/56 ### 5.10.5 Sensor hub example This section provides an example of how to use the sensor hub, assuming that an LIS3MDL magnetometer is used as external sensor. This example assumes also that the LIS2DS12 internal accelerometer is enabled at any ODR value. Reading the LIS3MDL WhoAml register ``` /* Configure advanced configuration registers * 1. Write 15h in 21h // set FUNC_CFG_EN to 1 to access // advanced configuration registers 2. Write 3Dh in 30h // LIS3MDL I2C addr in SLV0_ADD + R mode 3. Write 0Fh in 31h // WHO_AM_I addr in SLV0_SUBADD 4. Write 01h in 32h // 1 byte to read 5. Write 00h in 3Fh // Set FUNC_CFG_EN to 0 to disable access of advanced configuration registers. Please note that all bits but 4<sup>th</sup> are read-only. /* Control sensor hub activity */ 6. Write 0Ch in 3Fh // Enable sensor hub + pull-ups 7. Wait for bit0 equal to 1 in 3Eh // SENSORHUB END OP equals 1 8. Read 06h // WAI reg is in SENSORHUB1_REG 9. Write 00h in 3Fh // Disable sensor hub ``` #### Programming the LIS3MDL device ``` /* Configure advanced configuration registers * ``` 1. Write 15h in 21h // set FUNC\_CFG\_EN to 1 to access // advanced configuration regs 2. Write 3Ch in 30h // LIS3MDL I2C addr in SLV0\_ADD + W mode 3. Write 22h in 31h // CTRL3 reg addr in SLV0\_SUBADD 4. Write 01h in 32h // 1 byte to write 5. Write 00h in 33h // LIS3MDL in continuous conversion mode 6 Write 00h in 3Fh // Set FUNC\_CFG\_EN to 0 to disable access of advanced configuration registers. Please note that all bits but 4<sup>th</sup> are read-only. /\* Control sensor hub activity \*/ 7. Write 0Ch in 3Fh // Enable sensor hub + pull-ups 8. Wait for bit0 equal to 1 in 3Eh // SENSORHUB\_END\_OP equals 1 9. Write 00h in 3Fh // Disable sensor hub # Reading LIS3MDL samples /\* Configure advanced configuration registers \* 1. Write 15h in 21h // set FUNC\_CFG\_EN to 1 to access // advanced configuration registers AN4748 - Rev 5 page 35/56 | 2. Write 3Dh in 30h | // LIS3MDL I2C addr in SLV0_ADD + R mode | |------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------| | 3. Write 28h in 31h | // LIS3MDL OUT_X_L reg addr | | 4. Write 06h in 32h | // 6 bytes to read | | 5. Write 00h in 3Fh | // Set FUNC_CFG_EN to 0 to disable access of advanced configuration registers. Please note that all bits but 4 <sup>th</sup> are read-only. | | /* Control sensor hub activity */ | | | 6. Write 0Ch in 3Fh | // Enable sensor hub + pull-ups | | 7. Wait for bit0 equal to 1 in 3Eh | // SENSORHUB_END_OP equals 1 | | 8. Read 06h | // X_L in SENSORHUB1_REG | | 9. Read 07h | // X_H in SENSORHUB1_REG | | 10. Read 08h | // Y_L in SENSORHUB1_REG | | 11. Read 09h | // Y_H in SENSORHUB1_REG | | 12. Read 0Ah | // Z_L in SENSORHUB1_REG | | 13. Read 0Bh | // Z_H in SENSORHUB1_REG | | | | As long as the sensor hub is enabled, it keeps reading data from LIS3MDL at the trigger frequency (maximum is 100 Hz). AN4748 - Rev 5 page 36/56 ## 6 First-in first-out (FIFO) buffer In order to limit intervention by the host processor and facilitate post-processing data for events recognition, the LIS2DS12 embeds a first-in, first-out buffer (FIFO) for each of the three output channels, X, Y, and Z. FIFO use allows consistent power saving for the system, it can wake up only when needed and burst the significant data out from the FIFO. The FIFO buffer can work according to five different modes that guarantee a high level of flexibility during application development: Bypass mode, FIFO mode, Continuous mode, Bypass-to-Continuous and Continuous-to-FIFO mode. A programmable watermark level and the FIFO\_FULL event can be enabled to generate dedicated interrupts on the INT1 pin. ## 6.1 FIFO description The FIFO buffer is able to store up to 256 acceleration samples of 14 bits for each channel or store the output of the acceleration module computation up to 768 entries (see Section 6.4 Module-to-FIFO); data are stored in the 14-bit 2's complement left-justified representation, which means that they always have to be right-shifted by two. The data sample set consists of 6 bytes (XI, Xh, YI, Yh, ZI, and Zh) and they are released to the FIFO at the selected output data rate (ODR). The new sample set is placed in the first empty FIFO slot until the buffer is full, therefore, the oldest value is overwritten. | Output | 28h | 29h | 2Ah | 2Bh | 2Ch | 2Dh | | | | |------------|---------|-----------------|---------|---------|---------|---------|--|--|--| | registers | ΧI | Xh | YI | Yh | ZI | Zh | | | | | FIFO index | | FIFO sample set | | | | | | | | | FIFO(0) | XI(0) | Xh(0) | YI(0) | Yh(0) | ZI(0) | Zh(0) | | | | | FIFO(1) | XI(1) | Xh(1) | YI(1) | Yh(1) | ZI(1) | Zh(1) | | | | | FIFO(2) | XI(2) | Xh(2) | YI(2) | Yh(2) | ZI(2) | Zh(2) | | | | | FIFO(3) | XI(3) | Xh(3) | YI(3) | Yh(3) | ZI(3) | Zh(3) | | | | | | | | | | | | | | | | FIFO(254) | XI(254) | Xh(254) | YI(254) | Yh(254) | ZI(254) | Zh(254) | | | | | FIFO(255) | XI(255) | Xh(255) | YI(255) | Yh(255) | ZI(255) | Zh(255) | | | | Table 25. FIFO buffer full representation (256th sample set stored) Table 26. FIFO buffer full representation (257<sup>th</sup> sample set stored and 1<sup>st</sup> sample discarded) | Output | 28h | 29h | 2Ah | 2Bh | 2Ch | 2Dh | |------------|---------|---------|---------|---------|---------|---------| | registers | ΧI | Xh | YI | Yh | ZI | Zh | | FIFO index | | | Samp | ole set | | | | FIFO(0) | XI(1) | Xh(1) | YI(1) | Yh(1) | ZI(1) | Zh(1) | | FIFO(1) | XI(2) | Xh(2) | YI(2) | Yh(2) | ZI(2) | Zh(2) | | FIFO(2) | XI(3) | Xh(3) | YI(3) | Yh(3) | ZI(3) | Zh(3) | | FIFO(3) | XI(4) | Xh(4) | YI(4) | Yh(4) | ZI(4) | Zh(4) | | | | | | | | | | FIFO(255) | XI(256) | Xh(256) | YI(256) | Yh(256) | ZI(256) | Zh(256) | AN4748 - Rev 5 page 37/56 Table 25. FIFO buffer full representation (256<sup>th</sup> sample set stored) represents the FIFO full status when 256 samples are stored in the buffer while Table 26. FIFO buffer full representation (257<sup>th</sup> sample set stored and 1<sup>st</sup> sample discarded) represents the next step when the 257<sup>th</sup> sample is inserted into FIFO and the 1<sup>st</sup> sample is overwritten. The new oldest sample set is made available in the output registers. When FIFO is enabled and the mode is different from Bypass, the LIS2DS12 output registers (28h to 2Dh) always contain the oldest FIFO sample set. ### 6.2 FIFO registers The FIFO buffer is managed by four different accelerometer registers, two of these allow enabling and configuring the FIFO behavior, the other two provide information about the buffer status. A few other registers are used to route FIFO events on the pin to interrupt the application processor. These are discussed in Section 6.3 FIFO interrupts. #### 6.2.1 FIFO\_CTRL (25h) The FIFO\_CTRL register contains the mode at which the FIFO is set. At reset by default the FIFO mode is Bypass which means off; the FIFO gets enabled and starts storing the samples (or the module) as soon as the mode is set to a mode other than Bypass. | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | |--------|--------|--------|-------|-----------|----|----|--------| | | | | INT2_ | | | | | | FMODE2 | FMODE1 | FMODE0 | STEP_ | MODULE_TO | 0 | 0 | IF_CS_ | | FWODE2 | | | COUNT | _FIFO | U | U | PU_DIS | | | | | _OV | | | | | Table 27. FIFO\_CTRL register The FMODE[2:0] bits select the FIFO buffer behavior: - 1. FMODE[2:0] = 000b: Bypass mode (FIFO turned off) - 2. FMODE[2:0] = 001b: FIFO mode - 3. FMODE[2:0] = 011b: Continuous-to-FIFO mode - 4. FMODE[2:0] = 100b: Bypass-to-continuous mode - 5. FMODE[2:0] = 110b: Continuous mode MODULE\_TO\_FIFO enables the module of the X/Y/Z samples ( $sqrt(x^2+y^2+z^2)$ ) to go in FIFO instead of the samples themselves. Please note that the MODULE\_ON bit of the FUNC\_CTRL register must be on. When the MODULE\_ON bit is set to 1, the embedded functions (pedometer, tilt and significant motion) are not available. ## 6.2.2 FIFO\_THS (2Eh) This register may be used to set the FIFO threshold level. Table 28. FIFO\_THS register | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | |------|------|------|------|------|------|------|------| | FTH7 | FTH6 | FTH5 | FTH4 | FTH3 | FTH2 | FTH1 | FTH0 | The FTH[7:0] bits define the watermark level; when FIFO content is greater than or equal to this value, the FTH bit is set to "1" in the FIFO\_SRC register. AN4748 - Rev 5 page 38/56 #### 6.2.3 FIFO\_SRC (2Fh) This register is updated at every ODR and provides information about the FIFO buffer status. Table 29. FIFO\_SRC register | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | |-----|--------------|-------|----|----|----|----|----| | FTH | FIFO_<br>OVR | DIFF8 | 0 | 0 | 0 | 0 | 0 | - FTH bit is set high when FIFO content exceeds watermark level. This flag can be routed to the pin (see Section 6.3 FIFO interrupts). - FIFO\_OVR bit is set high when the first sample is overwritten after the FIFO buffer is full. This means that the FIFO buffer contains 256 unread samples. The FIFO\_OVR bit is reset when the first sample set has been read. - DIFF8 bit (or FIFO\_FULL bit) is used together with bits of FIFO\_SAMPLES (DIFF[7:0]) to provide information of how many FIFO entries are used (000000000b means FIFO empty, 100000000b means FIFO full). This flag can be routed to the pin (see Section 6.3 FIFO interrupts). The register content is updated synchronous to the FIFO write and read operation. Table 30. FIFO\_SRC behavior assuming FTH[7:0] = 15 | FTH | DIFF8<br>(FIFO_FULL) | FIFO_OVR | DIFF[8:0] | Unread FIFO samples | Timing | |-----|----------------------|----------|-----------|---------------------|--------------| | 0 | 0 | 0 | 000000000 | 0 | t0 | | 0 | 0 | 0 | 00000001 | 1 | t0 + 1/ODR | | 0 | 0 | 0 | 00000010 | 2 | t0 + 2/ODR | | | | | | | | | 0 | 0 | 0 | 000001110 | 14 | t0 + 14/ODR | | 1 | 0 | 0 | 000001111 | 15 | t0 + 15/ODR | | | | | | | | | 1 | 0 | 0 | 011111111 | 255 | t0 + 255/ODR | | 1 | 1 | 0 | 100000000 | 256 | t0 + 256/ODR | | 1 | 1 | 1 | 10000000 | 256 | t0 + 257/ODR | ### 6.2.4 FIFO\_SAMPLES (30h) The content of this register is used together with the DIFF8 bit of the FIFO\_SRC register (DIFF[7:0]) to provide information of how many FIFO entries are used (000000000b means FIFO empty, 1000000000b means FIFO full). Table 31. FIFO\_SAMPLES register | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | |-------|-------|-------|-------|-------|-------|-------|-------| | DIFF7 | DIFF6 | DIFF5 | DIFF4 | DIFF3 | DIFF2 | DIFF1 | DIFF0 | AN4748 - Rev 5 page 39/56 ### 6.3 FIFO interrupts There are two specific FIFO events that can be routed to the pin in order to interrupt the main processor: FIFO threshold and FIFO full. The third FIFO event, FIFO\_OVR, cannot be routed on the pin, but can instead be polled by reading the corresponding bit in the FIFO\_SRC register. #### 6.3.1 FIFO threshold The FIFO threshold is a configurable feature that can be used to generate a specific interrupt in order to know when the FIFO buffer contains at least the number of samples defined as the threshold level. The user can select the desired level in a range from 0 to 255 using the FTH[7:0] field in the FIFO\_THS register. If the number of entries in FIFO (DIFF[8:0]) is greater than or equal to the value programmed in FTH[7:0], the FTH bit is set high in the FIFO\_SRC register. DIFF[8:0] increases by one step at the ODR frequency and decreases by one step every time that a sample set reading is performed by the user. The threshold flag (FTH) can be routed to the INT1 and INT2 pin to provide a dedicated interrupt for the application processor that can consume less power between each interrupt. The INT1\_FTH bit of CTRL4 register and the INT2\_FTH bit of CTRL5 register are dedicated to this task. #### 6.3.2 FIFO FULL It is possible to configure the device to generate an interrupt whenever the FIFO gets full. To do so just set the INT1\_FSS7 bit of the WAKE\_UP\_DUR register to '1'. To avoid losing samples, the FIFO reading operation must start and complete inside 1 ODR window. #### 6.4 Module-to-FIFO If the module computation is on (MODULE\_ON bit of FUNC\_CTRL register is '1') and the MODULE\_TO\_FIFO bit of FIFO\_CTRL is set to '1', then the FIFO buffer will not contain the acceleration samples but instead the computation of their module ( $\sqrt{(x^2+y^2+z^2)}$ ). Since the module is a number of 14-bit in size, the FIFO buffer may contain up to 768 module entries (256 \* 3). When the module is stored in FIFO, the threshold set in FIFO\_THS and the number of stored data available in the FIFO SAMPLES register are represented by 1LSb = 3 samples. The Module-to-FIFO functionality cannot be enabled if one of the embedded functions (pedometer, significant motion, tilt) is enabled. The Module-to-FIFO maximum output sensor data rate (ODR) is 800 Hz. The following is a simple procedure to enable the FIFO to contain the acceleration sample module: - 1. Set MODULE ON to 1 in FUNC CTRL (3Fh) to enable module computation - 2. Set MODULE TO FIFO bit of FIFO CTRL (25h) to '1' to save module in FIFO buffer - 3. Enable the FIFO in one of the operative modes (see Section 6.5 FIFO modes) AN4748 - Rev 5 page 40/56 #### 6.5 FIFO modes The LIS2DS12 FIFO buffer can be configured to operate in five different modes selectable by the FMODE[2:0] field in FIFO\_CTRL register. Available configurations ensure a high-level of flexibility and extend the number of functions usable in application development. Bypass, FIFO, Continuous, Bypass-to-Continuous and Continuous-to-FIFO modes are described in the following paragraphs. #### 6.5.1 Bypass mode When Bypass mode is enabled, the FIFO is not operational: buffer content is cleared, output registers (0x28 to 0x2D) are frozen at the last value loaded, and the FIFO buffer remains empty until another mode is selected. Bypass mode is activated by setting the FMODE[2:0] field to 000b in the FIFO\_CTRL register. Bypass mode must be used in order to stop and reset the FIFO buffer when a different mode is operating. Note that placing the FIFO buffer into Bypass mode clears the whole buffer content. #### 6.5.2 FIFO mode In FIFO mode, the buffer continues filling until full (256 sample set stored). As soon as the FIFO\_OVR flag gets to '1', the FIFO stops collecting data and its content remains unchanged until a different mode is selected. FIFO mode is activated by setting the FMODE[2:0] field to 001b in the FIFO CTRL register. By selecting this mode, FIFO starts data collection and DIFF[8:0] changes according to the number of samples stored. At the end of the procedure, the FIFO\_OVR flag rises to 1, and data can then be retrieved, performing a 256 sample set reading from the output registers. Communication speed is not so important in FIFO mode because data collection is stopped and there is no risk of overwriting acquired data. Before restarting FIFO mode, at the end of the reading procedure it is necessary to exit Bypass mode. In order to serve the FIFO\_FULL event as soon as possible, it is recommended to route it to the pin in order to generate an interrupt, which will then be managed by a specific handler: - 1. Set INT1\_FSS7 to '1': Enables FIFO\_FULL interrupt - 2. Set FMODE[2:0] = 001b: Enables FIFO mode When the FIFO FULL interrupt is generated or the FIFO OVR bit is high (polling mode): 1. Read data from the accelerometer output registers Figure 13. FIFO mode behavior As indicated in Figure 13. FIFO mode behavior, when FIFO mode is enabled, the buffer starts to collect data and fills all the 256 slots (from F0 to F255) at the selected output data rate. When the buffer is full, as the next sample comes in and overrides the buffer, the FIFO\_OVR bit goes high and data collection is permanently stopped; the AN4748 - Rev 5 page 41/56 user can decide to read FIFO content at any time because it is maintained unchanged until Bypass mode is selected. The reading procedure may be performed inside an interrupt handler triggered by a FIFO\_FULL condition (DIFF8) and it is composed of a 256 sample set of 6 bytes for a total of 1236 bytes and retrieves data starting from the oldest sample stored in FIFO (F0). The FIFO\_OVR bit is reset when the first sample set has been read. The Bypass mode setting resets FIFO and allows the user to enable FIFO mode again. #### 6.5.3 Continuous mode In Continuous mode FIFO continues filling, when the buffer is full, the FIFO index restarts from the beginning and older data is replaced by current data. The oldest values continue to be overwritten until a read operation frees FIFO slots. The host processor reading speed is most important in order to free slots faster than new data is made available. FMODE[2:0] in Bypass configuration is used to stop this mode. Follow these steps for FIFO Continuous configuration which sets a threshold to generate an interrupt to trigger a read by the application processor: - 1. Set FTH[7:0] to 255. - 2. Set INT2\_FTH to '1': Enable FIFO threshold interrupt - 3. Activate Continuous mode by setting the FMODE[2:0] field to 110b in the FIFO\_CTRL register (25h). When the FTH interrupt is generated, data is read from the accelerometer output registers. Figure 14. Continuous mode with interrupt trigger As indicated in Figure 14. Continuous mode with interrupt trigger, when Continuous mode is enabled, the FIFO buffer is continuously filling (from F0 to F255) at the selected output data rate. When the buffer is full, the FTH interrupt (as well as the FIFO\_FULL condition indicated by the DIFF8 bit in FIFO\_SRC (2Fh), which might also be used to trigger an interrupt) goes high, and the application processor may read all FIFO samples (256 \* 6 bytes) as soon as possible to avoid loss of data and to limit intervention by the host processor which increases system efficiency. See Section 6.6 Retrieving data from FIFO for more details on FIFO reading speed. When a read command is sent to the device, the content of the output registers is moved to the SPI/I<sup>2</sup>C register and the current oldest FIFO value is shifted into the output registers in order to allow the next read operation. AN4748 - Rev 5 page 42/56 #### 6.5.4 Continuous-to-FIFO mode This mode is a combination of the Continuous and FIFO modes previously described. In Continuous-to-FIFO mode, the FIFO buffer starts operating in Continuous mode and switches to FIFO mode when the selected interrupt (e.g. wakeup, free-fall, tap, ...) occurs. This mode can be used in order to analyze the samples history that generate an interrupt; the standard operation is to read FIFO content when FIFO mode is triggered and FIFO buffer is full and stopped. Follow these steps for Continuous-to-FIFO mode configuration: - 1. Configure the desired interrupt generator by following the instructions in Section 5 Interrupt generation and embedded functions (be sure it is latched). - 2. Activate Continuous-to-FIFO mode by setting the FMODE[2:0] field to 011b in the FIFO\_CTRL register (25h). Note: When the requested event takes place, the FIFO mode change is triggered if and only if the event flag is routed to the INT1 or INT2 pin. While in Continuous mode the FIFO buffer continues filling; when the requested event takes place the FIFO mode changes; then, as soon as the buffer becomes full, the FIFO\_OVR bit is set high and the next samples overwrite the oldest and the FIFO stops collecting data (see Figure 15. Continuous-to-FIFO mode: interrupt latched and non-latched). Figure 15. Continuous-to-FIFO mode: interrupt latched and non-latched AN4748 - Rev 5 page 43/56 #### 6.5.5 Bypass-to-Continuous mode This mode is a combination of the Bypass and Continuous modes previously described. In Bypass-to-Continuous mode, the FIFO buffer starts in Bypass mode and switches to Continuous mode when the selected interrupt (e.g. wakeup, free-fall, tap, ...) occurs. Follow these steps for Bypass-to-Continuous mode configuration: - Configure desired interrupt generator by following the instructions in Section 5 Interrupt generation and embedded functions (be sure it is latched). - 2. Set FTH[7:0] to 255. - 3. Set INT2\_FTH to '1': Enables FIFO threshold interrupt - Activate Bypass-to-Continuous mode by setting the FMODE[2:0] field to 100b in the FIFO\_CTRL register (25h). When the FTH interrupt is generated, data is read from the accelerometer output registers. Figure 16. Bypass-to-Continuous mode As indicated in Figure 16. Bypass-to-Continuous mode the FIFO is initially in Bypass mode, so no samples enter in the FIFO buffer. As soon as an event occurs (e.g. a wakeup or a free-fall event) the FIFO switches to Continuous mode and starts to store the samples at the configured data rate. When the programmed threshold is reached, the FTH interrupt goes high, and the application processor may start reading all FIFO samples (256 \* 6 bytes) as soon as possible to avoid loss of data. If the FIFO\_OVR flag was set, it will go to 0 as soon as the first FIFO set is read, creating space for new data. Since the FIFO is still in Continuous mode, the FIFO eventually reaches the threshold again and the situation repeats. Finally, either the interrupt event is cleared or the FIFO enters directly Bypass mode and then it stops collecting data. AN4748 - Rev 5 page 44/56 #### 6.6 Retrieving data from FIFO When the FIFO mode is different from Bypass, reading the output registers (28h to 2Dh) returns the oldest FIFO sample set. Whenever the output registers are read, their content is moved to the SPI/I<sup>2</sup>C output buffer. FIFO slots are ideally shifted up one level in order to release room for receiving a new sample and the output registers load the current oldest value stored in the FIFO buffer. The whole FIFO content is retrieved by performing 256 read operations from the accelerometer output registers. The size of the data stored in FIFO is always 14-bit regardless of the power mode. Every other read operation returns the same last value until a new sample set is available in the FIFO buffer. Data can be retrieved from FIFO using every reading byte combination in order to increase application flexibility (ex: 1536 single byte read, 256 reads of 6 bytes, 1 multiple read of 1536 bytes, etc.). It is recommended to read all FIFO slots in a multiple byte reading of 1536 bytes (6 output registers by 256 slots). In order to minimize communication between the master and slave the reading address may be automatically incremented by the device by setting the IF\_ADD\_INC bit of CTRL2 register to '1'; the device rolls back to 0x28 when register 0x2D is reached. The I<sup>2</sup>C speed is lower than SPI and it needs about 29 clock pulses to start communication (Start, Slave Address, Register Address+Write, Restart, Register Address+Read) plus an additional 9 clock pulses for every byte to read (total of 83 clock pulses). So, in the case of standard I<sup>2</sup>C mode being used (max rate 100 kHz), a single sample set reading takes 830 µs while total FIFO download takes about 138.53 ms (29 + 9 \* 1536 clock pulses). In the case of the SPI, instead, 9 clock pulses are required only once at the very beginning to get started (r/w + Register Address) plus additional 8 clock pulses for every byte to read. With a 2 MHz clock a single sample set reading would take 28.5 $\mu$ s, while total FIFO download takes about 6.15 ms. If this recommendation were followed, using a standard $I^2C$ (100 kHz) the complete FIFO reading (138.53 ms) is taking 14/ODR with ODR at 100 Hz. Using a SPI @2 MHz (10 MHz is the maximum supported by the device) the complete FIFO reading would take 1/ODR with ODR at 100 Hz. So, in order to not lose samples, the application will read samples before the FIFO becomes full, setting a threshold and using the FTH interrupt (see section Section 6.3 FIFO interrupts). FTH THS FTH THS FTH THS ODR (Hz) (SPI @ 2 MHz) (I<sup>2</sup>C @ 100 kHz) (I<sup>2</sup>C @ 400 kHz) 147 50 36 256 100 17 73 256 8 208 200 36 400 4 17 103 800 1 8 51 1600 4 25 Table 32. Example: threshold function of ODR AN4748 - Rev 5 page 45/56 ## 7 Temperature sensor The LIS2DS12 is provided with an internal temperature sensor that is suitable for ambient temperature measurement. If the accelerometer sensor is in power-down mode, the temperature sensor is off and is showing the last value measured. The output data rate of temperature sensor is fixed at 12.5 Hz. The temperature data is given by the OUT\_T register and it is represented as a number of 8 bits in two's complement format, with a sensitivity of +1 LSB/°C. The output zero level corresponds to 25 °C ±15 °C. ## 7.1 Example of temperature data calculation Table 33. Output data registers content vs. temperature provides a few basic examples of the data that is read from the temperature data registers at different ambient temperature values. The values listed in this table are given under the hypothesis of perfect device calibration (i.e. no offset, no gain error,...). Table 33. Output data registers content vs. temperature | Temperature values | OUT_T (26h) | |--------------------|-------------| | 23 °C | FEh | | 24 °C | FFh | | 25 °C | 00h | | 27 °C | 02h | AN4748 - Rev 5 page 46/56 ## 8 Self-test The embedded self-test functions allows checking device functionality without moving it. #### 8.1 Accelerometer self-test When the accelerometer self-test is enabled, an actuation force is applied to the sensor, leading to a deflection of the moveable part of the sensor and generates an acceleration. In this case the sensor outputs exhibit a change in their DC levels which are related to the selected full scale through the sensitivity value. The accelerometer self-test function is off when the ST[2:1] bits of the CTRL3 register are programmed to 00b; it is enabled when the ST[2:1] bits are set to 01b (positive sign self-test) or 10b (negative sign self-test). When the accelerometer self-test is activated, the sensor output level is given by the algebraic sum of the signals produced by the acceleration acting on the sensor and by the electrostatic test-force. The procedure consists of: - 1. enabling the accelerometer - 2. averaging five samples before enabling the self-test - 3. averaging five samples after enabling the self-test - 4. computing the difference in module for each axis and verify it falls in a given range. The min and max value are provided in the datasheet. The complete accelerometer self-test procedure is indicated in Figure 17. Accelerometer self-test procedure. Note: Keep the device still during the self-test procedure. AN4748 - Rev 5 page 47/56 Figure 17. Accelerometer self-test procedure ``` * Initialize Sensor: * Set BDU=1, FS=2G, ODR = 50Hz Check DRDY in STATUS (27h) Write 31h to CTRL1 (20h) wait for 200ms for stable output → Discard data /* Read/discard first set of samples BEFORE Self Test */ Check DRDY in STATUS (27h) Loop 5 time { Read OUTX (28h/29h), OUTY (2Ah/2Bh), OUTZ (2Ch/2Dh) → Discard data /* Read five set of samples BEFORE enabling Self Test */ Loop 5 time { OUTX_AVG_ST Check DRDY in STATUS (27h) OUTY_AVG_ST Read OUTX (28h/29h), OUTY (2Ah/2Bh), OUTZ (2Ch/2Dh) OUTZ_AVG_ST /* Calculate average of the 5 read for each axis */ OUTX_AVG_NO_ST OUTY_AVG_NO_ST OUTZ_AVG_NO_ST /* Enable positive-sign Self Test */ Write 01h to ST[2:1] of CTRL3 (22h) YES (PASS) Wait for 200ms for stable output ``` ``` /* Read/discard first set of samples AFTER Self Test */ Read OUTX (28h/29h), OUTY (2Ah/2Bh), OUTZ (2Ch/2Dh) /* Read five set of samples AFTER enabling Self Test */ Check DRDY in STATUS (27h) Read OUTX (28h/29h), OUTY (2Ah/2Bh), OUTZ (2Ch/2Dh) /* Calculate average of the 5 read for each axis */ |Min(ST_X)| <=|OUTX_AVG_ST - OUTX_AVG_NO_ST| <= |Max(ST_X)| AND |Min(ST_Y)<=| OUTY_AVG_ST - OUTY_AVG_NO_ST | <= |Max(ST_Y)| AND |Min(ST_Z)| \le |OUTZ_AVG_ST - OUTZ_AVG_NO_ST| \le |MAX(ST_Z)| NO (FAIL) Write 00h to CTRL1 (20h): /* Disable sensor */ Write 00h to CTRL3 (22h): /* Disable self test */ ``` ## **Revision history** Table 34. Document revision history | Date | Revision | Changes | |-------------|----------|----------------------------------------------------------------------------------------------------------------------| | 05-Nov-2015 | 1 | Initial release | | | | Updated: Section 1 "Introduction", | | | | Table 1: "Registers", | | | | Section 3.4: "Accelerometer bandwidth" and Figure 1: "Accelerometer sampling chain diagram", | | | | Section 3.4.1: "Accelerometer slope filter", | | | | Section 4.3: "Using the data-ready signal" and Figure 3: "Data-ready" signal , | | | | Section 4.4: " Using the block data update (BDU) feature", | | | | Section 4.5: "Understanding output data", | | | | Section 4.5.1: "Example of output data", | | | | Section 5: "Interrupt generation and embedded functions", | | | | Section 5.1: "Interrupt pin configuration", | | | | Section 5.3: "Free-fall interrupt", | | | | Section 5.4: "Wake-up interrupt", | | | | Section 5.5.1: "6D orientation" and Figure 6: "6D recognized orientations , | | | | Section 5.6.2: "Double tap" and Figure 8: "Double-tap event recognition (LIR bit = 0), | | | | Section 5.6.3: "Single-tap and double-tap recognition configuration, | | | | Section 5.6.4: "Single-tap example", | | 10-May-2017 | 2 | Section 5.6.5: "Double-tap example", | | | | Section 5.7: "Activity/Inactivity recognition" and Figure 10: "Activity/Inactivity recognition", | | | | Section 5.9: "Embedded functions", | | | | Section 5.9.1: "Pedometer functions: step detector and step counter", | | | | Section 5.9.2: "Significant motion", | | | | Section 5.10.1: "Sensor hub pin description", | | | | Section 5.10.5: "Sensor hub example", | | | | Section 6.2.1: "FIFO_CTRL (25h), | | | | Section 6.2.3: "FIFO_SRC (2Fh), | | | | Section 6.2.4: "FIFO_SAMPLES (30h), | | | | Section 6.3: "FIFO interrupts", | | | | Section 6.3.2: "FIFO FULL", | | | | Section 6.5.2: "FIFO mode" and Figure 12: "FIFO mode behavior", | | | | Section 6.5.3: "Continuous mode", | | | | Section 6.5.4: "Continuous-to-FIFO mode" and Figure 14: "Continuous-to-FIFO mode: interrupt latched and non-latched, | | | | Section 6.5.5: "Bypass-to-Continuous mode" | | | | Section 6.6: "Retrieving data from FIFO", | | | | and Section 7: "Temperature sensor" | AN4748 - Rev 5 page 49/56 | Date | Revision | Changes | |-------------|----------|---------------------------------------------------------------------------| | 12-Jan-2018 | | Added Section 2: "Pin description" | | | 3 | Updated Figure 2: "Accelerometer sampling chain" | | | 3 | Updated Figure 4: "Data-ready signal" | | | | Updated Figure 11: "Activity/Inactivity recognition" | | | | Updated Section 5.9.1 Pedometer functions: step detector and step counter | | 06-Sep-2018 | 4 | Updated Section 5.9.2 Significant motion | | | | Updated Section 6.4 Module-to-FIFO | | 10-Sep-2018 | 5 | Minor textual updates | AN4748 - Rev 5 page 50/56 ## **Contents** | 1 | tion | 2 | | | | | | | | | |---|-------|-------------------------------------------|-----------------------------------------------------|----|--|--|--|--|--|--| | 2 | Regi | sters | | 3 | | | | | | | | | 2.1 | Advand | ced configuration registers | 5 | | | | | | | | 3 | Ope | Operating modes6 | | | | | | | | | | | 3.1 | Power- | -down | 7 | | | | | | | | | 3.2 | High-re | esolution/high-frequency mode | 7 | | | | | | | | | 3.3 | Low-po | ower mode | 7 | | | | | | | | | 3.4 | Accele | rometer bandwidth | 8 | | | | | | | | | | 3.4.1 | Accelerometer slope filter | 9 | | | | | | | | 4 | Read | ding out | tput data | 10 | | | | | | | | | 4.1 | Startup | o sequence | 10 | | | | | | | | | 4.2 | Using t | the status register | 10 | | | | | | | | | 4.3 | Using the data-ready signal | | | | | | | | | | | 4.4 | Using the block data update (BDU) feature | | | | | | | | | | | 4.5 | Unders | standing output data | 11 | | | | | | | | | | 4.5.1 | Example of output data | 12 | | | | | | | | 5 | Inter | rupt ge | neration and embedded functions | 13 | | | | | | | | | 5.1 | Interru | pt pin configuration | 14 | | | | | | | | | 5.2 | Event | status | 15 | | | | | | | | | 5.3 | Free-fa | all interrupt | 15 | | | | | | | | | 5.4 | Wake-ı | up interrupt | 16 | | | | | | | | | 5.5 | 6D/4D | orientation detection | 17 | | | | | | | | | | 5.5.1 | 6D orientation detection | 18 | | | | | | | | | | 5.5.2 | 4D orientation detection | 19 | | | | | | | | | 5.6 | Single- | -tap and double-tap recognition | 20 | | | | | | | | | | 5.6.1 | Single tap | 21 | | | | | | | | | | 5.6.2 | Double tap | 22 | | | | | | | | | | 5.6.3 | Single-tap and double-tap recognition configuration | 22 | | | | | | | | | | 5.6.4 | Single-tap example | 24 | | | | | | | | | | 5.6.5 | Double-tap example | 25 | | | | | |---|--------|------------------------------|-----------------------------------------------------|------|--|--|--|--| | | 5.7 | Activity/ | Inactivity recognition | 26 | | | | | | | 5.8 | Boot sta | atus | 28 | | | | | | | 5.9 | Embedo | ded functions | 28 | | | | | | | | 5.9.1 | Pedometer functions: step detector and step counter | 28 | | | | | | | | 5.9.2 | Significant motion | 30 | | | | | | | | 5.9.3 | Tilt | 31 | | | | | | | 5.10 | Sensor | hub | 31 | | | | | | | | 5.10.1 | Sensor hub pin description | 32 | | | | | | | | 5.10.2 | Configuring the sensor hub | 32 | | | | | | | | 5.10.3 | Enabling the sensor hub | 34 | | | | | | | | 5.10.4 | Reading samples from the sensor hub | 34 | | | | | | | | 5.10.5 | Sensor hub example | 34 | | | | | | 6 | First- | in first-out (FIFO) buffer37 | | | | | | | | | 6.1 | 6.1 FIFO description | | | | | | | | | 6.2 | FIFO re | gisters | . 38 | | | | | | | | 6.2.1 | FIFO_CTRL register (25h) | . 38 | | | | | | | | 6.2.2 | FIFO_THS register (2Eh) | . 38 | | | | | | | | 6.2.3 | FIFO_SRC (2Fh) | 38 | | | | | | | | 6.2.4 | FIFO_SAMPLES (30h) | 39 | | | | | | | 6.3 | FIFO in | terrupts | 40 | | | | | | | | 6.3.1 | FIFO threshold | 40 | | | | | | | | 6.3.2 | FIFO FULL | 40 | | | | | | | 6.4 | Module- | -to-FIFO | 40 | | | | | | | 6.5 | FIFO m | odes | 41 | | | | | | | | 6.5.1 | Bypass mode | 41 | | | | | | | | 6.5.2 | FIFO mode | 41 | | | | | | | | 6.5.3 | Continuous mode | 42 | | | | | | | | 6.5.4 | Continuous-to-FIFO mode | . 43 | | | | | | | | 6.5.5 | Bypass-to-Continuous mode | 44 | | | | | | | 6.6 | Retrievi | ng data from FIFO | . 45 | | | | | | 7 | Temperature sensor | | | | |-----|--------------------|-----------------------------------------|------|--| | | 7.1 | Example of temperature data calculation | . 46 | | | 8 | Self-test | | | | | | 8.1 | Accelerometer self-test | . 47 | | | Rev | /ision | history | .49 | | ## **List of tables** | Table 1. | Pin description. | . 2 | |-----------|------------------------------------------------------------------------------------------------------------|-----| | Table 2. | Registers | . 3 | | Table 3. | Advanced configuration registers | . 5 | | Table 4. | Accelerometer ODR and power mode selection | . 6 | | Table 5. | Power consumption | . 6 | | Table 6. | Accelerometer LPF1 cutoff frequency | . 8 | | Table 7. | CTRL4 register | 14 | | Table 8. | CTRL5 register | 14 | | Table 9. | Free-fall threshold LSB value | 16 | | Table 10. | 6D_SRC register | | | Table 11. | Threshold for 4D/6D function | | | Table 12. | 6D_SRC register for 6D positions | 19 | | Table 13. | TAP_SRC register | | | Table 14. | SMD threshold | | | Table 15. | Sensor hub pin description | 32 | | Table 16. | SLV0_ADD (30h) register | 32 | | Table 17. | SLV0_SUBADD (31h) register | | | Table 18. | SLV0_CONFIG (32h) register | 33 | | Table 19. | DATAWRITE_SLV0 (33h) register | 33 | | Table 20. | FUNC_CTRL (3Fh) register | 33 | | Table 21. | FUNC_CTRL (3Fh) register | | | Table 22. | FUNC_SRC (3Eh) register | 34 | | Table 23. | CTRL4 (23h) register | 34 | | Table 24. | Sensor hub registers | 34 | | Table 25. | FIFO buffer full representation (256 <sup>th</sup> sample set stored) | 37 | | Table 26. | FIFO buffer full representation (257 <sup>th</sup> sample set stored and 1 <sup>st</sup> sample discarded) | 37 | | Table 27. | FIFO_CTRL register | | | Table 28. | FIFO_THS register | 38 | | Table 29. | FIFO SRC register | 39 | | Table 30. | FIFO_SRC behavior assuming FTH[7:0] = 15 | 39 | | Table 31. | FIFO_SAMPLES register | | | Table 32. | Example: threshold function of ODR | | | Table 33. | Output data registers content vs. temperature | | | Table 34. | Document revision history | 49 | # **List of figures** | Figure 1. | Pin connections | . 2 | |------------|------------------------------------------------------------|-----| | Figure 2. | Accelerometer sampling chain | . 8 | | Figure 3. | Accelerometer slope filter | . 9 | | Figure 4. | Data-ready signal | 11 | | Figure 5. | Free-fall interrupt | 15 | | Figure 6. | Wake-up interrupt | 17 | | Figure 7. | 6D recognized orientations | 19 | | Figure 8. | Single-tap event recognition | 21 | | Figure 9. | Double-tap event recognition (LIR bit = 0) | 22 | | Figure 10. | Single and double-tap recognition (LIR bit = 0) | 23 | | Figure 11. | Activity/Inactivity recognition | 27 | | Figure 12. | Minimum threshold | 29 | | Figure 13. | FIFO mode behavior | 41 | | Figure 14. | Continuous mode with interrupt trigger | 42 | | Figure 15. | Continuous-to-FIFO mode: interrupt latched and non-latched | 43 | | Figure 16. | Bypass-to-Continuous mode | 44 | | Figure 17. | Accelerometer self-test procedure | 48 | #### **IMPORTANT NOTICE - PLEASE READ CAREFULLY** STMicroelectronics NV and its subsidiaries ("ST") reserve the right to make changes, corrections, enhancements, modifications, and improvements to ST products and/or to this document at any time without notice. Purchasers should obtain the latest relevant information on ST products before placing orders. ST products are sold pursuant to ST's terms and conditions of sale in place at the time of order acknowledgement. Purchasers are solely responsible for the choice, selection, and use of ST products and ST assumes no liability for application assistance or the design of Purchasers' products. No license, express or implied, to any intellectual property right is granted by ST herein. Resale of ST products with provisions different from the information set forth herein shall void any warranty granted by ST for such product. ST and the ST logo are trademarks of ST. All other product or service names are the property of their respective owners. Information in this document supersedes and replaces information previously supplied in any prior versions of this document. © 2018 STMicroelectronics - All rights reserved AN4748 - Rev 5 page 56/56