diff options
| author | Linus Torvalds <torvalds@woody.osdl.org> | 2007-01-09 12:36:06 -0500 |
|---|---|---|
| committer | Linus Torvalds <torvalds@woody.osdl.org> | 2007-01-09 12:36:06 -0500 |
| commit | 97bee8e25da4dfc3b7a369fb2c2f280f5c1918c2 (patch) | |
| tree | 75dcf606ca1c29bd3aca571834355ccf6f06bd5b /drivers/net | |
| parent | 8ba1f2798224086c72c1132acd6fdb45068279d7 (diff) | |
| parent | 77aab8bf22042d1658d4adbca8b71779e7f2d0ff (diff) | |
Merge branch 'upstream-linus' of master.kernel.org:/pub/scm/linux/kernel/git/jgarzik/netdev-2.6
* 'upstream-linus' of master.kernel.org:/pub/scm/linux/kernel/git/jgarzik/netdev-2.6:
pcnet_cs : add new id
chelsio: error path fix
s390: iucv Kconfig help description changes
s390: qeth driver fixes: atomic context fixups
s390: qeth driver fixes: packet socket
s390: qeth driver fixes: VLAN hdr, perf stats
forcedeth: sideband management fix
Revert "[PATCH] e1000: disable TSO on the 82544 with slab debugging"
qeth: fix uaccess handling and get rid of unused variable
qla3xxx: Add delay to NVRAM register access.
qla3xxx: Remove NETIF_F_LLTX from driver features.
ixgb: Write RA register high word first, increment version
ixgb: Maybe stop TX if not enough free descriptors
ixgb: Fix early TSO completion
[PATCH] ipw2100: Fix dropping fragmented small packet problem
[PATCH] ieee80211: WLAN_GET_SEQ_SEQ fix (select correct region)
Diffstat (limited to 'drivers/net')
| -rw-r--r-- | drivers/net/chelsio/my3126.c | 5 | ||||
| -rw-r--r-- | drivers/net/e1000/e1000_main.c | 6 | ||||
| -rw-r--r-- | drivers/net/forcedeth.c | 111 | ||||
| -rw-r--r-- | drivers/net/ixgb/ixgb.h | 1 | ||||
| -rw-r--r-- | drivers/net/ixgb/ixgb_ethtool.c | 1 | ||||
| -rw-r--r-- | drivers/net/ixgb/ixgb_hw.c | 3 | ||||
| -rw-r--r-- | drivers/net/ixgb/ixgb_main.c | 57 | ||||
| -rw-r--r-- | drivers/net/pcmcia/pcnet_cs.c | 2 | ||||
| -rw-r--r-- | drivers/net/qla3xxx.c | 38 | ||||
| -rw-r--r-- | drivers/net/wireless/ipw2100.c | 2 |
10 files changed, 140 insertions, 86 deletions
diff --git a/drivers/net/chelsio/my3126.c b/drivers/net/chelsio/my3126.c index c7731b6f9de3..82fed1dd5005 100644 --- a/drivers/net/chelsio/my3126.c +++ b/drivers/net/chelsio/my3126.c | |||
| @@ -170,9 +170,10 @@ static struct cphy *my3126_phy_create(adapter_t *adapter, | |||
| 170 | { | 170 | { |
| 171 | struct cphy *cphy = kzalloc(sizeof (*cphy), GFP_KERNEL); | 171 | struct cphy *cphy = kzalloc(sizeof (*cphy), GFP_KERNEL); |
| 172 | 172 | ||
| 173 | if (cphy) | 173 | if (!cphy) |
| 174 | cphy_init(cphy, adapter, phy_addr, &my3126_ops, mdio_ops); | 174 | return NULL; |
| 175 | 175 | ||
| 176 | cphy_init(cphy, adapter, phy_addr, &my3126_ops, mdio_ops); | ||
| 176 | INIT_DELAYED_WORK(&cphy->phy_update, my3216_poll); | 177 | INIT_DELAYED_WORK(&cphy->phy_update, my3216_poll); |
| 177 | cphy->bmsr = 0; | 178 | cphy->bmsr = 0; |
| 178 | 179 | ||
diff --git a/drivers/net/e1000/e1000_main.c b/drivers/net/e1000/e1000_main.c index 4c1ff752048c..c6259c7127f6 100644 --- a/drivers/net/e1000/e1000_main.c +++ b/drivers/net/e1000/e1000_main.c | |||
| @@ -995,12 +995,6 @@ e1000_probe(struct pci_dev *pdev, | |||
| 995 | (adapter->hw.mac_type != e1000_82547)) | 995 | (adapter->hw.mac_type != e1000_82547)) |
| 996 | netdev->features |= NETIF_F_TSO; | 996 | netdev->features |= NETIF_F_TSO; |
| 997 | 997 | ||
| 998 | #ifdef CONFIG_DEBUG_SLAB | ||
| 999 | /* 82544's work arounds do not play nicely with DEBUG SLAB */ | ||
| 1000 | if (adapter->hw.mac_type == e1000_82544) | ||
| 1001 | netdev->features &= ~NETIF_F_TSO; | ||
| 1002 | #endif | ||
| 1003 | |||
| 1004 | #ifdef NETIF_F_TSO6 | 998 | #ifdef NETIF_F_TSO6 |
| 1005 | if (adapter->hw.mac_type > e1000_82547_rev_2) | 999 | if (adapter->hw.mac_type > e1000_82547_rev_2) |
| 1006 | netdev->features |= NETIF_F_TSO6; | 1000 | netdev->features |= NETIF_F_TSO6; |
diff --git a/drivers/net/forcedeth.c b/drivers/net/forcedeth.c index 2f48fe9a29a7..93f2b7a22160 100644 --- a/drivers/net/forcedeth.c +++ b/drivers/net/forcedeth.c | |||
| @@ -234,6 +234,7 @@ enum { | |||
| 234 | #define NVREG_XMITCTL_HOST_SEMA_MASK 0x0000f000 | 234 | #define NVREG_XMITCTL_HOST_SEMA_MASK 0x0000f000 |
| 235 | #define NVREG_XMITCTL_HOST_SEMA_ACQ 0x0000f000 | 235 | #define NVREG_XMITCTL_HOST_SEMA_ACQ 0x0000f000 |
| 236 | #define NVREG_XMITCTL_HOST_LOADED 0x00004000 | 236 | #define NVREG_XMITCTL_HOST_LOADED 0x00004000 |
| 237 | #define NVREG_XMITCTL_TX_PATH_EN 0x01000000 | ||
| 237 | NvRegTransmitterStatus = 0x088, | 238 | NvRegTransmitterStatus = 0x088, |
| 238 | #define NVREG_XMITSTAT_BUSY 0x01 | 239 | #define NVREG_XMITSTAT_BUSY 0x01 |
| 239 | 240 | ||
| @@ -249,6 +250,7 @@ enum { | |||
| 249 | #define NVREG_OFFLOAD_NORMAL RX_NIC_BUFSIZE | 250 | #define NVREG_OFFLOAD_NORMAL RX_NIC_BUFSIZE |
| 250 | NvRegReceiverControl = 0x094, | 251 | NvRegReceiverControl = 0x094, |
| 251 | #define NVREG_RCVCTL_START 0x01 | 252 | #define NVREG_RCVCTL_START 0x01 |
| 253 | #define NVREG_RCVCTL_RX_PATH_EN 0x01000000 | ||
| 252 | NvRegReceiverStatus = 0x98, | 254 | NvRegReceiverStatus = 0x98, |
| 253 | #define NVREG_RCVSTAT_BUSY 0x01 | 255 | #define NVREG_RCVSTAT_BUSY 0x01 |
| 254 | 256 | ||
| @@ -1169,16 +1171,21 @@ static void nv_start_rx(struct net_device *dev) | |||
| 1169 | { | 1171 | { |
| 1170 | struct fe_priv *np = netdev_priv(dev); | 1172 | struct fe_priv *np = netdev_priv(dev); |
| 1171 | u8 __iomem *base = get_hwbase(dev); | 1173 | u8 __iomem *base = get_hwbase(dev); |
| 1174 | u32 rx_ctrl = readl(base + NvRegReceiverControl); | ||
| 1172 | 1175 | ||
| 1173 | dprintk(KERN_DEBUG "%s: nv_start_rx\n", dev->name); | 1176 | dprintk(KERN_DEBUG "%s: nv_start_rx\n", dev->name); |
| 1174 | /* Already running? Stop it. */ | 1177 | /* Already running? Stop it. */ |
| 1175 | if (readl(base + NvRegReceiverControl) & NVREG_RCVCTL_START) { | 1178 | if ((readl(base + NvRegReceiverControl) & NVREG_RCVCTL_START) && !np->mac_in_use) { |
| 1176 | writel(0, base + NvRegReceiverControl); | 1179 | rx_ctrl &= ~NVREG_RCVCTL_START; |
| 1180 | writel(rx_ctrl, base + NvRegReceiverControl); | ||
| 1177 | pci_push(base); | 1181 | pci_push(base); |
| 1178 | } | 1182 | } |
| 1179 | writel(np->linkspeed, base + NvRegLinkSpeed); | 1183 | writel(np->linkspeed, base + NvRegLinkSpeed); |
| 1180 | pci_push(base); | 1184 | pci_push(base); |
| 1181 | writel(NVREG_RCVCTL_START, base + NvRegReceiverControl); | 1185 | rx_ctrl |= NVREG_RCVCTL_START; |
| 1186 | if (np->mac_in_use) | ||
| 1187 | rx_ctrl &= ~NVREG_RCVCTL_RX_PATH_EN; | ||
| 1188 | writel(rx_ctrl, base + NvRegReceiverControl); | ||
| 1182 | dprintk(KERN_DEBUG "%s: nv_start_rx to duplex %d, speed 0x%08x.\n", | 1189 | dprintk(KERN_DEBUG "%s: nv_start_rx to duplex %d, speed 0x%08x.\n", |
| 1183 | dev->name, np->duplex, np->linkspeed); | 1190 | dev->name, np->duplex, np->linkspeed); |
| 1184 | pci_push(base); | 1191 | pci_push(base); |
| @@ -1186,39 +1193,59 @@ static void nv_start_rx(struct net_device *dev) | |||
| 1186 | 1193 | ||
| 1187 | static void nv_stop_rx(struct net_device *dev) | 1194 | static void nv_stop_rx(struct net_device *dev) |
| 1188 | { | 1195 | { |
| 1196 | struct fe_priv *np = netdev_priv(dev); | ||
| 1189 | u8 __iomem *base = get_hwbase(dev); | 1197 | u8 __iomem *base = get_hwbase(dev); |
| 1198 | u32 rx_ctrl = readl(base + NvRegReceiverControl); | ||
| 1190 | 1199 | ||
| 1191 | dprintk(KERN_DEBUG "%s: nv_stop_rx\n", dev->name); | 1200 | dprintk(KERN_DEBUG "%s: nv_stop_rx\n", dev->name); |
| 1192 | writel(0, base + NvRegReceiverControl); | 1201 | if (!np->mac_in_use) |
| 1202 | rx_ctrl &= ~NVREG_RCVCTL_START; | ||
| 1203 | else | ||
| 1204 | rx_ctrl |= NVREG_RCVCTL_RX_PATH_EN; | ||
| 1205 | writel(rx_ctrl, base + NvRegReceiverControl); | ||
| 1193 | reg_delay(dev, NvRegReceiverStatus, NVREG_RCVSTAT_BUSY, 0, | 1206 | reg_delay(dev, NvRegReceiverStatus, NVREG_RCVSTAT_BUSY, 0, |
| 1194 | NV_RXSTOP_DELAY1, NV_RXSTOP_DELAY1MAX, | 1207 | NV_RXSTOP_DELAY1, NV_RXSTOP_DELAY1MAX, |
| 1195 | KERN_INFO "nv_stop_rx: ReceiverStatus remained busy"); | 1208 | KERN_INFO "nv_stop_rx: ReceiverStatus remained busy"); |
| 1196 | 1209 | ||
| 1197 | udelay(NV_RXSTOP_DELAY2); | 1210 | udelay(NV_RXSTOP_DELAY2); |
| 1198 | writel(0, base + NvRegLinkSpeed); | 1211 | if (!np->mac_in_use) |
| 1212 | writel(0, base + NvRegLinkSpeed); | ||
| 1199 | } | 1213 | } |
| 1200 | 1214 | ||
| 1201 | static void nv_start_tx(struct net_device *dev) | 1215 | static void nv_start_tx(struct net_device *dev) |
| 1202 | { | 1216 | { |
| 1217 | struct fe_priv *np = netdev_priv(dev); | ||
| 1203 | u8 __iomem *base = get_hwbase(dev); | 1218 | u8 __iomem *base = get_hwbase(dev); |
| 1219 | u32 tx_ctrl = readl(base + NvRegTransmitterControl); | ||
| 1204 | 1220 | ||
| 1205 | dprintk(KERN_DEBUG "%s: nv_start_tx\n", dev->name); | 1221 | dprintk(KERN_DEBUG "%s: nv_start_tx\n", dev->name); |
| 1206 | writel(NVREG_XMITCTL_START, base + NvRegTransmitterControl); | 1222 | tx_ctrl |= NVREG_XMITCTL_START; |
| 1223 | if (np->mac_in_use) | ||
| 1224 | tx_ctrl &= ~NVREG_XMITCTL_TX_PATH_EN; | ||
| 1225 | writel(tx_ctrl, base + NvRegTransmitterControl); | ||
| 1207 | pci_push(base); | 1226 | pci_push(base); |
| 1208 | } | 1227 | } |
| 1209 | 1228 | ||
| 1210 | static void nv_stop_tx(struct net_device *dev) | 1229 | static void nv_stop_tx(struct net_device *dev) |
| 1211 | { | 1230 | { |
| 1231 | struct fe_priv *np = netdev_priv(dev); | ||
| 1212 | u8 __iomem *base = get_hwbase(dev); | 1232 | u8 __iomem *base = get_hwbase(dev); |
| 1233 | u32 tx_ctrl = readl(base + NvRegTransmitterControl); | ||
| 1213 | 1234 | ||
| 1214 | dprintk(KERN_DEBUG "%s: nv_stop_tx\n", dev->name); | 1235 | dprintk(KERN_DEBUG "%s: nv_stop_tx\n", dev->name); |
| 1215 | writel(0, base + NvRegTransmitterControl); | 1236 | if (!np->mac_in_use) |
| 1237 | tx_ctrl &= ~NVREG_XMITCTL_START; | ||
| 1238 | else | ||
| 1239 | tx_ctrl |= NVREG_XMITCTL_TX_PATH_EN; | ||
| 1240 | writel(tx_ctrl, base + NvRegTransmitterControl); | ||
| 1216 | reg_delay(dev, NvRegTransmitterStatus, NVREG_XMITSTAT_BUSY, 0, | 1241 | reg_delay(dev, NvRegTransmitterStatus, NVREG_XMITSTAT_BUSY, 0, |
| 1217 | NV_TXSTOP_DELAY1, NV_TXSTOP_DELAY1MAX, | 1242 | NV_TXSTOP_DELAY1, NV_TXSTOP_DELAY1MAX, |
| 1218 | KERN_INFO "nv_stop_tx: TransmitterStatus remained busy"); | 1243 | KERN_INFO "nv_stop_tx: TransmitterStatus remained busy"); |
| 1219 | 1244 | ||
| 1220 | udelay(NV_TXSTOP_DELAY2); | 1245 | udelay(NV_TXSTOP_DELAY2); |
| 1221 | writel(readl(base + NvRegTransmitPoll) & NVREG_TRANSMITPOLL_MAC_ADDR_REV, base + NvRegTransmitPoll); | 1246 | if (!np->mac_in_use) |
| 1247 | writel(readl(base + NvRegTransmitPoll) & NVREG_TRANSMITPOLL_MAC_ADDR_REV, | ||
| 1248 | base + NvRegTransmitPoll); | ||
| 1222 | } | 1249 | } |
| 1223 | 1250 | ||
| 1224 | static void nv_txrx_reset(struct net_device *dev) | 1251 | static void nv_txrx_reset(struct net_device *dev) |
| @@ -4148,20 +4175,6 @@ static int nv_mgmt_acquire_sema(struct net_device *dev) | |||
| 4148 | return 0; | 4175 | return 0; |
| 4149 | } | 4176 | } |
| 4150 | 4177 | ||
| 4151 | /* Indicate to mgmt unit whether driver is loaded or not */ | ||
| 4152 | static void nv_mgmt_driver_loaded(struct net_device *dev, int loaded) | ||
| 4153 | { | ||
| 4154 | u8 __iomem *base = get_hwbase(dev); | ||
| 4155 | u32 tx_ctrl; | ||
| 4156 | |||
| 4157 | tx_ctrl = readl(base + NvRegTransmitterControl); | ||
| 4158 | if (loaded) | ||
| 4159 | tx_ctrl |= NVREG_XMITCTL_HOST_LOADED; | ||
| 4160 | else | ||
| 4161 | tx_ctrl &= ~NVREG_XMITCTL_HOST_LOADED; | ||
| 4162 | writel(tx_ctrl, base + NvRegTransmitterControl); | ||
| 4163 | } | ||
| 4164 | |||
| 4165 | static int nv_open(struct net_device *dev) | 4178 | static int nv_open(struct net_device *dev) |
| 4166 | { | 4179 | { |
| 4167 | struct fe_priv *np = netdev_priv(dev); | 4180 | struct fe_priv *np = netdev_priv(dev); |
| @@ -4659,33 +4672,24 @@ static int __devinit nv_probe(struct pci_dev *pci_dev, const struct pci_device_i | |||
| 4659 | writel(NVREG_MIISTAT_MASK, base + NvRegMIIStatus); | 4672 | writel(NVREG_MIISTAT_MASK, base + NvRegMIIStatus); |
| 4660 | 4673 | ||
| 4661 | if (id->driver_data & DEV_HAS_MGMT_UNIT) { | 4674 | if (id->driver_data & DEV_HAS_MGMT_UNIT) { |
| 4662 | writel(0x1, base + 0x204); pci_push(base); | ||
| 4663 | msleep(500); | ||
| 4664 | /* management unit running on the mac? */ | 4675 | /* management unit running on the mac? */ |
| 4665 | np->mac_in_use = readl(base + NvRegTransmitterControl) & NVREG_XMITCTL_MGMT_ST; | 4676 | if (readl(base + NvRegTransmitterControl) & NVREG_XMITCTL_SYNC_PHY_INIT) { |
| 4666 | if (np->mac_in_use) { | 4677 | np->mac_in_use = readl(base + NvRegTransmitterControl) & NVREG_XMITCTL_MGMT_ST; |
| 4667 | u32 mgmt_sync; | 4678 | dprintk(KERN_INFO "%s: mgmt unit is running. mac in use %x.\n", pci_name(pci_dev), np->mac_in_use); |
| 4668 | /* management unit setup the phy already? */ | 4679 | for (i = 0; i < 5000; i++) { |
| 4669 | mgmt_sync = readl(base + NvRegTransmitterControl) & NVREG_XMITCTL_SYNC_MASK; | 4680 | msleep(1); |
| 4670 | if (mgmt_sync == NVREG_XMITCTL_SYNC_NOT_READY) { | 4681 | if (nv_mgmt_acquire_sema(dev)) { |
| 4671 | if (!nv_mgmt_acquire_sema(dev)) { | 4682 | /* management unit setup the phy already? */ |
| 4672 | for (i = 0; i < 5000; i++) { | 4683 | if ((readl(base + NvRegTransmitterControl) & NVREG_XMITCTL_SYNC_MASK) == |
| 4673 | msleep(1); | 4684 | NVREG_XMITCTL_SYNC_PHY_INIT) { |
| 4674 | mgmt_sync = readl(base + NvRegTransmitterControl) & NVREG_XMITCTL_SYNC_MASK; | 4685 | /* phy is inited by mgmt unit */ |
| 4675 | if (mgmt_sync == NVREG_XMITCTL_SYNC_NOT_READY) | 4686 | phyinitialized = 1; |
| 4676 | continue; | 4687 | dprintk(KERN_INFO "%s: Phy already initialized by mgmt unit.\n", pci_name(pci_dev)); |
| 4677 | if (mgmt_sync == NVREG_XMITCTL_SYNC_PHY_INIT) | 4688 | } else { |
| 4678 | phyinitialized = 1; | 4689 | /* we need to init the phy */ |
| 4679 | break; | ||
| 4680 | } | 4690 | } |
| 4681 | } else { | 4691 | break; |
| 4682 | /* we need to init the phy */ | ||
| 4683 | } | 4692 | } |
| 4684 | } else if (mgmt_sync == NVREG_XMITCTL_SYNC_PHY_INIT) { | ||
| 4685 | /* phy is inited by SMU */ | ||
| 4686 | phyinitialized = 1; | ||
| 4687 | } else { | ||
| 4688 | /* we need to init the phy */ | ||
| 4689 | } | 4693 | } |
| 4690 | } | 4694 | } |
| 4691 | } | 4695 | } |
| @@ -4724,10 +4728,12 @@ static int __devinit nv_probe(struct pci_dev *pci_dev, const struct pci_device_i | |||
| 4724 | if (!phyinitialized) { | 4728 | if (!phyinitialized) { |
| 4725 | /* reset it */ | 4729 | /* reset it */ |
| 4726 | phy_init(dev); | 4730 | phy_init(dev); |
| 4727 | } | 4731 | } else { |
| 4728 | 4732 | /* see if it is a gigabit phy */ | |
| 4729 | if (id->driver_data & DEV_HAS_MGMT_UNIT) { | 4733 | u32 mii_status = mii_rw(dev, np->phyaddr, MII_BMSR, MII_READ); |
| 4730 | nv_mgmt_driver_loaded(dev, 1); | 4734 | if (mii_status & PHY_GIGABIT) { |
| 4735 | np->gigabit = PHY_GIGABIT; | ||
| 4736 | } | ||
| 4731 | } | 4737 | } |
| 4732 | 4738 | ||
| 4733 | /* set default link speed settings */ | 4739 | /* set default link speed settings */ |
| @@ -4749,8 +4755,6 @@ static int __devinit nv_probe(struct pci_dev *pci_dev, const struct pci_device_i | |||
| 4749 | out_error: | 4755 | out_error: |
| 4750 | if (phystate_orig) | 4756 | if (phystate_orig) |
| 4751 | writel(phystate|NVREG_ADAPTCTL_RUNNING, base + NvRegAdapterControl); | 4757 | writel(phystate|NVREG_ADAPTCTL_RUNNING, base + NvRegAdapterControl); |
| 4752 | if (np->mac_in_use) | ||
| 4753 | nv_mgmt_driver_loaded(dev, 0); | ||
| 4754 | pci_set_drvdata(pci_dev, NULL); | 4758 | pci_set_drvdata(pci_dev, NULL); |
| 4755 | out_freering: | 4759 | out_freering: |
| 4756 | free_rings(dev); | 4760 | free_rings(dev); |
| @@ -4780,9 +4784,6 @@ static void __devexit nv_remove(struct pci_dev *pci_dev) | |||
| 4780 | writel(np->orig_mac[0], base + NvRegMacAddrA); | 4784 | writel(np->orig_mac[0], base + NvRegMacAddrA); |
| 4781 | writel(np->orig_mac[1], base + NvRegMacAddrB); | 4785 | writel(np->orig_mac[1], base + NvRegMacAddrB); |
| 4782 | 4786 | ||
| 4783 | if (np->mac_in_use) | ||
| 4784 | nv_mgmt_driver_loaded(dev, 0); | ||
| 4785 | |||
| 4786 | /* free all structures */ | 4787 | /* free all structures */ |
| 4787 | free_rings(dev); | 4788 | free_rings(dev); |
| 4788 | iounmap(get_hwbase(dev)); | 4789 | iounmap(get_hwbase(dev)); |
diff --git a/drivers/net/ixgb/ixgb.h b/drivers/net/ixgb/ixgb.h index 50ffe90488ff..f4aba4355b19 100644 --- a/drivers/net/ixgb/ixgb.h +++ b/drivers/net/ixgb/ixgb.h | |||
| @@ -171,6 +171,7 @@ struct ixgb_adapter { | |||
| 171 | 171 | ||
| 172 | /* TX */ | 172 | /* TX */ |
| 173 | struct ixgb_desc_ring tx_ring ____cacheline_aligned_in_smp; | 173 | struct ixgb_desc_ring tx_ring ____cacheline_aligned_in_smp; |
| 174 | unsigned int restart_queue; | ||
| 174 | unsigned long timeo_start; | 175 | unsigned long timeo_start; |
| 175 | uint32_t tx_cmd_type; | 176 | uint32_t tx_cmd_type; |
| 176 | uint64_t hw_csum_tx_good; | 177 | uint64_t hw_csum_tx_good; |
diff --git a/drivers/net/ixgb/ixgb_ethtool.c b/drivers/net/ixgb/ixgb_ethtool.c index cd22523fb035..82c044d6e08a 100644 --- a/drivers/net/ixgb/ixgb_ethtool.c +++ b/drivers/net/ixgb/ixgb_ethtool.c | |||
| @@ -79,6 +79,7 @@ static struct ixgb_stats ixgb_gstrings_stats[] = { | |||
| 79 | {"tx_window_errors", IXGB_STAT(net_stats.tx_window_errors)}, | 79 | {"tx_window_errors", IXGB_STAT(net_stats.tx_window_errors)}, |
| 80 | {"tx_deferred_ok", IXGB_STAT(stats.dc)}, | 80 | {"tx_deferred_ok", IXGB_STAT(stats.dc)}, |
| 81 | {"tx_timeout_count", IXGB_STAT(tx_timeout_count) }, | 81 | {"tx_timeout_count", IXGB_STAT(tx_timeout_count) }, |
| 82 | {"tx_restart_queue", IXGB_STAT(restart_queue) }, | ||
| 82 | {"rx_long_length_errors", IXGB_STAT(stats.roc)}, | 83 | {"rx_long_length_errors", IXGB_STAT(stats.roc)}, |
| 83 | {"rx_short_length_errors", IXGB_STAT(stats.ruc)}, | 84 | {"rx_short_length_errors", IXGB_STAT(stats.ruc)}, |
| 84 | #ifdef NETIF_F_TSO | 85 | #ifdef NETIF_F_TSO |
diff --git a/drivers/net/ixgb/ixgb_hw.c b/drivers/net/ixgb/ixgb_hw.c index 02089b64e42c..ecbf45861c68 100644 --- a/drivers/net/ixgb/ixgb_hw.c +++ b/drivers/net/ixgb/ixgb_hw.c | |||
| @@ -399,8 +399,9 @@ ixgb_init_rx_addrs(struct ixgb_hw *hw) | |||
| 399 | /* Zero out the other 15 receive addresses. */ | 399 | /* Zero out the other 15 receive addresses. */ |
| 400 | DEBUGOUT("Clearing RAR[1-15]\n"); | 400 | DEBUGOUT("Clearing RAR[1-15]\n"); |
| 401 | for(i = 1; i < IXGB_RAR_ENTRIES; i++) { | 401 | for(i = 1; i < IXGB_RAR_ENTRIES; i++) { |
| 402 | IXGB_WRITE_REG_ARRAY(hw, RA, (i << 1), 0); | 402 | /* Write high reg first to disable the AV bit first */ |
| 403 | IXGB_WRITE_REG_ARRAY(hw, RA, ((i << 1) + 1), 0); | 403 | IXGB_WRITE_REG_ARRAY(hw, RA, ((i << 1) + 1), 0); |
| 404 | IXGB_WRITE_REG_ARRAY(hw, RA, (i << 1), 0); | ||
| 404 | } | 405 | } |
| 405 | 406 | ||
| 406 | return; | 407 | return; |
diff --git a/drivers/net/ixgb/ixgb_main.c b/drivers/net/ixgb/ixgb_main.c index e628126c9c49..a083a9189230 100644 --- a/drivers/net/ixgb/ixgb_main.c +++ b/drivers/net/ixgb/ixgb_main.c | |||
| @@ -36,7 +36,7 @@ static char ixgb_driver_string[] = "Intel(R) PRO/10GbE Network Driver"; | |||
| 36 | #else | 36 | #else |
| 37 | #define DRIVERNAPI "-NAPI" | 37 | #define DRIVERNAPI "-NAPI" |
| 38 | #endif | 38 | #endif |
| 39 | #define DRV_VERSION "1.0.117-k2"DRIVERNAPI | 39 | #define DRV_VERSION "1.0.126-k2"DRIVERNAPI |
| 40 | char ixgb_driver_version[] = DRV_VERSION; | 40 | char ixgb_driver_version[] = DRV_VERSION; |
| 41 | static char ixgb_copyright[] = "Copyright (c) 1999-2006 Intel Corporation."; | 41 | static char ixgb_copyright[] = "Copyright (c) 1999-2006 Intel Corporation."; |
| 42 | 42 | ||
| @@ -1287,6 +1287,7 @@ ixgb_tx_map(struct ixgb_adapter *adapter, struct sk_buff *skb, | |||
| 1287 | struct ixgb_buffer *buffer_info; | 1287 | struct ixgb_buffer *buffer_info; |
| 1288 | int len = skb->len; | 1288 | int len = skb->len; |
| 1289 | unsigned int offset = 0, size, count = 0, i; | 1289 | unsigned int offset = 0, size, count = 0, i; |
| 1290 | unsigned int mss = skb_shinfo(skb)->gso_size; | ||
| 1290 | 1291 | ||
| 1291 | unsigned int nr_frags = skb_shinfo(skb)->nr_frags; | 1292 | unsigned int nr_frags = skb_shinfo(skb)->nr_frags; |
| 1292 | unsigned int f; | 1293 | unsigned int f; |
| @@ -1298,6 +1299,11 @@ ixgb_tx_map(struct ixgb_adapter *adapter, struct sk_buff *skb, | |||
| 1298 | while(len) { | 1299 | while(len) { |
| 1299 | buffer_info = &tx_ring->buffer_info[i]; | 1300 | buffer_info = &tx_ring->buffer_info[i]; |
| 1300 | size = min(len, IXGB_MAX_DATA_PER_TXD); | 1301 | size = min(len, IXGB_MAX_DATA_PER_TXD); |
| 1302 | /* Workaround for premature desc write-backs | ||
| 1303 | * in TSO mode. Append 4-byte sentinel desc */ | ||
| 1304 | if (unlikely(mss && !nr_frags && size == len && size > 8)) | ||
| 1305 | size -= 4; | ||
| 1306 | |||
| 1301 | buffer_info->length = size; | 1307 | buffer_info->length = size; |
| 1302 | WARN_ON(buffer_info->dma != 0); | 1308 | WARN_ON(buffer_info->dma != 0); |
| 1303 | buffer_info->dma = | 1309 | buffer_info->dma = |
| @@ -1324,6 +1330,13 @@ ixgb_tx_map(struct ixgb_adapter *adapter, struct sk_buff *skb, | |||
| 1324 | while(len) { | 1330 | while(len) { |
| 1325 | buffer_info = &tx_ring->buffer_info[i]; | 1331 | buffer_info = &tx_ring->buffer_info[i]; |
| 1326 | size = min(len, IXGB_MAX_DATA_PER_TXD); | 1332 | size = min(len, IXGB_MAX_DATA_PER_TXD); |
| 1333 | |||
| 1334 | /* Workaround for premature desc write-backs | ||
| 1335 | * in TSO mode. Append 4-byte sentinel desc */ | ||
| 1336 | if (unlikely(mss && !nr_frags && size == len | ||
| 1337 | && size > 8)) | ||
| 1338 | size -= 4; | ||
| 1339 | |||
| 1327 | buffer_info->length = size; | 1340 | buffer_info->length = size; |
| 1328 | buffer_info->dma = | 1341 | buffer_info->dma = |
| 1329 | pci_map_page(adapter->pdev, | 1342 | pci_map_page(adapter->pdev, |
| @@ -1398,11 +1411,43 @@ ixgb_tx_queue(struct ixgb_adapter *adapter, int count, int vlan_id,int tx_flags) | |||
| 1398 | IXGB_WRITE_REG(&adapter->hw, TDT, i); | 1411 | IXGB_WRITE_REG(&adapter->hw, TDT, i); |
| 1399 | } | 1412 | } |
| 1400 | 1413 | ||
| 1414 | static int __ixgb_maybe_stop_tx(struct net_device *netdev, int size) | ||
| 1415 | { | ||
| 1416 | struct ixgb_adapter *adapter = netdev_priv(netdev); | ||
| 1417 | struct ixgb_desc_ring *tx_ring = &adapter->tx_ring; | ||
| 1418 | |||
| 1419 | netif_stop_queue(netdev); | ||
| 1420 | /* Herbert's original patch had: | ||
| 1421 | * smp_mb__after_netif_stop_queue(); | ||
| 1422 | * but since that doesn't exist yet, just open code it. */ | ||
| 1423 | smp_mb(); | ||
| 1424 | |||
| 1425 | /* We need to check again in a case another CPU has just | ||
| 1426 | * made room available. */ | ||
| 1427 | if (likely(IXGB_DESC_UNUSED(tx_ring) < size)) | ||
| 1428 | return -EBUSY; | ||
| 1429 | |||
| 1430 | /* A reprieve! */ | ||
| 1431 | netif_start_queue(netdev); | ||
| 1432 | ++adapter->restart_queue; | ||
| 1433 | return 0; | ||
| 1434 | } | ||
| 1435 | |||
| 1436 | static int ixgb_maybe_stop_tx(struct net_device *netdev, | ||
| 1437 | struct ixgb_desc_ring *tx_ring, int size) | ||
| 1438 | { | ||
| 1439 | if (likely(IXGB_DESC_UNUSED(tx_ring) >= size)) | ||
| 1440 | return 0; | ||
| 1441 | return __ixgb_maybe_stop_tx(netdev, size); | ||
| 1442 | } | ||
| 1443 | |||
| 1444 | |||
| 1401 | /* Tx Descriptors needed, worst case */ | 1445 | /* Tx Descriptors needed, worst case */ |
| 1402 | #define TXD_USE_COUNT(S) (((S) >> IXGB_MAX_TXD_PWR) + \ | 1446 | #define TXD_USE_COUNT(S) (((S) >> IXGB_MAX_TXD_PWR) + \ |
| 1403 | (((S) & (IXGB_MAX_DATA_PER_TXD - 1)) ? 1 : 0)) | 1447 | (((S) & (IXGB_MAX_DATA_PER_TXD - 1)) ? 1 : 0)) |
| 1404 | #define DESC_NEEDED TXD_USE_COUNT(IXGB_MAX_DATA_PER_TXD) + \ | 1448 | #define DESC_NEEDED TXD_USE_COUNT(IXGB_MAX_DATA_PER_TXD) /* skb->date */ + \ |
| 1405 | MAX_SKB_FRAGS * TXD_USE_COUNT(PAGE_SIZE) + 1 | 1449 | MAX_SKB_FRAGS * TXD_USE_COUNT(PAGE_SIZE) + 1 /* for context */ \ |
| 1450 | + 1 /* one more needed for sentinel TSO workaround */ | ||
| 1406 | 1451 | ||
| 1407 | static int | 1452 | static int |
| 1408 | ixgb_xmit_frame(struct sk_buff *skb, struct net_device *netdev) | 1453 | ixgb_xmit_frame(struct sk_buff *skb, struct net_device *netdev) |
| @@ -1430,7 +1475,8 @@ ixgb_xmit_frame(struct sk_buff *skb, struct net_device *netdev) | |||
| 1430 | spin_lock_irqsave(&adapter->tx_lock, flags); | 1475 | spin_lock_irqsave(&adapter->tx_lock, flags); |
| 1431 | #endif | 1476 | #endif |
| 1432 | 1477 | ||
| 1433 | if(unlikely(IXGB_DESC_UNUSED(&adapter->tx_ring) < DESC_NEEDED)) { | 1478 | if (unlikely(ixgb_maybe_stop_tx(netdev, &adapter->tx_ring, |
| 1479 | DESC_NEEDED))) { | ||
| 1434 | netif_stop_queue(netdev); | 1480 | netif_stop_queue(netdev); |
| 1435 | spin_unlock_irqrestore(&adapter->tx_lock, flags); | 1481 | spin_unlock_irqrestore(&adapter->tx_lock, flags); |
| 1436 | return NETDEV_TX_BUSY; | 1482 | return NETDEV_TX_BUSY; |
| @@ -1468,8 +1514,7 @@ ixgb_xmit_frame(struct sk_buff *skb, struct net_device *netdev) | |||
| 1468 | 1514 | ||
| 1469 | #ifdef NETIF_F_LLTX | 1515 | #ifdef NETIF_F_LLTX |
| 1470 | /* Make sure there is space in the ring for the next send. */ | 1516 | /* Make sure there is space in the ring for the next send. */ |
| 1471 | if(unlikely(IXGB_DESC_UNUSED(&adapter->tx_ring) < DESC_NEEDED)) | 1517 | ixgb_maybe_stop_tx(netdev, &adapter->tx_ring, DESC_NEEDED); |
| 1472 | netif_stop_queue(netdev); | ||
| 1473 | 1518 | ||
| 1474 | spin_unlock_irqrestore(&adapter->tx_lock, flags); | 1519 | spin_unlock_irqrestore(&adapter->tx_lock, flags); |
| 1475 | 1520 | ||
diff --git a/drivers/net/pcmcia/pcnet_cs.c b/drivers/net/pcmcia/pcnet_cs.c index 2b1238e2dbdb..d88e9b2e93cf 100644 --- a/drivers/net/pcmcia/pcnet_cs.c +++ b/drivers/net/pcmcia/pcnet_cs.c | |||
| @@ -1617,6 +1617,7 @@ static struct pcmcia_device_id pcnet_ids[] = { | |||
| 1617 | PCMCIA_DEVICE_PROD_ID12("corega K.K.", "corega FastEther PCC-TX", 0x5261440f, 0x485e85d9), | 1617 | PCMCIA_DEVICE_PROD_ID12("corega K.K.", "corega FastEther PCC-TX", 0x5261440f, 0x485e85d9), |
| 1618 | PCMCIA_DEVICE_PROD_ID12("Corega,K.K.", "Ethernet LAN Card", 0x110d26d9, 0x9fd2f0a2), | 1618 | PCMCIA_DEVICE_PROD_ID12("Corega,K.K.", "Ethernet LAN Card", 0x110d26d9, 0x9fd2f0a2), |
| 1619 | PCMCIA_DEVICE_PROD_ID12("corega,K.K.", "Ethernet LAN Card", 0x9791a90e, 0x9fd2f0a2), | 1619 | PCMCIA_DEVICE_PROD_ID12("corega,K.K.", "Ethernet LAN Card", 0x9791a90e, 0x9fd2f0a2), |
| 1620 | PCMCIA_DEVICE_PROD_ID12("corega K.K.", "(CG-LAPCCTXD)", 0x5261440f, 0x73ec0d88), | ||
| 1620 | PCMCIA_DEVICE_PROD_ID12("CouplerlessPCMCIA", "100BASE", 0xee5af0ad, 0x7c2add04), | 1621 | PCMCIA_DEVICE_PROD_ID12("CouplerlessPCMCIA", "100BASE", 0xee5af0ad, 0x7c2add04), |
| 1621 | PCMCIA_DEVICE_PROD_ID12("CyQ've", "ELA-010", 0x77008979, 0x9d8d445d), | 1622 | PCMCIA_DEVICE_PROD_ID12("CyQ've", "ELA-010", 0x77008979, 0x9d8d445d), |
| 1622 | PCMCIA_DEVICE_PROD_ID12("CyQ've", "ELA-110E 10/100M LAN Card", 0x77008979, 0xfd184814), | 1623 | PCMCIA_DEVICE_PROD_ID12("CyQ've", "ELA-110E 10/100M LAN Card", 0x77008979, 0xfd184814), |
| @@ -1667,6 +1668,7 @@ static struct pcmcia_device_id pcnet_ids[] = { | |||
| 1667 | PCMCIA_DEVICE_PROD_ID12("Logitec", "LPM-LN100TX", 0x88fcdeda, 0x6d772737), | 1668 | PCMCIA_DEVICE_PROD_ID12("Logitec", "LPM-LN100TX", 0x88fcdeda, 0x6d772737), |
| 1668 | PCMCIA_DEVICE_PROD_ID12("Logitec", "LPM-LN100TE", 0x88fcdeda, 0x0e714bee), | 1669 | PCMCIA_DEVICE_PROD_ID12("Logitec", "LPM-LN100TE", 0x88fcdeda, 0x0e714bee), |
| 1669 | PCMCIA_DEVICE_PROD_ID12("Logitec", "LPM-LN20T", 0x88fcdeda, 0x81090922), | 1670 | PCMCIA_DEVICE_PROD_ID12("Logitec", "LPM-LN20T", 0x88fcdeda, 0x81090922), |
| 1671 | PCMCIA_DEVICE_PROD_ID12("Logitec", "LPM-LN10TE", 0x88fcdeda, 0xc1e2521c), | ||
| 1670 | PCMCIA_DEVICE_PROD_ID12("LONGSHINE", "PCMCIA Ethernet Card", 0xf866b0b0, 0x6f6652e0), | 1672 | PCMCIA_DEVICE_PROD_ID12("LONGSHINE", "PCMCIA Ethernet Card", 0xf866b0b0, 0x6f6652e0), |
| 1671 | PCMCIA_DEVICE_PROD_ID12("MACNICA", "ME1-JEIDA", 0x20841b68, 0xaf8a3578), | 1673 | PCMCIA_DEVICE_PROD_ID12("MACNICA", "ME1-JEIDA", 0x20841b68, 0xaf8a3578), |
| 1672 | PCMCIA_DEVICE_PROD_ID12("Macsense", "MPC-10", 0xd830297f, 0xd265c307), | 1674 | PCMCIA_DEVICE_PROD_ID12("Macsense", "MPC-10", 0xd830297f, 0xd265c307), |
diff --git a/drivers/net/qla3xxx.c b/drivers/net/qla3xxx.c index d79d141a601d..8844c20eac2d 100644 --- a/drivers/net/qla3xxx.c +++ b/drivers/net/qla3xxx.c | |||
| @@ -208,6 +208,15 @@ static void ql_write_common_reg(struct ql3_adapter *qdev, | |||
| 208 | return; | 208 | return; |
| 209 | } | 209 | } |
| 210 | 210 | ||
| 211 | static void ql_write_nvram_reg(struct ql3_adapter *qdev, | ||
| 212 | u32 __iomem *reg, u32 value) | ||
| 213 | { | ||
| 214 | writel(value, reg); | ||
| 215 | readl(reg); | ||
| 216 | udelay(1); | ||
| 217 | return; | ||
| 218 | } | ||
| 219 | |||
| 211 | static void ql_write_page0_reg(struct ql3_adapter *qdev, | 220 | static void ql_write_page0_reg(struct ql3_adapter *qdev, |
| 212 | u32 __iomem *reg, u32 value) | 221 | u32 __iomem *reg, u32 value) |
| 213 | { | 222 | { |
| @@ -336,9 +345,9 @@ static void fm93c56a_select(struct ql3_adapter *qdev) | |||
| 336 | qdev->mem_map_registers; | 345 | qdev->mem_map_registers; |
| 337 | 346 | ||
| 338 | qdev->eeprom_cmd_data = AUBURN_EEPROM_CS_1; | 347 | qdev->eeprom_cmd_data = AUBURN_EEPROM_CS_1; |
| 339 | ql_write_common_reg(qdev, &port_regs->CommonRegs.serialPortInterfaceReg, | 348 | ql_write_nvram_reg(qdev, &port_regs->CommonRegs.serialPortInterfaceReg, |
| 340 | ISP_NVRAM_MASK | qdev->eeprom_cmd_data); | 349 | ISP_NVRAM_MASK | qdev->eeprom_cmd_data); |
| 341 | ql_write_common_reg(qdev, &port_regs->CommonRegs.serialPortInterfaceReg, | 350 | ql_write_nvram_reg(qdev, &port_regs->CommonRegs.serialPortInterfaceReg, |
| 342 | ((ISP_NVRAM_MASK << 16) | qdev->eeprom_cmd_data)); | 351 | ((ISP_NVRAM_MASK << 16) | qdev->eeprom_cmd_data)); |
| 343 | } | 352 | } |
| 344 | 353 | ||
| @@ -355,14 +364,14 @@ static void fm93c56a_cmd(struct ql3_adapter *qdev, u32 cmd, u32 eepromAddr) | |||
| 355 | qdev->mem_map_registers; | 364 | qdev->mem_map_registers; |
| 356 | 365 | ||
| 357 | /* Clock in a zero, then do the start bit */ | 366 | /* Clock in a zero, then do the start bit */ |
| 358 | ql_write_common_reg(qdev, &port_regs->CommonRegs.serialPortInterfaceReg, | 367 | ql_write_nvram_reg(qdev, &port_regs->CommonRegs.serialPortInterfaceReg, |
| 359 | ISP_NVRAM_MASK | qdev->eeprom_cmd_data | | 368 | ISP_NVRAM_MASK | qdev->eeprom_cmd_data | |
| 360 | AUBURN_EEPROM_DO_1); | 369 | AUBURN_EEPROM_DO_1); |
| 361 | ql_write_common_reg(qdev, &port_regs->CommonRegs.serialPortInterfaceReg, | 370 | ql_write_nvram_reg(qdev, &port_regs->CommonRegs.serialPortInterfaceReg, |
| 362 | ISP_NVRAM_MASK | qdev-> | 371 | ISP_NVRAM_MASK | qdev-> |
| 363 | eeprom_cmd_data | AUBURN_EEPROM_DO_1 | | 372 | eeprom_cmd_data | AUBURN_EEPROM_DO_1 | |
| 364 | AUBURN_EEPROM_CLK_RISE); | 373 | AUBURN_EEPROM_CLK_RISE); |
| 365 | ql_write_common_reg(qdev, &port_regs->CommonRegs.serialPortInterfaceReg, | 374 | ql_write_nvram_reg(qdev, &port_regs->CommonRegs.serialPortInterfaceReg, |
| 366 | ISP_NVRAM_MASK | qdev-> | 375 | ISP_NVRAM_MASK | qdev-> |
| 367 | eeprom_cmd_data | AUBURN_EEPROM_DO_1 | | 376 | eeprom_cmd_data | AUBURN_EEPROM_DO_1 | |
| 368 | AUBURN_EEPROM_CLK_FALL); | 377 | AUBURN_EEPROM_CLK_FALL); |
| @@ -378,20 +387,20 @@ static void fm93c56a_cmd(struct ql3_adapter *qdev, u32 cmd, u32 eepromAddr) | |||
| 378 | * If the bit changed, then change the DO state to | 387 | * If the bit changed, then change the DO state to |
| 379 | * match | 388 | * match |
| 380 | */ | 389 | */ |
| 381 | ql_write_common_reg(qdev, | 390 | ql_write_nvram_reg(qdev, |
| 382 | &port_regs->CommonRegs. | 391 | &port_regs->CommonRegs. |
| 383 | serialPortInterfaceReg, | 392 | serialPortInterfaceReg, |
| 384 | ISP_NVRAM_MASK | qdev-> | 393 | ISP_NVRAM_MASK | qdev-> |
| 385 | eeprom_cmd_data | dataBit); | 394 | eeprom_cmd_data | dataBit); |
| 386 | previousBit = dataBit; | 395 | previousBit = dataBit; |
| 387 | } | 396 | } |
| 388 | ql_write_common_reg(qdev, | 397 | ql_write_nvram_reg(qdev, |
| 389 | &port_regs->CommonRegs. | 398 | &port_regs->CommonRegs. |
| 390 | serialPortInterfaceReg, | 399 | serialPortInterfaceReg, |
| 391 | ISP_NVRAM_MASK | qdev-> | 400 | ISP_NVRAM_MASK | qdev-> |
| 392 | eeprom_cmd_data | dataBit | | 401 | eeprom_cmd_data | dataBit | |
| 393 | AUBURN_EEPROM_CLK_RISE); | 402 | AUBURN_EEPROM_CLK_RISE); |
| 394 | ql_write_common_reg(qdev, | 403 | ql_write_nvram_reg(qdev, |
| 395 | &port_regs->CommonRegs. | 404 | &port_regs->CommonRegs. |
| 396 | serialPortInterfaceReg, | 405 | serialPortInterfaceReg, |
| 397 | ISP_NVRAM_MASK | qdev-> | 406 | ISP_NVRAM_MASK | qdev-> |
| @@ -412,20 +421,20 @@ static void fm93c56a_cmd(struct ql3_adapter *qdev, u32 cmd, u32 eepromAddr) | |||
| 412 | * If the bit changed, then change the DO state to | 421 | * If the bit changed, then change the DO state to |
| 413 | * match | 422 | * match |
| 414 | */ | 423 | */ |
| 415 | ql_write_common_reg(qdev, | 424 | ql_write_nvram_reg(qdev, |
| 416 | &port_regs->CommonRegs. | 425 | &port_regs->CommonRegs. |
| 417 | serialPortInterfaceReg, | 426 | serialPortInterfaceReg, |
| 418 | ISP_NVRAM_MASK | qdev-> | 427 | ISP_NVRAM_MASK | qdev-> |
| 419 | eeprom_cmd_data | dataBit); | 428 | eeprom_cmd_data | dataBit); |
| 420 | previousBit = dataBit; | 429 | previousBit = dataBit; |
| 421 | } | 430 | } |
| 422 | ql_write_common_reg(qdev, | 431 | ql_write_nvram_reg(qdev, |
| 423 | &port_regs->CommonRegs. | 432 | &port_regs->CommonRegs. |
| 424 | serialPortInterfaceReg, | 433 | serialPortInterfaceReg, |
| 425 | ISP_NVRAM_MASK | qdev-> | 434 | ISP_NVRAM_MASK | qdev-> |
| 426 | eeprom_cmd_data | dataBit | | 435 | eeprom_cmd_data | dataBit | |
| 427 | AUBURN_EEPROM_CLK_RISE); | 436 | AUBURN_EEPROM_CLK_RISE); |
| 428 | ql_write_common_reg(qdev, | 437 | ql_write_nvram_reg(qdev, |
| 429 | &port_regs->CommonRegs. | 438 | &port_regs->CommonRegs. |
| 430 | serialPortInterfaceReg, | 439 | serialPortInterfaceReg, |
| 431 | ISP_NVRAM_MASK | qdev-> | 440 | ISP_NVRAM_MASK | qdev-> |
| @@ -443,7 +452,7 @@ static void fm93c56a_deselect(struct ql3_adapter *qdev) | |||
| 443 | struct ql3xxx_port_registers __iomem *port_regs = | 452 | struct ql3xxx_port_registers __iomem *port_regs = |
| 444 | qdev->mem_map_registers; | 453 | qdev->mem_map_registers; |
| 445 | qdev->eeprom_cmd_data = AUBURN_EEPROM_CS_0; | 454 | qdev->eeprom_cmd_data = AUBURN_EEPROM_CS_0; |
| 446 | ql_write_common_reg(qdev, &port_regs->CommonRegs.serialPortInterfaceReg, | 455 | ql_write_nvram_reg(qdev, &port_regs->CommonRegs.serialPortInterfaceReg, |
| 447 | ISP_NVRAM_MASK | qdev->eeprom_cmd_data); | 456 | ISP_NVRAM_MASK | qdev->eeprom_cmd_data); |
| 448 | } | 457 | } |
| 449 | 458 | ||
| @@ -461,12 +470,12 @@ static void fm93c56a_datain(struct ql3_adapter *qdev, unsigned short *value) | |||
| 461 | /* Read the data bits */ | 470 | /* Read the data bits */ |
| 462 | /* The first bit is a dummy. Clock right over it. */ | 471 | /* The first bit is a dummy. Clock right over it. */ |
| 463 | for (i = 0; i < dataBits; i++) { | 472 | for (i = 0; i < dataBits; i++) { |
| 464 | ql_write_common_reg(qdev, | 473 | ql_write_nvram_reg(qdev, |
| 465 | &port_regs->CommonRegs. | 474 | &port_regs->CommonRegs. |
| 466 | serialPortInterfaceReg, | 475 | serialPortInterfaceReg, |
| 467 | ISP_NVRAM_MASK | qdev->eeprom_cmd_data | | 476 | ISP_NVRAM_MASK | qdev->eeprom_cmd_data | |
| 468 | AUBURN_EEPROM_CLK_RISE); | 477 | AUBURN_EEPROM_CLK_RISE); |
| 469 | ql_write_common_reg(qdev, | 478 | ql_write_nvram_reg(qdev, |
| 470 | &port_regs->CommonRegs. | 479 | &port_regs->CommonRegs. |
| 471 | serialPortInterfaceReg, | 480 | serialPortInterfaceReg, |
| 472 | ISP_NVRAM_MASK | qdev->eeprom_cmd_data | | 481 | ISP_NVRAM_MASK | qdev->eeprom_cmd_data | |
| @@ -3370,7 +3379,6 @@ static int __devinit ql3xxx_probe(struct pci_dev *pdev, | |||
| 3370 | SET_MODULE_OWNER(ndev); | 3379 | SET_MODULE_OWNER(ndev); |
| 3371 | SET_NETDEV_DEV(ndev, &pdev->dev); | 3380 | SET_NETDEV_DEV(ndev, &pdev->dev); |
| 3372 | 3381 | ||
| 3373 | ndev->features = NETIF_F_LLTX; | ||
| 3374 | if (pci_using_dac) | 3382 | if (pci_using_dac) |
| 3375 | ndev->features |= NETIF_F_HIGHDMA; | 3383 | ndev->features |= NETIF_F_HIGHDMA; |
| 3376 | 3384 | ||
diff --git a/drivers/net/wireless/ipw2100.c b/drivers/net/wireless/ipw2100.c index 0e94fbbf7a94..b85857a84870 100644 --- a/drivers/net/wireless/ipw2100.c +++ b/drivers/net/wireless/ipw2100.c | |||
| @@ -2664,7 +2664,7 @@ static void __ipw2100_rx_process(struct ipw2100_priv *priv) | |||
| 2664 | break; | 2664 | break; |
| 2665 | } | 2665 | } |
| 2666 | #endif | 2666 | #endif |
| 2667 | if (stats.len < sizeof(u->rx_data.header)) | 2667 | if (stats.len < sizeof(struct ieee80211_hdr_3addr)) |
| 2668 | break; | 2668 | break; |
| 2669 | switch (WLAN_FC_GET_TYPE(u->rx_data.header.frame_ctl)) { | 2669 | switch (WLAN_FC_GET_TYPE(u->rx_data.header.frame_ctl)) { |
| 2670 | case IEEE80211_FTYPE_MGMT: | 2670 | case IEEE80211_FTYPE_MGMT: |
