1
0
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:
benpicco 2021-11-29 11:44:59 +01:00 committed by GitHub
commit c84a40abc4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
43 changed files with 128 additions and 279 deletions

View File

@ -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)

View File

@ -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;

View File

@ -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)

View File

@ -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)

View File

@ -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)

View File

@ -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)) {

View File

@ -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)

View File

@ -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)

View File

@ -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)

View File

@ -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;
} }

View File

@ -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)

View File

@ -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)

View File

@ -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)

View File

@ -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)

View File

@ -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)

View File

@ -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)

View File

@ -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);

View File

@ -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;

View File

@ -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;
} }

View File

@ -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);

View File

@ -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;

View File

@ -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;
} }

View File

@ -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)) {

View File

@ -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);

View File

@ -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);

View File

@ -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);

View File

@ -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);

View File

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

View File

@ -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);

View File

@ -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)

View File

@ -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) {

View File

@ -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);

View File

@ -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);

View File

@ -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) {

View File

@ -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)) {

View File

@ -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;

View File

@ -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);

View File

@ -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;

View File

@ -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,

View File

@ -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,

View File

@ -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"

View File

@ -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)

View File

@ -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 */