Zephyr Project API  3.4.0
A Scalable Open Source RTOS
i2c.h
Go to the documentation of this file.
1
7/*
8 * Copyright (c) 2015 Intel Corporation
9 *
10 * SPDX-License-Identifier: Apache-2.0
11 */
12#ifndef ZEPHYR_INCLUDE_DRIVERS_I2C_H_
13#define ZEPHYR_INCLUDE_DRIVERS_I2C_H_
14
22#include <errno.h>
23
24#include <zephyr/types.h>
25#include <zephyr/device.h>
26#include <zephyr/kernel.h>
27#include <zephyr/sys/slist.h>
28#include <zephyr/rtio/rtio.h>
29
30#ifdef __cplusplus
31extern "C" {
32#endif
33
34/*
35 * The following #defines are used to configure the I2C controller.
36 */
37
39#define I2C_SPEED_STANDARD (0x1U)
40
42#define I2C_SPEED_FAST (0x2U)
43
45#define I2C_SPEED_FAST_PLUS (0x3U)
46
48#define I2C_SPEED_HIGH (0x4U)
49
51#define I2C_SPEED_ULTRA (0x5U)
52
54#define I2C_SPEED_DT (0x7U)
55
56#define I2C_SPEED_SHIFT (1U)
57#define I2C_SPEED_SET(speed) (((speed) << I2C_SPEED_SHIFT) \
58 & I2C_SPEED_MASK)
59#define I2C_SPEED_MASK (0x7U << I2C_SPEED_SHIFT) /* 3 bits */
60#define I2C_SPEED_GET(cfg) (((cfg) & I2C_SPEED_MASK) \
61 >> I2C_SPEED_SHIFT)
62
64#define I2C_ADDR_10_BITS BIT(0)
65
67#define I2C_MODE_CONTROLLER BIT(4)
68
76 const struct device *bus;
78};
79
90#define I2C_DT_SPEC_GET_ON_I3C(node_id) \
91 .bus = DEVICE_DT_GET(DT_BUS(node_id)), \
92 .addr = DT_PROP_BY_IDX(node_id, reg, 0)
93
104#define I2C_DT_SPEC_GET_ON_I2C(node_id) \
105 .bus = DEVICE_DT_GET(DT_BUS(node_id)), \
106 .addr = DT_REG_ADDR(node_id)
107
118#define I2C_DT_SPEC_GET(node_id) \
119 { \
120 COND_CODE_1(DT_ON_BUS(node_id, i3c), \
121 (I2C_DT_SPEC_GET_ON_I3C(node_id)), \
122 (I2C_DT_SPEC_GET_ON_I2C(node_id))) \
123 }
124
133#define I2C_DT_SPEC_INST_GET(inst) \
134 I2C_DT_SPEC_GET(DT_DRV_INST(inst))
135
136
137/*
138 * I2C_MSG_* are I2C Message flags.
139 */
140
142#define I2C_MSG_WRITE (0U << 0U)
143
145#define I2C_MSG_READ BIT(0)
146
148#define I2C_MSG_RW_MASK BIT(0)
152#define I2C_MSG_STOP BIT(1)
153
161#define I2C_MSG_RESTART BIT(2)
162
166#define I2C_MSG_ADDR_10_BITS BIT(3)
167
182struct i2c_msg {
185
188
191};
192
200typedef void (*i2c_callback_t)(const struct device *dev, int result, void *data);
201
208struct i2c_target_config;
209
210typedef int (*i2c_api_configure_t)(const struct device *dev,
211 uint32_t dev_config);
212typedef int (*i2c_api_get_config_t)(const struct device *dev,
213 uint32_t *dev_config);
214typedef int (*i2c_api_full_io_t)(const struct device *dev,
215 struct i2c_msg *msgs,
216 uint8_t num_msgs,
217 uint16_t addr);
218typedef int (*i2c_api_target_register_t)(const struct device *dev,
219 struct i2c_target_config *cfg);
220typedef int (*i2c_api_target_unregister_t)(const struct device *dev,
221 struct i2c_target_config *cfg);
222#ifdef CONFIG_I2C_CALLBACK
223typedef int (*i2c_api_transfer_cb_t)(const struct device *dev,
224 struct i2c_msg *msgs,
225 uint8_t num_msgs,
226 uint16_t addr,
228 void *userdata);
229#endif /* CONFIG_I2C_CALLBACK */
230#if defined(CONFIG_I2C_RTIO) || defined(DOXYGEN)
231
236typedef void (*i2c_api_iodev_submit)(const struct device *dev,
237 struct rtio_iodev_sqe *iodev_sqe);
238#endif /* CONFIG_I2C_RTIO */
239
240typedef int (*i2c_api_recover_bus_t)(const struct device *dev);
241
242__subsystem struct i2c_driver_api {
243 i2c_api_configure_t configure;
244 i2c_api_get_config_t get_config;
245 i2c_api_full_io_t transfer;
246 i2c_api_target_register_t target_register;
247 i2c_api_target_unregister_t target_unregister;
248#ifdef CONFIG_I2C_CALLBACK
249 i2c_api_transfer_cb_t transfer_cb;
250#endif
251#ifdef CONFIG_I2C_RTIO
252 i2c_api_iodev_submit iodev_submit;
253#endif
254 i2c_api_recover_bus_t recover_bus;
255};
256
257typedef int (*i2c_target_api_register_t)(const struct device *dev);
258typedef int (*i2c_target_api_unregister_t)(const struct device *dev);
259
260struct i2c_target_driver_api {
261 i2c_target_api_register_t driver_register;
262 i2c_target_api_unregister_t driver_unregister;
263};
264
270#define I2C_TARGET_FLAGS_ADDR_10_BITS BIT(0)
271
288 struct i2c_target_config *config);
289
309 struct i2c_target_config *config, uint8_t val);
310
331 struct i2c_target_config *config, uint8_t *val);
332
353 struct i2c_target_config *config, uint8_t *val);
354
369typedef int (*i2c_target_stop_cb_t)(struct i2c_target_config *config);
370
383};
384
399
402
405
408};
409
418static inline bool i2c_is_ready_dt(const struct i2c_dt_spec *spec)
419{
420 /* Validate bus is ready */
421 return device_is_ready(spec->bus);
422}
423
450void i2c_dump_msgs_rw(const char *name, const struct i2c_msg *msgs,
451 uint8_t num_msgs, uint16_t addr, bool dump_read);
452
467static inline void i2c_dump_msgs(const char *name, const struct i2c_msg *msgs,
468 uint8_t num_msgs, uint16_t addr)
469{
470 i2c_dump_msgs_rw(name, msgs, num_msgs, addr, false);
471}
472
473#if defined(CONFIG_I2C_STATS) || defined(__DOXYGEN__)
474
475#include <zephyr/stats/stats.h>
476
480STATS_SECT_ENTRY32(bytes_read)
481STATS_SECT_ENTRY32(bytes_written)
482STATS_SECT_ENTRY32(message_count)
483STATS_SECT_ENTRY32(transfer_call_count)
485
487STATS_NAME(i2c, bytes_read)
488STATS_NAME(i2c, bytes_written)
489STATS_NAME(i2c, message_count)
490STATS_NAME(i2c, transfer_call_count)
491STATS_NAME_END(i2c);
492
501 struct stats_i2c stats;
502};
503
511static inline void i2c_xfer_stats(const struct device *dev, struct i2c_msg *msgs,
512 uint8_t num_msgs)
513{
514 struct i2c_device_state *state =
516 uint32_t bytes_read = 0U;
517 uint32_t bytes_written = 0U;
518
519 STATS_INC(state->stats, transfer_call_count);
520 STATS_INCN(state->stats, message_count, num_msgs);
521 for (uint8_t i = 0U; i < num_msgs; i++) {
522 if (msgs[i].flags & I2C_MSG_READ) {
523 bytes_read += msgs[i].len;
524 } else {
525 bytes_written += msgs[i].len;
526 }
527 }
528 STATS_INCN(state->stats, bytes_read, bytes_read);
529 STATS_INCN(state->stats, bytes_written, bytes_written);
530}
531
537#define Z_I2C_DEVICE_STATE_DEFINE(dev_id) \
538 static struct i2c_device_state Z_DEVICE_STATE_NAME(dev_id) \
539 __attribute__((__section__(".z_devstate")))
540
547#define Z_I2C_INIT_FN(dev_id, init_fn) \
548 static inline int UTIL_CAT(dev_id, _init)(const struct device *dev) \
549 { \
550 struct i2c_device_state *state = \
551 CONTAINER_OF(dev->state, struct i2c_device_state, devstate); \
552 stats_init(&state->stats.s_hdr, STATS_SIZE_32, 4, \
553 STATS_NAME_INIT_PARMS(i2c)); \
554 stats_register(dev->name, &(state->stats.s_hdr)); \
555 if (init_fn != NULL) { \
556 return init_fn(dev); \
557 } \
558 \
559 return 0; \
560 }
561
591#define I2C_DEVICE_DT_DEFINE(node_id, init_fn, pm, data, config, level, \
592 prio, api, ...) \
593 Z_I2C_DEVICE_STATE_DEFINE(Z_DEVICE_DT_DEV_ID(node_id)); \
594 Z_I2C_INIT_FN(Z_DEVICE_DT_DEV_ID(node_id), init_fn) \
595 Z_DEVICE_DEFINE(node_id, Z_DEVICE_DT_DEV_ID(node_id), \
596 DEVICE_DT_NAME(node_id), \
597 &UTIL_CAT(Z_DEVICE_DT_DEV_ID(node_id), _init), \
598 pm_device, data, config, level, prio, api, \
599 &(Z_DEVICE_STATE_NAME(Z_DEVICE_DT_DEV_ID(node_id)).devstate), \
600 __VA_ARGS__)
601
602#else /* CONFIG_I2C_STATS */
603
604static inline void i2c_xfer_stats(const struct device *dev, struct i2c_msg *msgs,
605 uint8_t num_msgs)
606{
607 ARG_UNUSED(dev);
608 ARG_UNUSED(msgs);
609 ARG_UNUSED(num_msgs);
610}
611
612#define I2C_DEVICE_DT_DEFINE(node_id, init_fn, pm, data, config, level, \
613 prio, api, ...) \
614 DEVICE_DT_DEFINE(node_id, init_fn, pm, data, config, level, \
615 prio, api, __VA_ARGS__)
616
617#endif /* CONFIG_I2C_STATS */
618
627#define I2C_DEVICE_DT_INST_DEFINE(inst, ...) \
628 I2C_DEVICE_DT_DEFINE(DT_DRV_INST(inst), __VA_ARGS__)
629
630
641__syscall int i2c_configure(const struct device *dev, uint32_t dev_config);
642
643static inline int z_impl_i2c_configure(const struct device *dev,
644 uint32_t dev_config)
645{
646 const struct i2c_driver_api *api =
647 (const struct i2c_driver_api *)dev->api;
648
649 return api->configure(dev, dev_config);
650}
651
672__syscall int i2c_get_config(const struct device *dev, uint32_t *dev_config);
673
674static inline int z_impl_i2c_get_config(const struct device *dev, uint32_t *dev_config)
675{
676 const struct i2c_driver_api *api = (const struct i2c_driver_api *)dev->api;
677
678 if (api->get_config == NULL) {
679 return -ENOSYS;
680 }
681
682 return api->get_config(dev, dev_config);
683}
684
712__syscall int i2c_transfer(const struct device *dev,
713 struct i2c_msg *msgs, uint8_t num_msgs,
714 uint16_t addr);
715
716static inline int z_impl_i2c_transfer(const struct device *dev,
717 struct i2c_msg *msgs, uint8_t num_msgs,
718 uint16_t addr)
719{
720 const struct i2c_driver_api *api =
721 (const struct i2c_driver_api *)dev->api;
722
723 int res = api->transfer(dev, msgs, num_msgs, addr);
724
725 i2c_xfer_stats(dev, msgs, num_msgs);
726
727 if (IS_ENABLED(CONFIG_I2C_DUMP_MESSAGES)) {
728 i2c_dump_msgs_rw(dev->name, msgs, num_msgs, addr, true);
729 }
730
731 return res;
732}
733
734#ifdef CONFIG_I2C_CALLBACK
735
758static inline int i2c_transfer_cb(const struct device *dev,
759 struct i2c_msg *msgs,
760 uint8_t num_msgs,
761 uint16_t addr,
763 void *userdata)
764{
765 const struct i2c_driver_api *api = (const struct i2c_driver_api *)dev->api;
766
767 if (api->transfer_cb == NULL) {
768 return -ENOSYS;
769 }
770
771 return api->transfer_cb(dev, msgs, num_msgs, addr, cb, userdata);
772}
773
789static inline int i2c_transfer_cb_dt(const struct i2c_dt_spec *spec,
790 struct i2c_msg *msgs,
791 uint8_t num_msgs,
793 void *userdata)
794{
795 return i2c_transfer_cb(spec->bus, msgs, num_msgs, spec->addr, cb, userdata);
796}
797
821static inline int i2c_write_read_cb(const struct device *dev, struct i2c_msg *msgs,
822 uint8_t num_msgs, uint16_t addr, const void *write_buf,
823 size_t num_write, void *read_buf, size_t num_read,
824 i2c_callback_t cb, void *userdata)
825{
826 if ((msgs == NULL) || (num_msgs != 2)) {
827 return -EINVAL;
828 }
829
830 msgs[0].buf = (uint8_t *)write_buf;
831 msgs[0].len = num_write;
832 msgs[0].flags = I2C_MSG_WRITE;
833
834 msgs[1].buf = (uint8_t *)read_buf;
835 msgs[1].len = num_read;
837
838 return i2c_transfer_cb(dev, msgs, num_msgs, addr, cb, userdata);
839}
840
862static inline int i2c_write_read_cb_dt(const struct i2c_dt_spec *spec, struct i2c_msg *msgs,
863 uint8_t num_msgs, const void *write_buf, size_t num_write,
864 void *read_buf, size_t num_read, i2c_callback_t cb,
865 void *userdata)
866{
867 return i2c_write_read_cb(spec->bus, msgs, num_msgs, spec->addr, write_buf, num_write,
868 read_buf, num_read, cb, userdata);
869}
870
871#ifdef CONFIG_POLL
872
874void z_i2c_transfer_signal_cb(const struct device *dev, int result, void *userdata);
898static inline int i2c_transfer_signal(const struct device *dev,
899 struct i2c_msg *msgs,
900 uint8_t num_msgs,
901 uint16_t addr,
902 struct k_poll_signal *sig)
903{
904 const struct i2c_driver_api *api = (const struct i2c_driver_api *)dev->api;
905
906 if (api->transfer_cb == NULL) {
907 return -ENOSYS;
908 }
909
910 return api->transfer_cb(dev, msgs, num_msgs, addr, z_i2c_transfer_signal_cb, sig);
911}
912
913#endif /* CONFIG_POLL */
914
915#endif /* CONFIG_I2C_CALLBACK */
916
917
918#if defined(CONFIG_I2C_RTIO) || defined(DOXYGEN)
919
926static inline void i2c_iodev_submit(struct rtio_iodev_sqe *iodev_sqe)
927{
928 const struct i2c_dt_spec *dt_spec = iodev_sqe->sqe->iodev->data;
929 const struct device *dev = dt_spec->bus;
930 const struct i2c_driver_api *api = (const struct i2c_driver_api *)dev->api;
931
932 api->iodev_submit(dt_spec->bus, iodev_sqe);
933}
934
935extern const struct rtio_iodev_api i2c_iodev_api;
936
945#define I2C_DT_IODEV_DEFINE(name, node_id) \
946 const struct i2c_dt_spec _i2c_dt_spec_##name = \
947 I2C_DT_SPEC_GET(node_id); \
948 RTIO_IODEV_DEFINE(name, &i2c_iodev_api, (void *)&_i2c_dt_spec_##name)
949
961struct rtio_sqe *i2c_rtio_copy(struct rtio *r,
962 struct rtio_iodev *iodev,
963 const struct i2c_msg *msgs,
964 uint8_t num_msgs);
965
966#endif /* CONFIG_I2C_RTIO */
967
981static inline int i2c_transfer_dt(const struct i2c_dt_spec *spec,
982 struct i2c_msg *msgs, uint8_t num_msgs)
983{
984 return i2c_transfer(spec->bus, msgs, num_msgs, spec->addr);
985}
986
999__syscall int i2c_recover_bus(const struct device *dev);
1000
1001static inline int z_impl_i2c_recover_bus(const struct device *dev)
1002{
1003 const struct i2c_driver_api *api =
1004 (const struct i2c_driver_api *)dev->api;
1005
1006 if (api->recover_bus == NULL) {
1007 return -ENOSYS;
1008 }
1009
1010 return api->recover_bus(dev);
1011}
1012
1037static inline int i2c_target_register(const struct device *dev,
1038 struct i2c_target_config *cfg)
1039{
1040 const struct i2c_driver_api *api =
1041 (const struct i2c_driver_api *)dev->api;
1042
1043 if (api->target_register == NULL) {
1044 return -ENOSYS;
1045 }
1046
1047 return api->target_register(dev, cfg);
1048}
1049
1066static inline int i2c_target_unregister(const struct device *dev,
1067 struct i2c_target_config *cfg)
1068{
1069 const struct i2c_driver_api *api =
1070 (const struct i2c_driver_api *)dev->api;
1071
1072 if (api->target_unregister == NULL) {
1073 return -ENOSYS;
1074 }
1075
1076 return api->target_unregister(dev, cfg);
1077}
1078
1092__syscall int i2c_target_driver_register(const struct device *dev);
1093
1094static inline int z_impl_i2c_target_driver_register(const struct device *dev)
1095{
1096 const struct i2c_target_driver_api *api =
1097 (const struct i2c_target_driver_api *)dev->api;
1098
1099 return api->driver_register(dev);
1100}
1101
1115__syscall int i2c_target_driver_unregister(const struct device *dev);
1116
1117static inline int z_impl_i2c_target_driver_unregister(const struct device *dev)
1118{
1119 const struct i2c_target_driver_api *api =
1120 (const struct i2c_target_driver_api *)dev->api;
1121
1122 return api->driver_unregister(dev);
1123}
1124
1125/*
1126 * Derived i2c APIs -- all implemented in terms of i2c_transfer()
1127 */
1128
1143static inline int i2c_write(const struct device *dev, const uint8_t *buf,
1144 uint32_t num_bytes, uint16_t addr)
1145{
1146 struct i2c_msg msg;
1147
1148 msg.buf = (uint8_t *)buf;
1149 msg.len = num_bytes;
1150 msg.flags = I2C_MSG_WRITE | I2C_MSG_STOP;
1151
1152 return i2c_transfer(dev, &msg, 1, addr);
1153}
1154
1168static inline int i2c_write_dt(const struct i2c_dt_spec *spec,
1169 const uint8_t *buf, uint32_t num_bytes)
1170{
1171 return i2c_write(spec->bus, buf, num_bytes, spec->addr);
1172}
1173
1188static inline int i2c_read(const struct device *dev, uint8_t *buf,
1189 uint32_t num_bytes, uint16_t addr)
1190{
1191 struct i2c_msg msg;
1192
1193 msg.buf = buf;
1194 msg.len = num_bytes;
1195 msg.flags = I2C_MSG_READ | I2C_MSG_STOP;
1196
1197 return i2c_transfer(dev, &msg, 1, addr);
1198}
1199
1213static inline int i2c_read_dt(const struct i2c_dt_spec *spec,
1214 uint8_t *buf, uint32_t num_bytes)
1215{
1216 return i2c_read(spec->bus, buf, num_bytes, spec->addr);
1217}
1218
1237static inline int i2c_write_read(const struct device *dev, uint16_t addr,
1238 const void *write_buf, size_t num_write,
1239 void *read_buf, size_t num_read)
1240{
1241 struct i2c_msg msg[2];
1242
1243 msg[0].buf = (uint8_t *)write_buf;
1244 msg[0].len = num_write;
1245 msg[0].flags = I2C_MSG_WRITE;
1246
1247 msg[1].buf = (uint8_t *)read_buf;
1248 msg[1].len = num_read;
1250
1251 return i2c_transfer(dev, msg, 2, addr);
1252}
1253
1271static inline int i2c_write_read_dt(const struct i2c_dt_spec *spec,
1272 const void *write_buf, size_t num_write,
1273 void *read_buf, size_t num_read)
1274{
1275 return i2c_write_read(spec->bus, spec->addr,
1276 write_buf, num_write,
1277 read_buf, num_read);
1278}
1279
1298static inline int i2c_burst_read(const struct device *dev,
1299 uint16_t dev_addr,
1300 uint8_t start_addr,
1301 uint8_t *buf,
1302 uint32_t num_bytes)
1303{
1304 return i2c_write_read(dev, dev_addr,
1305 &start_addr, sizeof(start_addr),
1306 buf, num_bytes);
1307}
1308
1323static inline int i2c_burst_read_dt(const struct i2c_dt_spec *spec,
1324 uint8_t start_addr,
1325 uint8_t *buf,
1326 uint32_t num_bytes)
1327{
1328 return i2c_burst_read(spec->bus, spec->addr,
1329 start_addr, buf, num_bytes);
1330}
1331
1353static inline int i2c_burst_write(const struct device *dev,
1354 uint16_t dev_addr,
1355 uint8_t start_addr,
1356 const uint8_t *buf,
1357 uint32_t num_bytes)
1358{
1359 struct i2c_msg msg[2];
1360
1361 msg[0].buf = &start_addr;
1362 msg[0].len = 1U;
1363 msg[0].flags = I2C_MSG_WRITE;
1364
1365 msg[1].buf = (uint8_t *)buf;
1366 msg[1].len = num_bytes;
1367 msg[1].flags = I2C_MSG_WRITE | I2C_MSG_STOP;
1368
1369 return i2c_transfer(dev, msg, 2, dev_addr);
1370}
1371
1386static inline int i2c_burst_write_dt(const struct i2c_dt_spec *spec,
1387 uint8_t start_addr,
1388 const uint8_t *buf,
1389 uint32_t num_bytes)
1390{
1391 return i2c_burst_write(spec->bus, spec->addr,
1392 start_addr, buf, num_bytes);
1393}
1394
1410static inline int i2c_reg_read_byte(const struct device *dev,
1411 uint16_t dev_addr,
1412 uint8_t reg_addr, uint8_t *value)
1413{
1414 return i2c_write_read(dev, dev_addr,
1415 &reg_addr, sizeof(reg_addr),
1416 value, sizeof(*value));
1417}
1418
1432static inline int i2c_reg_read_byte_dt(const struct i2c_dt_spec *spec,
1433 uint8_t reg_addr, uint8_t *value)
1434{
1435 return i2c_reg_read_byte(spec->bus, spec->addr, reg_addr, value);
1436}
1437
1456static inline int i2c_reg_write_byte(const struct device *dev,
1457 uint16_t dev_addr,
1458 uint8_t reg_addr, uint8_t value)
1459{
1460 uint8_t tx_buf[2] = {reg_addr, value};
1461
1462 return i2c_write(dev, tx_buf, 2, dev_addr);
1463}
1464
1478static inline int i2c_reg_write_byte_dt(const struct i2c_dt_spec *spec,
1479 uint8_t reg_addr, uint8_t value)
1480{
1481 return i2c_reg_write_byte(spec->bus, spec->addr, reg_addr, value);
1482}
1483
1503static inline int i2c_reg_update_byte(const struct device *dev,
1504 uint8_t dev_addr,
1505 uint8_t reg_addr, uint8_t mask,
1506 uint8_t value)
1507{
1508 uint8_t old_value, new_value;
1509 int rc;
1510
1511 rc = i2c_reg_read_byte(dev, dev_addr, reg_addr, &old_value);
1512 if (rc != 0) {
1513 return rc;
1514 }
1515
1516 new_value = (old_value & ~mask) | (value & mask);
1517 if (new_value == old_value) {
1518 return 0;
1519 }
1520
1521 return i2c_reg_write_byte(dev, dev_addr, reg_addr, new_value);
1522}
1523
1538static inline int i2c_reg_update_byte_dt(const struct i2c_dt_spec *spec,
1539 uint8_t reg_addr, uint8_t mask,
1540 uint8_t value)
1541{
1542 return i2c_reg_update_byte(spec->bus, spec->addr,
1543 reg_addr, mask, value);
1544}
1545
1546#ifdef __cplusplus
1547}
1548#endif
1549
1554#include <syscalls/i2c.h>
1555
1556#endif /* ZEPHYR_INCLUDE_DRIVERS_I2C_H_ */
workaround assembler barfing for ST r
Definition: asm-macro-32-bit-gnu.h:24
struct result result[2]
Definition: errno.c:42
System error numbers.
bool device_is_ready(const struct device *dev)
Verify that a device is ready for use.
int i2c_target_driver_unregister(const struct device *dev)
Instructs the I2C Target device to unregister itself from the I2C Controller.
static int i2c_burst_write_dt(const struct i2c_dt_spec *spec, uint8_t start_addr, const uint8_t *buf, uint32_t num_bytes)
Write multiple bytes to an internal address of an I2C device.
Definition: i2c.h:1386
static int i2c_target_unregister(const struct device *dev, struct i2c_target_config *cfg)
Unregisters the provided config as Target device.
Definition: i2c.h:1066
static int i2c_write_read(const struct device *dev, uint16_t addr, const void *write_buf, size_t num_write, void *read_buf, size_t num_read)
Write then read data from an I2C device.
Definition: i2c.h:1237
int i2c_target_driver_register(const struct device *dev)
Instructs the I2C Target device to register itself to the I2C Controller.
int(* i2c_target_read_requested_cb_t)(struct i2c_target_config *config, uint8_t *val)
Function called when a read from the device is initiated.
Definition: i2c.h:330
int i2c_transfer(const struct device *dev, struct i2c_msg *msgs, uint8_t num_msgs, uint16_t addr)
Perform data transfer to another I2C device in controller mode.
static int i2c_write(const struct device *dev, const uint8_t *buf, uint32_t num_bytes, uint16_t addr)
Write a set amount of data to an I2C device.
Definition: i2c.h:1143
static int i2c_write_dt(const struct i2c_dt_spec *spec, const uint8_t *buf, uint32_t num_bytes)
Write a set amount of data to an I2C device.
Definition: i2c.h:1168
static int i2c_write_read_dt(const struct i2c_dt_spec *spec, const void *write_buf, size_t num_write, void *read_buf, size_t num_read)
Write then read data from an I2C device.
Definition: i2c.h:1271
int(* i2c_target_stop_cb_t)(struct i2c_target_config *config)
Function called when a stop condition is observed after a start condition addressed to a particular d...
Definition: i2c.h:369
void i2c_dump_msgs_rw(const char *name, const struct i2c_msg *msgs, uint8_t num_msgs, uint16_t addr, bool dump_read)
Dump out an I2C message.
static int i2c_burst_read(const struct device *dev, uint16_t dev_addr, uint8_t start_addr, uint8_t *buf, uint32_t num_bytes)
Read multiple bytes from an internal address of an I2C device.
Definition: i2c.h:1298
static void i2c_dump_msgs(const char *name, const struct i2c_msg *msgs, uint8_t num_msgs, uint16_t addr)
Dump out an I2C message, before it is executed.
Definition: i2c.h:467
int(* i2c_target_read_processed_cb_t)(struct i2c_target_config *config, uint8_t *val)
Function called when a read from the device is continued.
Definition: i2c.h:352
int(* i2c_target_write_requested_cb_t)(struct i2c_target_config *config)
Function called when a write to the device is initiated.
Definition: i2c.h:287
static int i2c_reg_update_byte_dt(const struct i2c_dt_spec *spec, uint8_t reg_addr, uint8_t mask, uint8_t value)
Update internal register of an I2C device.
Definition: i2c.h:1538
void(* i2c_callback_t)(const struct device *dev, int result, void *data)
I2C callback for asynchronous transfer requests.
Definition: i2c.h:200
static int i2c_read_dt(const struct i2c_dt_spec *spec, uint8_t *buf, uint32_t num_bytes)
Read a set amount of data from an I2C device.
Definition: i2c.h:1213
int(* i2c_target_write_received_cb_t)(struct i2c_target_config *config, uint8_t val)
Function called when a write to the device is continued.
Definition: i2c.h:308
static int i2c_reg_write_byte_dt(const struct i2c_dt_spec *spec, uint8_t reg_addr, uint8_t value)
Write internal register of an I2C device.
Definition: i2c.h:1478
int i2c_get_config(const struct device *dev, uint32_t *dev_config)
Get configuration of a host controller.
static int i2c_reg_write_byte(const struct device *dev, uint16_t dev_addr, uint8_t reg_addr, uint8_t value)
Write internal register of an I2C device.
Definition: i2c.h:1456
#define I2C_MSG_READ
Definition: i2c.h:145
static int i2c_reg_read_byte_dt(const struct i2c_dt_spec *spec, uint8_t reg_addr, uint8_t *value)
Read internal register of an I2C device.
Definition: i2c.h:1432
int i2c_configure(const struct device *dev, uint32_t dev_config)
Configure operation of a host controller.
#define I2C_MSG_RESTART
Definition: i2c.h:161
static int i2c_transfer_dt(const struct i2c_dt_spec *spec, struct i2c_msg *msgs, uint8_t num_msgs)
Perform data transfer to another I2C device in controller mode.
Definition: i2c.h:981
int i2c_recover_bus(const struct device *dev)
Recover the I2C bus.
static int i2c_read(const struct device *dev, uint8_t *buf, uint32_t num_bytes, uint16_t addr)
Read a set amount of data from an I2C device.
Definition: i2c.h:1188
static int i2c_burst_read_dt(const struct i2c_dt_spec *spec, uint8_t start_addr, uint8_t *buf, uint32_t num_bytes)
Read multiple bytes from an internal address of an I2C device.
Definition: i2c.h:1323
static int i2c_target_register(const struct device *dev, struct i2c_target_config *cfg)
Registers the provided config as Target device of a controller.
Definition: i2c.h:1037
#define I2C_MSG_STOP
Definition: i2c.h:152
static void i2c_xfer_stats(const struct device *dev, struct i2c_msg *msgs, uint8_t num_msgs)
Updates the i2c stats for i2c transfers.
Definition: i2c.h:511
static int i2c_reg_update_byte(const struct device *dev, uint8_t dev_addr, uint8_t reg_addr, uint8_t mask, uint8_t value)
Update internal register of an I2C device.
Definition: i2c.h:1503
#define I2C_MSG_WRITE
Definition: i2c.h:142
static int i2c_reg_read_byte(const struct device *dev, uint16_t dev_addr, uint8_t reg_addr, uint8_t *value)
Read internal register of an I2C device.
Definition: i2c.h:1410
static int i2c_burst_write(const struct device *dev, uint16_t dev_addr, uint8_t start_addr, const uint8_t *buf, uint32_t num_bytes)
Write multiple bytes to an internal address of an I2C device.
Definition: i2c.h:1353
static bool i2c_is_ready_dt(const struct i2c_dt_spec *spec)
Validate that I2C bus is ready.
Definition: i2c.h:418
#define IS_ENABLED(config_macro)
Check for macro definition in compiler-visible expressions.
Definition: util_macro.h:124
#define CONTAINER_OF(ptr, type, field)
Get a pointer to a structure containing the element.
Definition: util.h:224
#define EINVAL
Definition: errno.h:61
#define ENOSYS
Definition: errno.h:83
Public kernel APIs.
flags
Definition: parser.h:96
state
Definition: parser_state.h:29
Real-Time IO device API for moving bytes with low effort.
Single-linked list implementation.
struct _snode sys_snode_t
Definition: slist.h:33
Statistics.
#define STATS_NAME_END(name__)
Definition: stats.h:391
#define STATS_NAME(name__, entry__)
Definition: stats.h:390
#define STATS_SECT_END
Ends a stats group struct definition.
Definition: stats.h:89
#define STATS_SECT_ENTRY32(var__)
Definition: stats.h:359
#define STATS_INC(group__, var__)
Definition: stats.h:364
#define STATS_NAME_START(name__)
Definition: stats.h:389
#define STATS_INCN(group__, var__, n__)
Definition: stats.h:363
#define STATS_SECT_START(group__)
Definition: stats.h:354
__UINT32_TYPE__ uint32_t
Definition: stdint.h:90
__UINT8_TYPE__ uint8_t
Definition: stdint.h:88
__UINT16_TYPE__ uint16_t
Definition: stdint.h:89
Runtime device dynamic structure (in RAM) per driver instance.
Definition: device.h:353
Runtime device structure (in ROM) per driver instance.
Definition: device.h:380
const char * name
Definition: device.h:382
const void * api
Definition: device.h:386
struct device_state * state
Definition: device.h:388
I2C specific device state which allows for i2c device class specific additions.
Definition: i2c.h:499
struct stats_i2c stats
Definition: i2c.h:501
struct device_state devstate
Definition: i2c.h:500
Complete I2C DT information.
Definition: i2c.h:75
const struct device * bus
Definition: i2c.h:76
uint16_t addr
Definition: i2c.h:77
One I2C Message.
Definition: i2c.h:182
uint8_t * buf
Definition: i2c.h:184
uint32_t len
Definition: i2c.h:187
uint8_t flags
Definition: i2c.h:190
Structure providing callbacks to be implemented for devices that supports the I2C target API.
Definition: i2c.h:377
i2c_target_read_requested_cb_t read_requested
Definition: i2c.h:379
i2c_target_write_received_cb_t write_received
Definition: i2c.h:380
i2c_target_read_processed_cb_t read_processed
Definition: i2c.h:381
i2c_target_write_requested_cb_t write_requested
Definition: i2c.h:378
i2c_target_stop_cb_t stop
Definition: i2c.h:382
Structure describing a device that supports the I2C target API.
Definition: i2c.h:396
uint8_t flags
Definition: i2c.h:401
uint16_t address
Definition: i2c.h:404
sys_snode_t node
Definition: i2c.h:398
const struct i2c_target_callbacks * callbacks
Definition: i2c.h:407
Definition: kernel.h:5517
Definition: errno.c:37
API that an RTIO IO device should implement.
Definition: rtio.h:421
Compute the mempool block index for a given pointer.
Definition: rtio.h:411
struct rtio_sqe sqe
Definition: rtio.h:412
An IO device with a function table for submitting requests.
Definition: rtio.h:439
void * data
Definition: rtio.h:447
A submission queue event.
Definition: rtio.h:238
const struct rtio_iodev * iodev
Definition: rtio.h:249
An RTIO context containing what can be viewed as a pair of queues.
Definition: rtio.h:338
static fdata_t data[2]
Definition: test_fifo_contexts.c:15
static void msg(uint64_t c64)
Definition: main.c:17