blob: c8dc40214a087f752a0be4ce7b644e7c24fc223c [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);
252static irqreturn_t scc_isr(int irq, void *dev_id, struct pt_regs *regs);
253static void rx_isr(struct scc_priv *priv);
254static void special_condition(struct scc_priv *priv, int rc);
255static void rx_bh(void *arg);
256static 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;
267static char ax25_broadcast[7] __initdata =
268 { 'Q' << 1, 'S' << 1, 'T' << 1, ' ' << 1, ' ' << 1, ' ' << 1,
269'0' << 1 };
270static char ax25_test[7] __initdata =
271 { 'L' << 1, 'I' << 1, 'N' << 1, 'U' << 1, 'X' << 1, ' ' << 1,
272'1' << 1 };
273
274
275/* Global variables */
276
277static struct scc_info *first;
278static unsigned long rand;
279
280
281MODULE_AUTHOR("Klaus Kudielka");
282MODULE_DESCRIPTION("Driver for high-speed SCC boards");
283MODULE_PARM(io, "1-" __MODULE_STRING(MAX_NUM_DEVS) "i");
284MODULE_LICENSE("GPL");
285
286static void __exit dmascc_exit(void)
287{
288 int i;
289 struct scc_info *info;
290
291 while (first) {
292 info = first;
293
294 /* Unregister devices */
295 for (i = 0; i < 2; i++)
296 unregister_netdev(info->dev[i]);
297
298 /* Reset board */
299 if (info->priv[0].type == TYPE_TWIN)
300 outb(0, info->dev[0]->base_addr + TWIN_SERIAL_CFG);
301 write_scc(&info->priv[0], R9, FHWRES);
302 release_region(info->dev[0]->base_addr,
303 hw[info->priv[0].type].io_size);
304
305 for (i = 0; i < 2; i++)
306 free_netdev(info->dev[i]);
307
308 /* Free memory */
309 first = info->next;
310 kfree(info);
311 }
312}
313
Linus Torvalds1da177e2005-04-16 15:20:36 -0700314static int __init dmascc_init(void)
315{
316 int h, i, j, n;
317 int base[MAX_NUM_DEVS], tcmd[MAX_NUM_DEVS], t0[MAX_NUM_DEVS],
318 t1[MAX_NUM_DEVS];
319 unsigned t_val;
320 unsigned long time, start[MAX_NUM_DEVS], delay[MAX_NUM_DEVS],
321 counting[MAX_NUM_DEVS];
322
323 /* Initialize random number generator */
324 rand = jiffies;
325 /* Cards found = 0 */
326 n = 0;
327 /* Warning message */
328 if (!io[0])
329 printk(KERN_INFO "dmascc: autoprobing (dangerous)\n");
330
331 /* Run autodetection for each card type */
332 for (h = 0; h < NUM_TYPES; h++) {
333
334 if (io[0]) {
335 /* User-specified I/O address regions */
336 for (i = 0; i < hw[h].num_devs; i++)
337 base[i] = 0;
338 for (i = 0; i < MAX_NUM_DEVS && io[i]; i++) {
339 j = (io[i] -
340 hw[h].io_region) / hw[h].io_delta;
341 if (j >= 0 && j < hw[h].num_devs
342 && hw[h].io_region +
343 j * hw[h].io_delta == io[i]) {
344 base[j] = io[i];
345 }
346 }
347 } else {
348 /* Default I/O address regions */
349 for (i = 0; i < hw[h].num_devs; i++) {
350 base[i] =
351 hw[h].io_region + i * hw[h].io_delta;
352 }
353 }
354
355 /* Check valid I/O address regions */
356 for (i = 0; i < hw[h].num_devs; i++)
357 if (base[i]) {
358 if (!request_region
359 (base[i], hw[h].io_size, "dmascc"))
360 base[i] = 0;
361 else {
362 tcmd[i] =
363 base[i] + hw[h].tmr_offset +
364 TMR_CTRL;
365 t0[i] =
366 base[i] + hw[h].tmr_offset +
367 TMR_CNT0;
368 t1[i] =
369 base[i] + hw[h].tmr_offset +
370 TMR_CNT1;
371 }
372 }
373
374 /* Start timers */
375 for (i = 0; i < hw[h].num_devs; i++)
376 if (base[i]) {
377 /* Timer 0: LSB+MSB, Mode 3, TMR_0_HZ */
378 outb(0x36, tcmd[i]);
379 outb((hw[h].tmr_hz / TMR_0_HZ) & 0xFF,
380 t0[i]);
381 outb((hw[h].tmr_hz / TMR_0_HZ) >> 8,
382 t0[i]);
383 /* Timer 1: LSB+MSB, Mode 0, HZ/10 */
384 outb(0x70, tcmd[i]);
385 outb((TMR_0_HZ / HZ * 10) & 0xFF, t1[i]);
386 outb((TMR_0_HZ / HZ * 10) >> 8, t1[i]);
387 start[i] = jiffies;
388 delay[i] = 0;
389 counting[i] = 1;
390 /* Timer 2: LSB+MSB, Mode 0 */
391 outb(0xb0, tcmd[i]);
392 }
393 time = jiffies;
394 /* Wait until counter registers are loaded */
395 udelay(2000000 / TMR_0_HZ);
396
397 /* Timing loop */
398 while (jiffies - time < 13) {
399 for (i = 0; i < hw[h].num_devs; i++)
400 if (base[i] && counting[i]) {
401 /* Read back Timer 1: latch; read LSB; read MSB */
402 outb(0x40, tcmd[i]);
403 t_val =
404 inb(t1[i]) + (inb(t1[i]) << 8);
405 /* Also check whether counter did wrap */
406 if (t_val == 0
407 || t_val > TMR_0_HZ / HZ * 10)
408 counting[i] = 0;
409 delay[i] = jiffies - start[i];
410 }
411 }
412
413 /* Evaluate measurements */
414 for (i = 0; i < hw[h].num_devs; i++)
415 if (base[i]) {
416 if ((delay[i] >= 9 && delay[i] <= 11) &&
417 /* Ok, we have found an adapter */
418 (setup_adapter(base[i], h, n) == 0))
419 n++;
420 else
421 release_region(base[i],
422 hw[h].io_size);
423 }
424
425 } /* NUM_TYPES */
426
427 /* If any adapter was successfully initialized, return ok */
428 if (n)
429 return 0;
430
431 /* If no adapter found, return error */
432 printk(KERN_INFO "dmascc: no adapters found\n");
433 return -EIO;
434}
435
436module_init(dmascc_init);
437module_exit(dmascc_exit);
438
439static void dev_setup(struct net_device *dev)
440{
441 dev->type = ARPHRD_AX25;
Ralf Baechlec4bc7ee2005-09-12 14:19:26 -0700442 dev->hard_header_len = AX25_MAX_HEADER_LEN;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700443 dev->mtu = 1500;
Ralf Baechlec4bc7ee2005-09-12 14:19:26 -0700444 dev->addr_len = AX25_ADDR_LEN;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700445 dev->tx_queue_len = 64;
Ralf Baechlec4bc7ee2005-09-12 14:19:26 -0700446 memcpy(dev->broadcast, ax25_broadcast, AX25_ADDR_LEN);
447 memcpy(dev->dev_addr, ax25_test, AX25_ADDR_LEN);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700448}
449
450static int __init setup_adapter(int card_base, int type, int n)
451{
452 int i, irq, chip;
453 struct scc_info *info;
454 struct net_device *dev;
455 struct scc_priv *priv;
456 unsigned long time;
457 unsigned int irqs;
458 int tmr_base = card_base + hw[type].tmr_offset;
459 int scc_base = card_base + hw[type].scc_offset;
460 char *chipnames[] = CHIPNAMES;
461
462 /* Allocate memory */
463 info = kmalloc(sizeof(struct scc_info), GFP_KERNEL | GFP_DMA);
464 if (!info) {
465 printk(KERN_ERR "dmascc: "
466 "could not allocate memory for %s at %#3x\n",
467 hw[type].name, card_base);
468 goto out;
469 }
470
471 /* Initialize what is necessary for write_scc and write_scc_data */
472 memset(info, 0, sizeof(struct scc_info));
473
474 info->dev[0] = alloc_netdev(0, "", dev_setup);
475 if (!info->dev[0]) {
476 printk(KERN_ERR "dmascc: "
477 "could not allocate memory for %s at %#3x\n",
478 hw[type].name, card_base);
479 goto out1;
480 }
481
482 info->dev[1] = alloc_netdev(0, "", dev_setup);
483 if (!info->dev[1]) {
484 printk(KERN_ERR "dmascc: "
485 "could not allocate memory for %s at %#3x\n",
486 hw[type].name, card_base);
487 goto out2;
488 }
489 spin_lock_init(&info->register_lock);
490
491 priv = &info->priv[0];
492 priv->type = type;
493 priv->card_base = card_base;
494 priv->scc_cmd = scc_base + SCCA_CMD;
495 priv->scc_data = scc_base + SCCA_DATA;
496 priv->register_lock = &info->register_lock;
497
498 /* Reset SCC */
499 write_scc(priv, R9, FHWRES | MIE | NV);
500
501 /* Determine type of chip by enabling SDLC/HDLC enhancements */
502 write_scc(priv, R15, SHDLCE);
503 if (!read_scc(priv, R15)) {
504 /* WR7' not present. This is an ordinary Z8530 SCC. */
505 chip = Z8530;
506 } else {
507 /* Put one character in TX FIFO */
508 write_scc_data(priv, 0, 0);
509 if (read_scc(priv, R0) & Tx_BUF_EMP) {
510 /* TX FIFO not full. This is a Z85230 ESCC with a 4-byte FIFO. */
511 chip = Z85230;
512 } else {
513 /* TX FIFO full. This is a Z85C30 SCC with a 1-byte FIFO. */
514 chip = Z85C30;
515 }
516 }
517 write_scc(priv, R15, 0);
518
519 /* Start IRQ auto-detection */
520 irqs = probe_irq_on();
521
522 /* Enable interrupts */
523 if (type == TYPE_TWIN) {
524 outb(0, card_base + TWIN_DMA_CFG);
525 inb(card_base + TWIN_CLR_TMR1);
526 inb(card_base + TWIN_CLR_TMR2);
527 info->twin_serial_cfg = TWIN_EI;
528 outb(info->twin_serial_cfg, card_base + TWIN_SERIAL_CFG);
529 } else {
530 write_scc(priv, R15, CTSIE);
531 write_scc(priv, R0, RES_EXT_INT);
532 write_scc(priv, R1, EXT_INT_ENAB);
533 }
534
535 /* Start timer */
536 outb(1, tmr_base + TMR_CNT1);
537 outb(0, tmr_base + TMR_CNT1);
538
539 /* Wait and detect IRQ */
540 time = jiffies;
541 while (jiffies - time < 2 + HZ / TMR_0_HZ);
542 irq = probe_irq_off(irqs);
543
544 /* Clear pending interrupt, disable interrupts */
545 if (type == TYPE_TWIN) {
546 inb(card_base + TWIN_CLR_TMR1);
547 } else {
548 write_scc(priv, R1, 0);
549 write_scc(priv, R15, 0);
550 write_scc(priv, R0, RES_EXT_INT);
551 }
552
553 if (irq <= 0) {
554 printk(KERN_ERR
555 "dmascc: could not find irq of %s at %#3x (irq=%d)\n",
556 hw[type].name, card_base, irq);
557 goto out3;
558 }
559
560 /* Set up data structures */
561 for (i = 0; i < 2; i++) {
562 dev = info->dev[i];
563 priv = &info->priv[i];
564 priv->type = type;
565 priv->chip = chip;
566 priv->dev = dev;
567 priv->info = info;
568 priv->channel = i;
569 spin_lock_init(&priv->ring_lock);
570 priv->register_lock = &info->register_lock;
571 priv->card_base = card_base;
572 priv->scc_cmd = scc_base + (i ? SCCB_CMD : SCCA_CMD);
573 priv->scc_data = scc_base + (i ? SCCB_DATA : SCCA_DATA);
574 priv->tmr_cnt = tmr_base + (i ? TMR_CNT2 : TMR_CNT1);
575 priv->tmr_ctrl = tmr_base + TMR_CTRL;
576 priv->tmr_mode = i ? 0xb0 : 0x70;
577 priv->param.pclk_hz = hw[type].pclk_hz;
578 priv->param.brg_tc = -1;
579 priv->param.clocks = TCTRxCP | RCRTxCP;
580 priv->param.persist = 256;
581 priv->param.dma = -1;
582 INIT_WORK(&priv->rx_work, rx_bh, priv);
583 dev->priv = priv;
584 sprintf(dev->name, "dmascc%i", 2 * n + i);
585 SET_MODULE_OWNER(dev);
586 dev->base_addr = card_base;
587 dev->irq = irq;
588 dev->open = scc_open;
589 dev->stop = scc_close;
590 dev->do_ioctl = scc_ioctl;
591 dev->hard_start_xmit = scc_send_packet;
592 dev->get_stats = scc_get_stats;
Ralf Baechle6f749982005-09-12 14:21:01 -0700593 dev->hard_header = ax25_hard_header;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700594 dev->rebuild_header = ax25_rebuild_header;
595 dev->set_mac_address = scc_set_mac_address;
596 }
597 if (register_netdev(info->dev[0])) {
598 printk(KERN_ERR "dmascc: could not register %s\n",
599 info->dev[0]->name);
600 goto out3;
601 }
602 if (register_netdev(info->dev[1])) {
603 printk(KERN_ERR "dmascc: could not register %s\n",
604 info->dev[1]->name);
605 goto out4;
606 }
607
608
609 info->next = first;
610 first = info;
611 printk(KERN_INFO "dmascc: found %s (%s) at %#3x, irq %d\n",
612 hw[type].name, chipnames[chip], card_base, irq);
613 return 0;
614
615 out4:
616 unregister_netdev(info->dev[0]);
617 out3:
618 if (info->priv[0].type == TYPE_TWIN)
619 outb(0, info->dev[0]->base_addr + TWIN_SERIAL_CFG);
620 write_scc(&info->priv[0], R9, FHWRES);
621 free_netdev(info->dev[1]);
622 out2:
623 free_netdev(info->dev[0]);
624 out1:
625 kfree(info);
626 out:
627 return -1;
628}
629
630
631/* Driver functions */
632
633static void write_scc(struct scc_priv *priv, int reg, int val)
634{
635 unsigned long flags;
636 switch (priv->type) {
637 case TYPE_S5:
638 if (reg)
639 outb(reg, priv->scc_cmd);
640 outb(val, priv->scc_cmd);
641 return;
642 case TYPE_TWIN:
643 if (reg)
644 outb_p(reg, priv->scc_cmd);
645 outb_p(val, priv->scc_cmd);
646 return;
647 default:
648 spin_lock_irqsave(priv->register_lock, flags);
649 outb_p(0, priv->card_base + PI_DREQ_MASK);
650 if (reg)
651 outb_p(reg, priv->scc_cmd);
652 outb_p(val, priv->scc_cmd);
653 outb(1, priv->card_base + PI_DREQ_MASK);
654 spin_unlock_irqrestore(priv->register_lock, flags);
655 return;
656 }
657}
658
659
660static void write_scc_data(struct scc_priv *priv, int val, int fast)
661{
662 unsigned long flags;
663 switch (priv->type) {
664 case TYPE_S5:
665 outb(val, priv->scc_data);
666 return;
667 case TYPE_TWIN:
668 outb_p(val, priv->scc_data);
669 return;
670 default:
671 if (fast)
672 outb_p(val, priv->scc_data);
673 else {
674 spin_lock_irqsave(priv->register_lock, flags);
675 outb_p(0, priv->card_base + PI_DREQ_MASK);
676 outb_p(val, priv->scc_data);
677 outb(1, priv->card_base + PI_DREQ_MASK);
678 spin_unlock_irqrestore(priv->register_lock, flags);
679 }
680 return;
681 }
682}
683
684
685static int read_scc(struct scc_priv *priv, int reg)
686{
687 int rc;
688 unsigned long flags;
689 switch (priv->type) {
690 case TYPE_S5:
691 if (reg)
692 outb(reg, priv->scc_cmd);
693 return inb(priv->scc_cmd);
694 case TYPE_TWIN:
695 if (reg)
696 outb_p(reg, priv->scc_cmd);
697 return inb_p(priv->scc_cmd);
698 default:
699 spin_lock_irqsave(priv->register_lock, flags);
700 outb_p(0, priv->card_base + PI_DREQ_MASK);
701 if (reg)
702 outb_p(reg, priv->scc_cmd);
703 rc = inb_p(priv->scc_cmd);
704 outb(1, priv->card_base + PI_DREQ_MASK);
705 spin_unlock_irqrestore(priv->register_lock, flags);
706 return rc;
707 }
708}
709
710
711static int read_scc_data(struct scc_priv *priv)
712{
713 int rc;
714 unsigned long flags;
715 switch (priv->type) {
716 case TYPE_S5:
717 return inb(priv->scc_data);
718 case TYPE_TWIN:
719 return inb_p(priv->scc_data);
720 default:
721 spin_lock_irqsave(priv->register_lock, flags);
722 outb_p(0, priv->card_base + PI_DREQ_MASK);
723 rc = inb_p(priv->scc_data);
724 outb(1, priv->card_base + PI_DREQ_MASK);
725 spin_unlock_irqrestore(priv->register_lock, flags);
726 return rc;
727 }
728}
729
730
731static int scc_open(struct net_device *dev)
732{
733 struct scc_priv *priv = dev->priv;
734 struct scc_info *info = priv->info;
735 int card_base = priv->card_base;
736
737 /* Request IRQ if not already used by other channel */
738 if (!info->irq_used) {
739 if (request_irq(dev->irq, scc_isr, 0, "dmascc", info)) {
740 return -EAGAIN;
741 }
742 }
743 info->irq_used++;
744
745 /* Request DMA if required */
746 if (priv->param.dma >= 0) {
747 if (request_dma(priv->param.dma, "dmascc")) {
748 if (--info->irq_used == 0)
749 free_irq(dev->irq, info);
750 return -EAGAIN;
751 } else {
752 unsigned long flags = claim_dma_lock();
753 clear_dma_ff(priv->param.dma);
754 release_dma_lock(flags);
755 }
756 }
757
758 /* Initialize local variables */
759 priv->rx_ptr = 0;
760 priv->rx_over = 0;
761 priv->rx_head = priv->rx_tail = priv->rx_count = 0;
762 priv->state = IDLE;
763 priv->tx_head = priv->tx_tail = priv->tx_count = 0;
764 priv->tx_ptr = 0;
765
766 /* Reset channel */
767 write_scc(priv, R9, (priv->channel ? CHRB : CHRA) | MIE | NV);
768 /* X1 clock, SDLC mode */
769 write_scc(priv, R4, SDLC | X1CLK);
770 /* DMA */
771 write_scc(priv, R1, EXT_INT_ENAB | WT_FN_RDYFN);
772 /* 8 bit RX char, RX disable */
773 write_scc(priv, R3, Rx8);
774 /* 8 bit TX char, TX disable */
775 write_scc(priv, R5, Tx8);
776 /* SDLC address field */
777 write_scc(priv, R6, 0);
778 /* SDLC flag */
779 write_scc(priv, R7, FLAG);
780 switch (priv->chip) {
781 case Z85C30:
782 /* Select WR7' */
783 write_scc(priv, R15, SHDLCE);
784 /* Auto EOM reset */
785 write_scc(priv, R7, AUTOEOM);
786 write_scc(priv, R15, 0);
787 break;
788 case Z85230:
789 /* Select WR7' */
790 write_scc(priv, R15, SHDLCE);
791 /* The following bits are set (see 2.5.2.1):
792 - Automatic EOM reset
793 - Interrupt request if RX FIFO is half full
794 This bit should be ignored in DMA mode (according to the
795 documentation), but actually isn't. The receiver doesn't work if
796 it is set. Thus, we have to clear it in DMA mode.
797 - Interrupt/DMA request if TX FIFO is completely empty
798 a) If set, the ESCC behaves as if it had no TX FIFO (Z85C30
799 compatibility).
800 b) If cleared, DMA requests may follow each other very quickly,
801 filling up the TX FIFO.
802 Advantage: TX works even in case of high bus latency.
803 Disadvantage: Edge-triggered DMA request circuitry may miss
804 a request. No more data is delivered, resulting
805 in a TX FIFO underrun.
806 Both PI2 and S5SCC/DMA seem to work fine with TXFIFOE cleared.
807 The PackeTwin doesn't. I don't know about the PI, but let's
808 assume it behaves like the PI2.
809 */
810 if (priv->param.dma >= 0) {
811 if (priv->type == TYPE_TWIN)
812 write_scc(priv, R7, AUTOEOM | TXFIFOE);
813 else
814 write_scc(priv, R7, AUTOEOM);
815 } else {
816 write_scc(priv, R7, AUTOEOM | RXFIFOH);
817 }
818 write_scc(priv, R15, 0);
819 break;
820 }
821 /* Preset CRC, NRZ(I) encoding */
822 write_scc(priv, R10, CRCPS | (priv->param.nrzi ? NRZI : NRZ));
823
824 /* Configure baud rate generator */
825 if (priv->param.brg_tc >= 0) {
826 /* Program BR generator */
827 write_scc(priv, R12, priv->param.brg_tc & 0xFF);
828 write_scc(priv, R13, (priv->param.brg_tc >> 8) & 0xFF);
829 /* BRG source = SYS CLK; enable BRG; DTR REQ function (required by
830 PackeTwin, not connected on the PI2); set DPLL source to BRG */
831 write_scc(priv, R14, SSBR | DTRREQ | BRSRC | BRENABL);
832 /* Enable DPLL */
833 write_scc(priv, R14, SEARCH | DTRREQ | BRSRC | BRENABL);
834 } else {
835 /* Disable BR generator */
836 write_scc(priv, R14, DTRREQ | BRSRC);
837 }
838
839 /* Configure clocks */
840 if (priv->type == TYPE_TWIN) {
841 /* Disable 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 write_scc(priv, R11, priv->param.clocks);
847 if ((priv->type == TYPE_TWIN) && !(priv->param.clocks & TRxCOI)) {
848 /* Enable external TX clock receiver */
849 outb((info->twin_serial_cfg |=
850 (priv->channel ? TWIN_EXTCLKB : TWIN_EXTCLKA)),
851 card_base + TWIN_SERIAL_CFG);
852 }
853
854 /* Configure PackeTwin */
855 if (priv->type == TYPE_TWIN) {
856 /* Assert DTR, enable interrupts */
857 outb((info->twin_serial_cfg |= TWIN_EI |
858 (priv->channel ? TWIN_DTRB_ON : TWIN_DTRA_ON)),
859 card_base + TWIN_SERIAL_CFG);
860 }
861
862 /* Read current status */
863 priv->rr0 = read_scc(priv, R0);
864 /* Enable DCD interrupt */
865 write_scc(priv, R15, DCDIE);
866
867 netif_start_queue(dev);
868
869 return 0;
870}
871
872
873static int scc_close(struct net_device *dev)
874{
875 struct scc_priv *priv = dev->priv;
876 struct scc_info *info = priv->info;
877 int card_base = priv->card_base;
878
879 netif_stop_queue(dev);
880
881 if (priv->type == TYPE_TWIN) {
882 /* Drop DTR */
883 outb((info->twin_serial_cfg &=
884 (priv->channel ? ~TWIN_DTRB_ON : ~TWIN_DTRA_ON)),
885 card_base + TWIN_SERIAL_CFG);
886 }
887
888 /* Reset channel, free DMA and IRQ */
889 write_scc(priv, R9, (priv->channel ? CHRB : CHRA) | MIE | NV);
890 if (priv->param.dma >= 0) {
891 if (priv->type == TYPE_TWIN)
892 outb(0, card_base + TWIN_DMA_CFG);
893 free_dma(priv->param.dma);
894 }
895 if (--info->irq_used == 0)
896 free_irq(dev->irq, info);
897
898 return 0;
899}
900
901
902static int scc_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
903{
904 struct scc_priv *priv = dev->priv;
905
906 switch (cmd) {
907 case SIOCGSCCPARAM:
908 if (copy_to_user
909 (ifr->ifr_data, &priv->param,
910 sizeof(struct scc_param)))
911 return -EFAULT;
912 return 0;
913 case SIOCSSCCPARAM:
914 if (!capable(CAP_NET_ADMIN))
915 return -EPERM;
916 if (netif_running(dev))
917 return -EAGAIN;
918 if (copy_from_user
919 (&priv->param, ifr->ifr_data,
920 sizeof(struct scc_param)))
921 return -EFAULT;
922 return 0;
923 default:
924 return -EINVAL;
925 }
926}
927
928
929static int scc_send_packet(struct sk_buff *skb, struct net_device *dev)
930{
931 struct scc_priv *priv = dev->priv;
932 unsigned long flags;
933 int i;
934
935 /* Temporarily stop the scheduler feeding us packets */
936 netif_stop_queue(dev);
937
938 /* Transfer data to DMA buffer */
939 i = priv->tx_head;
940 memcpy(priv->tx_buf[i], skb->data + 1, skb->len - 1);
941 priv->tx_len[i] = skb->len - 1;
942
943 /* Clear interrupts while we touch our circular buffers */
944
945 spin_lock_irqsave(&priv->ring_lock, flags);
946 /* Move the ring buffer's head */
947 priv->tx_head = (i + 1) % NUM_TX_BUF;
948 priv->tx_count++;
949
950 /* If we just filled up the last buffer, leave queue stopped.
951 The higher layers must wait until we have a DMA buffer
952 to accept the data. */
953 if (priv->tx_count < NUM_TX_BUF)
954 netif_wake_queue(dev);
955
956 /* Set new TX state */
957 if (priv->state == IDLE) {
958 /* Assert RTS, start timer */
959 priv->state = TX_HEAD;
960 priv->tx_start = jiffies;
961 write_scc(priv, R5, TxCRC_ENAB | RTS | TxENAB | Tx8);
962 write_scc(priv, R15, 0);
963 start_timer(priv, priv->param.txdelay, 0);
964 }
965
966 /* Turn interrupts back on and free buffer */
967 spin_unlock_irqrestore(&priv->ring_lock, flags);
968 dev_kfree_skb(skb);
969
970 return 0;
971}
972
973
974static struct net_device_stats *scc_get_stats(struct net_device *dev)
975{
976 struct scc_priv *priv = dev->priv;
977
978 return &priv->stats;
979}
980
981
982static int scc_set_mac_address(struct net_device *dev, void *sa)
983{
984 memcpy(dev->dev_addr, ((struct sockaddr *) sa)->sa_data,
985 dev->addr_len);
986 return 0;
987}
988
989
990static inline void tx_on(struct scc_priv *priv)
991{
992 int i, n;
993 unsigned long flags;
994
995 if (priv->param.dma >= 0) {
996 n = (priv->chip == Z85230) ? 3 : 1;
997 /* Program DMA controller */
998 flags = claim_dma_lock();
999 set_dma_mode(priv->param.dma, DMA_MODE_WRITE);
1000 set_dma_addr(priv->param.dma,
1001 (int) priv->tx_buf[priv->tx_tail] + n);
1002 set_dma_count(priv->param.dma,
1003 priv->tx_len[priv->tx_tail] - n);
1004 release_dma_lock(flags);
1005 /* Enable TX underrun interrupt */
1006 write_scc(priv, R15, TxUIE);
1007 /* Configure DREQ */
1008 if (priv->type == TYPE_TWIN)
1009 outb((priv->param.dma ==
1010 1) ? TWIN_DMA_HDX_T1 : TWIN_DMA_HDX_T3,
1011 priv->card_base + TWIN_DMA_CFG);
1012 else
1013 write_scc(priv, R1,
1014 EXT_INT_ENAB | WT_FN_RDYFN |
1015 WT_RDY_ENAB);
1016 /* Write first byte(s) */
1017 spin_lock_irqsave(priv->register_lock, flags);
1018 for (i = 0; i < n; i++)
1019 write_scc_data(priv,
1020 priv->tx_buf[priv->tx_tail][i], 1);
1021 enable_dma(priv->param.dma);
1022 spin_unlock_irqrestore(priv->register_lock, flags);
1023 } else {
1024 write_scc(priv, R15, TxUIE);
1025 write_scc(priv, R1,
1026 EXT_INT_ENAB | WT_FN_RDYFN | TxINT_ENAB);
1027 tx_isr(priv);
1028 }
1029 /* Reset EOM latch if we do not have the AUTOEOM feature */
1030 if (priv->chip == Z8530)
1031 write_scc(priv, R0, RES_EOM_L);
1032}
1033
1034
1035static inline void rx_on(struct scc_priv *priv)
1036{
1037 unsigned long flags;
1038
1039 /* Clear RX FIFO */
1040 while (read_scc(priv, R0) & Rx_CH_AV)
1041 read_scc_data(priv);
1042 priv->rx_over = 0;
1043 if (priv->param.dma >= 0) {
1044 /* Program DMA controller */
1045 flags = claim_dma_lock();
1046 set_dma_mode(priv->param.dma, DMA_MODE_READ);
1047 set_dma_addr(priv->param.dma,
1048 (int) priv->rx_buf[priv->rx_head]);
1049 set_dma_count(priv->param.dma, BUF_SIZE);
1050 release_dma_lock(flags);
1051 enable_dma(priv->param.dma);
1052 /* Configure PackeTwin DMA */
1053 if (priv->type == TYPE_TWIN) {
1054 outb((priv->param.dma ==
1055 1) ? TWIN_DMA_HDX_R1 : TWIN_DMA_HDX_R3,
1056 priv->card_base + TWIN_DMA_CFG);
1057 }
1058 /* Sp. cond. intr. only, ext int enable, RX DMA enable */
1059 write_scc(priv, R1, EXT_INT_ENAB | INT_ERR_Rx |
1060 WT_RDY_RT | WT_FN_RDYFN | WT_RDY_ENAB);
1061 } else {
1062 /* Reset current frame */
1063 priv->rx_ptr = 0;
1064 /* Intr. on all Rx characters and Sp. cond., ext int enable */
1065 write_scc(priv, R1, EXT_INT_ENAB | INT_ALL_Rx | WT_RDY_RT |
1066 WT_FN_RDYFN);
1067 }
1068 write_scc(priv, R0, ERR_RES);
1069 write_scc(priv, R3, RxENABLE | Rx8 | RxCRC_ENAB);
1070}
1071
1072
1073static inline void rx_off(struct scc_priv *priv)
1074{
1075 /* Disable receiver */
1076 write_scc(priv, R3, Rx8);
1077 /* Disable DREQ / RX interrupt */
1078 if (priv->param.dma >= 0 && priv->type == TYPE_TWIN)
1079 outb(0, priv->card_base + TWIN_DMA_CFG);
1080 else
1081 write_scc(priv, R1, EXT_INT_ENAB | WT_FN_RDYFN);
1082 /* Disable DMA */
1083 if (priv->param.dma >= 0)
1084 disable_dma(priv->param.dma);
1085}
1086
1087
1088static void start_timer(struct scc_priv *priv, int t, int r15)
1089{
1090 unsigned long flags;
1091
1092 outb(priv->tmr_mode, priv->tmr_ctrl);
1093 if (t == 0) {
1094 tm_isr(priv);
1095 } else if (t > 0) {
1096 save_flags(flags);
1097 cli();
1098 outb(t & 0xFF, priv->tmr_cnt);
1099 outb((t >> 8) & 0xFF, priv->tmr_cnt);
1100 if (priv->type != TYPE_TWIN) {
1101 write_scc(priv, R15, r15 | CTSIE);
1102 priv->rr0 |= CTS;
1103 }
1104 restore_flags(flags);
1105 }
1106}
1107
1108
1109static inline unsigned char random(void)
1110{
1111 /* See "Numerical Recipes in C", second edition, p. 284 */
1112 rand = rand * 1664525L + 1013904223L;
1113 return (unsigned char) (rand >> 24);
1114}
1115
1116static inline void z8530_isr(struct scc_info *info)
1117{
1118 int is, i = 100;
1119
1120 while ((is = read_scc(&info->priv[0], R3)) && i--) {
1121 if (is & CHARxIP) {
1122 rx_isr(&info->priv[0]);
1123 } else if (is & CHATxIP) {
1124 tx_isr(&info->priv[0]);
1125 } else if (is & CHAEXT) {
1126 es_isr(&info->priv[0]);
1127 } else if (is & CHBRxIP) {
1128 rx_isr(&info->priv[1]);
1129 } else if (is & CHBTxIP) {
1130 tx_isr(&info->priv[1]);
1131 } else {
1132 es_isr(&info->priv[1]);
1133 }
1134 write_scc(&info->priv[0], R0, RES_H_IUS);
1135 i++;
1136 }
1137 if (i < 0) {
1138 printk(KERN_ERR "dmascc: stuck in ISR with RR3=0x%02x.\n",
1139 is);
1140 }
1141 /* Ok, no interrupts pending from this 8530. The INT line should
1142 be inactive now. */
1143}
1144
1145
1146static irqreturn_t scc_isr(int irq, void *dev_id, struct pt_regs *regs)
1147{
1148 struct scc_info *info = dev_id;
1149
1150 spin_lock(info->priv[0].register_lock);
1151 /* At this point interrupts are enabled, and the interrupt under service
1152 is already acknowledged, but masked off.
1153
1154 Interrupt processing: We loop until we know that the IRQ line is
1155 low. If another positive edge occurs afterwards during the ISR,
1156 another interrupt will be triggered by the interrupt controller
1157 as soon as the IRQ level is enabled again (see asm/irq.h).
1158
1159 Bottom-half handlers will be processed after scc_isr(). This is
1160 important, since we only have small ringbuffers and want new data
1161 to be fetched/delivered immediately. */
1162
1163 if (info->priv[0].type == TYPE_TWIN) {
1164 int is, card_base = info->priv[0].card_base;
1165 while ((is = ~inb(card_base + TWIN_INT_REG)) &
1166 TWIN_INT_MSK) {
1167 if (is & TWIN_SCC_MSK) {
1168 z8530_isr(info);
1169 } else if (is & TWIN_TMR1_MSK) {
1170 inb(card_base + TWIN_CLR_TMR1);
1171 tm_isr(&info->priv[0]);
1172 } else {
1173 inb(card_base + TWIN_CLR_TMR2);
1174 tm_isr(&info->priv[1]);
1175 }
1176 }
1177 } else
1178 z8530_isr(info);
1179 spin_unlock(info->priv[0].register_lock);
1180 return IRQ_HANDLED;
1181}
1182
1183
1184static void rx_isr(struct scc_priv *priv)
1185{
1186 if (priv->param.dma >= 0) {
1187 /* Check special condition and perform error reset. See 2.4.7.5. */
1188 special_condition(priv, read_scc(priv, R1));
1189 write_scc(priv, R0, ERR_RES);
1190 } else {
1191 /* Check special condition for each character. Error reset not necessary.
1192 Same algorithm for SCC and ESCC. See 2.4.7.1 and 2.4.7.4. */
1193 int rc;
1194 while (read_scc(priv, R0) & Rx_CH_AV) {
1195 rc = read_scc(priv, R1);
1196 if (priv->rx_ptr < BUF_SIZE)
1197 priv->rx_buf[priv->rx_head][priv->
1198 rx_ptr++] =
1199 read_scc_data(priv);
1200 else {
1201 priv->rx_over = 2;
1202 read_scc_data(priv);
1203 }
1204 special_condition(priv, rc);
1205 }
1206 }
1207}
1208
1209
1210static void special_condition(struct scc_priv *priv, int rc)
1211{
1212 int cb;
1213 unsigned long flags;
1214
1215 /* See Figure 2-15. Only overrun and EOF need to be checked. */
1216
1217 if (rc & Rx_OVR) {
1218 /* Receiver overrun */
1219 priv->rx_over = 1;
1220 if (priv->param.dma < 0)
1221 write_scc(priv, R0, ERR_RES);
1222 } else if (rc & END_FR) {
1223 /* End of frame. Get byte count */
1224 if (priv->param.dma >= 0) {
1225 flags = claim_dma_lock();
1226 cb = BUF_SIZE - get_dma_residue(priv->param.dma) -
1227 2;
1228 release_dma_lock(flags);
1229 } else {
1230 cb = priv->rx_ptr - 2;
1231 }
1232 if (priv->rx_over) {
1233 /* We had an overrun */
1234 priv->stats.rx_errors++;
1235 if (priv->rx_over == 2)
1236 priv->stats.rx_length_errors++;
1237 else
1238 priv->stats.rx_fifo_errors++;
1239 priv->rx_over = 0;
1240 } else if (rc & CRC_ERR) {
1241 /* Count invalid CRC only if packet length >= minimum */
1242 if (cb >= 15) {
1243 priv->stats.rx_errors++;
1244 priv->stats.rx_crc_errors++;
1245 }
1246 } else {
1247 if (cb >= 15) {
1248 if (priv->rx_count < NUM_RX_BUF - 1) {
1249 /* Put good frame in FIFO */
1250 priv->rx_len[priv->rx_head] = cb;
1251 priv->rx_head =
1252 (priv->rx_head +
1253 1) % NUM_RX_BUF;
1254 priv->rx_count++;
1255 schedule_work(&priv->rx_work);
1256 } else {
1257 priv->stats.rx_errors++;
1258 priv->stats.rx_over_errors++;
1259 }
1260 }
1261 }
1262 /* Get ready for new frame */
1263 if (priv->param.dma >= 0) {
1264 flags = claim_dma_lock();
1265 set_dma_addr(priv->param.dma,
1266 (int) priv->rx_buf[priv->rx_head]);
1267 set_dma_count(priv->param.dma, BUF_SIZE);
1268 release_dma_lock(flags);
1269 } else {
1270 priv->rx_ptr = 0;
1271 }
1272 }
1273}
1274
1275
1276static void rx_bh(void *arg)
1277{
1278 struct scc_priv *priv = arg;
1279 int i = priv->rx_tail;
1280 int cb;
1281 unsigned long flags;
1282 struct sk_buff *skb;
1283 unsigned char *data;
1284
1285 spin_lock_irqsave(&priv->ring_lock, flags);
1286 while (priv->rx_count) {
1287 spin_unlock_irqrestore(&priv->ring_lock, flags);
1288 cb = priv->rx_len[i];
1289 /* Allocate buffer */
1290 skb = dev_alloc_skb(cb + 1);
1291 if (skb == NULL) {
1292 /* Drop packet */
1293 priv->stats.rx_dropped++;
1294 } else {
1295 /* Fill buffer */
1296 data = skb_put(skb, cb + 1);
1297 data[0] = 0;
1298 memcpy(&data[1], priv->rx_buf[i], cb);
Arnaldo Carvalho de Melo56cb5152005-04-24 18:53:06 -07001299 skb->protocol = ax25_type_trans(skb, priv->dev);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001300 netif_rx(skb);
1301 priv->dev->last_rx = jiffies;
1302 priv->stats.rx_packets++;
1303 priv->stats.rx_bytes += cb;
1304 }
1305 spin_lock_irqsave(&priv->ring_lock, flags);
1306 /* Move tail */
1307 priv->rx_tail = i = (i + 1) % NUM_RX_BUF;
1308 priv->rx_count--;
1309 }
1310 spin_unlock_irqrestore(&priv->ring_lock, flags);
1311}
1312
1313
1314static void tx_isr(struct scc_priv *priv)
1315{
1316 int i = priv->tx_tail, p = priv->tx_ptr;
1317
1318 /* Suspend TX interrupts if we don't want to send anything.
1319 See Figure 2-22. */
1320 if (p == priv->tx_len[i]) {
1321 write_scc(priv, R0, RES_Tx_P);
1322 return;
1323 }
1324
1325 /* Write characters */
1326 while ((read_scc(priv, R0) & Tx_BUF_EMP) && p < priv->tx_len[i]) {
1327 write_scc_data(priv, priv->tx_buf[i][p++], 0);
1328 }
1329
1330 /* Reset EOM latch of Z8530 */
1331 if (!priv->tx_ptr && p && priv->chip == Z8530)
1332 write_scc(priv, R0, RES_EOM_L);
1333
1334 priv->tx_ptr = p;
1335}
1336
1337
1338static void es_isr(struct scc_priv *priv)
1339{
1340 int i, rr0, drr0, res;
1341 unsigned long flags;
1342
1343 /* Read status, reset interrupt bit (open latches) */
1344 rr0 = read_scc(priv, R0);
1345 write_scc(priv, R0, RES_EXT_INT);
1346 drr0 = priv->rr0 ^ rr0;
1347 priv->rr0 = rr0;
1348
1349 /* Transmit underrun (2.4.9.6). We can't check the TxEOM flag, since
1350 it might have already been cleared again by AUTOEOM. */
1351 if (priv->state == TX_DATA) {
1352 /* Get remaining bytes */
1353 i = priv->tx_tail;
1354 if (priv->param.dma >= 0) {
1355 disable_dma(priv->param.dma);
1356 flags = claim_dma_lock();
1357 res = get_dma_residue(priv->param.dma);
1358 release_dma_lock(flags);
1359 } else {
1360 res = priv->tx_len[i] - priv->tx_ptr;
1361 priv->tx_ptr = 0;
1362 }
1363 /* Disable DREQ / TX interrupt */
1364 if (priv->param.dma >= 0 && priv->type == TYPE_TWIN)
1365 outb(0, priv->card_base + TWIN_DMA_CFG);
1366 else
1367 write_scc(priv, R1, EXT_INT_ENAB | WT_FN_RDYFN);
1368 if (res) {
1369 /* Update packet statistics */
1370 priv->stats.tx_errors++;
1371 priv->stats.tx_fifo_errors++;
1372 /* Other underrun interrupts may already be waiting */
1373 write_scc(priv, R0, RES_EXT_INT);
1374 write_scc(priv, R0, RES_EXT_INT);
1375 } else {
1376 /* Update packet statistics */
1377 priv->stats.tx_packets++;
1378 priv->stats.tx_bytes += priv->tx_len[i];
1379 /* Remove frame from FIFO */
1380 priv->tx_tail = (i + 1) % NUM_TX_BUF;
1381 priv->tx_count--;
1382 /* Inform upper layers */
1383 netif_wake_queue(priv->dev);
1384 }
1385 /* Switch state */
1386 write_scc(priv, R15, 0);
1387 if (priv->tx_count &&
1388 (jiffies - priv->tx_start) < priv->param.txtimeout) {
1389 priv->state = TX_PAUSE;
1390 start_timer(priv, priv->param.txpause, 0);
1391 } else {
1392 priv->state = TX_TAIL;
1393 start_timer(priv, priv->param.txtail, 0);
1394 }
1395 }
1396
1397 /* DCD transition */
1398 if (drr0 & DCD) {
1399 if (rr0 & DCD) {
1400 switch (priv->state) {
1401 case IDLE:
1402 case WAIT:
1403 priv->state = DCD_ON;
1404 write_scc(priv, R15, 0);
1405 start_timer(priv, priv->param.dcdon, 0);
1406 }
1407 } else {
1408 switch (priv->state) {
1409 case RX_ON:
1410 rx_off(priv);
1411 priv->state = DCD_OFF;
1412 write_scc(priv, R15, 0);
1413 start_timer(priv, priv->param.dcdoff, 0);
1414 }
1415 }
1416 }
1417
1418 /* CTS transition */
1419 if ((drr0 & CTS) && (~rr0 & CTS) && priv->type != TYPE_TWIN)
1420 tm_isr(priv);
1421
1422}
1423
1424
1425static void tm_isr(struct scc_priv *priv)
1426{
1427 switch (priv->state) {
1428 case TX_HEAD:
1429 case TX_PAUSE:
1430 tx_on(priv);
1431 priv->state = TX_DATA;
1432 break;
1433 case TX_TAIL:
1434 write_scc(priv, R5, TxCRC_ENAB | Tx8);
1435 priv->state = RTS_OFF;
1436 if (priv->type != TYPE_TWIN)
1437 write_scc(priv, R15, 0);
1438 start_timer(priv, priv->param.rtsoff, 0);
1439 break;
1440 case RTS_OFF:
1441 write_scc(priv, R15, DCDIE);
1442 priv->rr0 = read_scc(priv, R0);
1443 if (priv->rr0 & DCD) {
1444 priv->stats.collisions++;
1445 rx_on(priv);
1446 priv->state = RX_ON;
1447 } else {
1448 priv->state = WAIT;
1449 start_timer(priv, priv->param.waittime, DCDIE);
1450 }
1451 break;
1452 case WAIT:
1453 if (priv->tx_count) {
1454 priv->state = TX_HEAD;
1455 priv->tx_start = jiffies;
1456 write_scc(priv, R5,
1457 TxCRC_ENAB | RTS | TxENAB | Tx8);
1458 write_scc(priv, R15, 0);
1459 start_timer(priv, priv->param.txdelay, 0);
1460 } else {
1461 priv->state = IDLE;
1462 if (priv->type != TYPE_TWIN)
1463 write_scc(priv, R15, DCDIE);
1464 }
1465 break;
1466 case DCD_ON:
1467 case DCD_OFF:
1468 write_scc(priv, R15, DCDIE);
1469 priv->rr0 = read_scc(priv, R0);
1470 if (priv->rr0 & DCD) {
1471 rx_on(priv);
1472 priv->state = RX_ON;
1473 } else {
1474 priv->state = WAIT;
1475 start_timer(priv,
1476 random() / priv->param.persist *
1477 priv->param.slottime, DCDIE);
1478 }
1479 break;
1480 }
1481}