1 /*****************************************************************************/
4 * yam.c -- YAM radio modem driver.
6 * Copyright (C) 1998 Frederic Rible F1OAT (frible@teaser.fr)
7 * Adapted from baycom.c driver written by Thomas Sailer (sailer@ife.ee.ethz.ch)
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
23 * Please note that the GPL allows you to use the driver, NOT the radio.
24 * In order to use the radio, you need a license from the communications
25 * authority of your country.
29 * 0.0 F1OAT 06.06.98 Begin of work with baycom.c source code V 0.3
30 * 0.1 F1OAT 07.06.98 Add timer polling routine for channel arbitration
31 * 0.2 F6FBB 08.06.98 Added delay after FPGA programming
32 * 0.3 F6FBB 29.07.98 Delayed PTT implementation for dupmode=2
33 * 0.4 F6FBB 30.07.98 Added TxTail, Slottime and Persistance
34 * 0.5 F6FBB 01.08.98 Shared IRQs, /proc/net and network statistics
35 * 0.6 F6FBB 25.08.98 Added 1200Bds format
36 * 0.7 F6FBB 12.09.98 Added to the kernel configuration
37 * 0.8 F6FBB 14.10.98 Fixed slottime/persistence timing bug
38 * OK1ZIA 2.09.01 Fixed "kfree_skb on hard IRQ"
39 * using dev_kfree_skb_any(). (important in 2.4 kernel)
43 /*****************************************************************************/
45 #include <linux/module.h>
46 #include <linux/types.h>
47 #include <linux/net.h>
50 #include <linux/slab.h>
51 #include <linux/errno.h>
52 #include <linux/bitops.h>
53 #include <linux/random.h>
55 #include <asm/system.h>
56 #include <linux/interrupt.h>
57 #include <linux/ioport.h>
59 #include <linux/netdevice.h>
60 #include <linux/if_arp.h>
61 #include <linux/etherdevice.h>
62 #include <linux/skbuff.h>
65 #include <linux/kernel.h>
66 #include <linux/proc_fs.h>
67 #include <linux/seq_file.h>
68 #include <net/net_namespace.h>
70 #include <asm/uaccess.h>
71 #include <linux/init.h>
73 #include <linux/yam.h>
77 /* --------------------------------------------------------------------- */
79 static const char yam_drvname[] = "yam";
80 static char yam_drvinfo[] __initdata = KERN_INFO "YAM driver version 0.8 by F1OAT/F6FBB\n";
82 /* --------------------------------------------------------------------- */
88 #define YAM_MAGIC 0xF10A7654
90 /* Transmitter states */
99 #define YAM_MAX_FRAME 1024
101 #define DEFAULT_BITRATE 9600 /* bps */
102 #define DEFAULT_HOLDD 10 /* sec */
103 #define DEFAULT_TXD 300 /* ms */
104 #define DEFAULT_TXTAIL 10 /* ms */
105 #define DEFAULT_SLOT 100 /* ms */
106 #define DEFAULT_PERS 64 /* 0->255 */
116 struct net_device *dev;
121 /* Parameters section */
123 int txd; /* tx delay */
124 int holdd; /* duplex ptt delay */
125 int txtail; /* txtail delay */
126 int slot; /* slottime */
127 int pers; /* persistence */
134 unsigned char tx_buf[YAM_MAX_FRAME];
136 int tx_crcl, tx_crch;
137 struct sk_buff_head send_queue; /* Packets awaiting transmission */
142 unsigned char rx_buf[YAM_MAX_FRAME];
144 int rx_crcl, rx_crch;
148 unsigned char bits[YAM_FPGA_SIZE];
150 struct yam_mcs *next;
153 static struct net_device *yam_devs[NR_PORTS];
155 static struct yam_mcs *yam_data;
157 static DEFINE_TIMER(yam_timer, NULL, 0, 0);
159 /* --------------------------------------------------------------------- */
161 #define RBR(iobase) (iobase+0)
162 #define THR(iobase) (iobase+0)
163 #define IER(iobase) (iobase+1)
164 #define IIR(iobase) (iobase+2)
165 #define FCR(iobase) (iobase+2)
166 #define LCR(iobase) (iobase+3)
167 #define MCR(iobase) (iobase+4)
168 #define LSR(iobase) (iobase+5)
169 #define MSR(iobase) (iobase+6)
170 #define SCR(iobase) (iobase+7)
171 #define DLL(iobase) (iobase+0)
172 #define DLM(iobase) (iobase+1)
176 /* Interrupt Identification Register Bit Masks */
182 #define IIR_TIMEOUT 12 /* Fifo mode only */
184 #define IIR_MASK 0x0F
186 /* Interrupt Enable Register Bit Masks */
187 #define IER_RX 1 /* enable rx interrupt */
188 #define IER_TX 2 /* enable tx interrupt */
189 #define IER_LSR 4 /* enable line status interrupts */
190 #define IER_MSR 8 /* enable modem status interrupts */
192 /* Modem Control Register Bit Masks */
193 #define MCR_DTR 0x01 /* DTR output */
194 #define MCR_RTS 0x02 /* RTS output */
195 #define MCR_OUT1 0x04 /* OUT1 output (not accessible in RS232) */
196 #define MCR_OUT2 0x08 /* Master Interrupt enable (must be set on PCs) */
197 #define MCR_LOOP 0x10 /* Loopback enable */
199 /* Modem Status Register Bit Masks */
200 #define MSR_DCTS 0x01 /* Delta CTS input */
201 #define MSR_DDSR 0x02 /* Delta DSR */
202 #define MSR_DRIN 0x04 /* Delta RI */
203 #define MSR_DDCD 0x08 /* Delta DCD */
204 #define MSR_CTS 0x10 /* CTS input */
205 #define MSR_DSR 0x20 /* DSR input */
206 #define MSR_RING 0x40 /* RI input */
207 #define MSR_DCD 0x80 /* DCD input */
209 /* line status register bit mask */
214 #define LSR_BREAK 0x10
215 #define LSR_THRE 0x20
216 #define LSR_TSRE 0x40
218 /* Line Control Register Bit Masks */
219 #define LCR_DLAB 0x80
220 #define LCR_BREAK 0x40
221 #define LCR_PZERO 0x28
222 #define LCR_PEVEN 0x18
223 #define LCR_PODD 0x08
224 #define LCR_STOP1 0x00
225 #define LCR_STOP2 0x04
226 #define LCR_BIT5 0x00
227 #define LCR_BIT6 0x02
228 #define LCR_BIT7 0x01
229 #define LCR_BIT8 0x03
231 /* YAM Modem <-> UART Port mapping */
233 #define TX_RDY MSR_DCTS /* transmitter ready to send */
234 #define RX_DCD MSR_DCD /* carrier detect */
235 #define RX_FLAG MSR_RING /* hdlc flag received */
236 #define FPGA_DONE MSR_DSR /* FPGA is configured */
237 #define PTT_ON (MCR_RTS|MCR_OUT2) /* activate PTT */
238 #define PTT_OFF (MCR_DTR|MCR_OUT2) /* release PTT */
240 #define ENABLE_RXINT IER_RX /* enable uart rx interrupt during rx */
241 #define ENABLE_TXINT IER_MSR /* enable uart ms interrupt during tx */
242 #define ENABLE_RTXINT (IER_RX|IER_MSR) /* full duplex operations */
245 /*************************************************************************
247 ************************************************************************/
249 static const unsigned char chktabl[256] =
250 {0x00, 0x89, 0x12, 0x9b, 0x24, 0xad, 0x36, 0xbf, 0x48, 0xc1, 0x5a, 0xd3, 0x6c, 0xe5, 0x7e,
251 0xf7, 0x81, 0x08, 0x93, 0x1a, 0xa5, 0x2c, 0xb7, 0x3e, 0xc9, 0x40, 0xdb, 0x52, 0xed, 0x64,
252 0xff, 0x76, 0x02, 0x8b, 0x10, 0x99, 0x26, 0xaf, 0x34, 0xbd, 0x4a, 0xc3, 0x58, 0xd1, 0x6e,
253 0xe7, 0x7c, 0xf5, 0x83, 0x0a, 0x91, 0x18, 0xa7, 0x2e, 0xb5, 0x3c, 0xcb, 0x42, 0xd9, 0x50,
254 0xef, 0x66, 0xfd, 0x74, 0x04, 0x8d, 0x16, 0x9f, 0x20, 0xa9, 0x32, 0xbb, 0x4c, 0xc5, 0x5e,
255 0xd7, 0x68, 0xe1, 0x7a, 0xf3, 0x85, 0x0c, 0x97, 0x1e, 0xa1, 0x28, 0xb3, 0x3a, 0xcd, 0x44,
256 0xdf, 0x56, 0xe9, 0x60, 0xfb, 0x72, 0x06, 0x8f, 0x14, 0x9d, 0x22, 0xab, 0x30, 0xb9, 0x4e,
257 0xc7, 0x5c, 0xd5, 0x6a, 0xe3, 0x78, 0xf1, 0x87, 0x0e, 0x95, 0x1c, 0xa3, 0x2a, 0xb1, 0x38,
258 0xcf, 0x46, 0xdd, 0x54, 0xeb, 0x62, 0xf9, 0x70, 0x08, 0x81, 0x1a, 0x93, 0x2c, 0xa5, 0x3e,
259 0xb7, 0x40, 0xc9, 0x52, 0xdb, 0x64, 0xed, 0x76, 0xff, 0x89, 0x00, 0x9b, 0x12, 0xad, 0x24,
260 0xbf, 0x36, 0xc1, 0x48, 0xd3, 0x5a, 0xe5, 0x6c, 0xf7, 0x7e, 0x0a, 0x83, 0x18, 0x91, 0x2e,
261 0xa7, 0x3c, 0xb5, 0x42, 0xcb, 0x50, 0xd9, 0x66, 0xef, 0x74, 0xfd, 0x8b, 0x02, 0x99, 0x10,
262 0xaf, 0x26, 0xbd, 0x34, 0xc3, 0x4a, 0xd1, 0x58, 0xe7, 0x6e, 0xf5, 0x7c, 0x0c, 0x85, 0x1e,
263 0x97, 0x28, 0xa1, 0x3a, 0xb3, 0x44, 0xcd, 0x56, 0xdf, 0x60, 0xe9, 0x72, 0xfb, 0x8d, 0x04,
264 0x9f, 0x16, 0xa9, 0x20, 0xbb, 0x32, 0xc5, 0x4c, 0xd7, 0x5e, 0xe1, 0x68, 0xf3, 0x7a, 0x0e,
265 0x87, 0x1c, 0x95, 0x2a, 0xa3, 0x38, 0xb1, 0x46, 0xcf, 0x54, 0xdd, 0x62, 0xeb, 0x70, 0xf9,
266 0x8f, 0x06, 0x9d, 0x14, 0xab, 0x22, 0xb9, 0x30, 0xc7, 0x4e, 0xd5, 0x5c, 0xe3, 0x6a, 0xf1,
268 static const unsigned char chktabh[256] =
269 {0x00, 0x11, 0x23, 0x32, 0x46, 0x57, 0x65, 0x74, 0x8c, 0x9d, 0xaf, 0xbe, 0xca, 0xdb, 0xe9,
270 0xf8, 0x10, 0x01, 0x33, 0x22, 0x56, 0x47, 0x75, 0x64, 0x9c, 0x8d, 0xbf, 0xae, 0xda, 0xcb,
271 0xf9, 0xe8, 0x21, 0x30, 0x02, 0x13, 0x67, 0x76, 0x44, 0x55, 0xad, 0xbc, 0x8e, 0x9f, 0xeb,
272 0xfa, 0xc8, 0xd9, 0x31, 0x20, 0x12, 0x03, 0x77, 0x66, 0x54, 0x45, 0xbd, 0xac, 0x9e, 0x8f,
273 0xfb, 0xea, 0xd8, 0xc9, 0x42, 0x53, 0x61, 0x70, 0x04, 0x15, 0x27, 0x36, 0xce, 0xdf, 0xed,
274 0xfc, 0x88, 0x99, 0xab, 0xba, 0x52, 0x43, 0x71, 0x60, 0x14, 0x05, 0x37, 0x26, 0xde, 0xcf,
275 0xfd, 0xec, 0x98, 0x89, 0xbb, 0xaa, 0x63, 0x72, 0x40, 0x51, 0x25, 0x34, 0x06, 0x17, 0xef,
276 0xfe, 0xcc, 0xdd, 0xa9, 0xb8, 0x8a, 0x9b, 0x73, 0x62, 0x50, 0x41, 0x35, 0x24, 0x16, 0x07,
277 0xff, 0xee, 0xdc, 0xcd, 0xb9, 0xa8, 0x9a, 0x8b, 0x84, 0x95, 0xa7, 0xb6, 0xc2, 0xd3, 0xe1,
278 0xf0, 0x08, 0x19, 0x2b, 0x3a, 0x4e, 0x5f, 0x6d, 0x7c, 0x94, 0x85, 0xb7, 0xa6, 0xd2, 0xc3,
279 0xf1, 0xe0, 0x18, 0x09, 0x3b, 0x2a, 0x5e, 0x4f, 0x7d, 0x6c, 0xa5, 0xb4, 0x86, 0x97, 0xe3,
280 0xf2, 0xc0, 0xd1, 0x29, 0x38, 0x0a, 0x1b, 0x6f, 0x7e, 0x4c, 0x5d, 0xb5, 0xa4, 0x96, 0x87,
281 0xf3, 0xe2, 0xd0, 0xc1, 0x39, 0x28, 0x1a, 0x0b, 0x7f, 0x6e, 0x5c, 0x4d, 0xc6, 0xd7, 0xe5,
282 0xf4, 0x80, 0x91, 0xa3, 0xb2, 0x4a, 0x5b, 0x69, 0x78, 0x0c, 0x1d, 0x2f, 0x3e, 0xd6, 0xc7,
283 0xf5, 0xe4, 0x90, 0x81, 0xb3, 0xa2, 0x5a, 0x4b, 0x79, 0x68, 0x1c, 0x0d, 0x3f, 0x2e, 0xe7,
284 0xf6, 0xc4, 0xd5, 0xa1, 0xb0, 0x82, 0x93, 0x6b, 0x7a, 0x48, 0x59, 0x2d, 0x3c, 0x0e, 0x1f,
285 0xf7, 0xe6, 0xd4, 0xc5, 0xb1, 0xa0, 0x92, 0x83, 0x7b, 0x6a, 0x58, 0x49, 0x3d, 0x2c, 0x1e,
288 /*************************************************************************
290 ************************************************************************/
292 static void delay(int ms)
294 unsigned long timeout = jiffies + ((ms * HZ) / 1000);
295 while (time_before(jiffies, timeout))
303 static void fpga_reset(int iobase)
305 outb(0, IER(iobase));
306 outb(LCR_DLAB | LCR_BIT5, LCR(iobase));
307 outb(1, DLL(iobase));
308 outb(0, DLM(iobase));
310 outb(LCR_BIT5, LCR(iobase));
313 /* turn off FPGA supply voltage */
314 outb(MCR_OUT1 | MCR_OUT2, MCR(iobase));
316 /* turn on FPGA supply voltage again */
317 outb(MCR_DTR | MCR_RTS | MCR_OUT1 | MCR_OUT2, MCR(iobase));
322 * send one byte to FPGA
325 static int fpga_write(int iobase, unsigned char wrd)
329 unsigned long timeout = jiffies + HZ / 10;
331 for (k = 0; k < 8; k++) {
332 bit = (wrd & 0x80) ? (MCR_RTS | MCR_DTR) : MCR_DTR;
333 outb(bit | MCR_OUT1 | MCR_OUT2, MCR(iobase));
335 outb(0xfc, THR(iobase));
336 while ((inb(LSR(iobase)) & LSR_TSRE) == 0)
337 if (time_after(jiffies, timeout))
344 static unsigned char *add_mcs(unsigned char *bits, int bitrate)
348 /* If it already exists, replace the bit data */
351 if (p->bitrate == bitrate) {
352 memcpy(p->bits, bits, YAM_FPGA_SIZE);
358 /* Allocate a new mcs */
359 if ((p = kmalloc(sizeof(struct yam_mcs), GFP_KERNEL)) == NULL) {
360 printk(KERN_WARNING "YAM: no memory to allocate mcs\n");
363 memcpy(p->bits, bits, YAM_FPGA_SIZE);
364 p->bitrate = bitrate;
371 static unsigned char *get_mcs(int bitrate)
377 if (p->bitrate == bitrate)
382 /* Load predefined mcs data */
385 return add_mcs(bits_1200, bitrate);
387 return add_mcs(bits_9600, bitrate);
392 * download bitstream to FPGA
393 * data is contained in bits[] array in yam1200.h resp. yam9600.h
396 static int fpga_download(int iobase, int bitrate)
399 unsigned char *pbits;
401 pbits = get_mcs(bitrate);
406 for (i = 0; i < YAM_FPGA_SIZE; i++) {
407 if (fpga_write(iobase, pbits[i])) {
408 printk(KERN_ERR "yam: error in write cycle\n");
409 return -1; /* write... */
413 fpga_write(iobase, 0xFF);
414 rc = inb(MSR(iobase)); /* check DONE signal */
416 /* Needed for some hardwares */
419 return (rc & MSR_DSR) ? 0 : -1;
423 /************************************************************************
425 ************************************************************************/
427 static void yam_set_uart(struct net_device *dev)
429 struct yam_port *yp = netdev_priv(dev);
430 int divisor = 115200 / yp->baudrate;
432 outb(0, IER(dev->base_addr));
433 outb(LCR_DLAB | LCR_BIT8, LCR(dev->base_addr));
434 outb(divisor, DLL(dev->base_addr));
435 outb(0, DLM(dev->base_addr));
436 outb(LCR_BIT8, LCR(dev->base_addr));
437 outb(PTT_OFF, MCR(dev->base_addr));
438 outb(0x00, FCR(dev->base_addr));
440 /* Flush pending irq */
442 inb(RBR(dev->base_addr));
443 inb(MSR(dev->base_addr));
447 outb(ENABLE_RTXINT, IER(dev->base_addr));
451 /* --------------------------------------------------------------------- */
454 c_uart_unknown, c_uart_8250,
455 c_uart_16450, c_uart_16550, c_uart_16550A
458 static const char *uart_str[] =
459 {"unknown", "8250", "16450", "16550", "16550A"};
461 static enum uart yam_check_uart(unsigned int iobase)
463 unsigned char b1, b2, b3;
465 enum uart uart_tab[] =
466 {c_uart_16450, c_uart_unknown, c_uart_16550, c_uart_16550A};
468 b1 = inb(MCR(iobase));
469 outb(b1 | 0x10, MCR(iobase)); /* loopback mode */
470 b2 = inb(MSR(iobase));
471 outb(0x1a, MCR(iobase));
472 b3 = inb(MSR(iobase)) & 0xf0;
473 outb(b1, MCR(iobase)); /* restore old values */
474 outb(b2, MSR(iobase));
476 return c_uart_unknown;
479 outb(0x01, FCR(iobase)); /* enable FIFOs */
480 u = uart_tab[(inb(IIR(iobase)) >> 6) & 3];
481 if (u == c_uart_16450) {
482 outb(0x5a, SCR(iobase));
483 b1 = inb(SCR(iobase));
484 outb(0xa5, SCR(iobase));
485 b2 = inb(SCR(iobase));
486 if ((b1 != 0x5a) || (b2 != 0xa5))
492 /******************************************************************************
494 ******************************************************************************/
495 static inline void yam_rx_flag(struct net_device *dev, struct yam_port *yp)
497 if (yp->dcd && yp->rx_len >= 3 && yp->rx_len < YAM_MAX_FRAME) {
498 int pkt_len = yp->rx_len - 2 + 1; /* -CRC + kiss */
501 if ((yp->rx_crch & yp->rx_crcl) != 0xFF) {
504 if (!(skb = dev_alloc_skb(pkt_len))) {
505 printk(KERN_WARNING "%s: memory squeeze, dropping packet\n", dev->name);
506 ++dev->stats.rx_dropped;
509 cp = skb_put(skb, pkt_len);
510 *cp++ = 0; /* KISS kludge */
511 memcpy(cp, yp->rx_buf, pkt_len - 1);
512 skb->protocol = ax25_type_trans(skb, dev);
514 ++dev->stats.rx_packets;
523 static inline void yam_rx_byte(struct net_device *dev, struct yam_port *yp, unsigned char rxb)
525 if (yp->rx_len < YAM_MAX_FRAME) {
526 unsigned char c = yp->rx_crcl;
527 yp->rx_crcl = (chktabl[c] ^ yp->rx_crch);
528 yp->rx_crch = (chktabh[c] ^ rxb);
529 yp->rx_buf[yp->rx_len++] = rxb;
533 /********************************************************************************
535 ********************************************************************************/
537 static void ptt_on(struct net_device *dev)
539 outb(PTT_ON, MCR(dev->base_addr));
542 static void ptt_off(struct net_device *dev)
544 outb(PTT_OFF, MCR(dev->base_addr));
547 static int yam_send_packet(struct sk_buff *skb, struct net_device *dev)
549 struct yam_port *yp = netdev_priv(dev);
551 skb_queue_tail(&yp->send_queue, skb);
552 dev->trans_start = jiffies;
556 static void yam_start_tx(struct net_device *dev, struct yam_port *yp)
558 if ((yp->tx_state == TX_TAIL) || (yp->txd == 0))
561 yp->tx_count = (yp->bitrate * yp->txd) / 8000;
562 yp->tx_state = TX_HEAD;
566 static void yam_arbitrate(struct net_device *dev)
568 struct yam_port *yp = netdev_priv(dev);
570 if (yp->magic != YAM_MAGIC || yp->tx_state != TX_OFF ||
571 skb_queue_empty(&yp->send_queue))
573 /* tx_state is TX_OFF and there is data to send */
576 /* Full duplex mode, don't wait */
577 yam_start_tx(dev, yp);
581 /* DCD on, wait slotime ... */
582 yp->slotcnt = yp->slot / 10;
585 /* Is slottime passed ? */
586 if ((--yp->slotcnt) > 0)
589 yp->slotcnt = yp->slot / 10;
591 /* is random > persist ? */
592 if ((random32() % 256) > yp->pers)
595 yam_start_tx(dev, yp);
598 static void yam_dotimer(unsigned long dummy)
602 for (i = 0; i < NR_PORTS; i++) {
603 struct net_device *dev = yam_devs[i];
604 if (dev && netif_running(dev))
607 yam_timer.expires = jiffies + HZ / 100;
608 add_timer(&yam_timer);
611 static void yam_tx_byte(struct net_device *dev, struct yam_port *yp)
614 unsigned char b, temp;
616 switch (yp->tx_state) {
620 if (--yp->tx_count <= 0) {
621 if (!(skb = skb_dequeue(&yp->send_queue))) {
623 yp->tx_state = TX_OFF;
626 yp->tx_state = TX_DATA;
627 if (skb->data[0] != 0) {
628 /* do_kiss_params(s, skb->data, skb->len); */
629 dev_kfree_skb_any(skb);
632 yp->tx_len = skb->len - 1; /* strip KISS byte */
633 if (yp->tx_len >= YAM_MAX_FRAME || yp->tx_len < 2) {
634 dev_kfree_skb_any(skb);
637 skb_copy_from_linear_data_offset(skb, 1,
640 dev_kfree_skb_any(skb);
644 yp->tx_state = TX_DATA;
648 b = yp->tx_buf[yp->tx_count++];
649 outb(b, THR(dev->base_addr));
651 yp->tx_crcl = chktabl[temp] ^ yp->tx_crch;
652 yp->tx_crch = chktabh[temp] ^ b;
653 if (yp->tx_count >= yp->tx_len) {
654 yp->tx_state = TX_CRC1;
658 yp->tx_crch = chktabl[yp->tx_crcl] ^ yp->tx_crch;
659 yp->tx_crcl = chktabh[yp->tx_crcl] ^ chktabl[yp->tx_crch] ^ 0xff;
660 outb(yp->tx_crcl, THR(dev->base_addr));
661 yp->tx_state = TX_CRC2;
664 outb(chktabh[yp->tx_crch] ^ 0xFF, THR(dev->base_addr));
665 if (skb_queue_empty(&yp->send_queue)) {
666 yp->tx_count = (yp->bitrate * yp->txtail) / 8000;
667 if (yp->dupmode == 2)
668 yp->tx_count += (yp->bitrate * yp->holdd) / 8;
669 if (yp->tx_count == 0)
671 yp->tx_state = TX_TAIL;
674 yp->tx_state = TX_HEAD;
676 ++dev->stats.tx_packets;
679 if (--yp->tx_count <= 0) {
680 yp->tx_state = TX_OFF;
687 /***********************************************************************************
689 ************************************************************************************/
691 static irqreturn_t yam_interrupt(int irq, void *dev_id)
693 struct net_device *dev;
700 for (i = 0; i < NR_PORTS; i++) {
702 yp = netdev_priv(dev);
704 if (!netif_running(dev))
707 while ((iir = IIR_MASK & inb(IIR(dev->base_addr))) != IIR_NOPEND) {
708 unsigned char msr = inb(MSR(dev->base_addr));
709 unsigned char lsr = inb(LSR(dev->base_addr));
715 ++dev->stats.rx_fifo_errors;
717 yp->dcd = (msr & RX_DCD) ? 1 : 0;
719 if (--counter <= 0) {
720 printk(KERN_ERR "%s: too many irq iir=%d\n",
726 yam_tx_byte(dev, yp);
730 rxb = inb(RBR(dev->base_addr));
732 yam_rx_flag(dev, yp);
734 yam_rx_byte(dev, yp, rxb);
739 return IRQ_RETVAL(handled);
742 #ifdef CONFIG_PROC_FS
744 static void *yam_seq_start(struct seq_file *seq, loff_t *pos)
746 return (*pos < NR_PORTS) ? yam_devs[*pos] : NULL;
749 static void *yam_seq_next(struct seq_file *seq, void *v, loff_t *pos)
752 return (*pos < NR_PORTS) ? yam_devs[*pos] : NULL;
755 static void yam_seq_stop(struct seq_file *seq, void *v)
759 static int yam_seq_show(struct seq_file *seq, void *v)
761 struct net_device *dev = v;
762 const struct yam_port *yp = netdev_priv(dev);
764 seq_printf(seq, "Device %s\n", dev->name);
765 seq_printf(seq, " Up %d\n", netif_running(dev));
766 seq_printf(seq, " Speed %u\n", yp->bitrate);
767 seq_printf(seq, " IoBase 0x%x\n", yp->iobase);
768 seq_printf(seq, " BaudRate %u\n", yp->baudrate);
769 seq_printf(seq, " IRQ %u\n", yp->irq);
770 seq_printf(seq, " TxState %u\n", yp->tx_state);
771 seq_printf(seq, " Duplex %u\n", yp->dupmode);
772 seq_printf(seq, " HoldDly %u\n", yp->holdd);
773 seq_printf(seq, " TxDelay %u\n", yp->txd);
774 seq_printf(seq, " TxTail %u\n", yp->txtail);
775 seq_printf(seq, " SlotTime %u\n", yp->slot);
776 seq_printf(seq, " Persist %u\n", yp->pers);
777 seq_printf(seq, " TxFrames %lu\n", dev->stats.tx_packets);
778 seq_printf(seq, " RxFrames %lu\n", dev->stats.rx_packets);
779 seq_printf(seq, " TxInt %u\n", yp->nb_mdint);
780 seq_printf(seq, " RxInt %u\n", yp->nb_rxint);
781 seq_printf(seq, " RxOver %lu\n", dev->stats.rx_fifo_errors);
782 seq_printf(seq, "\n");
786 static const struct seq_operations yam_seqops = {
787 .start = yam_seq_start,
788 .next = yam_seq_next,
789 .stop = yam_seq_stop,
790 .show = yam_seq_show,
793 static int yam_info_open(struct inode *inode, struct file *file)
795 return seq_open(file, &yam_seqops);
798 static const struct file_operations yam_info_fops = {
799 .owner = THIS_MODULE,
800 .open = yam_info_open,
803 .release = seq_release,
809 /* --------------------------------------------------------------------- */
811 static int yam_open(struct net_device *dev)
813 struct yam_port *yp = netdev_priv(dev);
818 printk(KERN_INFO "Trying %s at iobase 0x%lx irq %u\n", dev->name, dev->base_addr, dev->irq);
820 if (!dev || !yp->bitrate)
822 if (!dev->base_addr || dev->base_addr > 0x1000 - YAM_EXTENT ||
823 dev->irq < 2 || dev->irq > 15) {
826 if (!request_region(dev->base_addr, YAM_EXTENT, dev->name))
828 printk(KERN_ERR "%s: cannot 0x%lx busy\n", dev->name, dev->base_addr);
831 if ((u = yam_check_uart(dev->base_addr)) == c_uart_unknown) {
832 printk(KERN_ERR "%s: cannot find uart type\n", dev->name);
834 goto out_release_base;
836 if (fpga_download(dev->base_addr, yp->bitrate)) {
837 printk(KERN_ERR "%s: cannot init FPGA\n", dev->name);
839 goto out_release_base;
841 outb(0, IER(dev->base_addr));
842 if (request_irq(dev->irq, yam_interrupt, IRQF_DISABLED | IRQF_SHARED, dev->name, dev)) {
843 printk(KERN_ERR "%s: irq %d busy\n", dev->name, dev->irq);
845 goto out_release_base;
850 netif_start_queue(dev);
852 yp->slotcnt = yp->slot / 10;
854 /* Reset overruns for all ports - FPGA programming makes overruns */
855 for (i = 0; i < NR_PORTS; i++) {
856 struct net_device *dev = yam_devs[i];
858 inb(LSR(dev->base_addr));
859 dev->stats.rx_fifo_errors = 0;
862 printk(KERN_INFO "%s at iobase 0x%lx irq %u uart %s\n", dev->name, dev->base_addr, dev->irq,
867 release_region(dev->base_addr, YAM_EXTENT);
871 /* --------------------------------------------------------------------- */
873 static int yam_close(struct net_device *dev)
876 struct yam_port *yp = netdev_priv(dev);
884 outb(0, IER(dev->base_addr));
885 outb(1, MCR(dev->base_addr));
886 /* Remove IRQ handler if last */
887 free_irq(dev->irq,dev);
888 release_region(dev->base_addr, YAM_EXTENT);
889 netif_stop_queue(dev);
890 while ((skb = skb_dequeue(&yp->send_queue)))
893 printk(KERN_INFO "%s: close yam at iobase 0x%lx irq %u\n",
894 yam_drvname, dev->base_addr, dev->irq);
898 /* --------------------------------------------------------------------- */
900 static int yam_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
902 struct yam_port *yp = netdev_priv(dev);
903 struct yamdrv_ioctl_cfg yi;
904 struct yamdrv_ioctl_mcs *ym;
907 if (copy_from_user(&ioctl_cmd, ifr->ifr_data, sizeof(int)))
910 if (yp->magic != YAM_MAGIC)
913 if (!capable(CAP_NET_ADMIN))
916 if (cmd != SIOCDEVPRIVATE)
921 case SIOCYAMRESERVED:
922 return -EINVAL; /* unused */
925 if (netif_running(dev))
926 return -EINVAL; /* Cannot change this parameter when up */
927 if ((ym = kmalloc(sizeof(struct yamdrv_ioctl_mcs), GFP_KERNEL)) == NULL)
930 if (copy_from_user(ym, ifr->ifr_data, sizeof(struct yamdrv_ioctl_mcs))) {
934 if (ym->bitrate > YAM_MAXBITRATE) {
938 add_mcs(ym->bits, ym->bitrate);
943 if (!capable(CAP_SYS_RAWIO))
945 if (copy_from_user(&yi, ifr->ifr_data, sizeof(struct yamdrv_ioctl_cfg)))
948 if ((yi.cfg.mask & YAM_IOBASE) && netif_running(dev))
949 return -EINVAL; /* Cannot change this parameter when up */
950 if ((yi.cfg.mask & YAM_IRQ) && netif_running(dev))
951 return -EINVAL; /* Cannot change this parameter when up */
952 if ((yi.cfg.mask & YAM_BITRATE) && netif_running(dev))
953 return -EINVAL; /* Cannot change this parameter when up */
954 if ((yi.cfg.mask & YAM_BAUDRATE) && netif_running(dev))
955 return -EINVAL; /* Cannot change this parameter when up */
957 if (yi.cfg.mask & YAM_IOBASE) {
958 yp->iobase = yi.cfg.iobase;
959 dev->base_addr = yi.cfg.iobase;
961 if (yi.cfg.mask & YAM_IRQ) {
964 yp->irq = yi.cfg.irq;
965 dev->irq = yi.cfg.irq;
967 if (yi.cfg.mask & YAM_BITRATE) {
968 if (yi.cfg.bitrate > YAM_MAXBITRATE)
970 yp->bitrate = yi.cfg.bitrate;
972 if (yi.cfg.mask & YAM_BAUDRATE) {
973 if (yi.cfg.baudrate > YAM_MAXBAUDRATE)
975 yp->baudrate = yi.cfg.baudrate;
977 if (yi.cfg.mask & YAM_MODE) {
978 if (yi.cfg.mode > YAM_MAXMODE)
980 yp->dupmode = yi.cfg.mode;
982 if (yi.cfg.mask & YAM_HOLDDLY) {
983 if (yi.cfg.holddly > YAM_MAXHOLDDLY)
985 yp->holdd = yi.cfg.holddly;
987 if (yi.cfg.mask & YAM_TXDELAY) {
988 if (yi.cfg.txdelay > YAM_MAXTXDELAY)
990 yp->txd = yi.cfg.txdelay;
992 if (yi.cfg.mask & YAM_TXTAIL) {
993 if (yi.cfg.txtail > YAM_MAXTXTAIL)
995 yp->txtail = yi.cfg.txtail;
997 if (yi.cfg.mask & YAM_PERSIST) {
998 if (yi.cfg.persist > YAM_MAXPERSIST)
1000 yp->pers = yi.cfg.persist;
1002 if (yi.cfg.mask & YAM_SLOTTIME) {
1003 if (yi.cfg.slottime > YAM_MAXSLOTTIME)
1005 yp->slot = yi.cfg.slottime;
1006 yp->slotcnt = yp->slot / 10;
1011 yi.cfg.mask = 0xffffffff;
1012 yi.cfg.iobase = yp->iobase;
1013 yi.cfg.irq = yp->irq;
1014 yi.cfg.bitrate = yp->bitrate;
1015 yi.cfg.baudrate = yp->baudrate;
1016 yi.cfg.mode = yp->dupmode;
1017 yi.cfg.txdelay = yp->txd;
1018 yi.cfg.holddly = yp->holdd;
1019 yi.cfg.txtail = yp->txtail;
1020 yi.cfg.persist = yp->pers;
1021 yi.cfg.slottime = yp->slot;
1022 if (copy_to_user(ifr->ifr_data, &yi, sizeof(struct yamdrv_ioctl_cfg)))
1034 /* --------------------------------------------------------------------- */
1036 static int yam_set_mac_address(struct net_device *dev, void *addr)
1038 struct sockaddr *sa = (struct sockaddr *) addr;
1040 /* addr is an AX.25 shifted ASCII mac address */
1041 memcpy(dev->dev_addr, sa->sa_data, dev->addr_len);
1045 /* --------------------------------------------------------------------- */
1047 static const struct net_device_ops yam_netdev_ops = {
1048 .ndo_open = yam_open,
1049 .ndo_stop = yam_close,
1050 .ndo_start_xmit = yam_send_packet,
1051 .ndo_do_ioctl = yam_ioctl,
1052 .ndo_set_mac_address = yam_set_mac_address,
1055 static void yam_setup(struct net_device *dev)
1057 struct yam_port *yp = netdev_priv(dev);
1059 yp->magic = YAM_MAGIC;
1060 yp->bitrate = DEFAULT_BITRATE;
1061 yp->baudrate = DEFAULT_BITRATE * 2;
1065 yp->holdd = DEFAULT_HOLDD;
1066 yp->txd = DEFAULT_TXD;
1067 yp->txtail = DEFAULT_TXTAIL;
1068 yp->slot = DEFAULT_SLOT;
1069 yp->pers = DEFAULT_PERS;
1072 dev->base_addr = yp->iobase;
1075 skb_queue_head_init(&yp->send_queue);
1077 dev->netdev_ops = &yam_netdev_ops;
1078 dev->header_ops = &ax25_header_ops;
1080 dev->type = ARPHRD_AX25;
1081 dev->hard_header_len = AX25_MAX_HEADER_LEN;
1082 dev->mtu = AX25_MTU;
1083 dev->addr_len = AX25_ADDR_LEN;
1084 memcpy(dev->broadcast, &ax25_bcast, AX25_ADDR_LEN);
1085 memcpy(dev->dev_addr, &ax25_defaddr, AX25_ADDR_LEN);
1088 static int __init yam_init_driver(void)
1090 struct net_device *dev;
1092 char name[IFNAMSIZ];
1094 printk(yam_drvinfo);
1096 for (i = 0; i < NR_PORTS; i++) {
1097 sprintf(name, "yam%d", i);
1099 dev = alloc_netdev(sizeof(struct yam_port), name,
1102 printk(KERN_ERR "yam: cannot allocate net device %s\n",
1108 err = register_netdev(dev);
1110 printk(KERN_WARNING "yam: cannot register net device %s\n", dev->name);
1117 yam_timer.function = yam_dotimer;
1118 yam_timer.expires = jiffies + HZ / 100;
1119 add_timer(&yam_timer);
1121 proc_net_fops_create(&init_net, "yam", S_IRUGO, &yam_info_fops);
1125 unregister_netdev(yam_devs[i]);
1126 free_netdev(yam_devs[i]);
1131 /* --------------------------------------------------------------------- */
1133 static void __exit yam_cleanup_driver(void)
1138 del_timer(&yam_timer);
1139 for (i = 0; i < NR_PORTS; i++) {
1140 struct net_device *dev = yam_devs[i];
1142 unregister_netdev(dev);
1149 yam_data = yam_data->next;
1153 proc_net_remove(&init_net, "yam");
1156 /* --------------------------------------------------------------------- */
1158 MODULE_AUTHOR("Frederic Rible F1OAT frible@teaser.fr");
1159 MODULE_DESCRIPTION("Yam amateur radio modem driver");
1160 MODULE_LICENSE("GPL");
1162 module_init(yam_init_driver);
1163 module_exit(yam_cleanup_driver);
1165 /* --------------------------------------------------------------------- */