1 /*****************************************************************
 
   5  * Description:   Driver for the Toshiba OBOE (or type-O or 701)
 
   6  *                FIR Chipset, also supports the DONAUOBOE (type-DO
 
   7  *                or d01) FIR chipset which as far as I know is
 
   9  * Documentation: http://libxg.free.fr/irda/lib-irda.html
 
  10  * Status:        Experimental.
 
  11  * Author:        James McKenzie <james@fishsoup.dhs.org>
 
  12  * Created at:    Sat May 8  12:35:27 1999
 
  13  * Modified:      Paul Bristow <paul.bristow@technologist.com>
 
  14  * Modified:      Mon Nov 11 19:10:05 1999
 
  15  * Modified:      James McKenzie <james@fishsoup.dhs.org>
 
  16  * Modified:      Thu Mar 16 12:49:00 2000 (Substantial rewrite)
 
  17  * Modified:      Sat Apr 29 00:23:03 2000 (Added DONAUOBOE support)
 
  18  * Modified:      Wed May 24 23:45:02 2000 (Fixed chipio_t structure)
 
  19  * Modified: 2.13 Christian Gennerat <christian.gennerat@polytechnique.org>
 
  20  * Modified: 2.13 dim jan 07 21:57:39 2001 (tested with kernel 2.4 & irnet/ppp)
 
  21  * Modified: 2.14 Christian Gennerat <christian.gennerat@polytechnique.org>
 
  22  * Modified: 2.14 lun fev 05 17:55:59 2001 (adapted to patch-2.4.1-pre8-irda1)
 
  23  * Modified: 2.15 Martin Lucina <mato@kotelna.sk>
 
  24  * Modified: 2.15 Fri Jun 21 20:40:59 2002 (sync with 2.4.18, substantial fixes)
 
  25  * Modified: 2.16 Martin Lucina <mato@kotelna.sk>
 
  26  * Modified: 2.16 Sat Jun 22 18:54:29 2002 (fix freeregion, default to verbose)
 
  27  * Modified: 2.17 Christian Gennerat <christian.gennerat@polytechnique.org>
 
  28  * Modified: 2.17 jeu sep 12 08:50:20 2002 (save_flags();cli(); replaced by spinlocks)
 
  29  * Modified: 2.18 Christian Gennerat <christian.gennerat@polytechnique.org>
 
  30  * Modified: 2.18 ven jan 10 03:14:16 2003 Change probe default options
 
  32  *     Copyright (c) 1999 James McKenzie, All Rights Reserved.
 
  34  *     This program is free software; you can redistribute it and/or
 
  35  *     modify it under the terms of the GNU General Public License as
 
  36  *     published by the Free Software Foundation; either version 2 of
 
  37  *     the License, or (at your option) any later version.
 
  39  *     Neither James McKenzie nor Cambridge University admit liability nor
 
  40  *     provide warranty for any of this software. This material is
 
  41  *     provided "AS-IS" and at no charge.
 
  43  *     Applicable Models : Libretto 100/110CT and many more.
 
  44  *     Toshiba refers to this chip as the type-O IR port,
 
  45  *     or the type-DO IR port.
 
  47  ********************************************************************/
 
  49 /* Look at toshoboe.h (currently in include/net/irda) for details of */
 
  50 /* Where to get documentation on the chip         */
 
  54   "$Id: donauboe.c V2.18 ven jan 10 03:14:16 2003$";
 
  56 /* See below for a description of the logic in this driver */
 
  58 /* User servicable parts */
 
  59 /* USE_PROBE Create the code which probes the chip and does a few tests */
 
  60 /* do_probe module parameter Enable this code */
 
  61 /* Probe code is very useful for understanding how the hardware works */
 
  62 /* Use it with various combinations of TT_LEN, RX_LEN */
 
  63 /* Strongly recomended, disable if the probe fails on your machine */
 
  64 /* and send me <james@fishsoup.dhs.org> the output of dmesg */
 
  68 /* Trace Transmit ring, interrupts, Receive ring or not ? */
 
  69 #define PROBE_VERBOSE 1
 
  71 /* Debug option, examine sent and received raw data */
 
  72 /* Irdadump is better, but does not see all packets. enable it if you want. */
 
  75 /* MIR mode has not been tested. Some behaviour is different */
 
  76 /* Seems to work against an Ericsson R520 for me. -Martin */
 
  79 /* Schedule back to back hardware transmits wherever possible, otherwise */
 
  80 /* we need an interrupt for every frame, unset if oboe works for a bit and */
 
  84 /* Set the number of slots in the rings */
 
  85 /* If you get rx/tx fifo overflows at high bitrates, you can try increasing */
 
  88 #define RING_SIZE (OBOE_RING_SIZE_RX8 | OBOE_RING_SIZE_TX8)
 
  93 /* Less user servicable parts below here */
 
  95 /* Test, Transmit and receive buffer sizes, adjust at your peril */
 
  96 /* remarks: nfs usually needs 1k blocks */
 
  97 /* remarks: in SIR mode, CRC is received, -> RX_LEN=TX_LEN+2 */
 
  98 /* remarks: test accepts large blocks. Standard is 0x80 */
 
  99 /* When TT_LEN > RX_LEN (SIR mode) data is stored in successive slots. */
 
 100 /* When 3 or more slots are needed for each test packet, */
 
 101 /* data received in the first slots is overwritten, even */
 
 102 /* if OBOE_CTL_RX_HW_OWNS is not set, without any error! */
 
 106 /* Real transmitted length (SIR mode) is about 14+(2%*TX_LEN) more */
 
 107 /* long than user-defined length (see async_wrap_skb) and is less then 4K */
 
 108 /* Real received length is (max RX_LEN) differs from user-defined */
 
 109 /* length only b the CRC (2 or 4 bytes) */
 
 110 #define BUF_SAFETY  0x7a
 
 111 #define RX_BUF_SZ   (RX_LEN)
 
 112 #define TX_BUF_SZ   (TX_LEN+BUF_SAFETY)
 
 115 /* Logic of the netdev part of this driver                             */
 
 117 /* The RX ring is filled with buffers, when a packet arrives           */
 
 118 /* it is DMA'd into the buffer which is marked used and RxDone called  */
 
 119 /* RxDone forms an skb (and checks the CRC if in SIR mode) and ships   */
 
 120 /* the packet off upstairs */
 
 122 /* The transmitter on the oboe chip can work in one of two modes       */
 
 123 /* for each ring->tx[] the transmitter can either                      */
 
 124 /* a) transmit the packet, leave the trasmitter enabled and proceed to */
 
 127 /* b) transmit the packet, switch off the transmitter and issue TxDone */
 
 129 /* All packets are entered into the ring in mode b), if the ring was   */
 
 130 /* empty the transmitter is started.                                   */
 
 132 /* If OPTIMIZE_TX is defined then in TxDone if the ring contains       */
 
 133 /* more than one packet, all but the last are set to mode a) [HOWEVER  */
 
 134 /* the hardware may not notice this, this is why we start in mode b) ] */
 
 135 /* then restart the transmitter                                        */
 
 137 /* If OPTIMIZE_TX is not defined then we just restart the transmitter  */
 
 138 /* if the ring isn't empty */
 
 140 /* Speed changes are delayed until the TxRing is empty                 */
 
 141 /* mtt is handled by generating packets with bad CRCs, before the data */
 
 144 /* check the mtt works ok      */
 
 145 /* finish the watchdog         */
 
 147 /* No user servicable parts below here */
 
 149 #include <linux/module.h>
 
 151 #include <linux/kernel.h>
 
 152 #include <linux/types.h>
 
 153 #include <linux/skbuff.h>
 
 154 #include <linux/netdevice.h>
 
 155 #include <linux/ioport.h>
 
 156 #include <linux/delay.h>
 
 157 #include <linux/slab.h>
 
 158 #include <linux/init.h>
 
 159 #include <linux/pci.h>
 
 160 #include <linux/rtnetlink.h>
 
 162 #include <asm/system.h>
 
 165 #include <net/irda/wrapper.h>
 
 166 #include <net/irda/irda.h>
 
 167 //#include <net/irda/irmod.h>
 
 168 //#include <net/irda/irlap_frame.h>
 
 169 #include <net/irda/irda_device.h>
 
 170 #include <net/irda/crc.h>
 
 172 #include "donauboe.h"
 
 174 #define INB(port)       inb_p(port)
 
 175 #define OUTB(val,port)  outb_p(val,port)
 
 176 #define OUTBP(val,port) outb_p(val,port)
 
 178 #define PROMPT  OUTB(OBOE_PROMPT_BIT,OBOE_PROMPT);
 
 181 #define PROBE_DEBUG(args...) (printk (args))
 
 183 #define PROBE_DEBUG(args...) ;
 
 186 /* Set the DMA to be byte at a time */
 
 187 #define CONFIG0H_DMA_OFF OBOE_CONFIG0H_RCVANY
 
 188 #define CONFIG0H_DMA_ON_NORX CONFIG0H_DMA_OFF| OBOE_CONFIG0H_ENDMAC
 
 189 #define CONFIG0H_DMA_ON CONFIG0H_DMA_ON_NORX | OBOE_CONFIG0H_ENRX
 
 191 static struct pci_device_id toshoboe_pci_tbl[] = {
 
 192         { PCI_VENDOR_ID_TOSHIBA, PCI_DEVICE_ID_FIR701, PCI_ANY_ID, PCI_ANY_ID, },
 
 193         { PCI_VENDOR_ID_TOSHIBA, PCI_DEVICE_ID_FIRD01, PCI_ANY_ID, PCI_ANY_ID, },
 
 194         { }                     /* Terminating entry */
 
 196 MODULE_DEVICE_TABLE(pci, toshoboe_pci_tbl);
 
 198 #define DRIVER_NAME "toshoboe"
 
 199 static char *driver_name = DRIVER_NAME;
 
 201 static int max_baud = 4000000;
 
 203 static int do_probe = 0;
 
 207 /**********************************************************************/
 
 209 toshoboe_checkfcs (unsigned char *buf, int len)
 
 219   fcs.value = INIT_FCS;
 
 221   for (i = 0; i < len; ++i)
 
 222     fcs.value = irda_fcs (fcs.value, *(buf++));
 
 224   return (fcs.value == GOOD_FCS);
 
 227 /***********************************************************************/
 
 228 /* Generic chip handling code */
 
 230 static unsigned char dump[50];
 
 232 _dumpbufs (unsigned char *data, int len, char tete)
 
 236 for (i=0;i<len;i+=16) {
 
 237     for (j=0;j<16 && i+j<len;j++) { sprintf(&dump[3*j],"%02x.",data[i+j]); }
 
 239     IRDA_DEBUG (2, "%c%s\n",head , dump);
 
 246 /* Dump the registers */
 
 248 toshoboe_dumpregs (struct toshoboe_cb *self)
 
 252   IRDA_DEBUG (4, "%s()\n", __FUNCTION__);
 
 254   ringbase = INB (OBOE_RING_BASE0) << 10;
 
 255   ringbase |= INB (OBOE_RING_BASE1) << 18;
 
 256   ringbase |= INB (OBOE_RING_BASE2) << 26;
 
 258   printk (KERN_ERR DRIVER_NAME ": Register dump:\n");
 
 259   printk (KERN_ERR "Interrupts: Tx:%d Rx:%d TxUnder:%d RxOver:%d Sip:%d\n",
 
 260           self->int_tx, self->int_rx, self->int_txunder, self->int_rxover,
 
 262   printk (KERN_ERR "RX %02x TX %02x RingBase %08x\n",
 
 263           INB (OBOE_RXSLOT), INB (OBOE_TXSLOT), ringbase);
 
 264   printk (KERN_ERR "RING_SIZE %02x IER %02x ISR %02x\n",
 
 265           INB (OBOE_RING_SIZE), INB (OBOE_IER), INB (OBOE_ISR));
 
 266   printk (KERN_ERR "CONFIG1 %02x STATUS %02x\n",
 
 267           INB (OBOE_CONFIG1), INB (OBOE_STATUS));
 
 268   printk (KERN_ERR "CONFIG0 %02x%02x ENABLE %02x%02x\n",
 
 269           INB (OBOE_CONFIG0H), INB (OBOE_CONFIG0L),
 
 270           INB (OBOE_ENABLEH), INB (OBOE_ENABLEL));
 
 271   printk (KERN_ERR "NEW_PCONFIG %02x%02x CURR_PCONFIG %02x%02x\n",
 
 272           INB (OBOE_NEW_PCONFIGH), INB (OBOE_NEW_PCONFIGL),
 
 273           INB (OBOE_CURR_PCONFIGH), INB (OBOE_CURR_PCONFIGL));
 
 274   printk (KERN_ERR "MAXLEN %02x%02x RXCOUNT %02x%02x\n",
 
 275           INB (OBOE_MAXLENH), INB (OBOE_MAXLENL),
 
 276           INB (OBOE_RXCOUNTL), INB (OBOE_RXCOUNTH));
 
 281       ringbase = virt_to_bus (self->ring);
 
 282       printk (KERN_ERR "Ring at %08x:\n", ringbase);
 
 283       printk (KERN_ERR "RX:");
 
 284       for (i = 0; i < RX_SLOTS; ++i)
 
 285         printk (" (%d,%02x)",self->ring->rx[i].len,self->ring->rx[i].control);
 
 287       printk (KERN_ERR "TX:");
 
 288       for (i = 0; i < RX_SLOTS; ++i)
 
 289         printk (" (%d,%02x)",self->ring->tx[i].len,self->ring->tx[i].control);
 
 295 /*Don't let the chip look at memory */
 
 297 toshoboe_disablebm (struct toshoboe_cb *self)
 
 300   IRDA_DEBUG (4, "%s()\n", __FUNCTION__);
 
 302   pci_read_config_byte (self->pdev, PCI_COMMAND, &command);
 
 303   command &= ~PCI_COMMAND_MASTER;
 
 304   pci_write_config_byte (self->pdev, PCI_COMMAND, command);
 
 308 /* Shutdown the chip and point the taskfile reg somewhere else */
 
 310 toshoboe_stopchip (struct toshoboe_cb *self)
 
 312   IRDA_DEBUG (4, "%s()\n", __FUNCTION__);
 
 314   /*Disable interrupts */
 
 315   OUTB (0x0, OBOE_IER);
 
 316   /*Disable DMA, Disable Rx, Disable Tx */
 
 317   OUTB (CONFIG0H_DMA_OFF, OBOE_CONFIG0H);
 
 318   /*Disable SIR MIR FIR, Tx and Rx */
 
 319   OUTB (0x00, OBOE_ENABLEH);
 
 320   /*Point the ring somewhere safe */
 
 321   OUTB (0x3f, OBOE_RING_BASE2);
 
 322   OUTB (0xff, OBOE_RING_BASE1);
 
 323   OUTB (0xff, OBOE_RING_BASE0);
 
 325   OUTB (RX_LEN >> 8, OBOE_MAXLENH);
 
 326   OUTB (RX_LEN & 0xff, OBOE_MAXLENL);
 
 328   /*Acknoledge any pending interrupts */
 
 329   OUTB (0xff, OBOE_ISR);
 
 332   OUTB (OBOE_ENABLEH_PHYANDCLOCK, OBOE_ENABLEH);
 
 335   OUTB (OBOE_CONFIG1_OFF, OBOE_CONFIG1);
 
 337   toshoboe_disablebm (self);
 
 340 /* Transmitter initialization */
 
 342 toshoboe_start_DMA (struct toshoboe_cb *self, int opts)
 
 344   OUTB (0x0, OBOE_ENABLEH);
 
 345   OUTB (CONFIG0H_DMA_ON | opts,  OBOE_CONFIG0H);
 
 346   OUTB (OBOE_ENABLEH_PHYANDCLOCK, OBOE_ENABLEH);
 
 350 /*Set the baud rate */
 
 352 toshoboe_setbaud (struct toshoboe_cb *self)
 
 357   IRDA_DEBUG (2, "%s(%d/%d)\n", __FUNCTION__, self->speed, self->io.speed);
 
 375       printk (KERN_ERR DRIVER_NAME ": switch to unsupported baudrate %d\n",
 
 382       /* For SIR the preamble is done by adding XBOFs */
 
 384       /* set to filtered SIR mode, filter looks for BOF and EOF */
 
 386       pconfig |= 47 << OBOE_PCONFIG_BAUDSHIFT;
 
 387       pconfig |= 25 << OBOE_PCONFIG_WIDTHSHIFT;
 
 390       pconfig |= 23 << OBOE_PCONFIG_BAUDSHIFT;
 
 391       pconfig |= 25 << OBOE_PCONFIG_WIDTHSHIFT;
 
 394       pconfig |= 11 << OBOE_PCONFIG_BAUDSHIFT;
 
 395       pconfig |= 25 << OBOE_PCONFIG_WIDTHSHIFT;
 
 398       pconfig |= 5 << OBOE_PCONFIG_BAUDSHIFT;
 
 399       pconfig |= 25 << OBOE_PCONFIG_WIDTHSHIFT;
 
 402       pconfig |= 2 << OBOE_PCONFIG_BAUDSHIFT;
 
 403       pconfig |= 25 << OBOE_PCONFIG_WIDTHSHIFT;
 
 406       pconfig |= 1 << OBOE_PCONFIG_BAUDSHIFT;
 
 407       pconfig |= 25 << OBOE_PCONFIG_WIDTHSHIFT;
 
 410       pconfig |= 0 << OBOE_PCONFIG_BAUDSHIFT;
 
 411       pconfig |= 25 << OBOE_PCONFIG_WIDTHSHIFT;
 
 414       /*Set to packet based reception */
 
 415       OUTB (RX_LEN >> 8, OBOE_MAXLENH);
 
 416       OUTB (RX_LEN & 0xff, OBOE_MAXLENL);
 
 429       config0l = OBOE_CONFIG0L_ENSIR;
 
 432           /*Set to character based reception */
 
 433           /*System will lock if MAXLEN=0 */
 
 434           /*so have to be careful */
 
 435           OUTB (0x01, OBOE_MAXLENH);
 
 436           OUTB (0x01, OBOE_MAXLENL);
 
 437           OUTB (0x00, OBOE_MAXLENH);
 
 441           /*Set to packet based reception */
 
 442           config0l |= OBOE_CONFIG0L_ENSIRF;
 
 443           OUTB (RX_LEN >> 8, OBOE_MAXLENH);
 
 444           OUTB (RX_LEN & 0xff, OBOE_MAXLENL);
 
 450       /* Set for 16 bit CRC and enable MIR */
 
 451       /* Preamble now handled by the chip */
 
 453       pconfig |= 0 << OBOE_PCONFIG_BAUDSHIFT;
 
 454       pconfig |= 8 << OBOE_PCONFIG_WIDTHSHIFT;
 
 455       pconfig |= 1 << OBOE_PCONFIG_PREAMBLESHIFT;
 
 456       config0l = OBOE_CONFIG0L_CRC16 | OBOE_CONFIG0L_ENMIR;
 
 460       /* Set for 32 bit CRC and enable FIR */
 
 461       /* Preamble handled by the chip */
 
 463       pconfig |= 0 << OBOE_PCONFIG_BAUDSHIFT;
 
 464       /* Documentation says 14, but toshiba use 15 in their drivers */
 
 465       pconfig |= 15 << OBOE_PCONFIG_PREAMBLESHIFT;
 
 466       config0l = OBOE_CONFIG0L_ENFIR;
 
 470   /* Copy into new PHY config buffer */
 
 471   OUTBP (pconfig >> 8, OBOE_NEW_PCONFIGH);
 
 472   OUTB (pconfig & 0xff, OBOE_NEW_PCONFIGL);
 
 473   OUTB (config0l, OBOE_CONFIG0L);
 
 475   /* Now make OBOE copy from new PHY to current PHY */
 
 476   OUTB (0x0, OBOE_ENABLEH);
 
 477   OUTB (OBOE_ENABLEH_PHYANDCLOCK, OBOE_ENABLEH);
 
 480   /* speed change executed */
 
 482   self->io.speed = self->speed;
 
 485 /*Let the chip look at memory */
 
 487 toshoboe_enablebm (struct toshoboe_cb *self)
 
 489   IRDA_DEBUG (4, "%s()\n", __FUNCTION__);
 
 490   pci_set_master (self->pdev);
 
 495 toshoboe_initring (struct toshoboe_cb *self)
 
 499   IRDA_DEBUG (4, "%s()\n", __FUNCTION__);
 
 501   for (i = 0; i < TX_SLOTS; ++i)
 
 503       self->ring->tx[i].len = 0;
 
 504       self->ring->tx[i].control = 0x00;
 
 505       self->ring->tx[i].address = virt_to_bus (self->tx_bufs[i]);
 
 508   for (i = 0; i < RX_SLOTS; ++i)
 
 510       self->ring->rx[i].len = RX_LEN;
 
 511       self->ring->rx[i].len = 0;
 
 512       self->ring->rx[i].address = virt_to_bus (self->rx_bufs[i]);
 
 513       self->ring->rx[i].control = OBOE_CTL_RX_HW_OWNS;
 
 518 toshoboe_resetptrs (struct toshoboe_cb *self)
 
 520   /* Can reset pointers by twidling DMA */
 
 521   OUTB (0x0, OBOE_ENABLEH);
 
 522   OUTBP (CONFIG0H_DMA_OFF, OBOE_CONFIG0H);
 
 523   OUTB (OBOE_ENABLEH_PHYANDCLOCK, OBOE_ENABLEH);
 
 525   self->rxs = inb_p (OBOE_RXSLOT) & OBOE_SLOT_MASK;
 
 526   self->txs = inb_p (OBOE_TXSLOT) & OBOE_SLOT_MASK;
 
 529 /* Called in locked state */
 
 531 toshoboe_initptrs (struct toshoboe_cb *self)
 
 534   /* spin_lock_irqsave(self->spinlock, flags); */
 
 535   /* save_flags (flags); */
 
 537   /* Can reset pointers by twidling DMA */
 
 538   toshoboe_resetptrs (self);
 
 540   OUTB (0x0, OBOE_ENABLEH);
 
 541   OUTB (CONFIG0H_DMA_ON, OBOE_CONFIG0H);
 
 542   OUTB (OBOE_ENABLEH_PHYANDCLOCK, OBOE_ENABLEH);
 
 546   /* spin_unlock_irqrestore(self->spinlock, flags); */
 
 547   /* restore_flags (flags); */
 
 550 /* Wake the chip up and get it looking at the rings */
 
 551 /* Called in locked state */
 
 553 toshoboe_startchip (struct toshoboe_cb *self)
 
 557   IRDA_DEBUG (4, "%s()\n", __FUNCTION__);
 
 559   toshoboe_initring (self);
 
 560   toshoboe_enablebm (self);
 
 561   OUTBP (OBOE_CONFIG1_RESET, OBOE_CONFIG1);
 
 562   OUTBP (OBOE_CONFIG1_ON, OBOE_CONFIG1);
 
 564   /* Stop the clocks */
 
 565   OUTB (0, OBOE_ENABLEH);
 
 567   /*Set size of rings */
 
 568   OUTB (RING_SIZE, OBOE_RING_SIZE);
 
 570   /*Acknoledge any pending interrupts */
 
 571   OUTB (0xff, OBOE_ISR);
 
 574   OUTB (OBOE_INT_TXDONE  | OBOE_INT_RXDONE |
 
 575         OBOE_INT_TXUNDER | OBOE_INT_RXOVER | OBOE_INT_SIP , OBOE_IER);
 
 577   /*Acknoledge any pending interrupts */
 
 578   OUTB (0xff, OBOE_ISR);
 
 580   /*Set the maximum packet length to 0xfff (4095) */
 
 581   OUTB (RX_LEN >> 8, OBOE_MAXLENH);
 
 582   OUTB (RX_LEN & 0xff, OBOE_MAXLENL);
 
 585   OUTB (CONFIG0H_DMA_OFF, OBOE_CONFIG0H);
 
 587   /*Find out where the rings live */
 
 588   physaddr = virt_to_bus (self->ring);
 
 590   IRDA_ASSERT ((physaddr & 0x3ff) == 0,
 
 591                printk (KERN_ERR DRIVER_NAME "ring not correctly aligned\n");
 
 594   OUTB ((physaddr >> 10) & 0xff, OBOE_RING_BASE0);
 
 595   OUTB ((physaddr >> 18) & 0xff, OBOE_RING_BASE1);
 
 596   OUTB ((physaddr >> 26) & 0x3f, OBOE_RING_BASE2);
 
 598   /*Enable DMA controler in byte mode and RX */
 
 599   OUTB (CONFIG0H_DMA_ON, OBOE_CONFIG0H);
 
 601   /* Start up the clocks */
 
 602   OUTB (OBOE_ENABLEH_PHYANDCLOCK, OBOE_ENABLEH);
 
 604   /*set to sensible speed */
 
 606   toshoboe_setbaud (self);
 
 607   toshoboe_initptrs (self);
 
 611 toshoboe_isntstuck (struct toshoboe_cb *self)
 
 616 toshoboe_checkstuck (struct toshoboe_cb *self)
 
 622       spin_lock_irqsave(&self->spinlock, flags);
 
 624       /* This will reset the chip completely */
 
 625       printk (KERN_ERR DRIVER_NAME ": Resetting chip\n");
 
 627       toshoboe_stopchip (self);
 
 628       toshoboe_startchip (self);
 
 629       spin_unlock_irqrestore(&self->spinlock, flags);
 
 633 /*Generate packet of about mtt us long */
 
 635 toshoboe_makemttpacket (struct toshoboe_cb *self, void *buf, int mtt)
 
 639   xbofs = ((int) (mtt/100)) * (int) (self->speed);
 
 640   xbofs=xbofs/80000; /*Eight bits per byte, and mtt is in us*/
 
 643   IRDA_DEBUG (2, DRIVER_NAME
 
 644       ": generated mtt of %d bytes for %d us at %d baud\n"
 
 645           , xbofs,mtt,self->speed);
 
 649       printk (KERN_ERR DRIVER_NAME ": wanted %d bytes MTT but TX_LEN is %d\n",
 
 654   /*xbofs will do for SIR, MIR and FIR,SIR mode doesn't generate a checksum anyway */
 
 655   memset (buf, XBOF, xbofs);
 
 660 static int toshoboe_invalid_dev(int irq)
 
 662   printk (KERN_WARNING DRIVER_NAME ": irq %d for unknown device.\n", irq);
 
 667 /***********************************************************************/
 
 671 toshoboe_dumptx (struct toshoboe_cb *self)
 
 674   PROBE_DEBUG(KERN_WARNING "TX:");
 
 675   for (i = 0; i < RX_SLOTS; ++i)
 
 676     PROBE_DEBUG(" (%d,%02x)",self->ring->tx[i].len,self->ring->tx[i].control);
 
 677   PROBE_DEBUG(" [%d]\n",self->speed);
 
 681 toshoboe_dumprx (struct toshoboe_cb *self, int score)
 
 684   PROBE_DEBUG(" %d\nRX:",score);
 
 685   for (i = 0; i < RX_SLOTS; ++i)
 
 686     PROBE_DEBUG(" (%d,%02x)",self->ring->rx[i].len,self->ring->rx[i].control);
 
 691 stuff_byte (__u8 byte, __u8 * buf)
 
 695     case BOF:                  /* FALLTHROUGH */
 
 696     case EOF:                  /* FALLTHROUGH */
 
 698       /* Insert transparently coded */
 
 699       buf[0] = CE;              /* Send link escape */
 
 700       buf[1] = byte ^ IRDA_TRANS; /* Complement bit 5 */
 
 704       /* Non-special value, no transparency required */
 
 712 toshoboe_probeinterrupt (int irq, void *dev_id, struct pt_regs *regs)
 
 714   struct toshoboe_cb *self = (struct toshoboe_cb *) dev_id;
 
 717   if (self == NULL && toshoboe_invalid_dev(irq))
 
 720   irqstat = INB (OBOE_ISR);
 
 723   if (!(irqstat & OBOE_INT_MASK))
 
 726 /* Ack all the interrupts */
 
 727   OUTB (irqstat, OBOE_ISR);
 
 729   if (irqstat & OBOE_INT_TXDONE)
 
 736       txp = INB (OBOE_TXSLOT) & OBOE_SLOT_MASK;
 
 737       if (self->ring->tx[txp].control & OBOE_CTL_TX_HW_OWNS)
 
 741           toshoboe_start_DMA(self, OBOE_CONFIG0H_ENTX | OBOE_CONFIG0H_LOOP);
 
 745   if (irqstat & OBOE_INT_RXDONE) {
 
 748   if (irqstat & OBOE_INT_TXUNDER) {
 
 751   if (irqstat & OBOE_INT_RXOVER) {
 
 754   if (irqstat & OBOE_INT_SIP) {
 
 761 toshoboe_maketestpacket (unsigned char *buf, int badcrc, int fir)
 
 774       memset (buf, 0, TT_LEN);
 
 778   fcs.value = INIT_FCS;
 
 780   memset (buf, XBOF, 10);
 
 784   for (i = 0; i < TT_LEN; ++i)
 
 786       len += stuff_byte (i, buf + len);
 
 787       fcs.value = irda_fcs (fcs.value, i);
 
 790   len += stuff_byte (fcs.bytes[0] ^ badcrc, buf + len);
 
 791   len += stuff_byte (fcs.bytes[1] ^ badcrc, buf + len);
 
 798 toshoboe_probefail (struct toshoboe_cb *self, char *msg)
 
 800   printk (KERN_ERR DRIVER_NAME "probe(%d) failed %s\n",self-> speed, msg);
 
 801   toshoboe_dumpregs (self);
 
 802   toshoboe_stopchip (self);
 
 803   free_irq (self->io.irq, (void *) self);
 
 808 toshoboe_numvalidrcvs (struct toshoboe_cb *self)
 
 811   for (i = 0; i < RX_SLOTS; ++i)
 
 812     if ((self->ring->rx[i].control & 0xe0) == 0)
 
 819 toshoboe_numrcvs (struct toshoboe_cb *self)
 
 822   for (i = 0; i < RX_SLOTS; ++i)
 
 823     if (!(self->ring->rx[i].control & OBOE_CTL_RX_HW_OWNS))
 
 830 toshoboe_probe (struct toshoboe_cb *self)
 
 834   int bauds[] = { 9600, 115200, 4000000, 1152000 };
 
 836   int bauds[] = { 9600, 115200, 4000000 };
 
 840   IRDA_DEBUG (4, "%s()\n", __FUNCTION__);
 
 842   if (request_irq (self->io.irq, toshoboe_probeinterrupt,
 
 843                    self->io.irqflags, "toshoboe", (void *) self))
 
 845       printk (KERN_ERR DRIVER_NAME ": probe failed to allocate irq %d\n",
 
 850   /* test 1: SIR filter and back to back */
 
 852   for (j = 0; j < (sizeof (bauds) / sizeof (int)); ++j)
 
 855       toshoboe_stopchip (self);
 
 858       spin_lock_irqsave(&self->spinlock, flags);
 
 859       /*Address is already setup */
 
 860       toshoboe_startchip (self);
 
 861       self->int_rx = self->int_tx = 0;
 
 862       self->speed = bauds[j];
 
 863       toshoboe_setbaud (self);
 
 864       toshoboe_initptrs (self);
 
 865       spin_unlock_irqrestore(&self->spinlock, flags);
 
 867       self->ring->tx[self->txs].control =
 
 868 /*   (FIR only) OBOE_CTL_TX_SIP needed for switching to next slot */
 
 869 /*    MIR: all received data is stored in one slot */
 
 870         (fir) ? OBOE_CTL_TX_HW_OWNS | OBOE_CTL_TX_RTCENTX
 
 871               : OBOE_CTL_TX_HW_OWNS ;
 
 872       self->ring->tx[self->txs].len =
 
 873         toshoboe_maketestpacket (self->tx_bufs[self->txs], 0, fir);
 
 875       self->txs %= TX_SLOTS;
 
 877       self->ring->tx[self->txs].control =
 
 878         (fir) ? OBOE_CTL_TX_HW_OWNS | OBOE_CTL_TX_SIP
 
 879               : OBOE_CTL_TX_HW_OWNS | OBOE_CTL_TX_RTCENTX ;
 
 880       self->ring->tx[self->txs].len =
 
 881         toshoboe_maketestpacket (self->tx_bufs[self->txs], 0, fir);
 
 883       self->txs %= TX_SLOTS;
 
 885       self->ring->tx[self->txs].control =
 
 886         (fir) ? OBOE_CTL_TX_HW_OWNS | OBOE_CTL_TX_RTCENTX
 
 887               : OBOE_CTL_TX_HW_OWNS ;
 
 888       self->ring->tx[self->txs].len =
 
 889         toshoboe_maketestpacket (self->tx_bufs[self->txs], 0, fir);
 
 891       self->txs %= TX_SLOTS;
 
 893       self->ring->tx[self->txs].control =
 
 894         (fir) ? OBOE_CTL_TX_HW_OWNS | OBOE_CTL_TX_RTCENTX
 
 895               | OBOE_CTL_TX_SIP     | OBOE_CTL_TX_BAD_CRC
 
 896               : OBOE_CTL_TX_HW_OWNS | OBOE_CTL_TX_RTCENTX ;
 
 897       self->ring->tx[self->txs].len =
 
 898         toshoboe_maketestpacket (self->tx_bufs[self->txs], 0, fir);
 
 900       self->txs %= TX_SLOTS;
 
 902       toshoboe_dumptx (self);
 
 903       /* Turn on TX and RX and loopback */
 
 904       toshoboe_start_DMA(self, OBOE_CONFIG0H_ENTX | OBOE_CONFIG0H_LOOP);
 
 908       while (toshoboe_numvalidrcvs (self) != n)
 
 911               return toshoboe_probefail (self, "filter test");
 
 912           udelay ((9600*(TT_LEN+16))/self->speed);
 
 917       while ((toshoboe_numrcvs(self) != self->int_rx) || (self->int_tx != n))
 
 920               return toshoboe_probefail (self, "interrupt test");
 
 921           udelay ((9600*(TT_LEN+16))/self->speed);
 
 924      toshoboe_dumprx (self,i);
 
 928   /* test 2: SIR in char at a time */
 
 930   toshoboe_stopchip (self);
 
 931   self->int_rx = self->int_tx = 0;
 
 933   spin_lock_irqsave(&self->spinlock, flags);
 
 934   toshoboe_startchip (self);
 
 935   spin_unlock_irqrestore(&self->spinlock, flags);
 
 938   self->speed = 115200;
 
 939   toshoboe_setbaud (self);
 
 940   self->ring->tx[self->txs].control =
 
 941     OBOE_CTL_TX_RTCENTX | OBOE_CTL_TX_HW_OWNS;
 
 942   self->ring->tx[self->txs].len = 4;
 
 944   ((unsigned char *) self->tx_bufs[self->txs])[0] = 'f';
 
 945   ((unsigned char *) self->tx_bufs[self->txs])[1] = 'i';
 
 946   ((unsigned char *) self->tx_bufs[self->txs])[2] = 's';
 
 947   ((unsigned char *) self->tx_bufs[self->txs])[3] = 'h';
 
 948   toshoboe_dumptx (self);
 
 949   toshoboe_start_DMA(self, OBOE_CONFIG0H_ENTX | OBOE_CONFIG0H_LOOP);
 
 952   while (toshoboe_numvalidrcvs (self) != 4)
 
 955           return toshoboe_probefail (self, "Async test");
 
 960   while ((toshoboe_numrcvs (self) != self->int_rx) || (self->int_tx != 1))
 
 963           return toshoboe_probefail (self, "Async interrupt test");
 
 967   toshoboe_dumprx (self,i);
 
 971   toshoboe_setbaud (self);
 
 972   toshoboe_stopchip (self);
 
 974   free_irq (self->io.irq, (void *) self);
 
 976   printk (KERN_WARNING DRIVER_NAME ": Self test passed ok\n");
 
 982 /******************************************************************/
 
 983 /* Netdev style code */
 
 985 /* Transmit something */
 
 987 toshoboe_hard_xmit (struct sk_buff *skb, struct net_device *dev)
 
 989   struct toshoboe_cb *self;
 
 993   struct irda_skb_cb *cb = (struct irda_skb_cb *) skb->cb;
 
 995   self = (struct toshoboe_cb *) dev->priv;
 
 997   IRDA_ASSERT (self != NULL, return 0; );
 
 999   IRDA_DEBUG (1, "%s.tx:%x(%x)%x\n", __FUNCTION__
 
1000       ,skb->len,self->txpending,INB (OBOE_ENABLEH));
 
1002       IRDA_DEBUG (2, "%s.Not IrLAP:%x\n", __FUNCTION__, cb->magic);
 
1004       _dumpbufs(skb->data,skb->len,'>');
 
1008   /* change speed pending, wait for its execution */
 
1009   if (self->new_speed)
 
1012   /* device stopped (apm) wait for restart */
 
1016   toshoboe_checkstuck (self);
 
1018   dev->trans_start = jiffies;
 
1020  /* Check if we need to change the speed */
 
1021   /* But not now. Wait after transmission if mtt not required */
 
1022   speed=irda_get_next_speed(skb);
 
1023   if ((speed != self->io.speed) && (speed != -1))
 
1025       spin_lock_irqsave(&self->spinlock, flags);
 
1027       if (self->txpending || skb->len)
 
1029           self->new_speed = speed;
 
1030           IRDA_DEBUG (1, "%s: Queued TxDone scheduled speed change %d\n" ,
 
1031                       __FUNCTION__, speed);
 
1032           /* if no data, that's all! */
 
1035               spin_unlock_irqrestore(&self->spinlock, flags);
 
1036               dev_kfree_skb (skb);
 
1039           /* True packet, go on, but */
 
1040           /* do not accept anything before change speed execution */
 
1041           netif_stop_queue(dev);
 
1042           /* ready to process TxDone interrupt */
 
1043           spin_unlock_irqrestore(&self->spinlock, flags);
 
1047           /* idle and no data, change speed now */
 
1048           self->speed = speed;
 
1049           toshoboe_setbaud (self);
 
1050           spin_unlock_irqrestore(&self->spinlock, flags);
 
1051           dev_kfree_skb (skb);
 
1057   if ((mtt = irda_get_mtt(skb)))
 
1059       /* This is fair since the queue should be empty anyway */
 
1060       spin_lock_irqsave(&self->spinlock, flags);
 
1062       if (self->txpending)
 
1064           spin_unlock_irqrestore(&self->spinlock, flags);
 
1068       /* If in SIR mode we need to generate a string of XBOFs */
 
1069       /* In MIR and FIR we need to generate a string of data */
 
1070       /* which we will add a wrong checksum to */
 
1072       mtt = toshoboe_makemttpacket (self, self->tx_bufs[self->txs], mtt);
 
1073       IRDA_DEBUG (1, "%s.mtt:%x(%x)%d\n", __FUNCTION__
 
1074           ,skb->len,mtt,self->txpending);
 
1077           self->ring->tx[self->txs].len = mtt & 0xfff;
 
1079           ctl = OBOE_CTL_TX_HW_OWNS | OBOE_CTL_TX_RTCENTX;
 
1080           if (INB (OBOE_ENABLEH) & OBOE_ENABLEH_FIRON)
 
1082               ctl |= OBOE_CTL_TX_BAD_CRC | OBOE_CTL_TX_SIP ;
 
1085           else if (INB (OBOE_ENABLEH) & OBOE_ENABLEH_MIRON)
 
1087               ctl |= OBOE_CTL_TX_BAD_CRC;
 
1090           self->ring->tx[self->txs].control = ctl;
 
1092           OUTB (0x0, OBOE_ENABLEH);
 
1093           /* It is only a timer. Do not send mtt packet outside! */
 
1094           toshoboe_start_DMA(self, OBOE_CONFIG0H_ENTX | OBOE_CONFIG0H_LOOP);
 
1099           self->txs %= TX_SLOTS;
 
1104           printk(KERN_ERR DRIVER_NAME ": problem with mtt packet - ignored\n");
 
1106       spin_unlock_irqrestore(&self->spinlock, flags);
 
1110 dumpbufs(skb->data,skb->len,'>');
 
1113   spin_lock_irqsave(&self->spinlock, flags);
 
1115   if (self->ring->tx[self->txs].control & OBOE_CTL_TX_HW_OWNS)
 
1117       IRDA_DEBUG (0, "%s.ful:%x(%x)%x\n", __FUNCTION__
 
1118           ,skb->len, self->ring->tx[self->txs].control, self->txpending);
 
1119       toshoboe_start_DMA(self, OBOE_CONFIG0H_ENTX);
 
1120       spin_unlock_irqrestore(&self->spinlock, flags);
 
1124   if (INB (OBOE_ENABLEH) & OBOE_ENABLEH_SIRON)
 
1126       len = async_wrap_skb (skb, self->tx_bufs[self->txs], TX_BUF_SZ);
 
1131       memcpy (self->tx_bufs[self->txs], skb->data, len);
 
1133   self->ring->tx[self->txs].len = len & 0x0fff;
 
1135   /*Sometimes the HW doesn't see us assert RTCENTX in the interrupt code */
 
1136   /*later this plays safe, we garuntee the last packet to be transmitted */
 
1137   /*has RTCENTX set */
 
1139   ctl = OBOE_CTL_TX_HW_OWNS | OBOE_CTL_TX_RTCENTX;
 
1140   if (INB (OBOE_ENABLEH) & OBOE_ENABLEH_FIRON)
 
1142       ctl |= OBOE_CTL_TX_SIP ;
 
1144   self->ring->tx[self->txs].control = ctl;
 
1146   /* If transmitter is idle start in one-shot mode */
 
1148   if (!self->txpending)
 
1149       toshoboe_start_DMA(self, OBOE_CONFIG0H_ENTX);
 
1154   self->txs %= TX_SLOTS;
 
1156   spin_unlock_irqrestore(&self->spinlock, flags);
 
1157   dev_kfree_skb (skb);
 
1162 /*interrupt handler */
 
1164 toshoboe_interrupt (int irq, void *dev_id, struct pt_regs *regs)
 
1166   struct toshoboe_cb *self = (struct toshoboe_cb *) dev_id;
 
1168   struct sk_buff *skb = NULL;
 
1170   if (self == NULL && toshoboe_invalid_dev(irq))
 
1173   irqstat = INB (OBOE_ISR);
 
1176   if (!(irqstat & OBOE_INT_MASK))
 
1179 /* Ack all the interrupts */
 
1180   OUTB (irqstat, OBOE_ISR);
 
1182   toshoboe_isntstuck (self);
 
1185   if (irqstat & OBOE_INT_TXDONE)
 
1190       txp = self->txpending;
 
1191       self->txpending = 0;
 
1193       for (i = 0; i < TX_SLOTS; ++i)
 
1195           if (self->ring->tx[i].control & OBOE_CTL_TX_HW_OWNS)
 
1198       IRDA_DEBUG (1, "%s.txd(%x)%x/%x\n", __FUNCTION__
 
1199           ,irqstat,txp,self->txpending);
 
1201       txp = INB (OBOE_TXSLOT) & OBOE_SLOT_MASK;
 
1203       /* Got anything queued ? start it together */
 
1204       if (self->ring->tx[txp].control & OBOE_CTL_TX_HW_OWNS)
 
1208           while (self->ring->tx[txpc].control & OBOE_CTL_TX_HW_OWNS)
 
1213               self->stats.tx_packets++;
 
1214               if (self->ring->tx[txpc].control & OBOE_CTL_TX_HW_OWNS)
 
1215                   self->ring->tx[txp].control &= ~OBOE_CTL_TX_RTCENTX;
 
1217           self->stats.tx_packets--;
 
1219           self->stats.tx_packets++;
 
1221           toshoboe_start_DMA(self, OBOE_CONFIG0H_ENTX);
 
1224       if ((!self->txpending) && (self->new_speed))
 
1226           self->speed = self->new_speed;
 
1227           IRDA_DEBUG (1, "%s: Executed TxDone scheduled speed change %d\n",
 
1228                       __FUNCTION__, self->speed);
 
1229           toshoboe_setbaud (self);
 
1232       /* Tell network layer that we want more frames */
 
1233       if (!self->new_speed)
 
1234           netif_wake_queue(self->netdev);
 
1237   if (irqstat & OBOE_INT_RXDONE)
 
1239       while (!(self->ring->rx[self->rxs].control & OBOE_CTL_RX_HW_OWNS))
 
1241           int len = self->ring->rx[self->rxs].len;
 
1243           IRDA_DEBUG (3, "%s.rcv:%x(%x)\n", __FUNCTION__
 
1244                       ,len,self->ring->rx[self->rxs].control);
 
1247 dumpbufs(self->rx_bufs[self->rxs],len,'<');
 
1250           if (self->ring->rx[self->rxs].control == 0)
 
1252               __u8 enable = INB (OBOE_ENABLEH);
 
1254               /* In SIR mode we need to check the CRC as this */
 
1255               /* hasn't been done by the hardware */
 
1256               if (enable & OBOE_ENABLEH_SIRON)
 
1258                   if (!toshoboe_checkfcs (self->rx_bufs[self->rxs], len))
 
1260                   /*Trim off the CRC */
 
1265                   IRDA_DEBUG (1, "%s.SIR:%x(%x)\n", __FUNCTION__, len,enable);
 
1269               else if (enable & OBOE_ENABLEH_MIRON)
 
1275                   IRDA_DEBUG (2, "%s.MIR:%x(%x)\n", __FUNCTION__, len,enable);
 
1278               else if (enable & OBOE_ENABLEH_FIRON)
 
1281                       len -= 4;   /*FIXME: check this */
 
1284                   IRDA_DEBUG (1, "%s.FIR:%x(%x)\n", __FUNCTION__, len,enable);
 
1287                   IRDA_DEBUG (0, "%s.?IR:%x(%x)\n", __FUNCTION__, len,enable);
 
1291                   skb = dev_alloc_skb (len + 1);
 
1294                       skb_reserve (skb, 1);
 
1297                       memcpy (skb->data, self->rx_bufs[self->rxs], len);
 
1299                       self->stats.rx_packets++;
 
1300                       skb->dev = self->netdev;
 
1301                       skb->mac.raw = skb->data;
 
1302                       skb->protocol = htons (ETH_P_IRDA);
 
1307                               "%s(), memory squeeze, dropping frame.\n",
 
1314             /* TODO: =========================================== */
 
1315             /*  if OBOE_CTL_RX_LENGTH, our buffers are too small */
 
1316             /* (MIR or FIR) data is lost. */
 
1317             /* (SIR) data is splitted in several slots. */
 
1318             /* we have to join all the received buffers received */
 
1319             /*in a large buffer before checking CRC. */
 
1320             IRDA_DEBUG (0, "%s.err:%x(%x)\n", __FUNCTION__
 
1321                 ,len,self->ring->rx[self->rxs].control);
 
1324           self->ring->rx[self->rxs].len = 0x0;
 
1325           self->ring->rx[self->rxs].control = OBOE_CTL_RX_HW_OWNS;
 
1328           self->rxs %= RX_SLOTS;
 
1336   if (irqstat & OBOE_INT_TXUNDER)
 
1338       printk (KERN_WARNING DRIVER_NAME ": tx fifo underflow\n");
 
1340   if (irqstat & OBOE_INT_RXOVER)
 
1342       printk (KERN_WARNING DRIVER_NAME ": rx fifo overflow\n");
 
1344 /* This must be useful for something... */
 
1345   if (irqstat & OBOE_INT_SIP)
 
1348       IRDA_DEBUG (1, "%s.sip:%x(%x)%x\n", __FUNCTION__
 
1349               ,self->int_sip,irqstat,self->txpending);
 
1356 toshoboe_net_open (struct net_device *dev)
 
1358   struct toshoboe_cb *self;
 
1359   unsigned long flags;
 
1361   IRDA_DEBUG (4, "%s()\n", __FUNCTION__);
 
1363   IRDA_ASSERT (dev != NULL, return -1; );
 
1364   self = (struct toshoboe_cb *) dev->priv;
 
1366   IRDA_ASSERT (self != NULL, return 0; );
 
1374   if (request_irq (self->io.irq, toshoboe_interrupt,
 
1375                    IRQF_SHARED | IRQF_DISABLED, dev->name, (void *) self))
 
1380   spin_lock_irqsave(&self->spinlock, flags);
 
1381   toshoboe_startchip (self);
 
1382   spin_unlock_irqrestore(&self->spinlock, flags);
 
1384   /* Ready to play! */
 
1385   netif_start_queue(dev);
 
1388    * Open new IrLAP layer instance, now that everything should be
 
1389    * initialized properly
 
1391   self->irlap = irlap_open (dev, &self->qos, driver_name);
 
1399 toshoboe_net_close (struct net_device *dev)
 
1401   struct toshoboe_cb *self;
 
1403   IRDA_DEBUG (4, "%s()\n", __FUNCTION__);
 
1405   IRDA_ASSERT (dev != NULL, return -1; );
 
1406   self = (struct toshoboe_cb *) dev->priv;
 
1409   netif_stop_queue(dev);
 
1411   /* Stop and remove instance of IrLAP */
 
1413     irlap_close (self->irlap);
 
1418   free_irq (self->io.irq, (void *) self);
 
1422       toshoboe_stopchip (self);
 
1429  * Function toshoboe_net_ioctl (dev, rq, cmd)
 
1431  *    Process IOCTL commands for this device
 
1435 toshoboe_net_ioctl (struct net_device *dev, struct ifreq *rq, int cmd)
 
1437   struct if_irda_req *irq = (struct if_irda_req *) rq;
 
1438   struct toshoboe_cb *self;
 
1439   unsigned long flags;
 
1442   IRDA_ASSERT (dev != NULL, return -1; );
 
1446   IRDA_ASSERT (self != NULL, return -1; );
 
1448   IRDA_DEBUG (5, "%s(), %s, (cmd=0x%X)\n", __FUNCTION__, dev->name, cmd);
 
1450   /* Disable interrupts & save flags */
 
1451   spin_lock_irqsave(&self->spinlock, flags);
 
1455     case SIOCSBANDWIDTH:       /* Set bandwidth */
 
1456       /* This function will also be used by IrLAP to change the
 
1457        * speed, so we still must allow for speed change within
 
1458        * interrupt context.
 
1460       IRDA_DEBUG (1, "%s(BANDWIDTH), %s, (%X/%ld\n", __FUNCTION__
 
1461           ,dev->name, INB (OBOE_STATUS), irq->ifr_baudrate );
 
1462       if (!in_interrupt () && !capable (CAP_NET_ADMIN)) {
 
1467       /* self->speed=irq->ifr_baudrate; */
 
1468       /* toshoboe_setbaud(self); */
 
1469       /* Just change speed once - inserted by Paul Bristow */
 
1470       self->new_speed = irq->ifr_baudrate;
 
1472     case SIOCSMEDIABUSY:       /* Set media busy */
 
1473       IRDA_DEBUG (1, "%s(MEDIABUSY), %s, (%X/%x)\n", __FUNCTION__
 
1474           ,dev->name, INB (OBOE_STATUS), capable (CAP_NET_ADMIN) );
 
1475       if (!capable (CAP_NET_ADMIN)) {
 
1479       irda_device_set_media_busy (self->netdev, TRUE);
 
1481     case SIOCGRECEIVING:       /* Check if we are receiving right now */
 
1482       irq->ifr_receiving = (INB (OBOE_STATUS) & OBOE_STATUS_RXBUSY) ? 1 : 0;
 
1483       IRDA_DEBUG (3, "%s(RECEIVING), %s, (%X/%x)\n", __FUNCTION__
 
1484           ,dev->name, INB (OBOE_STATUS), irq->ifr_receiving );
 
1487       IRDA_DEBUG (1, "%s(?), %s, (cmd=0x%X)\n", __FUNCTION__, dev->name, cmd);
 
1491   spin_unlock_irqrestore(&self->spinlock, flags);
 
1496 MODULE_DESCRIPTION("Toshiba OBOE IrDA Device Driver");
 
1497 MODULE_AUTHOR("James McKenzie <james@fishsoup.dhs.org>");
 
1498 MODULE_LICENSE("GPL");
 
1500 module_param (max_baud, int, 0);
 
1501 MODULE_PARM_DESC(max_baud, "Maximum baud rate");
 
1504 module_param (do_probe, bool, 0);
 
1505 MODULE_PARM_DESC(do_probe, "Enable/disable chip probing and self-test");
 
1509 toshoboe_close (struct pci_dev *pci_dev)
 
1512   struct toshoboe_cb *self = (struct toshoboe_cb*)pci_get_drvdata(pci_dev);
 
1514   IRDA_DEBUG (4, "%s()\n", __FUNCTION__);
 
1516   IRDA_ASSERT (self != NULL, return; );
 
1520       toshoboe_stopchip (self);
 
1523   release_region (self->io.fir_base, self->io.fir_ext);
 
1525   for (i = 0; i < TX_SLOTS; ++i)
 
1527       kfree (self->tx_bufs[i]);
 
1528       self->tx_bufs[i] = NULL;
 
1531   for (i = 0; i < RX_SLOTS; ++i)
 
1533       kfree (self->rx_bufs[i]);
 
1534       self->rx_bufs[i] = NULL;
 
1537   unregister_netdev(self->netdev);
 
1539   kfree (self->ringbuf);
 
1540   self->ringbuf = NULL;
 
1543   free_netdev(self->netdev);
 
1547 toshoboe_open (struct pci_dev *pci_dev, const struct pci_device_id *pdid)
 
1549   struct toshoboe_cb *self;
 
1550   struct net_device *dev;
 
1555   IRDA_DEBUG (4, "%s()\n", __FUNCTION__);
 
1557   if ((err=pci_enable_device(pci_dev)))
 
1560   dev = alloc_irdadev(sizeof (struct toshoboe_cb));
 
1563       printk (KERN_ERR DRIVER_NAME ": can't allocate memory for "
 
1564               "IrDA control block\n");
 
1570   self->pdev = pci_dev;
 
1571   self->base = pci_resource_start(pci_dev,0);
 
1573   self->io.fir_base = self->base;
 
1574   self->io.fir_ext = OBOE_IO_EXTENT;
 
1575   self->io.irq = pci_dev->irq;
 
1576   self->io.irqflags = IRQF_SHARED | IRQF_DISABLED;
 
1578   self->speed = self->io.speed = 9600;
 
1581   /* Lock the port that we need */
 
1582   if (NULL==request_region (self->io.fir_base, self->io.fir_ext, driver_name))
 
1584       printk (KERN_ERR DRIVER_NAME ": can't get iobase of 0x%03x\n"
 
1585               ,self->io.fir_base);
 
1590   spin_lock_init(&self->spinlock);
 
1592   irda_init_max_qos_capabilies (&self->qos);
 
1593   self->qos.baud_rate.bits = 0;
 
1595   if (max_baud >= 2400)
 
1596     self->qos.baud_rate.bits |= IR_2400;
 
1597   /*if (max_baud>=4800) idev->qos.baud_rate.bits|=IR_4800; */
 
1598   if (max_baud >= 9600)
 
1599     self->qos.baud_rate.bits |= IR_9600;
 
1600   if (max_baud >= 19200)
 
1601     self->qos.baud_rate.bits |= IR_19200;
 
1602   if (max_baud >= 115200)
 
1603     self->qos.baud_rate.bits |= IR_115200;
 
1605   if (max_baud >= 1152000)
 
1607       self->qos.baud_rate.bits |= IR_1152000;
 
1610   if (max_baud >= 4000000)
 
1612       self->qos.baud_rate.bits |= (IR_4000000 << 8);
 
1615   /*FIXME: work this out... */
 
1616   self->qos.min_turn_time.bits = 0xff;
 
1618   irda_qos_bits_to_value (&self->qos);
 
1620   /* Allocate twice the size to guarantee alignment */
 
1621   self->ringbuf = (void *) kmalloc (OBOE_RING_LEN << 1, GFP_KERNEL);
 
1624       printk (KERN_ERR DRIVER_NAME ": can't allocate DMA buffers\n");
 
1629 #if (BITS_PER_LONG == 64)
 
1630 #error broken on 64-bit:  casts pointer to 32-bit, and then back to pointer.
 
1633   /*We need to align the taskfile on a taskfile size boundary */
 
1637     addr = (__u32) self->ringbuf;
 
1638     addr &= ~(OBOE_RING_LEN - 1);
 
1639     addr += OBOE_RING_LEN;
 
1640     self->ring = (struct OboeRing *) addr;
 
1643   memset (self->ring, 0, OBOE_RING_LEN);
 
1644   self->io.mem_base = (__u32) self->ring;
 
1647   for (i = 0; i < TX_SLOTS; ++i)
 
1649       self->tx_bufs[i] = kmalloc (TX_BUF_SZ, GFP_KERNEL);
 
1650       if (!self->tx_bufs[i])
 
1654   for (i = 0; i < RX_SLOTS; ++i)
 
1656       self->rx_bufs[i] = kmalloc (RX_BUF_SZ, GFP_KERNEL);
 
1657       if (!self->rx_bufs[i])
 
1663       printk (KERN_ERR DRIVER_NAME ": can't allocate rx/tx buffers\n");
 
1671     if (!toshoboe_probe (self))
 
1678   SET_MODULE_OWNER(dev);
 
1679   SET_NETDEV_DEV(dev, &pci_dev->dev);
 
1680   dev->hard_start_xmit = toshoboe_hard_xmit;
 
1681   dev->open = toshoboe_net_open;
 
1682   dev->stop = toshoboe_net_close;
 
1683   dev->do_ioctl = toshoboe_net_ioctl;
 
1685   err = register_netdev(dev);
 
1688       printk (KERN_ERR DRIVER_NAME ": register_netdev() failed\n");
 
1692   printk (KERN_INFO "IrDA: Registered device %s\n", dev->name);
 
1694   pci_set_drvdata(pci_dev,self);
 
1696   printk (KERN_INFO DRIVER_NAME ": Using multiple tasks, version %s\n", rcsid);
 
1701   for (i = 0; i < TX_SLOTS; ++i)
 
1702     kfree (self->tx_bufs[i]);
 
1703   for (i = 0; i < RX_SLOTS; ++i)
 
1704     kfree (self->rx_bufs[i]);
 
1705   kfree(self->ringbuf);
 
1708   release_region (self->io.fir_base, self->io.fir_ext);
 
1717 toshoboe_gotosleep (struct pci_dev *pci_dev, pm_message_t crap)
 
1719   struct toshoboe_cb *self = (struct toshoboe_cb*)pci_get_drvdata(pci_dev);
 
1720   unsigned long flags;
 
1723   IRDA_DEBUG (4, "%s()\n", __FUNCTION__);
 
1725   if (!self || self->stopped)
 
1728   if ((!self->irdad) && (!self->async))
 
1731 /* Flush all packets */
 
1732   while ((i--) && (self->txpending))
 
1735   spin_lock_irqsave(&self->spinlock, flags);
 
1737   toshoboe_stopchip (self);
 
1739   self->txpending = 0;
 
1741   spin_unlock_irqrestore(&self->spinlock, flags);
 
1746 toshoboe_wakeup (struct pci_dev *pci_dev)
 
1748   struct toshoboe_cb *self = (struct toshoboe_cb*)pci_get_drvdata(pci_dev);
 
1749   unsigned long flags;
 
1751   IRDA_DEBUG (4, "%s()\n", __FUNCTION__);
 
1753   if (!self || !self->stopped)
 
1756   if ((!self->irdad) && (!self->async))
 
1759   spin_lock_irqsave(&self->spinlock, flags);
 
1761   toshoboe_startchip (self);
 
1764   netif_wake_queue(self->netdev);
 
1765   spin_unlock_irqrestore(&self->spinlock, flags);
 
1769 static struct pci_driver donauboe_pci_driver = {
 
1771         .id_table       = toshoboe_pci_tbl,
 
1772         .probe          = toshoboe_open,
 
1773         .remove         = toshoboe_close,
 
1774         .suspend        = toshoboe_gotosleep,
 
1775         .resume         = toshoboe_wakeup 
 
1779 donauboe_init (void)
 
1781   return pci_register_driver(&donauboe_pci_driver);
 
1785 donauboe_cleanup (void)
 
1787   pci_unregister_driver(&donauboe_pci_driver);
 
1790 module_init(donauboe_init);
 
1791 module_exit(donauboe_cleanup);