blob: 4c1f318820f43f3065cd2931fbf9bdf63a31c7d2 [file] [log] [blame]
/*
* Copyright (c), 2023 Basalte bv
*
* SPDX-License-Identifier: Apache-2.0
*/
#ifndef ZEPHYR_DRIVERS_I2C_I2C_SC18IM704_H_
#define ZEPHYR_DRIVERS_I2C_I2C_SC18IM704_H_
#include <stdint.h>
#ifdef __cplusplus
extern "C" {
#endif
#define SC18IM704_CMD_STOP 0x50
#define SC18IM704_CMD_I2C_START 0x53
#define SC18IM704_CMD_READ_REG 0x52
#define SC18IM704_CMD_WRITE_REG 0x57
#define SC18IM704_CMD_READ_GPIO 0x49
#define SC18IM704_CMD_WRITE_GPIO 0x4f
#define SC18IM704_CMD_POWER_DOWN 0x5a
#define SC18IM704_REG_BRG0 0x00
#define SC18IM704_REG_BRG1 0x01
#define SC18IM704_REG_GPIO_CONF1 0x02
#define SC18IM704_REG_GPIO_CONF2 0x03
#define SC18IM704_REG_GPIO_STATE 0x04
#define SC18IM704_REG_I2C_ADDR 0x06
#define SC18IM704_REG_I2C_CLK_L 0x07
#define SC18IM704_REG_I2C_CLK_H 0x08
#define SC18IM704_REG_I2C_TIMEOUT 0x09
#define SC18IM704_REG_I2C_STAT 0x0a
#define SC18IM704_I2C_STAT_OK 0xf0
#define SC18IM704_I2C_STAT_NACK_ADDR 0xf1
#define SC18IM704_I2C_STAT_NACK_DATA 0xf2
#define SC18IM704_I2C_STAT_TIMEOUT 0xf8
/**
* @brief Claim the SC18IM704 device.
*
* @warning After calling this routine, the device cannot be used by any other
* thread until the sc18im704_release routine is called.
*
* @param dev SC18IM704 device.
*
* @retval 0 Device claimed.
* @retval -EBUSY The device could not be claimed.
*/
int sc18im704_claim(const struct device *dev);
/**
* @brief Release the SC18IM704 device claim.
*
* @warning This routine must only be used after a sc18im704_claim.
*
* @param dev SC18IM704 device.
*
* @retval 0 Device claim to release.
* @retval -EPERM The current thread hasn't claimed the device.
* @retval -EINVAL The device has no active claims.
*/
int sc18im704_release(const struct device *dev);
/**
* @brief Exchange data with the SC18IM704 device.
*
* @param dev SC18IM704 device.
* @param tx_data The data buffer to write from.
* @param tx_len The length of the tx_data buffer.
* @param rx_data The data buffer to read to.
* @param rx_len The length of the rx_data buffer.
*
* @retval 0 If successful.
* @retval -EAGAIN The device did not respond in time (1 second timeout).
*/
int sc18im704_transfer(const struct device *dev,
const uint8_t *tx_data, uint8_t tx_len,
uint8_t *rx_data, uint8_t rx_len);
#ifdef __cplusplus
}
#endif
#endif /* ZEPHYR_DRIVERS_I2C_I2C_SC18IM704_H_ */