English | 简体中文 | 繁體中文 | 日本語 | Deutsch | 한국어
BMP384具有凝膠填充腔體,如果使用適用的集成管道,可以提高對水、液體和其他化學物質的耐受性。 BMP384非常適合水位和堵塞檢測應用。 它可與其他Bosch Sensortec感測器(包括BMI088)相容,以獲得更好的效能、耐用性和穩定性。 BMP384體積小巧,具有出色的設計靈活性,可提供單一封裝解決方案,易於集成到其他現有和即將推出的智能家居、工業產品和可穿戴設備中。
LibDriver BMP384是LibDriver推出的BMP384全功能驅動,該驅動提供壓強溫度連續讀取、壓強溫度單次讀取、中斷讀取和FIFO採集等功能並且它符合MISRA標準。
/src目錄包含了LibDriver BMP384的源文件。
/interface目錄包含了LibDriver BMP384與平台無關的IIC、SPI總線模板。
/test目錄包含了LibDriver BMP384驅動測試程序,該程序可以簡單的測試芯片必要功能。
/example目錄包含了LibDriver BMP384編程範例。
/doc目錄包含了LibDriver BMP384離線文檔。
/datasheet目錄包含了BMP384數據手冊。
/project目錄包含了常用Linux與單片機開發板的工程樣例。所有工程均採用shell腳本作為調試方法,詳細內容可參考每個工程裡面的README.md。
/misra目錄包含了LibDriver MISRA程式碼掃描結果。
參考/interface目錄下與平台無關的IIC、SPI總線模板,完成指定平台的IIC、SPI總線驅動。
將/src目錄,您使用平臺的介面驅動和您開發的驅動加入工程,如果您想要使用默認的範例驅動,可以將/example目錄加入您的工程。
您可以參考/example目錄下的程式設計範例完成適合您的驅動,如果您想要使用默認的程式設計範例,以下是它們的使用方法。
#include "driver_bmp384_basic.h"
uint8_t res;
uint8_t i;
float temperature_c;
float pressure_pa;
res = bmp384_basic_init(BMP384_INTERFACE_IIC, BMP384_ADDRESS_ADO_LOW);
if (res != 0)
{
return 1;
}
...
for (i = 0; i < 3; i++)
{
bmp384_interface_delay_ms(1000);
res = bmp384_basic_read((float *)&temperature_c, (float *)&pressure_pa);
if (res != 0)
{
(void)bmp384_basic_deinit();
return 1;
}
bmp384_interface_debug_print("bmp384: temperature is %0.2fC.\n", temperature_c);
bmp384_interface_debug_print("bmp384: pressure is %0.2fPa.\n", pressure_pa);
...
}
...
(void)bmp384_basic_deinit();
return 0;
#include "driver_bmp384_shot.h"
uint8_t res;
uint8_t i;
float temperature_c;
float pressure_pa;
res = bmp384_shot_init(BMP384_INTERFACE_IIC, BMP384_ADDRESS_ADO_LOW);
if (res != 0)
{
return 1;
}
...
for (i = 0; i < 3; i++)
{
bmp384_interface_delay_ms(1000);
res = bmp384_shot_read((float *)&temperature_c, (float *)&pressure_pa);
if (res != 0)
{
(void)bmp384_shot_deinit();
return 1;
}
bmp384_interface_debug_print("bmp384: temperature is %0.2fC.\n", temperature_c);
bmp384_interface_debug_print("bmp384: pressure is %0.2fPa.\n", pressure_pa);
...
}
...
(void)bmp384_shot_deinit();
return 0;
#include "driver_bmp384_interrupt.h"
uint8_t res;
uint16_t i, timeout;
uint8_t gs_data_ready_flag;
float gs_temperature_c;
float gs_pressure_pa;
void bmp384_interrupt_receive_callback(uint8_t type)
{
switch (type)
{
case BMP384_INTERRUPT_STATUS_FIFO_WATERMARK :
{
break;
}
case BMP384_INTERRUPT_STATUS_FIFO_FULL :
{
break;
}
case BMP384_INTERRUPT_STATUS_DATA_READY :
{
/* read temperature pressure */
if (bmp384_interrupt_read((float *)&gs_temperature_c, (float *)&gs_pressure_pa) != 0)
{
bmp384_interface_debug_print("bmp384: read temperature and pressure failed.\n");
return;
}
gs_data_ready_flag = 1;
break;
}
default :
{
break;
}
}
}
res = gpio_interrupt_init();
if (res != 0)
{
return 1;
}
res = bmp384_interrupt_init(BMP384_INTERFACE_IIC, BMP384_ADDRESS_ADO_LOW, bmp384_interrupt_receive_callback);
if (res != 0)
{
(void)gpio_interrupt_deinit();
return 1;
}
...
gs_data_ready_flag = 0;
timeout = 5000;
for (i = 0; i < 3; i++)
{
while (timeout != 0)
{
bmp384_interface_delay_ms(100);
timeout--;
if (gs_data_ready_flag != 0)
{
break;
}
if (timeout == 0)
{
(void)gpio_interrupt_deinit();
(void)bmp384_interrupt_deinit();
return 1;
}
}
gs_data_ready_flag = 0;
timeout = 5000;
bmp384_interface_debug_print("bmp384: temperature is %0.2fC.\n", gs_temperature_c);
bmp384_interface_debug_print("bmp384: pressure is %0.2fPa.\n", gs_pressure_pa);
...
}
...
(void)gpio_interrupt_deinit();
(void)bmp384_interrupt_deinit();
return 0;
#include "driver_bmp384_fifo.h"
uint8_t gs_fifo_full_flag;
uint8_t gs_fifo_watermark_flag;
uint16_t i, timeout;
uint8_t gs_buf[512];
bmp384_frame_t gs_frame[256];
void bmp384_fifo_receive_callback(uint8_t type)
{
switch (type)
{
case BMP384_INTERRUPT_STATUS_FIFO_WATERMARK :
{
uint8_t res;
uint16_t len;
uint16_t i, frame_len;
len = 512;
frame_len = 256;
res = bmp384_fifo_read(gs_buf, len, (bmp384_frame_t *)gs_frame, (uint16_t *)&frame_len);
if (res != 0)
{
bmp384_interface_debug_print("bmp384: fifo read failed.\n");
return;
}
for (i = 0; i < frame_len; i++)
{
if (gs_frame[i].type == BMP384_FRAME_TYPE_TEMPERATURE)
{
bmp384_interface_debug_print("bmp384: fifo %d/%d.\n", i+1, frame_len);
bmp384_interface_debug_print("bmp384: temperature is %0.2fC.\n", gs_frame[i].data);
}
else if (gs_frame[i].type == BMP384_FRAME_TYPE_PRESSURE)
{
bmp384_interface_debug_print("bmp384: fifo %d/%d.\n", i+1, frame_len);
bmp384_interface_debug_print("bmp384: pressure is %0.2fPa.\n", gs_frame[i].data);
}
else if (gs_frame[i].type == BMP384_FRAME_TYPE_SENSORTIME)
{
bmp384_interface_debug_print("bmp384: fifo %d/%d.\n", i+1, frame_len);
bmp384_interface_debug_print("bmp384: sensortime is %d.\n", gs_frame[i].raw);
}
else
{
bmp384_interface_debug_print("bmp384: fifo %d/%d.\n", i+1, frame_len);
bmp384_interface_debug_print("bmp384: unknow type.\n");
}
}
gs_fifo_watermark_flag = 1;
break;
}
case BMP384_INTERRUPT_STATUS_FIFO_FULL :
{
uint8_t res;
uint16_t len;
uint16_t i, frame_len;
len = 512;
frame_len = 256;
res = bmp384_fifo_read(gs_buf, len, (bmp384_frame_t *)gs_frame, (uint16_t *)&frame_len);
if (res != 0)
{
bmp384_interface_debug_print("bmp384: fifo read failed.\n");
return;
}
for (i = 0; i < frame_len; i++)
{
if (gs_frame[i].type == BMP384_FRAME_TYPE_TEMPERATURE)
{
bmp384_interface_debug_print("bmp384: fifo %d/%d.\n", i+1, frame_len);
bmp384_interface_debug_print("bmp384: temperature is %0.2fC.\n", gs_frame[i].data);
}
else if (gs_frame[i].type == BMP384_FRAME_TYPE_PRESSURE)
{
bmp384_interface_debug_print("bmp384: fifo %d/%d.\n", i+1, frame_len);
bmp384_interface_debug_print("bmp384: pressure is %0.2fPa.\n", gs_frame[i].data);
}
else if (gs_frame[i].type == BMP384_FRAME_TYPE_SENSORTIME)
{
bmp384_interface_debug_print("bmp384: fifo %d/%d.\n", i+1, frame_len);
bmp384_interface_debug_print("bmp384: sensortime is %d.\n", gs_frame[i].raw);
}
else
{
bmp384_interface_debug_print("bmp384: fifo %d/%d.\n", i+1, frame_len);
bmp384_interface_debug_print("bmp384: unknow type.\n");
}
}
gs_fifo_full_flag = 1;
break;
}
case BMP384_INTERRUPT_STATUS_DATA_READY :
{
break;
}
default :
{
break;
}
}
}
res = gpio_interrupt_init();
if (res != 0)
{
return 1;
}
res = bmp384_fifo_init(BMP384_INTERFACE_IIC, BMP384_ADDRESS_ADO_LOW, bmp384_fifo_receive_callback);
if (res != 0)
{
(void)gpio_interrupt_deinit();
return 1;
}
...
gs_fifo_watermark_flag = 0;
gs_fifo_full_flag = 0;
timeout = 5000;
for (i = 0; i < 3; i++)
{
while (timeout != 0)
{
bmp384_interface_delay_ms(100);
timeout--;
if ((gs_fifo_watermark_flag != 0) || (gs_fifo_full_flag != 0))
{
break;
}
if (timeout == 0)
{
(void)gpio_interrupt_deinit();
(void)bmp384_fifo_deinit();
return 1;
}
}
gs_fifo_watermark_flag = 0;
gs_fifo_full_flag = 0;
timeout = 5000;
...
}
(void)gpio_interrupt_deinit();
(void)bmp384_fifo_deinit();
...
return 0;
在線文檔: https://www.libdriver.com/docs/bmp384/index.html。
離線文檔: /doc/html/index.html。
請參攷CONTRIBUTING.md。
版權 (c) 2015 - 現在 LibDriver 版權所有
MIT 許可證(MIT)
特此免費授予任何獲得本軟件副本和相關文檔文件(下稱“軟件”)的人不受限制地處置該軟件的權利,包括不受限制地使用、複製、修改、合併、發布、分發、轉授許可和/或出售該軟件副本,以及再授權被配發了本軟件的人如上的權利,須在下列條件下:
上述版權聲明和本許可聲明應包含在該軟件的所有副本或實質成分中。
本軟件是“如此”提供的,沒有任何形式的明示或暗示的保證,包括但不限於對適銷性、特定用途的適用性和不侵權的保證。在任何情況下,作者或版權持有人都不對任何索賠、損害或其他責任負責,無論這些追責來自合同、侵權或其它行為中,還是產生於、源於或有關於本軟件以及本軟件的使用或其它處置。