aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/3c515.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/3c515.c')
-rw-r--r--drivers/net/3c515.c60
1 files changed, 30 insertions, 30 deletions
diff --git a/drivers/net/3c515.c b/drivers/net/3c515.c
index aedfddf20cb3..bde9f5bd3362 100644
--- a/drivers/net/3c515.c
+++ b/drivers/net/3c515.c
@@ -12,12 +12,12 @@
12 Annapolis MD 21403 12 Annapolis MD 21403
13 13
14 14
15 2000/2/2- Added support for kernel-level ISAPnP 15 2000/2/2- Added support for kernel-level ISAPnP
16 by Stephen Frost <sfrost@snowman.net> and Alessandro Zummo 16 by Stephen Frost <sfrost@snowman.net> and Alessandro Zummo
17 Cleaned up for 2.3.x/softnet by Jeff Garzik and Alan Cox. 17 Cleaned up for 2.3.x/softnet by Jeff Garzik and Alan Cox.
18 18
19 2001/11/17 - Added ethtool support (jgarzik) 19 2001/11/17 - Added ethtool support (jgarzik)
20 20
21 2002/10/28 - Locking updates for 2.5 (alan@redhat.com) 21 2002/10/28 - Locking updates for 2.5 (alan@redhat.com)
22 22
23*/ 23*/
@@ -187,9 +187,9 @@ enum corkscrew_cmd {
187 TotalReset = 0 << 11, SelectWindow = 1 << 11, StartCoax = 2 << 11, 187 TotalReset = 0 << 11, SelectWindow = 1 << 11, StartCoax = 2 << 11,
188 RxDisable = 3 << 11, RxEnable = 4 << 11, RxReset = 5 << 11, 188 RxDisable = 3 << 11, RxEnable = 4 << 11, RxReset = 5 << 11,
189 UpStall = 6 << 11, UpUnstall = (6 << 11) + 1, DownStall = (6 << 11) + 2, 189 UpStall = 6 << 11, UpUnstall = (6 << 11) + 1, DownStall = (6 << 11) + 2,
190 DownUnstall = (6 << 11) + 3, RxDiscard = 8 << 11, TxEnable = 9 << 11, 190 DownUnstall = (6 << 11) + 3, RxDiscard = 8 << 11, TxEnable = 9 << 11,
191 TxDisable = 10 << 11, TxReset = 11 << 11, FakeIntr = 12 << 11, 191 TxDisable = 10 << 11, TxReset = 11 << 11, FakeIntr = 12 << 11,
192 AckIntr = 13 << 11, SetIntrEnb = 14 << 11, SetStatusEnb = 15 << 11, 192 AckIntr = 13 << 11, SetIntrEnb = 14 << 11, SetStatusEnb = 15 << 11,
193 SetRxFilter = 16 << 11, SetRxThreshold = 17 << 11, 193 SetRxFilter = 16 << 11, SetRxThreshold = 17 << 11,
194 SetTxThreshold = 18 << 11, SetTxStart = 19 << 11, StartDMAUp = 20 << 11, 194 SetTxThreshold = 18 << 11, SetTxStart = 19 << 11, StartDMAUp = 20 << 11,
195 StartDMADown = (20 << 11) + 1, StatsEnable = 21 << 11, 195 StartDMADown = (20 << 11) + 1, StatsEnable = 21 << 11,
@@ -338,15 +338,15 @@ static struct media_table {
338 mask:8, /* The transceiver-present bit in Wn3_Config. */ 338 mask:8, /* The transceiver-present bit in Wn3_Config. */
339 next:8; /* The media type to try next. */ 339 next:8; /* The media type to try next. */
340 short wait; /* Time before we check media status. */ 340 short wait; /* Time before we check media status. */
341} media_tbl[] = { 341} media_tbl[] = {
342 { "10baseT", Media_10TP, 0x08, XCVR_10base2, (14 * HZ) / 10 }, 342 { "10baseT", Media_10TP, 0x08, XCVR_10base2, (14 * HZ) / 10 },
343 { "10Mbs AUI", Media_SQE, 0x20, XCVR_Default, (1 * HZ) / 10}, 343 { "10Mbs AUI", Media_SQE, 0x20, XCVR_Default, (1 * HZ) / 10},
344 { "undefined", 0, 0x80, XCVR_10baseT, 10000}, 344 { "undefined", 0, 0x80, XCVR_10baseT, 10000},
345 { "10base2", 0, 0x10, XCVR_AUI, (1 * HZ) / 10}, 345 { "10base2", 0, 0x10, XCVR_AUI, (1 * HZ) / 10},
346 { "100baseTX", Media_Lnk, 0x02, XCVR_100baseFx, (14 * HZ) / 10}, 346 { "100baseTX", Media_Lnk, 0x02, XCVR_100baseFx, (14 * HZ) / 10},
347 { "100baseFX", Media_Lnk, 0x04, XCVR_MII, (14 * HZ) / 10}, 347 { "100baseFX", Media_Lnk, 0x04, XCVR_MII, (14 * HZ) / 10},
348 { "MII", 0, 0x40, XCVR_10baseT, 3 * HZ}, 348 { "MII", 0, 0x40, XCVR_10baseT, 3 * HZ},
349 { "undefined", 0, 0x01, XCVR_10baseT, 10000}, 349 { "undefined", 0, 0x01, XCVR_10baseT, 10000},
350 { "Default", 0, 0xFF, XCVR_10baseT, 10000}, 350 { "Default", 0, 0xFF, XCVR_10baseT, 10000},
351}; 351};
352 352
@@ -380,9 +380,9 @@ static void update_stats(int addr, struct net_device *dev);
380static struct net_device_stats *corkscrew_get_stats(struct net_device *dev); 380static struct net_device_stats *corkscrew_get_stats(struct net_device *dev);
381static void set_rx_mode(struct net_device *dev); 381static void set_rx_mode(struct net_device *dev);
382static struct ethtool_ops netdev_ethtool_ops; 382static struct ethtool_ops netdev_ethtool_ops;
383
384 383
385/* 384
385/*
386 Unfortunately maximizing the shared code between the integrated and 386 Unfortunately maximizing the shared code between the integrated and
387 module version of the driver results in a complicated set of initialization 387 module version of the driver results in a complicated set of initialization
388 procedures. 388 procedures.
@@ -612,7 +612,7 @@ static int corkscrew_setup(struct net_device *dev, int ioaddr,
612 printk(KERN_INFO "%s: 3Com %s at %#3x,", dev->name, vp->product_name, ioaddr); 612 printk(KERN_INFO "%s: 3Com %s at %#3x,", dev->name, vp->product_name, ioaddr);
613 613
614 spin_lock_init(&vp->lock); 614 spin_lock_init(&vp->lock);
615 615
616 /* Read the station address from the EEPROM. */ 616 /* Read the station address from the EEPROM. */
617 EL3WINDOW(0); 617 EL3WINDOW(0);
618 for (i = 0; i < 0x18; i++) { 618 for (i = 0; i < 0x18; i++) {
@@ -691,7 +691,7 @@ static int corkscrew_setup(struct net_device *dev, int ioaddr,
691 691
692 return register_netdev(dev); 692 return register_netdev(dev);
693} 693}
694 694
695 695
696static int corkscrew_open(struct net_device *dev) 696static int corkscrew_open(struct net_device *dev)
697{ 697{
@@ -715,7 +715,7 @@ static int corkscrew_open(struct net_device *dev)
715 } else if (vp->autoselect) { 715 } else if (vp->autoselect) {
716 /* Find first available media type, starting with 100baseTx. */ 716 /* Find first available media type, starting with 100baseTx. */
717 dev->if_port = 4; 717 dev->if_port = 4;
718 while (!(vp->available_media & media_tbl[dev->if_port].mask)) 718 while (!(vp->available_media & media_tbl[dev->if_port].mask))
719 dev->if_port = media_tbl[dev->if_port].next; 719 dev->if_port = media_tbl[dev->if_port].next;
720 720
721 if (corkscrew_debug > 1) 721 if (corkscrew_debug > 1)
@@ -871,7 +871,7 @@ static void corkscrew_timer(unsigned long data)
871 dev->name, media_tbl[dev->if_port].name); 871 dev->name, media_tbl[dev->if_port].name);
872 872
873 spin_lock_irqsave(&vp->lock, flags); 873 spin_lock_irqsave(&vp->lock, flags);
874 874
875 { 875 {
876 int old_window = inw(ioaddr + EL3_CMD) >> 13; 876 int old_window = inw(ioaddr + EL3_CMD) >> 13;
877 int media_status; 877 int media_status;
@@ -911,7 +911,7 @@ static void corkscrew_timer(unsigned long data)
911 media_tbl[dev->if_port].next; 911 media_tbl[dev->if_port].next;
912 } 912 }
913 while (!(vp->available_media & media_tbl[dev->if_port].mask)); 913 while (!(vp->available_media & media_tbl[dev->if_port].mask));
914 914
915 if (dev->if_port == 8) { /* Go back to default. */ 915 if (dev->if_port == 8) { /* Go back to default. */
916 dev->if_port = vp->default_media; 916 dev->if_port = vp->default_media;
917 if (corkscrew_debug > 1) 917 if (corkscrew_debug > 1)
@@ -940,7 +940,7 @@ static void corkscrew_timer(unsigned long data)
940 } 940 }
941 EL3WINDOW(old_window); 941 EL3WINDOW(old_window);
942 } 942 }
943 943
944 spin_unlock_irqrestore(&vp->lock, flags); 944 spin_unlock_irqrestore(&vp->lock, flags);
945 if (corkscrew_debug > 1) 945 if (corkscrew_debug > 1)
946 printk("%s: Media selection timer finished, %s.\n", 946 printk("%s: Media selection timer finished, %s.\n",
@@ -1026,7 +1026,7 @@ static int corkscrew_start_xmit(struct sk_buff *skb,
1026 outw(DownStall, ioaddr + EL3_CMD); 1026 outw(DownStall, ioaddr + EL3_CMD);
1027 /* Wait for the stall to complete. */ 1027 /* Wait for the stall to complete. */
1028 for (i = 20; i >= 0; i--) 1028 for (i = 20; i >= 0; i--)
1029 if ((inw(ioaddr + EL3_STATUS) & CmdInProgress) == 0) 1029 if ((inw(ioaddr + EL3_STATUS) & CmdInProgress) == 0)
1030 break; 1030 break;
1031 if (prev_entry) 1031 if (prev_entry)
1032 prev_entry->next = isa_virt_to_bus(&vp->tx_ring[entry]); 1032 prev_entry->next = isa_virt_to_bus(&vp->tx_ring[entry]);
@@ -1102,7 +1102,7 @@ static int corkscrew_start_xmit(struct sk_buff *skb,
1102 int j; 1102 int j;
1103 outw(TxReset, ioaddr + EL3_CMD); 1103 outw(TxReset, ioaddr + EL3_CMD);
1104 for (j = 20; j >= 0; j--) 1104 for (j = 20; j >= 0; j--)
1105 if (!(inw(ioaddr + EL3_STATUS) & CmdInProgress)) 1105 if (!(inw(ioaddr + EL3_STATUS) & CmdInProgress))
1106 break; 1106 break;
1107 } 1107 }
1108 outw(TxEnable, ioaddr + EL3_CMD); 1108 outw(TxEnable, ioaddr + EL3_CMD);
@@ -1130,7 +1130,7 @@ static irqreturn_t corkscrew_interrupt(int irq, void *dev_id,
1130 latency = inb(ioaddr + Timer); 1130 latency = inb(ioaddr + Timer);
1131 1131
1132 spin_lock(&lp->lock); 1132 spin_lock(&lp->lock);
1133 1133
1134 status = inw(ioaddr + EL3_STATUS); 1134 status = inw(ioaddr + EL3_STATUS);
1135 1135
1136 if (corkscrew_debug > 4) 1136 if (corkscrew_debug > 4)
@@ -1249,7 +1249,7 @@ static irqreturn_t corkscrew_interrupt(int irq, void *dev_id,
1249 outw(AckIntr | IntReq | IntLatch, ioaddr + EL3_CMD); 1249 outw(AckIntr | IntReq | IntLatch, ioaddr + EL3_CMD);
1250 1250
1251 } while ((status = inw(ioaddr + EL3_STATUS)) & (IntLatch | RxComplete)); 1251 } while ((status = inw(ioaddr + EL3_STATUS)) & (IntLatch | RxComplete));
1252 1252
1253 spin_unlock(&lp->lock); 1253 spin_unlock(&lp->lock);
1254 1254
1255 if (corkscrew_debug > 4) 1255 if (corkscrew_debug > 4)
@@ -1308,7 +1308,7 @@ static int corkscrew_rx(struct net_device *dev)
1308 vp->stats.rx_bytes += pkt_len; 1308 vp->stats.rx_bytes += pkt_len;
1309 /* Wait a limited time to go to next packet. */ 1309 /* Wait a limited time to go to next packet. */
1310 for (i = 200; i >= 0; i--) 1310 for (i = 200; i >= 0; i--)
1311 if (! (inw(ioaddr + EL3_STATUS) & CmdInProgress)) 1311 if (! (inw(ioaddr + EL3_STATUS) & CmdInProgress))
1312 break; 1312 break;
1313 continue; 1313 continue;
1314 } else if (corkscrew_debug) 1314 } else if (corkscrew_debug)
@@ -1567,7 +1567,7 @@ static struct ethtool_ops netdev_ethtool_ops = {
1567 .set_msglevel = netdev_set_msglevel, 1567 .set_msglevel = netdev_set_msglevel,
1568}; 1568};
1569 1569
1570 1570
1571#ifdef MODULE 1571#ifdef MODULE
1572void cleanup_module(void) 1572void cleanup_module(void)
1573{ 1573{
@@ -1584,7 +1584,7 @@ void cleanup_module(void)
1584 } 1584 }
1585} 1585}
1586#endif /* MODULE */ 1586#endif /* MODULE */
1587 1587
1588/* 1588/*
1589 * Local variables: 1589 * Local variables:
1590 * compile-command: "gcc -DMODULE -D__KERNEL__ -Wall -Wstrict-prototypes -O6 -c 3c515.c" 1590 * compile-command: "gcc -DMODULE -D__KERNEL__ -Wall -Wstrict-prototypes -O6 -c 3c515.c"