mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
90fb789697
Add the vendor driver implementation from Bosch Sensortech as a package.
117 lines
2.9 KiB
C
117 lines
2.9 KiB
C
/*
|
|
* Copyright (C) 2019 Mesotic SAS
|
|
* 2020 Gunar Schorcht
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
* directory for more details.
|
|
*/
|
|
|
|
/**
|
|
* @ingroup pkg_driver_bme680
|
|
* @ingroup drivers_bme680
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Abstraction layer for RIOT adaption
|
|
*
|
|
* @author Dylan Laduranty <dylan.laduranty@mesotic.com>
|
|
* @author Gunar Schorcht <gunar@schorcht.net>
|
|
*/
|
|
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
|
|
#include "bme680.h"
|
|
#include "bme680_hal.h"
|
|
|
|
#ifdef MODULE_PERIPH_I2C
|
|
#include "periph/i2c.h"
|
|
#endif
|
|
#ifdef MODULE_PERIPH_SPI
|
|
#include "periph/spi.h"
|
|
#endif
|
|
|
|
#include "xtimer.h"
|
|
|
|
#ifndef BME680_SPI_SPEED
|
|
#define BME680_SPI_SPEED (SPI_CLK_1MHZ)
|
|
#endif /* BME680_SPI_SPEED */
|
|
|
|
#ifndef BME680_SPI_MODE
|
|
#define BME680_SPI_MODE (SPI_MODE_0)
|
|
#endif /* BME680_SPI_MODE */
|
|
|
|
void bme680_ms_sleep(uint32_t msleep)
|
|
{
|
|
xtimer_usleep(msleep * US_PER_MS);
|
|
}
|
|
|
|
#ifdef MODULE_PERIPH_I2C
|
|
int8_t bme680_i2c_read_hal(uint8_t dev_id, uint8_t reg_addr,
|
|
uint8_t *data, uint16_t len)
|
|
{
|
|
assert(dev_id < bme680_devs_numof);
|
|
|
|
bme680_intf_i2c_t* intf = &(bme680_devs[dev_id]->intf.i2c);
|
|
uint8_t ret;
|
|
|
|
i2c_acquire(intf->dev);
|
|
ret = i2c_read_regs(intf->dev, intf->addr, reg_addr, data, len, 0);
|
|
i2c_release(intf->dev);
|
|
return ret;
|
|
}
|
|
|
|
int8_t bme680_i2c_write_hal(uint8_t dev_id, uint8_t reg_addr,
|
|
uint8_t *data, uint16_t len)
|
|
{
|
|
assert(dev_id < bme680_devs_numof);
|
|
|
|
bme680_intf_i2c_t* intf = &(bme680_devs[dev_id]->intf.i2c);
|
|
uint8_t ret;
|
|
|
|
i2c_acquire(intf->dev);
|
|
ret = i2c_write_regs(intf->dev, intf->addr, reg_addr, data, len, 0);
|
|
i2c_release(intf->dev);
|
|
return ret;
|
|
}
|
|
#endif /* MODULE_PERIPH_I2C */
|
|
|
|
#ifdef MODULE_PERIPH_SPI
|
|
int8_t bme680_spi_read_hal(uint8_t dev_id, uint8_t reg_addr,
|
|
uint8_t *data, uint16_t len)
|
|
{
|
|
assert(dev_id < bme680_devs_numof);
|
|
|
|
bme680_intf_spi_t* intf = &(bme680_devs[dev_id]->intf.spi);
|
|
unsigned int cpsr = irq_disable();
|
|
|
|
gpio_clear(intf->nss_pin);
|
|
spi_acquire(intf->dev, SPI_CS_UNDEF, BME680_SPI_MODE, BME680_SPI_SPEED);
|
|
spi_transfer_regs(intf->dev, SPI_CS_UNDEF, reg_addr, NULL, data, len);
|
|
gpio_set(intf->nss_pin);
|
|
|
|
irq_restore(cpsr);
|
|
spi_release(intf->dev);
|
|
return 0;
|
|
}
|
|
|
|
int8_t bme680_spi_write_hal(uint8_t dev_id, uint8_t reg_addr,
|
|
uint8_t *data, uint16_t len)
|
|
{
|
|
assert(dev_id < bme680_devs_numof);
|
|
|
|
bme680_intf_spi_t* intf = &(bme680_devs[dev_id]->intf.spi);
|
|
unsigned int cpsr = irq_disable();
|
|
|
|
gpio_clear(intf->nss_pin);
|
|
spi_acquire(intf->dev, SPI_CS_UNDEF, BME680_SPI_MODE, BME680_SPI_SPEED);
|
|
spi_transfer_regs(intf->dev, SPI_CS_UNDEF, reg_addr, data, NULL, len);
|
|
gpio_set(intf->nss_pin);
|
|
|
|
irq_restore(cpsr);
|
|
spi_release(intf->dev);
|
|
return 0;
|
|
}
|
|
#endif /* MODULE_PERIPH_SPI */
|