1 /* Intel Professional Workstation/panther ethernet driver */
 
   2 /* lp486e.c: A panther 82596 ethernet driver for linux. */
 
   4     History and copyrights:
 
   7         Written 1993 by Donald Becker.
 
   8         Copyright 1993 United States Government as represented by the Director,
 
   9         National Security Agency.  This software may only be used and
 
  10         distributed according to the terms of the GNU General Public License
 
  11         as modified by SRC, incorporated herein by reference.
 
  13         The author may be reached as becker@scyld.com, or C/O
 
  14         Scyld Computing Corporation
 
  15         410 Severn Ave., Suite 210
 
  19         Written 1994 by Mark Evans.
 
  20         This driver is for the Apricot 82596 bus-master interface
 
  22         Modularised 12/94 Mark Evans
 
  24     Professional Workstation
 
  25         Derived from apricot.c by Ard van Breemen
 
  26         <ard@murphy.nl>|<ard@cstmel.hobby.nl>|<ard@cstmel.nl.eu.org>
 
  29         Thanks to Murphy Software BV for letting me write this in their time.
 
  30         Well, actually, I get payed doing this...
 
  31         (Also: see http://www.murphy.nl for murphy, and my homepage ~ard for
 
  32         more information on the Professional Workstation)
 
  38     There are currently two motherboards that I know of in the
 
  39     professional workstation. The only one that I know is the
 
  40     intel panther motherboard. -- ard
 
  43 The pws is equipped with an intel 82596. This is a very intelligent controller
 
  44 which runs its own micro-code. Communication with the hostprocessor is done
 
  45 through linked lists of commands and buffers in the hostprocessors memory.
 
  46 A complete description of the 82596 is available from intel. Search for
 
  47 a file called "29021806.pdf". It is a complete description of the chip itself.
 
  48 To use it for the pws some additions are needed regarding generation of
 
  49 the PORT and CA signal, and the interrupt glue needed for a pc.
 
  51 PORT  SIZE ACTION MEANING
 
  52 0xCB0    2 WRITE  Lower 16 bits for PORT command
 
  53 0xCB2    2 WRITE  Upper 16 bits for PORT command, and issue of PORT command
 
  54 0xCB4    1 WRITE  Generation of CA signal
 
  55 0xCB8    1 WRITE  Clear interrupt glue
 
  56 All other communication is through memory!
 
  59 #include <linux/module.h>
 
  60 #include <linux/init.h>
 
  61 #include <linux/delay.h>
 
  62 #include <linux/kernel.h>
 
  63 #include <linux/string.h>
 
  64 #include <linux/errno.h>
 
  65 #include <linux/ioport.h>
 
  66 #include <linux/slab.h>
 
  67 #include <linux/interrupt.h>
 
  68 #include <linux/netdevice.h>
 
  69 #include <linux/etherdevice.h>
 
  70 #include <linux/skbuff.h>
 
  71 #include <linux/bitops.h>
 
  76 #define DRV_NAME "lp486e"
 
  78 /* debug print flags */
 
  79 #define LOG_SRCDST    0x80000000
 
  80 #define LOG_STATINT   0x40000000
 
  81 #define LOG_STARTINT  0x20000000
 
  83 #define i596_debug debug
 
  85 static int i596_debug = 0;
 
  87 static const char * const medianame[] = {
 
  89         "10baseT-FD", "AUI-FD",
 
  92 #define LP486E_TOTAL_SIZE 16
 
  94 #define I596_NULL (0xffffffff)
 
  96 #define CMD_EOL         0x8000  /* The last command of the list, stop. */
 
  97 #define CMD_SUSP        0x4000  /* Suspend after doing cmd. */
 
  98 #define CMD_INTR        0x2000  /* Interrupt after doing cmd. */
 
 100 #define CMD_FLEX        0x0008  /* Enable flexible memory model */
 
 106         CmdMulticastList = 3,
 
 114 static const char *CUcmdnames[8] = { "NOP", "IASetup", "Configure", "MulticastList",
 
 115                                      "Tx", "TDR", "Dump", "Diagnose" };
 
 118 /* Status word bits */
 
 119 #define STAT_CX         0x8000  /* The CU finished executing a command
 
 120                                    with the Interrupt bit set */
 
 121 #define STAT_FR         0x4000  /* The RU finished receiving a frame */
 
 122 #define STAT_CNA        0x2000  /* The CU left the active state */
 
 123 #define STAT_RNR        0x1000  /* The RU left the active state */
 
 124 #define STAT_ACK        (STAT_CX | STAT_FR | STAT_CNA | STAT_RNR)
 
 125 #define STAT_CUS        0x0700  /* Status of CU: 0: idle, 1: suspended,
 
 126                                    2: active, 3-7: unused */
 
 127 #define STAT_RUS        0x00f0  /* Status of RU: 0: idle, 1: suspended,
 
 128                                    2: no resources, 4: ready,
 
 129                                    10: no resources due to no more RBDs,
 
 130                                    12: no more RBDs, other: unused */
 
 131 #define STAT_T          0x0008  /* Bus throttle timers loaded */
 
 132 #define STAT_ZERO       0x0807  /* Always zero */
 
 135 static char *CUstates[8] = {
 
 136         "idle", "suspended", "active", 0, 0, 0, 0, 0
 
 138 static char *RUstates[16] = {
 
 139         "idle", "suspended", "no resources", 0, "ready", 0, 0, 0,
 
 140         0, 0, "no RBDs", 0, "out of RBDs", 0, 0, 0
 
 144 i596_out_status(int status) {
 
 148         printk("status %4.4x:", status);
 
 149         if (status == 0xffff)
 
 150                 printk(" strange..\n");
 
 152                 if (status & STAT_CX)
 
 154                 if (status & STAT_CNA)
 
 155                         printk("  CU stopped");
 
 156                 if (status & STAT_FR)
 
 157                         printk("  got a frame");
 
 158                 if (status & STAT_RNR)
 
 159                         printk("  RU stopped");
 
 161                         printk("  throttled");
 
 162                 if (status & STAT_ZERO)
 
 164                 s = CUstates[(status & STAT_CUS) >> 8];
 
 168                         printk("  CU(%s)", s);
 
 169                 s = RUstates[(status & STAT_RUS) >> 4];
 
 173                         printk("  RU(%s)", s);
 
 175                         printk("  bad status");
 
 181 /* Command word bits */
 
 182 #define ACK_CX          0x8000
 
 183 #define ACK_FR          0x4000
 
 184 #define ACK_CNA         0x2000
 
 185 #define ACK_RNR         0x1000
 
 187 #define CUC_START       0x0100
 
 188 #define CUC_RESUME      0x0200
 
 189 #define CUC_SUSPEND     0x0300
 
 190 #define CUC_ABORT       0x0400
 
 192 #define RX_START        0x0010
 
 193 #define RX_RESUME       0x0020
 
 194 #define RX_SUSPEND      0x0030
 
 195 #define RX_ABORT        0x0040
 
 197 typedef u32 phys_addr;
 
 199 static inline phys_addr
 
 201         return x ? virt_to_bus(x) : I596_NULL;
 
 205 pa_to_va(phys_addr x) {
 
 206         return (x == I596_NULL) ? NULL : bus_to_virt(x);
 
 209 /* status bits for cmd */
 
 210 #define CMD_STAT_C      0x8000  /* CU command complete */
 
 211 #define CMD_STAT_B      0x4000  /* CU command in progress */
 
 212 #define CMD_STAT_OK     0x2000  /* CU command completed without errors */
 
 213 #define CMD_STAT_A      0x1000  /* CU command abnormally terminated */
 
 215 struct i596_cmd {               /* 8 bytes */
 
 216         unsigned short status;
 
 217         unsigned short command;
 
 218         phys_addr pa_next;      /* va_to_pa(struct i596_cmd *next) */
 
 222 #define SIZE_MASK       0x3fff
 
 227         phys_addr pa_next;      /* va_to_pa(struct i596_tbd *next) */
 
 228         phys_addr pa_data;      /* va_to_pa(char *data) */
 
 234         phys_addr pa_tbd;       /* va_to_pa(struct i596_tbd *tbd) */
 
 239 /* status bits for rfd */
 
 240 #define RFD_STAT_C      0x8000  /* Frame reception complete */
 
 241 #define RFD_STAT_B      0x4000  /* Frame reception in progress */
 
 242 #define RFD_STAT_OK     0x2000  /* Frame received without errors */
 
 243 #define RFD_STATUS      0x1fff
 
 244 #define RFD_LENGTH_ERR  0x1000
 
 245 #define RFD_CRC_ERR     0x0800
 
 246 #define RFD_ALIGN_ERR   0x0400
 
 247 #define RFD_NOBUFS_ERR  0x0200
 
 248 #define RFD_DMA_ERR     0x0100  /* DMA overrun failure to acquire system bus */
 
 249 #define RFD_SHORT_FRAME_ERR     0x0080
 
 250 #define RFD_NOEOP_ERR   0x0040
 
 251 #define RFD_TRUNC_ERR   0x0020
 
 252 #define RFD_MULTICAST  0x0002   /* 0: destination had our address
 
 253                                    1: destination was broadcast/multicast */
 
 254 #define RFD_COLLISION  0x0001
 
 256 /* receive frame descriptor */
 
 260         phys_addr pa_next;      /* va_to_pa(struct i596_rfd *next) */
 
 261         phys_addr pa_rbd;       /* va_to_pa(struct i596_rbd *rbd) */
 
 262         unsigned short count;
 
 267 #define RBD_EL          0x8000
 
 269 #define RBD_SIZEMASK    0x3fff
 
 270 #define RBD_EOF         0x8000
 
 273 /* receive buffer descriptor */
 
 277         phys_addr pa_next;      /* va_to_pa(struct i596_tbd *next) */
 
 278         phys_addr pa_data;      /* va_to_pa(char *data) */
 
 279         phys_addr pa_prev;      /* va_to_pa(struct i596_tbd *prev) */
 
 281         /* Driver private part */
 
 285 #define RX_RING_SIZE 64
 
 286 #define RX_SKBSIZE (ETH_FRAME_LEN+10)
 
 287 #define RX_RBD_SIZE 32
 
 289 /* System Control Block - 40 bytes */
 
 293         phys_addr pa_cmd;       /* 4 - va_to_pa(struct i596_cmd *cmd) */
 
 294         phys_addr pa_rfd;       /* 8 - va_to_pa(struct i596_rfd *rfd) */
 
 295         u32 crc_err;            /* 12 */
 
 296         u32 align_err;          /* 16 */
 
 297         u32 resource_err;       /* 20 */
 
 298         u32 over_err;           /* 24 */
 
 299         u32 rcvdt_err;          /* 28 */
 
 300         u32 short_err;          /* 32 */
 
 305 /* Intermediate System Configuration Pointer - 8 bytes */
 
 308         phys_addr pa_scb;       /* 4 - va_to_pa(struct i596_scb *scb) */
 
 311 /* System Configuration Pointer - 12 bytes */
 
 315         phys_addr pa_iscp;      /* 8 - va_to_pa(struct i596_iscp *iscp) */
 
 318 /* Selftest and dump results - needs 16-byte alignment */
 
 320  * The size of the dump area is 304 bytes. When the dump is executed
 
 321  * by the Port command an extra word will be appended to the dump area.
 
 322  * The extra word is a copy of the Dump status word (containing the
 
 323  * C, B, OK bits). [I find 0xa006, with a0 for C+OK and 6 for dump]
 
 326         u16 dump[153];          /* (304 = 130h) + 2 bytes */
 
 329 struct i596_private {           /* aligned to a 16-byte boundary */
 
 330         struct i596_scp scp;    /* 0 - needs 16-byte alignment */
 
 331         struct i596_iscp iscp;  /* 12 */
 
 332         struct i596_scb scb;    /* 20 */
 
 334         struct i596_dump dump;  /* 64 - needs 16-byte alignment */
 
 336         struct i596_cmd set_add;
 
 337         char eth_addr[8];       /* directly follows set_add */
 
 339         struct i596_cmd set_conf;
 
 340         char i596_config[16];   /* directly follows set_conf */
 
 343         unsigned long tdr_stat; /* directly follows tdr */
 
 346         struct i596_rbd *rbd_list;
 
 347         struct i596_rbd *rbd_tail;
 
 348         struct i596_rfd *rx_tail;
 
 349         struct i596_cmd *cmd_tail;
 
 350         struct i596_cmd *cmd_head;
 
 352         unsigned long last_cmd;
 
 353         struct net_device_stats stats;
 
 357 static char init_setup[14] = {
 
 358         0x8E,   /* length 14 bytes, prefetch on */
 
 359         0xC8,   /* default: fifo to 8, monitor off */
 
 360         0x40,   /* default: don't save bad frames (apricot.c had 0x80) */
 
 361         0x2E,   /* (default is 0x26)
 
 362                    No source address insertion, 8 byte preamble */
 
 363         0x00,   /* default priority and backoff */
 
 364         0x60,   /* default interframe spacing */
 
 365         0x00,   /* default slot time LSB */
 
 366         0xf2,   /* default slot time and nr of retries */
 
 367         0x00,   /* default various bits
 
 368                    (0: promiscuous mode, 1: broadcast disable,
 
 369                     2: encoding mode, 3: transmit on no CRS,
 
 370                     4: no CRC insertion, 5: CRC type,
 
 371                     6: bit stuffing, 7: padding) */
 
 372         0x00,   /* default carrier sense and collision detect */
 
 373         0x40,   /* default minimum frame length */
 
 374         0xff,   /* (default is 0xff, and that is what apricot.c has;
 
 375                    elp486.c has 0xfb: Enable crc append in memory.) */
 
 376         0x00,   /* default: not full duplex */
 
 377         0x7f    /* (default is 0x3f) multi IA */
 
 380 static int i596_open(struct net_device *dev);
 
 381 static int i596_start_xmit(struct sk_buff *skb, struct net_device *dev);
 
 382 static irqreturn_t i596_interrupt(int irq, void *dev_id);
 
 383 static int i596_close(struct net_device *dev);
 
 384 static struct net_device_stats *i596_get_stats(struct net_device *dev);
 
 385 static void i596_add_cmd(struct net_device *dev, struct i596_cmd *cmd);
 
 386 static void print_eth(char *);
 
 387 static void set_multicast_list(struct net_device *dev);
 
 388 static void i596_tx_timeout(struct net_device *dev);
 
 391 i596_timeout(struct net_device *dev, char *msg, int ct) {
 
 392         struct i596_private *lp;
 
 395         lp = (struct i596_private *) dev->priv;
 
 396         while (lp->scb.command) {
 
 397                 if (--boguscnt == 0) {
 
 398                         printk("%s: %s timed out - stat %4.4x, cmd %4.4x\n",
 
 400                                lp->scb.status, lp->scb.command);
 
 410 init_rx_bufs(struct net_device *dev, int num) {
 
 411         struct i596_private *lp;
 
 412         struct i596_rfd *rfd;
 
 414         // struct i596_rbd *rbd;
 
 416         lp = (struct i596_private *) dev->priv;
 
 417         lp->scb.pa_rfd = I596_NULL;
 
 419         for (i = 0; i < num; i++) {
 
 420                 rfd = kmalloc(sizeof(struct i596_rfd), GFP_KERNEL);
 
 425                 rfd->pa_rbd = I596_NULL;
 
 434                 rfd->pa_next = lp->scb.pa_rfd;
 
 435                 lp->scb.pa_rfd = va_to_pa(rfd);
 
 436                 lp->rx_tail->pa_next = lp->scb.pa_rfd;
 
 440         for (i = 0; i<RX_RBD_SIZE; i++) {
 
 441                 rbd = kmalloc(sizeof(struct i596_rbd), GFP_KERNEL);
 
 445                         rbd->skb = dev_alloc_skb(RX_SKBSIZE);
 
 447                                 printk("dev_alloc_skb failed");
 
 449                         rbd->next = rfd->rbd;
 
 451                                 rfd->rbd->prev = rbd;
 
 452                                 rbd->size = RX_SKBSIZE;
 
 454                                 rbd->size = (RX_SKBSIZE | RBD_EL);
 
 460                         printk("Could not kmalloc rbd\n");
 
 463         lp->rbd_tail->next = rfd->rbd;
 
 469 remove_rx_bufs(struct net_device *dev) {
 
 470         struct i596_private *lp;
 
 471         struct i596_rfd *rfd;
 
 473         lp = (struct i596_private *) dev->priv;
 
 474         lp->rx_tail->pa_next = I596_NULL;
 
 477                 rfd = pa_to_va(lp->scb.pa_rfd);
 
 478                 lp->scb.pa_rfd = rfd->pa_next;
 
 480         } while (rfd != lp->rx_tail);
 
 490 #define PORT_RESET              0x00    /* reset 82596 */
 
 491 #define PORT_SELFTEST           0x01    /* selftest */
 
 492 #define PORT_ALTSCP             0x02    /* alternate SCB address */
 
 493 #define PORT_DUMP               0x03    /* dump */
 
 495 #define IOADDR  0xcb0           /* real constant */
 
 496 #define IRQ     10              /* default IRQ - can be changed by ECU */
 
 498 /* The 82596 requires two 16-bit write cycles for a port command */
 
 500 PORT(phys_addr a, unsigned int cmd) {
 
 502                 printk("lp486e.c: PORT: address not aligned\n");
 
 503         outw(((a & 0xffff) | cmd), IOADDR);
 
 504         outw(((a>>16) & 0xffff), IOADDR+2);
 
 518 #define SIZE(x) (sizeof(x)/sizeof((x)[0]))
 
 521 /* selftest or dump */
 
 523 i596_port_do(struct net_device *dev, int portcmd, char *cmdname) {
 
 524         struct i596_private *lp = dev->priv;
 
 528         memset((void *)&(lp->dump), 0, sizeof(struct i596_dump));
 
 529         outp = &(lp->dump.dump[0]);
 
 531         PORT(va_to_pa(outp), portcmd);
 
 532         mdelay(30);             /* random, unmotivated */
 
 534         printk("lp486e i82596 %s result:\n", cmdname);
 
 535         for (m = SIZE(lp->dump.dump); m && lp->dump.dump[m-1] == 0; m--)
 
 537         for (i = 0; i < m; i++) {
 
 538                 printk(" %04x", lp->dump.dump[i]);
 
 547 i596_scp_setup(struct net_device *dev) {
 
 548         struct i596_private *lp = dev->priv;
 
 551         /* Setup SCP, ISCP, SCB */
 
 554          *  only a single byte is significant - here 0x44
 
 555          *  0x80: big endian mode (details depend on stepping)
 
 557          *  0x20: interrupt pin is active low
 
 558          *  0x10: lock function disabled
 
 559          *  0x08: external triggering of bus throttle timers
 
 560          *  0x06: 00: 82586 compat mode, 01: segmented mode, 10: linear mode
 
 563         lp->scp.sysbus = 0x00440000;            /* linear mode */
 
 564         lp->scp.pad = 0;                        /* must be zero */
 
 565         lp->scp.pa_iscp = va_to_pa(&(lp->iscp));
 
 568          * The CPU sets the ISCP to 1 before it gives the first CA()
 
 570         lp->iscp.busy = 0x0001;
 
 571         lp->iscp.pa_scb = va_to_pa(&(lp->scb));
 
 575         lp->scb.pa_cmd = I596_NULL;
 
 576         /* lp->scb.pa_rfd has been initialised already */
 
 578         lp->last_cmd = jiffies;
 
 584          * We need to wait 10 systemclock cycles, and
 
 585          * 5 serial clock cycles.
 
 587         PORT(0, PORT_RESET);    /* address part ignored */
 
 591          * Before the CA signal is asserted, the default SCP address
 
 592          * (0x00fffff4) can be changed to a 16-byte aligned value
 
 594         PORT(va_to_pa(&lp->scp), PORT_ALTSCP);  /* change the scp address */
 
 597          * The initialization procedure begins when a
 
 598          * Channel Attention signal is asserted after a reset.
 
 604          * The ISCP busy is cleared by the 82596 after the SCB address is read.
 
 607         while (lp->iscp.busy) {
 
 608                 if (--boguscnt == 0) {
 
 609                         /* No i82596 present? */
 
 610                         printk("%s: i82596 initialization timed out\n",
 
 617         /* I find here boguscnt==100, so no delay was required. */
 
 623 init_i596(struct net_device *dev) {
 
 624         struct i596_private *lp;
 
 626         if (i596_scp_setup(dev))
 
 629         lp = (struct i596_private *) dev->priv;
 
 632         memcpy ((void *)lp->i596_config, init_setup, 14);
 
 633         lp->set_conf.command = CmdConfigure;
 
 634         i596_add_cmd(dev, (void *)&lp->set_conf);
 
 636         memcpy ((void *)lp->eth_addr, dev->dev_addr, 6);
 
 637         lp->set_add.command = CmdIASetup;
 
 638         i596_add_cmd(dev, (struct i596_cmd *)&lp->set_add);
 
 640         lp->tdr.command = CmdTDR;
 
 641         i596_add_cmd(dev, (struct i596_cmd *)&lp->tdr);
 
 643         if (lp->scb.command && i596_timeout(dev, "i82596 init", 200))
 
 646         lp->scb.command = RX_START;
 
 651         if (lp->scb.command && i596_timeout(dev, "Receive Unit start", 100))
 
 657 /* Receive a single frame */
 
 659 i596_rx_one(struct net_device *dev, struct i596_private *lp,
 
 660             struct i596_rfd *rfd, int *frames) {
 
 662         if (rfd->stat & RFD_STAT_OK) {
 
 664                 int pkt_len = (rfd->count & 0x3fff);
 
 665                 struct sk_buff *skb = dev_alloc_skb(pkt_len);
 
 669                 if (rfd->cmd & CMD_EOL)
 
 670                         printk("Received on EOL\n");
 
 673                         printk ("%s: i596_rx Memory squeeze, "
 
 674                                 "dropping packet.\n", dev->name);
 
 675                         lp->stats.rx_dropped++;
 
 680                 memcpy(skb_put(skb,pkt_len), rfd->data, pkt_len);
 
 682                 skb->protocol = eth_type_trans(skb,dev);
 
 684                 dev->last_rx = jiffies;
 
 685                 lp->stats.rx_packets++;
 
 688                 printk("Frame reception error status %04x\n",
 
 691                 lp->stats.rx_errors++;
 
 692                 if (rfd->stat & RFD_COLLISION)
 
 693                         lp->stats.collisions++;
 
 694                 if (rfd->stat & RFD_SHORT_FRAME_ERR)
 
 695                         lp->stats.rx_length_errors++;
 
 696                 if (rfd->stat & RFD_DMA_ERR)
 
 697                         lp->stats.rx_over_errors++;
 
 698                 if (rfd->stat & RFD_NOBUFS_ERR)
 
 699                         lp->stats.rx_fifo_errors++;
 
 700                 if (rfd->stat & RFD_ALIGN_ERR)
 
 701                         lp->stats.rx_frame_errors++;
 
 702                 if (rfd->stat & RFD_CRC_ERR)
 
 703                         lp->stats.rx_crc_errors++;
 
 704                 if (rfd->stat & RFD_LENGTH_ERR)
 
 705                         lp->stats.rx_length_errors++;
 
 707         rfd->stat = rfd->count = 0;
 
 712 i596_rx(struct net_device *dev) {
 
 713         struct i596_private *lp = (struct i596_private *) dev->priv;
 
 714         struct i596_rfd *rfd;
 
 718                 rfd = pa_to_va(lp->scb.pa_rfd);
 
 720                         printk(KERN_ERR "i596_rx: NULL rfd?\n");
 
 724                 if (rfd->stat && !(rfd->stat & (RFD_STAT_C | RFD_STAT_B)))
 
 725                         printk("SF:%p-%04x\n", rfd, rfd->stat);
 
 727                 if (!(rfd->stat & RFD_STAT_C))
 
 728                         break;          /* next one not ready */
 
 729                 if (i596_rx_one(dev, lp, rfd, &frames))
 
 730                         break;          /* out of memory */
 
 732                 lp->rx_tail->cmd = 0;
 
 734                 lp->scb.pa_rfd = rfd->pa_next;
 
 742 i596_cleanup_cmd(struct net_device *dev) {
 
 743         struct i596_private *lp;
 
 744         struct i596_cmd *cmd;
 
 746         lp = (struct i596_private *) dev->priv;
 
 747         while (lp->cmd_head) {
 
 748                 cmd = (struct i596_cmd *)lp->cmd_head;
 
 750                 lp->cmd_head = pa_to_va(lp->cmd_head->pa_next);
 
 753                 switch ((cmd->command) & 0x7) {
 
 755                                 struct tx_cmd *tx_cmd = (struct tx_cmd *) cmd;
 
 756                                 struct i596_tbd * tx_cmd_tbd;
 
 757                                 tx_cmd_tbd = pa_to_va(tx_cmd->pa_tbd);
 
 759                                 dev_kfree_skb_any(tx_cmd_tbd->skb);
 
 761                                 lp->stats.tx_errors++;
 
 762                                 lp->stats.tx_aborted_errors++;
 
 764                                 cmd->pa_next = I596_NULL;
 
 765                                 kfree((unsigned char *)tx_cmd);
 
 766                                 netif_wake_queue(dev);
 
 769                         case CmdMulticastList: {
 
 770                                 // unsigned short count = *((unsigned short *) (ptr + 1));
 
 772                                 cmd->pa_next = I596_NULL;
 
 773                                 kfree((unsigned char *)cmd);
 
 777                                 cmd->pa_next = I596_NULL;
 
 784         if (lp->scb.command && i596_timeout(dev, "i596_cleanup_cmd", 100))
 
 787         lp->scb.pa_cmd = va_to_pa(lp->cmd_head);
 
 790 static void i596_reset(struct net_device *dev, struct i596_private *lp, int ioaddr) {
 
 792         if (lp->scb.command && i596_timeout(dev, "i596_reset", 100))
 
 795         netif_stop_queue(dev);
 
 797         lp->scb.command = CUC_ABORT | RX_ABORT;
 
 801         /* wait for shutdown */
 
 802         if (lp->scb.command && i596_timeout(dev, "i596_reset(2)", 400))
 
 805         i596_cleanup_cmd(dev);
 
 808         netif_start_queue(dev);
 
 809         /*dev_kfree_skb(skb, FREE_WRITE);*/
 
 813 static void i596_add_cmd(struct net_device *dev, struct i596_cmd *cmd) {
 
 814         struct i596_private *lp = dev->priv;
 
 815         int ioaddr = dev->base_addr;
 
 819         cmd->command |= (CMD_EOL | CMD_INTR);
 
 820         cmd->pa_next = I596_NULL;
 
 822         spin_lock_irqsave(&lp->cmd_lock, flags);
 
 825                 lp->cmd_tail->pa_next = va_to_pa(cmd);
 
 828                 if (lp->scb.command && i596_timeout(dev, "i596_add_cmd", 100))
 
 830                 lp->scb.pa_cmd = va_to_pa(cmd);
 
 831                 lp->scb.command = CUC_START;
 
 837         lp->cmd_head = pa_to_va(lp->scb.pa_cmd);
 
 838         spin_unlock_irqrestore(&lp->cmd_lock, flags);
 
 840         if (lp->cmd_backlog > 16) {
 
 841                 int tickssofar = jiffies - lp->last_cmd;
 
 842                 if (tickssofar < HZ/4)
 
 845                 printk(KERN_WARNING "%s: command unit timed out, status resetting.\n", dev->name);
 
 846                 i596_reset(dev, lp, ioaddr);
 
 850 static int i596_open(struct net_device *dev)
 
 854         i = request_irq(dev->irq, &i596_interrupt, IRQF_SHARED, dev->name, dev);
 
 856                 printk(KERN_ERR "%s: IRQ %d not free\n", dev->name, dev->irq);
 
 860         if ((i = init_rx_bufs(dev, RX_RING_SIZE)) < RX_RING_SIZE)
 
 861                 printk(KERN_ERR "%s: only able to allocate %d receive buffers\n", dev->name, i);
 
 864                 free_irq(dev->irq, dev);
 
 867         netif_start_queue(dev);
 
 869         return 0;                       /* Always succeed */
 
 872 static int i596_start_xmit (struct sk_buff *skb, struct net_device *dev) {
 
 873         struct i596_private *lp = dev->priv;
 
 874         struct tx_cmd *tx_cmd;
 
 879         if (length < ETH_ZLEN) {
 
 880                 if (skb_padto(skb, ETH_ZLEN))
 
 885         dev->trans_start = jiffies;
 
 887         tx_cmd = kmalloc((sizeof (struct tx_cmd) + sizeof (struct i596_tbd)), GFP_ATOMIC);
 
 888         if (tx_cmd == NULL) {
 
 889                 printk(KERN_WARNING "%s: i596_xmit Memory squeeze, dropping packet.\n", dev->name);
 
 890                 lp->stats.tx_dropped++;
 
 893                 struct i596_tbd *tx_cmd_tbd;
 
 894                 tx_cmd_tbd = (struct i596_tbd *) (tx_cmd + 1);
 
 895                 tx_cmd->pa_tbd = va_to_pa (tx_cmd_tbd);
 
 896                 tx_cmd_tbd->pa_next = I596_NULL;
 
 898                 tx_cmd->cmd.command = (CMD_FLEX | CmdTx);
 
 903                 tx_cmd_tbd->size = (EOF | length);
 
 905                 tx_cmd_tbd->pa_data = va_to_pa (skb->data);
 
 906                 tx_cmd_tbd->skb = skb;
 
 908                 if (i596_debug & LOG_SRCDST)
 
 909                         print_eth (skb->data);
 
 911                 i596_add_cmd (dev, (struct i596_cmd *) tx_cmd);
 
 913                 lp->stats.tx_packets++;
 
 920 i596_tx_timeout (struct net_device *dev) {
 
 921         struct i596_private *lp = dev->priv;
 
 922         int ioaddr = dev->base_addr;
 
 924         /* Transmitter timeout, serious problems. */
 
 925         printk(KERN_WARNING "%s: transmit timed out, status resetting.\n", dev->name);
 
 926         lp->stats.tx_errors++;
 
 928         /* Try to restart the adaptor */
 
 929         if (lp->last_restart == lp->stats.tx_packets) {
 
 930                 printk ("Resetting board.\n");
 
 932                 /* Shutdown and restart */
 
 933                 i596_reset (dev, lp, ioaddr);
 
 935                 /* Issue a channel attention signal */
 
 936                 printk ("Kicking board.\n");
 
 937                 lp->scb.command = (CUC_START | RX_START);
 
 939                 lp->last_restart = lp->stats.tx_packets;
 
 941         netif_wake_queue(dev);
 
 944 static void print_eth(char *add)
 
 949         for (i = 0; i < 6; i++)
 
 950                 printk(" %2.2X", (unsigned char) add[i]);
 
 954         for (i = 0; i < 6; i++)
 
 955                 printk(" %2.2X", (unsigned char) add[i+6]);
 
 958         printk ("type %2.2X%2.2X\n",
 
 959                 (unsigned char) add[12], (unsigned char) add[13]);
 
 962 static int __init lp486e_probe(struct net_device *dev) {
 
 963         struct i596_private *lp;
 
 964         unsigned char eth_addr[6] = { 0, 0xaa, 0, 0, 0, 0 };
 
 974         if (!request_region(IOADDR, LP486E_TOTAL_SIZE, DRV_NAME)) {
 
 975                 printk(KERN_ERR "lp486e: IO address 0x%x in use\n", IOADDR);
 
 979         lp = (struct i596_private *) dev->priv;
 
 980         spin_lock_init(&lp->cmd_lock);
 
 983          * Do we really have this thing?
 
 985         if (i596_scp_setup(dev)) {
 
 990         dev->base_addr = IOADDR;
 
 995          * How do we find the ethernet address? I don't know.
 
 996          * One possibility is to look at the EISA configuration area
 
 997          * [0xe8000-0xe9fff]. This contains the ethernet address
 
 998          * but not at a fixed address - things depend on setup options.
 
1000          * If we find no address, or the wrong address, use
 
1001          *   ifconfig eth0 hw ether a1:a2:a3:a4:a5:a6
 
1002          * with the value found in the BIOS setup.
 
1004         bios = bus_to_virt(0xe8000);
 
1005         for (j = 0; j < 0x2000; j++) {
 
1006                 if (bios[j] == 0 && bios[j+1] == 0xaa && bios[j+2] == 0) {
 
1007                         printk("%s: maybe address at BIOS 0x%x:",
 
1008                                dev->name, 0xe8000+j);
 
1009                         for (i = 0; i < 6; i++) {
 
1010                                 eth_addr[i] = bios[i+j];
 
1011                                 printk(" %2.2X", eth_addr[i]);
 
1017         printk("%s: lp486e 82596 at %#3lx, IRQ %d,",
 
1018                dev->name, dev->base_addr, dev->irq);
 
1019         for (i = 0; i < 6; i++)
 
1020                 printk(" %2.2X", dev->dev_addr[i] = eth_addr[i]);
 
1023         /* The LP486E-specific entries in the device structure. */
 
1024         dev->open = &i596_open;
 
1025         dev->stop = &i596_close;
 
1026         dev->hard_start_xmit = &i596_start_xmit;
 
1027         dev->get_stats = &i596_get_stats;
 
1028         dev->set_multicast_list = &set_multicast_list;
 
1029         dev->watchdog_timeo = 5*HZ;
 
1030         dev->tx_timeout = i596_tx_timeout;
 
1033         /* selftest reports 0x320925ae - don't know what that means */
 
1034         i596_port_do(dev, PORT_SELFTEST, "selftest");
 
1035         i596_port_do(dev, PORT_DUMP, "dump");
 
1040         release_region(IOADDR, LP486E_TOTAL_SIZE);
 
1045 i596_handle_CU_completion(struct net_device *dev,
 
1046                           struct i596_private *lp,
 
1047                           unsigned short status,
 
1048                           unsigned short *ack_cmdp) {
 
1049         struct i596_cmd *cmd;
 
1051         int commands_done = 0;
 
1053         unsigned long flags;
 
1055         spin_lock_irqsave(&lp->cmd_lock, flags);
 
1058         while (lp->cmd_head && (lp->cmd_head->status & CMD_STAT_C)) {
 
1061                 lp->cmd_head = pa_to_va(lp->cmd_head->pa_next);
 
1065                 cmd_val = cmd->command & 0x7;
 
1067                 printk("finished CU %s command (%d)\n",
 
1068                        CUcmdnames[cmd_val], cmd_val);
 
1073                         struct tx_cmd *tx_cmd;
 
1074                         struct i596_tbd *tx_cmd_tbd;
 
1076                         tx_cmd = (struct tx_cmd *) cmd;
 
1077                         tx_cmd_tbd = pa_to_va(tx_cmd->pa_tbd);
 
1080                         if (cmd->status & CMD_STAT_OK) {
 
1082                                         print_eth(pa_to_va(tx_cmd_tbd->pa_data));
 
1084                                 lp->stats.tx_errors++;
 
1086                                         printk("transmission failure:%04x\n",
 
1088                                 if (cmd->status & 0x0020)
 
1089                                         lp->stats.collisions++;
 
1090                                 if (!(cmd->status & 0x0040))
 
1091                                         lp->stats.tx_heartbeat_errors++;
 
1092                                 if (cmd->status & 0x0400)
 
1093                                         lp->stats.tx_carrier_errors++;
 
1094                                 if (cmd->status & 0x0800)
 
1095                                         lp->stats.collisions++;
 
1096                                 if (cmd->status & 0x1000)
 
1097                                         lp->stats.tx_aborted_errors++;
 
1099                         dev_kfree_skb_irq(tx_cmd_tbd->skb);
 
1101                         cmd->pa_next = I596_NULL;
 
1102                         kfree((unsigned char *)tx_cmd);
 
1103                         netif_wake_queue(dev);
 
1107                 case CmdMulticastList:
 
1108                         cmd->pa_next = I596_NULL;
 
1109                         kfree((unsigned char *)cmd);
 
1114                         unsigned long status = *((unsigned long *) (cmd + 1));
 
1115                         if (status & 0x8000) {
 
1117                                         printk("%s: link ok.\n", dev->name);
 
1119                                 if (status & 0x4000)
 
1120                                         printk("%s: Transceiver problem.\n",
 
1122                                 if (status & 0x2000)
 
1123                                         printk("%s: Termination problem.\n",
 
1125                                 if (status & 0x1000)
 
1126                                         printk("%s: Short circuit.\n",
 
1128                                 printk("%s: Time %ld.\n",
 
1129                                        dev->name, status & 0x07ff);
 
1133                         cmd->pa_next = I596_NULL;
 
1134                         lp->last_cmd = jiffies;
 
1141         while (cmd && (cmd != lp->cmd_tail)) {
 
1142                 cmd->command &= 0x1fff;
 
1143                 cmd = pa_to_va(cmd->pa_next);
 
1148                 *ack_cmdp |= CUC_START;
 
1149         lp->scb.pa_cmd = va_to_pa(lp->cmd_head);
 
1150         spin_unlock_irqrestore(&lp->cmd_lock, flags);
 
1154 i596_interrupt (int irq, void *dev_instance) {
 
1155         struct net_device *dev = (struct net_device *) dev_instance;
 
1156         struct i596_private *lp;
 
1157         unsigned short status, ack_cmd = 0;
 
1160         lp = (struct i596_private *) dev->priv;
 
1163          * The 82596 examines the command, performs the required action,
 
1164          * and then clears the SCB command word.
 
1166         if (lp->scb.command && i596_timeout(dev, "interrupt", 40))
 
1170          * The status word indicates the status of the 82596.
 
1171          * It is modified only by the 82596.
 
1173          * [So, we must not clear it. I find often status 0xffff,
 
1174          *  which is not one of the values allowed by the docs.]
 
1176         status = lp->scb.status;
 
1179                 printk("%s: i596 interrupt, ", dev->name);
 
1180                 i596_out_status(status);
 
1183         /* Impossible, but it happens - perhaps when we get
 
1184            a receive interrupt but scb.pa_rfd is I596_NULL. */
 
1185         if (status == 0xffff) {
 
1186                 printk("%s: i596_interrupt: got status 0xffff\n", dev->name);
 
1190         ack_cmd = (status & STAT_ACK);
 
1192         if (status & (STAT_CX | STAT_CNA))
 
1193                 i596_handle_CU_completion(dev, lp, status, &ack_cmd);
 
1195         if (status & (STAT_FR | STAT_RNR)) {
 
1196                 /* Restart the receive unit when it got inactive somehow */
 
1197                 if ((status & STAT_RNR) && netif_running(dev))
 
1198                         ack_cmd |= RX_START;
 
1200                 if (status & STAT_FR) {
 
1201                         frames_in = i596_rx(dev);
 
1203                                 printk("receive frame reported, but no frames\n");
 
1207         /* acknowledge the interrupt */
 
1209         if ((lp->scb.pa_cmd != I596_NULL) && netif_running(dev))
 
1210                 ack_cmd |= CUC_START;
 
1213         if (lp->scb.command && i596_timeout(dev, "i596 interrupt", 100))
 
1216         lp->scb.command = ack_cmd;
 
1225 static int i596_close(struct net_device *dev) {
 
1226         struct i596_private *lp = dev->priv;
 
1228         netif_stop_queue(dev);
 
1231                 printk("%s: Shutting down ethercard, status was %4.4x.\n",
 
1232                        dev->name, lp->scb.status);
 
1234         lp->scb.command = (CUC_ABORT | RX_ABORT);
 
1237         i596_cleanup_cmd(dev);
 
1239         if (lp->scb.command && i596_timeout(dev, "i596_close", 200))
 
1242         free_irq(dev->irq, dev);
 
1243         remove_rx_bufs(dev);
 
1248 static struct net_device_stats * i596_get_stats(struct net_device *dev) {
 
1249         struct i596_private *lp = dev->priv;
 
1255 *       Set or clear the multicast filter for this adaptor.
 
1258 static void set_multicast_list(struct net_device *dev) {
 
1259         struct i596_private *lp = dev->priv;
 
1260         struct i596_cmd *cmd;
 
1263                 printk ("%s: set multicast list %d\n",
 
1264                         dev->name, dev->mc_count);
 
1266         if (dev->mc_count > 0) {
 
1267                 struct dev_mc_list *dmi;
 
1269                 cmd = kmalloc(sizeof(struct i596_cmd)+2+dev->mc_count*6, GFP_ATOMIC);
 
1271                         printk (KERN_ERR "%s: set_multicast Memory squeeze.\n", dev->name);
 
1274                 cmd->command = CmdMulticastList;
 
1275                 *((unsigned short *) (cmd + 1)) = dev->mc_count * 6;
 
1276                 cp = ((char *)(cmd + 1))+2;
 
1277                 for (dmi = dev->mc_list; dmi != NULL; dmi = dmi->next) {
 
1281                 if (i596_debug & LOG_SRCDST)
 
1282                         print_eth (((char *)(cmd + 1)) + 2);
 
1283                 i596_add_cmd(dev, cmd);
 
1285                 if (lp->set_conf.pa_next != I596_NULL) {
 
1288                 if (dev->mc_count == 0 && !(dev->flags & (IFF_PROMISC | IFF_ALLMULTI))) {
 
1289                         if (dev->flags & IFF_ALLMULTI)
 
1290                                 dev->flags |= IFF_PROMISC;
 
1291                         lp->i596_config[8] &= ~0x01;
 
1293                         lp->i596_config[8] |= 0x01;
 
1296                 i596_add_cmd(dev, (struct i596_cmd *) &lp->set_conf);
 
1300 MODULE_AUTHOR("Ard van Breemen <ard@cstmel.nl.eu.org>");
 
1301 MODULE_DESCRIPTION("Intel Panther onboard i82596 driver");
 
1302 MODULE_LICENSE("GPL");
 
1304 static struct net_device *dev_lp486e;
 
1305 static int full_duplex;
 
1307 static int io = IOADDR;
 
1308 static int irq = IRQ;
 
1310 module_param(debug, int, 0);
 
1311 //module_param(max_interrupt_work, int, 0);
 
1312 //module_param(reverse_probe, int, 0);
 
1313 //module_param(rx_copybreak, int, 0);
 
1314 module_param(options, int, 0);
 
1315 module_param(full_duplex, int, 0);
 
1317 static int __init lp486e_init_module(void) {
 
1319         struct net_device *dev = alloc_etherdev(sizeof(struct i596_private));
 
1324         dev->base_addr = io;
 
1325         err = lp486e_probe(dev);
 
1330         err = register_netdev(dev);
 
1332                 release_region(dev->base_addr, LP486E_TOTAL_SIZE);
 
1342 static void __exit lp486e_cleanup_module(void) {
 
1343         unregister_netdev(dev_lp486e);
 
1344         release_region(dev_lp486e->base_addr, LP486E_TOTAL_SIZE);
 
1345         free_netdev(dev_lp486e);
 
1348 module_init(lp486e_init_module);
 
1349 module_exit(lp486e_cleanup_module);