| /* SPDX-License-Identifier: GPL-2.0-only */ |
| /* CAN driver for PEAK System micro-CAN based adapters |
| * |
| * Copyright (C) 2003-2011 PEAK System-Technik GmbH |
| * Copyright (C) 2011-2013 Stephane Grosjean <s.grosjean@peak-system.com> |
| */ |
| #ifndef PEAK_CANFD_USER_H |
| #define PEAK_CANFD_USER_H |
| |
| #include <linux/can/dev/peak_canfd.h> |
| |
| #define PCANFD_ECHO_SKB_DEF -1 |
| |
| /* data structure private to each uCAN interface */ |
| struct peak_canfd_priv { |
| struct can_priv can; /* socket-can private data */ |
| struct net_device *ndev; /* network device */ |
| int index; /* channel index */ |
| |
| struct can_berr_counter bec; /* rx/tx err counters */ |
| |
| int echo_idx; /* echo skb free slot index */ |
| spinlock_t echo_lock; |
| |
| int cmd_len; |
| void *cmd_buffer; |
| int cmd_maxlen; |
| |
| int (*pre_cmd)(struct peak_canfd_priv *priv); |
| int (*write_cmd)(struct peak_canfd_priv *priv); |
| int (*post_cmd)(struct peak_canfd_priv *priv); |
| |
| int (*enable_tx_path)(struct peak_canfd_priv *priv); |
| void *(*alloc_tx_msg)(struct peak_canfd_priv *priv, u16 msg_size, |
| int *room_left); |
| int (*write_tx_msg)(struct peak_canfd_priv *priv, |
| struct pucan_tx_msg *msg); |
| }; |
| |
| struct net_device *alloc_peak_canfd_dev(int sizeof_priv, int index, |
| int echo_skb_max); |
| int peak_canfd_handle_msg(struct peak_canfd_priv *priv, |
| struct pucan_rx_msg *msg); |
| int peak_canfd_handle_msgs_list(struct peak_canfd_priv *priv, |
| struct pucan_rx_msg *rx_msg, int rx_count); |
| #endif |