mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
Merge pull request #17275 from gschorcht/drivers/periph_i2c_acquire_void
drivers/periph_i2c: let i2c_acquire return void
This commit is contained in:
commit
c84a40abc4
@ -22,11 +22,12 @@
|
|||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <assert.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
|
||||||
#include "cpu.h"
|
#include "cpu.h"
|
||||||
#include "mutex.h"
|
#include "mutex.h"
|
||||||
#include "assert.h"
|
|
||||||
#include "periph/i2c.h"
|
#include "periph/i2c.h"
|
||||||
#include "periph_conf.h"
|
#include "periph_conf.h"
|
||||||
|
|
||||||
@ -219,12 +220,11 @@ int i2c_write_bytes(i2c_t dev, uint16_t addr, const void *data, size_t len,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int i2c_acquire(i2c_t dev)
|
void i2c_acquire(i2c_t dev)
|
||||||
{
|
{
|
||||||
assert(dev < I2C_NUMOF);
|
assert(dev < I2C_NUMOF);
|
||||||
|
|
||||||
mutex_lock(&locks[dev]);
|
mutex_lock(&locks[dev]);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void i2c_release(i2c_t dev)
|
void i2c_release(i2c_t dev)
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
*
|
*
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
#include <assert.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
|
||||||
#include "cpu.h"
|
#include "cpu.h"
|
||||||
@ -74,10 +75,7 @@ void i2c_init(i2c_t i2c)
|
|||||||
{
|
{
|
||||||
uint8_t baudrate;
|
uint8_t baudrate;
|
||||||
|
|
||||||
if (i2c >= I2C_NUMOF) {
|
assert((unsigned)i2c < I2C_NUMOF);
|
||||||
DEBUG("[i2c] init: dev is invalid.\n");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
baudrate = _i2c_calc_baud(i2c);
|
baudrate = _i2c_calc_baud(i2c);
|
||||||
if (baudrate == 0) {
|
if (baudrate == 0) {
|
||||||
@ -97,12 +95,14 @@ void i2c_init(i2c_t i2c)
|
|||||||
|
|
||||||
void i2c_init_pins(i2c_t i2c)
|
void i2c_init_pins(i2c_t i2c)
|
||||||
{
|
{
|
||||||
|
assert((unsigned)i2c < I2C_NUMOF);
|
||||||
gpio_init(i2c_config[i2c].sda_pin, GPIO_OPC_WRD_AND_PULL);
|
gpio_init(i2c_config[i2c].sda_pin, GPIO_OPC_WRD_AND_PULL);
|
||||||
gpio_init(i2c_config[i2c].scl_pin, GPIO_OPC_WRD_AND_PULL);
|
gpio_init(i2c_config[i2c].scl_pin, GPIO_OPC_WRD_AND_PULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
int i2c_acquire(i2c_t i2c)
|
void i2c_acquire(i2c_t i2c)
|
||||||
{
|
{
|
||||||
|
assert((unsigned)i2c < I2C_NUMOF);
|
||||||
DEBUG("acquire\n");
|
DEBUG("acquire\n");
|
||||||
pm_block(3);
|
pm_block(3);
|
||||||
mutex_lock(&i2c_ctx[i2c].locks);
|
mutex_lock(&i2c_ctx[i2c].locks);
|
||||||
@ -113,12 +113,11 @@ int i2c_acquire(i2c_t i2c)
|
|||||||
| TWI_MASTER_WIEN_bm
|
| TWI_MASTER_WIEN_bm
|
||||||
| TWI_MASTER_ENABLE_bm;
|
| TWI_MASTER_ENABLE_bm;
|
||||||
dev(i2c)->MASTER.STATUS = TWI_MASTER_BUSSTATE_IDLE_gc;
|
dev(i2c)->MASTER.STATUS = TWI_MASTER_BUSSTATE_IDLE_gc;
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void i2c_release(i2c_t i2c)
|
void i2c_release(i2c_t i2c)
|
||||||
{
|
{
|
||||||
|
assert((unsigned)i2c < I2C_NUMOF);
|
||||||
dev(i2c)->MASTER.CTRLA = 0;
|
dev(i2c)->MASTER.CTRLA = 0;
|
||||||
pm_periph_disable(i2c_config[i2c].pwr);
|
pm_periph_disable(i2c_config[i2c].pwr);
|
||||||
mutex_unlock(&i2c_ctx[i2c].locks);
|
mutex_unlock(&i2c_ctx[i2c].locks);
|
||||||
@ -129,6 +128,8 @@ void i2c_release(i2c_t i2c)
|
|||||||
static int _i2c_transaction(i2c_t i2c, uint16_t addr, const void *data,
|
static int _i2c_transaction(i2c_t i2c, uint16_t addr, const void *data,
|
||||||
size_t len, uint8_t flags, bool is_read)
|
size_t len, uint8_t flags, bool is_read)
|
||||||
{
|
{
|
||||||
|
assert((unsigned)i2c < I2C_NUMOF);
|
||||||
|
|
||||||
if (flags & I2C_ADDR10) {
|
if (flags & I2C_ADDR10) {
|
||||||
DEBUG("[i2c] xfer: no 10 bit address support.\n");
|
DEBUG("[i2c] xfer: no 10 bit address support.\n");
|
||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
@ -238,6 +239,8 @@ static inline void _i2c_read_handler(int i2c)
|
|||||||
*/
|
*/
|
||||||
static inline void isr_handler(int i2c)
|
static inline void isr_handler(int i2c)
|
||||||
{
|
{
|
||||||
|
assert((unsigned)i2c < I2C_NUMOF);
|
||||||
|
|
||||||
avr8_enter_isr();
|
avr8_enter_isr();
|
||||||
|
|
||||||
int8_t const m_status = dev(i2c)->MASTER.STATUS;
|
int8_t const m_status = dev(i2c)->MASTER.STATUS;
|
||||||
|
@ -231,14 +231,12 @@ void i2c_init(i2c_t dev)
|
|||||||
DEBUG(" - I2C master status (0x%x).\n", _i2c_master_stat_get());
|
DEBUG(" - I2C master status (0x%x).\n", _i2c_master_stat_get());
|
||||||
}
|
}
|
||||||
|
|
||||||
int i2c_acquire(i2c_t dev)
|
void i2c_acquire(i2c_t dev)
|
||||||
{
|
{
|
||||||
|
(void)dev;
|
||||||
|
assert(dev < I2C_NUMOF);
|
||||||
DEBUG("%s\n", __FUNCTION__);
|
DEBUG("%s\n", __FUNCTION__);
|
||||||
if (dev < I2C_NUMOF) {
|
mutex_lock(&lock);
|
||||||
mutex_lock(&lock);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void i2c_release(i2c_t dev)
|
void i2c_release(i2c_t dev)
|
||||||
|
@ -126,12 +126,11 @@ void i2c_init(i2c_t devnum)
|
|||||||
I2C->MTPR = MTPR_TPR_100KHZ;
|
I2C->MTPR = MTPR_TPR_100KHZ;
|
||||||
}
|
}
|
||||||
|
|
||||||
int i2c_acquire(i2c_t dev)
|
void i2c_acquire(i2c_t dev)
|
||||||
{
|
{
|
||||||
(void)dev;
|
(void)dev;
|
||||||
assert(dev < I2C_NUMOF);
|
assert(dev < I2C_NUMOF);
|
||||||
mutex_lock(&_lock);
|
mutex_lock(&_lock);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void i2c_release(i2c_t dev)
|
void i2c_release(i2c_t dev)
|
||||||
|
@ -142,15 +142,15 @@ void i2c_init(i2c_t dev)
|
|||||||
I2C_Enable(i2c_config[dev].dev, true);
|
I2C_Enable(i2c_config[dev].dev, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
int i2c_acquire(i2c_t dev)
|
void i2c_acquire(i2c_t dev)
|
||||||
{
|
{
|
||||||
|
assert(dev < I2C_NUMOF);
|
||||||
|
|
||||||
/* acquire lock */
|
/* acquire lock */
|
||||||
mutex_lock(&i2c_lock[dev]);
|
mutex_lock(&i2c_lock[dev]);
|
||||||
|
|
||||||
/* power peripheral */
|
/* power peripheral */
|
||||||
CMU_ClockEnable(i2c_config[dev].cmu, true);
|
CMU_ClockEnable(i2c_config[dev].cmu, true);
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void i2c_release(i2c_t dev)
|
void i2c_release(i2c_t dev)
|
||||||
|
@ -145,7 +145,7 @@ static inline void _i2c_delay (uint32_t delay);
|
|||||||
|
|
||||||
void i2c_init(i2c_t dev)
|
void i2c_init(i2c_t dev)
|
||||||
{
|
{
|
||||||
CHECK_PARAM (dev < I2C_NUMOF)
|
assert(dev < I2C_NUMOF);
|
||||||
|
|
||||||
if (i2c_config[dev].speed == I2C_SPEED_FAST_PLUS ||
|
if (i2c_config[dev].speed == I2C_SPEED_FAST_PLUS ||
|
||||||
i2c_config[dev].speed == I2C_SPEED_HIGH) {
|
i2c_config[dev].speed == I2C_SPEED_HIGH) {
|
||||||
@ -156,7 +156,7 @@ void i2c_init(i2c_t dev)
|
|||||||
|
|
||||||
mutex_init(&_i2c_bus[dev].lock);
|
mutex_init(&_i2c_bus[dev].lock);
|
||||||
|
|
||||||
i2c_acquire (dev);
|
i2c_acquire(dev);
|
||||||
|
|
||||||
_i2c_bus[dev].cmd = 0;
|
_i2c_bus[dev].cmd = 0;
|
||||||
_i2c_bus[dev].data = 0;
|
_i2c_bus[dev].data = 0;
|
||||||
@ -262,20 +262,17 @@ void i2c_init(i2c_t dev)
|
|||||||
xt_set_interrupt_handler(CPU_INUM_I2C, _i2c_intr_handler, NULL);
|
xt_set_interrupt_handler(CPU_INUM_I2C, _i2c_intr_handler, NULL);
|
||||||
xt_ints_on(BIT(CPU_INUM_I2C));
|
xt_ints_on(BIT(CPU_INUM_I2C));
|
||||||
|
|
||||||
i2c_release (dev);
|
i2c_release(dev);
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int i2c_acquire(i2c_t dev)
|
void i2c_acquire(i2c_t dev)
|
||||||
{
|
{
|
||||||
DEBUG ("%s\n", __func__);
|
DEBUG ("%s\n", __func__);
|
||||||
|
|
||||||
CHECK_PARAM_RET (dev < I2C_NUMOF, -1)
|
assert(dev < I2C_NUMOF);
|
||||||
|
|
||||||
mutex_lock(&_i2c_bus[dev].lock);
|
mutex_lock(&_i2c_bus[dev].lock);
|
||||||
_i2c_reset_hw(dev);
|
_i2c_reset_hw(dev);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void i2c_release(i2c_t dev)
|
void i2c_release(i2c_t dev)
|
||||||
@ -358,9 +355,9 @@ int i2c_read_bytes(i2c_t dev, uint16_t addr, void *data, size_t len, uint8_t fla
|
|||||||
DEBUG ("%s dev=%u addr=%02x data=%p len=%d flags=%01x\n",
|
DEBUG ("%s dev=%u addr=%02x data=%p len=%d flags=%01x\n",
|
||||||
__func__, dev, addr, data, len, flags);
|
__func__, dev, addr, data, len, flags);
|
||||||
|
|
||||||
CHECK_PARAM_RET (dev < I2C_NUMOF, -EINVAL);
|
assert(dev < I2C_NUMOF);
|
||||||
CHECK_PARAM_RET (len > 0, -EINVAL);
|
assert(len > 0);
|
||||||
CHECK_PARAM_RET (data != NULL, -EINVAL);
|
assert(data != NULL);
|
||||||
|
|
||||||
/* if I2C_NOSTART is not set, START condition and ADDR is used */
|
/* if I2C_NOSTART is not set, START condition and ADDR is used */
|
||||||
if (!(flags & I2C_NOSTART)) {
|
if (!(flags & I2C_NOSTART)) {
|
||||||
@ -445,9 +442,9 @@ int i2c_write_bytes(i2c_t dev, uint16_t addr, const void *data, size_t len, uint
|
|||||||
DEBUG ("%s dev=%u addr=%02x data=%p len=%d flags=%01x\n",
|
DEBUG ("%s dev=%u addr=%02x data=%p len=%d flags=%01x\n",
|
||||||
__func__, dev, addr, data, len, flags);
|
__func__, dev, addr, data, len, flags);
|
||||||
|
|
||||||
CHECK_PARAM_RET (dev < I2C_NUMOF, -EINVAL);
|
assert(dev < I2C_NUMOF);
|
||||||
CHECK_PARAM_RET (len > 0, -EINVAL);
|
assert(len > 0);
|
||||||
CHECK_PARAM_RET (data != NULL, -EINVAL);
|
assert(data != NULL);
|
||||||
|
|
||||||
/* if I2C_NOSTART is not set, START condition and ADDR is used */
|
/* if I2C_NOSTART is not set, START condition and ADDR is used */
|
||||||
if (!(flags & I2C_NOSTART)) {
|
if (!(flags & I2C_NOSTART)) {
|
||||||
|
@ -246,12 +246,11 @@ void i2c_init(i2c_t dev)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
int i2c_acquire(i2c_t dev)
|
void i2c_acquire(i2c_t dev)
|
||||||
{
|
{
|
||||||
assert(dev < I2C_NUMOF);
|
assert(dev < I2C_NUMOF);
|
||||||
|
|
||||||
mutex_lock(&_i2c_bus[dev].lock);
|
mutex_lock(&_i2c_bus[dev].lock);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void i2c_release(i2c_t dev)
|
void i2c_release(i2c_t dev)
|
||||||
|
@ -90,11 +90,10 @@ void i2c_init(i2c_t dev)
|
|||||||
DEBUG("[i2c] initialization done\n");
|
DEBUG("[i2c] initialization done\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
int i2c_acquire(i2c_t dev)
|
void i2c_acquire(i2c_t dev)
|
||||||
{
|
{
|
||||||
assert(dev < I2C_NUMOF);
|
assert(dev < I2C_NUMOF);
|
||||||
mutex_lock(&locks[dev]);
|
mutex_lock(&locks[dev]);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void i2c_release(i2c_t dev)
|
void i2c_release(i2c_t dev)
|
||||||
|
@ -106,12 +106,11 @@ typedef struct {
|
|||||||
|
|
||||||
static i2c_state_t i2c_state[I2C_NUMOF];
|
static i2c_state_t i2c_state[I2C_NUMOF];
|
||||||
|
|
||||||
int i2c_acquire(i2c_t dev)
|
void i2c_acquire(i2c_t dev)
|
||||||
{
|
{
|
||||||
assert((unsigned)dev < I2C_NUMOF);
|
assert((unsigned)dev < I2C_NUMOF);
|
||||||
mutex_lock(&i2c_state[dev].mtx);
|
mutex_lock(&i2c_state[dev].mtx);
|
||||||
i2c_state[dev].pid = thread_getpid();
|
i2c_state[dev].pid = thread_getpid();
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void i2c_release(i2c_t dev)
|
void i2c_release(i2c_t dev)
|
||||||
|
@ -103,14 +103,12 @@ static void poweroff(lpc23xx_i2c_t *i2c)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int i2c_acquire(i2c_t dev)
|
void i2c_acquire(i2c_t dev)
|
||||||
{
|
{
|
||||||
assert(dev < I2C_NUMOF);
|
assert(dev < I2C_NUMOF);
|
||||||
|
|
||||||
mutex_lock(&ctx[dev].lock);
|
mutex_lock(&ctx[dev].lock);
|
||||||
poweron(i2c_config[dev].dev);
|
poweron(i2c_config[dev].dev);
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void i2c_release(i2c_t dev)
|
void i2c_release(i2c_t dev)
|
||||||
@ -332,6 +330,8 @@ static void irq_handler(i2c_t dev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* clear interrupt flag */
|
/* clear interrupt flag */
|
||||||
|
/* cppcheck-suppress redundantAssignment
|
||||||
|
* (reason: writing 1 to volatile register to clear the interrupt) */
|
||||||
i2c->CONCLR = I2CONCLR_SIC;
|
i2c->CONCLR = I2CONCLR_SIC;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -132,12 +132,11 @@ void i2c_init(i2c_t dev)
|
|||||||
i2c(dev)->ENABLE = TWI_ENABLE_ENABLE_Enabled;
|
i2c(dev)->ENABLE = TWI_ENABLE_ENABLE_Enabled;
|
||||||
}
|
}
|
||||||
|
|
||||||
int i2c_acquire(i2c_t dev)
|
void i2c_acquire(i2c_t dev)
|
||||||
{
|
{
|
||||||
assert(dev < I2C_NUMOF);
|
assert(dev < I2C_NUMOF);
|
||||||
|
|
||||||
mutex_lock(&locks[dev]);
|
mutex_lock(&locks[dev]);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void i2c_release(i2c_t dev)
|
void i2c_release(i2c_t dev)
|
||||||
|
@ -154,7 +154,7 @@ void i2c_deinit_pins(i2c_t dev)
|
|||||||
}
|
}
|
||||||
#endif /* MODULE_PERIPH_I2C_RECONFIGURE */
|
#endif /* MODULE_PERIPH_I2C_RECONFIGURE */
|
||||||
|
|
||||||
int i2c_acquire(i2c_t dev)
|
void i2c_acquire(i2c_t dev)
|
||||||
{
|
{
|
||||||
assert(dev < I2C_NUMOF);
|
assert(dev < I2C_NUMOF);
|
||||||
|
|
||||||
@ -162,7 +162,6 @@ int i2c_acquire(i2c_t dev)
|
|||||||
bus(dev)->ENABLE = TWIM_ENABLE_ENABLE_Enabled;
|
bus(dev)->ENABLE = TWIM_ENABLE_ENABLE_Enabled;
|
||||||
|
|
||||||
DEBUG("[i2c] acquired dev %i\n", (int)dev);
|
DEBUG("[i2c] acquired dev %i\n", (int)dev);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void i2c_release(i2c_t dev)
|
void i2c_release(i2c_t dev)
|
||||||
|
@ -153,11 +153,10 @@ void i2c_deinit_pins(i2c_t dev)
|
|||||||
}
|
}
|
||||||
#endif /* MODULE_PERIPH_I2C_RECONFIGURE */
|
#endif /* MODULE_PERIPH_I2C_RECONFIGURE */
|
||||||
|
|
||||||
int i2c_acquire(i2c_t dev)
|
void i2c_acquire(i2c_t dev)
|
||||||
{
|
{
|
||||||
assert(dev < I2C_NUMOF);
|
assert(dev < I2C_NUMOF);
|
||||||
mutex_lock(&locks[dev]);
|
mutex_lock(&locks[dev]);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void i2c_release(i2c_t dev)
|
void i2c_release(i2c_t dev)
|
||||||
|
@ -194,11 +194,10 @@ void i2c_init(i2c_t dev)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int i2c_acquire(i2c_t dev)
|
void i2c_acquire(i2c_t dev)
|
||||||
{
|
{
|
||||||
assert(dev < I2C_NUMOF);
|
assert(dev < I2C_NUMOF);
|
||||||
mutex_lock(&locks[dev]);
|
mutex_lock(&locks[dev]);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void i2c_release(i2c_t dev)
|
void i2c_release(i2c_t dev)
|
||||||
|
@ -135,7 +135,7 @@ static void _i2c_init(I2C_TypeDef *i2c, uint32_t timing)
|
|||||||
i2c->CR1 |= I2C_CR1_PE;
|
i2c->CR1 |= I2C_CR1_PE;
|
||||||
}
|
}
|
||||||
|
|
||||||
int i2c_acquire(i2c_t dev)
|
void i2c_acquire(i2c_t dev)
|
||||||
{
|
{
|
||||||
assert(dev < I2C_NUMOF);
|
assert(dev < I2C_NUMOF);
|
||||||
|
|
||||||
@ -145,8 +145,6 @@ int i2c_acquire(i2c_t dev)
|
|||||||
|
|
||||||
/* enable device */
|
/* enable device */
|
||||||
i2c_config[dev].dev->CR1 |= I2C_CR1_PE;
|
i2c_config[dev].dev->CR1 |= I2C_CR1_PE;
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void i2c_release(i2c_t dev)
|
void i2c_release(i2c_t dev)
|
||||||
|
@ -180,7 +180,7 @@ static void _init(i2c_t dev)
|
|||||||
_i2c_init(i2c, i2c_config[dev].clk, ccr);
|
_i2c_init(i2c, i2c_config[dev].clk, ccr);
|
||||||
}
|
}
|
||||||
|
|
||||||
int i2c_acquire(i2c_t dev)
|
void i2c_acquire(i2c_t dev)
|
||||||
{
|
{
|
||||||
assert(dev < I2C_NUMOF);
|
assert(dev < I2C_NUMOF);
|
||||||
|
|
||||||
@ -195,8 +195,6 @@ int i2c_acquire(i2c_t dev)
|
|||||||
|
|
||||||
/* enable device */
|
/* enable device */
|
||||||
i2c_config[dev].dev->CR1 |= I2C_CR1_PE;
|
i2c_config[dev].dev->CR1 |= I2C_CR1_PE;
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void i2c_release(i2c_t dev)
|
void i2c_release(i2c_t dev)
|
||||||
|
@ -398,9 +398,7 @@ static int _device_write(aip31068_t* dev, uint8_t *data, uint8_t len)
|
|||||||
{
|
{
|
||||||
i2c_t i2c_dev = dev->params.i2c_dev;
|
i2c_t i2c_dev = dev->params.i2c_dev;
|
||||||
|
|
||||||
if (i2c_acquire(i2c_dev) != 0) {
|
i2c_acquire(i2c_dev);
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
int rc = i2c_write_bytes(i2c_dev, dev->params.i2c_addr, data, len, 0);
|
int rc = i2c_write_bytes(i2c_dev, dev->params.i2c_addr, data, len, 0);
|
||||||
|
|
||||||
|
@ -466,10 +466,7 @@ static int _reg_read(const apds99xx_t *dev, uint8_t reg, uint8_t *data, uint16_t
|
|||||||
assert(data != NULL);
|
assert(data != NULL);
|
||||||
assert(len != 0);
|
assert(len != 0);
|
||||||
|
|
||||||
if (i2c_acquire(dev->params.dev)) {
|
i2c_acquire(dev->params.dev);
|
||||||
DEBUG_DEV("could not acquire I2C bus", dev);
|
|
||||||
return -APDS99XX_ERROR_I2C;
|
|
||||||
}
|
|
||||||
int res = i2c_read_regs(dev->params.dev, APDS99XX_I2C_ADDRESS, reg, data, len, 0);
|
int res = i2c_read_regs(dev->params.dev, APDS99XX_I2C_ADDRESS, reg, data, len, 0);
|
||||||
i2c_release(dev->params.dev);
|
i2c_release(dev->params.dev);
|
||||||
|
|
||||||
@ -499,16 +496,15 @@ static int _reg_write(const apds99xx_t *dev, uint8_t reg, uint8_t *data, uint16_
|
|||||||
if (IS_ACTIVE(ENABLE_DEBUG)) {
|
if (IS_ACTIVE(ENABLE_DEBUG)) {
|
||||||
printf("[apds99xx] %s i2c dev=%d addr=%02x: write to reg 0x%02x: ",
|
printf("[apds99xx] %s i2c dev=%d addr=%02x: write to reg 0x%02x: ",
|
||||||
__func__, dev->params.dev, APDS99XX_I2C_ADDRESS, reg);
|
__func__, dev->params.dev, APDS99XX_I2C_ADDRESS, reg);
|
||||||
for (uint16_t i = 0; i < len; i++) {
|
if (data && len) {
|
||||||
printf("%02x ", data[i]);
|
for (uint16_t i = 0; i < len; i++) {
|
||||||
|
printf("%02x ", data[i]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
printf("\n");
|
printf("\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (i2c_acquire(dev->params.dev)) {
|
i2c_acquire(dev->params.dev);
|
||||||
DEBUG_DEV("could not acquire I2C bus", dev);
|
|
||||||
return -APDS99XX_ERROR_I2C;
|
|
||||||
}
|
|
||||||
|
|
||||||
int res;
|
int res;
|
||||||
|
|
||||||
|
@ -195,9 +195,7 @@ int at24cxxx_init(at24cxxx_t *dev, const at24cxxx_params_t *params)
|
|||||||
at24cxxx_disable_write_protect(dev);
|
at24cxxx_disable_write_protect(dev);
|
||||||
}
|
}
|
||||||
/* Check I2C bus once */
|
/* Check I2C bus once */
|
||||||
if (i2c_acquire(DEV_I2C_BUS)) {
|
i2c_acquire(DEV_I2C_BUS);
|
||||||
return -AT24CXXX_I2C_ERROR;
|
|
||||||
}
|
|
||||||
i2c_release(DEV_I2C_BUS);
|
i2c_release(DEV_I2C_BUS);
|
||||||
return AT24CXXX_OK;
|
return AT24CXXX_OK;
|
||||||
}
|
}
|
||||||
|
@ -54,10 +54,7 @@ static int _read_reg(at24mac_t dev, uint8_t reg, void *dst, size_t size)
|
|||||||
return -ENOTSUP;
|
return -ENOTSUP;
|
||||||
}
|
}
|
||||||
|
|
||||||
res = i2c_acquire(params->i2c_dev);
|
i2c_acquire(params->i2c_dev);
|
||||||
if (res) {
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
|
|
||||||
res = i2c_read_regs(params->i2c_dev, params->i2c_addr,
|
res = i2c_read_regs(params->i2c_dev, params->i2c_addr,
|
||||||
reg, dst, size, 0);
|
reg, dst, size, 0);
|
||||||
|
@ -46,15 +46,14 @@ int bh1900nux_read(const bh1900nux_t *dev, int16_t *temp)
|
|||||||
|
|
||||||
/* Read raw sensor value */
|
/* Read raw sensor value */
|
||||||
DEBUG("[bh1900nux] read temperature\n");
|
DEBUG("[bh1900nux] read temperature\n");
|
||||||
ret = i2c_acquire(dev->i2c);
|
|
||||||
if (ret < 0) {
|
i2c_acquire(dev->i2c);
|
||||||
return BH1900NUX_ERR_I2C;
|
|
||||||
}
|
|
||||||
ret = i2c_read_regs(dev->i2c, dev->addr, BH1900NUX_REG_ADDR, &raw, sizeof(raw), 0);
|
ret = i2c_read_regs(dev->i2c, dev->addr, BH1900NUX_REG_ADDR, &raw, sizeof(raw), 0);
|
||||||
|
i2c_release(dev->i2c);
|
||||||
|
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
i2c_release(dev->i2c);
|
|
||||||
|
|
||||||
/* Calculate temperature */
|
/* Calculate temperature */
|
||||||
raw = (int16_t) ntohs(raw) >> 4;
|
raw = (int16_t) ntohs(raw) >> 4;
|
||||||
|
@ -81,9 +81,7 @@ static int _read_burst(const bmx280_t *dev, uint8_t reg, void *buf, size_t len)
|
|||||||
|
|
||||||
static inline int _acquire(const bmx280_t *dev)
|
static inline int _acquire(const bmx280_t *dev)
|
||||||
{
|
{
|
||||||
if (i2c_acquire(BUS) != 0) {
|
i2c_acquire(BUS);
|
||||||
return BMX280_ERR_BUS;
|
|
||||||
}
|
|
||||||
return BMX280_OK;
|
return BMX280_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -482,12 +482,9 @@ static int _reg_read(const ccs811_t *dev, uint8_t reg, uint8_t *data, uint32_t l
|
|||||||
DEBUG_DEV("read %"PRIu32" bytes from sensor registers starting at addr %02x",
|
DEBUG_DEV("read %"PRIu32" bytes from sensor registers starting at addr %02x",
|
||||||
dev, len, reg);
|
dev, len, reg);
|
||||||
|
|
||||||
int res = CCS811_OK;
|
int res;
|
||||||
|
|
||||||
if (i2c_acquire(dev->params.i2c_dev) != CCS811_OK) {
|
i2c_acquire(dev->params.i2c_dev);
|
||||||
DEBUG_DEV("could not acquire I2C bus", dev);
|
|
||||||
return -CCS811_ERROR_I2C;
|
|
||||||
}
|
|
||||||
|
|
||||||
#if MODULE_CCS811_FULL
|
#if MODULE_CCS811_FULL
|
||||||
if (gpio_is_valid(dev->params.wake_pin)) {
|
if (gpio_is_valid(dev->params.wake_pin)) {
|
||||||
@ -545,10 +542,7 @@ static int _reg_write(const ccs811_t *dev, uint8_t reg, uint8_t *data, uint32_t
|
|||||||
printf("\n");
|
printf("\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (i2c_acquire(dev->params.i2c_dev)) {
|
i2c_acquire(dev->params.i2c_dev);
|
||||||
DEBUG_DEV("could not acquire I2C bus", dev);
|
|
||||||
return -CCS811_ERROR_I2C;
|
|
||||||
}
|
|
||||||
|
|
||||||
#if MODULE_CCS811_FULL
|
#if MODULE_CCS811_FULL
|
||||||
if (gpio_is_valid(dev->params.wake_pin)) {
|
if (gpio_is_valid(dev->params.wake_pin)) {
|
||||||
|
@ -96,8 +96,8 @@ static int _read(const ds3231_t *dev, uint8_t reg, uint8_t *buf, size_t len,
|
|||||||
{
|
{
|
||||||
int res;
|
int res;
|
||||||
|
|
||||||
if (acquire && i2c_acquire(dev->bus)) {
|
if (acquire) {
|
||||||
return -EIO;
|
i2c_acquire(dev->bus);
|
||||||
}
|
}
|
||||||
res = i2c_read_regs(dev->bus, DS3231_I2C_ADDR, reg, buf, len, 0);
|
res = i2c_read_regs(dev->bus, DS3231_I2C_ADDR, reg, buf, len, 0);
|
||||||
if (res < 0) {
|
if (res < 0) {
|
||||||
@ -113,8 +113,8 @@ static int _read(const ds3231_t *dev, uint8_t reg, uint8_t *buf, size_t len,
|
|||||||
static int _write(const ds3231_t *dev, uint8_t reg, uint8_t *buf, size_t len,
|
static int _write(const ds3231_t *dev, uint8_t reg, uint8_t *buf, size_t len,
|
||||||
int acquire, int release)
|
int acquire, int release)
|
||||||
{
|
{
|
||||||
if (acquire && i2c_acquire(dev->bus)) {
|
if (acquire) {
|
||||||
return -EIO;
|
i2c_acquire(dev->bus);
|
||||||
}
|
}
|
||||||
if (i2c_write_regs(dev->bus, DS3231_I2C_ADDR, reg, buf, len, 0) < 0) {
|
if (i2c_write_regs(dev->bus, DS3231_I2C_ADDR, reg, buf, len, 0) < 0) {
|
||||||
i2c_release(dev->bus);
|
i2c_release(dev->bus);
|
||||||
|
@ -234,11 +234,7 @@ static int _reg_read(const hmc5883l_t *dev, uint8_t reg, uint8_t *data, uint16_t
|
|||||||
DEBUG_DEV("read %d byte from sensor registers starting at addr 0x%02x",
|
DEBUG_DEV("read %d byte from sensor registers starting at addr 0x%02x",
|
||||||
dev, len, reg);
|
dev, len, reg);
|
||||||
|
|
||||||
if (i2c_acquire(dev->dev)) {
|
i2c_acquire(dev->dev);
|
||||||
DEBUG_DEV("could not acquire I2C bus", dev);
|
|
||||||
return HMC5883L_ERROR_I2C;
|
|
||||||
}
|
|
||||||
|
|
||||||
int res = i2c_read_regs(dev->dev, HMC5883L_I2C_ADDRESS, reg, data, len, 0);
|
int res = i2c_read_regs(dev->dev, HMC5883L_I2C_ADDRESS, reg, data, len, 0);
|
||||||
i2c_release(dev->dev);
|
i2c_release(dev->dev);
|
||||||
|
|
||||||
@ -275,11 +271,7 @@ static int _reg_write(const hmc5883l_t *dev, uint8_t reg, uint8_t data)
|
|||||||
printf("\n");
|
printf("\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (i2c_acquire(dev->dev)) {
|
i2c_acquire(dev->dev);
|
||||||
DEBUG_DEV("could not acquire I2C bus", dev);
|
|
||||||
return HMC5883L_ERROR_I2C;
|
|
||||||
}
|
|
||||||
|
|
||||||
int res = i2c_write_regs(dev->dev, HMC5883L_I2C_ADDRESS, reg, &data, 1, 0);
|
int res = i2c_write_regs(dev->dev, HMC5883L_I2C_ADDRESS, reg, &data, 1, 0);
|
||||||
i2c_release(dev->dev);
|
i2c_release(dev->dev);
|
||||||
|
|
||||||
|
@ -46,9 +46,7 @@ int hsc_init(hsc_t *dev, const hsc_params_t *params)
|
|||||||
uint8_t buf[HSC_FULL_DATA_LENGTH];
|
uint8_t buf[HSC_FULL_DATA_LENGTH];
|
||||||
|
|
||||||
/* Acquire exclusive access */
|
/* Acquire exclusive access */
|
||||||
if (i2c_acquire(DEV_I2C)) {
|
i2c_acquire(DEV_I2C);
|
||||||
return -ENODEV;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (i2c_read_bytes(DEV_I2C, DEV_ADDR, buf, sizeof(buf), 0) < 0) {
|
if (i2c_read_bytes(DEV_I2C, DEV_ADDR, buf, sizeof(buf), 0) < 0) {
|
||||||
i2c_release(DEV_I2C);
|
i2c_release(DEV_I2C);
|
||||||
@ -120,9 +118,7 @@ static int _read_ut(const hsc_t *dev, int32_t *output)
|
|||||||
uint8_t buf[HSC_FULL_DATA_LENGTH];
|
uint8_t buf[HSC_FULL_DATA_LENGTH];
|
||||||
|
|
||||||
/* Acquire exclusive access */
|
/* Acquire exclusive access */
|
||||||
if (i2c_acquire(DEV_I2C)) {
|
i2c_acquire(DEV_I2C);
|
||||||
return -ENODEV;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (i2c_read_bytes(DEV_I2C, DEV_ADDR, buf, sizeof(buf), 0) < 0) {
|
if (i2c_read_bytes(DEV_I2C, DEV_ADDR, buf, sizeof(buf), 0) < 0) {
|
||||||
i2c_release(DEV_I2C);
|
i2c_release(DEV_I2C);
|
||||||
@ -144,9 +140,7 @@ static int _read_up(const hsc_t *dev, int32_t *output)
|
|||||||
uint8_t buf[HSC_FULL_DATA_LENGTH];
|
uint8_t buf[HSC_FULL_DATA_LENGTH];
|
||||||
|
|
||||||
/* Acquire exclusive access */
|
/* Acquire exclusive access */
|
||||||
if (i2c_acquire(DEV_I2C)) {
|
i2c_acquire(DEV_I2C);
|
||||||
return -ENODEV;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (i2c_read_bytes(DEV_I2C, DEV_ADDR, buf, sizeof(buf), 0) < 0) {
|
if (i2c_read_bytes(DEV_I2C, DEV_ADDR, buf, sizeof(buf), 0) < 0) {
|
||||||
i2c_release(DEV_I2C);
|
i2c_release(DEV_I2C);
|
||||||
|
@ -58,9 +58,7 @@
|
|||||||
*/
|
*/
|
||||||
static int _read_reg(const ina3221_t *dev, uint8_t reg, uint16_t *out)
|
static int _read_reg(const ina3221_t *dev, uint8_t reg, uint16_t *out)
|
||||||
{
|
{
|
||||||
if (i2c_acquire(dev->params.i2c)) {
|
i2c_acquire(dev->params.i2c);
|
||||||
return -EIO;
|
|
||||||
}
|
|
||||||
int status = i2c_read_regs(dev->params.i2c, dev->params.addr, reg, out,
|
int status = i2c_read_regs(dev->params.i2c, dev->params.addr, reg, out,
|
||||||
INA3221_REG_LEN, 0);
|
INA3221_REG_LEN, 0);
|
||||||
i2c_release(dev->params.i2c);
|
i2c_release(dev->params.i2c);
|
||||||
@ -87,9 +85,7 @@ static int _read_reg(const ina3221_t *dev, uint8_t reg, uint16_t *out)
|
|||||||
static int _write_reg(const ina3221_t *dev, uint8_t reg, uint16_t in)
|
static int _write_reg(const ina3221_t *dev, uint8_t reg, uint16_t in)
|
||||||
{
|
{
|
||||||
in = htons(in);
|
in = htons(in);
|
||||||
if (i2c_acquire(dev->params.i2c)) {
|
i2c_acquire(dev->params.i2c);
|
||||||
return -EIO;
|
|
||||||
}
|
|
||||||
int status = i2c_write_regs(dev->params.i2c, dev->params.addr, reg, &in,
|
int status = i2c_write_regs(dev->params.i2c, dev->params.addr, reg, &in,
|
||||||
INA3221_REG_LEN, 0);
|
INA3221_REG_LEN, 0);
|
||||||
i2c_release(dev->params.i2c);
|
i2c_release(dev->params.i2c);
|
||||||
|
@ -276,11 +276,12 @@ gpio_t i2c_pin_scl(i2c_t dev);
|
|||||||
* In case the I2C device is busy, this function will block until the bus is
|
* In case the I2C device is busy, this function will block until the bus is
|
||||||
* free again.
|
* free again.
|
||||||
*
|
*
|
||||||
* @param[in] dev I2C device to access
|
* @pre Given device is valid, otherwise an assertion blows up
|
||||||
|
* (if assertions are enabled).
|
||||||
*
|
*
|
||||||
* @return 0 on success, -1 on error
|
* @param[in] dev I2C device to access
|
||||||
*/
|
*/
|
||||||
int i2c_acquire(i2c_t dev);
|
void i2c_acquire(i2c_t dev);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Release the given I2C device to be used by others
|
* @brief Release the given I2C device to be used by others
|
||||||
|
@ -299,11 +299,7 @@ static int _reg_read(const itg320x_t *dev, uint8_t reg, uint8_t *data, uint16_t
|
|||||||
|
|
||||||
DEBUG_DEV("read %d bytes from reg 0x%02x", dev, len, reg);
|
DEBUG_DEV("read %d bytes from reg 0x%02x", dev, len, reg);
|
||||||
|
|
||||||
if (i2c_acquire(dev->params.dev) != 0) {
|
i2c_acquire(dev->params.dev);
|
||||||
DEBUG_DEV("could not acquire the I2C bus", dev);
|
|
||||||
return ITG320X_ERROR_I2C;
|
|
||||||
}
|
|
||||||
|
|
||||||
int res = i2c_read_regs(dev->params.dev, dev->params.addr, reg, data, len, 0);
|
int res = i2c_read_regs(dev->params.dev, dev->params.addr, reg, data, len, 0);
|
||||||
i2c_release(dev->params.dev);
|
i2c_release(dev->params.dev);
|
||||||
|
|
||||||
@ -332,11 +328,7 @@ static int _reg_write(const itg320x_t *dev, uint8_t reg, uint8_t data)
|
|||||||
|
|
||||||
DEBUG_DEV("write 1 byte to reg 0x%02x: 0x%02x", dev, reg, data);
|
DEBUG_DEV("write 1 byte to reg 0x%02x: 0x%02x", dev, reg, data);
|
||||||
|
|
||||||
if (i2c_acquire(dev->params.dev) != 0) {
|
i2c_acquire(dev->params.dev);
|
||||||
DEBUG_DEV("could not acquire the I2C bus", dev);
|
|
||||||
return ITG320X_ERROR_I2C;
|
|
||||||
}
|
|
||||||
|
|
||||||
int res = i2c_write_regs(dev->params.dev, dev->params.addr, reg, &data, 1, 0);
|
int res = i2c_write_regs(dev->params.dev, dev->params.addr, reg, &data, 1, 0);
|
||||||
i2c_release(dev->params.dev);
|
i2c_release(dev->params.dev);
|
||||||
|
|
||||||
|
@ -105,7 +105,8 @@ static int _init_bus(const lis2dh12_t *dev)
|
|||||||
|
|
||||||
static int _acquire(const lis2dh12_t *dev)
|
static int _acquire(const lis2dh12_t *dev)
|
||||||
{
|
{
|
||||||
return i2c_acquire(BUS);
|
i2c_acquire(BUS);
|
||||||
|
return BUS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void _release(const lis2dh12_t *dev)
|
static void _release(const lis2dh12_t *dev)
|
||||||
|
@ -66,9 +66,7 @@ int lm75_init(lm75_t *dev, const lm75_params_t *params) {
|
|||||||
uint8_t config = (params->shutdown_mode) | (params->tm_mode << 1) \
|
uint8_t config = (params->shutdown_mode) | (params->tm_mode << 1) \
|
||||||
| (params->polarity << 2) | (params->fault_q << 3);
|
| (params->polarity << 2) | (params->fault_q << 3);
|
||||||
|
|
||||||
if (i2c_acquire(I2C_BUS) != 0) {
|
i2c_acquire(I2C_BUS);
|
||||||
return LM75_ERROR_I2C;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* read the device ID register of the TMP1075 sensor to confirm it is a TMP1075 */
|
/* read the device ID register of the TMP1075 sensor to confirm it is a TMP1075 */
|
||||||
if (IS_USED(MODULE_TMP1075) && (dev->lm75_params.res == &tmp1075_properties)) {
|
if (IS_USED(MODULE_TMP1075) && (dev->lm75_params.res == &tmp1075_properties)) {
|
||||||
@ -112,9 +110,7 @@ int lm75_init(lm75_t *dev, const lm75_params_t *params) {
|
|||||||
int lm75_get_temperature_raw(lm75_t *dev, int *temperature) {
|
int lm75_get_temperature_raw(lm75_t *dev, int *temperature) {
|
||||||
|
|
||||||
int16_t temp;
|
int16_t temp;
|
||||||
if (i2c_acquire(I2C_BUS) != 0) {
|
i2c_acquire(I2C_BUS);
|
||||||
return LM75_ERROR_I2C;
|
|
||||||
}
|
|
||||||
/* read the temperature register */
|
/* read the temperature register */
|
||||||
if (i2c_read_regs(I2C_BUS, I2C_ADDR, LM75_TEMP_REG, &temp, 2, 0) != 0) {
|
if (i2c_read_regs(I2C_BUS, I2C_ADDR, LM75_TEMP_REG, &temp, 2, 0) != 0) {
|
||||||
i2c_release(I2C_BUS);
|
i2c_release(I2C_BUS);
|
||||||
@ -184,9 +180,7 @@ int lm75_set_temp_limits(lm75_t *dev, int temp_hyst, int temp_os, gpio_cb_t cb,
|
|||||||
temp_os_short = temp_os_short << dev->lm75_params.res->os_shift;
|
temp_os_short = temp_os_short << dev->lm75_params.res->os_shift;
|
||||||
temp_os_short = ntohs(temp_os_short);
|
temp_os_short = ntohs(temp_os_short);
|
||||||
|
|
||||||
if (i2c_acquire(I2C_BUS) != 0) {
|
i2c_acquire(I2C_BUS);
|
||||||
return LM75_ERROR_I2C;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (i2c_write_regs(I2C_BUS, I2C_ADDR, LM75_THYST_REG, &temp_hyst_short, 2, 0) != 0) {
|
if (i2c_write_regs(I2C_BUS, I2C_ADDR, LM75_THYST_REG, &temp_hyst_short, 2, 0) != 0) {
|
||||||
i2c_release(I2C_BUS);
|
i2c_release(I2C_BUS);
|
||||||
@ -207,9 +201,7 @@ int lm75_set_temp_limits(lm75_t *dev, int temp_hyst, int temp_os, gpio_cb_t cb,
|
|||||||
int lm75_get_os_temp(lm75_t *dev, int *temperature) {
|
int lm75_get_os_temp(lm75_t *dev, int *temperature) {
|
||||||
|
|
||||||
int16_t temp;
|
int16_t temp;
|
||||||
if (i2c_acquire(I2C_BUS) != 0) {
|
i2c_acquire(I2C_BUS);
|
||||||
return LM75_ERROR_I2C;
|
|
||||||
}
|
|
||||||
/* read the temperature register */
|
/* read the temperature register */
|
||||||
if (i2c_read_regs(I2C_BUS, I2C_ADDR, LM75_TOS_REG, &temp, 2, 0) != 0) {
|
if (i2c_read_regs(I2C_BUS, I2C_ADDR, LM75_TOS_REG, &temp, 2, 0) != 0) {
|
||||||
i2c_release(I2C_BUS);
|
i2c_release(I2C_BUS);
|
||||||
@ -230,9 +222,7 @@ int lm75_get_os_temp(lm75_t *dev, int *temperature) {
|
|||||||
int lm75_get_hyst_temp(lm75_t *dev, int *temperature) {
|
int lm75_get_hyst_temp(lm75_t *dev, int *temperature) {
|
||||||
|
|
||||||
int16_t temp;
|
int16_t temp;
|
||||||
if (i2c_acquire(I2C_BUS) != 0) {
|
i2c_acquire(I2C_BUS);
|
||||||
return LM75_ERROR_I2C;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* read the temperature register */
|
/* read the temperature register */
|
||||||
if (i2c_read_regs(I2C_BUS, I2C_ADDR, LM75_THYST_REG, &temp, 2, 0) != 0) {
|
if (i2c_read_regs(I2C_BUS, I2C_ADDR, LM75_THYST_REG, &temp, 2, 0) != 0) {
|
||||||
@ -260,9 +250,7 @@ int lm75_get_os_pin(lm75_t *dev, bool *os_pin_state) {
|
|||||||
|
|
||||||
int lm75_poweroff(lm75_t *dev) {
|
int lm75_poweroff(lm75_t *dev) {
|
||||||
|
|
||||||
if (i2c_acquire(I2C_BUS) != 0) {
|
i2c_acquire(I2C_BUS);
|
||||||
return LM75_ERROR_I2C;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint8_t config;
|
uint8_t config;
|
||||||
|
|
||||||
@ -291,9 +279,7 @@ int lm75_poweroff(lm75_t *dev) {
|
|||||||
|
|
||||||
int lm75_poweron(lm75_t *dev) {
|
int lm75_poweron(lm75_t *dev) {
|
||||||
|
|
||||||
if (i2c_acquire(I2C_BUS) != 0) {
|
i2c_acquire(I2C_BUS);
|
||||||
return LM75_ERROR_I2C;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint8_t config;
|
uint8_t config;
|
||||||
if (i2c_read_reg(I2C_BUS, I2C_ADDR, LM75_CONF_REG, &config, 0) != 0) {
|
if (i2c_read_reg(I2C_BUS, I2C_ADDR, LM75_CONF_REG, &config, 0) != 0) {
|
||||||
@ -328,9 +314,7 @@ int tmp1075_one_shot(lm75_t *dev) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
else {
|
else {
|
||||||
if (i2c_acquire(I2C_BUS) != 0) {
|
i2c_acquire(I2C_BUS);
|
||||||
return LM75_ERROR_I2C;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint8_t config;
|
uint8_t config;
|
||||||
if (i2c_read_reg(I2C_BUS, I2C_ADDR, LM75_CONF_REG, &config, 0) != 0) {
|
if (i2c_read_reg(I2C_BUS, I2C_ADDR, LM75_CONF_REG, &config, 0) != 0) {
|
||||||
|
@ -117,9 +117,7 @@ int mpu9x50_set_accel_power(mpu9x50_t *dev, mpu9x50_pwr_t pwr_conf)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Acquire exclusive access */
|
/* Acquire exclusive access */
|
||||||
if (i2c_acquire(DEV_I2C)) {
|
i2c_acquire(DEV_I2C);
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Read current power management 2 configuration */
|
/* Read current power management 2 configuration */
|
||||||
i2c_read_reg(DEV_I2C, DEV_ADDR, MPU9X50_PWR_MGMT_2_REG, &pwr_2_setting, 0);
|
i2c_read_reg(DEV_I2C, DEV_ADDR, MPU9X50_PWR_MGMT_2_REG, &pwr_2_setting, 0);
|
||||||
@ -158,9 +156,7 @@ int mpu9x50_set_gyro_power(mpu9x50_t *dev, mpu9x50_pwr_t pwr_conf)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Acquire exclusive access */
|
/* Acquire exclusive access */
|
||||||
if (i2c_acquire(DEV_I2C)) {
|
i2c_acquire(DEV_I2C);
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Read current power management 2 configuration */
|
/* Read current power management 2 configuration */
|
||||||
i2c_read_reg(DEV_I2C, DEV_ADDR, MPU9X50_PWR_MGMT_2_REG, &pwr_2_setting, 0);
|
i2c_read_reg(DEV_I2C, DEV_ADDR, MPU9X50_PWR_MGMT_2_REG, &pwr_2_setting, 0);
|
||||||
@ -206,9 +202,7 @@ int mpu9x50_set_compass_power(mpu9x50_t *dev, mpu9x50_pwr_t pwr_conf)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Acquire exclusive access */
|
/* Acquire exclusive access */
|
||||||
if (i2c_acquire(DEV_I2C)) {
|
i2c_acquire(DEV_I2C);
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Read current user control configuration */
|
/* Read current user control configuration */
|
||||||
i2c_read_reg(DEV_I2C, DEV_ADDR, MPU9X50_USER_CTRL_REG, &usr_ctrl_setting, 0);
|
i2c_read_reg(DEV_I2C, DEV_ADDR, MPU9X50_USER_CTRL_REG, &usr_ctrl_setting, 0);
|
||||||
@ -266,9 +260,7 @@ int mpu9x50_read_gyro(const mpu9x50_t *dev, mpu9x50_results_t *output)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Acquire exclusive access */
|
/* Acquire exclusive access */
|
||||||
if (i2c_acquire(DEV_I2C)) {
|
i2c_acquire(DEV_I2C);
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
/* Read raw data */
|
/* Read raw data */
|
||||||
i2c_read_regs(DEV_I2C, DEV_ADDR, MPU9X50_GYRO_START_REG, data, 6, 0);
|
i2c_read_regs(DEV_I2C, DEV_ADDR, MPU9X50_GYRO_START_REG, data, 6, 0);
|
||||||
/* Release the bus */
|
/* Release the bus */
|
||||||
@ -309,9 +301,7 @@ int mpu9x50_read_accel(const mpu9x50_t *dev, mpu9x50_results_t *output)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Acquire exclusive access */
|
/* Acquire exclusive access */
|
||||||
if (i2c_acquire(DEV_I2C)) {
|
i2c_acquire(DEV_I2C);
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
/* Read raw data */
|
/* Read raw data */
|
||||||
i2c_read_regs(DEV_I2C, DEV_ADDR, MPU9X50_ACCEL_START_REG, data, 6, 0);
|
i2c_read_regs(DEV_I2C, DEV_ADDR, MPU9X50_ACCEL_START_REG, data, 6, 0);
|
||||||
/* Release the bus */
|
/* Release the bus */
|
||||||
@ -333,9 +323,7 @@ int mpu9x50_read_compass(const mpu9x50_t *dev, mpu9x50_results_t *output)
|
|||||||
uint8_t data[6];
|
uint8_t data[6];
|
||||||
|
|
||||||
/* Acquire exclusive access */
|
/* Acquire exclusive access */
|
||||||
if (i2c_acquire(DEV_I2C)) {
|
i2c_acquire(DEV_I2C);
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
/* Read raw data */
|
/* Read raw data */
|
||||||
i2c_read_regs(DEV_I2C, DEV_ADDR, MPU9X50_EXT_SENS_DATA_START_REG, data, 6, 0);
|
i2c_read_regs(DEV_I2C, DEV_ADDR, MPU9X50_EXT_SENS_DATA_START_REG, data, 6, 0);
|
||||||
/* Release the bus */
|
/* Release the bus */
|
||||||
@ -366,9 +354,7 @@ int mpu9x50_read_temperature(const mpu9x50_t *dev, int32_t *output)
|
|||||||
uint16_t data;
|
uint16_t data;
|
||||||
|
|
||||||
/* Acquire exclusive access */
|
/* Acquire exclusive access */
|
||||||
if (i2c_acquire(DEV_I2C)) {
|
i2c_acquire(DEV_I2C);
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
/* Read raw temperature value */
|
/* Read raw temperature value */
|
||||||
i2c_read_regs(DEV_I2C, DEV_ADDR, MPU9X50_TEMP_START_REG, &data, 2, 0);
|
i2c_read_regs(DEV_I2C, DEV_ADDR, MPU9X50_TEMP_START_REG, &data, 2, 0);
|
||||||
/* Release the bus */
|
/* Release the bus */
|
||||||
@ -392,9 +378,7 @@ int mpu9x50_set_gyro_fsr(mpu9x50_t *dev, mpu9x50_gyro_ranges_t fsr)
|
|||||||
case MPU9X50_GYRO_FSR_500DPS:
|
case MPU9X50_GYRO_FSR_500DPS:
|
||||||
case MPU9X50_GYRO_FSR_1000DPS:
|
case MPU9X50_GYRO_FSR_1000DPS:
|
||||||
case MPU9X50_GYRO_FSR_2000DPS:
|
case MPU9X50_GYRO_FSR_2000DPS:
|
||||||
if (i2c_acquire(DEV_I2C)) {
|
i2c_acquire(DEV_I2C);
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
i2c_write_reg(DEV_I2C, DEV_ADDR,
|
i2c_write_reg(DEV_I2C, DEV_ADDR,
|
||||||
MPU9X50_GYRO_CFG_REG, (fsr << 3), 0);
|
MPU9X50_GYRO_CFG_REG, (fsr << 3), 0);
|
||||||
i2c_release(DEV_I2C);
|
i2c_release(DEV_I2C);
|
||||||
@ -418,9 +402,7 @@ int mpu9x50_set_accel_fsr(mpu9x50_t *dev, mpu9x50_accel_ranges_t fsr)
|
|||||||
case MPU9X50_ACCEL_FSR_4G:
|
case MPU9X50_ACCEL_FSR_4G:
|
||||||
case MPU9X50_ACCEL_FSR_8G:
|
case MPU9X50_ACCEL_FSR_8G:
|
||||||
case MPU9X50_ACCEL_FSR_16G:
|
case MPU9X50_ACCEL_FSR_16G:
|
||||||
if (i2c_acquire(DEV_I2C)) {
|
i2c_acquire(DEV_I2C);
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
i2c_write_reg(DEV_I2C, DEV_ADDR,
|
i2c_write_reg(DEV_I2C, DEV_ADDR,
|
||||||
MPU9X50_ACCEL_CFG_REG, (fsr << 3), 0);
|
MPU9X50_ACCEL_CFG_REG, (fsr << 3), 0);
|
||||||
i2c_release(DEV_I2C);
|
i2c_release(DEV_I2C);
|
||||||
@ -447,9 +429,7 @@ int mpu9x50_set_sample_rate(mpu9x50_t *dev, uint16_t rate)
|
|||||||
/* Compute divider to achieve desired sample rate and write to rate div register */
|
/* Compute divider to achieve desired sample rate and write to rate div register */
|
||||||
divider = (1000 / rate - 1);
|
divider = (1000 / rate - 1);
|
||||||
|
|
||||||
if (i2c_acquire(DEV_I2C)) {
|
i2c_acquire(DEV_I2C);
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
i2c_write_reg(DEV_I2C, DEV_ADDR, MPU9X50_RATE_DIV_REG, divider, 0);
|
i2c_write_reg(DEV_I2C, DEV_ADDR, MPU9X50_RATE_DIV_REG, divider, 0);
|
||||||
|
|
||||||
/* Store configured sample rate */
|
/* Store configured sample rate */
|
||||||
@ -477,9 +457,7 @@ int mpu9x50_set_compass_sample_rate(mpu9x50_t *dev, uint8_t rate)
|
|||||||
/* Compute divider to achieve desired sample rate and write to slave ctrl register */
|
/* Compute divider to achieve desired sample rate and write to slave ctrl register */
|
||||||
divider = (dev->conf.sample_rate / rate - 1);
|
divider = (dev->conf.sample_rate / rate - 1);
|
||||||
|
|
||||||
if (i2c_acquire(DEV_I2C)) {
|
i2c_acquire(DEV_I2C);
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
i2c_write_reg(DEV_I2C, DEV_ADDR, MPU9X50_SLAVE4_CTRL_REG, divider, 0);
|
i2c_write_reg(DEV_I2C, DEV_ADDR, MPU9X50_SLAVE4_CTRL_REG, divider, 0);
|
||||||
i2c_release(DEV_I2C);
|
i2c_release(DEV_I2C);
|
||||||
|
|
||||||
|
@ -259,9 +259,7 @@ int _write_reg(pca9633_t* dev, uint8_t reg, uint8_t data)
|
|||||||
{
|
{
|
||||||
i2c_t i2c_dev = dev->params.i2c_dev;
|
i2c_t i2c_dev = dev->params.i2c_dev;
|
||||||
|
|
||||||
if (i2c_acquire(i2c_dev) != 0) {
|
i2c_acquire(i2c_dev);
|
||||||
return -PCA9633_ERROR_I2C;
|
|
||||||
}
|
|
||||||
int rc = i2c_write_reg(i2c_dev, dev->params.i2c_addr, reg, data, 0);
|
int rc = i2c_write_reg(i2c_dev, dev->params.i2c_addr, reg, data, 0);
|
||||||
i2c_release(i2c_dev);
|
i2c_release(i2c_dev);
|
||||||
|
|
||||||
@ -272,9 +270,7 @@ int _read_reg(pca9633_t* dev, uint8_t reg, uint8_t* data)
|
|||||||
{
|
{
|
||||||
i2c_t i2c_dev = dev->params.i2c_dev;
|
i2c_t i2c_dev = dev->params.i2c_dev;
|
||||||
|
|
||||||
if (i2c_acquire(i2c_dev) != 0) {
|
i2c_acquire(i2c_dev);
|
||||||
return -PCA9633_ERROR_I2C;
|
|
||||||
}
|
|
||||||
int rc = i2c_read_reg(i2c_dev, dev->params.i2c_addr, reg, data, 0);
|
int rc = i2c_read_reg(i2c_dev, dev->params.i2c_addr, reg, data, 0);
|
||||||
i2c_release(i2c_dev);
|
i2c_release(i2c_dev);
|
||||||
|
|
||||||
|
@ -292,10 +292,7 @@ static int _read(const pca9685_t *dev, uint8_t reg, uint8_t *data, uint32_t len)
|
|||||||
DEBUG_DEV("reg=%02x data=%p len=%"PRIu32"", dev, reg, data, len);
|
DEBUG_DEV("reg=%02x data=%p len=%"PRIu32"", dev, reg, data, len);
|
||||||
|
|
||||||
/* acquire the I2C device */
|
/* acquire the I2C device */
|
||||||
if (i2c_acquire(dev->params.i2c_dev)) {
|
i2c_acquire(dev->params.i2c_dev);
|
||||||
DEBUG_DEV("could not acquire I2C bus", dev);
|
|
||||||
return -PCA9685_ERROR_I2C;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (i2c_read_regs(dev->params.i2c_dev,
|
if (i2c_read_regs(dev->params.i2c_dev,
|
||||||
dev->params.i2c_addr, reg, data, len, 0) != 0) {
|
dev->params.i2c_addr, reg, data, len, 0) != 0) {
|
||||||
@ -313,10 +310,7 @@ static int _write(const pca9685_t *dev, uint8_t reg, const uint8_t *data, uint32
|
|||||||
{
|
{
|
||||||
DEBUG_DEV("reg=%02x data=%p len=%"PRIu32"", dev, reg, data, len);
|
DEBUG_DEV("reg=%02x data=%p len=%"PRIu32"", dev, reg, data, len);
|
||||||
|
|
||||||
if (i2c_acquire(dev->params.i2c_dev)) {
|
i2c_acquire(dev->params.i2c_dev);
|
||||||
DEBUG_DEV("could not acquire I2C bus", dev);
|
|
||||||
return -PCA9685_ERROR_I2C;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (i2c_write_regs(dev->params.i2c_dev,
|
if (i2c_write_regs(dev->params.i2c_dev,
|
||||||
dev->params.i2c_addr, reg, data, len, 0) != 0) {
|
dev->params.i2c_addr, reg, data, len, 0) != 0) {
|
||||||
|
@ -32,9 +32,7 @@ static int _reg_read(const qmc5883l_t *dev, uint8_t reg,
|
|||||||
uint8_t *val, int acquire, int release)
|
uint8_t *val, int acquire, int release)
|
||||||
{
|
{
|
||||||
if (acquire) {
|
if (acquire) {
|
||||||
if (i2c_acquire(dev->i2c) != 0) {
|
i2c_acquire(dev->i2c);
|
||||||
return QMC5883L_BUSERR;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
int res = i2c_read_reg(dev->i2c, ADDR, reg, val, 0);
|
int res = i2c_read_reg(dev->i2c, ADDR, reg, val, 0);
|
||||||
if ((release) || (res != 0)) {
|
if ((release) || (res != 0)) {
|
||||||
@ -47,9 +45,7 @@ static int _reg_write(const qmc5883l_t *dev, uint8_t reg,
|
|||||||
uint8_t val, int acquire, int release)
|
uint8_t val, int acquire, int release)
|
||||||
{
|
{
|
||||||
if (acquire) {
|
if (acquire) {
|
||||||
if (i2c_acquire(dev->i2c) != 0) {
|
i2c_acquire(dev->i2c);
|
||||||
return QMC5883L_BUSERR;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
int res = i2c_write_reg(dev->i2c, ADDR, reg, val, 0);
|
int res = i2c_write_reg(dev->i2c, ADDR, reg, val, 0);
|
||||||
if ((release) || (res != 0)) {
|
if ((release) || (res != 0)) {
|
||||||
|
@ -97,10 +97,7 @@ static int _rx_tx_data(sgp30_t *dev, uint16_t cmd, uint8_t *data,
|
|||||||
{
|
{
|
||||||
int res = 0;
|
int res = 0;
|
||||||
|
|
||||||
if (i2c_acquire(dev->params.i2c_dev) != 0) {
|
i2c_acquire(dev->params.i2c_dev);
|
||||||
DEBUG("[sgp30]: could not acquire I2C bus %d\n", dev->params.i2c_dev);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint8_t frame_cmd[sizeof(cmd) + len];
|
uint8_t frame_cmd[sizeof(cmd) + len];
|
||||||
frame_cmd[0] = cmd >> 8;
|
frame_cmd[0] = cmd >> 8;
|
||||||
|
@ -283,16 +283,12 @@ static int _send_command(sht3x_dev_t* dev, uint16_t cmd)
|
|||||||
{
|
{
|
||||||
ASSERT_PARAM (dev != NULL);
|
ASSERT_PARAM (dev != NULL);
|
||||||
|
|
||||||
int res = SHT3X_OK;
|
int res;
|
||||||
|
|
||||||
uint8_t data[2] = { cmd >> 8, cmd & 0xff };
|
uint8_t data[2] = { cmd >> 8, cmd & 0xff };
|
||||||
DEBUG_DEV("send command 0x%02x%02x", dev, data[0], data[1]);
|
DEBUG_DEV("send command 0x%02x%02x", dev, data[0], data[1]);
|
||||||
|
|
||||||
if (i2c_acquire(dev->i2c_dev) != 0) {
|
i2c_acquire(dev->i2c_dev);
|
||||||
DEBUG_DEV ("could not acquire I2C bus", dev);
|
|
||||||
return -SHT3X_ERROR_I2C;
|
|
||||||
}
|
|
||||||
|
|
||||||
res = i2c_write_bytes(dev->i2c_dev, dev->i2c_addr, (const void*)data, 2, 0);
|
res = i2c_write_bytes(dev->i2c_dev, dev->i2c_addr, (const void*)data, 2, 0);
|
||||||
i2c_release(dev->i2c_dev);
|
i2c_release(dev->i2c_dev);
|
||||||
|
|
||||||
@ -307,13 +303,9 @@ static int _send_command(sht3x_dev_t* dev, uint16_t cmd)
|
|||||||
|
|
||||||
static int _read_data(sht3x_dev_t* dev, uint8_t *data, uint8_t len)
|
static int _read_data(sht3x_dev_t* dev, uint8_t *data, uint8_t len)
|
||||||
{
|
{
|
||||||
int res = SHT3X_OK;
|
int res;
|
||||||
|
|
||||||
if (i2c_acquire(dev->i2c_dev) != 0) {
|
|
||||||
DEBUG_DEV ("could not acquire I2C bus", dev);
|
|
||||||
return -SHT3X_ERROR_I2C;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
i2c_acquire(dev->i2c_dev);
|
||||||
res = i2c_read_bytes(dev->i2c_dev, dev->i2c_addr, (void*)data, len, 0);
|
res = i2c_read_bytes(dev->i2c_dev, dev->i2c_addr, (void*)data, len, 0);
|
||||||
i2c_release(dev->i2c_dev);
|
i2c_release(dev->i2c_dev);
|
||||||
|
|
||||||
|
@ -147,10 +147,7 @@ static int _rx_tx_data(const sps30_t *dev, uint16_t ptr_addr,
|
|||||||
int res = 0;
|
int res = 0;
|
||||||
unsigned retr = CONFIG_SPS30_ERROR_RETRY;
|
unsigned retr = CONFIG_SPS30_ERROR_RETRY;
|
||||||
|
|
||||||
if (i2c_acquire(dev->p.i2c_dev) != 0) {
|
i2c_acquire(dev->p.i2c_dev);
|
||||||
LOG_ERROR("could not acquire I2C bus %d\n", dev->p.i2c_dev);
|
|
||||||
return -SPS30_I2C_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
do {
|
do {
|
||||||
size_t addr_data_crc_len = SPS30_PTR_LEN + len + len / 2;
|
size_t addr_data_crc_len = SPS30_PTR_LEN + len + len / 2;
|
||||||
|
@ -43,11 +43,7 @@ int tsl4531x_init(tsl4531x_t *dev, const tsl4531x_params_t *params)
|
|||||||
uint8_t id;
|
uint8_t id;
|
||||||
|
|
||||||
/* Initialise I2C bus */
|
/* Initialise I2C bus */
|
||||||
if ((r = i2c_acquire(params->i2c_dev)) < 0) {
|
i2c_acquire(params->i2c_dev);
|
||||||
DEBUG("I2C_dev is: %d.", params->i2c_dev);
|
|
||||||
DEBUG("[Error] Cannot acquire device. I2C error: %d\n", r);
|
|
||||||
return -ENODEV;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Test for connectivity - verify ID and compare against stored value */
|
/* Test for connectivity - verify ID and compare against stored value */
|
||||||
if ((r = i2c_read_reg(params->i2c_dev,
|
if ((r = i2c_read_reg(params->i2c_dev,
|
||||||
@ -107,10 +103,7 @@ int tsl4531x_set_low_power_mode(tsl4531x_t *dev, uint8_t low_power_mode)
|
|||||||
|
|
||||||
dev->low_power_mode = low_power_mode;
|
dev->low_power_mode = low_power_mode;
|
||||||
|
|
||||||
if ((r = i2c_acquire(dev->i2c_dev)) < 0) {
|
i2c_acquire(dev->i2c_dev);
|
||||||
DEBUG("[Error] Cannot acquire device. I2C error: %d\n", r);
|
|
||||||
return -ENODEV;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((r = i2c_write_reg(dev->i2c_dev,
|
if ((r = i2c_write_reg(dev->i2c_dev,
|
||||||
dev->i2c_addr,
|
dev->i2c_addr,
|
||||||
@ -142,10 +135,7 @@ int tsl4531x_start_sample(tsl4531x_t *dev)
|
|||||||
|
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
if ((r = i2c_acquire(dev->i2c_dev)) < 0) {
|
i2c_acquire(dev->i2c_dev);
|
||||||
DEBUG("[Error] Cannot acquire device. I2C error: %d\n", r);
|
|
||||||
return -ENODEV;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((r = i2c_write_reg(dev->i2c_dev,
|
if ((r = i2c_write_reg(dev->i2c_dev,
|
||||||
dev->i2c_addr,
|
dev->i2c_addr,
|
||||||
@ -195,10 +185,7 @@ int tsl4531x_get_sample(const tsl4531x_t *dev)
|
|||||||
int r;
|
int r;
|
||||||
uint8_t als_data[2]; /* = {[DATALOW], [DATAHIGH]} */
|
uint8_t als_data[2]; /* = {[DATALOW], [DATAHIGH]} */
|
||||||
|
|
||||||
if ((r = i2c_acquire(dev->i2c_dev)) < 0) {
|
i2c_acquire(dev->i2c_dev);
|
||||||
DEBUG("[Error] Cannot acquire device. I2C error: %d\n", r);
|
|
||||||
return -ENODEV;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((r = i2c_read_regs(dev->i2c_dev,
|
if ((r = i2c_read_regs(dev->i2c_dev,
|
||||||
dev->i2c_addr,
|
dev->i2c_addr,
|
||||||
|
@ -101,13 +101,12 @@ uint8_t TwoWire::requestFrom(uint8_t addr, uint8_t size, uint8_t stop)
|
|||||||
|
|
||||||
uint8_t read = 0;
|
uint8_t read = 0;
|
||||||
|
|
||||||
if (i2c_acquire(ARDUINO_I2C_DEV) == 0) {
|
i2c_acquire(ARDUINO_I2C_DEV);
|
||||||
if (i2c_read_bytes(ARDUINO_I2C_DEV, addr, rxBuffer, size,
|
if (i2c_read_bytes(ARDUINO_I2C_DEV, addr, rxBuffer, size,
|
||||||
stop ? 0 : I2C_NOSTOP) == 0) {
|
stop ? 0 : I2C_NOSTOP) == 0) {
|
||||||
read = size;
|
read = size;
|
||||||
}
|
|
||||||
i2c_release(ARDUINO_I2C_DEV);
|
|
||||||
}
|
}
|
||||||
|
i2c_release(ARDUINO_I2C_DEV);
|
||||||
|
|
||||||
rxBufferIndex = 0;
|
rxBufferIndex = 0;
|
||||||
rxBufferLength = read;
|
rxBufferLength = read;
|
||||||
@ -136,9 +135,7 @@ uint8_t TwoWire::endTransmission(uint8_t stop)
|
|||||||
return txError;
|
return txError;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (i2c_acquire(ARDUINO_I2C_DEV) != 0) {
|
i2c_acquire(ARDUINO_I2C_DEV);
|
||||||
return WIRE_PORT_ERROR_OTHER;
|
|
||||||
}
|
|
||||||
|
|
||||||
int res = i2c_write_bytes(ARDUINO_I2C_DEV,
|
int res = i2c_write_bytes(ARDUINO_I2C_DEV,
|
||||||
txAddress, txBuffer, txBufferLength,
|
txAddress, txBuffer, txBufferLength,
|
||||||
|
@ -59,10 +59,7 @@ int _i2c_scan(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
printf("Scanning I2C device %s...\n", argv[1]);
|
printf("Scanning I2C device %s...\n", argv[1]);
|
||||||
if (i2c_acquire(dev)){
|
i2c_acquire(dev);
|
||||||
puts("Failed to acquire I2C device");
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
puts(
|
puts(
|
||||||
"addr not ack'ed = \"-\", addr ack'ed = \"X\", addr reserved = \"R\", error = \"E\"\n"
|
"addr not ack'ed = \"-\", addr ack'ed = \"X\", addr reserved = \"R\", error = \"E\"\n"
|
||||||
|
@ -129,7 +129,6 @@ static int _print_i2c_error(int res)
|
|||||||
|
|
||||||
int cmd_i2c_acquire(int argc, char **argv)
|
int cmd_i2c_acquire(int argc, char **argv)
|
||||||
{
|
{
|
||||||
int res;
|
|
||||||
int dev;
|
int dev;
|
||||||
|
|
||||||
dev = _check_param(argc, argv, 1, 1, "DEV");
|
dev = _check_param(argc, argv, 1, 1, "DEV");
|
||||||
@ -138,12 +137,10 @@ int cmd_i2c_acquire(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
printf("Command: i2c_acquire(%i)\n", dev);
|
printf("Command: i2c_acquire(%i)\n", dev);
|
||||||
res = i2c_acquire(dev);
|
i2c_acquire(dev);
|
||||||
if (res == I2C_ACK) {
|
|
||||||
printf("Success: i2c_%i acquired\n", dev);
|
printf("Success: i2c_%i acquired\n", dev);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
|
||||||
return _print_i2c_error(res);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int cmd_i2c_release(int argc, char **argv)
|
int cmd_i2c_release(int argc, char **argv)
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
DEFINE_FFF_GLOBALS
|
DEFINE_FFF_GLOBALS
|
||||||
FAKE_VALUE_FUNC(int, i2c_read_bytes, i2c_t, uint16_t, void *, size_t, uint8_t)
|
FAKE_VALUE_FUNC(int, i2c_read_bytes, i2c_t, uint16_t, void *, size_t, uint8_t)
|
||||||
FAKE_VALUE_FUNC(int, i2c_acquire, i2c_t)
|
FAKE_VOID_FUNC(i2c_acquire, i2c_t)
|
||||||
FAKE_VOID_FUNC(i2c_release, i2c_t)
|
FAKE_VOID_FUNC(i2c_release, i2c_t)
|
||||||
|
|
||||||
int test_i2c_basic(void *buffer, size_t len);
|
int test_i2c_basic(void *buffer, size_t len);
|
||||||
@ -35,14 +35,10 @@ const uint8_t flags = 0;
|
|||||||
|
|
||||||
int test_i2c_basic(void *buffer, size_t len)
|
int test_i2c_basic(void *buffer, size_t len)
|
||||||
{
|
{
|
||||||
int acquire_return_val;
|
|
||||||
int read_return_val;
|
int read_return_val;
|
||||||
int failure = 0;
|
int failure = 0;
|
||||||
|
|
||||||
acquire_return_val = i2c_acquire(device);
|
i2c_acquire(device);
|
||||||
if (acquire_return_val != 0) {
|
|
||||||
failure = 1;
|
|
||||||
}
|
|
||||||
read_return_val = i2c_read_bytes(device, address, buffer, len, flags);
|
read_return_val = i2c_read_bytes(device, address, buffer, len, flags);
|
||||||
if (read_return_val != 0) {
|
if (read_return_val != 0) {
|
||||||
failure = 1;
|
failure = 1;
|
||||||
@ -70,7 +66,6 @@ int main(void)
|
|||||||
puts("Testing fff");
|
puts("Testing fff");
|
||||||
/* Set fake implementation / return values of the mocks */
|
/* Set fake implementation / return values of the mocks */
|
||||||
i2c_read_bytes_fake.custom_fake = read_fake_impl;
|
i2c_read_bytes_fake.custom_fake = read_fake_impl;
|
||||||
i2c_acquire_fake.return_val = 0;
|
|
||||||
/* Run function under test */
|
/* Run function under test */
|
||||||
basic_test_return_val = test_i2c_basic(buffer, fake_read_len);
|
basic_test_return_val = test_i2c_basic(buffer, fake_read_len);
|
||||||
/* Assert correct interaction of the function under test with the mocked API */
|
/* Assert correct interaction of the function under test with the mocked API */
|
||||||
|
Loading…
Reference in New Issue
Block a user