9#ifndef ZEPHYR_INCLUDE_DRIVERS_CAN_H_
10#define ZEPHYR_INCLUDE_DRIVERS_CAN_H_
40#define CAN_STD_ID_MASK 0x7FFU
44#define CAN_MAX_STD_ID CAN_STD_ID_MASK
48#define CAN_EXT_ID_MASK 0x1FFFFFFFU
52#define CAN_MAX_EXT_ID CAN_EXT_ID_MASK
60#define CANFD_MAX_DLC 15U
66#ifndef CONFIG_CAN_FD_MODE
67#define CAN_MAX_DLEN 8U
69#define CAN_MAX_DLEN 64U
84#define CAN_MODE_NORMAL 0
87#define CAN_MODE_LOOPBACK BIT(0)
90#define CAN_MODE_LISTENONLY BIT(1)
93#define CAN_MODE_FD BIT(2)
96#define CAN_MODE_ONE_SHOT BIT(3)
99#define CAN_MODE_3_SAMPLES BIT(4)
137#define CAN_FRAME_IDE BIT(0)
140#define CAN_FRAME_RTR BIT(1)
143#define CAN_FRAME_FDF BIT(2)
146#define CAN_FRAME_BRS BIT(3)
151#define CAN_FRAME_ESI BIT(4)
168#if defined(CONFIG_CAN_RX_TIMESTAMP) || defined(__DOXYGEN__)
197#define CAN_FILTER_IDE BIT(0)
200#define CAN_FILTER_RTR BIT(1)
203#define CAN_FILTER_DATA BIT(2)
206#define CAN_FILTER_FDF BIT(3)
240#define CAN_SJW_NO_CHANGE 0
330typedef int (*can_set_timing_t)(
const struct device *dev,
337typedef int (*can_set_timing_data_t)(
const struct device *dev,
344typedef int (*can_get_capabilities_t)(
const struct device *dev,
can_mode_t *cap);
350typedef int (*can_start_t)(
const struct device *dev);
356typedef int (*can_stop_t)(
const struct device *dev);
371typedef int (*can_send_t)(
const struct device *dev,
380typedef int (*can_add_rx_filter_t)(
const struct device *dev,
389typedef void (*can_remove_rx_filter_t)(
const struct device *dev,
int filter_id);
408typedef void(*can_set_state_change_callback_t)(
const struct device *dev,
416typedef int (*can_get_core_clock_t)(
const struct device *dev,
uint32_t *rate);
422typedef int (*can_get_max_filters_t)(
const struct device *dev,
bool ide);
428typedef int (*can_get_max_bitrate_t)(
const struct device *dev,
uint32_t *max_bitrate);
430__subsystem
struct can_driver_api {
431 can_get_capabilities_t get_capabilities;
434 can_set_mode_t set_mode;
435 can_set_timing_t set_timing;
437 can_add_rx_filter_t add_rx_filter;
438 can_remove_rx_filter_t remove_rx_filter;
439#if !defined(CONFIG_CAN_AUTO_BUS_OFF_RECOVERY) || defined(__DOXYGEN__)
440 can_recover_t recover;
442 can_get_state_t get_state;
443 can_set_state_change_callback_t set_state_change_callback;
444 can_get_core_clock_t get_core_clock;
445 can_get_max_filters_t get_max_filters;
446 can_get_max_bitrate_t get_max_bitrate;
451#if defined(CONFIG_CAN_FD_MODE) || defined(__DOXYGEN__)
452 can_set_timing_data_t set_timing_data;
462#if defined(CONFIG_CAN_STATS) || defined(__DOXYGEN__)
504#define Z_CAN_GET_STATS(dev_) \
505 CONTAINER_OF(dev_->state, struct can_device_state, devstate)->stats
517#define CAN_STATS_BIT0_ERROR_INC(dev_) \
518 STATS_INC(Z_CAN_GET_STATS(dev_), bit0_error)
528#define CAN_STATS_BIT1_ERROR_INC(dev_) \
529 STATS_INC(Z_CAN_GET_STATS(dev_), bit1_error)
539#define CAN_STATS_STUFF_ERROR_INC(dev_) \
540 STATS_INC(Z_CAN_GET_STATS(dev_), stuff_error)
550#define CAN_STATS_CRC_ERROR_INC(dev_) \
551 STATS_INC(Z_CAN_GET_STATS(dev_), crc_error)
561#define CAN_STATS_FORM_ERROR_INC(dev_) \
562 STATS_INC(Z_CAN_GET_STATS(dev_), form_error)
572#define CAN_STATS_ACK_ERROR_INC(dev_) \
573 STATS_INC(Z_CAN_GET_STATS(dev_), ack_error)
584#define CAN_STATS_RX_OVERRUN_INC(dev_) \
585 STATS_INC(Z_CAN_GET_STATS(dev_), rx_overrun)
595#define CAN_STATS_RESET(dev_) \
596 stats_reset(&(Z_CAN_GET_STATS(dev_).s_hdr))
603#define Z_CAN_DEVICE_STATE_DEFINE(dev_id) \
604 static struct can_device_state Z_DEVICE_STATE_NAME(dev_id) \
605 __attribute__((__section__(".z_devstate")))
613#define Z_CAN_INIT_FN(dev_id, init_fn) \
614 static inline int UTIL_CAT(dev_id, _init)(const struct device *dev) \
616 struct can_device_state *state = \
617 CONTAINER_OF(dev->state, struct can_device_state, devstate); \
618 stats_init(&state->stats.s_hdr, STATS_SIZE_32, 7, \
619 STATS_NAME_INIT_PARMS(can)); \
620 stats_register(dev->name, &(state->stats.s_hdr)); \
621 if (init_fn != NULL) { \
622 return init_fn(dev); \
650#define CAN_DEVICE_DT_DEFINE(node_id, init_fn, pm, data, config, level, \
652 Z_CAN_DEVICE_STATE_DEFINE(Z_DEVICE_DT_DEV_ID(node_id)); \
653 Z_CAN_INIT_FN(Z_DEVICE_DT_DEV_ID(node_id), init_fn) \
654 Z_DEVICE_DEFINE(node_id, Z_DEVICE_DT_DEV_ID(node_id), \
655 DEVICE_DT_NAME(node_id), \
656 &UTIL_CAT(Z_DEVICE_DT_DEV_ID(node_id), _init), \
657 pm, data, config, level, prio, api, \
658 &(Z_DEVICE_STATE_NAME(Z_DEVICE_DT_DEV_ID(node_id)).devstate), \
663#define CAN_STATS_BIT0_ERROR_INC(dev_)
664#define CAN_STATS_BIT1_ERROR_INC(dev_)
665#define CAN_STATS_STUFF_ERROR_INC(dev_)
666#define CAN_STATS_CRC_ERROR_INC(dev_)
667#define CAN_STATS_FORM_ERROR_INC(dev_)
668#define CAN_STATS_ACK_ERROR_INC(dev_)
669#define CAN_STATS_RX_OVERRUN_INC(dev_)
670#define CAN_STATS_RESET(dev_)
672#define CAN_DEVICE_DT_DEFINE(node_id, init_fn, pm, data, config, level, \
674 DEVICE_DT_DEFINE(node_id, init_fn, pm, data, config, level, \
675 prio, api, __VA_ARGS__)
686#define CAN_DEVICE_DT_INST_DEFINE(inst, ...) \
687 CAN_DEVICE_DT_DEFINE(DT_DRV_INST(inst), __VA_ARGS__)
707static inline int z_impl_can_get_core_clock(
const struct device *dev,
uint32_t *rate)
709 const struct can_driver_api *api = (
const struct can_driver_api *)dev->
api;
711 return api->get_core_clock(dev, rate);
728static inline int z_impl_can_get_max_bitrate(
const struct device *dev,
uint32_t *max_bitrate)
730 const struct can_driver_api *api = (
const struct can_driver_api *)dev->
api;
732 if (api->get_max_bitrate == NULL) {
736 return api->get_max_bitrate(dev, max_bitrate);
748static inline const struct can_timing *z_impl_can_get_timing_min(
const struct device *dev)
750 const struct can_driver_api *api = (
const struct can_driver_api *)dev->
api;
752 return &api->timing_min;
764static inline const struct can_timing *z_impl_can_get_timing_max(
const struct device *dev)
766 const struct can_driver_api *api = (
const struct can_driver_api *)dev->
api;
768 return &api->timing_max;
810#ifdef CONFIG_CAN_FD_MODE
811static inline const struct can_timing *z_impl_can_get_timing_data_min(
const struct device *dev)
813 const struct can_driver_api *api = (
const struct can_driver_api *)dev->
api;
815 return &api->timing_data_min;
834#ifdef CONFIG_CAN_FD_MODE
835static inline const struct can_timing *z_impl_can_get_timing_data_max(
const struct device *dev)
837 const struct can_driver_api *api = (
const struct can_driver_api *)dev->
api;
839 return &api->timing_data_max;
969static inline int z_impl_can_get_capabilities(
const struct device *dev,
can_mode_t *cap)
971 const struct can_driver_api *api = (
const struct can_driver_api *)dev->
api;
973 return api->get_capabilities(dev, cap);
993static inline int z_impl_can_start(
const struct device *dev)
995 const struct can_driver_api *api = (
const struct can_driver_api *)dev->
api;
997 return api->start(dev);
1017static inline int z_impl_can_stop(
const struct device *dev)
1019 const struct can_driver_api *api = (
const struct can_driver_api *)dev->
api;
1021 return api->stop(dev);
1036static inline int z_impl_can_set_mode(
const struct device *dev,
can_mode_t mode)
1038 const struct can_driver_api *api = (
const struct can_driver_api *)dev->
api;
1040 return api->set_mode(dev, mode);
1160 const struct can_driver_api *api = (
const struct can_driver_api *)dev->
api;
1166 return api->add_rx_filter(dev, callback,
user_data, filter);
1179#define CAN_MSGQ_DEFINE(name, max_frames) \
1180 K_MSGQ_DEFINE(name, sizeof(struct can_frame), max_frames, 4)
1222static inline void z_impl_can_remove_rx_filter(
const struct device *dev,
int filter_id)
1224 const struct can_driver_api *api = (
const struct can_driver_api *)dev->
api;
1226 return api->remove_rx_filter(dev, filter_id);
1244static inline int z_impl_can_get_max_filters(
const struct device *dev,
bool ide)
1246 const struct can_driver_api *api = (
const struct can_driver_api *)dev->
api;
1248 if (api->get_max_filters == NULL) {
1252 return api->get_max_filters(dev, ide);
1282 const struct can_driver_api *api = (
const struct can_driver_api *)dev->
api;
1284 return api->get_state(dev,
state, err_cnt);
1302#if !defined(CONFIG_CAN_AUTO_BUS_OFF_RECOVERY) || defined(__DOXYGEN__)
1307 const struct can_driver_api *api = (
const struct can_driver_api *)dev->
api;
1309 return api->recover(dev,
timeout);
1338 const struct can_driver_api *api = (
const struct can_driver_api *)dev->
api;
1340 api->set_state_change_callback(dev, callback,
user_data);
1360 static const uint8_t dlc_table[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 12,
1361 16, 20, 24, 32, 48, 64};
1363 return dlc > 0x0F ? 64 : dlc_table[dlc];
1375 return num_bytes <= 8 ? num_bytes :
1376 num_bytes <= 12 ? 9 :
1377 num_bytes <= 16 ? 10 :
1378 num_bytes <= 20 ? 11 :
1379 num_bytes <= 24 ? 12 :
1380 num_bytes <= 32 ? 13 :
1381 num_bytes <= 48 ? 14 :
1425 if ((frame->
id ^ filter->
id) & filter->
mask) {
1443#include <syscalls/can.h>
ZTEST_BMEM int timeout
Definition: main.c:31
static ssize_t send(int sock, const void *buf, size_t len, int flags)
Definition: socket.h:738
void(* can_state_change_callback_t)(const struct device *dev, enum can_state state, struct can_bus_err_cnt err_cnt, void *user_data)
Defines the state change callback handler function signature.
Definition: can.h:315
int can_set_bitrate(const struct device *dev, uint32_t bitrate)
Set the bitrate of the CAN controller.
int can_set_bitrate_data(const struct device *dev, uint32_t bitrate_data)
Set the bitrate for the data phase of the CAN-FD controller.
uint32_t can_mode_t
Provides a type to hold CAN controller configuration flags.
Definition: can.h:111
static int can_add_rx_filter(const struct device *dev, can_rx_callback_t callback, void *user_data, const struct can_filter *filter)
Add a callback function for a given CAN filter.
Definition: can.h:1157
#define CAN_FILTER_FDF
Definition: can.h:206
int can_stop(const struct device *dev)
Stop the CAN controller.
int can_set_timing(const struct device *dev, const struct can_timing *timing)
Configure the bus timing of a CAN controller.
#define CAN_FRAME_FDF
Definition: can.h:143
int can_calc_timing_data(const struct device *dev, struct can_timing *res, uint32_t bitrate, uint16_t sample_pnt)
Calculate timing parameters for the data phase.
int can_send(const struct device *dev, const struct can_frame *frame, k_timeout_t timeout, can_tx_callback_t callback, void *user_data)
Queue a CAN frame for transmission on the CAN bus.
const struct can_timing * can_get_timing_data_max(const struct device *dev)
Get the maximum supported timing parameter values for the data phase.
int can_get_core_clock(const struct device *dev, uint32_t *rate)
Get the CAN core clock rate.
int can_get_capabilities(const struct device *dev, can_mode_t *cap)
Get the supported modes of the CAN controller.
int can_get_max_filters(const struct device *dev, bool ide)
Get maximum number of RX filters.
const struct can_timing * can_get_timing_min(const struct device *dev)
Get the minimum supported timing parameter values.
int can_set_timing_data(const struct device *dev, const struct can_timing *timing_data)
Configure the bus timing for the data phase of a CAN-FD controller.
const struct can_timing * can_get_timing_data_min(const struct device *dev)
Get the minimum supported timing parameter values for the data phase.
int can_calc_prescaler(const struct device *dev, struct can_timing *timing, uint32_t bitrate)
Fill in the prescaler value for a given bitrate and timing.
void can_remove_rx_filter(const struct device *dev, int filter_id)
Remove a CAN RX filter.
static uint8_t can_bytes_to_dlc(uint8_t num_bytes)
Convert from number of bytes to Data Length Code (DLC)
Definition: can.h:1373
int can_get_max_bitrate(const struct device *dev, uint32_t *max_bitrate)
Get maximum supported bitrate.
#define CAN_FILTER_RTR
Definition: can.h:200
#define CAN_FRAME_IDE
Definition: can.h:137
static uint8_t can_dlc_to_bytes(uint8_t dlc)
Convert from Data Length Code (DLC) to the number of data bytes.
Definition: can.h:1358
#define CAN_FILTER_DATA
Definition: can.h:203
int can_add_rx_filter_msgq(const struct device *dev, struct k_msgq *msgq, const struct can_filter *filter)
Simple wrapper function for adding a message queue for a given filter.
void(* can_rx_callback_t)(const struct device *dev, struct can_frame *frame, void *user_data)
Defines the application callback handler function signature for receiving.
Definition: can.h:304
static bool can_frame_matches_filter(const struct can_frame *frame, const struct can_filter *filter)
Check if a CAN frame matches a CAN filter.
Definition: can.h:1392
void(* can_tx_callback_t)(const struct device *dev, int error, void *user_data)
Defines the application callback handler function signature.
Definition: can.h:295
int can_get_state(const struct device *dev, enum can_state *state, struct can_bus_err_cnt *err_cnt)
Get current CAN controller state.
const struct can_timing * can_get_timing_max(const struct device *dev)
Get the maximum supported timing parameter values.
int can_calc_timing(const struct device *dev, struct can_timing *res, uint32_t bitrate, uint16_t sample_pnt)
Calculate timing parameters from bitrate and sample point.
int can_recover(const struct device *dev, k_timeout_t timeout)
Recover from bus-off state.
can_state
Defines the state of the CAN controller.
Definition: can.h:116
static void can_set_state_change_callback(const struct device *dev, can_state_change_callback_t callback, void *user_data)
Set a callback for CAN controller state change events.
Definition: can.h:1334
int can_set_mode(const struct device *dev, can_mode_t mode)
Set the CAN controller to the given operation mode.
int can_start(const struct device *dev)
Start the CAN controller.
#define CAN_FRAME_RTR
Definition: can.h:140
#define CAN_FILTER_IDE
Definition: can.h:197
@ CAN_STATE_ERROR_ACTIVE
Definition: can.h:118
@ CAN_STATE_ERROR_WARNING
Definition: can.h:120
@ CAN_STATE_STOPPED
Definition: can.h:126
@ CAN_STATE_BUS_OFF
Definition: can.h:124
@ CAN_STATE_ERROR_PASSIVE
Definition: can.h:122
#define DIV_ROUND_UP(n, d)
Divide and round up.
Definition: util.h:262
#define EINVAL
Definition: errno.h:61
#define ENOSYS
Definition: errno.h:83
Variables needed for system clock.
struct k_msgq msgq
Definition: test_msgq_contexts.c:12
state
Definition: parser_state.h:29
#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_NAME_START(name__)
Definition: stats.h:389
#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
CAN controller error counters.
Definition: can.h:230
uint8_t tx_err_cnt
Definition: can.h:232
uint8_t rx_err_cnt
Definition: can.h:234
CAN specific device state which allows for CAN device class specific additions.
Definition: can.h:494
struct device_state devstate
Definition: can.h:495
struct stats_can stats
Definition: can.h:496
CAN filter structure.
Definition: can.h:213
uint32_t mask
Definition: can.h:222
uint8_t flags
Definition: can.h:224
uint32_t id
Definition: can.h:215
CAN frame structure.
Definition: can.h:158
uint8_t dlc
Definition: can.h:165
uint8_t flags
Definition: can.h:167
uint32_t id
Definition: can.h:160
uint8_t data[CAN_MAX_DLEN]
Definition: can.h:184
uint32_t data_32[DIV_ROUND_UP(CAN_MAX_DLEN, sizeof(uint32_t))]
Definition: can.h:185
uint16_t timestamp
Definition: can.h:176
CAN bus timing structure.
Definition: can.h:274
uint16_t sjw
Definition: can.h:276
uint16_t phase_seg2
Definition: can.h:282
uint16_t prescaler
Definition: can.h:284
uint16_t phase_seg1
Definition: can.h:280
uint16_t prop_seg
Definition: can.h:278
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 void * api
Definition: device.h:386
Message Queue Structure.
Definition: kernel.h:4306
Kernel timeout type.
Definition: sys_clock.h:65
static const intptr_t user_data[5]
Definition: main.c:588