blob: 3be8c5047599f5bc0029842eeb072f2593745f5b [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * Driver for high-speed SCC boards (those with DMA support)
3 * Copyright (C) 1997-2000 Klaus Kudielka
4 *
5 * S5SCC/DMA support by Janko Koleznik S52HI
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 */
21
22
23#include <linux/module.h>
24#include <linux/delay.h>
25#include <linux/errno.h>
26#include <linux/if_arp.h>
27#include <linux/in.h>
28#include <linux/init.h>
29#include <linux/interrupt.h>
30#include <linux/ioport.h>
31#include <linux/kernel.h>
32#include <linux/mm.h>
33#include <linux/netdevice.h>
34#include <linux/rtnetlink.h>
35#include <linux/sockios.h>
36#include <linux/workqueue.h>
37#include <asm/atomic.h>
38#include <asm/bitops.h>
39#include <asm/dma.h>
40#include <asm/io.h>
41#include <asm/irq.h>
42#include <asm/uaccess.h>
43#include <net/ax25.h>
44#include "z8530.h"
45
46
47/* Number of buffers per channel */
48
49#define NUM_TX_BUF 2 /* NUM_TX_BUF >= 1 (min. 2 recommended) */
50#define NUM_RX_BUF 6 /* NUM_RX_BUF >= 1 (min. 2 recommended) */
51#define BUF_SIZE 1576 /* BUF_SIZE >= mtu + hard_header_len */
52
53
54/* Cards supported */
55
56#define HW_PI { "Ottawa PI", 0x300, 0x20, 0x10, 8, \
57 0, 8, 1843200, 3686400 }
58#define HW_PI2 { "Ottawa PI2", 0x300, 0x20, 0x10, 8, \
59 0, 8, 3686400, 7372800 }
60#define HW_TWIN { "Gracilis PackeTwin", 0x200, 0x10, 0x10, 32, \
61 0, 4, 6144000, 6144000 }
62#define HW_S5 { "S5SCC/DMA", 0x200, 0x10, 0x10, 32, \
63 0, 8, 4915200, 9830400 }
64
65#define HARDWARE { HW_PI, HW_PI2, HW_TWIN, HW_S5 }
66
67#define TMR_0_HZ 25600 /* Frequency of timer 0 */
68
69#define TYPE_PI 0
70#define TYPE_PI2 1
71#define TYPE_TWIN 2
72#define TYPE_S5 3
73#define NUM_TYPES 4
74
75#define MAX_NUM_DEVS 32
76
77
78/* SCC chips supported */
79
80#define Z8530 0
81#define Z85C30 1
82#define Z85230 2
83
84#define CHIPNAMES { "Z8530", "Z85C30", "Z85230" }
85
86
87/* I/O registers */
88
89/* 8530 registers relative to card base */
90#define SCCB_CMD 0x00
91#define SCCB_DATA 0x01
92#define SCCA_CMD 0x02
93#define SCCA_DATA 0x03
94
95/* 8253/8254 registers relative to card base */
96#define TMR_CNT0 0x00
97#define TMR_CNT1 0x01
98#define TMR_CNT2 0x02
99#define TMR_CTRL 0x03
100
101/* Additional PI/PI2 registers relative to card base */
102#define PI_DREQ_MASK 0x04
103
104/* Additional PackeTwin registers relative to card base */
105#define TWIN_INT_REG 0x08
106#define TWIN_CLR_TMR1 0x09
107#define TWIN_CLR_TMR2 0x0a
108#define TWIN_SPARE_1 0x0b
109#define TWIN_DMA_CFG 0x08
110#define TWIN_SERIAL_CFG 0x09
111#define TWIN_DMA_CLR_FF 0x0a
112#define TWIN_SPARE_2 0x0b
113
114
115/* PackeTwin I/O register values */
116
117/* INT_REG */
118#define TWIN_SCC_MSK 0x01
119#define TWIN_TMR1_MSK 0x02
120#define TWIN_TMR2_MSK 0x04
121#define TWIN_INT_MSK 0x07
122
123/* SERIAL_CFG */
124#define TWIN_DTRA_ON 0x01
125#define TWIN_DTRB_ON 0x02
126#define TWIN_EXTCLKA 0x04
127#define TWIN_EXTCLKB 0x08
128#define TWIN_LOOPA_ON 0x10
129#define TWIN_LOOPB_ON 0x20
130#define TWIN_EI 0x80
131
132/* DMA_CFG */
133#define TWIN_DMA_HDX_T1 0x08
134#define TWIN_DMA_HDX_R1 0x0a
135#define TWIN_DMA_HDX_T3 0x14
136#define TWIN_DMA_HDX_R3 0x16
137#define TWIN_DMA_FDX_T3R1 0x1b
138#define TWIN_DMA_FDX_T1R3 0x1d
139
140
141/* Status values */
142
143#define IDLE 0
144#define TX_HEAD 1
145#define TX_DATA 2
146#define TX_PAUSE 3
147#define TX_TAIL 4
148#define RTS_OFF 5
149#define WAIT 6
150#define DCD_ON 7
151#define RX_ON 8
152#define DCD_OFF 9
153
154
155/* Ioctls */
156
157#define SIOCGSCCPARAM SIOCDEVPRIVATE
158#define SIOCSSCCPARAM (SIOCDEVPRIVATE+1)
159
160
161/* Data types */
162
163struct scc_param {
164 int pclk_hz; /* frequency of BRG input (don't change) */
165 int brg_tc; /* BRG terminal count; BRG disabled if < 0 */
166 int nrzi; /* 0 (nrz), 1 (nrzi) */
167 int clocks; /* see dmascc_cfg documentation */
168 int txdelay; /* [1/TMR_0_HZ] */
169 int txtimeout; /* [1/HZ] */
170 int txtail; /* [1/TMR_0_HZ] */
171 int waittime; /* [1/TMR_0_HZ] */
172 int slottime; /* [1/TMR_0_HZ] */
173 int persist; /* 1 ... 256 */
174 int dma; /* -1 (disable), 0, 1, 3 */
175 int txpause; /* [1/TMR_0_HZ] */
176 int rtsoff; /* [1/TMR_0_HZ] */
177 int dcdon; /* [1/TMR_0_HZ] */
178 int dcdoff; /* [1/TMR_0_HZ] */
179};
180
181struct scc_hardware {
182 char *name;
183 int io_region;
184 int io_delta;
185 int io_size;
186 int num_devs;
187 int scc_offset;
188 int tmr_offset;
189 int tmr_hz;
190 int pclk_hz;
191};
192
193struct scc_priv {
194 int type;
195 int chip;
196 struct net_device *dev;
197 struct scc_info *info;
198 struct net_device_stats stats;
199 int channel;
200 int card_base, scc_cmd, scc_data;
201 int tmr_cnt, tmr_ctrl, tmr_mode;
202 struct scc_param param;
203 char rx_buf[NUM_RX_BUF][BUF_SIZE];
204 int rx_len[NUM_RX_BUF];
205 int rx_ptr;
206 struct work_struct rx_work;
207 int rx_head, rx_tail, rx_count;
208 int rx_over;
209 char tx_buf[NUM_TX_BUF][BUF_SIZE];
210 int tx_len[NUM_TX_BUF];
211 int tx_ptr;
212 int tx_head, tx_tail, tx_count;
213 int state;
214 unsigned long tx_start;
215 int rr0;
216 spinlock_t *register_lock; /* Per scc_info */
217 spinlock_t ring_lock;
218};
219
220struct scc_info {
221 int irq_used;
222 int twin_serial_cfg;
223 struct net_device *dev[2];
224 struct scc_priv priv[2];
225 struct scc_info *next;
226 spinlock_t register_lock; /* Per device register lock */
227};
228
229
230/* Function declarations */
231static int setup_adapter(int card_base, int type, int n) __init;
232
233static void write_scc(struct scc_priv *priv, int reg, int val);
234static void write_scc_data(struct scc_priv *priv, int val, int fast);
235static int read_scc(struct scc_priv *priv, int reg);
236static int read_scc_data(struct scc_priv *priv);
237
238static int scc_open(struct net_device *dev);
239static int scc_close(struct net_device *dev);
240static int scc_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd);
241static int scc_send_packet(struct sk_buff *skb, struct net_device *dev);
242static struct net_device_stats *scc_get_stats(struct net_device *dev);
243static int scc_set_mac_address(struct net_device *dev, void *sa);
244
245static inline void tx_on(struct scc_priv *priv);
246static inline void rx_on(struct scc_priv *priv);
247static inline void rx_off(struct scc_priv *priv);
248static void start_timer(struct scc_priv *priv, int t, int r15);
249static inline unsigned char random(void);
250
251static inline void z8530_isr(struct scc_info *info);
David Howells7d12e782006-10-05 14:55:46 +0100252static irqreturn_t scc_isr(int irq, void *dev_id);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700253static void rx_isr(struct scc_priv *priv);
254static void special_condition(struct scc_priv *priv, int rc);
Al Viro7a87b6c2006-12-06 18:51:40 +0000255static void rx_bh(struct work_struct *);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700256static void tx_isr(struct scc_priv *priv);
257static void es_isr(struct scc_priv *priv);
258static void tm_isr(struct scc_priv *priv);
259
260
261/* Initialization variables */
262
263static int io[MAX_NUM_DEVS] __initdata = { 0, };
264
265/* Beware! hw[] is also used in cleanup_module(). */
266static struct scc_hardware hw[NUM_TYPES] __initdata_or_module = HARDWARE;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700267
268
269/* Global variables */
270
271static struct scc_info *first;
272static unsigned long rand;
273
274
275MODULE_AUTHOR("Klaus Kudielka");
276MODULE_DESCRIPTION("Driver for high-speed SCC boards");
Rusty Russell8d3b33f2006-03-25 03:07:05 -0800277module_param_array(io, int, NULL, 0);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700278MODULE_LICENSE("GPL");
279
280static void __exit dmascc_exit(void)
281{
282 int i;
283 struct scc_info *info;
284
285 while (first) {
286 info = first;
287
288 /* Unregister devices */
289 for (i = 0; i < 2; i++)
290 unregister_netdev(info->dev[i]);
291
292 /* Reset board */
293 if (info->priv[0].type == TYPE_TWIN)
294 outb(0, info->dev[0]->base_addr + TWIN_SERIAL_CFG);
295 write_scc(&info->priv[0], R9, FHWRES);
296 release_region(info->dev[0]->base_addr,
297 hw[info->priv[0].type].io_size);
298
299 for (i = 0; i < 2; i++)
300 free_netdev(info->dev[i]);
301
302 /* Free memory */
303 first = info->next;
304 kfree(info);
305 }
306}
307
Linus Torvalds1da177e2005-04-16 15:20:36 -0700308static int __init dmascc_init(void)
309{
310 int h, i, j, n;
311 int base[MAX_NUM_DEVS], tcmd[MAX_NUM_DEVS], t0[MAX_NUM_DEVS],
312 t1[MAX_NUM_DEVS];
313 unsigned t_val;
314 unsigned long time, start[MAX_NUM_DEVS], delay[MAX_NUM_DEVS],
315 counting[MAX_NUM_DEVS];
316
317 /* Initialize random number generator */
318 rand = jiffies;
319 /* Cards found = 0 */
320 n = 0;
321 /* Warning message */
322 if (!io[0])
323 printk(KERN_INFO "dmascc: autoprobing (dangerous)\n");
324
325 /* Run autodetection for each card type */
326 for (h = 0; h < NUM_TYPES; h++) {
327
328 if (io[0]) {
329 /* User-specified I/O address regions */
330 for (i = 0; i < hw[h].num_devs; i++)
331 base[i] = 0;
332 for (i = 0; i < MAX_NUM_DEVS && io[i]; i++) {
333 j = (io[i] -
334 hw[h].io_region) / hw[h].io_delta;
335 if (j >= 0 && j < hw[h].num_devs
336 && hw[h].io_region +
337 j * hw[h].io_delta == io[i]) {
338 base[j] = io[i];
339 }
340 }
341 } else {
342 /* Default I/O address regions */
343 for (i = 0; i < hw[h].num_devs; i++) {
344 base[i] =
345 hw[h].io_region + i * hw[h].io_delta;
346 }
347 }
348
349 /* Check valid I/O address regions */
350 for (i = 0; i < hw[h].num_devs; i++)
351 if (base[i]) {
352 if (!request_region
353 (base[i], hw[h].io_size, "dmascc"))
354 base[i] = 0;
355 else {
356 tcmd[i] =
357 base[i] + hw[h].tmr_offset +
358 TMR_CTRL;
359 t0[i] =
360 base[i] + hw[h].tmr_offset +
361 TMR_CNT0;
362 t1[i] =
363 base[i] + hw[h].tmr_offset +
364 TMR_CNT1;
365 }
366 }
367
368 /* Start timers */
369 for (i = 0; i < hw[h].num_devs; i++)
370 if (base[i]) {
371 /* Timer 0: LSB+MSB, Mode 3, TMR_0_HZ */
372 outb(0x36, tcmd[i]);
373 outb((hw[h].tmr_hz / TMR_0_HZ) & 0xFF,
374 t0[i]);
375 outb((hw[h].tmr_hz / TMR_0_HZ) >> 8,
376 t0[i]);
377 /* Timer 1: LSB+MSB, Mode 0, HZ/10 */
378 outb(0x70, tcmd[i]);
379 outb((TMR_0_HZ / HZ * 10) & 0xFF, t1[i]);
380 outb((TMR_0_HZ / HZ * 10) >> 8, t1[i]);
381 start[i] = jiffies;
382 delay[i] = 0;
383 counting[i] = 1;
384 /* Timer 2: LSB+MSB, Mode 0 */
385 outb(0xb0, tcmd[i]);
386 }
387 time = jiffies;
388 /* Wait until counter registers are loaded */
389 udelay(2000000 / TMR_0_HZ);
390
391 /* Timing loop */
392 while (jiffies - time < 13) {
393 for (i = 0; i < hw[h].num_devs; i++)
394 if (base[i] && counting[i]) {
395 /* Read back Timer 1: latch; read LSB; read MSB */
396 outb(0x40, tcmd[i]);
397 t_val =
398 inb(t1[i]) + (inb(t1[i]) << 8);
399 /* Also check whether counter did wrap */
400 if (t_val == 0
401 || t_val > TMR_0_HZ / HZ * 10)
402 counting[i] = 0;
403 delay[i] = jiffies - start[i];
404 }
405 }
406
407 /* Evaluate measurements */
408 for (i = 0; i < hw[h].num_devs; i++)
409 if (base[i]) {
410 if ((delay[i] >= 9 && delay[i] <= 11) &&
411 /* Ok, we have found an adapter */
412 (setup_adapter(base[i], h, n) == 0))
413 n++;
414 else
415 release_region(base[i],
416 hw[h].io_size);
417 }
418
419 } /* NUM_TYPES */
420
421 /* If any adapter was successfully initialized, return ok */
422 if (n)
423 return 0;
424
425 /* If no adapter found, return error */
426 printk(KERN_INFO "dmascc: no adapters found\n");
427 return -EIO;
428}
429
430module_init(dmascc_init);
431module_exit(dmascc_exit);
432
Adrian Bunke2fdbc02006-06-26 12:31:46 +0200433static void __init dev_setup(struct net_device *dev)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700434{
435 dev->type = ARPHRD_AX25;
Ralf Baechlec4bc7ee2005-09-12 14:19:26 -0700436 dev->hard_header_len = AX25_MAX_HEADER_LEN;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700437 dev->mtu = 1500;
Ralf Baechlec4bc7ee2005-09-12 14:19:26 -0700438 dev->addr_len = AX25_ADDR_LEN;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700439 dev->tx_queue_len = 64;
Ralf Baechle15b1c0e2006-12-07 15:47:08 -0800440 memcpy(dev->broadcast, &ax25_bcast, AX25_ADDR_LEN);
441 memcpy(dev->dev_addr, &ax25_defaddr, AX25_ADDR_LEN);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700442}
443
444static int __init setup_adapter(int card_base, int type, int n)
445{
446 int i, irq, chip;
447 struct scc_info *info;
448 struct net_device *dev;
449 struct scc_priv *priv;
450 unsigned long time;
451 unsigned int irqs;
452 int tmr_base = card_base + hw[type].tmr_offset;
453 int scc_base = card_base + hw[type].scc_offset;
454 char *chipnames[] = CHIPNAMES;
455
456 /* Allocate memory */
457 info = kmalloc(sizeof(struct scc_info), GFP_KERNEL | GFP_DMA);
458 if (!info) {
459 printk(KERN_ERR "dmascc: "
460 "could not allocate memory for %s at %#3x\n",
461 hw[type].name, card_base);
462 goto out;
463 }
464
465 /* Initialize what is necessary for write_scc and write_scc_data */
466 memset(info, 0, sizeof(struct scc_info));
467
468 info->dev[0] = alloc_netdev(0, "", dev_setup);
469 if (!info->dev[0]) {
470 printk(KERN_ERR "dmascc: "
471 "could not allocate memory for %s at %#3x\n",
472 hw[type].name, card_base);
473 goto out1;
474 }
475
476 info->dev[1] = alloc_netdev(0, "", dev_setup);
477 if (!info->dev[1]) {
478 printk(KERN_ERR "dmascc: "
479 "could not allocate memory for %s at %#3x\n",
480 hw[type].name, card_base);
481 goto out2;
482 }
483 spin_lock_init(&info->register_lock);
484
485 priv = &info->priv[0];
486 priv->type = type;
487 priv->card_base = card_base;
488 priv->scc_cmd = scc_base + SCCA_CMD;
489 priv->scc_data = scc_base + SCCA_DATA;
490 priv->register_lock = &info->register_lock;
491
492 /* Reset SCC */
493 write_scc(priv, R9, FHWRES | MIE | NV);
494
495 /* Determine type of chip by enabling SDLC/HDLC enhancements */
496 write_scc(priv, R15, SHDLCE);
497 if (!read_scc(priv, R15)) {
498 /* WR7' not present. This is an ordinary Z8530 SCC. */
499 chip = Z8530;
500 } else {
501 /* Put one character in TX FIFO */
502 write_scc_data(priv, 0, 0);
503 if (read_scc(priv, R0) & Tx_BUF_EMP) {
504 /* TX FIFO not full. This is a Z85230 ESCC with a 4-byte FIFO. */
505 chip = Z85230;
506 } else {
507 /* TX FIFO full. This is a Z85C30 SCC with a 1-byte FIFO. */
508 chip = Z85C30;
509 }
510 }
511 write_scc(priv, R15, 0);
512
513 /* Start IRQ auto-detection */
514 irqs = probe_irq_on();
515
516 /* Enable interrupts */
517 if (type == TYPE_TWIN) {
518 outb(0, card_base + TWIN_DMA_CFG);
519 inb(card_base + TWIN_CLR_TMR1);
520 inb(card_base + TWIN_CLR_TMR2);
521 info->twin_serial_cfg = TWIN_EI;
522 outb(info->twin_serial_cfg, card_base + TWIN_SERIAL_CFG);
523 } else {
524 write_scc(priv, R15, CTSIE);
525 write_scc(priv, R0, RES_EXT_INT);
526 write_scc(priv, R1, EXT_INT_ENAB);
527 }
528
529 /* Start timer */
530 outb(1, tmr_base + TMR_CNT1);
531 outb(0, tmr_base + TMR_CNT1);
532
533 /* Wait and detect IRQ */
534 time = jiffies;
535 while (jiffies - time < 2 + HZ / TMR_0_HZ);
536 irq = probe_irq_off(irqs);
537
538 /* Clear pending interrupt, disable interrupts */
539 if (type == TYPE_TWIN) {
540 inb(card_base + TWIN_CLR_TMR1);
541 } else {
542 write_scc(priv, R1, 0);
543 write_scc(priv, R15, 0);
544 write_scc(priv, R0, RES_EXT_INT);
545 }
546
547 if (irq <= 0) {
548 printk(KERN_ERR
549 "dmascc: could not find irq of %s at %#3x (irq=%d)\n",
550 hw[type].name, card_base, irq);
551 goto out3;
552 }
553
554 /* Set up data structures */
555 for (i = 0; i < 2; i++) {
556 dev = info->dev[i];
557 priv = &info->priv[i];
558 priv->type = type;
559 priv->chip = chip;
560 priv->dev = dev;
561 priv->info = info;
562 priv->channel = i;
563 spin_lock_init(&priv->ring_lock);
564 priv->register_lock = &info->register_lock;
565 priv->card_base = card_base;
566 priv->scc_cmd = scc_base + (i ? SCCB_CMD : SCCA_CMD);
567 priv->scc_data = scc_base + (i ? SCCB_DATA : SCCA_DATA);
568 priv->tmr_cnt = tmr_base + (i ? TMR_CNT2 : TMR_CNT1);
569 priv->tmr_ctrl = tmr_base + TMR_CTRL;
570 priv->tmr_mode = i ? 0xb0 : 0x70;
571 priv->param.pclk_hz = hw[type].pclk_hz;
572 priv->param.brg_tc = -1;
573 priv->param.clocks = TCTRxCP | RCRTxCP;
574 priv->param.persist = 256;
575 priv->param.dma = -1;
Al Viro7a87b6c2006-12-06 18:51:40 +0000576 INIT_WORK(&priv->rx_work, rx_bh);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700577 dev->priv = priv;
578 sprintf(dev->name, "dmascc%i", 2 * n + i);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700579 dev->base_addr = card_base;
580 dev->irq = irq;
581 dev->open = scc_open;
582 dev->stop = scc_close;
583 dev->do_ioctl = scc_ioctl;
584 dev->hard_start_xmit = scc_send_packet;
585 dev->get_stats = scc_get_stats;
Ralf Baechle6f749982005-09-12 14:21:01 -0700586 dev->hard_header = ax25_hard_header;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700587 dev->rebuild_header = ax25_rebuild_header;
588 dev->set_mac_address = scc_set_mac_address;
589 }
590 if (register_netdev(info->dev[0])) {
591 printk(KERN_ERR "dmascc: could not register %s\n",
592 info->dev[0]->name);
593 goto out3;
594 }
595 if (register_netdev(info->dev[1])) {
596 printk(KERN_ERR "dmascc: could not register %s\n",
597 info->dev[1]->name);
598 goto out4;
599 }
600
601
602 info->next = first;
603 first = info;
604 printk(KERN_INFO "dmascc: found %s (%s) at %#3x, irq %d\n",
605 hw[type].name, chipnames[chip], card_base, irq);
606 return 0;
607
608 out4:
609 unregister_netdev(info->dev[0]);
610 out3:
611 if (info->priv[0].type == TYPE_TWIN)
612 outb(0, info->dev[0]->base_addr + TWIN_SERIAL_CFG);
613 write_scc(&info->priv[0], R9, FHWRES);
614 free_netdev(info->dev[1]);
615 out2:
616 free_netdev(info->dev[0]);
617 out1:
618 kfree(info);
619 out:
620 return -1;
621}
622
623
624/* Driver functions */
625
626static void write_scc(struct scc_priv *priv, int reg, int val)
627{
628 unsigned long flags;
629 switch (priv->type) {
630 case TYPE_S5:
631 if (reg)
632 outb(reg, priv->scc_cmd);
633 outb(val, priv->scc_cmd);
634 return;
635 case TYPE_TWIN:
636 if (reg)
637 outb_p(reg, priv->scc_cmd);
638 outb_p(val, priv->scc_cmd);
639 return;
640 default:
641 spin_lock_irqsave(priv->register_lock, flags);
642 outb_p(0, priv->card_base + PI_DREQ_MASK);
643 if (reg)
644 outb_p(reg, priv->scc_cmd);
645 outb_p(val, priv->scc_cmd);
646 outb(1, priv->card_base + PI_DREQ_MASK);
647 spin_unlock_irqrestore(priv->register_lock, flags);
648 return;
649 }
650}
651
652
653static void write_scc_data(struct scc_priv *priv, int val, int fast)
654{
655 unsigned long flags;
656 switch (priv->type) {
657 case TYPE_S5:
658 outb(val, priv->scc_data);
659 return;
660 case TYPE_TWIN:
661 outb_p(val, priv->scc_data);
662 return;
663 default:
664 if (fast)
665 outb_p(val, priv->scc_data);
666 else {
667 spin_lock_irqsave(priv->register_lock, flags);
668 outb_p(0, priv->card_base + PI_DREQ_MASK);
669 outb_p(val, priv->scc_data);
670 outb(1, priv->card_base + PI_DREQ_MASK);
671 spin_unlock_irqrestore(priv->register_lock, flags);
672 }
673 return;
674 }
675}
676
677
678static int read_scc(struct scc_priv *priv, int reg)
679{
680 int rc;
681 unsigned long flags;
682 switch (priv->type) {
683 case TYPE_S5:
684 if (reg)
685 outb(reg, priv->scc_cmd);
686 return inb(priv->scc_cmd);
687 case TYPE_TWIN:
688 if (reg)
689 outb_p(reg, priv->scc_cmd);
690 return inb_p(priv->scc_cmd);
691 default:
692 spin_lock_irqsave(priv->register_lock, flags);
693 outb_p(0, priv->card_base + PI_DREQ_MASK);
694 if (reg)
695 outb_p(reg, priv->scc_cmd);
696 rc = inb_p(priv->scc_cmd);
697 outb(1, priv->card_base + PI_DREQ_MASK);
698 spin_unlock_irqrestore(priv->register_lock, flags);
699 return rc;
700 }
701}
702
703
704static int read_scc_data(struct scc_priv *priv)
705{
706 int rc;
707 unsigned long flags;
708 switch (priv->type) {
709 case TYPE_S5:
710 return inb(priv->scc_data);
711 case TYPE_TWIN:
712 return inb_p(priv->scc_data);
713 default:
714 spin_lock_irqsave(priv->register_lock, flags);
715 outb_p(0, priv->card_base + PI_DREQ_MASK);
716 rc = inb_p(priv->scc_data);
717 outb(1, priv->card_base + PI_DREQ_MASK);
718 spin_unlock_irqrestore(priv->register_lock, flags);
719 return rc;
720 }
721}
722
723
724static int scc_open(struct net_device *dev)
725{
726 struct scc_priv *priv = dev->priv;
727 struct scc_info *info = priv->info;
728 int card_base = priv->card_base;
729
730 /* Request IRQ if not already used by other channel */
731 if (!info->irq_used) {
732 if (request_irq(dev->irq, scc_isr, 0, "dmascc", info)) {
733 return -EAGAIN;
734 }
735 }
736 info->irq_used++;
737
738 /* Request DMA if required */
739 if (priv->param.dma >= 0) {
740 if (request_dma(priv->param.dma, "dmascc")) {
741 if (--info->irq_used == 0)
742 free_irq(dev->irq, info);
743 return -EAGAIN;
744 } else {
745 unsigned long flags = claim_dma_lock();
746 clear_dma_ff(priv->param.dma);
747 release_dma_lock(flags);
748 }
749 }
750
751 /* Initialize local variables */
752 priv->rx_ptr = 0;
753 priv->rx_over = 0;
754 priv->rx_head = priv->rx_tail = priv->rx_count = 0;
755 priv->state = IDLE;
756 priv->tx_head = priv->tx_tail = priv->tx_count = 0;
757 priv->tx_ptr = 0;
758
759 /* Reset channel */
760 write_scc(priv, R9, (priv->channel ? CHRB : CHRA) | MIE | NV);
761 /* X1 clock, SDLC mode */
762 write_scc(priv, R4, SDLC | X1CLK);
763 /* DMA */
764 write_scc(priv, R1, EXT_INT_ENAB | WT_FN_RDYFN);
765 /* 8 bit RX char, RX disable */
766 write_scc(priv, R3, Rx8);
767 /* 8 bit TX char, TX disable */
768 write_scc(priv, R5, Tx8);
769 /* SDLC address field */
770 write_scc(priv, R6, 0);
771 /* SDLC flag */
772 write_scc(priv, R7, FLAG);
773 switch (priv->chip) {
774 case Z85C30:
775 /* Select WR7' */
776 write_scc(priv, R15, SHDLCE);
777 /* Auto EOM reset */
778 write_scc(priv, R7, AUTOEOM);
779 write_scc(priv, R15, 0);
780 break;
781 case Z85230:
782 /* Select WR7' */
783 write_scc(priv, R15, SHDLCE);
784 /* The following bits are set (see 2.5.2.1):
785 - Automatic EOM reset
786 - Interrupt request if RX FIFO is half full
787 This bit should be ignored in DMA mode (according to the
788 documentation), but actually isn't. The receiver doesn't work if
789 it is set. Thus, we have to clear it in DMA mode.
790 - Interrupt/DMA request if TX FIFO is completely empty
791 a) If set, the ESCC behaves as if it had no TX FIFO (Z85C30
792 compatibility).
793 b) If cleared, DMA requests may follow each other very quickly,
794 filling up the TX FIFO.
795 Advantage: TX works even in case of high bus latency.
796 Disadvantage: Edge-triggered DMA request circuitry may miss
797 a request. No more data is delivered, resulting
798 in a TX FIFO underrun.
799 Both PI2 and S5SCC/DMA seem to work fine with TXFIFOE cleared.
800 The PackeTwin doesn't. I don't know about the PI, but let's
801 assume it behaves like the PI2.
802 */
803 if (priv->param.dma >= 0) {
804 if (priv->type == TYPE_TWIN)
805 write_scc(priv, R7, AUTOEOM | TXFIFOE);
806 else
807 write_scc(priv, R7, AUTOEOM);
808 } else {
809 write_scc(priv, R7, AUTOEOM | RXFIFOH);
810 }
811 write_scc(priv, R15, 0);
812 break;
813 }
814 /* Preset CRC, NRZ(I) encoding */
815 write_scc(priv, R10, CRCPS | (priv->param.nrzi ? NRZI : NRZ));
816
817 /* Configure baud rate generator */
818 if (priv->param.brg_tc >= 0) {
819 /* Program BR generator */
820 write_scc(priv, R12, priv->param.brg_tc & 0xFF);
821 write_scc(priv, R13, (priv->param.brg_tc >> 8) & 0xFF);
822 /* BRG source = SYS CLK; enable BRG; DTR REQ function (required by
823 PackeTwin, not connected on the PI2); set DPLL source to BRG */
824 write_scc(priv, R14, SSBR | DTRREQ | BRSRC | BRENABL);
825 /* Enable DPLL */
826 write_scc(priv, R14, SEARCH | DTRREQ | BRSRC | BRENABL);
827 } else {
828 /* Disable BR generator */
829 write_scc(priv, R14, DTRREQ | BRSRC);
830 }
831
832 /* Configure clocks */
833 if (priv->type == TYPE_TWIN) {
834 /* Disable external TX clock receiver */
835 outb((info->twin_serial_cfg &=
836 ~(priv->channel ? TWIN_EXTCLKB : TWIN_EXTCLKA)),
837 card_base + TWIN_SERIAL_CFG);
838 }
839 write_scc(priv, R11, priv->param.clocks);
840 if ((priv->type == TYPE_TWIN) && !(priv->param.clocks & TRxCOI)) {
841 /* Enable external TX clock receiver */
842 outb((info->twin_serial_cfg |=
843 (priv->channel ? TWIN_EXTCLKB : TWIN_EXTCLKA)),
844 card_base + TWIN_SERIAL_CFG);
845 }
846
847 /* Configure PackeTwin */
848 if (priv->type == TYPE_TWIN) {
849 /* Assert DTR, enable interrupts */
850 outb((info->twin_serial_cfg |= TWIN_EI |
851 (priv->channel ? TWIN_DTRB_ON : TWIN_DTRA_ON)),
852 card_base + TWIN_SERIAL_CFG);
853 }
854
855 /* Read current status */
856 priv->rr0 = read_scc(priv, R0);
857 /* Enable DCD interrupt */
858 write_scc(priv, R15, DCDIE);
859
860 netif_start_queue(dev);
861
862 return 0;
863}
864
865
866static int scc_close(struct net_device *dev)
867{
868 struct scc_priv *priv = dev->priv;
869 struct scc_info *info = priv->info;
870 int card_base = priv->card_base;
871
872 netif_stop_queue(dev);
873
874 if (priv->type == TYPE_TWIN) {
875 /* Drop DTR */
876 outb((info->twin_serial_cfg &=
877 (priv->channel ? ~TWIN_DTRB_ON : ~TWIN_DTRA_ON)),
878 card_base + TWIN_SERIAL_CFG);
879 }
880
881 /* Reset channel, free DMA and IRQ */
882 write_scc(priv, R9, (priv->channel ? CHRB : CHRA) | MIE | NV);
883 if (priv->param.dma >= 0) {
884 if (priv->type == TYPE_TWIN)
885 outb(0, card_base + TWIN_DMA_CFG);
886 free_dma(priv->param.dma);
887 }
888 if (--info->irq_used == 0)
889 free_irq(dev->irq, info);
890
891 return 0;
892}
893
894
895static int scc_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
896{
897 struct scc_priv *priv = dev->priv;
898
899 switch (cmd) {
900 case SIOCGSCCPARAM:
901 if (copy_to_user
902 (ifr->ifr_data, &priv->param,
903 sizeof(struct scc_param)))
904 return -EFAULT;
905 return 0;
906 case SIOCSSCCPARAM:
907 if (!capable(CAP_NET_ADMIN))
908 return -EPERM;
909 if (netif_running(dev))
910 return -EAGAIN;
911 if (copy_from_user
912 (&priv->param, ifr->ifr_data,
913 sizeof(struct scc_param)))
914 return -EFAULT;
915 return 0;
916 default:
917 return -EINVAL;
918 }
919}
920
921
922static int scc_send_packet(struct sk_buff *skb, struct net_device *dev)
923{
924 struct scc_priv *priv = dev->priv;
925 unsigned long flags;
926 int i;
927
928 /* Temporarily stop the scheduler feeding us packets */
929 netif_stop_queue(dev);
930
931 /* Transfer data to DMA buffer */
932 i = priv->tx_head;
Arnaldo Carvalho de Melod626f622007-03-27 18:55:52 -0300933 skb_copy_from_linear_data_offset(skb, 1, priv->tx_buf[i], skb->len - 1);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700934 priv->tx_len[i] = skb->len - 1;
935
936 /* Clear interrupts while we touch our circular buffers */
937
938 spin_lock_irqsave(&priv->ring_lock, flags);
939 /* Move the ring buffer's head */
940 priv->tx_head = (i + 1) % NUM_TX_BUF;
941 priv->tx_count++;
942
943 /* If we just filled up the last buffer, leave queue stopped.
944 The higher layers must wait until we have a DMA buffer
945 to accept the data. */
946 if (priv->tx_count < NUM_TX_BUF)
947 netif_wake_queue(dev);
948
949 /* Set new TX state */
950 if (priv->state == IDLE) {
951 /* Assert RTS, start timer */
952 priv->state = TX_HEAD;
953 priv->tx_start = jiffies;
954 write_scc(priv, R5, TxCRC_ENAB | RTS | TxENAB | Tx8);
955 write_scc(priv, R15, 0);
956 start_timer(priv, priv->param.txdelay, 0);
957 }
958
959 /* Turn interrupts back on and free buffer */
960 spin_unlock_irqrestore(&priv->ring_lock, flags);
961 dev_kfree_skb(skb);
962
963 return 0;
964}
965
966
967static struct net_device_stats *scc_get_stats(struct net_device *dev)
968{
969 struct scc_priv *priv = dev->priv;
970
971 return &priv->stats;
972}
973
974
975static int scc_set_mac_address(struct net_device *dev, void *sa)
976{
977 memcpy(dev->dev_addr, ((struct sockaddr *) sa)->sa_data,
978 dev->addr_len);
979 return 0;
980}
981
982
983static inline void tx_on(struct scc_priv *priv)
984{
985 int i, n;
986 unsigned long flags;
987
988 if (priv->param.dma >= 0) {
989 n = (priv->chip == Z85230) ? 3 : 1;
990 /* Program DMA controller */
991 flags = claim_dma_lock();
992 set_dma_mode(priv->param.dma, DMA_MODE_WRITE);
993 set_dma_addr(priv->param.dma,
994 (int) priv->tx_buf[priv->tx_tail] + n);
995 set_dma_count(priv->param.dma,
996 priv->tx_len[priv->tx_tail] - n);
997 release_dma_lock(flags);
998 /* Enable TX underrun interrupt */
999 write_scc(priv, R15, TxUIE);
1000 /* Configure DREQ */
1001 if (priv->type == TYPE_TWIN)
1002 outb((priv->param.dma ==
1003 1) ? TWIN_DMA_HDX_T1 : TWIN_DMA_HDX_T3,
1004 priv->card_base + TWIN_DMA_CFG);
1005 else
1006 write_scc(priv, R1,
1007 EXT_INT_ENAB | WT_FN_RDYFN |
1008 WT_RDY_ENAB);
1009 /* Write first byte(s) */
1010 spin_lock_irqsave(priv->register_lock, flags);
1011 for (i = 0; i < n; i++)
1012 write_scc_data(priv,
1013 priv->tx_buf[priv->tx_tail][i], 1);
1014 enable_dma(priv->param.dma);
1015 spin_unlock_irqrestore(priv->register_lock, flags);
1016 } else {
1017 write_scc(priv, R15, TxUIE);
1018 write_scc(priv, R1,
1019 EXT_INT_ENAB | WT_FN_RDYFN | TxINT_ENAB);
1020 tx_isr(priv);
1021 }
1022 /* Reset EOM latch if we do not have the AUTOEOM feature */
1023 if (priv->chip == Z8530)
1024 write_scc(priv, R0, RES_EOM_L);
1025}
1026
1027
1028static inline void rx_on(struct scc_priv *priv)
1029{
1030 unsigned long flags;
1031
1032 /* Clear RX FIFO */
1033 while (read_scc(priv, R0) & Rx_CH_AV)
1034 read_scc_data(priv);
1035 priv->rx_over = 0;
1036 if (priv->param.dma >= 0) {
1037 /* Program DMA controller */
1038 flags = claim_dma_lock();
1039 set_dma_mode(priv->param.dma, DMA_MODE_READ);
1040 set_dma_addr(priv->param.dma,
1041 (int) priv->rx_buf[priv->rx_head]);
1042 set_dma_count(priv->param.dma, BUF_SIZE);
1043 release_dma_lock(flags);
1044 enable_dma(priv->param.dma);
1045 /* Configure PackeTwin DMA */
1046 if (priv->type == TYPE_TWIN) {
1047 outb((priv->param.dma ==
1048 1) ? TWIN_DMA_HDX_R1 : TWIN_DMA_HDX_R3,
1049 priv->card_base + TWIN_DMA_CFG);
1050 }
1051 /* Sp. cond. intr. only, ext int enable, RX DMA enable */
1052 write_scc(priv, R1, EXT_INT_ENAB | INT_ERR_Rx |
1053 WT_RDY_RT | WT_FN_RDYFN | WT_RDY_ENAB);
1054 } else {
1055 /* Reset current frame */
1056 priv->rx_ptr = 0;
1057 /* Intr. on all Rx characters and Sp. cond., ext int enable */
1058 write_scc(priv, R1, EXT_INT_ENAB | INT_ALL_Rx | WT_RDY_RT |
1059 WT_FN_RDYFN);
1060 }
1061 write_scc(priv, R0, ERR_RES);
1062 write_scc(priv, R3, RxENABLE | Rx8 | RxCRC_ENAB);
1063}
1064
1065
1066static inline void rx_off(struct scc_priv *priv)
1067{
1068 /* Disable receiver */
1069 write_scc(priv, R3, Rx8);
1070 /* Disable DREQ / RX interrupt */
1071 if (priv->param.dma >= 0 && priv->type == TYPE_TWIN)
1072 outb(0, priv->card_base + TWIN_DMA_CFG);
1073 else
1074 write_scc(priv, R1, EXT_INT_ENAB | WT_FN_RDYFN);
1075 /* Disable DMA */
1076 if (priv->param.dma >= 0)
1077 disable_dma(priv->param.dma);
1078}
1079
1080
1081static void start_timer(struct scc_priv *priv, int t, int r15)
1082{
1083 unsigned long flags;
1084
1085 outb(priv->tmr_mode, priv->tmr_ctrl);
1086 if (t == 0) {
1087 tm_isr(priv);
1088 } else if (t > 0) {
1089 save_flags(flags);
1090 cli();
1091 outb(t & 0xFF, priv->tmr_cnt);
1092 outb((t >> 8) & 0xFF, priv->tmr_cnt);
1093 if (priv->type != TYPE_TWIN) {
1094 write_scc(priv, R15, r15 | CTSIE);
1095 priv->rr0 |= CTS;
1096 }
1097 restore_flags(flags);
1098 }
1099}
1100
1101
1102static inline unsigned char random(void)
1103{
1104 /* See "Numerical Recipes in C", second edition, p. 284 */
1105 rand = rand * 1664525L + 1013904223L;
1106 return (unsigned char) (rand >> 24);
1107}
1108
1109static inline void z8530_isr(struct scc_info *info)
1110{
1111 int is, i = 100;
1112
1113 while ((is = read_scc(&info->priv[0], R3)) && i--) {
1114 if (is & CHARxIP) {
1115 rx_isr(&info->priv[0]);
1116 } else if (is & CHATxIP) {
1117 tx_isr(&info->priv[0]);
1118 } else if (is & CHAEXT) {
1119 es_isr(&info->priv[0]);
1120 } else if (is & CHBRxIP) {
1121 rx_isr(&info->priv[1]);
1122 } else if (is & CHBTxIP) {
1123 tx_isr(&info->priv[1]);
1124 } else {
1125 es_isr(&info->priv[1]);
1126 }
1127 write_scc(&info->priv[0], R0, RES_H_IUS);
1128 i++;
1129 }
1130 if (i < 0) {
1131 printk(KERN_ERR "dmascc: stuck in ISR with RR3=0x%02x.\n",
1132 is);
1133 }
1134 /* Ok, no interrupts pending from this 8530. The INT line should
1135 be inactive now. */
1136}
1137
1138
David Howells7d12e782006-10-05 14:55:46 +01001139static irqreturn_t scc_isr(int irq, void *dev_id)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001140{
1141 struct scc_info *info = dev_id;
1142
1143 spin_lock(info->priv[0].register_lock);
1144 /* At this point interrupts are enabled, and the interrupt under service
1145 is already acknowledged, but masked off.
1146
1147 Interrupt processing: We loop until we know that the IRQ line is
1148 low. If another positive edge occurs afterwards during the ISR,
1149 another interrupt will be triggered by the interrupt controller
1150 as soon as the IRQ level is enabled again (see asm/irq.h).
1151
1152 Bottom-half handlers will be processed after scc_isr(). This is
1153 important, since we only have small ringbuffers and want new data
1154 to be fetched/delivered immediately. */
1155
1156 if (info->priv[0].type == TYPE_TWIN) {
1157 int is, card_base = info->priv[0].card_base;
1158 while ((is = ~inb(card_base + TWIN_INT_REG)) &
1159 TWIN_INT_MSK) {
1160 if (is & TWIN_SCC_MSK) {
1161 z8530_isr(info);
1162 } else if (is & TWIN_TMR1_MSK) {
1163 inb(card_base + TWIN_CLR_TMR1);
1164 tm_isr(&info->priv[0]);
1165 } else {
1166 inb(card_base + TWIN_CLR_TMR2);
1167 tm_isr(&info->priv[1]);
1168 }
1169 }
1170 } else
1171 z8530_isr(info);
1172 spin_unlock(info->priv[0].register_lock);
1173 return IRQ_HANDLED;
1174}
1175
1176
1177static void rx_isr(struct scc_priv *priv)
1178{
1179 if (priv->param.dma >= 0) {
1180 /* Check special condition and perform error reset. See 2.4.7.5. */
1181 special_condition(priv, read_scc(priv, R1));
1182 write_scc(priv, R0, ERR_RES);
1183 } else {
1184 /* Check special condition for each character. Error reset not necessary.
1185 Same algorithm for SCC and ESCC. See 2.4.7.1 and 2.4.7.4. */
1186 int rc;
1187 while (read_scc(priv, R0) & Rx_CH_AV) {
1188 rc = read_scc(priv, R1);
1189 if (priv->rx_ptr < BUF_SIZE)
1190 priv->rx_buf[priv->rx_head][priv->
1191 rx_ptr++] =
1192 read_scc_data(priv);
1193 else {
1194 priv->rx_over = 2;
1195 read_scc_data(priv);
1196 }
1197 special_condition(priv, rc);
1198 }
1199 }
1200}
1201
1202
1203static void special_condition(struct scc_priv *priv, int rc)
1204{
1205 int cb;
1206 unsigned long flags;
1207
1208 /* See Figure 2-15. Only overrun and EOF need to be checked. */
1209
1210 if (rc & Rx_OVR) {
1211 /* Receiver overrun */
1212 priv->rx_over = 1;
1213 if (priv->param.dma < 0)
1214 write_scc(priv, R0, ERR_RES);
1215 } else if (rc & END_FR) {
1216 /* End of frame. Get byte count */
1217 if (priv->param.dma >= 0) {
1218 flags = claim_dma_lock();
1219 cb = BUF_SIZE - get_dma_residue(priv->param.dma) -
1220 2;
1221 release_dma_lock(flags);
1222 } else {
1223 cb = priv->rx_ptr - 2;
1224 }
1225 if (priv->rx_over) {
1226 /* We had an overrun */
1227 priv->stats.rx_errors++;
1228 if (priv->rx_over == 2)
1229 priv->stats.rx_length_errors++;
1230 else
1231 priv->stats.rx_fifo_errors++;
1232 priv->rx_over = 0;
1233 } else if (rc & CRC_ERR) {
1234 /* Count invalid CRC only if packet length >= minimum */
1235 if (cb >= 15) {
1236 priv->stats.rx_errors++;
1237 priv->stats.rx_crc_errors++;
1238 }
1239 } else {
1240 if (cb >= 15) {
1241 if (priv->rx_count < NUM_RX_BUF - 1) {
1242 /* Put good frame in FIFO */
1243 priv->rx_len[priv->rx_head] = cb;
1244 priv->rx_head =
1245 (priv->rx_head +
1246 1) % NUM_RX_BUF;
1247 priv->rx_count++;
1248 schedule_work(&priv->rx_work);
1249 } else {
1250 priv->stats.rx_errors++;
1251 priv->stats.rx_over_errors++;
1252 }
1253 }
1254 }
1255 /* Get ready for new frame */
1256 if (priv->param.dma >= 0) {
1257 flags = claim_dma_lock();
1258 set_dma_addr(priv->param.dma,
1259 (int) priv->rx_buf[priv->rx_head]);
1260 set_dma_count(priv->param.dma, BUF_SIZE);
1261 release_dma_lock(flags);
1262 } else {
1263 priv->rx_ptr = 0;
1264 }
1265 }
1266}
1267
1268
Al Viro7a87b6c2006-12-06 18:51:40 +00001269static void rx_bh(struct work_struct *ugli_api)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001270{
Al Viro7a87b6c2006-12-06 18:51:40 +00001271 struct scc_priv *priv = container_of(ugli_api, struct scc_priv, rx_work);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001272 int i = priv->rx_tail;
1273 int cb;
1274 unsigned long flags;
1275 struct sk_buff *skb;
1276 unsigned char *data;
1277
1278 spin_lock_irqsave(&priv->ring_lock, flags);
1279 while (priv->rx_count) {
1280 spin_unlock_irqrestore(&priv->ring_lock, flags);
1281 cb = priv->rx_len[i];
1282 /* Allocate buffer */
1283 skb = dev_alloc_skb(cb + 1);
1284 if (skb == NULL) {
1285 /* Drop packet */
1286 priv->stats.rx_dropped++;
1287 } else {
1288 /* Fill buffer */
1289 data = skb_put(skb, cb + 1);
1290 data[0] = 0;
1291 memcpy(&data[1], priv->rx_buf[i], cb);
Arnaldo Carvalho de Melo56cb5152005-04-24 18:53:06 -07001292 skb->protocol = ax25_type_trans(skb, priv->dev);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001293 netif_rx(skb);
1294 priv->dev->last_rx = jiffies;
1295 priv->stats.rx_packets++;
1296 priv->stats.rx_bytes += cb;
1297 }
1298 spin_lock_irqsave(&priv->ring_lock, flags);
1299 /* Move tail */
1300 priv->rx_tail = i = (i + 1) % NUM_RX_BUF;
1301 priv->rx_count--;
1302 }
1303 spin_unlock_irqrestore(&priv->ring_lock, flags);
1304}
1305
1306
1307static void tx_isr(struct scc_priv *priv)
1308{
1309 int i = priv->tx_tail, p = priv->tx_ptr;
1310
1311 /* Suspend TX interrupts if we don't want to send anything.
1312 See Figure 2-22. */
1313 if (p == priv->tx_len[i]) {
1314 write_scc(priv, R0, RES_Tx_P);
1315 return;
1316 }
1317
1318 /* Write characters */
1319 while ((read_scc(priv, R0) & Tx_BUF_EMP) && p < priv->tx_len[i]) {
1320 write_scc_data(priv, priv->tx_buf[i][p++], 0);
1321 }
1322
1323 /* Reset EOM latch of Z8530 */
1324 if (!priv->tx_ptr && p && priv->chip == Z8530)
1325 write_scc(priv, R0, RES_EOM_L);
1326
1327 priv->tx_ptr = p;
1328}
1329
1330
1331static void es_isr(struct scc_priv *priv)
1332{
1333 int i, rr0, drr0, res;
1334 unsigned long flags;
1335
1336 /* Read status, reset interrupt bit (open latches) */
1337 rr0 = read_scc(priv, R0);
1338 write_scc(priv, R0, RES_EXT_INT);
1339 drr0 = priv->rr0 ^ rr0;
1340 priv->rr0 = rr0;
1341
1342 /* Transmit underrun (2.4.9.6). We can't check the TxEOM flag, since
1343 it might have already been cleared again by AUTOEOM. */
1344 if (priv->state == TX_DATA) {
1345 /* Get remaining bytes */
1346 i = priv->tx_tail;
1347 if (priv->param.dma >= 0) {
1348 disable_dma(priv->param.dma);
1349 flags = claim_dma_lock();
1350 res = get_dma_residue(priv->param.dma);
1351 release_dma_lock(flags);
1352 } else {
1353 res = priv->tx_len[i] - priv->tx_ptr;
1354 priv->tx_ptr = 0;
1355 }
1356 /* Disable DREQ / TX interrupt */
1357 if (priv->param.dma >= 0 && priv->type == TYPE_TWIN)
1358 outb(0, priv->card_base + TWIN_DMA_CFG);
1359 else
1360 write_scc(priv, R1, EXT_INT_ENAB | WT_FN_RDYFN);
1361 if (res) {
1362 /* Update packet statistics */
1363 priv->stats.tx_errors++;
1364 priv->stats.tx_fifo_errors++;
1365 /* Other underrun interrupts may already be waiting */
1366 write_scc(priv, R0, RES_EXT_INT);
1367 write_scc(priv, R0, RES_EXT_INT);
1368 } else {
1369 /* Update packet statistics */
1370 priv->stats.tx_packets++;
1371 priv->stats.tx_bytes += priv->tx_len[i];
1372 /* Remove frame from FIFO */
1373 priv->tx_tail = (i + 1) % NUM_TX_BUF;
1374 priv->tx_count--;
1375 /* Inform upper layers */
1376 netif_wake_queue(priv->dev);
1377 }
1378 /* Switch state */
1379 write_scc(priv, R15, 0);
1380 if (priv->tx_count &&
1381 (jiffies - priv->tx_start) < priv->param.txtimeout) {
1382 priv->state = TX_PAUSE;
1383 start_timer(priv, priv->param.txpause, 0);
1384 } else {
1385 priv->state = TX_TAIL;
1386 start_timer(priv, priv->param.txtail, 0);
1387 }
1388 }
1389
1390 /* DCD transition */
1391 if (drr0 & DCD) {
1392 if (rr0 & DCD) {
1393 switch (priv->state) {
1394 case IDLE:
1395 case WAIT:
1396 priv->state = DCD_ON;
1397 write_scc(priv, R15, 0);
1398 start_timer(priv, priv->param.dcdon, 0);
1399 }
1400 } else {
1401 switch (priv->state) {
1402 case RX_ON:
1403 rx_off(priv);
1404 priv->state = DCD_OFF;
1405 write_scc(priv, R15, 0);
1406 start_timer(priv, priv->param.dcdoff, 0);
1407 }
1408 }
1409 }
1410
1411 /* CTS transition */
1412 if ((drr0 & CTS) && (~rr0 & CTS) && priv->type != TYPE_TWIN)
1413 tm_isr(priv);
1414
1415}
1416
1417
1418static void tm_isr(struct scc_priv *priv)
1419{
1420 switch (priv->state) {
1421 case TX_HEAD:
1422 case TX_PAUSE:
1423 tx_on(priv);
1424 priv->state = TX_DATA;
1425 break;
1426 case TX_TAIL:
1427 write_scc(priv, R5, TxCRC_ENAB | Tx8);
1428 priv->state = RTS_OFF;
1429 if (priv->type != TYPE_TWIN)
1430 write_scc(priv, R15, 0);
1431 start_timer(priv, priv->param.rtsoff, 0);
1432 break;
1433 case RTS_OFF:
1434 write_scc(priv, R15, DCDIE);
1435 priv->rr0 = read_scc(priv, R0);
1436 if (priv->rr0 & DCD) {
1437 priv->stats.collisions++;
1438 rx_on(priv);
1439 priv->state = RX_ON;
1440 } else {
1441 priv->state = WAIT;
1442 start_timer(priv, priv->param.waittime, DCDIE);
1443 }
1444 break;
1445 case WAIT:
1446 if (priv->tx_count) {
1447 priv->state = TX_HEAD;
1448 priv->tx_start = jiffies;
1449 write_scc(priv, R5,
1450 TxCRC_ENAB | RTS | TxENAB | Tx8);
1451 write_scc(priv, R15, 0);
1452 start_timer(priv, priv->param.txdelay, 0);
1453 } else {
1454 priv->state = IDLE;
1455 if (priv->type != TYPE_TWIN)
1456 write_scc(priv, R15, DCDIE);
1457 }
1458 break;
1459 case DCD_ON:
1460 case DCD_OFF:
1461 write_scc(priv, R15, DCDIE);
1462 priv->rr0 = read_scc(priv, R0);
1463 if (priv->rr0 & DCD) {
1464 rx_on(priv);
1465 priv->state = RX_ON;
1466 } else {
1467 priv->state = WAIT;
1468 start_timer(priv,
1469 random() / priv->param.persist *
1470 priv->param.slottime, DCDIE);
1471 }
1472 break;
1473 }
1474}