42a509b812
Add I2C target mode support for NPCX i2c driver. Verified with i2c_target_api test suite on npcx9m6_evb. Signed-off-by: Mulin Chao <mlchao@nuvoton.com>
114 lines
3.5 KiB
C
114 lines
3.5 KiB
C
/*
|
|
* Copyright (c) 2020 Nuvoton Technology Corporation.
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
#ifndef ZEPHYR_DRIVERS_I2C_I2C_NPCX_CONTROLLER_H_
|
|
#define ZEPHYR_DRIVERS_I2C_I2C_NPCX_CONTROLLER_H_
|
|
|
|
#include <zephyr/device.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @brief Lock the mutex of npcx i2c controller.
|
|
*
|
|
* @param i2c_dev Pointer to the device structure for i2c controller instance.
|
|
*/
|
|
void npcx_i2c_ctrl_mutex_lock(const struct device *i2c_dev);
|
|
|
|
/**
|
|
* @brief Unlock the mutex of npcx i2c controller.
|
|
*
|
|
* @param i2c_dev Pointer to the device structure for i2c controller instance.
|
|
*/
|
|
void npcx_i2c_ctrl_mutex_unlock(const struct device *i2c_dev);
|
|
|
|
/**
|
|
* @brief Configure operation of a npcx i2c controller.
|
|
*
|
|
* @param i2c_dev Pointer to the device structure for i2c controller instance.
|
|
* @param dev_config Bit-packed 32-bit value to the device runtime configuration
|
|
* for the I2C controller.
|
|
*
|
|
* @retval 0 If successful.
|
|
* @retval -EIO General input / output error, failed to configure device.
|
|
* @retval -ERANGE Out of supported i2c frequency.
|
|
*/
|
|
int npcx_i2c_ctrl_configure(const struct device *i2c_dev, uint32_t dev_config);
|
|
|
|
/**
|
|
* @brief Get I2C controller speed.
|
|
*
|
|
* @param i2c_dev Pointer to the device structure for i2c controller instance.
|
|
* @param speed Pointer to store the I2C speed.
|
|
*
|
|
* @retval 0 If successful.
|
|
* @retval -ERANGE Stored I2C frequency out of supported range.
|
|
* @retval -EIO Controller is not configured.
|
|
*/
|
|
int npcx_i2c_ctrl_get_speed(const struct device *i2c_dev, uint32_t *speed);
|
|
|
|
/**
|
|
* @brief Perform data transfer to via npcx i2c controller.
|
|
*
|
|
* @param i2c_dev Pointer to the device structure for i2c controller instance.
|
|
* @param msgs Array of messages to transfer.
|
|
* @param num_msgs Number of messages to transfer.
|
|
* @param addr Address of the I2C target device.
|
|
* @param port Port index of selected i2c port.
|
|
*
|
|
* @retval 0 If successful.
|
|
* @retval -EIO General input / output error.
|
|
* @retval -ENXIO No slave address match.
|
|
* @retval -ETIMEDOUT Timeout occurred for a i2c transaction.
|
|
*/
|
|
int npcx_i2c_ctrl_transfer(const struct device *i2c_dev, struct i2c_msg *msgs,
|
|
uint8_t num_msgs, uint16_t addr, uint8_t port);
|
|
|
|
/**
|
|
* @brief Toggle the SCL to generate maxmium 9 clocks until the target release
|
|
* the SDA line and send a STOP condition.
|
|
*
|
|
* @param i2c_dev Pointer to the device structure for i2c controller instance.
|
|
*
|
|
* @retval 0 If successful.
|
|
* @retval -EBUSY fail to recover the bus.
|
|
*/
|
|
int npcx_i2c_ctrl_recover_bus(const struct device *dev);
|
|
|
|
/**
|
|
* @brief Registers the provided config as Target device of a npcx i2c controller.
|
|
*
|
|
* @param i2c_dev Pointer to the device structure for i2c controller instance.
|
|
* @param target_cfg Config struct used by the i2c target driver
|
|
* @param port Port index of selected i2c port.
|
|
*
|
|
* @retval 0 Is successful
|
|
* @retval -EBUSY If i2c transaction is proceeding.
|
|
*/
|
|
int npcx_i2c_ctrl_target_register(const struct device *i2c_dev,
|
|
struct i2c_target_config *target_cfg, uint8_t port);
|
|
|
|
/**
|
|
* @brief Unregisters the provided config as Target device of a npcx i2c controller.
|
|
*
|
|
* @param i2c_dev Pointer to the device structure for i2c controller instance.
|
|
* @param target_cfg Config struct used by the i2c target driver
|
|
*
|
|
* @retval 0 Is successful
|
|
* @retval -EBUSY If i2c transaction is proceeding.
|
|
* @retval -EINVAL If parameters are invalid
|
|
*/
|
|
int npcx_i2c_ctrl_target_unregister(const struct device *i2c_dev,
|
|
struct i2c_target_config *target_cfg);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* ZEPHYR_DRIVERS_I2C_I2C_NPCX_CONTROLLER_H_ */
|