2019-05-29 22:17:59 +08:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
2017-01-19 23:31:07 +08:00
|
|
|
/*
|
|
|
|
* 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
|