aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/r8169.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/r8169.c')
-rw-r--r--drivers/net/r8169.c65
1 files changed, 32 insertions, 33 deletions
diff --git a/drivers/net/r8169.c b/drivers/net/r8169.c
index 653b9a7a4178..5d620d81e8cb 100644
--- a/drivers/net/r8169.c
+++ b/drivers/net/r8169.c
@@ -6,26 +6,26 @@
6 History: 6 History:
7 Feb 4 2002 - created initially by ShuChen <shuchen@realtek.com.tw>. 7 Feb 4 2002 - created initially by ShuChen <shuchen@realtek.com.tw>.
8 May 20 2002 - Add link status force-mode and TBI mode support. 8 May 20 2002 - Add link status force-mode and TBI mode support.
9 2004 - Massive updates. See kernel SCM system for details. 9 2004 - Massive updates. See kernel SCM system for details.
10========================================================================= 10=========================================================================
11 1. [DEPRECATED: use ethtool instead] The media can be forced in 5 modes. 11 1. [DEPRECATED: use ethtool instead] The media can be forced in 5 modes.
12 Command: 'insmod r8169 media = SET_MEDIA' 12 Command: 'insmod r8169 media = SET_MEDIA'
13 Ex: 'insmod r8169 media = 0x04' will force PHY to operate in 100Mpbs Half-duplex. 13 Ex: 'insmod r8169 media = 0x04' will force PHY to operate in 100Mpbs Half-duplex.
14 14
15 SET_MEDIA can be: 15 SET_MEDIA can be:
16 _10_Half = 0x01 16 _10_Half = 0x01
17 _10_Full = 0x02 17 _10_Full = 0x02
18 _100_Half = 0x04 18 _100_Half = 0x04
19 _100_Full = 0x08 19 _100_Full = 0x08
20 _1000_Full = 0x10 20 _1000_Full = 0x10
21 21
22 2. Support TBI mode. 22 2. Support TBI mode.
23========================================================================= 23=========================================================================
24VERSION 1.1 <2002/10/4> 24VERSION 1.1 <2002/10/4>
25 25
26 The bit4:0 of MII register 4 is called "selector field", and have to be 26 The bit4:0 of MII register 4 is called "selector field", and have to be
27 00001b to indicate support of IEEE std 802.3 during NWay process of 27 00001b to indicate support of IEEE std 802.3 during NWay process of
28 exchanging Link Code Word (FLP). 28 exchanging Link Code Word (FLP).
29 29
30VERSION 1.2 <2002/11/30> 30VERSION 1.2 <2002/11/30>
31 31
@@ -81,10 +81,10 @@ VERSION 2.2LK <2005/01/25>
81 81
82#ifdef RTL8169_DEBUG 82#ifdef RTL8169_DEBUG
83#define assert(expr) \ 83#define assert(expr) \
84 if(!(expr)) { \ 84 if (!(expr)) { \
85 printk( "Assertion failed! %s,%s,%s,line=%d\n", \ 85 printk( "Assertion failed! %s,%s,%s,line=%d\n", \
86 #expr,__FILE__,__FUNCTION__,__LINE__); \ 86 #expr,__FILE__,__FUNCTION__,__LINE__); \
87 } 87 }
88#define dprintk(fmt, args...) do { printk(PFX fmt, ## args); } while (0) 88#define dprintk(fmt, args...) do { printk(PFX fmt, ## args); } while (0)
89#else 89#else
90#define assert(expr) do {} while (0) 90#define assert(expr) do {} while (0)
@@ -520,7 +520,7 @@ static const u16 rtl8169_intr_mask =
520static const u16 rtl8169_napi_event = 520static const u16 rtl8169_napi_event =
521 RxOK | RxOverflow | RxFIFOOver | TxOK | TxErr; 521 RxOK | RxOverflow | RxFIFOOver | TxOK | TxErr;
522static const unsigned int rtl8169_rx_config = 522static const unsigned int rtl8169_rx_config =
523 (RX_FIFO_THRESH << RxCfgFIFOShift) | (RX_DMA_BURST << RxCfgDMAShift); 523 (RX_FIFO_THRESH << RxCfgFIFOShift) | (RX_DMA_BURST << RxCfgDMAShift);
524 524
525#define PHY_Cap_10_Half_Or_Less PHY_Cap_10_Half 525#define PHY_Cap_10_Half_Or_Less PHY_Cap_10_Half
526#define PHY_Cap_10_Full_Or_Less PHY_Cap_10_Full | PHY_Cap_10_Half_Or_Less 526#define PHY_Cap_10_Full_Or_Less PHY_Cap_10_Full | PHY_Cap_10_Half_Or_Less
@@ -535,7 +535,7 @@ static void mdio_write(void __iomem *ioaddr, int RegAddr, int value)
535 535
536 for (i = 20; i > 0; i--) { 536 for (i = 20; i > 0; i--) {
537 /* Check if the RTL8169 has completed writing to the specified MII register */ 537 /* Check if the RTL8169 has completed writing to the specified MII register */
538 if (!(RTL_R32(PHYAR) & 0x80000000)) 538 if (!(RTL_R32(PHYAR) & 0x80000000))
539 break; 539 break;
540 udelay(25); 540 udelay(25);
541 } 541 }
@@ -640,7 +640,7 @@ static void rtl8169_link_option(int idx, u8 *autoneg, u16 *speed, u8 *duplex)
640 { SPEED_1000, DUPLEX_FULL, AUTONEG_ENABLE, 0xff } 640 { SPEED_1000, DUPLEX_FULL, AUTONEG_ENABLE, 0xff }
641 }, *p; 641 }, *p;
642 unsigned char option; 642 unsigned char option;
643 643
644 option = ((idx < MAX_UNITS) && (idx >= 0)) ? media[idx] : 0xff; 644 option = ((idx < MAX_UNITS) && (idx >= 0)) ? media[idx] : 0xff;
645 645
646 if ((option != 0xff) && !idx && netif_msg_drv(&debug)) 646 if ((option != 0xff) && !idx && netif_msg_drv(&debug))
@@ -682,9 +682,9 @@ static void rtl8169_get_wol(struct net_device *dev, struct ethtool_wolinfo *wol)
682 if (options & UWF) 682 if (options & UWF)
683 wol->wolopts |= WAKE_UCAST; 683 wol->wolopts |= WAKE_UCAST;
684 if (options & BWF) 684 if (options & BWF)
685 wol->wolopts |= WAKE_BCAST; 685 wol->wolopts |= WAKE_BCAST;
686 if (options & MWF) 686 if (options & MWF)
687 wol->wolopts |= WAKE_MCAST; 687 wol->wolopts |= WAKE_MCAST;
688 688
689out_unlock: 689out_unlock:
690 spin_unlock_irq(&tp->lock); 690 spin_unlock_irq(&tp->lock);
@@ -855,7 +855,7 @@ static int rtl8169_set_settings(struct net_device *dev, struct ethtool_cmd *cmd)
855 spin_lock_irqsave(&tp->lock, flags); 855 spin_lock_irqsave(&tp->lock, flags);
856 ret = rtl8169_set_speed(dev, cmd->autoneg, cmd->speed, cmd->duplex); 856 ret = rtl8169_set_speed(dev, cmd->autoneg, cmd->speed, cmd->duplex);
857 spin_unlock_irqrestore(&tp->lock, flags); 857 spin_unlock_irqrestore(&tp->lock, flags);
858 858
859 return ret; 859 return ret;
860} 860}
861 861
@@ -988,7 +988,7 @@ static void rtl8169_gset_xmii(struct net_device *dev, struct ethtool_cmd *cmd)
988 SUPPORTED_100baseT_Full | 988 SUPPORTED_100baseT_Full |
989 SUPPORTED_1000baseT_Full | 989 SUPPORTED_1000baseT_Full |
990 SUPPORTED_Autoneg | 990 SUPPORTED_Autoneg |
991 SUPPORTED_TP; 991 SUPPORTED_TP;
992 992
993 cmd->autoneg = 1; 993 cmd->autoneg = 1;
994 cmd->advertising = ADVERTISED_TP | ADVERTISED_Autoneg; 994 cmd->advertising = ADVERTISED_TP | ADVERTISED_Autoneg;
@@ -1038,15 +1038,15 @@ static int rtl8169_get_settings(struct net_device *dev, struct ethtool_cmd *cmd)
1038static void rtl8169_get_regs(struct net_device *dev, struct ethtool_regs *regs, 1038static void rtl8169_get_regs(struct net_device *dev, struct ethtool_regs *regs,
1039 void *p) 1039 void *p)
1040{ 1040{
1041 struct rtl8169_private *tp = netdev_priv(dev); 1041 struct rtl8169_private *tp = netdev_priv(dev);
1042 unsigned long flags; 1042 unsigned long flags;
1043 1043
1044 if (regs->len > R8169_REGS_SIZE) 1044 if (regs->len > R8169_REGS_SIZE)
1045 regs->len = R8169_REGS_SIZE; 1045 regs->len = R8169_REGS_SIZE;
1046 1046
1047 spin_lock_irqsave(&tp->lock, flags); 1047 spin_lock_irqsave(&tp->lock, flags);
1048 memcpy_fromio(p, tp->mmio_addr, regs->len); 1048 memcpy_fromio(p, tp->mmio_addr, regs->len);
1049 spin_unlock_irqrestore(&tp->lock, flags); 1049 spin_unlock_irqrestore(&tp->lock, flags);
1050} 1050}
1051 1051
1052static u32 rtl8169_get_msglevel(struct net_device *dev) 1052static u32 rtl8169_get_msglevel(struct net_device *dev)
@@ -1128,7 +1128,7 @@ static void rtl8169_get_ethtool_stats(struct net_device *dev,
1128 RTL_W32(CounterAddrLow, 0); 1128 RTL_W32(CounterAddrLow, 0);
1129 RTL_W32(CounterAddrHigh, 0); 1129 RTL_W32(CounterAddrHigh, 0);
1130 1130
1131 data[0] = le64_to_cpu(counters->tx_packets); 1131 data[0] = le64_to_cpu(counters->tx_packets);
1132 data[1] = le64_to_cpu(counters->rx_packets); 1132 data[1] = le64_to_cpu(counters->rx_packets);
1133 data[2] = le64_to_cpu(counters->tx_errors); 1133 data[2] = le64_to_cpu(counters->tx_errors);
1134 data[3] = le32_to_cpu(counters->rx_errors); 1134 data[3] = le32_to_cpu(counters->rx_errors);
@@ -1188,7 +1188,7 @@ static void rtl8169_write_gmii_reg_bit(void __iomem *ioaddr, int reg, int bitnum
1188 val = mdio_read(ioaddr, reg); 1188 val = mdio_read(ioaddr, reg);
1189 val = (bitval == 1) ? 1189 val = (bitval == 1) ?
1190 val | (bitval << bitnum) : val & ~(0x0001 << bitnum); 1190 val | (bitval << bitnum) : val & ~(0x0001 << bitnum);
1191 mdio_write(ioaddr, reg, val & 0xffff); 1191 mdio_write(ioaddr, reg, val & 0xffff);
1192} 1192}
1193 1193
1194static void rtl8169_get_mac_version(struct rtl8169_private *tp, void __iomem *ioaddr) 1194static void rtl8169_get_mac_version(struct rtl8169_private *tp, void __iomem *ioaddr)
@@ -1201,7 +1201,7 @@ static void rtl8169_get_mac_version(struct rtl8169_private *tp, void __iomem *io
1201 { 0x38000000, RTL_GIGA_MAC_VER_12 }, 1201 { 0x38000000, RTL_GIGA_MAC_VER_12 },
1202 { 0x34000000, RTL_GIGA_MAC_VER_13 }, 1202 { 0x34000000, RTL_GIGA_MAC_VER_13 },
1203 { 0x30800000, RTL_GIGA_MAC_VER_14 }, 1203 { 0x30800000, RTL_GIGA_MAC_VER_14 },
1204 { 0x30000000, RTL_GIGA_MAC_VER_11 }, 1204 { 0x30000000, RTL_GIGA_MAC_VER_11 },
1205 { 0x18000000, RTL_GIGA_MAC_VER_05 }, 1205 { 0x18000000, RTL_GIGA_MAC_VER_05 },
1206 { 0x10000000, RTL_GIGA_MAC_VER_04 }, 1206 { 0x10000000, RTL_GIGA_MAC_VER_04 },
1207 { 0x04000000, RTL_GIGA_MAC_VER_03 }, 1207 { 0x04000000, RTL_GIGA_MAC_VER_03 },
@@ -1361,7 +1361,7 @@ static void rtl8169_phy_timer(unsigned long __opaque)
1361 spin_lock_irq(&tp->lock); 1361 spin_lock_irq(&tp->lock);
1362 1362
1363 if (tp->phy_reset_pending(ioaddr)) { 1363 if (tp->phy_reset_pending(ioaddr)) {
1364 /* 1364 /*
1365 * A busy loop could burn quite a few cycles on nowadays CPU. 1365 * A busy loop could burn quite a few cycles on nowadays CPU.
1366 * Let's delay the execution of the timer for a few ticks. 1366 * Let's delay the execution of the timer for a few ticks.
1367 */ 1367 */
@@ -1887,9 +1887,8 @@ rtl8169_hw_start(struct net_device *dev)
1887 RTL_W32(RxConfig, i); 1887 RTL_W32(RxConfig, i);
1888 1888
1889 /* Set DMA burst size and Interframe Gap Time */ 1889 /* Set DMA burst size and Interframe Gap Time */
1890 RTL_W32(TxConfig, 1890 RTL_W32(TxConfig, (TX_DMA_BURST << TxDMAShift) |
1891 (TX_DMA_BURST << TxDMAShift) | (InterFrameGap << 1891 (InterFrameGap << TxInterFrameGapShift));
1892 TxInterFrameGapShift));
1893 1892
1894 tp->cp_cmd |= RTL_R16(CPlusCmd) | PCIMulRW; 1893 tp->cp_cmd |= RTL_R16(CPlusCmd) | PCIMulRW;
1895 1894
@@ -2042,7 +2041,7 @@ static u32 rtl8169_rx_fill(struct rtl8169_private *tp, struct net_device *dev,
2042 u32 start, u32 end) 2041 u32 start, u32 end)
2043{ 2042{
2044 u32 cur; 2043 u32 cur;
2045 2044
2046 for (cur = start; end - cur > 0; cur++) { 2045 for (cur = start; end - cur > 0; cur++) {
2047 int ret, i = cur % NUM_RX_DESC; 2046 int ret, i = cur % NUM_RX_DESC;
2048 2047
@@ -2280,7 +2279,7 @@ static int rtl8169_start_xmit(struct sk_buff *skb, struct net_device *dev)
2280 u32 status, len; 2279 u32 status, len;
2281 u32 opts1; 2280 u32 opts1;
2282 int ret = NETDEV_TX_OK; 2281 int ret = NETDEV_TX_OK;
2283 2282
2284 if (unlikely(TX_BUFFS_AVAIL(tp) < skb_shinfo(skb)->nr_frags)) { 2283 if (unlikely(TX_BUFFS_AVAIL(tp) < skb_shinfo(skb)->nr_frags)) {
2285 if (netif_msg_drv(tp)) { 2284 if (netif_msg_drv(tp)) {
2286 printk(KERN_ERR 2285 printk(KERN_ERR
@@ -2637,7 +2636,7 @@ rtl8169_interrupt(int irq, void *dev_instance, struct pt_regs *regs)
2637 __netif_rx_schedule(dev); 2636 __netif_rx_schedule(dev);
2638 else if (netif_msg_intr(tp)) { 2637 else if (netif_msg_intr(tp)) {
2639 printk(KERN_INFO "%s: interrupt %04x taken in poll\n", 2638 printk(KERN_INFO "%s: interrupt %04x taken in poll\n",
2640 dev->name, status); 2639 dev->name, status);
2641 } 2640 }
2642 break; 2641 break;
2643#else 2642#else
@@ -2844,7 +2843,7 @@ static struct net_device_stats *rtl8169_get_stats(struct net_device *dev)
2844 RTL_W32(RxMissed, 0); 2843 RTL_W32(RxMissed, 0);
2845 spin_unlock_irqrestore(&tp->lock, flags); 2844 spin_unlock_irqrestore(&tp->lock, flags);
2846 } 2845 }
2847 2846
2848 return &tp->stats; 2847 return &tp->stats;
2849} 2848}
2850 2849