2 * Socket CAN driver for Aeroflex Gaisler GRCAN and GRHCAN.
4 * 2012 (c) Aeroflex Gaisler AB
6 * This driver supports GRCAN and GRHCAN CAN controllers available in the GRLIB
7 * VHDL IP core library.
9 * Full documentation of the GRCAN core can be found here:
10 * http://www.gaisler.com/products/grlib/grip.pdf
12 * See "Documentation/devicetree/bindings/net/can/grcan.txt" for information on
13 * open firmware properties.
15 * See "Documentation/ABI/testing/sysfs-class-net-grcan" for information on the
18 * See "Documentation/kernel-parameters.txt" for information on the module
21 * This program is free software; you can redistribute it and/or modify it
22 * under the terms of the GNU General Public License as published by the
23 * Free Software Foundation; either version 2 of the License, or (at your
24 * option) any later version.
26 * Contributors: Andreas Larsson <andreas@gaisler.com>
29 #include <linux/kernel.h>
30 #include <linux/module.h>
31 #include <linux/interrupt.h>
32 #include <linux/netdevice.h>
33 #include <linux/delay.h>
35 #include <linux/can/dev.h>
36 #include <linux/spinlock.h>
38 #include <linux/of_platform.h>
41 #include <linux/of_irq.h>
43 #include <linux/dma-mapping.h>
45 #define DRV_NAME "grcan"
47 #define GRCAN_NAPI_WEIGHT 32
49 #define GRCAN_RESERVE_SIZE(slot1, slot2) (((slot2) - (slot1)) / 4 - 1)
51 struct grcan_registers
{
55 u32 __reserved1
[GRCAN_RESERVE_SIZE(0x08, 0x18)];
56 u32 smask
; /* 0x18 - CanMASK */
57 u32 scode
; /* 0x1c - CanCODE */
58 u32 __reserved2
[GRCAN_RESERVE_SIZE(0x1c, 0x100)];
59 u32 pimsr
; /* 0x100 */
65 u32 __reserved3
[GRCAN_RESERVE_SIZE(0x114, 0x200)];
66 u32 txctrl
; /* 0x200 */
67 u32 txaddr
; /* 0x204 */
68 u32 txsize
; /* 0x208 */
71 u32 txirq
; /* 0x214 */
72 u32 __reserved4
[GRCAN_RESERVE_SIZE(0x214, 0x300)];
73 u32 rxctrl
; /* 0x300 */
74 u32 rxaddr
; /* 0x304 */
75 u32 rxsize
; /* 0x308 */
78 u32 rxirq
; /* 0x314 */
79 u32 rxmask
; /* 0x318 */
80 u32 rxcode
; /* 0x31C */
83 #define GRCAN_CONF_ABORT 0x00000001
84 #define GRCAN_CONF_ENABLE0 0x00000002
85 #define GRCAN_CONF_ENABLE1 0x00000004
86 #define GRCAN_CONF_SELECT 0x00000008
87 #define GRCAN_CONF_SILENT 0x00000010
88 #define GRCAN_CONF_SAM 0x00000020 /* Available in some hardware */
89 #define GRCAN_CONF_BPR 0x00000300 /* Note: not BRP */
90 #define GRCAN_CONF_RSJ 0x00007000
91 #define GRCAN_CONF_PS1 0x00f00000
92 #define GRCAN_CONF_PS2 0x000f0000
93 #define GRCAN_CONF_SCALER 0xff000000
94 #define GRCAN_CONF_OPERATION \
95 (GRCAN_CONF_ABORT | GRCAN_CONF_ENABLE0 | GRCAN_CONF_ENABLE1 \
96 | GRCAN_CONF_SELECT | GRCAN_CONF_SILENT | GRCAN_CONF_SAM)
97 #define GRCAN_CONF_TIMING \
98 (GRCAN_CONF_BPR | GRCAN_CONF_RSJ | GRCAN_CONF_PS1 \
99 | GRCAN_CONF_PS2 | GRCAN_CONF_SCALER)
101 #define GRCAN_CONF_RSJ_MIN 1
102 #define GRCAN_CONF_RSJ_MAX 4
103 #define GRCAN_CONF_PS1_MIN 1
104 #define GRCAN_CONF_PS1_MAX 15
105 #define GRCAN_CONF_PS2_MIN 2
106 #define GRCAN_CONF_PS2_MAX 8
107 #define GRCAN_CONF_SCALER_MIN 0
108 #define GRCAN_CONF_SCALER_MAX 255
109 #define GRCAN_CONF_SCALER_INC 1
111 #define GRCAN_CONF_BPR_BIT 8
112 #define GRCAN_CONF_RSJ_BIT 12
113 #define GRCAN_CONF_PS1_BIT 20
114 #define GRCAN_CONF_PS2_BIT 16
115 #define GRCAN_CONF_SCALER_BIT 24
117 #define GRCAN_STAT_PASS 0x000001
118 #define GRCAN_STAT_OFF 0x000002
119 #define GRCAN_STAT_OR 0x000004
120 #define GRCAN_STAT_AHBERR 0x000008
121 #define GRCAN_STAT_ACTIVE 0x000010
122 #define GRCAN_STAT_RXERRCNT 0x00ff00
123 #define GRCAN_STAT_TXERRCNT 0xff0000
125 #define GRCAN_STAT_ERRCTR_RELATED (GRCAN_STAT_PASS | GRCAN_STAT_OFF)
127 #define GRCAN_STAT_RXERRCNT_BIT 8
128 #define GRCAN_STAT_TXERRCNT_BIT 16
130 #define GRCAN_STAT_ERRCNT_WARNING_LIMIT 96
131 #define GRCAN_STAT_ERRCNT_PASSIVE_LIMIT 127
133 #define GRCAN_CTRL_RESET 0x2
134 #define GRCAN_CTRL_ENABLE 0x1
136 #define GRCAN_TXCTRL_ENABLE 0x1
137 #define GRCAN_TXCTRL_ONGOING 0x2
138 #define GRCAN_TXCTRL_SINGLE 0x4
140 #define GRCAN_RXCTRL_ENABLE 0x1
141 #define GRCAN_RXCTRL_ONGOING 0x2
143 /* Relative offset of IRQ sources to AMBA Plug&Play */
144 #define GRCAN_IRQIX_IRQ 0
145 #define GRCAN_IRQIX_TXSYNC 1
146 #define GRCAN_IRQIX_RXSYNC 2
148 #define GRCAN_IRQ_PASS 0x00001
149 #define GRCAN_IRQ_OFF 0x00002
150 #define GRCAN_IRQ_OR 0x00004
151 #define GRCAN_IRQ_RXAHBERR 0x00008
152 #define GRCAN_IRQ_TXAHBERR 0x00010
153 #define GRCAN_IRQ_RXIRQ 0x00020
154 #define GRCAN_IRQ_TXIRQ 0x00040
155 #define GRCAN_IRQ_RXFULL 0x00080
156 #define GRCAN_IRQ_TXEMPTY 0x00100
157 #define GRCAN_IRQ_RX 0x00200
158 #define GRCAN_IRQ_TX 0x00400
159 #define GRCAN_IRQ_RXSYNC 0x00800
160 #define GRCAN_IRQ_TXSYNC 0x01000
161 #define GRCAN_IRQ_RXERRCTR 0x02000
162 #define GRCAN_IRQ_TXERRCTR 0x04000
163 #define GRCAN_IRQ_RXMISS 0x08000
164 #define GRCAN_IRQ_TXLOSS 0x10000
166 #define GRCAN_IRQ_NONE 0
167 #define GRCAN_IRQ_ALL \
168 (GRCAN_IRQ_PASS | GRCAN_IRQ_OFF | GRCAN_IRQ_OR \
169 | GRCAN_IRQ_RXAHBERR | GRCAN_IRQ_TXAHBERR \
170 | GRCAN_IRQ_RXIRQ | GRCAN_IRQ_TXIRQ \
171 | GRCAN_IRQ_RXFULL | GRCAN_IRQ_TXEMPTY \
172 | GRCAN_IRQ_RX | GRCAN_IRQ_TX | GRCAN_IRQ_RXSYNC \
173 | GRCAN_IRQ_TXSYNC | GRCAN_IRQ_RXERRCTR \
174 | GRCAN_IRQ_TXERRCTR | GRCAN_IRQ_RXMISS \
177 #define GRCAN_IRQ_ERRCTR_RELATED (GRCAN_IRQ_RXERRCTR | GRCAN_IRQ_TXERRCTR \
178 | GRCAN_IRQ_PASS | GRCAN_IRQ_OFF)
179 #define GRCAN_IRQ_ERRORS (GRCAN_IRQ_ERRCTR_RELATED | GRCAN_IRQ_OR \
180 | GRCAN_IRQ_TXAHBERR | GRCAN_IRQ_RXAHBERR \
182 #define GRCAN_IRQ_DEFAULT (GRCAN_IRQ_RX | GRCAN_IRQ_TX | GRCAN_IRQ_ERRORS)
184 #define GRCAN_MSG_SIZE 16
186 #define GRCAN_MSG_IDE 0x80000000
187 #define GRCAN_MSG_RTR 0x40000000
188 #define GRCAN_MSG_BID 0x1ffc0000
189 #define GRCAN_MSG_EID 0x1fffffff
190 #define GRCAN_MSG_IDE_BIT 31
191 #define GRCAN_MSG_RTR_BIT 30
192 #define GRCAN_MSG_BID_BIT 18
193 #define GRCAN_MSG_EID_BIT 0
195 #define GRCAN_MSG_DLC 0xf0000000
196 #define GRCAN_MSG_TXERRC 0x00ff0000
197 #define GRCAN_MSG_RXERRC 0x0000ff00
198 #define GRCAN_MSG_DLC_BIT 28
199 #define GRCAN_MSG_TXERRC_BIT 16
200 #define GRCAN_MSG_RXERRC_BIT 8
201 #define GRCAN_MSG_AHBERR 0x00000008
202 #define GRCAN_MSG_OR 0x00000004
203 #define GRCAN_MSG_OFF 0x00000002
204 #define GRCAN_MSG_PASS 0x00000001
206 #define GRCAN_MSG_DATA_SLOT_INDEX(i) (2 + (i) / 4)
207 #define GRCAN_MSG_DATA_SHIFT(i) ((3 - (i) % 4) * 8)
209 #define GRCAN_BUFFER_ALIGNMENT 1024
210 #define GRCAN_DEFAULT_BUFFER_SIZE 1024
211 #define GRCAN_VALID_TR_SIZE_MASK 0x001fffc0
213 #define GRCAN_INVALID_BUFFER_SIZE(s) \
214 ((s) == 0 || ((s) & ~GRCAN_VALID_TR_SIZE_MASK))
216 #if GRCAN_INVALID_BUFFER_SIZE(GRCAN_DEFAULT_BUFFER_SIZE)
217 #error "Invalid default buffer size"
220 struct grcan_dma_buffer
{
229 dma_addr_t base_handle
;
230 struct grcan_dma_buffer tx
;
231 struct grcan_dma_buffer rx
;
234 /* GRCAN configuration parameters */
235 struct grcan_device_config
{
236 unsigned short enable0
;
237 unsigned short enable1
;
238 unsigned short select
;
243 #define GRCAN_DEFAULT_DEVICE_CONFIG { \
247 .txsize = GRCAN_DEFAULT_BUFFER_SIZE, \
248 .rxsize = GRCAN_DEFAULT_BUFFER_SIZE, \
251 #define GRCAN_TXBUG_SAFE_GRLIB_VERSION 0x4100
252 #define GRLIB_VERSION_MASK 0xffff
254 /* GRCAN private data structure */
256 struct can_priv can
; /* must be the first member */
257 struct net_device
*dev
;
258 struct napi_struct napi
;
260 struct grcan_registers __iomem
*regs
; /* ioremap'ed registers */
261 struct grcan_device_config config
;
262 struct grcan_dma dma
;
264 struct sk_buff
**echo_skb
; /* We allocate this on our own */
265 u8
*txdlc
; /* Length of queued frames */
267 /* The echo skb pointer, pointing into echo_skb and indicating which
268 * frames can be echoed back. See the "Notes on the tx cyclic buffer
269 * handling"-comment for grcan_start_xmit for more details.
273 /* Lock for controlling changes to the netif tx queue state, accesses to
274 * the echo_skb pointer eskbp and for making sure that a running reset
275 * and/or a close of the interface is done without interference from
276 * other parts of the code.
278 * The echo_skb pointer, eskbp, should only be accessed under this lock
279 * as it can be changed in several places and together with decisions on
280 * whether to wake up the tx queue.
282 * The tx queue must never be woken up if there is a running reset or
285 * A running reset (see below on need_txbug_workaround) should never be
286 * done if the interface is closing down and several running resets
287 * should never be scheduled simultaneously.
291 /* Whether a workaround is needed due to a bug in older hardware. In
292 * this case, the driver both tries to prevent the bug from being
293 * triggered and recovers, if the bug nevertheless happens, by doing a
294 * running reset. A running reset, resets the device and continues from
295 * where it were without being noticeable from outside the driver (apart
296 * from slight delays).
298 bool need_txbug_workaround
;
300 /* To trigger initization of running reset and to trigger running reset
301 * respectively in the case of a hanged device due to a txbug.
303 struct timer_list hang_timer
;
304 struct timer_list rr_timer
;
306 /* To avoid waking up the netif queue and restarting timers
307 * when a reset is scheduled or when closing of the device is
314 /* Wait time for a short wait for ongoing to clear */
315 #define GRCAN_SHORTWAIT_USECS 10
317 /* Limit on the number of transmitted bits of an eff frame according to the CAN
318 * specification: 1 bit start of frame, 32 bits arbitration field, 6 bits
319 * control field, 8 bytes data field, 16 bits crc field, 2 bits ACK field and 7
322 #define GRCAN_EFF_FRAME_MAX_BITS (1+32+6+8*8+16+2+7)
324 #if defined(__BIG_ENDIAN)
325 static inline u32
grcan_read_reg(u32 __iomem
*reg
)
327 return ioread32be(reg
);
330 static inline void grcan_write_reg(u32 __iomem
*reg
, u32 val
)
332 iowrite32be(val
, reg
);
335 static inline u32
grcan_read_reg(u32 __iomem
*reg
)
337 return ioread32(reg
);
340 static inline void grcan_write_reg(u32 __iomem
*reg
, u32 val
)
346 static inline void grcan_clear_bits(u32 __iomem
*reg
, u32 mask
)
348 grcan_write_reg(reg
, grcan_read_reg(reg
) & ~mask
);
351 static inline void grcan_set_bits(u32 __iomem
*reg
, u32 mask
)
353 grcan_write_reg(reg
, grcan_read_reg(reg
) | mask
);
356 static inline u32
grcan_read_bits(u32 __iomem
*reg
, u32 mask
)
358 return grcan_read_reg(reg
) & mask
;
361 static inline void grcan_write_bits(u32 __iomem
*reg
, u32 value
, u32 mask
)
363 u32 old
= grcan_read_reg(reg
);
365 grcan_write_reg(reg
, (old
& ~mask
) | (value
& mask
));
368 /* a and b should both be in [0,size] and a == b == size should not hold */
369 static inline u32
grcan_ring_add(u32 a
, u32 b
, u32 size
)
379 /* a and b should both be in [0,size) */
380 static inline u32
grcan_ring_sub(u32 a
, u32 b
, u32 size
)
382 return grcan_ring_add(a
, size
- b
, size
);
385 /* Available slots for new transmissions */
386 static inline u32
grcan_txspace(size_t txsize
, u32 txwr
, u32 eskbp
)
388 u32 slots
= txsize
/ GRCAN_MSG_SIZE
- 1;
389 u32 used
= grcan_ring_sub(txwr
, eskbp
, txsize
) / GRCAN_MSG_SIZE
;
394 /* Configuration parameters that can be set via module parameters */
395 static struct grcan_device_config grcan_module_config
=
396 GRCAN_DEFAULT_DEVICE_CONFIG
;
398 static const struct can_bittiming_const grcan_bittiming_const
= {
400 .tseg1_min
= GRCAN_CONF_PS1_MIN
+ 1,
401 .tseg1_max
= GRCAN_CONF_PS1_MAX
+ 1,
402 .tseg2_min
= GRCAN_CONF_PS2_MIN
,
403 .tseg2_max
= GRCAN_CONF_PS2_MAX
,
404 .sjw_max
= GRCAN_CONF_RSJ_MAX
,
405 .brp_min
= GRCAN_CONF_SCALER_MIN
+ 1,
406 .brp_max
= GRCAN_CONF_SCALER_MAX
+ 1,
407 .brp_inc
= GRCAN_CONF_SCALER_INC
,
410 static int grcan_set_bittiming(struct net_device
*dev
)
412 struct grcan_priv
*priv
= netdev_priv(dev
);
413 struct grcan_registers __iomem
*regs
= priv
->regs
;
414 struct can_bittiming
*bt
= &priv
->can
.bittiming
;
416 int bpr
, rsj
, ps1
, ps2
, scaler
;
418 /* Should never happen - function will not be called when
421 if (grcan_read_bits(®s
->ctrl
, GRCAN_CTRL_ENABLE
))
424 bpr
= 0; /* Note bpr and brp are different concepts */
426 ps1
= (bt
->prop_seg
+ bt
->phase_seg1
) - 1; /* tseg1 - 1 */
427 ps2
= bt
->phase_seg2
;
428 scaler
= (bt
->brp
- 1);
429 netdev_dbg(dev
, "Request for BPR=%d, RSJ=%d, PS1=%d, PS2=%d, SCALER=%d",
430 bpr
, rsj
, ps1
, ps2
, scaler
);
432 netdev_err(dev
, "PS1 > PS2 must hold: PS1=%d, PS2=%d\n",
437 netdev_err(dev
, "PS2 >= RSJ must hold: PS2=%d, RSJ=%d\n",
442 timing
|= (bpr
<< GRCAN_CONF_BPR_BIT
) & GRCAN_CONF_BPR
;
443 timing
|= (rsj
<< GRCAN_CONF_RSJ_BIT
) & GRCAN_CONF_RSJ
;
444 timing
|= (ps1
<< GRCAN_CONF_PS1_BIT
) & GRCAN_CONF_PS1
;
445 timing
|= (ps2
<< GRCAN_CONF_PS2_BIT
) & GRCAN_CONF_PS2
;
446 timing
|= (scaler
<< GRCAN_CONF_SCALER_BIT
) & GRCAN_CONF_SCALER
;
447 netdev_info(dev
, "setting timing=0x%x\n", timing
);
448 grcan_write_bits(®s
->conf
, timing
, GRCAN_CONF_TIMING
);
453 static int grcan_get_berr_counter(const struct net_device
*dev
,
454 struct can_berr_counter
*bec
)
456 struct grcan_priv
*priv
= netdev_priv(dev
);
457 struct grcan_registers __iomem
*regs
= priv
->regs
;
458 u32 status
= grcan_read_reg(®s
->stat
);
460 bec
->txerr
= (status
& GRCAN_STAT_TXERRCNT
) >> GRCAN_STAT_TXERRCNT_BIT
;
461 bec
->rxerr
= (status
& GRCAN_STAT_RXERRCNT
) >> GRCAN_STAT_RXERRCNT_BIT
;
465 static int grcan_poll(struct napi_struct
*napi
, int budget
);
467 /* Reset device, but keep configuration information */
468 static void grcan_reset(struct net_device
*dev
)
470 struct grcan_priv
*priv
= netdev_priv(dev
);
471 struct grcan_registers __iomem
*regs
= priv
->regs
;
472 u32 config
= grcan_read_reg(®s
->conf
);
474 grcan_set_bits(®s
->ctrl
, GRCAN_CTRL_RESET
);
475 grcan_write_reg(®s
->conf
, config
);
477 priv
->eskbp
= grcan_read_reg(®s
->txrd
);
478 priv
->can
.state
= CAN_STATE_STOPPED
;
480 /* Turn off hardware filtering - regs->rxcode set to 0 by reset */
481 grcan_write_reg(®s
->rxmask
, 0);
484 /* stop device without changing any configurations */
485 static void grcan_stop_hardware(struct net_device
*dev
)
487 struct grcan_priv
*priv
= netdev_priv(dev
);
488 struct grcan_registers __iomem
*regs
= priv
->regs
;
490 grcan_write_reg(®s
->imr
, GRCAN_IRQ_NONE
);
491 grcan_clear_bits(®s
->txctrl
, GRCAN_TXCTRL_ENABLE
);
492 grcan_clear_bits(®s
->rxctrl
, GRCAN_RXCTRL_ENABLE
);
493 grcan_clear_bits(®s
->ctrl
, GRCAN_CTRL_ENABLE
);
496 /* Let priv->eskbp catch up to regs->txrd and echo back the skbs if echo
497 * is true and free them otherwise.
499 * If budget is >= 0, stop after handling at most budget skbs. Otherwise,
500 * continue until priv->eskbp catches up to regs->txrd.
502 * priv->lock *must* be held when calling this function
504 static int catch_up_echo_skb(struct net_device
*dev
, int budget
, bool echo
)
506 struct grcan_priv
*priv
= netdev_priv(dev
);
507 struct grcan_registers __iomem
*regs
= priv
->regs
;
508 struct grcan_dma
*dma
= &priv
->dma
;
509 struct net_device_stats
*stats
= &dev
->stats
;
512 /* Updates to priv->eskbp and wake-ups of the queue needs to
513 * be atomic towards the reads of priv->eskbp and shut-downs
514 * of the queue in grcan_start_xmit.
516 u32 txrd
= grcan_read_reg(®s
->txrd
);
518 for (work_done
= 0; work_done
< budget
|| budget
< 0; work_done
++) {
519 if (priv
->eskbp
== txrd
)
521 i
= priv
->eskbp
/ GRCAN_MSG_SIZE
;
523 /* Normal echo of messages */
525 stats
->tx_bytes
+= priv
->txdlc
[i
];
527 can_get_echo_skb(dev
, i
);
529 /* For cleanup of untransmitted messages */
530 can_free_echo_skb(dev
, i
);
533 priv
->eskbp
= grcan_ring_add(priv
->eskbp
, GRCAN_MSG_SIZE
,
535 txrd
= grcan_read_reg(®s
->txrd
);
540 static void grcan_lost_one_shot_frame(struct net_device
*dev
)
542 struct grcan_priv
*priv
= netdev_priv(dev
);
543 struct grcan_registers __iomem
*regs
= priv
->regs
;
544 struct grcan_dma
*dma
= &priv
->dma
;
548 spin_lock_irqsave(&priv
->lock
, flags
);
550 catch_up_echo_skb(dev
, -1, true);
552 if (unlikely(grcan_read_bits(®s
->txctrl
, GRCAN_TXCTRL_ENABLE
))) {
553 /* Should never happen */
554 netdev_err(dev
, "TXCTRL enabled at TXLOSS in one shot mode\n");
556 /* By the time an GRCAN_IRQ_TXLOSS is generated in
557 * one-shot mode there is no problem in writing
558 * to TXRD even in versions of the hardware in
559 * which GRCAN_TXCTRL_ONGOING is not cleared properly
563 /* Skip message and discard echo-skb */
564 txrd
= grcan_read_reg(®s
->txrd
);
565 txrd
= grcan_ring_add(txrd
, GRCAN_MSG_SIZE
, dma
->tx
.size
);
566 grcan_write_reg(®s
->txrd
, txrd
);
567 catch_up_echo_skb(dev
, -1, false);
569 if (!priv
->resetting
&& !priv
->closing
&&
570 !(priv
->can
.ctrlmode
& CAN_CTRLMODE_LISTENONLY
)) {
571 netif_wake_queue(dev
);
572 grcan_set_bits(®s
->txctrl
, GRCAN_TXCTRL_ENABLE
);
576 spin_unlock_irqrestore(&priv
->lock
, flags
);
579 static void grcan_err(struct net_device
*dev
, u32 sources
, u32 status
)
581 struct grcan_priv
*priv
= netdev_priv(dev
);
582 struct grcan_registers __iomem
*regs
= priv
->regs
;
583 struct grcan_dma
*dma
= &priv
->dma
;
584 struct net_device_stats
*stats
= &dev
->stats
;
587 /* Zero potential error_frame */
588 memset(&cf
, 0, sizeof(cf
));
590 /* Message lost interrupt. This might be due to arbitration error, but
591 * is also triggered when there is no one else on the can bus or when
592 * there is a problem with the hardware interface or the bus itself. As
593 * arbitration errors can not be singled out, no error frames are
594 * generated reporting this event as an arbitration error.
596 if (sources
& GRCAN_IRQ_TXLOSS
) {
597 /* Take care of failed one-shot transmit */
598 if (priv
->can
.ctrlmode
& CAN_CTRLMODE_ONE_SHOT
)
599 grcan_lost_one_shot_frame(dev
);
601 /* Stop printing as soon as error passive or bus off is in
602 * effect to limit the amount of txloss debug printouts.
604 if (!(status
& GRCAN_STAT_ERRCTR_RELATED
)) {
605 netdev_dbg(dev
, "tx message lost\n");
610 /* Conditions dealing with the error counters. There is no interrupt for
611 * error warning, but there are interrupts for increases of the error
614 if ((sources
& GRCAN_IRQ_ERRCTR_RELATED
) ||
615 (status
& GRCAN_STAT_ERRCTR_RELATED
)) {
616 enum can_state state
= priv
->can
.state
;
617 enum can_state oldstate
= state
;
618 u32 txerr
= (status
& GRCAN_STAT_TXERRCNT
)
619 >> GRCAN_STAT_TXERRCNT_BIT
;
620 u32 rxerr
= (status
& GRCAN_STAT_RXERRCNT
)
621 >> GRCAN_STAT_RXERRCNT_BIT
;
623 /* Figure out current state */
624 if (status
& GRCAN_STAT_OFF
) {
625 state
= CAN_STATE_BUS_OFF
;
626 } else if (status
& GRCAN_STAT_PASS
) {
627 state
= CAN_STATE_ERROR_PASSIVE
;
628 } else if (txerr
>= GRCAN_STAT_ERRCNT_WARNING_LIMIT
||
629 rxerr
>= GRCAN_STAT_ERRCNT_WARNING_LIMIT
) {
630 state
= CAN_STATE_ERROR_WARNING
;
632 state
= CAN_STATE_ERROR_ACTIVE
;
635 /* Handle and report state changes */
636 if (state
!= oldstate
) {
638 case CAN_STATE_BUS_OFF
:
639 netdev_dbg(dev
, "bus-off\n");
640 netif_carrier_off(dev
);
641 priv
->can
.can_stats
.bus_off
++;
643 /* Prevent the hardware from recovering from bus
644 * off on its own if restart is disabled.
646 if (!priv
->can
.restart_ms
)
647 grcan_stop_hardware(dev
);
649 cf
.can_id
|= CAN_ERR_BUSOFF
;
652 case CAN_STATE_ERROR_PASSIVE
:
653 netdev_dbg(dev
, "Error passive condition\n");
654 priv
->can
.can_stats
.error_passive
++;
656 cf
.can_id
|= CAN_ERR_CRTL
;
657 if (txerr
>= GRCAN_STAT_ERRCNT_PASSIVE_LIMIT
)
658 cf
.data
[1] |= CAN_ERR_CRTL_TX_PASSIVE
;
659 if (rxerr
>= GRCAN_STAT_ERRCNT_PASSIVE_LIMIT
)
660 cf
.data
[1] |= CAN_ERR_CRTL_RX_PASSIVE
;
663 case CAN_STATE_ERROR_WARNING
:
664 netdev_dbg(dev
, "Error warning condition\n");
665 priv
->can
.can_stats
.error_warning
++;
667 cf
.can_id
|= CAN_ERR_CRTL
;
668 if (txerr
>= GRCAN_STAT_ERRCNT_WARNING_LIMIT
)
669 cf
.data
[1] |= CAN_ERR_CRTL_TX_WARNING
;
670 if (rxerr
>= GRCAN_STAT_ERRCNT_WARNING_LIMIT
)
671 cf
.data
[1] |= CAN_ERR_CRTL_RX_WARNING
;
674 case CAN_STATE_ERROR_ACTIVE
:
675 netdev_dbg(dev
, "Error active condition\n");
676 cf
.can_id
|= CAN_ERR_CRTL
;
680 /* There are no others at this point */
685 priv
->can
.state
= state
;
688 /* Report automatic restarts */
689 if (priv
->can
.restart_ms
&& oldstate
== CAN_STATE_BUS_OFF
) {
692 cf
.can_id
|= CAN_ERR_RESTARTED
;
693 netdev_dbg(dev
, "restarted\n");
694 priv
->can
.can_stats
.restarts
++;
695 netif_carrier_on(dev
);
697 spin_lock_irqsave(&priv
->lock
, flags
);
699 if (!priv
->resetting
&& !priv
->closing
) {
700 u32 txwr
= grcan_read_reg(®s
->txwr
);
702 if (grcan_txspace(dma
->tx
.size
, txwr
,
704 netif_wake_queue(dev
);
707 spin_unlock_irqrestore(&priv
->lock
, flags
);
711 /* Data overrun interrupt */
712 if ((sources
& GRCAN_IRQ_OR
) || (status
& GRCAN_STAT_OR
)) {
713 netdev_dbg(dev
, "got data overrun interrupt\n");
714 stats
->rx_over_errors
++;
717 cf
.can_id
|= CAN_ERR_CRTL
;
718 cf
.data
[1] |= CAN_ERR_CRTL_RX_OVERFLOW
;
721 /* AHB bus error interrupts (not CAN bus errors) - shut down the
724 if (sources
& (GRCAN_IRQ_TXAHBERR
| GRCAN_IRQ_RXAHBERR
) ||
725 (status
& GRCAN_STAT_AHBERR
)) {
729 if (sources
& GRCAN_IRQ_TXAHBERR
) {
732 } else if (sources
& GRCAN_IRQ_RXAHBERR
) {
736 netdev_err(dev
, "Fatal AHB buss error %s- halting device\n",
739 spin_lock_irqsave(&priv
->lock
, flags
);
741 /* Prevent anything to be enabled again and halt device */
742 priv
->closing
= true;
743 netif_stop_queue(dev
);
744 grcan_stop_hardware(dev
);
745 priv
->can
.state
= CAN_STATE_STOPPED
;
747 spin_unlock_irqrestore(&priv
->lock
, flags
);
750 /* Pass on error frame if something to report,
751 * i.e. id contains some information
754 struct can_frame
*skb_cf
;
755 struct sk_buff
*skb
= alloc_can_err_skb(dev
, &skb_cf
);
758 netdev_dbg(dev
, "could not allocate error frame\n");
761 skb_cf
->can_id
|= cf
.can_id
;
762 memcpy(skb_cf
->data
, cf
.data
, sizeof(cf
.data
));
768 static irqreturn_t
grcan_interrupt(int irq
, void *dev_id
)
770 struct net_device
*dev
= dev_id
;
771 struct grcan_priv
*priv
= netdev_priv(dev
);
772 struct grcan_registers __iomem
*regs
= priv
->regs
;
775 /* Find out the source */
776 sources
= grcan_read_reg(®s
->pimsr
);
779 grcan_write_reg(®s
->picr
, sources
);
780 status
= grcan_read_reg(®s
->stat
);
782 /* If we got TX progress, the device has not hanged,
783 * so disable the hang timer
785 if (priv
->need_txbug_workaround
&&
786 (sources
& (GRCAN_IRQ_TX
| GRCAN_IRQ_TXLOSS
))) {
787 del_timer(&priv
->hang_timer
);
790 /* Frame(s) received or transmitted */
791 if (sources
& (GRCAN_IRQ_TX
| GRCAN_IRQ_RX
)) {
792 /* Disable tx/rx interrupts and schedule poll(). No need for
793 * locking as interference from a running reset at worst leads
794 * to an extra interrupt.
796 grcan_clear_bits(®s
->imr
, GRCAN_IRQ_TX
| GRCAN_IRQ_RX
);
797 napi_schedule(&priv
->napi
);
800 /* (Potential) error conditions to take care of */
801 if (sources
& GRCAN_IRQ_ERRORS
)
802 grcan_err(dev
, sources
, status
);
807 /* Reset device and restart operations from where they were.
809 * This assumes that RXCTRL & RXCTRL is properly disabled and that RX
810 * is not ONGOING (TX might be stuck in ONGOING due to a harwrware bug
813 static void grcan_running_reset(unsigned long data
)
815 struct net_device
*dev
= (struct net_device
*)data
;
816 struct grcan_priv
*priv
= netdev_priv(dev
);
817 struct grcan_registers __iomem
*regs
= priv
->regs
;
820 /* This temporarily messes with eskbp, so we need to lock
823 spin_lock_irqsave(&priv
->lock
, flags
);
825 priv
->resetting
= false;
826 del_timer(&priv
->hang_timer
);
827 del_timer(&priv
->rr_timer
);
829 if (!priv
->closing
) {
830 /* Save and reset - config register preserved by grcan_reset */
831 u32 imr
= grcan_read_reg(®s
->imr
);
833 u32 txaddr
= grcan_read_reg(®s
->txaddr
);
834 u32 txsize
= grcan_read_reg(®s
->txsize
);
835 u32 txwr
= grcan_read_reg(®s
->txwr
);
836 u32 txrd
= grcan_read_reg(®s
->txrd
);
837 u32 eskbp
= priv
->eskbp
;
839 u32 rxaddr
= grcan_read_reg(®s
->rxaddr
);
840 u32 rxsize
= grcan_read_reg(®s
->rxsize
);
841 u32 rxwr
= grcan_read_reg(®s
->rxwr
);
842 u32 rxrd
= grcan_read_reg(®s
->rxrd
);
847 grcan_write_reg(®s
->txaddr
, txaddr
);
848 grcan_write_reg(®s
->txsize
, txsize
);
849 grcan_write_reg(®s
->txwr
, txwr
);
850 grcan_write_reg(®s
->txrd
, txrd
);
853 grcan_write_reg(®s
->rxaddr
, rxaddr
);
854 grcan_write_reg(®s
->rxsize
, rxsize
);
855 grcan_write_reg(®s
->rxwr
, rxwr
);
856 grcan_write_reg(®s
->rxrd
, rxrd
);
858 /* Turn on device again */
859 grcan_write_reg(®s
->imr
, imr
);
860 priv
->can
.state
= CAN_STATE_ERROR_ACTIVE
;
861 grcan_write_reg(®s
->txctrl
, GRCAN_TXCTRL_ENABLE
862 | (priv
->can
.ctrlmode
& CAN_CTRLMODE_ONE_SHOT
863 ? GRCAN_TXCTRL_SINGLE
: 0));
864 grcan_write_reg(®s
->rxctrl
, GRCAN_RXCTRL_ENABLE
);
865 grcan_write_reg(®s
->ctrl
, GRCAN_CTRL_ENABLE
);
867 /* Start queue if there is size and listen-onle mode is not
870 if (grcan_txspace(priv
->dma
.tx
.size
, txwr
, priv
->eskbp
) &&
871 !(priv
->can
.ctrlmode
& CAN_CTRLMODE_LISTENONLY
))
872 netif_wake_queue(dev
);
875 spin_unlock_irqrestore(&priv
->lock
, flags
);
877 netdev_err(dev
, "Device reset and restored\n");
880 /* Waiting time in usecs corresponding to the transmission of three maximum
881 * sized can frames in the given bitrate (in bits/sec). Waiting for this amount
882 * of time makes sure that the can controller have time to finish sending or
883 * receiving a frame with a good margin.
885 * usecs/sec * number of frames * bits/frame / bits/sec
887 static inline u32
grcan_ongoing_wait_usecs(__u32 bitrate
)
889 return 1000000 * 3 * GRCAN_EFF_FRAME_MAX_BITS
/ bitrate
;
892 /* Set timer so that it will not fire until after a period in which the can
893 * controller have a good margin to finish transmitting a frame unless it has
896 static inline void grcan_reset_timer(struct timer_list
*timer
, __u32 bitrate
)
898 u32 wait_jiffies
= usecs_to_jiffies(grcan_ongoing_wait_usecs(bitrate
));
900 mod_timer(timer
, jiffies
+ wait_jiffies
);
903 /* Disable channels and schedule a running reset */
904 static void grcan_initiate_running_reset(unsigned long data
)
906 struct net_device
*dev
= (struct net_device
*)data
;
907 struct grcan_priv
*priv
= netdev_priv(dev
);
908 struct grcan_registers __iomem
*regs
= priv
->regs
;
911 netdev_err(dev
, "Device seems hanged - reset scheduled\n");
913 spin_lock_irqsave(&priv
->lock
, flags
);
915 /* The main body of this function must never be executed again
916 * until after an execution of grcan_running_reset
918 if (!priv
->resetting
&& !priv
->closing
) {
919 priv
->resetting
= true;
920 netif_stop_queue(dev
);
921 grcan_clear_bits(®s
->txctrl
, GRCAN_TXCTRL_ENABLE
);
922 grcan_clear_bits(®s
->rxctrl
, GRCAN_RXCTRL_ENABLE
);
923 grcan_reset_timer(&priv
->rr_timer
, priv
->can
.bittiming
.bitrate
);
926 spin_unlock_irqrestore(&priv
->lock
, flags
);
929 static void grcan_free_dma_buffers(struct net_device
*dev
)
931 struct grcan_priv
*priv
= netdev_priv(dev
);
932 struct grcan_dma
*dma
= &priv
->dma
;
934 dma_free_coherent(&dev
->dev
, dma
->base_size
, dma
->base_buf
,
936 memset(dma
, 0, sizeof(*dma
));
939 static int grcan_allocate_dma_buffers(struct net_device
*dev
,
940 size_t tsize
, size_t rsize
)
942 struct grcan_priv
*priv
= netdev_priv(dev
);
943 struct grcan_dma
*dma
= &priv
->dma
;
944 struct grcan_dma_buffer
*large
= rsize
> tsize
? &dma
->rx
: &dma
->tx
;
945 struct grcan_dma_buffer
*small
= rsize
> tsize
? &dma
->tx
: &dma
->rx
;
948 /* Need a whole number of GRCAN_BUFFER_ALIGNMENT for the large,
951 size_t maxs
= max(tsize
, rsize
);
952 size_t lsize
= ALIGN(maxs
, GRCAN_BUFFER_ALIGNMENT
);
954 /* Put the small buffer after that */
955 size_t ssize
= min(tsize
, rsize
);
957 /* Extra GRCAN_BUFFER_ALIGNMENT to allow for alignment */
958 dma
->base_size
= lsize
+ ssize
+ GRCAN_BUFFER_ALIGNMENT
;
959 dma
->base_buf
= dma_alloc_coherent(&dev
->dev
,
967 dma
->tx
.size
= tsize
;
968 dma
->rx
.size
= rsize
;
970 large
->handle
= ALIGN(dma
->base_handle
, GRCAN_BUFFER_ALIGNMENT
);
971 small
->handle
= large
->handle
+ lsize
;
972 shift
= large
->handle
- dma
->base_handle
;
974 large
->buf
= dma
->base_buf
+ shift
;
975 small
->buf
= large
->buf
+ lsize
;
980 /* priv->lock *must* be held when calling this function */
981 static int grcan_start(struct net_device
*dev
)
983 struct grcan_priv
*priv
= netdev_priv(dev
);
984 struct grcan_registers __iomem
*regs
= priv
->regs
;
989 grcan_write_reg(®s
->txaddr
, priv
->dma
.tx
.handle
);
990 grcan_write_reg(®s
->txsize
, priv
->dma
.tx
.size
);
991 /* regs->txwr, regs->txrd and priv->eskbp already set to 0 by reset */
993 grcan_write_reg(®s
->rxaddr
, priv
->dma
.rx
.handle
);
994 grcan_write_reg(®s
->rxsize
, priv
->dma
.rx
.size
);
995 /* regs->rxwr and regs->rxrd already set to 0 by reset */
997 /* Enable interrupts */
998 grcan_read_reg(®s
->pir
);
999 grcan_write_reg(®s
->imr
, GRCAN_IRQ_DEFAULT
);
1001 /* Enable interfaces, channels and device */
1002 confop
= GRCAN_CONF_ABORT
1003 | (priv
->config
.enable0
? GRCAN_CONF_ENABLE0
: 0)
1004 | (priv
->config
.enable1
? GRCAN_CONF_ENABLE1
: 0)
1005 | (priv
->config
.select
? GRCAN_CONF_SELECT
: 0)
1006 | (priv
->can
.ctrlmode
& CAN_CTRLMODE_LISTENONLY
?
1007 GRCAN_CONF_SILENT
: 0)
1008 | (priv
->can
.ctrlmode
& CAN_CTRLMODE_3_SAMPLES
?
1009 GRCAN_CONF_SAM
: 0);
1010 grcan_write_bits(®s
->conf
, confop
, GRCAN_CONF_OPERATION
);
1011 txctrl
= GRCAN_TXCTRL_ENABLE
1012 | (priv
->can
.ctrlmode
& CAN_CTRLMODE_ONE_SHOT
1013 ? GRCAN_TXCTRL_SINGLE
: 0);
1014 grcan_write_reg(®s
->txctrl
, txctrl
);
1015 grcan_write_reg(®s
->rxctrl
, GRCAN_RXCTRL_ENABLE
);
1016 grcan_write_reg(®s
->ctrl
, GRCAN_CTRL_ENABLE
);
1018 priv
->can
.state
= CAN_STATE_ERROR_ACTIVE
;
1023 static int grcan_set_mode(struct net_device
*dev
, enum can_mode mode
)
1025 struct grcan_priv
*priv
= netdev_priv(dev
);
1026 unsigned long flags
;
1029 if (mode
== CAN_MODE_START
) {
1030 /* This might be called to restart the device to recover from
1033 spin_lock_irqsave(&priv
->lock
, flags
);
1034 if (priv
->closing
|| priv
->resetting
) {
1037 netdev_info(dev
, "Restarting device\n");
1039 if (!(priv
->can
.ctrlmode
& CAN_CTRLMODE_LISTENONLY
))
1040 netif_wake_queue(dev
);
1042 spin_unlock_irqrestore(&priv
->lock
, flags
);
1048 static int grcan_open(struct net_device
*dev
)
1050 struct grcan_priv
*priv
= netdev_priv(dev
);
1051 struct grcan_dma
*dma
= &priv
->dma
;
1052 unsigned long flags
;
1055 /* Allocate memory */
1056 err
= grcan_allocate_dma_buffers(dev
, priv
->config
.txsize
,
1057 priv
->config
.rxsize
);
1059 netdev_err(dev
, "could not allocate DMA buffers\n");
1063 priv
->echo_skb
= kzalloc(dma
->tx
.size
* sizeof(*priv
->echo_skb
),
1065 if (!priv
->echo_skb
) {
1067 goto exit_free_dma_buffers
;
1069 priv
->can
.echo_skb_max
= dma
->tx
.size
;
1070 priv
->can
.echo_skb
= priv
->echo_skb
;
1072 priv
->txdlc
= kzalloc(dma
->tx
.size
* sizeof(*priv
->txdlc
), GFP_KERNEL
);
1075 goto exit_free_echo_skb
;
1078 /* Get can device up */
1079 err
= open_candev(dev
);
1081 goto exit_free_txdlc
;
1083 err
= request_irq(dev
->irq
, grcan_interrupt
, IRQF_SHARED
,
1086 goto exit_close_candev
;
1088 spin_lock_irqsave(&priv
->lock
, flags
);
1090 napi_enable(&priv
->napi
);
1092 if (!(priv
->can
.ctrlmode
& CAN_CTRLMODE_LISTENONLY
))
1093 netif_start_queue(dev
);
1094 priv
->resetting
= false;
1095 priv
->closing
= false;
1097 spin_unlock_irqrestore(&priv
->lock
, flags
);
1106 kfree(priv
->echo_skb
);
1107 exit_free_dma_buffers
:
1108 grcan_free_dma_buffers(dev
);
1112 static int grcan_close(struct net_device
*dev
)
1114 struct grcan_priv
*priv
= netdev_priv(dev
);
1115 unsigned long flags
;
1117 napi_disable(&priv
->napi
);
1119 spin_lock_irqsave(&priv
->lock
, flags
);
1121 priv
->closing
= true;
1122 if (priv
->need_txbug_workaround
) {
1123 del_timer_sync(&priv
->hang_timer
);
1124 del_timer_sync(&priv
->rr_timer
);
1126 netif_stop_queue(dev
);
1127 grcan_stop_hardware(dev
);
1128 priv
->can
.state
= CAN_STATE_STOPPED
;
1130 spin_unlock_irqrestore(&priv
->lock
, flags
);
1132 free_irq(dev
->irq
, dev
);
1135 grcan_free_dma_buffers(dev
);
1136 priv
->can
.echo_skb_max
= 0;
1137 priv
->can
.echo_skb
= NULL
;
1138 kfree(priv
->echo_skb
);
1144 static int grcan_transmit_catch_up(struct net_device
*dev
, int budget
)
1146 struct grcan_priv
*priv
= netdev_priv(dev
);
1147 unsigned long flags
;
1150 spin_lock_irqsave(&priv
->lock
, flags
);
1152 work_done
= catch_up_echo_skb(dev
, budget
, true);
1154 if (!priv
->resetting
&& !priv
->closing
&&
1155 !(priv
->can
.ctrlmode
& CAN_CTRLMODE_LISTENONLY
))
1156 netif_wake_queue(dev
);
1158 /* With napi we don't get TX interrupts for a while,
1159 * so prevent a running reset while catching up
1161 if (priv
->need_txbug_workaround
)
1162 del_timer(&priv
->hang_timer
);
1165 spin_unlock_irqrestore(&priv
->lock
, flags
);
1170 static int grcan_receive(struct net_device
*dev
, int budget
)
1172 struct grcan_priv
*priv
= netdev_priv(dev
);
1173 struct grcan_registers __iomem
*regs
= priv
->regs
;
1174 struct grcan_dma
*dma
= &priv
->dma
;
1175 struct net_device_stats
*stats
= &dev
->stats
;
1176 struct can_frame
*cf
;
1177 struct sk_buff
*skb
;
1178 u32 wr
, rd
, startrd
;
1180 u32 i
, rtr
, eff
, j
, shift
;
1183 rd
= grcan_read_reg(®s
->rxrd
);
1185 for (work_done
= 0; work_done
< budget
; work_done
++) {
1186 /* Check for packet to receive */
1187 wr
= grcan_read_reg(®s
->rxwr
);
1191 /* Take care of packet */
1192 skb
= alloc_can_skb(dev
, &cf
);
1195 "dropping frame: skb allocation failed\n");
1196 stats
->rx_dropped
++;
1200 slot
= dma
->rx
.buf
+ rd
;
1201 eff
= slot
[0] & GRCAN_MSG_IDE
;
1202 rtr
= slot
[0] & GRCAN_MSG_RTR
;
1204 cf
->can_id
= ((slot
[0] & GRCAN_MSG_EID
)
1205 >> GRCAN_MSG_EID_BIT
);
1206 cf
->can_id
|= CAN_EFF_FLAG
;
1208 cf
->can_id
= ((slot
[0] & GRCAN_MSG_BID
)
1209 >> GRCAN_MSG_BID_BIT
);
1211 cf
->can_dlc
= get_can_dlc((slot
[1] & GRCAN_MSG_DLC
)
1212 >> GRCAN_MSG_DLC_BIT
);
1214 cf
->can_id
|= CAN_RTR_FLAG
;
1216 for (i
= 0; i
< cf
->can_dlc
; i
++) {
1217 j
= GRCAN_MSG_DATA_SLOT_INDEX(i
);
1218 shift
= GRCAN_MSG_DATA_SHIFT(i
);
1219 cf
->data
[i
] = (u8
)(slot
[j
] >> shift
);
1222 netif_receive_skb(skb
);
1224 /* Update statistics and read pointer */
1225 stats
->rx_packets
++;
1226 stats
->rx_bytes
+= cf
->can_dlc
;
1227 rd
= grcan_ring_add(rd
, GRCAN_MSG_SIZE
, dma
->rx
.size
);
1230 /* Make sure everything is read before allowing hardware to
1235 /* Update read pointer - no need to check for ongoing */
1236 if (likely(rd
!= startrd
))
1237 grcan_write_reg(®s
->rxrd
, rd
);
1242 static int grcan_poll(struct napi_struct
*napi
, int budget
)
1244 struct grcan_priv
*priv
= container_of(napi
, struct grcan_priv
, napi
);
1245 struct net_device
*dev
= priv
->dev
;
1246 struct grcan_registers __iomem
*regs
= priv
->regs
;
1247 unsigned long flags
;
1248 int tx_work_done
, rx_work_done
;
1249 int rx_budget
= budget
/ 2;
1250 int tx_budget
= budget
- rx_budget
;
1252 /* Half of the budget for receiveing messages */
1253 rx_work_done
= grcan_receive(dev
, rx_budget
);
1255 /* Half of the budget for transmitting messages as that can trigger echo
1256 * frames being received
1258 tx_work_done
= grcan_transmit_catch_up(dev
, tx_budget
);
1260 if (rx_work_done
< rx_budget
&& tx_work_done
< tx_budget
) {
1261 napi_complete(napi
);
1263 /* Guarantee no interference with a running reset that otherwise
1264 * could turn off interrupts.
1266 spin_lock_irqsave(&priv
->lock
, flags
);
1268 /* Enable tx and rx interrupts again. No need to check
1269 * priv->closing as napi_disable in grcan_close is waiting for
1270 * scheduled napi calls to finish.
1272 grcan_set_bits(®s
->imr
, GRCAN_IRQ_TX
| GRCAN_IRQ_RX
);
1274 spin_unlock_irqrestore(&priv
->lock
, flags
);
1277 return rx_work_done
+ tx_work_done
;
1280 /* Work tx bug by waiting while for the risky situation to clear. If that fails,
1281 * drop a frame in one-shot mode or indicate a busy device otherwise.
1283 * Returns 0 on successful wait. Otherwise it sets *netdev_tx_status to the
1284 * value that should be returned by grcan_start_xmit when aborting the xmit.
1286 static int grcan_txbug_workaround(struct net_device
*dev
, struct sk_buff
*skb
,
1287 u32 txwr
, u32 oneshotmode
,
1288 netdev_tx_t
*netdev_tx_status
)
1290 struct grcan_priv
*priv
= netdev_priv(dev
);
1291 struct grcan_registers __iomem
*regs
= priv
->regs
;
1292 struct grcan_dma
*dma
= &priv
->dma
;
1294 unsigned long flags
;
1296 /* Wait a while for ongoing to be cleared or read pointer to catch up to
1297 * write pointer. The latter is needed due to a bug in older versions of
1298 * GRCAN in which ONGOING is not cleared properly one-shot mode when a
1299 * transmission fails.
1301 for (i
= 0; i
< GRCAN_SHORTWAIT_USECS
; i
++) {
1303 if (!grcan_read_bits(®s
->txctrl
, GRCAN_TXCTRL_ONGOING
) ||
1304 grcan_read_reg(®s
->txrd
) == txwr
) {
1309 /* Clean up, in case the situation was not resolved */
1310 spin_lock_irqsave(&priv
->lock
, flags
);
1311 if (!priv
->resetting
&& !priv
->closing
) {
1312 /* Queue might have been stopped earlier in grcan_start_xmit */
1313 if (grcan_txspace(dma
->tx
.size
, txwr
, priv
->eskbp
))
1314 netif_wake_queue(dev
);
1315 /* Set a timer to resolve a hanged tx controller */
1316 if (!timer_pending(&priv
->hang_timer
))
1317 grcan_reset_timer(&priv
->hang_timer
,
1318 priv
->can
.bittiming
.bitrate
);
1320 spin_unlock_irqrestore(&priv
->lock
, flags
);
1323 /* In one-shot mode we should never end up here because
1324 * then the interrupt handler increases txrd on TXLOSS,
1325 * but it is consistent with one-shot mode to drop the
1326 * frame in this case.
1329 *netdev_tx_status
= NETDEV_TX_OK
;
1331 /* In normal mode the socket-can transmission queue get
1332 * to keep the frame so that it can be retransmitted
1335 *netdev_tx_status
= NETDEV_TX_BUSY
;
1340 /* Notes on the tx cyclic buffer handling:
1342 * regs->txwr - the next slot for the driver to put data to be sent
1343 * regs->txrd - the next slot for the device to read data
1344 * priv->eskbp - the next slot for the driver to call can_put_echo_skb for
1346 * grcan_start_xmit can enter more messages as long as regs->txwr does
1347 * not reach priv->eskbp (within 1 message gap)
1349 * The device sends messages until regs->txrd reaches regs->txwr
1351 * The interrupt calls handler calls can_put_echo_skb until
1352 * priv->eskbp reaches regs->txrd
1354 static netdev_tx_t
grcan_start_xmit(struct sk_buff
*skb
,
1355 struct net_device
*dev
)
1357 struct grcan_priv
*priv
= netdev_priv(dev
);
1358 struct grcan_registers __iomem
*regs
= priv
->regs
;
1359 struct grcan_dma
*dma
= &priv
->dma
;
1360 struct can_frame
*cf
= (struct can_frame
*)skb
->data
;
1361 u32 id
, txwr
, txrd
, space
, txctrl
;
1364 u32 i
, rtr
, eff
, dlc
, tmp
, err
;
1366 unsigned long flags
;
1367 u32 oneshotmode
= priv
->can
.ctrlmode
& CAN_CTRLMODE_ONE_SHOT
;
1369 if (can_dropped_invalid_skb(dev
, skb
))
1370 return NETDEV_TX_OK
;
1372 /* Trying to transmit in silent mode will generate error interrupts, but
1373 * this should never happen - the queue should not have been started.
1375 if (priv
->can
.ctrlmode
& CAN_CTRLMODE_LISTENONLY
)
1376 return NETDEV_TX_BUSY
;
1378 /* Reads of priv->eskbp and shut-downs of the queue needs to
1379 * be atomic towards the updates to priv->eskbp and wake-ups
1380 * of the queue in the interrupt handler.
1382 spin_lock_irqsave(&priv
->lock
, flags
);
1384 txwr
= grcan_read_reg(®s
->txwr
);
1385 space
= grcan_txspace(dma
->tx
.size
, txwr
, priv
->eskbp
);
1387 slotindex
= txwr
/ GRCAN_MSG_SIZE
;
1388 slot
= dma
->tx
.buf
+ txwr
;
1390 if (unlikely(space
== 1))
1391 netif_stop_queue(dev
);
1393 spin_unlock_irqrestore(&priv
->lock
, flags
);
1394 /* End of critical section*/
1396 /* This should never happen. If circular buffer is full, the
1397 * netif_stop_queue should have been stopped already.
1399 if (unlikely(!space
)) {
1400 netdev_err(dev
, "No buffer space, but queue is non-stopped.\n");
1401 return NETDEV_TX_BUSY
;
1404 /* Convert and write CAN message to DMA buffer */
1405 eff
= cf
->can_id
& CAN_EFF_FLAG
;
1406 rtr
= cf
->can_id
& CAN_RTR_FLAG
;
1407 id
= cf
->can_id
& (eff
? CAN_EFF_MASK
: CAN_SFF_MASK
);
1410 tmp
= (id
<< GRCAN_MSG_EID_BIT
) & GRCAN_MSG_EID
;
1412 tmp
= (id
<< GRCAN_MSG_BID_BIT
) & GRCAN_MSG_BID
;
1413 slot
[0] = (eff
? GRCAN_MSG_IDE
: 0) | (rtr
? GRCAN_MSG_RTR
: 0) | tmp
;
1415 slot
[1] = ((dlc
<< GRCAN_MSG_DLC_BIT
) & GRCAN_MSG_DLC
);
1418 for (i
= 0; i
< dlc
; i
++) {
1419 j
= GRCAN_MSG_DATA_SLOT_INDEX(i
);
1420 shift
= GRCAN_MSG_DATA_SHIFT(i
);
1421 slot
[j
] |= cf
->data
[i
] << shift
;
1424 /* Checking that channel has not been disabled. These cases
1425 * should never happen
1427 txctrl
= grcan_read_reg(®s
->txctrl
);
1428 if (!(txctrl
& GRCAN_TXCTRL_ENABLE
))
1429 netdev_err(dev
, "tx channel spuriously disabled\n");
1431 if (oneshotmode
&& !(txctrl
& GRCAN_TXCTRL_SINGLE
))
1432 netdev_err(dev
, "one-shot mode spuriously disabled\n");
1434 /* Bug workaround for old version of grcan where updating txwr
1435 * in the same clock cycle as the controller updates txrd to
1436 * the current txwr could hang the can controller
1438 if (priv
->need_txbug_workaround
) {
1439 txrd
= grcan_read_reg(®s
->txrd
);
1440 if (unlikely(grcan_ring_sub(txwr
, txrd
, dma
->tx
.size
) == 1)) {
1441 netdev_tx_t txstatus
;
1443 err
= grcan_txbug_workaround(dev
, skb
, txwr
,
1444 oneshotmode
, &txstatus
);
1450 /* Prepare skb for echoing. This must be after the bug workaround above
1451 * as ownership of the skb is passed on by calling can_put_echo_skb.
1452 * Returning NETDEV_TX_BUSY or accessing skb or cf after a call to
1453 * can_put_echo_skb would be an error unless other measures are
1456 priv
->txdlc
[slotindex
] = cf
->can_dlc
; /* Store dlc for statistics */
1457 can_put_echo_skb(skb
, dev
, slotindex
);
1459 /* Make sure everything is written before allowing hardware to
1460 * read from the memory
1464 /* Update write pointer to start transmission */
1465 grcan_write_reg(®s
->txwr
,
1466 grcan_ring_add(txwr
, GRCAN_MSG_SIZE
, dma
->tx
.size
));
1468 return NETDEV_TX_OK
;
1471 /* ========== Setting up sysfs interface and module parameters ========== */
1473 #define GRCAN_NOT_BOOL(unsigned_val) ((unsigned_val) > 1)
1475 #define GRCAN_MODULE_PARAM(name, mtype, valcheckf, desc) \
1476 static void grcan_sanitize_##name(struct platform_device *pd) \
1478 struct grcan_device_config grcan_default_config \
1479 = GRCAN_DEFAULT_DEVICE_CONFIG; \
1480 if (valcheckf(grcan_module_config.name)) { \
1482 "Invalid module parameter value for " \
1483 #name " - setting default\n"); \
1484 grcan_module_config.name = \
1485 grcan_default_config.name; \
1488 module_param_named(name, grcan_module_config.name, \
1490 MODULE_PARM_DESC(name, desc)
1492 #define GRCAN_CONFIG_ATTR(name, desc) \
1493 static ssize_t grcan_store_##name(struct device *sdev, \
1494 struct device_attribute *att, \
1498 struct net_device *dev = to_net_dev(sdev); \
1499 struct grcan_priv *priv = netdev_priv(dev); \
1502 if (dev->flags & IFF_UP) \
1504 ret = kstrtou8(buf, 0, &val); \
1505 if (ret < 0 || val > 1) \
1507 priv->config.name = val; \
1510 static ssize_t grcan_show_##name(struct device *sdev, \
1511 struct device_attribute *att, \
1514 struct net_device *dev = to_net_dev(sdev); \
1515 struct grcan_priv *priv = netdev_priv(dev); \
1516 return sprintf(buf, "%d\n", priv->config.name); \
1518 static DEVICE_ATTR(name, S_IRUGO | S_IWUSR, \
1519 grcan_show_##name, \
1520 grcan_store_##name); \
1521 GRCAN_MODULE_PARAM(name, ushort, GRCAN_NOT_BOOL, desc)
1523 /* The following configuration options are made available both via module
1524 * parameters and writable sysfs files. See the chapter about GRCAN in the
1525 * documentation for the GRLIB VHDL library for further details.
1527 GRCAN_CONFIG_ATTR(enable0
,
1528 "Configuration of physical interface 0. Determines\n" \
1529 "the \"Enable 0\" bit of the configuration register.\n" \
1530 "Format: 0 | 1\nDefault: 0\n");
1532 GRCAN_CONFIG_ATTR(enable1
,
1533 "Configuration of physical interface 1. Determines\n" \
1534 "the \"Enable 1\" bit of the configuration register.\n" \
1535 "Format: 0 | 1\nDefault: 0\n");
1537 GRCAN_CONFIG_ATTR(select
,
1538 "Select which physical interface to use.\n" \
1539 "Format: 0 | 1\nDefault: 0\n");
1541 /* The tx and rx buffer size configuration options are only available via module
1544 GRCAN_MODULE_PARAM(txsize
, uint
, GRCAN_INVALID_BUFFER_SIZE
,
1545 "Sets the size of the tx buffer.\n" \
1546 "Format: <unsigned int> where (txsize & ~0x1fffc0) == 0\n" \
1548 GRCAN_MODULE_PARAM(rxsize
, uint
, GRCAN_INVALID_BUFFER_SIZE
,
1549 "Sets the size of the rx buffer.\n" \
1550 "Format: <unsigned int> where (size & ~0x1fffc0) == 0\n" \
1553 /* Function that makes sure that configuration done using
1554 * module parameters are set to valid values
1556 static void grcan_sanitize_module_config(struct platform_device
*ofdev
)
1558 grcan_sanitize_enable0(ofdev
);
1559 grcan_sanitize_enable1(ofdev
);
1560 grcan_sanitize_select(ofdev
);
1561 grcan_sanitize_txsize(ofdev
);
1562 grcan_sanitize_rxsize(ofdev
);
1565 static const struct attribute
*const sysfs_grcan_attrs
[] = {
1567 &dev_attr_enable0
.attr
,
1568 &dev_attr_enable1
.attr
,
1569 &dev_attr_select
.attr
,
1573 static const struct attribute_group sysfs_grcan_group
= {
1575 .attrs
= (struct attribute
**)sysfs_grcan_attrs
,
1578 /* ========== Setting up the driver ========== */
1580 static const struct net_device_ops grcan_netdev_ops
= {
1581 .ndo_open
= grcan_open
,
1582 .ndo_stop
= grcan_close
,
1583 .ndo_start_xmit
= grcan_start_xmit
,
1586 static int grcan_setup_netdev(struct platform_device
*ofdev
,
1588 int irq
, u32 ambafreq
, bool txbug
)
1590 struct net_device
*dev
;
1591 struct grcan_priv
*priv
;
1592 struct grcan_registers __iomem
*regs
;
1595 dev
= alloc_candev(sizeof(struct grcan_priv
), 0);
1600 dev
->flags
|= IFF_ECHO
;
1601 dev
->netdev_ops
= &grcan_netdev_ops
;
1602 dev
->sysfs_groups
[0] = &sysfs_grcan_group
;
1604 priv
= netdev_priv(dev
);
1605 memcpy(&priv
->config
, &grcan_module_config
,
1606 sizeof(struct grcan_device_config
));
1609 priv
->can
.bittiming_const
= &grcan_bittiming_const
;
1610 priv
->can
.do_set_bittiming
= grcan_set_bittiming
;
1611 priv
->can
.do_set_mode
= grcan_set_mode
;
1612 priv
->can
.do_get_berr_counter
= grcan_get_berr_counter
;
1613 priv
->can
.clock
.freq
= ambafreq
;
1614 priv
->can
.ctrlmode_supported
=
1615 CAN_CTRLMODE_LISTENONLY
| CAN_CTRLMODE_ONE_SHOT
;
1616 priv
->need_txbug_workaround
= txbug
;
1618 /* Discover if triple sampling is supported by hardware */
1620 grcan_set_bits(®s
->ctrl
, GRCAN_CTRL_RESET
);
1621 grcan_set_bits(®s
->conf
, GRCAN_CONF_SAM
);
1622 if (grcan_read_bits(®s
->conf
, GRCAN_CONF_SAM
)) {
1623 priv
->can
.ctrlmode_supported
|= CAN_CTRLMODE_3_SAMPLES
;
1624 dev_dbg(&ofdev
->dev
, "Hardware supports triple-sampling\n");
1627 spin_lock_init(&priv
->lock
);
1629 if (priv
->need_txbug_workaround
) {
1630 init_timer(&priv
->rr_timer
);
1631 priv
->rr_timer
.function
= grcan_running_reset
;
1632 priv
->rr_timer
.data
= (unsigned long)dev
;
1634 init_timer(&priv
->hang_timer
);
1635 priv
->hang_timer
.function
= grcan_initiate_running_reset
;
1636 priv
->hang_timer
.data
= (unsigned long)dev
;
1639 netif_napi_add(dev
, &priv
->napi
, grcan_poll
, GRCAN_NAPI_WEIGHT
);
1641 SET_NETDEV_DEV(dev
, &ofdev
->dev
);
1642 dev_info(&ofdev
->dev
, "regs=0x%p, irq=%d, clock=%d\n",
1643 priv
->regs
, dev
->irq
, priv
->can
.clock
.freq
);
1645 err
= register_candev(dev
);
1647 goto exit_free_candev
;
1649 platform_set_drvdata(ofdev
, dev
);
1651 /* Reset device to allow bit-timing to be set. No need to call
1652 * grcan_reset at this stage. That is done in grcan_open.
1654 grcan_write_reg(®s
->ctrl
, GRCAN_CTRL_RESET
);
1662 static int grcan_probe(struct platform_device
*ofdev
)
1664 struct device_node
*np
= ofdev
->dev
.of_node
;
1665 struct resource
*res
;
1666 u32 sysid
, ambafreq
;
1671 /* Compare GRLIB version number with the first that does not
1672 * have the tx bug (see start_xmit)
1674 err
= of_property_read_u32(np
, "systemid", &sysid
);
1675 if (!err
&& ((sysid
& GRLIB_VERSION_MASK
)
1676 >= GRCAN_TXBUG_SAFE_GRLIB_VERSION
))
1679 err
= of_property_read_u32(np
, "freq", &ambafreq
);
1681 dev_err(&ofdev
->dev
, "unable to fetch \"freq\" property\n");
1685 res
= platform_get_resource(ofdev
, IORESOURCE_MEM
, 0);
1686 base
= devm_ioremap_resource(&ofdev
->dev
, res
);
1688 err
= PTR_ERR(base
);
1692 irq
= irq_of_parse_and_map(np
, GRCAN_IRQIX_IRQ
);
1694 dev_err(&ofdev
->dev
, "no irq found\n");
1699 grcan_sanitize_module_config(ofdev
);
1701 err
= grcan_setup_netdev(ofdev
, base
, irq
, ambafreq
, txbug
);
1703 goto exit_dispose_irq
;
1708 irq_dispose_mapping(irq
);
1710 dev_err(&ofdev
->dev
,
1711 "%s socket CAN driver initialization failed with error %d\n",
1716 static int grcan_remove(struct platform_device
*ofdev
)
1718 struct net_device
*dev
= platform_get_drvdata(ofdev
);
1719 struct grcan_priv
*priv
= netdev_priv(dev
);
1721 unregister_candev(dev
); /* Will in turn call grcan_close */
1723 irq_dispose_mapping(dev
->irq
);
1724 netif_napi_del(&priv
->napi
);
1730 static struct of_device_id grcan_match
[] = {
1731 {.name
= "GAISLER_GRCAN"},
1733 {.name
= "GAISLER_GRHCAN"},
1738 MODULE_DEVICE_TABLE(of
, grcan_match
);
1740 static struct platform_driver grcan_driver
= {
1743 .owner
= THIS_MODULE
,
1744 .of_match_table
= grcan_match
,
1746 .probe
= grcan_probe
,
1747 .remove
= grcan_remove
,
1750 module_platform_driver(grcan_driver
);
1752 MODULE_AUTHOR("Aeroflex Gaisler AB.");
1753 MODULE_DESCRIPTION("Socket CAN driver for Aeroflex Gaisler GRCAN");
1754 MODULE_LICENSE("GPL");