8#ifndef ZEPHYR_MCTP_I2C_GPIO_TARGET_H_
9#define ZEPHYR_MCTP_I2C_GPIO_TARGET_H_
24 struct mctp_binding binding;
32 struct mctp_pktbuf *rx_pkt;
33 struct k_sem *tx_lock;
34 struct k_sem *tx_complete;
36 struct mctp_pktbuf *tx_pkt;
42int mctp_i2c_gpio_target_start(
struct mctp_binding *binding);
43int mctp_i2c_gpio_target_tx(
struct mctp_binding *binding,
struct mctp_pktbuf *pkt);
70#define MCTP_I2C_GPIO_TARGET_DT_DEFINE(_name, _node_id) \
71 K_SEM_DEFINE(_name ##_tx_lock, 1, 1); \
72 K_SEM_DEFINE(_name ##_tx_complete, 0, 1); \
73 struct mctp_binding_i2c_gpio_target _name = { \
75 .name = STRINGIFY(_name), .version = 1, \
76 .start = mctp_i2c_gpio_target_start, \
77 .tx = mctp_i2c_gpio_target_tx, \
78 .pkt_size = MCTP_I2C_GPIO_MAX_PKT_SIZE, \
80 .i2c = DEVICE_DT_GET(DT_PHANDLE(_node_id, i2c)), \
82 .address = DT_PROP(_node_id, i2c_addr), \
83 .callbacks = &mctp_i2c_gpio_target_callbacks, \
85 .endpoint_id = DT_PROP(_node_id, endpoint_id), \
86 .endpoint_gpio = GPIO_DT_SPEC_GET(_node_id, endpoint_gpios), \
87 .tx_lock = &_name##_tx_lock, \
88 .tx_complete = &_name##_tx_complete, \
Public APIs for GPIO drivers.
Public APIs for the I2C drivers.
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
Runtime device structure (in ROM) per driver instance.
Definition device.h:510
Container for GPIO pin information specified in devicetree.
Definition gpio.h:295
Structure providing callbacks to be implemented for devices that supports the I2C target API.
Definition i2c.h:422
Structure describing a device that supports the I2C target API.
Definition i2c.h:445
Semaphore structure.
Definition kernel.h:3275
An MCTP binding for Zephyr's I2C target interface using GPIO.
Definition mctp_i2c_gpio_target.h:22