1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

drivers/lpsxxx: add support for lps22hh

This commit is contained in:
Vera Clemens 2021-09-22 17:37:11 +02:00
parent ea8e632eda
commit 06359e05ad
10 changed files with 77 additions and 8 deletions

View File

@ -76,7 +76,7 @@ ifneq (,$(filter tmp1075 lm75%,$(USEMODULE)))
USEMODULE += lm75
endif
ifneq (,$(filter lps331ap lps2%hb,$(USEMODULE)))
ifneq (,$(filter lps331ap lps2%hb lps22hh,$(USEMODULE)))
USEMODULE += lpsxxx
endif

View File

@ -81,6 +81,13 @@ typedef enum {
LPSXXX_RATE_25HZ = 3, /**< sample with 25Hz, default */
LPSXXX_RATE_50HZ = 4, /**< sample with 50Hz */
LPSXXX_RATE_75HZ = 5 /**< sample with 75Hz */
#elif MODULE_LPS22HH
LPSXXX_RATE_10HZ = 2, /**< sample with 10Hz */
LPSXXX_RATE_25HZ = 3, /**< sample with 25Hz, default */
LPSXXX_RATE_50HZ = 4, /**< sample with 50Hz */
LPSXXX_RATE_75HZ = 5, /**< sample with 75Hz */
LPSXXX_RATE_100HZ = 6, /**< sample with 100Hz */
LPSXXX_RATE_200HZ = 7 /**< sample with 200Hz */
#endif
} lpsxxx_rate_t;
@ -89,7 +96,7 @@ typedef enum {
*/
#if MODULE_LPS331AP || MODULE_LPS25HB
#define LPSXXX_DEFAULT_RATE (LPSXXX_RATE_7HZ)
#else /* MODULE_LPS22HB */
#else /* MODULE_LPS22HB || MODULE_LPS22HH */
#define LPSXXX_DEFAULT_RATE (LPSXXX_RATE_25HZ)
#endif

View File

@ -13,7 +13,7 @@ choice
depends on TEST_KCONFIG
help
Device driver for the LPSXXX pressure sensor family
(LPS331AP/LPS25HB/LPS22HB). Select a model.
(LPS331AP/LPS25HB/LPS22HB/LPS22HH). Select a model.
config MODULE_LPS331AP
bool "LPS331AP"
@ -23,6 +23,10 @@ config MODULE_LPS22HB
bool "LPS22HB"
select MODULE_LPSXXX
config MODULE_LPS22HH
bool "LPS22HH"
select MODULE_LPSXXX
config MODULE_LPS25HB
bool "LPS25HB"
select MODULE_LPSXXX

View File

@ -168,7 +168,57 @@ extern "C" {
*/
#define LPSXXX_WHO_AM_I (0xb1)
#endif /* MODULE_LPS22HB */
#elif MODULE_LPS22HH
/**
* @name LPS22HH registers
* @{
*/
#define LPSXXX_REG_INT_CFG (0x0b)
#define LPSXXX_REG_THS_P_L (0x0c)
#define LPSXXX_REG_THS_P_H (0x0d)
#define LPSXXX_REG_IF_CTRL (0x0e)
#define LPSXXX_REG_CTRL_REG1 (0x10)
#define LPSXXX_REG_CTRL_REG2 (0x11)
#define LPSXXX_REG_CTRL_REG3 (0x12)
#define LPSXXX_REG_FIFO_CTRL (0x13)
#define LPSXXX_REG_FIFO_WTM (0x14)
#define LPSXXX_REG_REF_P_L (0x15)
#define LPSXXX_REG_REF_P_H (0x16)
#define LPSXXX_REG_RPDS_L (0x18)
#define LPSXXX_REG_RPDS_H (0x19)
#define LPSXXX_REG_INT_SOURCE (0x24)
#define LPSXXX_REG_FIFO_STATUS1 (0x25)
#define LPSXXX_REG_FIFO_STATUS2 (0x26)
#define LPSXXX_REG_FIFO_OUT_PRESS_XL (0x78)
#define LPSXXX_REG_FIFO_OUT_PRESS_L (0x79)
#define LPSXXX_REG_FIFO_OUT_PRESS_H (0x7a)
#define LPSXXX_REG_FIFO_OUT_TEMP_L (0x7b)
#define LPSXXX_REG_FIFO_OUT_TEMP_H (0x7c)
/** @} */
/**
* @name LPS22HH CTRL_REG1 bitfields
* @{
*/
#define LPSXXX_CTRL_REG1_EN_LPFP (0x08)
#define LPSXXX_CTRL_REG1_LPFP_CFG (0x04)
#define LPSXXX_CTRL_REG1_BDU (0x02)
/** @} */
/**
* @name LPS22HH CTRL_REG2 bitfields
* @{
*/
#define LPSXXX_CTRL_REG2_ID_ADD_INC (0x10)
/** @} */
/**
* @brief LPS22HH WHO_AM_I register value
*/
#define LPSXXX_WHO_AM_I (0xb3)
#endif /* MODULE_LPS22HH */
#ifdef __cplusplus
}

View File

@ -55,6 +55,8 @@ extern "C" {
#define LPSXXX_SAUL_NAME "lps25hb"
#elif MODULE_LPS22HB
#define LPSXXX_SAUL_NAME "lps22hb"
#elif MODULE_LPS22HH
#define LPSXXX_SAUL_NAME "lps22hh"
#endif
#ifndef LPSXXX_SAUL_INFO
#define LPSXXX_SAUL_INFO { .name = LPSXXX_SAUL_NAME }

View File

@ -106,6 +106,9 @@ int lpsxxx_init(lpsxxx_t *dev, const lpsxxx_params_t * params)
#elif MODULE_LPS22HB
tmp = LPSXXX_CTRL_REG1_EN_LPFP | /* Low-pass filter configuration: ODR/9 */
LPSXXX_CTRL_REG1_BDU | (DEV_RATE << LPSXXX_CTRL_REG1_ODR_POS);
#elif MODULE_LPS22HH
tmp = LPSXXX_CTRL_REG1_EN_LPFP | /* Low-pass filter configuration: ODR/9 */
LPSXXX_CTRL_REG1_BDU | (DEV_RATE << LPSXXX_CTRL_REG1_ODR_POS);
#endif
DEBUG("[lpsxxx] init: update reg1, value: %02X\n", tmp);

View File

@ -12,7 +12,8 @@
* @{
*
* @file
* @brief LPSXXX (LPS331ap/LPS25HB/LPS22HB) adaption to SAUL interface
* @brief LPSXXX (LPS331ap/LPS25HB/LPS22HB/LPS22HH) adaption to SAUL
* interface
*
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
* @author Alexandre Abadie <alexandre.abadie@inria.fr>

View File

@ -314,6 +314,7 @@ PSEUDOMODULES += ws281x_%
# include variants of lpsxxx drivers as pseudo modules
PSEUDOMODULES += lps331ap
PSEUDOMODULES += lps22hb
PSEUDOMODULES += lps22hh
PSEUDOMODULES += lps25hb
# add all pseudo random number generator variants as pseudomodules

View File

@ -1,7 +1,7 @@
# About
This is a manual test application for the LPSXXX family of pressure sensors
driver. This driver can be used with LPS331AP, LPS25HB and LPS22HB.
driver. This driver can be used with LPS331AP, LPS25HB, LPS22HB and LPS22HH.
Default driver is `lps331ap`. To use the LPS25HB driver, set the `DRIVER` when
building the application:
@ -11,7 +11,7 @@ building the application:
# Usage
This test application will initialize the pressure sensor with a sampling rate
of 7Hz (25Hz with lps22hb).
of 7Hz (25Hz with lps22hb and lps22hh).
After initialization, the sensor reads the pressure and temperature values
every 250ms and prints them to the STDOUT.

View File

@ -12,7 +12,8 @@
* @{
*
* @file
* @brief Test application for the LPS331AP/LPS25HB/LPS22HB pressure sensor
* @brief Test application for the LPS331AP/LPS25HB/LPS22HB/LPS22HH
* pressure sensor
*
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
* @author Alexandre Abadie <alexandre.abadie@inria.fr>