# imall

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



# Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China





## LPS25H

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



### Features

- 260 to 1260 hPa absolute pressure range
- High-resolution mode: 1 Pa RMS
- Low power consumption:
  - Low resolution mode: 4 µA
  - High resolution mode: 25 µA
- High overpressure capability: 20x full scale
- Embedded temperature compensation
- Embedded 24-bit ADC
- Selectable ODR from 1 Hz to 25 Hz
- SPI and I<sup>2</sup>C interfaces
- Embedded FIFO
- Supply voltage: 1.7 to 3.6 V
- High shock survivability: 10,000 g
- Small and thin package
- ECOPACK<sup>®</sup> lead-free compliant

Datasheet - not recommended for new design

### **Applications**

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

### Description

The LPS25H is an ultra compact absolute piezoresistive pressure sensor. It includes a monolithic sensing element and an IC interface able to take the information from the sensing element and to provide a digital signal to the external world.

The sensing element consists of a suspended membrane realized inside a single mono-silicon substrate. It is capable to detect the absolute pressure and is manufactured with a dedicated process developed by ST.

The membrane is very small compared to the traditionally built silicon micromachined membranes. Membrane breakage is prevented by an intrinsic mechanical stopper.

The IC interface is manufactured using a standard CMOS process that allows a high level of integration to design a dedicated circuit which is trimmed to better match the sensing element characteristics.

The LPS25H is available in a cavity holed LGA package (HCLGA). It is guaranteed to operate over a temperature range extending from -30 °C to +105 °C. The package is holed to allow external pressure to reach the sensing element.

#### Table 1. Device summary

| Order code | Temperature range [°C] | Package   | Packing       |
|------------|------------------------|-----------|---------------|
| LPS25HTR   | -30 to +105            | HCLGA-10L | Tape and reel |
| LPS25H     | -50 10 + 105           | HOLGA-TOL | Tray          |

### Contents

| 1 | Bloc  | k diagra             | am and pin description5                                |
|---|-------|----------------------|--------------------------------------------------------|
|   | 1.1   | Pin de               | scription                                              |
| 2 | Mec   | hanical              | and electrical specifications7                         |
|   | 2.1   | Mecha                | nical characteristics                                  |
|   | 2.2   | Electri              | cal characteristics                                    |
|   | 2.3   | Comm                 | unication interface characteristics                    |
|   |       | 2.3.1                | SPI - serial peripheral interface8                     |
|   |       | 2.3.2                | I <sup>2</sup> C - inter IC control interface          |
|   | 2.4   | Absolu               | ite maximum ratings 10                                 |
| 3 | Fund  | ctionalit            | y 11                                                   |
|   | 3.1   | Sensir               | ng element                                             |
|   | 3.2   | IC inte              | rface                                                  |
|   | 3.3   | Factor               | y calibration                                          |
|   | 3.4   | FIFO .               |                                                        |
|   |       | 3.4.1                | Bypass mode (F MODE2:0="000" in FIFO CTRL (2Eh))       |
|   |       | 3.4.2                | FIFO mode (F_MODE2:0="001" in FIFO_CTRL (2Eh))         |
|   |       | 3.4.3                | Stream mode (F_MODE2:0="010" in FIFO_CTRL (2Eh))       |
|   |       | 3.4.4                | FIFO mean mode (F_MODE2:0="110" in FIFO_CTRL (2Eh)) 12 |
| 4 | Арр   | lication             | hints                                                  |
|   | 4.1   | Solder               | ing information                                        |
| 5 | Digit | tal inter            | faces                                                  |
|   | 5.1   | I <sup>2</sup> C ser | rial interface                                         |
|   | 5.2   | I <sup>2</sup> C ser | rial interface (CS=High)                               |
|   |       | 5.2.1                | I <sup>2</sup> C operation                             |
|   | 5.3   | SPI bu               | is interface                                           |
|   |       | 5.3.1                | SPI read                                               |
|   |       | 5.3.2                | SPI write                                              |
|   |       | 5.3.3                | SPI read in 3-wires mode                               |



| 6  | Regis | ster mapping                                | 20 |
|----|-------|---------------------------------------------|----|
| 7  | Regis | ster description                            | 22 |
|    | 7.1   | REF_P_XL                                    | 22 |
|    | 7.2   | REF_P_L                                     | 23 |
|    | 7.3   | REF_P_H                                     | 23 |
|    | 7.4   | WHO_AM_I                                    | 23 |
|    | 7.5   | RES_CONF                                    | 24 |
|    | 7.6   | CTRL_REG1                                   | 25 |
|    | 7.7   | CTRL_REG2                                   | 27 |
|    | 7.8   | CTRL_REG3                                   | 28 |
|    | 7.9   | CTRL_REG4                                   | 29 |
|    | 7.10  | INTERRUPT_CFG                               | 30 |
|    | 7.11  | INT_SOURCE                                  | 31 |
|    | 7.12  | STATUS_REG                                  | 31 |
|    | 7.13  | PRESS_OUT_XL                                | 32 |
|    | 7.14  | PRESS_OUT_L                                 | 33 |
|    | 7.15  | PRESS_OUT_H                                 | 33 |
|    | 7.16  | TEMP_OUT_L                                  | 33 |
|    | 7.17  | TEMP_OUT_H                                  | 34 |
|    | 7.18  | FIFO_CTRL                                   | 34 |
|    | 7.19  | FIFO_STATUS                                 | 35 |
|    | 7.20  | THS_P_L                                     | 36 |
|    | 7.21  | THS_P_H                                     | 36 |
|    | 7.22  | RPDS_L                                      | 36 |
|    | 7.23  | RPDS_H                                      | 37 |
| 8  | FIFO  | operating details                           | 38 |
|    | 8.1   | FIFO registers                              | 38 |
| 9  | Hardy | ware digital filter                         | 10 |
|    | 9.1   | Filter enabling and suggested configuration | 40 |
| 10 | Packa | age mechanical data                         | 11 |



| 11 | <b>Revision history</b> |  | 14 |
|----|-------------------------|--|----|
|----|-------------------------|--|----|



### 1 Block diagram and pin description



### 1.1 Pin description



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



| Pin n° | Name                  | Function                                                                                                               |
|--------|-----------------------|------------------------------------------------------------------------------------------------------------------------|
| 1      | VDD_IO                | Power supply for I/O pins                                                                                              |
| 2      | SCL<br>SPC            | I²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²C less significant bit of the device address (SA0)                            |
| 6      | CS                    | SPI enable<br>I <sup>2</sup> C/SPI mode selection (1: I <sup>2</sup> C mode; 0: SPI enabled)                           |
| 7      | INT1                  | Interrupt 1 (or data ready)                                                                                            |
| 8      | GND                   | 0 V supply                                                                                                             |
| 9      | GND                   | 0 V supply                                                                                                             |
| 10     | VDD                   | Power supply                                                                                                           |

#### Table 2. Pin description



## 2 Mechanical and electrical specifications

### 2.1 Mechanical characteristics

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

| Symbol  | Parameter                                                  | Test condition                         | Min. | Typ. <sup>(1)</sup> | Max. | Unit        |
|---------|------------------------------------------------------------|----------------------------------------|------|---------------------|------|-------------|
| Тор     | Operating temperature range                                |                                        | -30  |                     | 105  | °C          |
| Tfull   | Full accuracy temperature range                            |                                        | 0    |                     | 80   | °C          |
| Рор     | Operating pressure range                                   |                                        | 260  |                     | 1260 | hPa         |
| Pbits   | Pressure output data                                       |                                        |      | 24                  |      | bits        |
| Psens   | Pressure sensitivity                                       |                                        |      | 4096                |      | LSB/<br>hPa |
| Paccrel | Relative accuracy over pressure <sup>(2)</sup>             | P = 800 to 1100 hPa<br>T = 25°C        |      | ± 0.1               |      | hPa         |
| PaccT   | Absolute accuracy pressure over temperature <sup>(3)</sup> | P = 260 to 1260 hPa<br>T = 20 ~ +60 °C |      | ± 0.2               |      | hPa         |
|         |                                                            | P = 260 to 1260 hPa<br>T = 0 ~ +80 °C  |      | ± 1                 |      | in a        |
| Pnoise  | Pressure noise <sup>(4)</sup>                              | without embedded filtering             |      | 0.03                |      | hPa         |
| Phoise  |                                                            | with embedded filtering                |      | 0.01                |      | RMS         |
| Tbits   | Temperature output data                                    |                                        |      | 16                  |      | bits        |
| Tsens   | Temperature sensitivity                                    |                                        |      | 480                 |      | LSB/°C      |
| Тасс    | Absolute accuracy temperature                              | T= 0 ~ +65 °C                          | 1    | ± 2                 |      | °C          |

| Table 3. Mechanical | characteristics |
|---------------------|-----------------|
|---------------------|-----------------|

1. Typical specifications are not guaranteed.

2. Characterization data. Parameter not tested at final test

3. Embedded quadratic compensation.

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



### 2.2 Electrical characteristics

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

| Symbol | Parameter                                      | Test condition | Min. | Typ. <sup>(1)</sup> | Max. | Unit |
|--------|------------------------------------------------|----------------|------|---------------------|------|------|
| VDD    | Supply voltage                                 |                | 1.7  |                     | 3.6  | V    |
| VDD_IO | IO supply voltage                              |                | 1.7  |                     | 3.6  | V    |
| ldd    | Supply current @ ODR 1 Hz, highest resolution  |                |      | 25                  |      | μA   |
| lddPdn | Supply current in power-down mode<br>T = 25 °C |                |      | 0.5                 |      | μA   |

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_{\rm OP}$ 

| Symbol   | Parameter               | Valu | Unit |      |
|----------|-------------------------|------|------|------|
|          | Falanielei              | Min  | Max  | Onic |
| tc(SPC)  | SPI clock cycle         | 100  |      | ns   |
| fc(SPC)  | SPI clock frequency     |      | 10   | MHz  |
| tsu(CS)  | CS setup time           | 6    |      |      |
| th(CS)   | CS hold time            | 8    |      |      |
| tsu(SI)  | SDI input setup time    | 5    |      |      |
| th(SI)   | SDI input hold time     | 15   |      | ns   |
| tv(SO)   | SDO valid output time   |      | 50   |      |
| th(SO)   | SDO output hold time    | 9    |      |      |
| tdis(SO) | 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.



Figure 3. SPI slave timing diagram

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

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

Subject to general operating conditions for Vdd and  $T_{OP}$ .

|                         |                                                | I C Slave li            | ming values             |                                       |      |      |  |
|-------------------------|------------------------------------------------|-------------------------|-------------------------|---------------------------------------|------|------|--|
| Symbol                  | Parameter <sup>(1)</sup>                       | I <sup>2</sup> C standa | ard mode <sup>(1)</sup> | I <sup>2</sup> C fast i               | Unit |      |  |
|                         | Parameter                                      | Min                     | Мах                     | Min                                   | Мах  |      |  |
| 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_{r(SDA)} t_{r(SCL)}$ | SDA and SCL rise time                          |                         | 1000                    | 20 + 0.1C <sub>b</sub> <sup>(2)</sup> | 300  | 20   |  |
| $t_{f(SDA)} t_{f(SCL)}$ | SDA and SCL fall time                          |                         | 300                     | 20 + 0.1C <sub>b</sub> <sup>(2)</sup> | 300  | 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                                   |      |      |  |

Table 6. I<sup>2</sup>C slave timing values

1. Data based on standard I2C protocol requirement, not tested in production.

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







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

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

| Table | 7.  | Absolute   | maximum  | ratings |
|-------|-----|------------|----------|---------|
| IUNIO | ••• | / 10001010 | maximani | racingo |

Note:

Supply voltage on any pin should never exceed 4.8 V.

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



This is an ESD sensitive device, improper handling can cause permanent damage to the part.



### 3 Functionality

The LPS25H is a high resolution, digital output pressure sensor packaged in a HCLGA holed package. The complete device includes a sensing element based on a piezoresistive Wheatstone bridge approach, and an IC interface able to take the information from the sensing element to the external world, as a digital signal.

### 3.1 Sensing element

An ST proprietary process is used to obtain a mono-silicon  $\mu$ -sized membrane for MEMS pressure sensors, without requiring substrate to substrate bonding. 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 pressure overstress, ensuring measurement repeatability.

The pressure inside the buried cavity under the membrane is constant and controlled by process parameters.

### 3.2 IC interface

The complete measurement chain is composed by a low-noise amplifier which converts the resistance unbalancing of the MEMS sensors (pressure and temperature) into an analog voltage that is finally available to the user by 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 LPS25H 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 by a non-volatile structure. Whenever the device is turned on, the trimming parameters are downloaded into the registers to be employed during normal operation. This allows the user to employ the device without requiring any further calibration.

### 3.4 FIFO

The LPS25H embeds FIFO register able to store 32 pressure output values, in order to improve the system power saving, since the host processor does not need to continuously poll data from the sensor, but it can wakeup only when requested and burst the significant data out from the FIFO.



DocID023722 Rev 5

The FIFO buffer is enabled by setting to 1 the FIFO\_EN bit (21h - CTRL\_REG2) and can work accordingly to 4 different modes: bypass mode, FIFO mode, Stream mode and FIFO Mean mode. Each mode is selected by the FIFO\_MODE bits in FIFO\_CTRL (2Eh).

Programmable Watermark level WTM\_POINT4:0 (FIFO\_CTRL register, 2Eh), EMPTY\_FIFO or FULL\_FIFO events can be enabled to generate dedicated interrupts on the INT1 pin (configuration through CTRL3 (22h) and CTRL4 (23h)).

### 3.4.1 Bypass mode (F\_MODE2:0="000" in FIFO\_CTRL (2Eh))

The FIFO is not operational and for this reason it remains empty.

#### 3.4.2 FIFO mode (F\_MODE2:0="001" in FIFO\_CTRL (2Eh))

The data from PRESS\_OUT\_XL (28h), PRESS\_OUT\_L (29h) and PRESS\_OUT\_H (2Ah) are stored in the FIFO.

A Watermark interrupt can be enabled (WTM\_EN bit in CTRL2 (21h) in order to be raised when the FIFO is filled to the level specified in the WTM\_POINT4:0 bits of FIFO\_CTRL (2Eh). The FIFO continues filling until it is full (32 slots of data for XL, L and H). When full, the FIFO stops collecting data from the input pressure data.

#### 3.4.3 Stream mode (F\_MODE2:0="010" in FIFO\_CTRL (2Eh))

The data from PRESS\_OUT\_XL (28h), PRESS\_OUT\_L (29h) and PRESS\_OUT\_H (2Ah) measurements are stored in the FIFO. The FIFO continues filling until it's full (32 slots of data for XL, L and H). When full, the FIFO discards the older data as the new arrive. A Watermark interrupt can be enabled and set as in FIFO mode.

Stream mode is use to implement the digital filter averaging the samples stored in the FIFO

#### 3.4.4 FIFO mean mode (F\_MODE2:0="110" in FIFO\_CTRL (2Eh))

The pressure data are not directly sent to the output register but are firstly stored in the FIFO to calculate the average. The FIFO Mean Mode can be enabled by setting the FIFO\_MEAN\_DEC bit (CTRL\_REG2, 21h). The number of averaged samples can be set by changing the watermark in WTM\_POINT4:0 bits of FIFO\_CTRL (2Eh).



### 4 Application hints



Figure 5. LPS25H electrical connection

The device core is supplied through the VDD line. Power supply decoupling capacitors (100 nF, 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 high (i.e. connected to VDD\_IO).

### 4.1 Soldering information

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



### 5 Digital interfaces

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

The registers embedded in the LPS25H 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<sup>2</sup>C interface, 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: I <sup>2</sup> C mode; 0: SPI enabled)                           |
| SCL/SPC               | I <sup>2</sup> 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. Serial interface pin description

### 5.2 I<sup>2</sup>C serial interface (CS=High)

The LPS25H 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. Serial interface pin description

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.



### 5.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 LPS25H 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 LPS25H 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 in the LPS25H 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 (SAK) has been returned, a 8-bit sub-address (SUB) will be transmitted: the 7 LSB represents the actual register address while the MSB enables address auto increment. If the MSb of the SUB field is '1', the SUB (register address) will be automatically increased to allow multiple data read/write.

The slave address is completed with a Read/Write bit. If the bit was '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 |
|-----------|----------------|----------|
|-----------|----------------|----------|

| Table 11. Transfer when | master is writing one byte to slave |
|-------------------------|-------------------------------------|
|-------------------------|-------------------------------------|

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



|        |    |         |     |     |     |      | <b>,</b> |      |     |    |
|--------|----|---------|-----|-----|-----|------|----------|------|-----|----|
| 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.



### 5.3 SPI bus interface

The LPS25H SPI is a bus slave. The SPI allows to write and read the registers of the device. The serial interface interacts with the outside world with 4 wires: **CS**, **SPC**, **SDI** and **SDO**.



Figure 6. Read and write protocol

**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 bytes read/write. 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*: MS bit. When 0, the address will remain unchanged in multiple read/write commands. When 1, the address will be auto incremented in multiple read/write commands.

bit 2-7: address AD(5: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  $M\overline{S}$  bit is 0 the address used to read/write data remains the same for every block. When  $M\overline{S}$  bit is 1 the address used to read/write data is increased at every block.

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



#### 5.3.1 SPI read



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

bit 0: READ bit. The value is 1.

bit 1: MS bit. When 0 do not increment address, when 1 increment address in multiple reading.

bit 2-7: address AD(5: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 readings.



#### 5.3.2 SPI write



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

bit 0: WRITE bit. The value is 0.

DocID023722 Rev 5



*bit* **1**:  $M\overline{S}$  bit. When 0 do not increment the address, when 1 increment the address in multiple writings.

*bit 2 -7*: address AD(5: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 writings.



#### Figure 10. Multiple bytes SPI write protocol (2 bytes example)

#### 5.3.3 SPI read in 3-wires mode

A 3-wires mode is entered by setting to '1' bit SIM (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*:  $M\overline{S}$  bit. When 0, do not increment the address, when 1, increment the address in multiple readings.

bit 2-7: address AD(5: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). Multiple read command is also available in 3-wires mode.



## 6 Register mapping

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

| Table 15. Registers address map |      |                     |          |                      |  |  |  |  |  |
|---------------------------------|------|---------------------|----------|----------------------|--|--|--|--|--|
| Name                            | Туре | Register<br>address | Default  | Function and comment |  |  |  |  |  |
|                                 |      | Hex                 | Binary   |                      |  |  |  |  |  |
| Reserved (do not modify)        |      | 00-07<br>0D - 0E    |          | Reserved             |  |  |  |  |  |
| REF_P_XL                        | R/W  | 08                  | 00000000 |                      |  |  |  |  |  |
| REF_P_L                         | R/W  | 09                  | 00000000 |                      |  |  |  |  |  |
| REF_P_H                         | R/W  | 0A                  | 00000000 |                      |  |  |  |  |  |
| WHO_AM_I                        | R    | 0F                  | 10111101 | ID register          |  |  |  |  |  |
| RES_CONF                        | R/W  | 10                  | 00000101 |                      |  |  |  |  |  |
| Reserved (Do not modify)        |      | 11-1F               |          | Reserved             |  |  |  |  |  |
| CTRL_REG1                       | R/W  | 20                  | 00000000 |                      |  |  |  |  |  |
| CTRL_REG2                       | R/W  | 21                  | 00000000 |                      |  |  |  |  |  |
| CTRL_REG3                       | R/W  | 22                  | 00000000 |                      |  |  |  |  |  |
| CTRL_REG4                       | R/W  | 23                  | 00000000 |                      |  |  |  |  |  |
| INT_CFG                         | R/W  | 24                  | 00000000 |                      |  |  |  |  |  |
| INT_SOURCE                      | R    | 25                  | 00000000 |                      |  |  |  |  |  |
| Reserved (Do not modify)        |      | 26                  |          | Reserved             |  |  |  |  |  |
| STATUS_REG                      | R    | 27                  | 00000000 |                      |  |  |  |  |  |
| PRESS_POUT_XL                   | R    | 28                  | output   |                      |  |  |  |  |  |
| PRESS_OUT_L                     | R    | 29                  | output   |                      |  |  |  |  |  |
| PRESS_OUT_H                     | R    | 2A                  | output   |                      |  |  |  |  |  |
| TEMP_OUT_L                      | R    | 2B                  | output   |                      |  |  |  |  |  |
| TEMP_OUT_H                      | R    | 2C                  | output   |                      |  |  |  |  |  |
| Reserved (do not modify)        |      | 2D                  |          | Reserved             |  |  |  |  |  |
| FIFO_CTRL                       | R/W  | 2E                  | 00000000 |                      |  |  |  |  |  |
| FIFO_STATUS                     | R    | 2F                  | 00000000 |                      |  |  |  |  |  |
| THS_P_L                         | R/W  | 30                  | 00000000 |                      |  |  |  |  |  |
| THS_P_H                         | R/W  | 31                  | 00000000 |                      |  |  |  |  |  |
| Reserved                        |      | 32-38               |          |                      |  |  |  |  |  |
| RPDS_L                          | R/W  | 39                  | 00111000 |                      |  |  |  |  |  |
| RPDS_H                          | R/W  | 3A                  | 00000000 |                      |  |  |  |  |  |

Table 15. Registers address map



Registers marked as *Reserved* must not be changed. The writing to those registers may cause permanent damages to the device. 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.



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

### 7.1 REF\_P\_XL

### Reference pressure (LSB data)

| 7            | 6                           | 5                                                            | 4                                             | 3                                            | 2                                                                                   | 1                                               | 0                                    |  |  |  |  |  |
|--------------|-----------------------------|--------------------------------------------------------------|-----------------------------------------------|----------------------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------|--------------------------------------|--|--|--|--|--|
| REFL7        | REFL6                       | REFL5                                                        | REFL4                                         | REFL3                                        | REFL2                                                                               | REFL1                                           | REFL0                                |  |  |  |  |  |
| Address:     | 08h (R                      | 08h (R/W)                                                    |                                               |                                              |                                                                                     |                                                 |                                      |  |  |  |  |  |
| Reset:       | 00h                         | 00h                                                          |                                               |                                              |                                                                                     |                                                 |                                      |  |  |  |  |  |
| Description: | is sum<br>by REI<br>referer | to the sensor<br>-P_XL, REF<br>nce pressure<br>mmed limits ( | r output press<br>-P_H & REF<br>value can als | sure. The full<br>P_L and is<br>o be used to | art of the refe<br>reference pre<br>represented a<br>detect a mea<br>I for Autozero | essure value i<br>as 2's comple<br>sured pressu | s composed<br>ment. The<br>re beyond |  |  |  |  |  |

[7:0] REFL7-0: LSB reference pressure data



### 7.2 REF\_P\_L

### Reference pressure (middle part)

| 15           | 14     | 13                                                                                                                                                   | 12     | 11     | 10     | 9     | 8     |  |
|--------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|--------|-------|-------|--|
| REFL15       | REFL14 | REFL13                                                                                                                                               | REFL12 | REFL11 | REFL10 | REFL9 | REFL8 |  |
| Address:     | 09h (R | 09h (R/W)                                                                                                                                            |        |        |        |       |       |  |
| Reset:       | 00h    | 00h                                                                                                                                                  |        |        |        |       |       |  |
| Description: |        | The REF_P_L register contains the middle part of the reference pressure value that is sum to the sensor output pressure. (See REF_P_XL description). |        |        |        |       |       |  |

[15:8] REFL15-8:Middle part reference pressure data

### 7.3 REF\_P\_H

### Reference pressure (MSB data)

| 23           | 22     | 21                                                                                                                                                   | 20     | 19     | 18     | 17     | 16     |  |
|--------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|--------|--------|--------|--|
| REFL23       | REFL22 | REFL21                                                                                                                                               | REFL20 | REFL19 | REFL18 | REFL17 | REFL16 |  |
| Address:     | 0Ah (R | 0Ah (R/W)                                                                                                                                            |        |        |        |        |        |  |
| Reset:       | 00h    | 00h                                                                                                                                                  |        |        |        |        |        |  |
| Description: |        | The REF_P_H register contains the highest part of the reference pressure value that is sum to the sensor output pressure.(See description REF_P_XL). |        |        |        |        |        |  |

[23:16] REFL23-16: MSB reference pressure data.

### 7.4 WHO\_AM\_I





### 7.5 RES\_CONF

### Pressure and temperature resolution mode

| 7            | 6                                                        | 5     | 4 | 3     | 2     | 1     | 0     |  |
|--------------|----------------------------------------------------------|-------|---|-------|-------|-------|-------|--|
|              | Rese                                                     | erved |   | AVGT1 | AVGT0 | AVGP1 | AVGP0 |  |
| Address:     | 10h (R                                                   | /W)   |   |       |       |       |       |  |
| Reset:       | 05h                                                      | 05h   |   |       |       |       |       |  |
| Description: | Pressure and temperature internal average configuration. |       |   |       |       |       |       |  |

[7:4] Reserved

[3:2] AVGP1-0: select the pressure internal average. See Table 16.

[1:0] AVGT1-0: select the temperature internal average. See *Table 17*.

#### Table 16. Pressure resolution configuration

| AVGP1 | AVGP0 | N. internal average |
|-------|-------|---------------------|
| 0     | 0     | 8                   |
| 0     | 1     | 32                  |
| 1     | 0     | 128                 |
| 1     | 1     | 512                 |

| Table 17 | . Temperature | resolution | configuration |
|----------|---------------|------------|---------------|
|----------|---------------|------------|---------------|

| AVGT1 | AVGT0 | N. internal average |
|-------|-------|---------------------|
| 0     | 0     | 8                   |
| 0     | 1     | 16                  |
| 1     | 0     | 32                  |
| 1     | 1     | 64                  |



### 7.6 CTRL\_REG1

#### **Control register 1**

| 7            |                                   | 6                                                                                                                                                                                    | 5                                                                                                                                                                                                                              | 4                                                                                              | 3                                                                      | 2              | 1                                    | 0   |
|--------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|----------------|--------------------------------------|-----|
| PD           | O                                 | DR2                                                                                                                                                                                  | ODR1                                                                                                                                                                                                                           | ODR0                                                                                           | DIFF_EN                                                                | BDU            | RESET_AZ                             | SIM |
| Address:     |                                   | 20h (R                                                                                                                                                                               | /W)                                                                                                                                                                                                                            |                                                                                                |                                                                        |                |                                      |     |
| Reset:       |                                   | 00h                                                                                                                                                                                  |                                                                                                                                                                                                                                |                                                                                                |                                                                        |                |                                      |     |
| Description: | [7]<br>[6:4]<br>[3]<br>[2]<br>[1] | Control<br>PD: pow<br>Default<br>(0: powe<br>ODR2, 0<br>Default<br>(see Tak<br>DIFF_E<br>Default<br>(0: intern<br>BDU: blo<br>Default<br>(0: conti<br>RESET_<br>register<br>(1: Rese | er-down mode;<br>DDR1, ODR0:<br>value: 00<br>ble 18)<br>N: Interrupt circ<br>value: 0<br>rupt generation<br>ock data updat<br>value: 0<br>nuous update;<br>_AZ: Reset Aut<br>(@0x39/A)<br>et. 0: disable)<br>PI Serial Interfa | 1: active mod<br>output data ra<br>cuit enable.<br>n disabled; 1: in<br>re.<br>1: output regis | te selection.<br>nterrupt circuit<br>sters not updat<br>n. Reset REF_F | ed until MSB a | and LSB reading<br>sure to default v |     |

**PD** bit allows to turn on the device. The device is in power-down mode when PD = '0' (default value after boot). The device is active when PD is set to '1'.

**ODR2- ODR1 - ODR0** bits allow to change the output data rates of pressure and temperature samples. The default value is "000" which corresponds to "one shot configuration" for both pressure and temperature output. ODR2, ODR1 and ODR0 bits can be configured as described in *Table 18*.

| ODR2 | ODR1 | ODR0 | Pressure (Hz) | Temperature (Hz) |  |  |  |
|------|------|------|---------------|------------------|--|--|--|
| 0    | 0    | 0    | One shot      |                  |  |  |  |
| 0    | 0    | 1    | 1 Hz          | 1 Hz             |  |  |  |
| 0    | 1    | 0    | 7 Hz          | 7 Hz             |  |  |  |
| 0    | 1    | 1    | 12.5 Hz       | 12.5 Hz          |  |  |  |
| 1    | 0    | 0    | 25 Hz         | 25 Hz            |  |  |  |
| 1    | 0    | 1    | Reserved      |                  |  |  |  |

Table 18. Output data rate bit configurations

