drivers: can: remove deprecated APIs
Remove the CAN APIs deprecated in Zephyr v3.0.0. Signed-off-by: Henrik Brix Andersen <hebad@vestas.com>
This commit is contained in:
parent
da2a0befbb
commit
cf1879bfac
3 changed files with 1 additions and 345 deletions
|
@ -75,13 +75,6 @@ config CAN_INIT_PRIORITY
|
|||
Note that the priority needs to be lower than the net stack
|
||||
so that it can start before the networking sub-system.
|
||||
|
||||
config CAN_WORKQ_FRAMES_BUF_CNT
|
||||
int "Work queue buffer frame count (DEPRECATED)"
|
||||
default 4
|
||||
range 1 65534
|
||||
help
|
||||
Number of frames in the buffer of a zcan_work.
|
||||
|
||||
config CAN_RX_TIMESTAMP
|
||||
bool "Enable receiving timestamps"
|
||||
depends on CAN_HAS_RX_TIMESTAMP
|
||||
|
|
|
@ -11,21 +11,9 @@
|
|||
|
||||
LOG_MODULE_REGISTER(can_common, CONFIG_CAN_LOG_LEVEL);
|
||||
|
||||
/* CAN sync segment is always one time quantum */
|
||||
#define CAN_SYNC_SEG 1
|
||||
|
||||
#define WORK_BUF_COUNT_IS_POWER_OF_2 !(CONFIG_CAN_WORKQ_FRAMES_BUF_CNT & \
|
||||
(CONFIG_CAN_WORKQ_FRAMES_BUF_CNT - 1))
|
||||
|
||||
#define WORK_BUF_MOD_MASK (CONFIG_CAN_WORKQ_FRAMES_BUF_CNT - 1)
|
||||
|
||||
#if WORK_BUF_COUNT_IS_POWER_OF_2
|
||||
#define WORK_BUF_MOD_SIZE(x) ((x) & WORK_BUF_MOD_MASK)
|
||||
#else
|
||||
#define WORK_BUF_MOD_SIZE(x) ((x) % CONFIG_CAN_WORKQ_FRAMES_BUF_CNT)
|
||||
#endif
|
||||
|
||||
#define WORK_BUF_FULL 0xFFFF
|
||||
|
||||
static void can_msgq_put(struct zcan_frame *frame, void *arg)
|
||||
{
|
||||
struct k_msgq *msgq = (struct k_msgq *)arg;
|
||||
|
@ -47,102 +35,6 @@ int z_impl_can_add_rx_filter_msgq(const struct device *dev, struct k_msgq *msgq,
|
|||
return api->add_rx_filter(dev, can_msgq_put, msgq, filter);
|
||||
}
|
||||
|
||||
static inline void can_work_buffer_init(struct can_frame_buffer *buffer)
|
||||
{
|
||||
buffer->head = 0;
|
||||
buffer->tail = 0;
|
||||
}
|
||||
|
||||
static inline int can_work_buffer_put(struct zcan_frame *frame,
|
||||
struct can_frame_buffer *buffer)
|
||||
{
|
||||
uint16_t next_head = WORK_BUF_MOD_SIZE(buffer->head + 1);
|
||||
|
||||
if (buffer->head == WORK_BUF_FULL) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
buffer->buf[buffer->head] = *frame;
|
||||
|
||||
/* Buffer is almost full */
|
||||
if (next_head == buffer->tail) {
|
||||
buffer->head = WORK_BUF_FULL;
|
||||
} else {
|
||||
buffer->head = next_head;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static inline
|
||||
struct zcan_frame *can_work_buffer_get_next(struct can_frame_buffer *buffer)
|
||||
{
|
||||
/* Buffer empty */
|
||||
if (buffer->head == buffer->tail) {
|
||||
return NULL;
|
||||
} else {
|
||||
return &buffer->buf[buffer->tail];
|
||||
}
|
||||
}
|
||||
|
||||
static inline void can_work_buffer_free_next(struct can_frame_buffer *buffer)
|
||||
{
|
||||
uint16_t next_tail = WORK_BUF_MOD_SIZE(buffer->tail + 1);
|
||||
|
||||
if (buffer->head == buffer->tail) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (buffer->head == WORK_BUF_FULL) {
|
||||
buffer->head = buffer->tail;
|
||||
}
|
||||
|
||||
buffer->tail = next_tail;
|
||||
}
|
||||
|
||||
static void can_work_handler(struct k_work *work)
|
||||
{
|
||||
struct zcan_work *can_work = CONTAINER_OF(work, struct zcan_work,
|
||||
work_item);
|
||||
struct zcan_frame *frame;
|
||||
|
||||
while ((frame = can_work_buffer_get_next(&can_work->buf))) {
|
||||
can_work->cb(frame, can_work->cb_arg);
|
||||
can_work_buffer_free_next(&can_work->buf);
|
||||
}
|
||||
}
|
||||
|
||||
static void can_work_isr_put(struct zcan_frame *frame, void *arg)
|
||||
{
|
||||
struct zcan_work *work = (struct zcan_work *)arg;
|
||||
int ret;
|
||||
|
||||
ret = can_work_buffer_put(frame, &work->buf);
|
||||
if (ret) {
|
||||
LOG_ERR("Workq buffer overflow. Frame ID: 0x%x", frame->id);
|
||||
return;
|
||||
}
|
||||
|
||||
k_work_submit_to_queue(work->work_queue, &work->work_item);
|
||||
}
|
||||
|
||||
int can_attach_workq(const struct device *dev, struct k_work_q *work_q,
|
||||
struct zcan_work *work,
|
||||
can_rx_callback_t callback, void *user_data,
|
||||
const struct zcan_filter *filter)
|
||||
{
|
||||
const struct can_driver_api *api = dev->api;
|
||||
|
||||
k_work_init(&work->work_item, can_work_handler);
|
||||
work->work_queue = work_q;
|
||||
work->cb = callback;
|
||||
work->cb_arg = user_data;
|
||||
can_work_buffer_init(&work->buf);
|
||||
|
||||
return api->add_rx_filter(dev, can_work_isr_put, work, filter);
|
||||
}
|
||||
|
||||
|
||||
static int update_sampling_pnt(uint32_t ts, uint32_t sp, struct can_timing *res,
|
||||
const struct can_timing *max,
|
||||
const struct can_timing *min)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue