| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 |  | 
|  | 2 | /* | 
|  | 3 | *	Index to functions. | 
|  | 4 | */ | 
|  | 5 |  | 
|  | 6 | static int  el1_probe1(struct net_device *dev, int ioaddr); | 
|  | 7 | static int  el_open(struct net_device *dev); | 
|  | 8 | static void el_timeout(struct net_device *dev); | 
| Stephen Hemminger | 27a1de9 | 2009-08-31 19:50:54 +0000 | [diff] [blame] | 9 | static netdev_tx_t el_start_xmit(struct sk_buff *skb, struct net_device *dev); | 
| David Howells | 7d12e78 | 2006-10-05 14:55:46 +0100 | [diff] [blame] | 10 | static irqreturn_t el_interrupt(int irq, void *dev_id); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 11 | static void el_receive(struct net_device *dev); | 
|  | 12 | static void el_reset(struct net_device *dev); | 
|  | 13 | static int  el1_close(struct net_device *dev); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 14 | static void set_multicast_list(struct net_device *dev); | 
| Jeff Garzik | 7282d49 | 2006-09-13 14:30:00 -0400 | [diff] [blame] | 15 | static const struct ethtool_ops netdev_ethtool_ops; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 16 |  | 
|  | 17 | #define EL1_IO_EXTENT	16 | 
|  | 18 |  | 
|  | 19 | #ifndef EL_DEBUG | 
|  | 20 | #define EL_DEBUG  0	/* use 0 for production, 1 for devel., >2 for debug */ | 
|  | 21 | #endif			/* Anything above 5 is wordy death! */ | 
|  | 22 | #define debug el_debug | 
|  | 23 | static int el_debug = EL_DEBUG; | 
|  | 24 |  | 
|  | 25 | /* | 
| Wang Chen | b74ca3a | 2008-12-08 01:14:16 -0800 | [diff] [blame] | 26 | *	Board-specific info in netdev_priv(dev). | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 27 | */ | 
|  | 28 |  | 
|  | 29 | struct net_local | 
|  | 30 | { | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 31 | int		tx_pkt_start;	/* The length of the current Tx packet. */ | 
|  | 32 | int		collisions;	/* Tx collisions this packet */ | 
|  | 33 | int		loading;	/* Spot buffer load collisions */ | 
|  | 34 | int		txing;		/* True if card is in TX mode */ | 
|  | 35 | spinlock_t	lock;		/* Serializing lock */ | 
|  | 36 | }; | 
|  | 37 |  | 
| Jeff Garzik | 6aa20a2 | 2006-09-13 13:24:59 -0400 | [diff] [blame] | 38 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 39 | #define RX_STATUS (ioaddr + 0x06) | 
|  | 40 | #define RX_CMD	  RX_STATUS | 
|  | 41 | #define TX_STATUS (ioaddr + 0x07) | 
|  | 42 | #define TX_CMD	  TX_STATUS | 
|  | 43 | #define GP_LOW 	  (ioaddr + 0x08) | 
|  | 44 | #define GP_HIGH   (ioaddr + 0x09) | 
|  | 45 | #define RX_BUF_CLR (ioaddr + 0x0A) | 
|  | 46 | #define RX_LOW	  (ioaddr + 0x0A) | 
|  | 47 | #define RX_HIGH   (ioaddr + 0x0B) | 
|  | 48 | #define SAPROM	  (ioaddr + 0x0C) | 
|  | 49 | #define AX_STATUS (ioaddr + 0x0E) | 
|  | 50 | #define AX_CMD	  AX_STATUS | 
|  | 51 | #define DATAPORT  (ioaddr + 0x0F) | 
|  | 52 | #define TX_RDY 0x08		/* In TX_STATUS */ | 
|  | 53 |  | 
|  | 54 | #define EL1_DATAPTR	0x08 | 
|  | 55 | #define EL1_RXPTR	0x0A | 
|  | 56 | #define EL1_SAPROM	0x0C | 
|  | 57 | #define EL1_DATAPORT 	0x0f | 
|  | 58 |  | 
|  | 59 | /* | 
|  | 60 | *	Writes to the ax command register. | 
|  | 61 | */ | 
|  | 62 |  | 
|  | 63 | #define AX_OFF	0x00			/* Irq off, buffer access on */ | 
|  | 64 | #define AX_SYS  0x40			/* Load the buffer */ | 
|  | 65 | #define AX_XMIT 0x44			/* Transmit a packet */ | 
|  | 66 | #define AX_RX	0x48			/* Receive a packet */ | 
|  | 67 | #define AX_LOOP	0x0C			/* Loopback mode */ | 
|  | 68 | #define AX_RESET 0x80 | 
|  | 69 |  | 
|  | 70 | /* | 
|  | 71 | *	Normal receive mode written to RX_STATUS.  We must intr on short packets | 
|  | 72 | *	to avoid bogus rx lockups. | 
|  | 73 | */ | 
|  | 74 |  | 
|  | 75 | #define RX_NORM 0xA8		/* 0x68 == all addrs, 0xA8 only to me. */ | 
|  | 76 | #define RX_PROM 0x68		/* Senior Prom, uhmm promiscuous mode. */ | 
|  | 77 | #define RX_MULT 0xE8		/* Accept multicast packets. */ | 
|  | 78 | #define TX_NORM 0x0A		/* Interrupt on everything that might hang the chip */ | 
|  | 79 |  | 
|  | 80 | /* | 
|  | 81 | *	TX_STATUS register. | 
|  | 82 | */ | 
|  | 83 |  | 
|  | 84 | #define TX_COLLISION 0x02 | 
|  | 85 | #define TX_16COLLISIONS 0x04 | 
|  | 86 | #define TX_READY 0x08 | 
|  | 87 |  | 
|  | 88 | #define RX_RUNT 0x08 | 
|  | 89 | #define RX_MISSED 0x01		/* Missed a packet due to 3c501 braindamage. */ | 
|  | 90 | #define RX_GOOD	0x30		/* Good packet 0x20, or simple overflow 0x10. */ | 
|  | 91 |  |