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
;
120 struct net_device_stats stats
;
125 /* Parameters section */
127 int txd
; /* tx delay */
128 int holdd
; /* duplex ptt delay */
129 int txtail
; /* txtail delay */
130 int slot
; /* slottime */
131 int pers
; /* persistence */
138 unsigned char tx_buf
[YAM_MAX_FRAME
];
140 int tx_crcl
, tx_crch
;
141 struct sk_buff_head send_queue
; /* Packets awaiting transmission */
146 unsigned char rx_buf
[YAM_MAX_FRAME
];
148 int rx_crcl
, rx_crch
;
152 unsigned char bits
[YAM_FPGA_SIZE
];
154 struct yam_mcs
*next
;
157 static struct net_device
*yam_devs
[NR_PORTS
];
159 static struct yam_mcs
*yam_data
;
161 static DEFINE_TIMER(yam_timer
, NULL
, 0, 0);
163 /* --------------------------------------------------------------------- */
165 #define RBR(iobase) (iobase+0)
166 #define THR(iobase) (iobase+0)
167 #define IER(iobase) (iobase+1)
168 #define IIR(iobase) (iobase+2)
169 #define FCR(iobase) (iobase+2)
170 #define LCR(iobase) (iobase+3)
171 #define MCR(iobase) (iobase+4)
172 #define LSR(iobase) (iobase+5)
173 #define MSR(iobase) (iobase+6)
174 #define SCR(iobase) (iobase+7)
175 #define DLL(iobase) (iobase+0)
176 #define DLM(iobase) (iobase+1)
180 /* Interrupt Identification Register Bit Masks */
186 #define IIR_TIMEOUT 12 /* Fifo mode only */
188 #define IIR_MASK 0x0F
190 /* Interrupt Enable Register Bit Masks */
191 #define IER_RX 1 /* enable rx interrupt */
192 #define IER_TX 2 /* enable tx interrupt */
193 #define IER_LSR 4 /* enable line status interrupts */
194 #define IER_MSR 8 /* enable modem status interrupts */
196 /* Modem Control Register Bit Masks */
197 #define MCR_DTR 0x01 /* DTR output */
198 #define MCR_RTS 0x02 /* RTS output */
199 #define MCR_OUT1 0x04 /* OUT1 output (not accessible in RS232) */
200 #define MCR_OUT2 0x08 /* Master Interrupt enable (must be set on PCs) */
201 #define MCR_LOOP 0x10 /* Loopback enable */
203 /* Modem Status Register Bit Masks */
204 #define MSR_DCTS 0x01 /* Delta CTS input */
205 #define MSR_DDSR 0x02 /* Delta DSR */
206 #define MSR_DRIN 0x04 /* Delta RI */
207 #define MSR_DDCD 0x08 /* Delta DCD */
208 #define MSR_CTS 0x10 /* CTS input */
209 #define MSR_DSR 0x20 /* DSR input */
210 #define MSR_RING 0x40 /* RI input */
211 #define MSR_DCD 0x80 /* DCD input */
213 /* line status register bit mask */
218 #define LSR_BREAK 0x10
219 #define LSR_THRE 0x20
220 #define LSR_TSRE 0x40
222 /* Line Control Register Bit Masks */
223 #define LCR_DLAB 0x80
224 #define LCR_BREAK 0x40
225 #define LCR_PZERO 0x28
226 #define LCR_PEVEN 0x18
227 #define LCR_PODD 0x08
228 #define LCR_STOP1 0x00
229 #define LCR_STOP2 0x04
230 #define LCR_BIT5 0x00
231 #define LCR_BIT6 0x02
232 #define LCR_BIT7 0x01
233 #define LCR_BIT8 0x03
235 /* YAM Modem <-> UART Port mapping */
237 #define TX_RDY MSR_DCTS /* transmitter ready to send */
238 #define RX_DCD MSR_DCD /* carrier detect */
239 #define RX_FLAG MSR_RING /* hdlc flag received */
240 #define FPGA_DONE MSR_DSR /* FPGA is configured */
241 #define PTT_ON (MCR_RTS|MCR_OUT2) /* activate PTT */
242 #define PTT_OFF (MCR_DTR|MCR_OUT2) /* release PTT */
244 #define ENABLE_RXINT IER_RX /* enable uart rx interrupt during rx */
245 #define ENABLE_TXINT IER_MSR /* enable uart ms interrupt during tx */
246 #define ENABLE_RTXINT (IER_RX|IER_MSR) /* full duplex operations */
249 /*************************************************************************
251 ************************************************************************/
253 static const unsigned char chktabl
[256] =
254 {0x00, 0x89, 0x12, 0x9b, 0x24, 0xad, 0x36, 0xbf, 0x48, 0xc1, 0x5a, 0xd3, 0x6c, 0xe5, 0x7e,
255 0xf7, 0x81, 0x08, 0x93, 0x1a, 0xa5, 0x2c, 0xb7, 0x3e, 0xc9, 0x40, 0xdb, 0x52, 0xed, 0x64,
256 0xff, 0x76, 0x02, 0x8b, 0x10, 0x99, 0x26, 0xaf, 0x34, 0xbd, 0x4a, 0xc3, 0x58, 0xd1, 0x6e,
257 0xe7, 0x7c, 0xf5, 0x83, 0x0a, 0x91, 0x18, 0xa7, 0x2e, 0xb5, 0x3c, 0xcb, 0x42, 0xd9, 0x50,
258 0xef, 0x66, 0xfd, 0x74, 0x04, 0x8d, 0x16, 0x9f, 0x20, 0xa9, 0x32, 0xbb, 0x4c, 0xc5, 0x5e,
259 0xd7, 0x68, 0xe1, 0x7a, 0xf3, 0x85, 0x0c, 0x97, 0x1e, 0xa1, 0x28, 0xb3, 0x3a, 0xcd, 0x44,
260 0xdf, 0x56, 0xe9, 0x60, 0xfb, 0x72, 0x06, 0x8f, 0x14, 0x9d, 0x22, 0xab, 0x30, 0xb9, 0x4e,
261 0xc7, 0x5c, 0xd5, 0x6a, 0xe3, 0x78, 0xf1, 0x87, 0x0e, 0x95, 0x1c, 0xa3, 0x2a, 0xb1, 0x38,
262 0xcf, 0x46, 0xdd, 0x54, 0xeb, 0x62, 0xf9, 0x70, 0x08, 0x81, 0x1a, 0x93, 0x2c, 0xa5, 0x3e,
263 0xb7, 0x40, 0xc9, 0x52, 0xdb, 0x64, 0xed, 0x76, 0xff, 0x89, 0x00, 0x9b, 0x12, 0xad, 0x24,
264 0xbf, 0x36, 0xc1, 0x48, 0xd3, 0x5a, 0xe5, 0x6c, 0xf7, 0x7e, 0x0a, 0x83, 0x18, 0x91, 0x2e,
265 0xa7, 0x3c, 0xb5, 0x42, 0xcb, 0x50, 0xd9, 0x66, 0xef, 0x74, 0xfd, 0x8b, 0x02, 0x99, 0x10,
266 0xaf, 0x26, 0xbd, 0x34, 0xc3, 0x4a, 0xd1, 0x58, 0xe7, 0x6e, 0xf5, 0x7c, 0x0c, 0x85, 0x1e,
267 0x97, 0x28, 0xa1, 0x3a, 0xb3, 0x44, 0xcd, 0x56, 0xdf, 0x60, 0xe9, 0x72, 0xfb, 0x8d, 0x04,
268 0x9f, 0x16, 0xa9, 0x20, 0xbb, 0x32, 0xc5, 0x4c, 0xd7, 0x5e, 0xe1, 0x68, 0xf3, 0x7a, 0x0e,
269 0x87, 0x1c, 0x95, 0x2a, 0xa3, 0x38, 0xb1, 0x46, 0xcf, 0x54, 0xdd, 0x62, 0xeb, 0x70, 0xf9,
270 0x8f, 0x06, 0x9d, 0x14, 0xab, 0x22, 0xb9, 0x30, 0xc7, 0x4e, 0xd5, 0x5c, 0xe3, 0x6a, 0xf1,
272 static const unsigned char chktabh
[256] =
273 {0x00, 0x11, 0x23, 0x32, 0x46, 0x57, 0x65, 0x74, 0x8c, 0x9d, 0xaf, 0xbe, 0xca, 0xdb, 0xe9,
274 0xf8, 0x10, 0x01, 0x33, 0x22, 0x56, 0x47, 0x75, 0x64, 0x9c, 0x8d, 0xbf, 0xae, 0xda, 0xcb,
275 0xf9, 0xe8, 0x21, 0x30, 0x02, 0x13, 0x67, 0x76, 0x44, 0x55, 0xad, 0xbc, 0x8e, 0x9f, 0xeb,
276 0xfa, 0xc8, 0xd9, 0x31, 0x20, 0x12, 0x03, 0x77, 0x66, 0x54, 0x45, 0xbd, 0xac, 0x9e, 0x8f,
277 0xfb, 0xea, 0xd8, 0xc9, 0x42, 0x53, 0x61, 0x70, 0x04, 0x15, 0x27, 0x36, 0xce, 0xdf, 0xed,
278 0xfc, 0x88, 0x99, 0xab, 0xba, 0x52, 0x43, 0x71, 0x60, 0x14, 0x05, 0x37, 0x26, 0xde, 0xcf,
279 0xfd, 0xec, 0x98, 0x89, 0xbb, 0xaa, 0x63, 0x72, 0x40, 0x51, 0x25, 0x34, 0x06, 0x17, 0xef,
280 0xfe, 0xcc, 0xdd, 0xa9, 0xb8, 0x8a, 0x9b, 0x73, 0x62, 0x50, 0x41, 0x35, 0x24, 0x16, 0x07,
281 0xff, 0xee, 0xdc, 0xcd, 0xb9, 0xa8, 0x9a, 0x8b, 0x84, 0x95, 0xa7, 0xb6, 0xc2, 0xd3, 0xe1,
282 0xf0, 0x08, 0x19, 0x2b, 0x3a, 0x4e, 0x5f, 0x6d, 0x7c, 0x94, 0x85, 0xb7, 0xa6, 0xd2, 0xc3,
283 0xf1, 0xe0, 0x18, 0x09, 0x3b, 0x2a, 0x5e, 0x4f, 0x7d, 0x6c, 0xa5, 0xb4, 0x86, 0x97, 0xe3,
284 0xf2, 0xc0, 0xd1, 0x29, 0x38, 0x0a, 0x1b, 0x6f, 0x7e, 0x4c, 0x5d, 0xb5, 0xa4, 0x96, 0x87,
285 0xf3, 0xe2, 0xd0, 0xc1, 0x39, 0x28, 0x1a, 0x0b, 0x7f, 0x6e, 0x5c, 0x4d, 0xc6, 0xd7, 0xe5,
286 0xf4, 0x80, 0x91, 0xa3, 0xb2, 0x4a, 0x5b, 0x69, 0x78, 0x0c, 0x1d, 0x2f, 0x3e, 0xd6, 0xc7,
287 0xf5, 0xe4, 0x90, 0x81, 0xb3, 0xa2, 0x5a, 0x4b, 0x79, 0x68, 0x1c, 0x0d, 0x3f, 0x2e, 0xe7,
288 0xf6, 0xc4, 0xd5, 0xa1, 0xb0, 0x82, 0x93, 0x6b, 0x7a, 0x48, 0x59, 0x2d, 0x3c, 0x0e, 0x1f,
289 0xf7, 0xe6, 0xd4, 0xc5, 0xb1, 0xa0, 0x92, 0x83, 0x7b, 0x6a, 0x58, 0x49, 0x3d, 0x2c, 0x1e,
292 /*************************************************************************
294 ************************************************************************/
296 static void delay(int ms
)
298 unsigned long timeout
= jiffies
+ ((ms
* HZ
) / 1000);
299 while (time_before(jiffies
, timeout
))
307 static void fpga_reset(int iobase
)
309 outb(0, IER(iobase
));
310 outb(LCR_DLAB
| LCR_BIT5
, LCR(iobase
));
311 outb(1, DLL(iobase
));
312 outb(0, DLM(iobase
));
314 outb(LCR_BIT5
, LCR(iobase
));
317 /* turn off FPGA supply voltage */
318 outb(MCR_OUT1
| MCR_OUT2
, MCR(iobase
));
320 /* turn on FPGA supply voltage again */
321 outb(MCR_DTR
| MCR_RTS
| MCR_OUT1
| MCR_OUT2
, MCR(iobase
));
326 * send one byte to FPGA
329 static int fpga_write(int iobase
, unsigned char wrd
)
333 unsigned long timeout
= jiffies
+ HZ
/ 10;
335 for (k
= 0; k
< 8; k
++) {
336 bit
= (wrd
& 0x80) ? (MCR_RTS
| MCR_DTR
) : MCR_DTR
;
337 outb(bit
| MCR_OUT1
| MCR_OUT2
, MCR(iobase
));
339 outb(0xfc, THR(iobase
));
340 while ((inb(LSR(iobase
)) & LSR_TSRE
) == 0)
341 if (time_after(jiffies
, timeout
))
348 static unsigned char *add_mcs(unsigned char *bits
, int bitrate
)
352 /* If it already exists, replace the bit data */
355 if (p
->bitrate
== bitrate
) {
356 memcpy(p
->bits
, bits
, YAM_FPGA_SIZE
);
362 /* Allocate a new mcs */
363 if ((p
= kmalloc(sizeof(struct yam_mcs
), GFP_KERNEL
)) == NULL
) {
364 printk(KERN_WARNING
"YAM: no memory to allocate mcs\n");
367 memcpy(p
->bits
, bits
, YAM_FPGA_SIZE
);
368 p
->bitrate
= bitrate
;
375 static unsigned char *get_mcs(int bitrate
)
381 if (p
->bitrate
== bitrate
)
386 /* Load predefined mcs data */
389 return add_mcs(bits_1200
, bitrate
);
391 return add_mcs(bits_9600
, bitrate
);
396 * download bitstream to FPGA
397 * data is contained in bits[] array in yam1200.h resp. yam9600.h
400 static int fpga_download(int iobase
, int bitrate
)
403 unsigned char *pbits
;
405 pbits
= get_mcs(bitrate
);
410 for (i
= 0; i
< YAM_FPGA_SIZE
; i
++) {
411 if (fpga_write(iobase
, pbits
[i
])) {
412 printk(KERN_ERR
"yam: error in write cycle\n");
413 return -1; /* write... */
417 fpga_write(iobase
, 0xFF);
418 rc
= inb(MSR(iobase
)); /* check DONE signal */
420 /* Needed for some hardwares */
423 return (rc
& MSR_DSR
) ? 0 : -1;
427 /************************************************************************
429 ************************************************************************/
431 static void yam_set_uart(struct net_device
*dev
)
433 struct yam_port
*yp
= netdev_priv(dev
);
434 int divisor
= 115200 / yp
->baudrate
;
436 outb(0, IER(dev
->base_addr
));
437 outb(LCR_DLAB
| LCR_BIT8
, LCR(dev
->base_addr
));
438 outb(divisor
, DLL(dev
->base_addr
));
439 outb(0, DLM(dev
->base_addr
));
440 outb(LCR_BIT8
, LCR(dev
->base_addr
));
441 outb(PTT_OFF
, MCR(dev
->base_addr
));
442 outb(0x00, FCR(dev
->base_addr
));
444 /* Flush pending irq */
446 inb(RBR(dev
->base_addr
));
447 inb(MSR(dev
->base_addr
));
451 outb(ENABLE_RTXINT
, IER(dev
->base_addr
));
455 /* --------------------------------------------------------------------- */
458 c_uart_unknown
, c_uart_8250
,
459 c_uart_16450
, c_uart_16550
, c_uart_16550A
462 static const char *uart_str
[] =
463 {"unknown", "8250", "16450", "16550", "16550A"};
465 static enum uart
yam_check_uart(unsigned int iobase
)
467 unsigned char b1
, b2
, b3
;
469 enum uart uart_tab
[] =
470 {c_uart_16450
, c_uart_unknown
, c_uart_16550
, c_uart_16550A
};
472 b1
= inb(MCR(iobase
));
473 outb(b1
| 0x10, MCR(iobase
)); /* loopback mode */
474 b2
= inb(MSR(iobase
));
475 outb(0x1a, MCR(iobase
));
476 b3
= inb(MSR(iobase
)) & 0xf0;
477 outb(b1
, MCR(iobase
)); /* restore old values */
478 outb(b2
, MSR(iobase
));
480 return c_uart_unknown
;
483 outb(0x01, FCR(iobase
)); /* enable FIFOs */
484 u
= uart_tab
[(inb(IIR(iobase
)) >> 6) & 3];
485 if (u
== c_uart_16450
) {
486 outb(0x5a, SCR(iobase
));
487 b1
= inb(SCR(iobase
));
488 outb(0xa5, SCR(iobase
));
489 b2
= inb(SCR(iobase
));
490 if ((b1
!= 0x5a) || (b2
!= 0xa5))
496 /******************************************************************************
498 ******************************************************************************/
499 static inline void yam_rx_flag(struct net_device
*dev
, struct yam_port
*yp
)
501 if (yp
->dcd
&& yp
->rx_len
>= 3 && yp
->rx_len
< YAM_MAX_FRAME
) {
502 int pkt_len
= yp
->rx_len
- 2 + 1; /* -CRC + kiss */
505 if ((yp
->rx_crch
& yp
->rx_crcl
) != 0xFF) {
508 if (!(skb
= dev_alloc_skb(pkt_len
))) {
509 printk(KERN_WARNING
"%s: memory squeeze, dropping packet\n", dev
->name
);
510 ++yp
->stats
.rx_dropped
;
513 cp
= skb_put(skb
, pkt_len
);
514 *cp
++ = 0; /* KISS kludge */
515 memcpy(cp
, yp
->rx_buf
, pkt_len
- 1);
516 skb
->protocol
= ax25_type_trans(skb
, dev
);
518 dev
->last_rx
= jiffies
;
519 ++yp
->stats
.rx_packets
;
528 static inline void yam_rx_byte(struct net_device
*dev
, struct yam_port
*yp
, unsigned char rxb
)
530 if (yp
->rx_len
< YAM_MAX_FRAME
) {
531 unsigned char c
= yp
->rx_crcl
;
532 yp
->rx_crcl
= (chktabl
[c
] ^ yp
->rx_crch
);
533 yp
->rx_crch
= (chktabh
[c
] ^ rxb
);
534 yp
->rx_buf
[yp
->rx_len
++] = rxb
;
538 /********************************************************************************
540 ********************************************************************************/
542 static void ptt_on(struct net_device
*dev
)
544 outb(PTT_ON
, MCR(dev
->base_addr
));
547 static void ptt_off(struct net_device
*dev
)
549 outb(PTT_OFF
, MCR(dev
->base_addr
));
552 static int yam_send_packet(struct sk_buff
*skb
, struct net_device
*dev
)
554 struct yam_port
*yp
= netdev_priv(dev
);
556 skb_queue_tail(&yp
->send_queue
, skb
);
557 dev
->trans_start
= jiffies
;
561 static void yam_start_tx(struct net_device
*dev
, struct yam_port
*yp
)
563 if ((yp
->tx_state
== TX_TAIL
) || (yp
->txd
== 0))
566 yp
->tx_count
= (yp
->bitrate
* yp
->txd
) / 8000;
567 yp
->tx_state
= TX_HEAD
;
571 static void yam_arbitrate(struct net_device
*dev
)
573 struct yam_port
*yp
= netdev_priv(dev
);
575 if (yp
->magic
!= YAM_MAGIC
|| yp
->tx_state
!= TX_OFF
||
576 skb_queue_empty(&yp
->send_queue
))
578 /* tx_state is TX_OFF and there is data to send */
581 /* Full duplex mode, don't wait */
582 yam_start_tx(dev
, yp
);
586 /* DCD on, wait slotime ... */
587 yp
->slotcnt
= yp
->slot
/ 10;
590 /* Is slottime passed ? */
591 if ((--yp
->slotcnt
) > 0)
594 yp
->slotcnt
= yp
->slot
/ 10;
596 /* is random > persist ? */
597 if ((random32() % 256) > yp
->pers
)
600 yam_start_tx(dev
, yp
);
603 static void yam_dotimer(unsigned long dummy
)
607 for (i
= 0; i
< NR_PORTS
; i
++) {
608 struct net_device
*dev
= yam_devs
[i
];
609 if (dev
&& netif_running(dev
))
612 yam_timer
.expires
= jiffies
+ HZ
/ 100;
613 add_timer(&yam_timer
);
616 static void yam_tx_byte(struct net_device
*dev
, struct yam_port
*yp
)
619 unsigned char b
, temp
;
621 switch (yp
->tx_state
) {
625 if (--yp
->tx_count
<= 0) {
626 if (!(skb
= skb_dequeue(&yp
->send_queue
))) {
628 yp
->tx_state
= TX_OFF
;
631 yp
->tx_state
= TX_DATA
;
632 if (skb
->data
[0] != 0) {
633 /* do_kiss_params(s, skb->data, skb->len); */
634 dev_kfree_skb_any(skb
);
637 yp
->tx_len
= skb
->len
- 1; /* strip KISS byte */
638 if (yp
->tx_len
>= YAM_MAX_FRAME
|| yp
->tx_len
< 2) {
639 dev_kfree_skb_any(skb
);
642 skb_copy_from_linear_data_offset(skb
, 1,
645 dev_kfree_skb_any(skb
);
649 yp
->tx_state
= TX_DATA
;
653 b
= yp
->tx_buf
[yp
->tx_count
++];
654 outb(b
, THR(dev
->base_addr
));
656 yp
->tx_crcl
= chktabl
[temp
] ^ yp
->tx_crch
;
657 yp
->tx_crch
= chktabh
[temp
] ^ b
;
658 if (yp
->tx_count
>= yp
->tx_len
) {
659 yp
->tx_state
= TX_CRC1
;
663 yp
->tx_crch
= chktabl
[yp
->tx_crcl
] ^ yp
->tx_crch
;
664 yp
->tx_crcl
= chktabh
[yp
->tx_crcl
] ^ chktabl
[yp
->tx_crch
] ^ 0xff;
665 outb(yp
->tx_crcl
, THR(dev
->base_addr
));
666 yp
->tx_state
= TX_CRC2
;
669 outb(chktabh
[yp
->tx_crch
] ^ 0xFF, THR(dev
->base_addr
));
670 if (skb_queue_empty(&yp
->send_queue
)) {
671 yp
->tx_count
= (yp
->bitrate
* yp
->txtail
) / 8000;
672 if (yp
->dupmode
== 2)
673 yp
->tx_count
+= (yp
->bitrate
* yp
->holdd
) / 8;
674 if (yp
->tx_count
== 0)
676 yp
->tx_state
= TX_TAIL
;
679 yp
->tx_state
= TX_HEAD
;
681 ++yp
->stats
.tx_packets
;
684 if (--yp
->tx_count
<= 0) {
685 yp
->tx_state
= TX_OFF
;
692 /***********************************************************************************
694 ************************************************************************************/
696 static irqreturn_t
yam_interrupt(int irq
, void *dev_id
)
698 struct net_device
*dev
;
705 for (i
= 0; i
< NR_PORTS
; i
++) {
707 yp
= netdev_priv(dev
);
709 if (!netif_running(dev
))
712 while ((iir
= IIR_MASK
& inb(IIR(dev
->base_addr
))) != IIR_NOPEND
) {
713 unsigned char msr
= inb(MSR(dev
->base_addr
));
714 unsigned char lsr
= inb(LSR(dev
->base_addr
));
720 ++yp
->stats
.rx_fifo_errors
;
722 yp
->dcd
= (msr
& RX_DCD
) ? 1 : 0;
724 if (--counter
<= 0) {
725 printk(KERN_ERR
"%s: too many irq iir=%d\n",
731 yam_tx_byte(dev
, yp
);
735 rxb
= inb(RBR(dev
->base_addr
));
737 yam_rx_flag(dev
, yp
);
739 yam_rx_byte(dev
, yp
, rxb
);
744 return IRQ_RETVAL(handled
);
747 #ifdef CONFIG_PROC_FS
749 static void *yam_seq_start(struct seq_file
*seq
, loff_t
*pos
)
751 return (*pos
< NR_PORTS
) ? yam_devs
[*pos
] : NULL
;
754 static void *yam_seq_next(struct seq_file
*seq
, void *v
, loff_t
*pos
)
757 return (*pos
< NR_PORTS
) ? yam_devs
[*pos
] : NULL
;
760 static void yam_seq_stop(struct seq_file
*seq
, void *v
)
764 static int yam_seq_show(struct seq_file
*seq
, void *v
)
766 struct net_device
*dev
= v
;
767 const struct yam_port
*yp
= netdev_priv(dev
);
769 seq_printf(seq
, "Device %s\n", dev
->name
);
770 seq_printf(seq
, " Up %d\n", netif_running(dev
));
771 seq_printf(seq
, " Speed %u\n", yp
->bitrate
);
772 seq_printf(seq
, " IoBase 0x%x\n", yp
->iobase
);
773 seq_printf(seq
, " BaudRate %u\n", yp
->baudrate
);
774 seq_printf(seq
, " IRQ %u\n", yp
->irq
);
775 seq_printf(seq
, " TxState %u\n", yp
->tx_state
);
776 seq_printf(seq
, " Duplex %u\n", yp
->dupmode
);
777 seq_printf(seq
, " HoldDly %u\n", yp
->holdd
);
778 seq_printf(seq
, " TxDelay %u\n", yp
->txd
);
779 seq_printf(seq
, " TxTail %u\n", yp
->txtail
);
780 seq_printf(seq
, " SlotTime %u\n", yp
->slot
);
781 seq_printf(seq
, " Persist %u\n", yp
->pers
);
782 seq_printf(seq
, " TxFrames %lu\n", yp
->stats
.tx_packets
);
783 seq_printf(seq
, " RxFrames %lu\n", yp
->stats
.rx_packets
);
784 seq_printf(seq
, " TxInt %u\n", yp
->nb_mdint
);
785 seq_printf(seq
, " RxInt %u\n", yp
->nb_rxint
);
786 seq_printf(seq
, " RxOver %lu\n", yp
->stats
.rx_fifo_errors
);
787 seq_printf(seq
, "\n");
791 static struct seq_operations yam_seqops
= {
792 .start
= yam_seq_start
,
793 .next
= yam_seq_next
,
794 .stop
= yam_seq_stop
,
795 .show
= yam_seq_show
,
798 static int yam_info_open(struct inode
*inode
, struct file
*file
)
800 return seq_open(file
, &yam_seqops
);
803 static const struct file_operations yam_info_fops
= {
804 .owner
= THIS_MODULE
,
805 .open
= yam_info_open
,
808 .release
= seq_release
,
814 /* --------------------------------------------------------------------- */
816 static struct net_device_stats
*yam_get_stats(struct net_device
*dev
)
823 yp
= netdev_priv(dev
);
824 if (yp
->magic
!= YAM_MAGIC
)
828 * Get the current statistics. This may be called with the
829 * card open or closed.
834 /* --------------------------------------------------------------------- */
836 static int yam_open(struct net_device
*dev
)
838 struct yam_port
*yp
= netdev_priv(dev
);
843 printk(KERN_INFO
"Trying %s at iobase 0x%lx irq %u\n", dev
->name
, dev
->base_addr
, dev
->irq
);
845 if (!dev
|| !yp
->bitrate
)
847 if (!dev
->base_addr
|| dev
->base_addr
> 0x1000 - YAM_EXTENT
||
848 dev
->irq
< 2 || dev
->irq
> 15) {
851 if (!request_region(dev
->base_addr
, YAM_EXTENT
, dev
->name
))
853 printk(KERN_ERR
"%s: cannot 0x%lx busy\n", dev
->name
, dev
->base_addr
);
856 if ((u
= yam_check_uart(dev
->base_addr
)) == c_uart_unknown
) {
857 printk(KERN_ERR
"%s: cannot find uart type\n", dev
->name
);
859 goto out_release_base
;
861 if (fpga_download(dev
->base_addr
, yp
->bitrate
)) {
862 printk(KERN_ERR
"%s: cannot init FPGA\n", dev
->name
);
864 goto out_release_base
;
866 outb(0, IER(dev
->base_addr
));
867 if (request_irq(dev
->irq
, yam_interrupt
, IRQF_DISABLED
| IRQF_SHARED
, dev
->name
, dev
)) {
868 printk(KERN_ERR
"%s: irq %d busy\n", dev
->name
, dev
->irq
);
870 goto out_release_base
;
875 netif_start_queue(dev
);
877 yp
->slotcnt
= yp
->slot
/ 10;
879 /* Reset overruns for all ports - FPGA programming makes overruns */
880 for (i
= 0; i
< NR_PORTS
; i
++) {
881 struct net_device
*dev
= yam_devs
[i
];
882 struct yam_port
*yp
= netdev_priv(dev
);
883 inb(LSR(dev
->base_addr
));
884 yp
->stats
.rx_fifo_errors
= 0;
887 printk(KERN_INFO
"%s at iobase 0x%lx irq %u uart %s\n", dev
->name
, dev
->base_addr
, dev
->irq
,
892 release_region(dev
->base_addr
, YAM_EXTENT
);
896 /* --------------------------------------------------------------------- */
898 static int yam_close(struct net_device
*dev
)
901 struct yam_port
*yp
= netdev_priv(dev
);
909 outb(0, IER(dev
->base_addr
));
910 outb(1, MCR(dev
->base_addr
));
911 /* Remove IRQ handler if last */
912 free_irq(dev
->irq
,dev
);
913 release_region(dev
->base_addr
, YAM_EXTENT
);
914 netif_stop_queue(dev
);
915 while ((skb
= skb_dequeue(&yp
->send_queue
)))
918 printk(KERN_INFO
"%s: close yam at iobase 0x%lx irq %u\n",
919 yam_drvname
, dev
->base_addr
, dev
->irq
);
923 /* --------------------------------------------------------------------- */
925 static int yam_ioctl(struct net_device
*dev
, struct ifreq
*ifr
, int cmd
)
927 struct yam_port
*yp
= netdev_priv(dev
);
928 struct yamdrv_ioctl_cfg yi
;
929 struct yamdrv_ioctl_mcs
*ym
;
932 if (copy_from_user(&ioctl_cmd
, ifr
->ifr_data
, sizeof(int)))
935 if (yp
->magic
!= YAM_MAGIC
)
938 if (!capable(CAP_NET_ADMIN
))
941 if (cmd
!= SIOCDEVPRIVATE
)
946 case SIOCYAMRESERVED
:
947 return -EINVAL
; /* unused */
950 if (netif_running(dev
))
951 return -EINVAL
; /* Cannot change this parameter when up */
952 if ((ym
= kmalloc(sizeof(struct yamdrv_ioctl_mcs
), GFP_KERNEL
)) == NULL
)
955 if (copy_from_user(ym
, ifr
->ifr_data
, sizeof(struct yamdrv_ioctl_mcs
))) {
959 if (ym
->bitrate
> YAM_MAXBITRATE
) {
963 add_mcs(ym
->bits
, ym
->bitrate
);
968 if (!capable(CAP_SYS_RAWIO
))
970 if (copy_from_user(&yi
, ifr
->ifr_data
, sizeof(struct yamdrv_ioctl_cfg
)))
973 if ((yi
.cfg
.mask
& YAM_IOBASE
) && netif_running(dev
))
974 return -EINVAL
; /* Cannot change this parameter when up */
975 if ((yi
.cfg
.mask
& YAM_IRQ
) && netif_running(dev
))
976 return -EINVAL
; /* Cannot change this parameter when up */
977 if ((yi
.cfg
.mask
& YAM_BITRATE
) && netif_running(dev
))
978 return -EINVAL
; /* Cannot change this parameter when up */
979 if ((yi
.cfg
.mask
& YAM_BAUDRATE
) && netif_running(dev
))
980 return -EINVAL
; /* Cannot change this parameter when up */
982 if (yi
.cfg
.mask
& YAM_IOBASE
) {
983 yp
->iobase
= yi
.cfg
.iobase
;
984 dev
->base_addr
= yi
.cfg
.iobase
;
986 if (yi
.cfg
.mask
& YAM_IRQ
) {
989 yp
->irq
= yi
.cfg
.irq
;
990 dev
->irq
= yi
.cfg
.irq
;
992 if (yi
.cfg
.mask
& YAM_BITRATE
) {
993 if (yi
.cfg
.bitrate
> YAM_MAXBITRATE
)
995 yp
->bitrate
= yi
.cfg
.bitrate
;
997 if (yi
.cfg
.mask
& YAM_BAUDRATE
) {
998 if (yi
.cfg
.baudrate
> YAM_MAXBAUDRATE
)
1000 yp
->baudrate
= yi
.cfg
.baudrate
;
1002 if (yi
.cfg
.mask
& YAM_MODE
) {
1003 if (yi
.cfg
.mode
> YAM_MAXMODE
)
1005 yp
->dupmode
= yi
.cfg
.mode
;
1007 if (yi
.cfg
.mask
& YAM_HOLDDLY
) {
1008 if (yi
.cfg
.holddly
> YAM_MAXHOLDDLY
)
1010 yp
->holdd
= yi
.cfg
.holddly
;
1012 if (yi
.cfg
.mask
& YAM_TXDELAY
) {
1013 if (yi
.cfg
.txdelay
> YAM_MAXTXDELAY
)
1015 yp
->txd
= yi
.cfg
.txdelay
;
1017 if (yi
.cfg
.mask
& YAM_TXTAIL
) {
1018 if (yi
.cfg
.txtail
> YAM_MAXTXTAIL
)
1020 yp
->txtail
= yi
.cfg
.txtail
;
1022 if (yi
.cfg
.mask
& YAM_PERSIST
) {
1023 if (yi
.cfg
.persist
> YAM_MAXPERSIST
)
1025 yp
->pers
= yi
.cfg
.persist
;
1027 if (yi
.cfg
.mask
& YAM_SLOTTIME
) {
1028 if (yi
.cfg
.slottime
> YAM_MAXSLOTTIME
)
1030 yp
->slot
= yi
.cfg
.slottime
;
1031 yp
->slotcnt
= yp
->slot
/ 10;
1036 yi
.cfg
.mask
= 0xffffffff;
1037 yi
.cfg
.iobase
= yp
->iobase
;
1038 yi
.cfg
.irq
= yp
->irq
;
1039 yi
.cfg
.bitrate
= yp
->bitrate
;
1040 yi
.cfg
.baudrate
= yp
->baudrate
;
1041 yi
.cfg
.mode
= yp
->dupmode
;
1042 yi
.cfg
.txdelay
= yp
->txd
;
1043 yi
.cfg
.holddly
= yp
->holdd
;
1044 yi
.cfg
.txtail
= yp
->txtail
;
1045 yi
.cfg
.persist
= yp
->pers
;
1046 yi
.cfg
.slottime
= yp
->slot
;
1047 if (copy_to_user(ifr
->ifr_data
, &yi
, sizeof(struct yamdrv_ioctl_cfg
)))
1059 /* --------------------------------------------------------------------- */
1061 static int yam_set_mac_address(struct net_device
*dev
, void *addr
)
1063 struct sockaddr
*sa
= (struct sockaddr
*) addr
;
1065 /* addr is an AX.25 shifted ASCII mac address */
1066 memcpy(dev
->dev_addr
, sa
->sa_data
, dev
->addr_len
);
1070 /* --------------------------------------------------------------------- */
1072 static void yam_setup(struct net_device
*dev
)
1074 struct yam_port
*yp
= netdev_priv(dev
);
1076 yp
->magic
= YAM_MAGIC
;
1077 yp
->bitrate
= DEFAULT_BITRATE
;
1078 yp
->baudrate
= DEFAULT_BITRATE
* 2;
1082 yp
->holdd
= DEFAULT_HOLDD
;
1083 yp
->txd
= DEFAULT_TXD
;
1084 yp
->txtail
= DEFAULT_TXTAIL
;
1085 yp
->slot
= DEFAULT_SLOT
;
1086 yp
->pers
= DEFAULT_PERS
;
1089 dev
->base_addr
= yp
->iobase
;
1092 dev
->open
= yam_open
;
1093 dev
->stop
= yam_close
;
1094 dev
->do_ioctl
= yam_ioctl
;
1095 dev
->hard_start_xmit
= yam_send_packet
;
1096 dev
->get_stats
= yam_get_stats
;
1098 skb_queue_head_init(&yp
->send_queue
);
1100 dev
->header_ops
= &ax25_header_ops
;
1102 dev
->set_mac_address
= yam_set_mac_address
;
1104 dev
->type
= ARPHRD_AX25
;
1105 dev
->hard_header_len
= AX25_MAX_HEADER_LEN
;
1106 dev
->mtu
= AX25_MTU
;
1107 dev
->addr_len
= AX25_ADDR_LEN
;
1108 memcpy(dev
->broadcast
, &ax25_bcast
, AX25_ADDR_LEN
);
1109 memcpy(dev
->dev_addr
, &ax25_defaddr
, AX25_ADDR_LEN
);
1112 static int __init
yam_init_driver(void)
1114 struct net_device
*dev
;
1116 char name
[IFNAMSIZ
];
1118 printk(yam_drvinfo
);
1120 for (i
= 0; i
< NR_PORTS
; i
++) {
1121 sprintf(name
, "yam%d", i
);
1123 dev
= alloc_netdev(sizeof(struct yam_port
), name
,
1126 printk(KERN_ERR
"yam: cannot allocate net device %s\n",
1132 err
= register_netdev(dev
);
1134 printk(KERN_WARNING
"yam: cannot register net device %s\n", dev
->name
);
1141 yam_timer
.function
= yam_dotimer
;
1142 yam_timer
.expires
= jiffies
+ HZ
/ 100;
1143 add_timer(&yam_timer
);
1145 proc_net_fops_create(&init_net
, "yam", S_IRUGO
, &yam_info_fops
);
1149 unregister_netdev(yam_devs
[i
]);
1150 free_netdev(yam_devs
[i
]);
1155 /* --------------------------------------------------------------------- */
1157 static void __exit
yam_cleanup_driver(void)
1162 del_timer(&yam_timer
);
1163 for (i
= 0; i
< NR_PORTS
; i
++) {
1164 struct net_device
*dev
= yam_devs
[i
];
1166 unregister_netdev(dev
);
1173 yam_data
= yam_data
->next
;
1177 proc_net_remove(&init_net
, "yam");
1180 /* --------------------------------------------------------------------- */
1182 MODULE_AUTHOR("Frederic Rible F1OAT frible@teaser.fr");
1183 MODULE_DESCRIPTION("Yam amateur radio modem driver");
1184 MODULE_LICENSE("GPL");
1186 module_init(yam_init_driver
);
1187 module_exit(yam_cleanup_driver
);
1189 /* --------------------------------------------------------------------- */