1
2
3
4
5
6
7#include <linux/atomic.h>
8#include <linux/netdevice.h>
9#include <linux/ktime.h>
10#include <linux/mutex.h>
11#include <linux/spinlock.h>
12#include <linux/can.h>
13#include <linux/can/dev.h>
14
15#include "softing_platform.h"
16
17struct softing;
18
19struct softing_priv {
20 struct can_priv can;
21 struct net_device *netdev;
22 struct softing *card;
23 struct {
24 int pending;
25
26 int echo_put;
27 int echo_get;
28 } tx;
29 struct can_bittiming_const btr_const;
30 int index;
31 uint8_t output;
32 uint16_t chip;
33};
34#define netdev2softing(netdev) ((struct softing_priv *)netdev_priv(netdev))
35
36struct softing {
37 const struct softing_platform_data *pdat;
38 struct platform_device *pdev;
39 struct net_device *net[2];
40 spinlock_t spin;
41 ktime_t ts_ref;
42 ktime_t ts_overflow;
43
44 struct {
45
46 int up;
47
48 struct mutex lock;
49 } fw;
50 struct {
51 int nr;
52 int requested;
53 int svc_count;
54 unsigned int dpram_position;
55 } irq;
56 struct {
57 int pending;
58 int last_bus;
59
60
61
62
63 } tx;
64 __iomem uint8_t *dpram;
65 unsigned long dpram_phys;
66 unsigned long dpram_size;
67 struct {
68 uint16_t fw_version, hw_version, license, serial;
69 uint16_t chip[2];
70 unsigned int freq;
71 } id;
72};
73
74extern int softing_default_output(struct net_device *netdev);
75
76extern ktime_t softing_raw2ktime(struct softing *card, u32 raw);
77
78extern int softing_chip_poweron(struct softing *card);
79
80extern int softing_bootloader_command(struct softing *card, int16_t cmd,
81 const char *msg);
82
83
84extern int softing_load_fw(const char *file, struct softing *card,
85 __iomem uint8_t *virt, unsigned int size, int offset);
86
87
88extern int softing_load_app_fw(const char *file, struct softing *card);
89
90
91
92
93
94extern int softing_enable_irq(struct softing *card, int enable);
95
96
97extern int softing_startstop(struct net_device *netdev, int up);
98
99
100extern int softing_netdev_rx(struct net_device *netdev,
101 const struct can_frame *msg, ktime_t ktime);
102
103
104#define DPRAM_RX 0x0000
105 #define DPRAM_RX_SIZE 32
106 #define DPRAM_RX_CNT 16
107#define DPRAM_RX_RD 0x0201
108#define DPRAM_RX_WR 0x0205
109#define DPRAM_RX_LOST 0x0207
110
111#define DPRAM_FCT_PARAM 0x0300
112#define DPRAM_FCT_RESULT 0x0328
113#define DPRAM_FCT_HOST 0x032b
114
115#define DPRAM_INFO_BUSSTATE 0x0331
116#define DPRAM_INFO_BUSSTATE2 0x0335
117#define DPRAM_INFO_ERRSTATE 0x0339
118#define DPRAM_INFO_ERRSTATE2 0x033d
119#define DPRAM_RESET 0x0341
120#define DPRAM_CLR_RECV_FIFO 0x0345
121#define DPRAM_RESET_TIME 0x034d
122#define DPRAM_TIME 0x0350
123#define DPRAM_WR_START 0x0358
124#define DPRAM_WR_END 0x0359
125#define DPRAM_RESET_RX_FIFO 0x0361
126#define DPRAM_RESET_TX_FIFO 0x0364
127#define DPRAM_READ_FIFO_LEVEL 0x0365
128#define DPRAM_RX_FIFO_LEVEL 0x0366
129#define DPRAM_TX_FIFO_LEVEL 0x0366
130
131#define DPRAM_TX 0x0400
132 #define DPRAM_TX_SIZE 16
133 #define DPRAM_TX_CNT 32
134#define DPRAM_TX_RD 0x0601
135#define DPRAM_TX_WR 0x0605
136
137#define DPRAM_COMMAND 0x07e0
138#define DPRAM_RECEIPT 0x07f0
139#define DPRAM_IRQ_TOHOST 0x07fe
140#define DPRAM_IRQ_TOCARD 0x07ff
141
142#define DPRAM_V2_RESET 0x0e00
143#define DPRAM_V2_IRQ_TOHOST 0x0e02
144
145#define TXMAX (DPRAM_TX_CNT - 1)
146
147
148#define RES_NONE 0
149#define RES_OK 1
150#define RES_NOK 2
151#define RES_UNKNOWN 3
152
153#define CMD_TX 0x01
154#define CMD_ACK 0x02
155#define CMD_XTD 0x04
156#define CMD_RTR 0x08
157#define CMD_ERR 0x10
158#define CMD_BUS2 0x80
159
160
161#define SF_MASK_BUSOFF 0x80
162#define SF_MASK_EPASSIVE 0x60
163
164
165#define STATE_BUSOFF 2
166#define STATE_EPASSIVE 1
167#define STATE_EACTIVE 0
168