

### LPS22HB

Datasheet - target specification

## MEMS nano pressure sensor: 260-1260 hPa absolute digital output barometer



### Features

- 260 to 1260 hPa absolute pressure range
- Current consumption down to 4 µA
- High overpressure capability: 20x full scale
- Embedded temperature compensation
- 24-bit pressure data output
- 16-bit temperature data output
- ODR from 1 Hz to 75 Hz
- SPI and I<sup>2</sup>C interfaces
- Embedded FIFO
- Interrupt functions: Data Ready, FIFO flags, pressure thresholds
- Supply voltage: 1.7 to 3.6 V
- High shock survivability: 22,000 g
- Small and thin package
- ECOPACK<sup>®</sup> lead-free compliant

### Applications

- Altimeter and barometer for portable devices
- GPS applications
- Weather station equipment
- Sport watches

### Description

The LPS22HB is an ultra-compact piezoresistive absolute pressure sensor which functions as a digital output barometer. The device comprises a sensing element and an IC interface which communicates through I<sup>2</sup>C or SPI from the sensing element to the application.

The sensing element, which detects absolute pressure, consists of a suspended membrane manufactured using a dedicated process developed by ST.

The LPS22HB is available in a full-mold, holed LGA package (HLGA). It is guaranteed to operate over a temperature range extending from -40 °C to +85 °C. The package is holed to allow external pressure to reach the sensing element.

# Order codesTemperature range [°C]PackagePackingLPS22HBTR-40 to +85°CHLGA-10LTape and reelLPS22HB-40 to +85°CHLGA-10LTray

Table 1. Device summary

#### DocID027083 Rev 1

1/37

### Contents

| 1 | Block  | diagra                 | m and pin description6                        |
|---|--------|------------------------|-----------------------------------------------|
| 2 | Mech   | anical a               | nd electrical specifications8                 |
|   | 2.1    | Mechan                 | ical characteristics                          |
|   | 2.2    | Electrica              | al characteristics                            |
|   | 2.3    | Commu                  | nication interface characteristics            |
|   |        | 2.3.1                  | SPI - serial peripheral interface             |
|   |        | 2.3.2                  | I <sup>2</sup> C - inter-IC control interface |
|   | 2.4    | Absolute               | e maximum ratings 12                          |
| 3 | Funct  | tionality              |                                               |
|   | 3.1    | Sensing                | gelement                                      |
|   | 3.2    | I <sup>2</sup> C inter | fface                                         |
|   | 3.3    | Factory                | calibration                                   |
| 4 | FIFO   |                        |                                               |
|   |        | 4.0.1                  | Bypass mode                                   |
|   |        | 4.0.2                  | FIFO mode                                     |
|   |        | 4.0.3                  | Stream mode                                   |
|   |        | 4.0.4                  | Stream-to-FIFO mode                           |
|   |        | 4.0.5                  | Bypass-to-Stream mode                         |
|   |        | 4.0.6                  | Bypass-to-FIFO mode                           |
|   |        | 4.0.7                  | Retrieving data from FIFO                     |
| 5 | Applie | cation h               | ints                                          |
|   | 5.1    | Solderin               | ng information                                |
| 6 | Digita | l interfa              | aces 17                                       |
|   | 6.1    | I <sup>2</sup> C seria | al interface                                  |
|   | 6.2    | I <sup>2</sup> C seria | al interface (CS = High) 17                   |
|   |        | 6.2.1                  | I <sup>2</sup> C operation                    |
|   | 6.3    | SPI bus                | interface                                     |
|   |        | 6.3.1                  | SPI read                                      |
|   |        | 6.3.2                  | SPI write                                     |
|   |        |                        | _                                             |



|    |       | 6.3.3 SPI read in 3-wire mode |
|----|-------|-------------------------------|
| 7  | Regi  | ster mapping                  |
| 8  | Regi  | ster description              |
|    | 8.1   | INTERRUPT_CFG (0Bh) 25        |
|    | 8.2   | THS_P_L (0Ch)                 |
|    | 8.3   | THS_P_H (0Dh) 26              |
|    | 8.4   | WHO_AM_I                      |
|    | 8.5   | CTRL_REG1 (10h) 26            |
|    | 8.6   | CTRL_REG2 (11h) 28            |
|    | 8.7   | CTRL_REG3 (12h) 29            |
|    | 8.8   | FIFO_CTRL (14h)               |
|    | 8.9   | REF_P_XL (15h)                |
|    | 8.10  | REF_P_L (16h)                 |
|    | 8.11  | REF_P_H (17h) 31              |
|    | 8.12  | RPDS_L (18h)                  |
|    | 8.13  | RPDS_H (19h) 31               |
|    | 8.14  | RES_CONF (1Ah) 31             |
|    | 8.15  | INT_SOURCE (25h) 32           |
|    | 8.16  | FIFO_STATUS (26h)             |
|    | 8.17  | STATUS (27h)                  |
|    | 8.18  | PRESS_OUT_XL (28h)            |
|    | 8.19  | PRESS_OUT_L (29h) 33          |
|    | 8.20  | PRESS_OUT_H (2Ah) 34          |
|    | 8.21  | TEMP_OUT_L (2Bh)              |
|    | 8.22  | TEMP_OUT_H (2Ch)              |
| 9  | Pack  | age mechanical data           |
| 10 | Revis | sion history                  |



### List of tables

| Table 1.  | Device summary                                                                |
|-----------|-------------------------------------------------------------------------------|
| Table 2.  | Pin description                                                               |
| Table 3.  | Pressure and temperature sensor characteristics                               |
| Table 4.  | Electrical characteristics                                                    |
| Table 5.  | SPI slave timing values                                                       |
| Table 6.  | I <sup>2</sup> C slave timing values                                          |
| Table 7.  | Absolute maximum ratings                                                      |
| Table 8.  | Serial interface pin description                                              |
| Table 9.  | I <sup>2</sup> C terminology                                                  |
| Table 10. | SAD+Read/Write patterns                                                       |
| Table 11. | Transfer when master is writing one byte to slave                             |
| Table 12. | Transfer when master is writing multiple bytes to slave                       |
| Table 13. | Transfer when master is receiving (reading) one byte of data from slave       |
| Table 14. | Transfer when master is receiving (reading) multiple bytes of data from slave |
| Table 15. | Registers address map                                                         |
| Table 16. | Output data rate bit configurations                                           |
| Table 17. | Low-pass filter configurations                                                |
| Table 18. | Interrupt configurations                                                      |
| Table 19. | FIFO mode selection                                                           |
| Table 20. | Document revision history                                                     |
|           |                                                                               |



### List of figures

| Figure 1.  | Block diagram                                                     | 6 |
|------------|-------------------------------------------------------------------|---|
| Figure 2.  | Pin connections (bottom view)                                     | 6 |
| Figure 3.  | SPI slave timing diagram                                          | 0 |
| Figure 4.  | I <sup>2</sup> C slave timing diagram1                            | 1 |
| Figure 5.  | LPS22HB electrical connections (top view) 10                      | 6 |
| Figure 6.  | Read and write protocol                                           | 0 |
| Figure 7.  | SPI read protocol                                                 | 0 |
| Figure 8.  | Multiple byte SPI read protocol (2-byte example)2                 | 1 |
| Figure 9.  | SPI write protocol                                                | 1 |
| Figure 10. | Multiple byte SPI write protocol (2-byte example)                 | 1 |
| Figure 11. | SPI read protocol in 3-wire mode                                  | 2 |
| Figure 12. | HLGA - 10L (2.0 x 2.0 x 0.76 mm typ.) outline and mechanical data | 5 |
|            |                                                                   |   |



### 1 Block diagram and pin description



Figure 1. Block diagram



#### Figure 2. Pin connections (bottom view)



| Pin number | Pin number Name Function |                                                                                                                                                                            |  |  |  |  |  |
|------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 1          | Vdd_IO                   | Power supply for I/O pins                                                                                                                                                  |  |  |  |  |  |
| 2          | SCL<br>SPC               | I <sup>2</sup> C serial clock (SCL)<br>SPI serial port clock (SPC)                                                                                                         |  |  |  |  |  |
| 3          | Reserved                 | Connect to GND                                                                                                                                                             |  |  |  |  |  |
| 4          | SDA<br>SDI<br>SDI/SDO    | I <sup>2</sup> C serial data (SDA)<br>4-wire SPI serial data input (SDI)<br>3-wire serial data input/output (SDI/SDO)                                                      |  |  |  |  |  |
| 5          | SDO<br>SA0               | 4-wire SPI serial data output (SDO)<br>I <sup>2</sup> C less significant bit of the device address (SA0)                                                                   |  |  |  |  |  |
| 6          | CS                       | SPI enable<br>I <sup>2</sup> C/SPI mode selection<br>(1: SPI idle mode / I <sup>2</sup> C communication enabled;<br>0: SPI communication mode / I <sup>2</sup> C disabled) |  |  |  |  |  |
| 7          | INT_DRDY                 | Interrupt or Data Ready                                                                                                                                                    |  |  |  |  |  |
| 8          | GND                      | 0 V supply                                                                                                                                                                 |  |  |  |  |  |
| 9          | GND                      | 0 V supply                                                                                                                                                                 |  |  |  |  |  |
| 10         | VDD                      | Power supply                                                                                                                                                               |  |  |  |  |  |



### 2 Mechanical and electrical specifications

#### 2.1 Mechanical characteristics

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

| Symbol              | Parameter Test condition                       |                                                            | Min. | Typ. <sup>(1)</sup> | Max. | Unit        |
|---------------------|------------------------------------------------|------------------------------------------------------------|------|---------------------|------|-------------|
| Pressure se         | ensor characteristics                          | 1                                                          |      |                     |      | 1           |
| PT <sub>op</sub>    | Operating temperature range                    |                                                            | -40  |                     | +85  | °C          |
| PT <sub>full</sub>  | Full accuracy temperature range                |                                                            | 0    |                     | +65  | °C          |
| P <sub>op</sub>     | Operating pressure range                       |                                                            | 260  |                     | 1260 | hPa         |
| P <sub>bits</sub>   | Pressure output data                           |                                                            |      | 24                  |      | bits        |
| P <sub>sens</sub>   | Pressure sensitivity                           |                                                            |      | 4096                |      | LSB/<br>hPa |
| P <sub>AccRel</sub> | Relative accuracy over pressure <sup>(2)</sup> | P = 800 - 1100 hPa<br>T = 25 °C                            |      | ±0.1                |      | hPa         |
| D                   |                                                | $P_{op}$ T = 0 to 65 °C<br>After OPC <sup>(3)</sup>        |      | ±0.1                |      | - hPa       |
| P <sub>AccT</sub>   | Absolute accuracy over temperature             | P <sub>op</sub><br>T = 0 to 65 °C<br>no OPC <sup>(3)</sup> |      | ±1                  |      |             |
| P <sub>noise</sub>  | RMS pressure sensing noise <sup>(4)</sup>      | without embedded filtering                                 |      | 0.01                |      | hPa<br>RMS  |
|                     |                                                |                                                            |      | 1                   |      |             |
|                     |                                                |                                                            |      | 10                  |      | Hz          |
| ODR <sub>Pres</sub> | Pressure output data rate <sup>(5)</sup>       |                                                            |      | 25                  |      |             |
|                     |                                                |                                                            |      | 50                  |      |             |
|                     |                                                |                                                            |      | 75                  |      |             |
| •                   | e sensor characteristics                       |                                                            |      |                     |      |             |
| T <sub>op</sub>     | Operating temperature range                    |                                                            | -40  |                     | +85  | °C          |
| T <sub>sens</sub>   | Temperature sensitivity                        |                                                            |      | 100                 |      | LSB/°C      |
| T <sub>acc</sub>    | Temperature absolute accuracy                  | T = 0 to 65 °C                                             |      | ±1.5                |      | °C          |
|                     |                                                |                                                            |      | 1                   |      |             |
|                     |                                                |                                                            |      | 10                  |      |             |
| ODR <sub>T</sub>    | Output temperature data rate <sup>(5)</sup>    |                                                            |      | 25                  |      | Hz          |
|                     |                                                |                                                            |      | 50                  |      |             |
|                     |                                                |                                                            |      | 75                  |      |             |

#### Table 3. Pressure and temperature sensor characteristics

1. Typical specifications are not guaranteed.

2. Parameter not tested at final test

3. OPC: One Point Calibration, see registers RPDS\_L/H (18h,19h).

4. Pressure noise RMS evaluated in a controlled environment, based on the average standard deviation of 32 measurements at highest ODR.

5. Output data rate is configured acting on ODR[2:0] in CTRL\_REG1 (10h)



### 2.2 Electrical characteristics

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

| Symbol | Parameter                         | Test condition              | Min. | Тур. <sup>(1)</sup> | Max.    | Unit |  |
|--------|-----------------------------------|-----------------------------|------|---------------------|---------|------|--|
| VDD    | Supply voltage                    |                             | 1.7  |                     | 3.6     | V    |  |
| Vdd_IO | IO supply voltage                 |                             | 1.7  |                     | Vdd+0.1 | V    |  |
| ldd    | Supply current                    | @ ODR 1 Hz<br>LC_EN bit = 0 |      | 15                  |         | - μΑ |  |
|        |                                   | @ ODR 1 Hz<br>LC_EN bit = 1 |      | 4                   |         |      |  |
| IddPdn | Supply current in power-down mode |                             |      | 1                   |         | μA   |  |

#### Table 4. Electrical characteristics

1. Typical specifications are not guaranteed.



### 2.3 Communication interface characteristics

#### 2.3.1 SPI - serial peripheral interface

Subject to general operating conditions for Vdd and  $T_{\mbox{\scriptsize OP}}$ 

| Symbol               | Parameter               | Valu | Unit |      |  |
|----------------------|-------------------------|------|------|------|--|
| Symbol               | Parameter               | Min  | Max  | onit |  |
| t <sub>c(SPC)</sub>  | SPI clock cycle         | 100  |      | ns   |  |
| f <sub>c(SPC)</sub>  | SPI clock frequency     |      | 10   | MHz  |  |
| t <sub>su(CS)</sub>  | CS setup time           | 6    |      |      |  |
| t <sub>h(CS)</sub>   | CS hold time            | 8    |      |      |  |
| t <sub>su(SI)</sub>  | SDI input setup time    | 5    |      |      |  |
| t <sub>h(SI)</sub>   | SDI input hold time     | 15   |      | ns   |  |
| t <sub>v(SO)</sub>   | SDO valid output time   |      | 50   |      |  |
| t <sub>h(SO)</sub>   | SDO output hold time    | 9    |      |      |  |
| t <sub>dis(SO)</sub> | SDO output disable time |      | 50   |      |  |

#### Table 5. SPI slave timing values

1. Values are guaranteed at 10 MHz clock frequency for SPI with both 4 and 3 wires, based on characterization results, not tested in production.





Note: Measurement points are done at 0.2 · Vdd\_IO and 0.8 · Vdd\_IO, for both ports.



### 2.3.2 I<sup>2</sup>C - inter-IC control interface

Subject to general operating conditions for Vdd and  $\mathrm{T}_{\mathrm{OP}}$ 

| Symbol                                  | Devementary (4)                                | I <sup>2</sup> C standard mode <sup>(1)</sup> |      | l <sup>2</sup> C fast mode <sup>(1)</sup> |     |       |  |
|-----------------------------------------|------------------------------------------------|-----------------------------------------------|------|-------------------------------------------|-----|-------|--|
| Symbol                                  | Parameter (1)                                  | Min                                           | Max  | Min                                       | Мах | Unit  |  |
| f <sub>(SCL)</sub>                      | SCL clock frequency                            | 0                                             | 100  | 0                                         | 400 | kHz   |  |
| t <sub>w(SCLL)</sub>                    | SCL clock low time                             | 4.7                                           |      | 1.3                                       |     |       |  |
| t <sub>w(SCLH)</sub>                    | SCL clock high time                            | 4.0                                           |      | 0.6                                       |     | — µs  |  |
| t <sub>su(SDA)</sub>                    | SDA setup time                                 | 250                                           |      | 100                                       |     | ns    |  |
| t <sub>h(SDA)</sub>                     | SDA data hold time                             | 0.01                                          | 3.45 | 0                                         | 0.9 | μs    |  |
| t <sub>r(SDA)</sub> t <sub>r(SCL)</sub> | SDA and SCL rise time                          |                                               | 1000 | 20 + 0.1C <sub>b</sub> <sup>(2)</sup>     | 300 |       |  |
| t <sub>f(SDA)</sub> t <sub>f(SCL)</sub> | SDA and SCL fall time                          |                                               | 300  | 20 + 0.1C <sub>b</sub> <sup>(2)</sup>     | 300 | ns ns |  |
| t <sub>h(ST)</sub>                      | START condition hold time                      | 4                                             |      | 0.6                                       |     |       |  |
| t <sub>su(SR)</sub>                     | Repeated START condition setup time            | 4.7                                           |      | 0.6                                       |     |       |  |
| t <sub>su(SP)</sub>                     | STOP condition setup time                      | 4                                             |      | 0.6                                       |     | — µs  |  |
| t <sub>w(SP:SR)</sub>                   | Bus free time between STOP and START condition | 4.7                                           |      | 1.3                                       |     |       |  |

1. Data based on standard  $I^2C$  protocol requirement, not tested in production.

2.  $C_b$  = total capacitance of one bus line, in pF.



#### Figure 4. I<sup>2</sup>C slave timing diagram

Note:

Measurement points are done at 0.2 Vdd\_IO and 0.8 Vdd\_IO, for both ports.



#### 2.4 Absolute maximum ratings

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

| Symbol           | Ratings                            | Maximum value       | Unit |
|------------------|------------------------------------|---------------------|------|
| Vdd              | Supply voltage                     | -0.3 to 4.8         | V    |
| Vdd_IO           | I/O pins supply voltage            | -0.3 to 4.8         | V    |
| Vin              | Input voltage on any control pin   | -0.3 to Vdd_IO +0.3 | V    |
| Р                | Overpressure                       | 2                   | MPa  |
| T <sub>STG</sub> | Storage temperature range          | -40 to +125         | °C   |
| ESD              | Electrostatic discharge protection | 2 (HBM)             | kV   |

Note:

Supply voltage on any pin should never exceed 4.8 V.



This device is sensitive to mechanical shock, improper handling can cause permanent damage to the part.



This device is sensitive to electrostatic discharge (ESD), improper handling can cause permanent damage to the part.



### 3 Functionality

The LPS22HB is a high resolution, digital output pressure sensor packaged in an HLGA fullmold package. The complete device includes a sensing element based on a piezoresistive Wheatstone bridge approach, and an IC interface which communicates a digital signal from the sensing element to the application.

### 3.1 Sensing element

An ST proprietary process is used to obtain a silicon membrane for MEMS pressure sensors. When pressure is applied, the membrane deflection induces an imbalance in the Wheatstone bridge piezoresistances whose output signal is converted by the IC interface.

Intrinsic mechanical stoppers prevent breakage in case of excessive pressure, ensuring measurement repeatability.

### 3.2 I<sup>2</sup>C interface

The complete measurement chain is composed of a low-noise amplifier which converts the resistance unbalance of the MEMS sensors (pressure and temperature) into an analog voltage using an analog-to-digital converter.

The pressure and temperature data may be accessed through an I<sup>2</sup>C/SPI interface thus making the device particularly suitable for direct interfacing with a microcontroller.

The LPS22HB features a Data-Ready signal which indicates when a new set of measured pressure and temperature data are available, thus simplifying data synchronization in the digital system that uses the device.

### 3.3 Factory calibration

The IC interface is factory calibrated at three temperatures and two pressures for sensitivity and accuracy.

The trimming values are stored inside the device in a non-volatile structure. When the device is turned on, the trimming parameters are downloaded into the registers to be employed during normal operation which allows the device to be used without requiring any further calibration.



### 4 FIFO

The LPS22HB embeds 32-slot data FIFO to store the pressure and temperature output values. The FIFO allows consistent power saving for the system, since the host processor does not need to continuously poll data from the sensor, but it can wake up only when needed and burst the significant data out from the FIFO.

This buffer can work according to six different modes: Bypass mode, FIFO mode, Stream mode, Stream-to-FIFO mode, Bypass-to-Stream mode and Bypass-to-FIFO mode.

The FIFO buffer is enabled when the FIFO\_EN bit in *CTRL\_REG2 (11h)* is set to '1' and each mode is selected by the FIFO\_MODE[2:0] bits in *FIFO\_CTRL (14h)*.

FIFO threshold status, FIFO overrun events and the number of unread samples stored are available in the *FIFO\_STATUS (26h)* register and can be set to generate dedicated interrupts on the INT\_DRDY pin using the *CTRL\_REG3 (12h)* register.

#### 4.0.1 Bypass mode

In Bypass mode (F\_MODE[2:0] in *FIFO\_CTRL (14h)* set to '000'), the FIFO is not operational and it remains empty.

#### 4.0.2 FIFO mode

In FIFO mode (F\_MODE[2:0] in *FIFO\_CTRL* (14h) set to '001'), the data from *PRESS\_OUT\_H* (2Ah), *PRESS\_OUT\_L* (29h) and *PRESS\_OUT\_XL* (28h) and *TEMP\_OUT\_H* (2Ch) and *TEMP\_OUT\_L* (2Bh) are stored in the FIFO.

A watermark interrupt can be enabled (STOP\_ON\_FTH bit set to '1' in *CTRL\_REG2 (11h)*) in order to be raised when the FIFO is filled to the level specified by the WTM[4:0] bits of *FIFO\_CTRL (14h)*. The FIFO continues filling until it is full (32 slots of data for pressure and temperature output). When full, the FIFO stops collecting data.

#### 4.0.3 Stream mode

In Stream mode (F\_MODE[2:0] in *FIFO\_CTRL (14h)* set to '010'), the data from *PRESS\_OUT\_H (2Ah)*, *PRESS\_OUT\_L (29h)* and *PRESS\_OUT\_XL (28h)* and *TEMP\_OUT\_H (2Ch)* and *TEMP\_OUT\_L (2Bh)* are stored in the FIFO. The FIFO continues filling until it's full (32 slots of data for pressure and temperature output). When full, the FIFO discards the older data as the new arrive. A watermark interrupt can be enabled and set as in FIFO mode.

#### 4.0.4 Stream-to-FIFO mode

In Stream-to-FIFO mode (F\_MODE[2:0] in *FIFO\_CTRL (14h)* set to '011'), the data from *PRESS\_OUT\_H (2Ah)*, *PRESS\_OUT\_L (29h)* and *PRESS\_OUT\_XL (28h)* and *TEMP\_OUT\_H (2Ch)* and *TEMP\_OUT\_L (2Bh)* are stored in the FIFO.

A Watermark interrupt can be enabled (STOP\_ON\_FTH bit set to '1' in *CTRL\_REG2 (11h)*) in order to be raised when the FIFO is filled to the level specified by the WTM[4:0] bits of *FIFO\_CTRL (14h)*. The FIFO continues filling until it's full (32 slots of data for pressure and temperature output). When full, the FIFO discards the older data as the new arrive. Once a trigger event occurs, the FIFO starts operating in FIFO mode. A trigger event can be configured in *INTERRUPT\_CFG (0Bh)*.

#### 4.0.5 Bypass-to-Stream mode

In Bypass-to-Stream mode (F\_MODE[2:0] in *FIFO\_CTRL (14h)* set to '100'), the FIFO is in Bypass mode until a trigger event occurs and the FIFO starts operating in Stream mode. A trigger event can be configured in *INTERRUPT\_CFG (0Bh)*.

#### 4.0.6 Bypass-to-FIFO mode

In Bypass-to-FIFO (F\_MODE[2:0] in *FIFO\_CTRL (14h)* set to '001'), the FIFO is in Bypass mode until a trigger event occurs and the FIFO starts operating in FIFO mode. A trigger event can be configured in *INTERRUPT\_CFG (0Bh)*.

#### 4.0.7 Retrieving data from FIFO

When the FIFO is enabled, FIFO data are read from *PRESS\_OUT\_H* (2Ah), *PRESS\_OUT\_L* (29h), *PRESS\_OUT\_XL* (28h), *TEMP\_OUT\_H* (2Ch) and *TEMP\_OUT\_L* (2Bh) registers.

Each time data is read from the FIFO, the oldest data are placed in the *PRESS\_OUT\_H* (2Ah), *PRESS\_OUT\_L* (29h), *PRESS\_OUT\_XL* (28h), *TEMP\_OUT\_H* (2Ch) and *TEMP\_OUT\_L* (2Bh) registers and both single-read and read-burst operations can be used. The reading address is automatically updated by the device and it rolls back to 28h when register 2Ch is reached. In order to read all FIFO levels in a multiple byte reading, 160 bytes (5 output registers by 32 levels) must be read.

### 5 Application hints



Figure 5. LPS22HB electrical connections (top view)

Power supply decoupling capacitors  $C_1(100nF)$  and  $C_2(4.7\mu F)$  should be placed as near as possible to the supply pad of the device (common design practice).

The functionality of the device and the measured data outputs are selectable and accessible through the  $I^2C/SPI$  interface. When using the  $I^2C$ , CS must be tied to Vdd\_IO.

All the voltage and ground supplies must be present at the same time to have proper behavior of the IC (refer to *Figure 5*). It is possible to remove VDD while maintaining Vdd\_IO without blocking the communication bus, in this condition the measurement chain is powered off.

### 5.1 Soldering information

The HLGA package is compliant with the ECOPACK<sup>®</sup> standard and it is qualified for soldering heat resistance according to JEDEC J-STD-020.



### 6 Digital interfaces

### 6.1 I<sup>2</sup>C serial interface

The registers embedded in the LPS22HB may be accessed through both the I<sup>2</sup>C and SPI serial interfaces. The latter may be SW configured to operate either in 3-wire or 4-wire interface mode.

The serial interfaces are mapped onto the same pads. To select/exploit the  $I^2C$  interface, the CS line must be tied high (i.e. connected to Vdd\_IO).

| Pin name              | Pin description                                                                                                                                                         |  |  |  |  |  |  |  |  |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| CS                    | SPI enable<br>I <sup>2</sup> C/SPI mode selection (1: SPI idle mode / I <sup>2</sup> C communication enabled; 0: SPI<br>communication mode / I <sup>2</sup> C disabled) |  |  |  |  |  |  |  |  |
| SCL/SPC               | I²C serial clock (SCL)<br>SPI serial port clock (SPC)                                                                                                                   |  |  |  |  |  |  |  |  |
| SDA<br>SDI<br>SDI/SDO | I <sup>2</sup> C serial data (SDA)<br>4-wire SPI serial data input (SDI)<br>3-wire serial data input /output (SDI/SDO)                                                  |  |  |  |  |  |  |  |  |
| SDO<br>SAO            | SPI serial data output (SDO)<br>I²C less significant bit of the device address (SA0)                                                                                    |  |  |  |  |  |  |  |  |

| Table 8 | 8. Serial | interface | pin | description |
|---------|-----------|-----------|-----|-------------|
| 10010   | 0. 00.141 | monuou    | P   | 400011011   |

### 6.2 $I^2C$ serial interface (CS = High)

The LPS22HB I<sup>2</sup>C is a bus slave. The I<sup>2</sup>C is employed to write data into registers whose content can also be read back.

The relevant I<sup>2</sup>C terminology is given in Table 9.

| Term        | Description                                                                              |  |  |  |  |  |  |  |  |
|-------------|------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Transmitter | The device which sends data to the bus                                                   |  |  |  |  |  |  |  |  |
| Receiver    | The device which receives data from the bus                                              |  |  |  |  |  |  |  |  |
| Master      | The device which initiates a transfer, generates clock signals and terminates a transfer |  |  |  |  |  |  |  |  |
| Slave       | The device addressed by the master                                                       |  |  |  |  |  |  |  |  |

| Table | 9. | l <sup>2</sup> C | terminol | ogy |
|-------|----|------------------|----------|-----|
|-------|----|------------------|----------|-----|

There are two signals associated with the I<sup>2</sup>C bus: the serial clock line (SCL) and the serial data line (SDA). The latter is a bi-directional line used for sending and receiving the data to/from the interface. Both lines have to be connected to Vdd\_IO through pull-up resistors.

The I<sup>2</sup>C interface is compliant with fast mode (400 kHz) I<sup>2</sup>C standards as well as with the normal mode.



#### 6.2.1 I<sup>2</sup>C operation

The transaction on the bus is started through a START (ST) signal. A start condition is defined as a HIGH-to-LOW transition on the data line while the SCL line is held HIGH. After this has been transmitted by the master, the bus is considered busy. The next data byte transmitted after the start condition contains the address of the slave in the first 7 bits and the eighth bit tells whether the master is receiving data from the slave or transmitting data to the slave. When an address is sent, each device in the system compares the first seven bits after a start condition with its address. If they match, the device considers itself addressed by the master.

The slave address (SAD) associated to the LPS22HB is 101110xb. The **SDO/SA0** pad can be used to modify the less significant bit of the device address. If the SA0 pad is connected to voltage supply, LSb is '1' (address 1011101b), otherwise if the SA0 pad is connected to ground, the LSb value is '0' (address 1011100b). This solution permits to connect and address two different LPS22HB devices to the same I<sup>2</sup>C lines.

Data transfer with acknowledge is mandatory. The transmitter must release the SDA line during the acknowledge pulse. The receiver must then pull the data line LOW so that it remains stable low during the HIGH period of the acknowledge clock pulse. A receiver which has been addressed is obliged to generate an acknowledge after each byte of data received.

The I<sup>2</sup>C embedded inside the ASIC behaves like a slave device and the following protocol must be adhered to. After the start condition (ST) a slave address is sent, once a slave acknowledge has been returned (SAK), an 8-bit sub-address will be transmitted (SUB): the 7 LSB represent the actual register address while the MSB has no meaning. The IF\_ADD\_INC bit in CTRL2 register (11h) enables sub-address auto increment (IF\_ADD\_INC is '1' by default), so if IF\_ADD\_INC = '1' the SUB (sub-address) will be automatically increased to allow multiple data read/write.

The slave address is completed with a Read/Write bit. If the bit is '1' (Read), a repeated START (SR) condition must be issued after the two sub-address bytes; if the bit is '0' (Write) the master will transmit to the slave with direction unchanged. *Table 10* explains how the SAD+read/write bit pattern is composed, listing all the possible configurations.

|         |          | -            |     |                |
|---------|----------|--------------|-----|----------------|
| Command | SAD[6:1] | SAD[0] = SA0 | R/W | SAD+R/W        |
| Read    | 101110   | 0            | 1   | 10111001 (B9h) |
| Write   | 101110   | 0            | 0   | 10111000 (B8h) |
| Read    | 101110   | 1            | 1   | 10111011 (BBh) |
| Write   | 101110   | 1            | 0   | 10111010 (BAh) |

Table 10. SAD+Read/Write patterns

| Master | ST | SAD + W |     | SUB |     | DATA |     | SP |
|--------|----|---------|-----|-----|-----|------|-----|----|
| Slave  |    |         | SAK |     | SAK |      | SAK |    |



| Table 12. Transfer when master is writing multiple bytes to slave |    |         |     |     |     |      |     |      |     |    |
|-------------------------------------------------------------------|----|---------|-----|-----|-----|------|-----|------|-----|----|
| Master                                                            | ST | SAD + W |     | SUB |     | DATA |     | DATA |     | SP |
| Slave                                                             |    |         | SAK |     | SAK |      | SAK |      | SAK |    |

#### Table 12. Transfer when master is writing multiple bytes to slave

#### Table 13. Transfer when master is receiving (reading) one byte of data from slave

| Master | ST | SAD + W |     | SUB |     | SR | SAD + R |     |      | NMAK | SP |
|--------|----|---------|-----|-----|-----|----|---------|-----|------|------|----|
| Slave  |    |         | SAK |     | SAK |    |         | SAK | DATA |      |    |

#### Table 14. Transfer when master is receiving (reading) multiple bytes of data from slave

| Master | ST | SAD+W |     | SUB |     | SR | SAD+R |     |      | MAK |      | MAK |      | NMAK | SP |
|--------|----|-------|-----|-----|-----|----|-------|-----|------|-----|------|-----|------|------|----|
| Slave  |    |       | SAK |     | SAK |    |       | SAK | DATA |     | DATA |     | DATA |      |    |

Data are transmitted in byte format (DATA). Each data transfer contains 8 bits. The number of bytes transferred per transfer is unlimited. Data is transferred with the most significant bit (MSb) first. If a receiver can't receive another complete byte of data until it has performed some other functions, it can hold the clock line, SCL LOW to force the transmitter into a wait state. Data transfer only continues when the receiver is ready for another byte and releases the data line. If a slave receiver does not acknowledge the slave address (i.e. it is not able to receive because it is performing some real-time function) the data line must be kept HIGH by the slave. The master can then abort the transfer. A LOW-to-HIGH transition on the SDA line while the SCL line is HIGH is defined as a STOP condition. Each data transfer must be terminated by the generation of a STOP (SP) condition.

In order to read multiple bytes incrementing the register address, it is necessary to assert the most significant bit of the sub-address field. In other words, SUB(7) must be equal to 1 while SUB(6-0) represents the address of the first register to be read.

In the presented communication format MAK is Master acknowledge and NMAK is no master acknowledge.

#### 6.3 SPI bus interface

The LPS22HB SPI is a bus slave. The SPI allows writing to and reading from the registers of the device.

The serial interface interacts with the outside world with 4 wires: CS, SPC, SDI and SDO.





**CS** is the serial port enable and it is controlled by the SPI master. It goes low at the start of the transmission and returns to high at the end. **SPC** is the serial port clock and it is controlled by the SPI master. It is stopped high when **CS** is high (no transmission). **SDI** and **SDO** are respectively the serial port data input and output. Those lines are driven at the falling edge of **SPC** and should be captured at the rising edge of **SPC**.

Both the read register and write register commands are completed in 16 clock pulses or in multiples of 8 in the case of multiple read/write bytes. Bit duration is the time between two falling edges of **SPC**. The first bit (bit 0) starts at the first falling edge of **SPC** after the falling edge of **CS** while the last bit (bit 15, bit 23,...) starts at the last falling edge of SPC just before the rising edge of **CS**.

*bit 0*: RW bit. When 0, the data DI(7:0) is written into the device. When 1, the data DO(7:0) from the device is read. In the latter case, the chip will drive **SDO** at the start of bit 8.

*bit 1-7*: address AD(6:0). This is the address field of the indexed register.

*bit 8-15*: data DI(7:0) (write mode). This is the data that is written into the device (MSb first). *bit 8-15*: data DO(7:0) (read mode). This is the data that is read from the device (MSb first). In multiple read/write commands further blocks of 8 clock periods are added. When the IF\_ADD\_INC bit is 0, the address used to read/write data remains the same for every block. When the IF\_ADD\_INC bit is 1, the address used to read/write data is incremented at every block.

The function and the behavior of **SDI** and **SDO** remain unchanged.

#### 6.3.1 SPI read



The SPI read command is performed with 16 clock pulses. The multiple byte read command is performed by adding blocks of 8 clock pulses to the previous one.



bit 0: READ bit. The value is 1.

bit 1-7: address AD(6:0). This is the address field of the indexed register.

bit 8-15: data DO(7:0) (read mode). This is the data that is read from the device (MSb first).

*bit 16-...*: data DO(...-8). Further data in multiple byte reads.





#### 6.3.2 SPI write





The SPI write command is performed with 16 clock pulses. The multiple byte write command is performed by adding blocks of 8 clock pulses to the previous one.

*bit 0*: WRITE bit. The value is 0.

*bit 1-7*: address AD(6:0). This is the address field of the indexed register.

bit 8-15: data DI(7:0) (write mode). This is the data that is written in the device (MSb first).

bit 16-...: data DI(...-8). Further data in multiple byte writes.







#### 6.3.3 SPI read in 3-wire mode

A 3-wire mode is entered by setting bit SIM to '1' (SPI serial interface mode selection) in CTRL\_REG1.





The SPI read command is performed with 16 clock pulses:

*bit 0*: READ bit. The value is 1.

bit 1-7: address AD(6:0). This is the address field of the indexed register.

*bit 8-15*: data DO(7:0) (read mode). This is the data that is read from the device (MSb first). A multiple read command is also available in 3-wire mode.



### 7 Register mapping

Table 15 provides a quick overview of the 8-bit registers embedded in the device.

| I able 15. Registers address map |      |                     |          |                      |  |  |  |  |  |  |  |  |
|----------------------------------|------|---------------------|----------|----------------------|--|--|--|--|--|--|--|--|
| Name                             | Туре | Register<br>Address | Default  | Function and comment |  |  |  |  |  |  |  |  |
|                                  |      | Hex                 | Binary   | Common               |  |  |  |  |  |  |  |  |
| Reserved                         |      | 00 - 0A             | -        | Reserved             |  |  |  |  |  |  |  |  |
| INTERRUPT_CFG                    | R/W  | 0B                  | 00000000 |                      |  |  |  |  |  |  |  |  |
| THS_P_L                          | R/W  | 0C                  | 00000000 |                      |  |  |  |  |  |  |  |  |
| THS_P_H                          | R/W  | 0D                  | 00000000 |                      |  |  |  |  |  |  |  |  |
| Reserved                         |      | 0E                  | -        | Reserved             |  |  |  |  |  |  |  |  |
| WHO_AM_I                         | R    | 0F                  | 10110001 | Who am I             |  |  |  |  |  |  |  |  |
| CTRL_REG1                        | R/W  | 10                  | 00000000 |                      |  |  |  |  |  |  |  |  |
| CTRL_REG2                        | R/W  | 11                  | 00010000 |                      |  |  |  |  |  |  |  |  |
| CTRL_REG3                        | R/W  | 12                  | 00000000 | Interrupt control    |  |  |  |  |  |  |  |  |
| Reserved                         |      | 13                  | -        | Reserved             |  |  |  |  |  |  |  |  |
| FIFO_CTRL                        | R/W  | 14                  | 00000000 |                      |  |  |  |  |  |  |  |  |
| REF_P_XL                         | R/W  | 15                  | 00000000 |                      |  |  |  |  |  |  |  |  |
| REF_P_L                          | R/W  | 16                  | 00000000 |                      |  |  |  |  |  |  |  |  |
| REF_P_H                          | R/W  | 17                  | 00000000 |                      |  |  |  |  |  |  |  |  |
| RPDS_L                           | R/W  | 18                  | 00000000 |                      |  |  |  |  |  |  |  |  |
| RPDS_H                           | R/W  | 19                  | 00000000 |                      |  |  |  |  |  |  |  |  |
| RES_CONF                         | R/W  | 1A                  | 00000000 |                      |  |  |  |  |  |  |  |  |
| Reserved                         |      | 1B - 24             | -        | Reserved             |  |  |  |  |  |  |  |  |
| INT_SOURCE                       | R    | 25                  | -        |                      |  |  |  |  |  |  |  |  |
| FIFO_STATUS                      | R    | 26                  | -        |                      |  |  |  |  |  |  |  |  |
| STATUS                           | R    | 27                  | -        |                      |  |  |  |  |  |  |  |  |
| PRESS_OUT_XL                     | R    | 28                  | -        |                      |  |  |  |  |  |  |  |  |
| PRESS_OUT_L                      | R    | 29                  | -        |                      |  |  |  |  |  |  |  |  |
| PRESS_OUT_H                      | R    | 2A                  | -        |                      |  |  |  |  |  |  |  |  |
| TEMP_OUT_L                       | R    | 2B                  | -        |                      |  |  |  |  |  |  |  |  |
| TEMP_OUT_H                       | R    | 2C                  | -        |                      |  |  |  |  |  |  |  |  |

| Table 15. Registers address ma |
|--------------------------------|
|--------------------------------|

Registers marked as Reserved must not be changed. Writing to those registers may cause permanent damage to the device.



To guarantee the proper behavior of the device, all register addresses not listed in the above table must not be accessed and the content stored in those registers must not be changed.

The content of the registers that are loaded at boot should not be changed. They contain the factory calibration values. Their content is automatically restored when the device is powered up.



### 8 **Register description**

The device contains a set of registers which are used to control its behavior and to retrieve pressure and temperature data. The register address, made up of 7 bits, is used to identify them and to read/write the data through the serial interface.

### 8.1 INTERRUPT\_CFG (0Bh)

Interrupt configuration

| 7        | 6         | 5        | 4        | 3       | 2   | 1   | 0   |
|----------|-----------|----------|----------|---------|-----|-----|-----|
| AUTORIFP | RESET_ARP | AUTOZERO | RESET_AZ | DIFF_EN | LIR | PLE | PHE |

| AUTORIFP  | AUTORIFP: AutoRifP enable. Default value: 0.<br>(0: normal mode; 1: AutoRifP enabled)                                                                                                                                     |  |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| RESET_ARP | Reset AutoRifP function. Default value: 0.<br>(0: normal mode; 1: reset AutoRifP function)                                                                                                                                |  |
| AUTOZERO  | <ul><li>Autozero enable. Default value: 0.</li><li>(0: normal mode; 1: Autozero enabled)</li></ul>                                                                                                                        |  |
| RESET_AZ  | Reset Autozero function. Default value: 0.<br>(0: normal mode; 1: reset Autozero function)                                                                                                                                |  |
| DIFF_EN   | Interrupt generation enable. Default value: 0<br>(0: interrupt generation disabled; 1: interrupt generation enabled)                                                                                                      |  |
| LIR       | Latch interrupt request to the INT_SOURCE register. Default value: 0. (0: interrupt request not latched; 1: interrupt request latched)                                                                                    |  |
| PLE       | Enable interrupt generation on differential pressure low event. Default value: 0.<br>(0: disable interrupt request; 1: enable interrupt request on measured differential pressure value lower than preset threshold)      |  |
| PHE       | Enable interrupt generation on differential pressure high event. Default value: 0.<br>(0: disable interrupt request; 1: enable interrupt request on measured differential<br>pressure value higher than preset threshold) |  |

**AUTORIFP**, when written to '1', an internal register is set with current pressure values and the bit is forced to '0'. When the bit is enabled, the content of the internal register is subtracted from the pressure output value and result is used for the interrupt generation. The output registers (*PRESS\_OUT\_H* (2Ah), *PRESS\_OUT\_L* (29h) and *PRESS\_OUT\_XL* (28h)) are updated with the actual pressure value.

The **RESET\_ARP** bit is used to disable the AUTORIFP function. RESET\_ARP is self-cleared.

**AUTOZERO**, when set to '1', the actual pressure output value is copied in  $REF_P_H$  (17h),  $REF_P_L$  (16h) and  $REF_P_XL$  (15h). When this bit is enabled, the register content of REF\_P is subtracted from the pressure output value. To disable autozero, the REF\_P registers have to be cleared.



The **RESET\_AZ** bit is used to reset the AutoZero function. Resetting  $REF_P_H$  (17*h*),  $REF_P_L$  (16*h*) and  $REF_P_XL$  (15*h*) sets the pressure reference registers  $RPDS_H$  (19*h*) and  $RPDS_L$  (18*h*) to the default values. RESET\_AZ is self-cleared.

The **DIFF\_EN** bit is used to enable the computing of differential pressure output. It is recommended to enable DIFF\_EN after the configuration of  $REF_P_H$  (17h),  $REF_P_L$  (16h),  $REF_P_XL$  (15h),  $THS_P_H$  (0Dh) and  $THS_P_L$  (0Ch).

### 8.2 THS\_P\_L (0Ch)

Least significant bits of the threshold value for pressure interrupt generation.

| 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |  |
|------|------|------|------|------|------|------|------|--|
| THS7 | THS6 | THS5 | THS4 | THS3 | THS2 | THS1 | THS0 |  |

|  | THSI7:01 | This register contains the low part of threshold value for pressure interrupt genera-<br>tion. |  |
|--|----------|------------------------------------------------------------------------------------------------|--|
|--|----------|------------------------------------------------------------------------------------------------|--|

The threshold value for pressure interrupt generation is a 16-bit register composed of  $THS_P_H (0Dh)$  and  $THS_P_L (0Ch)$ . The value is expressed as unsigned number: Interrupt threshold(hPA) = (THS\_P)/16.

### 8.3 THS\_P\_H (0Dh)

Most significant bits of the threshold value for pressure interrupt generation.

| 7     | 6     | 5     | 4     | 3     | 2     | 1    | 0    |
|-------|-------|-------|-------|-------|-------|------|------|
| THS15 | THS14 | THS13 | THS12 | THS11 | THS10 | THS9 | THS8 |

THS[15:8]This register contains the high part of threshold value for pressure interrupt generation. Refer to THS\_P\_L (0Ch).

### 8.4 WHO\_AM\_I

Device Who am I

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

### 8.5 CTRL\_REG1 (10h)

| C                | Control registe | er 1 |      |         |         |     |     |
|------------------|-----------------|------|------|---------|---------|-----|-----|
| 7                | 6               | 5    | 4    | 3       | 2       | 1   | 0   |
| 0 <sup>(1)</sup> | ODR2            | ODR1 | ODR0 | EN_LPFP | LPF_CFG | BDU | SIM |

1. This bit must be set to '0' for proper operation of the device



| ODR [2:0] | Output data rate selection. Default value: 000<br>Refer to <i>Table 16</i> .                                                       |
|-----------|------------------------------------------------------------------------------------------------------------------------------------|
| EN_LPFP   | Enable low-pass filter on pressure data. Default value: 0<br>(0: Low-pass filter disabled; 1: Low-pass filter enabled)             |
| LPF_CFG   | LPF_CFG: Low-pass configuration register. Default value:0 Refer to <i>Table 17</i> .                                               |
| BDU       | Block data update. Default value: 0<br>(0: continuous update;<br>1: output registers not updated until MSB and LSB have been read) |
| SIM       | SPI Serial Interface Mode selection.Default value: 0<br>(0: 4-wire interface; 1: 3-wire interface)                                 |

| ODR2 | ODR1 | ODR0 | Pressure (Hz)         | Temperature (Hz) |
|------|------|------|-----------------------|------------------|
| 0    | 0    | 0    | One shot mode enabled |                  |
| 0    | 0    | 1    | 1 Hz                  | 1 Hz             |
| 0    | 1    | 0    | 10 Hz                 | 10 Hz            |
| 0    | 1    | 1    | 25 Hz                 | 25 Hz            |
| 1    | 0    | 0    | 50 Hz                 | 50 Hz            |
| 1    | 0    | 1    | 75 Hz                 | 75 Hz            |

When ODR[2,0] are set to '000' the device enables One-Shot Mode. When the ONE\_SHOT bit in *CTRL\_REG2 (11h)* is set to '1', a new set of data for pressure and temperature is acquired.

| Table 17. Low-pass | filter configurations |
|--------------------|-----------------------|
|--------------------|-----------------------|

| LPF_CFG | Filter cutoff |
|---------|---------------|
| 0       | ODR/9         |
| 1       | ODR/20        |

The **BDU** bit is used to inhibit the update of the output registers between the reading of upper and lower register parts. In default mode (BDU = '0'), the lower and upper register parts are updated continuously. When the BDU is activated (BDU = '1'), the content of the output registers is not updated until both MSB and LSB are read, avoiding the reading of values related to different samples.



### 8.6 CTRL\_REG2 (11h)

Control register 2

| 7    | 6       | 5           | 4          | 3       | 2       | 1                | 0        |
|------|---------|-------------|------------|---------|---------|------------------|----------|
| BOOT | FIFO_EN | STOP_ON_FTH | IF_ADD_INC | I2C_DIS | SWRESET | 0 <sup>(1)</sup> | ONE_SHOT |

1. This bit must be set to '0' for proper operation of the device

| BOOT        | Reboot memory content. Default value: 0.<br>(0: normal mode; 1: reboot memory content). The bit is self-cleared when the BOOT is completed.                         |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FIFO_EN     | FIFO enable. Default value: 0.<br>(0: disable; 1: enable)                                                                                                           |
| STOP_ON_FTH | Stop on FIFO threshold. Enable FIFO watermark level use. Default value 0 (0: disable; 1: enable)                                                                    |
| IF_ADD_INC  | Register address automatically incremented during a multiple byte access with a serial interface (I <sup>2</sup> C or SPI). Default value 1. (0: disable; 1 enable) |
| I2C_DIS     | Disable I <sup>2</sup> C interface. Default value 0.<br>(0: I <sup>2</sup> C enabled;1: I <sup>2</sup> C disabled)                                                  |
| SWRESET     | Software reset. Default value: 0.<br>(0: normal mode; 1: software reset).<br>The bit is self-cleared when the reset is completed.                                   |
| ONE_SHOT    | One-shot enable. Default value: 0.<br>(0: idle mode; 1: a new dataset is acquired)                                                                                  |

The **BOOT** bit is used to refresh the content of the internal registers stored in the Flash memory block. At device power-up the content of the Flash memory block is transferred to the internal registers related to the trimming functions to allow correct behavior of the device itself. If for any reason the content of the trimming registers is modified, it is sufficient to use this bit to restore the correct values. When the BOOT bit is set to '1', the content of the internal Flash is copied inside the corresponding internal registers and is used to calibrate the device. These values are factory trimmed and they are different for every device. They allow correct behavior of the device and normally they should not be changed. At the end of the boot process the BOOT bit is set again to '0' by hardware. The BOOT bit takes effect after one ODR clock cycle.

**SWRESET** is the software reset bit. The device is reset to the power-on configuration if the SWRESET bit is set to '1' and BOOT is set to '1'.

The **ONE\_SHOT** bit is used to start a new conversion when the ODR[2,0] bits in *CTRL\_REG1 (10h)* are set to '000'. Writing a '1' in ONE\_SHOT triggers a single measurement of pressure and temperature. Once the measurement is done, the ONE\_SHOT bit will self-clear, the new data are available in the output registers, and the STATUS\_REG bits are updated.



### 8.7 CTRL\_REG3 (12h)

Control register 3 - INT\_DRDY pin control register

| 7       | 6     | 5      | 4     | 3     | 2    | 1      | 0      |
|---------|-------|--------|-------|-------|------|--------|--------|
| INT_H_L | PP_OD | F_FSS5 | F_FTH | F_OVR | DRDY | INT_S2 | INT_S1 |

| INT_H_L    | Interrupt active-high/low. Default value: 0.<br>(0: active high; 1: active low)                      |
|------------|------------------------------------------------------------------------------------------------------|
| PP_OD      | Push-pull/open drain selection on interrupt pads. Default value: 0.<br>(0: push-pull; 1: open drain) |
| F_FSS5     | FIFO full flag on INT_DRDY pin. Default value: 0.<br>(0: Disable; 1: Enable)                         |
| F_FTH      | FIFO threshold (Watermark) status on INT_DRDY pin. Default value: 0. (0: Disable; 1: Enable)         |
| F_OVR      | FIFO overrun interrupt on INT_DRDY pin. Default value: 0.<br>(0: Disable; 1: Enable)                 |
| DRDY       | Data-ready signal on INT_DRDY pin. Default value: 0.<br>(0: Disable; 1: Enable)                      |
| INT_S[2:1] | Data signal on INT_DRDY pin control bits. Default value: 00. Refer to <i>Table 18</i> .              |

#### Table 18. Interrupt configurations

| INT_S2 | INT_S1 | INT_DRDY pin configuration                                               |
|--------|--------|--------------------------------------------------------------------------|
| 0      | 0      | Data signal (in order of priority: PTH_DRDY or F_FTH or F_OVR or F_FSSS5 |
| 0      | 1      | Pressure high (P_high)                                                   |
| 1      | 0      | Pressure low (P_low)                                                     |
| 1      | 1      | Pressure low OR high                                                     |

### 8.8 FIFO\_CTRL (14h)

FIFO control register

| 7       | 6       | 5       | 4    | 3    | 2    | 1    | 0    |
|---------|---------|---------|------|------|------|------|------|
| F_MODE2 | F_MODE1 | F_MODE0 | WTM4 | WTM3 | WTM2 | WTM1 | WTM0 |

| F_MODE[2:0] | FIFO mode selection. Default value: 000.<br>Refer to <i>Table 19</i> and <i>Section 4</i> for additional details. |
|-------------|-------------------------------------------------------------------------------------------------------------------|
| WTM[4:0]    | FIFO watermark level selection.                                                                                   |



| F_MODE2 | F_MODE1 | F_MODE0 | FIFO mode selection   |
|---------|---------|---------|-----------------------|
| 0       | 0       | 0       | Bypass mode           |
| 0       | 0       | 1       | FIFO mode             |
| 0       | 1       | 0       | Stream mode           |
| 0       | 1       | 1       | Stream-to-FIFO mode   |
| 1       | 0       | 0       | Bypass-to-Stream mode |
| 1       | 0       | 1       | Reserved              |
| 1       | 1       | 0       | Reserved              |
| 1       | 1       | 1       | Bypass-to-FIFO mode   |

Table 19. FIFO mode selection

### 8.9 **REF\_P\_XL** (15h)

Reference pressure (LSB data)

| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|-------|-------|-------|-------|-------|-------|-------|
| REFL7 | REFL6 | REFL5 | REFL4 | REFL3 | REFL2 | REFL1 | REFL0 |

REFL[7:0] This register contains the low part of the reference pressure value.

The Reference pressure value is a 24-bit data added to the sensor output measurement and it is composed of  $REF_P_H$  (17h),  $REF_P_L$  (16h) and  $REF_P_XL$  (15h). The value is expressed as 2's complement.

The reference pressure value is added to the sensor output measurement, to detect a measured pressure beyond programmed limits (refer to the *CTRL\_REG3 (12h)* register) and for the Autozero function (refer to the *INTERRUPT\_CFG (0Bh)* register).

### 8.10 REF\_P\_L (16h)

Reference pressure (middle part)

| 7      | 6      | 5      | 4      | 3      | 2      | 1     | 0     |
|--------|--------|--------|--------|--------|--------|-------|-------|
| REFL15 | REFL14 | REFL13 | REFL12 | REFL11 | REFL10 | REFL9 | REFL8 |

| REFL[15:8] | This register contains the mid part of the reference pressure value. |
|------------|----------------------------------------------------------------------|
|            | Refer to REF_P_XL (15h).                                             |



### 8.11 **REF\_P\_H** (17h)

Reference pressure (MSB part)

| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------|--------|--------|--------|--------|--------|--------|--------|
| REFL23 | REFL22 | REFL21 | REFL20 | REFL19 | REFL18 | REFL17 | REFL16 |

REFL[23:16] This register contains the high part of the reference pressure value. Refer to *REF\_P\_XL (15h)*.

### 8.12 RPDS\_L (18h)

Pressure offset (LSB data)

| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|-------|-------|-------|-------|-------|-------|-------|
| RPDS7 | RPDS6 | RPDS5 | RPDS4 | RPDS3 | RPDS2 | RPDS1 | RPDS0 |

RPDS[7:0] This register contains the low part of the pressure offset value.

The pressure offset value is a 16-bit data that can be used to implement the one-point calibration (OPC) after soldering, This value is composed of *RPDS\_H (19h)* and *RPDS\_L (18h)*. The value is expressed as 2's complement.

### 8.13 RPDS\_H (19h)

Pressure offset (MSB data)

| 7      | 6      | 5      | 4      | 3      | 2      | 1     | 0     |
|--------|--------|--------|--------|--------|--------|-------|-------|
| RPDS15 | RPDS14 | RPDS13 | RPDS12 | RPDS11 | RPDS10 | RPDS9 | RPDS8 |

RPDS[15:8]This register contains the high part of the pressure offset value.Refer to RPDS\_L (18h).

### 8.14 RES\_CONF (1Ah)

Low-power mode configuration

| 7                | 6                | 5                | 4                | 3                | 2                | 1                       | 0     |
|------------------|------------------|------------------|------------------|------------------|------------------|-------------------------|-------|
| 0 <sup>(1)</sup> | reserved <sup>(2)</sup> | LC_EN |

1. These bits must be set to '0' for proper operation of the device.

2. The content of this bit must not be modified for proper operation of the device

| LC_EN Low current mode enable. Default 0.<br>0: Normal mode (low-noise mode); 1: Low-current mode). | LC_EN |
|-----------------------------------------------------------------------------------------------------|-------|
|-----------------------------------------------------------------------------------------------------|-------|



### 8.15 INT\_SOURCE (25h)

Interrupt source

| 7           | 6 | 5 | 4 | 3 | 2  | 1  | 0  |
|-------------|---|---|---|---|----|----|----|
| BOOT_STATUS | 0 | 0 | 0 | 0 | IA | PL | PH |

| BOOT_STATUS | If '1' indicates that the Boot (Reboot) phase is running.                                                                 |
|-------------|---------------------------------------------------------------------------------------------------------------------------|
| IA          | Interrupt active.<br>(0: no interrupt has been generated;<br>1: one or more interrupt events have been generated).        |
| PL          | Differential pressure Low.<br>(0: no interrupt has been generated;<br>1: Low differential pressure event has occurred).   |
| РН          | Differential pressure High.<br>(0: no interrupt has been generated;<br>1: High differential pressure event has occurred). |

### 8.16 FIFO\_STATUS (26h)

#### FIFO status

| 7        | 6   | 5    | 4    | 3    | 2    | 1    | 0    |
|----------|-----|------|------|------|------|------|------|
| FTH_FIFO | OVR | FSS5 | FSS4 | FSS3 | FSS2 | FSS1 | FSS0 |

| FTH_FIFO | FIFO threshold status.<br>(0: FIFO filling is lower than FTH level,<br>1: FIFO filling is equal or higher than FTH level). |
|----------|----------------------------------------------------------------------------------------------------------------------------|
| OVR      | Overrun bit status.<br>(0: FIFO not full;<br>1: FIFO is full and at least one sample in the FIFO has been overwritten).    |
| FSS[5:0] | FIFO stored data level.<br>(000000: FIFO empty, 100000: FIFO is full and has 32 unread samples).                           |

### 8.17 STATUS (27h)

Status register

| 7 | 6 | 5    | 4    | 3 | 2 | 1    | 0    |
|---|---|------|------|---|---|------|------|
|   |   | T_OR | P_OR |   |   | T_DA | P_DA |



| T_OR | Temperature data overrun.<br>(0: no overrun has occurred;<br>1: a new data for temperature has overwritten the previous one)   |
|------|--------------------------------------------------------------------------------------------------------------------------------|
| P_OR | Pressure data overrun.<br>(0: no overrun has occurred;<br>1: new data for pressure has overwritten the previous one)           |
| T_DA | Temperature data available.<br>(0: new data for temperature is not yet available;<br>1: new data for temperature is available) |
| P_DA | Pressure data available.<br>(0: new data for pressure is not yet available;<br>1: new data for pressure is available)          |

This register is updated every ODR cycle.

**T\_OR** is set to '1' when a new temperature data is generated before the previous one has been read.

**P\_OR** is set to '1' when a new pressure data is generated before the previous one has been read.

### 8.18 PRESS\_OUT\_XL (28h)

Pressure output value (LSB)

| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|-------|-------|-------|-------|-------|-------|-------|
| POUT7 | POUT6 | POUT5 | POUT4 | POUT3 | POUT2 | POUT1 | POUT0 |

POUT[7:0] This register contains the low part of the pressure output value.

The pressure output value is a 24-bit data that contains the measured pressure. It is composed of *PRESS\_OUT\_H* (2Ah), *PRESS\_OUT\_L* (29h) and *PRESS\_OUT\_XL* (28h). The value is expressed as 2's complement.

#### 8.19 PRESS\_OUT\_L (29h)

Pressure output value (mid part)

| 7      | 6      | 5      | 4      | 3      | 2      | 1     | 0     |
|--------|--------|--------|--------|--------|--------|-------|-------|
| POUT15 | POUT14 | POUT13 | POUT12 | POUT11 | POUT10 | POUT9 | POUT8 |

| POUT[15:8] | This register contains the mid part of the pressure output value. |
|------------|-------------------------------------------------------------------|
|            | Refer to PRESS_OUT_XL (28h).                                      |



### 8.20 PRESS\_OUT\_H (2Ah)

Pressure output value (MSB)

| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------|--------|--------|--------|--------|--------|--------|--------|
| POUT23 | POUT22 | POUT21 | POUT20 | POUT19 | POUT18 | POUT17 | POUT16 |

POUT[23:16] This register contains the low part of the pressure output value. Refer to *PRESS\_OUT\_XL (28h)*.

### 8.21 TEMP\_OUT\_L (2Bh)

Temperature output value (LSB)

| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|-------|-------|-------|-------|-------|-------|-------|
| TOUT7 | TOUT6 | TOUT5 | TOUT4 | TOUT3 | TOUT2 | TOUT1 | TOUT0 |

TOUT[7:0] This register contains the low part of the temperature output value.

The temperature output value is a 16-bit data that contains the measured temperature. It is composed of *TEMP\_OUT\_H (2Ch)*, and *TEMP\_OUT\_L (2Bh)*. The value is expressed as 2's complement.

### 8.22 TEMP\_OUT\_H (2Ch)

Temperature output value (MSB)

| 7      | 6      | 5      | 4      | 3      | 2      | 1     | 0     |
|--------|--------|--------|--------|--------|--------|-------|-------|
| TOUT15 | TOUT14 | TOUT13 | TOUT12 | TOUT11 | TOUT10 | TOUT9 | TOUT8 |

TOUT[15:8] This register contains the high part of the temperature output value.

The temperature output value is a 24-bit data that contains the measured temperature. It is composed of *PRESS\_OUT\_H (2Ah)*, and *PRESS\_OUT\_XL (28h)*. The value is expressed as 2's complement.

### 9 Package mechanical data

In order to meet environmental requirements, ST offers these devices in different grades of ECOPACK<sup>®</sup> packages, depending on their level of environmental compliance. ECOPACK<sup>®</sup> specifications, grade definitions and product status are available at: *www.st.com*. ECOPACK<sup>®</sup> is an ST trademark.







Pad Inset

0.10

±0.05

### 10 Revision history

| Date        | Revision | Changes          |
|-------------|----------|------------------|
| 29-Oct-2014 | 1        | Initial release. |



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

© 2014 STMicroelectronics – All rights reserved

