aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlan Cox <alan@linux.intel.com>2009-08-27 06:03:09 -0400
committerGreg Kroah-Hartman <gregkh@suse.de>2009-09-15 15:02:29 -0400
commit15700039b108fccc36507bcabdd4dda93f7c4c61 (patch)
tree31629674e011fb606072d89b913aa169cc689fbc
parentbc7f9c597fa55814548845a7c43f53d6bbbce94b (diff)
Staging: et131x: prune all the debug code
We don't need it, we have a perfectly good set of debug tools. For this pass keep a few debug printks around which are "should not happen" items Signed-off-by: Alan Cox <alan@linux.intel.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-rw-r--r--drivers/staging/et131x/Makefile1
-rw-r--r--drivers/staging/et131x/et1310_eeprom.c1
-rw-r--r--drivers/staging/et131x/et1310_mac.c64
-rw-r--r--drivers/staging/et131x/et1310_phy.c88
-rw-r--r--drivers/staging/et131x/et1310_pm.c14
-rw-r--r--drivers/staging/et131x/et1310_rx.c138
-rw-r--r--drivers/staging/et131x/et1310_tx.c592
-rw-r--r--drivers/staging/et131x/et131x_adapter.h7
-rw-r--r--drivers/staging/et131x/et131x_debug.c208
-rw-r--r--drivers/staging/et131x/et131x_debug.h255
-rw-r--r--drivers/staging/et131x/et131x_initpci.c236
-rw-r--r--drivers/staging/et131x/et131x_isr.c58
-rw-r--r--drivers/staging/et131x/et131x_netdev.c176
13 files changed, 117 insertions, 1721 deletions
diff --git a/drivers/staging/et131x/Makefile b/drivers/staging/et131x/Makefile
index 111049405cb3..95c645d8af39 100644
--- a/drivers/staging/et131x/Makefile
+++ b/drivers/staging/et131x/Makefile
@@ -10,7 +10,6 @@ et131x-objs := et1310_eeprom.o \
10 et1310_pm.o \ 10 et1310_pm.o \
11 et1310_rx.o \ 11 et1310_rx.o \
12 et1310_tx.o \ 12 et1310_tx.o \
13 et131x_debug.o \
14 et131x_initpci.o \ 13 et131x_initpci.o \
15 et131x_isr.o \ 14 et131x_isr.o \
16 et131x_netdev.o 15 et131x_netdev.o
diff --git a/drivers/staging/et131x/et1310_eeprom.c b/drivers/staging/et131x/et1310_eeprom.c
index 7b2e4ea2ad09..c853a2c243a8 100644
--- a/drivers/staging/et131x/et1310_eeprom.c
+++ b/drivers/staging/et131x/et1310_eeprom.c
@@ -56,7 +56,6 @@
56 */ 56 */
57 57
58#include "et131x_version.h" 58#include "et131x_version.h"
59#include "et131x_debug.h"
60#include "et131x_defs.h" 59#include "et131x_defs.h"
61 60
62#include <linux/pci.h> 61#include <linux/pci.h>
diff --git a/drivers/staging/et131x/et1310_mac.c b/drivers/staging/et131x/et1310_mac.c
index c94d66194ac0..f81e1cba8547 100644
--- a/drivers/staging/et131x/et1310_mac.c
+++ b/drivers/staging/et131x/et1310_mac.c
@@ -56,7 +56,6 @@
56 */ 56 */
57 57
58#include "et131x_version.h" 58#include "et131x_version.h"
59#include "et131x_debug.h"
60#include "et131x_defs.h" 59#include "et131x_defs.h"
61 60
62#include <linux/init.h> 61#include <linux/init.h>
@@ -75,6 +74,7 @@
75#include <linux/delay.h> 74#include <linux/delay.h>
76#include <linux/io.h> 75#include <linux/io.h>
77#include <linux/bitops.h> 76#include <linux/bitops.h>
77#include <linux/pci.h>
78#include <asm/system.h> 78#include <asm/system.h>
79 79
80#include <linux/netdevice.h> 80#include <linux/netdevice.h>
@@ -92,11 +92,6 @@
92#include "et131x_adapter.h" 92#include "et131x_adapter.h"
93#include "et131x_initpci.h" 93#include "et131x_initpci.h"
94 94
95/* Data for debugging facilities */
96#ifdef CONFIG_ET131X_DEBUG
97extern dbg_info_t *et131x_dbginfo;
98#endif /* CONFIG_ET131X_DEBUG */
99
100/** 95/**
101 * ConfigMacRegs1 - Initialize the first part of MAC regs 96 * ConfigMacRegs1 - Initialize the first part of MAC regs
102 * @pAdpater: pointer to our adapter structure 97 * @pAdpater: pointer to our adapter structure
@@ -110,8 +105,6 @@ void ConfigMACRegs1(struct et131x_adapter *etdev)
110 MAC_HFDP_t hfdp; 105 MAC_HFDP_t hfdp;
111 MII_MGMT_CFG_t mii_mgmt_cfg; 106 MII_MGMT_CFG_t mii_mgmt_cfg;
112 107
113 DBG_ENTER(et131x_dbginfo);
114
115 /* First we need to reset everything. Write to MAC configuration 108 /* First we need to reset everything. Write to MAC configuration
116 * register 1 to perform reset. 109 * register 1 to perform reset.
117 */ 110 */
@@ -171,8 +164,6 @@ void ConfigMACRegs1(struct et131x_adapter *etdev)
171 164
172 /* clear out MAC config reset */ 165 /* clear out MAC config reset */
173 writel(0, &pMac->cfg1.value); 166 writel(0, &pMac->cfg1.value);
174
175 DBG_LEAVE(et131x_dbginfo);
176} 167}
177 168
178/** 169/**
@@ -188,8 +179,6 @@ void ConfigMACRegs2(struct et131x_adapter *etdev)
188 MAC_IF_CTRL_t ifctrl; 179 MAC_IF_CTRL_t ifctrl;
189 TXMAC_CTL_t ctl; 180 TXMAC_CTL_t ctl;
190 181
191 DBG_ENTER(et131x_dbginfo);
192
193 ctl.value = readl(&etdev->regs->txmac.ctl.value); 182 ctl.value = readl(&etdev->regs->txmac.ctl.value);
194 cfg1.value = readl(&pMac->cfg1.value); 183 cfg1.value = readl(&pMac->cfg1.value);
195 cfg2.value = readl(&pMac->cfg2.value); 184 cfg2.value = readl(&pMac->cfg2.value);
@@ -255,17 +244,11 @@ void ConfigMACRegs2(struct et131x_adapter *etdev)
255 delay < 100); 244 delay < 100);
256 245
257 if (delay == 100) { 246 if (delay == 100) {
258 DBG_ERROR(et131x_dbginfo, 247 dev_warn(&etdev->pdev->dev,
259 "Syncd bits did not respond correctly cfg1 word 0x%08x\n", 248 "Syncd bits did not respond correctly cfg1 word 0x%08x\n",
260 cfg1.value); 249 cfg1.value);
261 } 250 }
262 251
263 DBG_TRACE(et131x_dbginfo,
264 "Speed %d, Dup %d, CFG1 0x%08x, CFG2 0x%08x, if_ctrl 0x%08x\n",
265 etdev->linkspeed, etdev->duplex_mode,
266 readl(&pMac->cfg1.value), readl(&pMac->cfg2.value),
267 readl(&pMac->if_ctrl.value));
268
269 /* Enable TXMAC */ 252 /* Enable TXMAC */
270 ctl.bits.txmac_en = 0x1; 253 ctl.bits.txmac_en = 0x1;
271 ctl.bits.fc_disable = 0x1; 254 ctl.bits.fc_disable = 0x1;
@@ -275,12 +258,7 @@ void ConfigMACRegs2(struct et131x_adapter *etdev)
275 if (etdev->Flags & fMP_ADAPTER_LOWER_POWER) { 258 if (etdev->Flags & fMP_ADAPTER_LOWER_POWER) {
276 et131x_rx_dma_enable(etdev); 259 et131x_rx_dma_enable(etdev);
277 et131x_tx_dma_enable(etdev); 260 et131x_tx_dma_enable(etdev);
278 } else {
279 DBG_WARNING(et131x_dbginfo,
280 "Didn't enable Rx/Tx due to low-power mode\n");
281 } 261 }
282
283 DBG_LEAVE(et131x_dbginfo);
284} 262}
285 263
286void ConfigRxMacRegs(struct et131x_adapter *etdev) 264void ConfigRxMacRegs(struct et131x_adapter *etdev)
@@ -290,8 +268,6 @@ void ConfigRxMacRegs(struct et131x_adapter *etdev)
290 RXMAC_WOL_SA_HI_t sa_hi; 268 RXMAC_WOL_SA_HI_t sa_hi;
291 RXMAC_PF_CTRL_t pf_ctrl = { 0 }; 269 RXMAC_PF_CTRL_t pf_ctrl = { 0 };
292 270
293 DBG_ENTER(et131x_dbginfo);
294
295 /* Disable the MAC while it is being configured (also disable WOL) */ 271 /* Disable the MAC while it is being configured (also disable WOL) */
296 writel(0x8, &pRxMac->ctrl.value); 272 writel(0x8, &pRxMac->ctrl.value);
297 273
@@ -421,8 +397,6 @@ void ConfigRxMacRegs(struct et131x_adapter *etdev)
421 */ 397 */
422 writel(pf_ctrl.value, &pRxMac->pf_ctrl.value); 398 writel(pf_ctrl.value, &pRxMac->pf_ctrl.value);
423 writel(0x9, &pRxMac->ctrl.value); 399 writel(0x9, &pRxMac->ctrl.value);
424
425 DBG_LEAVE(et131x_dbginfo);
426} 400}
427 401
428void ConfigTxMacRegs(struct et131x_adapter *etdev) 402void ConfigTxMacRegs(struct et131x_adapter *etdev)
@@ -430,8 +404,6 @@ void ConfigTxMacRegs(struct et131x_adapter *etdev)
430 struct _TXMAC_t __iomem *pTxMac = &etdev->regs->txmac; 404 struct _TXMAC_t __iomem *pTxMac = &etdev->regs->txmac;
431 TXMAC_CF_PARAM_t Local; 405 TXMAC_CF_PARAM_t Local;
432 406
433 DBG_ENTER(et131x_dbginfo);
434
435 /* We need to update the Control Frame Parameters 407 /* We need to update the Control Frame Parameters
436 * cfpt - control frame pause timer set to 64 (0x40) 408 * cfpt - control frame pause timer set to 64 (0x40)
437 * cfep - control frame extended pause timer set to 0x0 409 * cfep - control frame extended pause timer set to 0x0
@@ -443,8 +415,6 @@ void ConfigTxMacRegs(struct et131x_adapter *etdev)
443 Local.bits.cfep = 0x0; 415 Local.bits.cfep = 0x0;
444 writel(Local.value, &pTxMac->cf_param.value); 416 writel(Local.value, &pTxMac->cf_param.value);
445 } 417 }
446
447 DBG_LEAVE(et131x_dbginfo);
448} 418}
449 419
450void ConfigMacStatRegs(struct et131x_adapter *etdev) 420void ConfigMacStatRegs(struct et131x_adapter *etdev)
@@ -452,8 +422,6 @@ void ConfigMacStatRegs(struct et131x_adapter *etdev)
452 struct _MAC_STAT_t __iomem *pDevMacStat = 422 struct _MAC_STAT_t __iomem *pDevMacStat =
453 &etdev->regs->macStat; 423 &etdev->regs->macStat;
454 424
455 DBG_ENTER(et131x_dbginfo);
456
457 /* Next we need to initialize all the MAC_STAT registers to zero on 425 /* Next we need to initialize all the MAC_STAT registers to zero on
458 * the device. 426 * the device.
459 */ 427 */
@@ -534,8 +502,6 @@ void ConfigMacStatRegs(struct et131x_adapter *etdev)
534 502
535 writel(Carry2M.value, &pDevMacStat->Carry2M.value); 503 writel(Carry2M.value, &pDevMacStat->Carry2M.value);
536 } 504 }
537
538 DBG_LEAVE(et131x_dbginfo);
539} 505}
540 506
541void ConfigFlowControl(struct et131x_adapter *etdev) 507void ConfigFlowControl(struct et131x_adapter *etdev)
@@ -614,8 +580,6 @@ void HandleMacStatInterrupt(struct et131x_adapter *etdev)
614 MAC_STAT_REG_1_t Carry1; 580 MAC_STAT_REG_1_t Carry1;
615 MAC_STAT_REG_2_t Carry2; 581 MAC_STAT_REG_2_t Carry2;
616 582
617 DBG_ENTER(et131x_dbginfo);
618
619 /* Read the interrupt bits from the register(s). These are Clear On 583 /* Read the interrupt bits from the register(s). These are Clear On
620 * Write. 584 * Write.
621 */ 585 */
@@ -659,8 +623,6 @@ void HandleMacStatInterrupt(struct et131x_adapter *etdev)
659 etdev->Stats.late_collisions += COUNTER_WRAP_12_BIT; 623 etdev->Stats.late_collisions += COUNTER_WRAP_12_BIT;
660 if (Carry2.bits.tncl) 624 if (Carry2.bits.tncl)
661 etdev->Stats.collisions += COUNTER_WRAP_12_BIT; 625 etdev->Stats.collisions += COUNTER_WRAP_12_BIT;
662
663 DBG_LEAVE(et131x_dbginfo);
664} 626}
665 627
666void SetupDeviceForMulticast(struct et131x_adapter *etdev) 628void SetupDeviceForMulticast(struct et131x_adapter *etdev)
@@ -674,30 +636,14 @@ void SetupDeviceForMulticast(struct et131x_adapter *etdev)
674 uint32_t hash4 = 0; 636 uint32_t hash4 = 0;
675 u32 pm_csr; 637 u32 pm_csr;
676 638
677 DBG_ENTER(et131x_dbginfo);
678
679 /* If ET131X_PACKET_TYPE_MULTICAST is specified, then we provision 639 /* If ET131X_PACKET_TYPE_MULTICAST is specified, then we provision
680 * the multi-cast LIST. If it is NOT specified, (and "ALL" is not 640 * the multi-cast LIST. If it is NOT specified, (and "ALL" is not
681 * specified) then we should pass NO multi-cast addresses to the 641 * specified) then we should pass NO multi-cast addresses to the
682 * driver. 642 * driver.
683 */ 643 */
684 if (etdev->PacketFilter & ET131X_PACKET_TYPE_MULTICAST) { 644 if (etdev->PacketFilter & ET131X_PACKET_TYPE_MULTICAST) {
685 DBG_VERBOSE(et131x_dbginfo,
686 "MULTICAST flag is set, MCCount: %d\n",
687 etdev->MCAddressCount);
688
689 /* Loop through our multicast array and set up the device */ 645 /* Loop through our multicast array and set up the device */
690 for (nIndex = 0; nIndex < etdev->MCAddressCount; nIndex++) { 646 for (nIndex = 0; nIndex < etdev->MCAddressCount; nIndex++) {
691 DBG_VERBOSE(et131x_dbginfo,
692 "MCList[%d]: %02x:%02x:%02x:%02x:%02x:%02x\n",
693 nIndex,
694 etdev->MCList[nIndex][0],
695 etdev->MCList[nIndex][1],
696 etdev->MCList[nIndex][2],
697 etdev->MCList[nIndex][3],
698 etdev->MCList[nIndex][4],
699 etdev->MCList[nIndex][5]);
700
701 result = ether_crc(6, etdev->MCList[nIndex]); 647 result = ether_crc(6, etdev->MCList[nIndex]);
702 648
703 result = (result & 0x3F800000) >> 23; 649 result = (result & 0x3F800000) >> 23;
@@ -725,8 +671,6 @@ void SetupDeviceForMulticast(struct et131x_adapter *etdev)
725 writel(hash3, &rxmac->multi_hash3); 671 writel(hash3, &rxmac->multi_hash3);
726 writel(hash4, &rxmac->multi_hash4); 672 writel(hash4, &rxmac->multi_hash4);
727 } 673 }
728
729 DBG_LEAVE(et131x_dbginfo);
730} 674}
731 675
732void SetupDeviceForUnicast(struct et131x_adapter *etdev) 676void SetupDeviceForUnicast(struct et131x_adapter *etdev)
@@ -737,8 +681,6 @@ void SetupDeviceForUnicast(struct et131x_adapter *etdev)
737 RXMAC_UNI_PF_ADDR3_t uni_pf3; 681 RXMAC_UNI_PF_ADDR3_t uni_pf3;
738 u32 pm_csr; 682 u32 pm_csr;
739 683
740 DBG_ENTER(et131x_dbginfo);
741
742 /* Set up unicast packet filter reg 3 to be the first two octets of 684 /* Set up unicast packet filter reg 3 to be the first two octets of
743 * the MAC address for both address 685 * the MAC address for both address
744 * 686 *
@@ -769,6 +711,4 @@ void SetupDeviceForUnicast(struct et131x_adapter *etdev)
769 writel(uni_pf2.value, &rxmac->uni_pf_addr2.value); 711 writel(uni_pf2.value, &rxmac->uni_pf_addr2.value);
770 writel(uni_pf3.value, &rxmac->uni_pf_addr3.value); 712 writel(uni_pf3.value, &rxmac->uni_pf_addr3.value);
771 } 713 }
772
773 DBG_LEAVE(et131x_dbginfo);
774} 714}
diff --git a/drivers/staging/et131x/et1310_phy.c b/drivers/staging/et131x/et1310_phy.c
index 98055e6b316c..dd199bdb9eff 100644
--- a/drivers/staging/et131x/et1310_phy.c
+++ b/drivers/staging/et131x/et1310_phy.c
@@ -56,7 +56,6 @@
56 */ 56 */
57 57
58#include "et131x_version.h" 58#include "et131x_version.h"
59#include "et131x_debug.h"
60#include "et131x_defs.h" 59#include "et131x_defs.h"
61 60
62#include <linux/pci.h> 61#include <linux/pci.h>
@@ -98,11 +97,6 @@
98#include "et1310_rx.h" 97#include "et1310_rx.h"
99#include "et1310_mac.h" 98#include "et1310_mac.h"
100 99
101/* Data for debugging facilities */
102#ifdef CONFIG_ET131X_DEBUG
103extern dbg_info_t *et131x_dbginfo;
104#endif /* CONFIG_ET131X_DEBUG */
105
106/* Prototypes for functions with local scope */ 100/* Prototypes for functions with local scope */
107static int et131x_xcvr_init(struct et131x_adapter *adapter); 101static int et131x_xcvr_init(struct et131x_adapter *adapter);
108 102
@@ -157,9 +151,9 @@ int PhyMiRead(struct et131x_adapter *adapter, uint8_t xcvrAddr,
157 151
158 /* If we hit the max delay, we could not read the register */ 152 /* If we hit the max delay, we could not read the register */
159 if (delay >= 50) { 153 if (delay >= 50) {
160 DBG_WARNING(et131x_dbginfo, 154 dev_warn(&adapter->pdev->dev,
161 "xcvrReg 0x%08x could not be read\n", xcvrReg); 155 "xcvrReg 0x%08x could not be read\n", xcvrReg);
162 DBG_WARNING(et131x_dbginfo, "status is 0x%08x\n", 156 dev_warn(&adapter->pdev->dev, "status is 0x%08x\n",
163 miiIndicator.value); 157 miiIndicator.value);
164 158
165 status = -EIO; 159 status = -EIO;
@@ -179,10 +173,6 @@ int PhyMiRead(struct et131x_adapter *adapter, uint8_t xcvrAddr,
179 /* Stop the read operation */ 173 /* Stop the read operation */
180 writel(0, &mac->mii_mgmt_cmd.value); 174 writel(0, &mac->mii_mgmt_cmd.value);
181 175
182 DBG_VERBOSE(et131x_dbginfo, " xcvr_addr = 0x%02x, "
183 "xcvr_reg = 0x%02x, "
184 "value = 0x%04x.\n", xcvrAddr, xcvrReg, *value);
185
186 /* set the registers we touched back to the state at which we entered 176 /* set the registers we touched back to the state at which we entered
187 * this function 177 * this function
188 */ 178 */
@@ -242,11 +232,11 @@ int MiWrite(struct et131x_adapter *adapter, uint8_t xcvrReg, uint16_t value)
242 if (delay == 100) { 232 if (delay == 100) {
243 uint16_t TempValue; 233 uint16_t TempValue;
244 234
245 DBG_WARNING(et131x_dbginfo, 235 dev_warn(&adapter->pdev->dev,
246 "xcvrReg 0x%08x could not be written", xcvrReg); 236 "xcvrReg 0x%08x could not be written", xcvrReg);
247 DBG_WARNING(et131x_dbginfo, "status is 0x%08x\n", 237 dev_warn(&adapter->pdev->dev, "status is 0x%08x\n",
248 miiIndicator.value); 238 miiIndicator.value);
249 DBG_WARNING(et131x_dbginfo, "command is 0x%08x\n", 239 dev_warn(&adapter->pdev->dev, "command is 0x%08x\n",
250 readl(&mac->mii_mgmt_cmd.value)); 240 readl(&mac->mii_mgmt_cmd.value));
251 241
252 MiRead(adapter, xcvrReg, &TempValue); 242 MiRead(adapter, xcvrReg, &TempValue);
@@ -263,10 +253,6 @@ int MiWrite(struct et131x_adapter *adapter, uint8_t xcvrReg, uint16_t value)
263 writel(miiAddr.value, &mac->mii_mgmt_addr.value); 253 writel(miiAddr.value, &mac->mii_mgmt_addr.value);
264 writel(miiCmd.value, &mac->mii_mgmt_cmd.value); 254 writel(miiCmd.value, &mac->mii_mgmt_cmd.value);
265 255
266 DBG_VERBOSE(et131x_dbginfo, " xcvr_addr = 0x%02x, "
267 "xcvr_reg = 0x%02x, "
268 "value = 0x%04x.\n", xcvrAddr, xcvrReg, value);
269
270 return status; 256 return status;
271} 257}
272 258
@@ -284,8 +270,6 @@ int et131x_xcvr_find(struct et131x_adapter *adapter)
284 MI_IDR2_t idr2; 270 MI_IDR2_t idr2;
285 uint32_t xcvr_id; 271 uint32_t xcvr_id;
286 272
287 DBG_ENTER(et131x_dbginfo);
288
289 /* We need to get xcvr id and address we just get the first one */ 273 /* We need to get xcvr id and address we just get the first one */
290 for (xcvr_addr = 0; xcvr_addr < 32; xcvr_addr++) { 274 for (xcvr_addr = 0; xcvr_addr < 32; xcvr_addr++) {
291 /* Read the ID from the PHY */ 275 /* Read the ID from the PHY */
@@ -299,10 +283,6 @@ int et131x_xcvr_find(struct et131x_adapter *adapter)
299 xcvr_id = (uint32_t) ((idr1.value << 16) | idr2.value); 283 xcvr_id = (uint32_t) ((idr1.value << 16) | idr2.value);
300 284
301 if ((idr1.value != 0) && (idr1.value != 0xffff)) { 285 if ((idr1.value != 0) && (idr1.value != 0xffff)) {
302 DBG_TRACE(et131x_dbginfo,
303 "Xcvr addr: 0x%02x\tXcvr_id: 0x%08x\n",
304 xcvr_addr, xcvr_id);
305
306 adapter->Stats.xcvr_id = xcvr_id; 286 adapter->Stats.xcvr_id = xcvr_id;
307 adapter->Stats.xcvr_addr = xcvr_addr; 287 adapter->Stats.xcvr_addr = xcvr_addr;
308 288
@@ -310,8 +290,6 @@ int et131x_xcvr_find(struct et131x_adapter *adapter)
310 break; 290 break;
311 } 291 }
312 } 292 }
313
314 DBG_LEAVE(et131x_dbginfo);
315 return status; 293 return status;
316} 294}
317 295
@@ -327,13 +305,9 @@ int et131x_setphy_normal(struct et131x_adapter *adapter)
327{ 305{
328 int status; 306 int status;
329 307
330 DBG_ENTER(et131x_dbginfo);
331
332 /* Make sure the PHY is powered up */ 308 /* Make sure the PHY is powered up */
333 ET1310_PhyPowerDown(adapter, 0); 309 ET1310_PhyPowerDown(adapter, 0);
334 status = et131x_xcvr_init(adapter); 310 status = et131x_xcvr_init(adapter);
335
336 DBG_LEAVE(et131x_dbginfo);
337 return status; 311 return status;
338} 312}
339 313
@@ -350,8 +324,6 @@ static int et131x_xcvr_init(struct et131x_adapter *adapter)
350 MI_ISR_t isr; 324 MI_ISR_t isr;
351 MI_LCR2_t lcr2; 325 MI_LCR2_t lcr2;
352 326
353 DBG_ENTER(et131x_dbginfo);
354
355 /* Zero out the adapter structure variable representing BMSR */ 327 /* Zero out the adapter structure variable representing BMSR */
356 adapter->Bmsr.value = 0; 328 adapter->Bmsr.value = 0;
357 329
@@ -412,8 +384,6 @@ static int et131x_xcvr_init(struct et131x_adapter *adapter)
412 384
413 /* NOTE - Do we need this? */ 385 /* NOTE - Do we need this? */
414 ET1310_PhyAccessMiBit(adapter, TRUEPHY_BIT_SET, 0, 9, NULL); 386 ET1310_PhyAccessMiBit(adapter, TRUEPHY_BIT_SET, 0, 9, NULL);
415
416 DBG_LEAVE(et131x_dbginfo);
417 return status; 387 return status;
418 } else { 388 } else {
419 ET1310_PhyAutoNeg(adapter, false); 389 ET1310_PhyAutoNeg(adapter, false);
@@ -469,7 +439,6 @@ static int et131x_xcvr_init(struct et131x_adapter *adapter)
469 break; 439 break;
470 } 440 }
471 441
472 DBG_LEAVE(et131x_dbginfo);
473 return status; 442 return status;
474 } 443 }
475} 444}
@@ -486,8 +455,6 @@ void et131x_Mii_check(struct et131x_adapter *etdev,
486 uint32_t polarity; 455 uint32_t polarity;
487 unsigned long flags; 456 unsigned long flags;
488 457
489 DBG_ENTER(et131x_dbginfo);
490
491 if (bmsr_ints.bits.link_status) { 458 if (bmsr_ints.bits.link_status) {
492 if (bmsr.bits.link_status) { 459 if (bmsr.bits.link_status) {
493 etdev->PoMgmt.TransPhyComaModeOnBoot = 20; 460 etdev->PoMgmt.TransPhyComaModeOnBoot = 20;
@@ -506,8 +473,8 @@ void et131x_Mii_check(struct et131x_adapter *etdev,
506 if (etdev->RegistryPhyLoopbk == false) 473 if (etdev->RegistryPhyLoopbk == false)
507 netif_carrier_on(etdev->netdev); 474 netif_carrier_on(etdev->netdev);
508 } else { 475 } else {
509 DBG_WARNING(et131x_dbginfo, 476 dev_warn(&etdev->pdev->dev,
510 "Link down cable problem\n"); 477 "Link down - cable problem ?\n");
511 478
512 if (etdev->linkspeed == TRUEPHY_SPEED_10MBPS) { 479 if (etdev->linkspeed == TRUEPHY_SPEED_10MBPS) {
513 /* NOTE - Is there a way to query this without 480 /* NOTE - Is there a way to query this without
@@ -586,11 +553,6 @@ void et131x_Mii_check(struct et131x_adapter *etdev,
586 etdev->linkspeed = speed; 553 etdev->linkspeed = speed;
587 etdev->duplex_mode = duplex; 554 etdev->duplex_mode = duplex;
588 555
589 DBG_TRACE(et131x_dbginfo,
590 "etdev->linkspeed 0x%04x, etdev->duplex_mode 0x%08x\n",
591 etdev->linkspeed,
592 etdev->duplex_mode);
593
594 etdev->PoMgmt.TransPhyComaModeOnBoot = 20; 556 etdev->PoMgmt.TransPhyComaModeOnBoot = 20;
595 557
596 if (etdev->linkspeed == TRUEPHY_SPEED_10MBPS) { 558 if (etdev->linkspeed == TRUEPHY_SPEED_10MBPS) {
@@ -619,8 +581,6 @@ void et131x_Mii_check(struct et131x_adapter *etdev,
619 ConfigMACRegs2(etdev); 581 ConfigMACRegs2(etdev);
620 } 582 }
621 } 583 }
622
623 DBG_LEAVE(et131x_dbginfo);
624} 584}
625 585
626/** 586/**
@@ -631,8 +591,6 @@ void et131x_Mii_check(struct et131x_adapter *etdev,
631 */ 591 */
632void TPAL_SetPhy10HalfDuplex(struct et131x_adapter *etdev) 592void TPAL_SetPhy10HalfDuplex(struct et131x_adapter *etdev)
633{ 593{
634 DBG_ENTER(et131x_dbginfo);
635
636 /* Power down PHY */ 594 /* Power down PHY */
637 ET1310_PhyPowerDown(etdev, 1); 595 ET1310_PhyPowerDown(etdev, 1);
638 596
@@ -646,8 +604,6 @@ void TPAL_SetPhy10HalfDuplex(struct et131x_adapter *etdev)
646 604
647 /* Power up PHY */ 605 /* Power up PHY */
648 ET1310_PhyPowerDown(etdev, 0); 606 ET1310_PhyPowerDown(etdev, 0);
649
650 DBG_LEAVE(et131x_dbginfo);
651} 607}
652 608
653/** 609/**
@@ -658,8 +614,6 @@ void TPAL_SetPhy10HalfDuplex(struct et131x_adapter *etdev)
658 */ 614 */
659void TPAL_SetPhy10FullDuplex(struct et131x_adapter *etdev) 615void TPAL_SetPhy10FullDuplex(struct et131x_adapter *etdev)
660{ 616{
661 DBG_ENTER(et131x_dbginfo);
662
663 /* Power down PHY */ 617 /* Power down PHY */
664 ET1310_PhyPowerDown(etdev, 1); 618 ET1310_PhyPowerDown(etdev, 1);
665 619
@@ -673,8 +627,6 @@ void TPAL_SetPhy10FullDuplex(struct et131x_adapter *etdev)
673 627
674 /* Power up PHY */ 628 /* Power up PHY */
675 ET1310_PhyPowerDown(etdev, 0); 629 ET1310_PhyPowerDown(etdev, 0);
676
677 DBG_LEAVE(et131x_dbginfo);
678} 630}
679 631
680/** 632/**
@@ -683,8 +635,6 @@ void TPAL_SetPhy10FullDuplex(struct et131x_adapter *etdev)
683 */ 635 */
684void TPAL_SetPhy10Force(struct et131x_adapter *etdev) 636void TPAL_SetPhy10Force(struct et131x_adapter *etdev)
685{ 637{
686 DBG_ENTER(et131x_dbginfo);
687
688 /* Power down PHY */ 638 /* Power down PHY */
689 ET1310_PhyPowerDown(etdev, 1); 639 ET1310_PhyPowerDown(etdev, 1);
690 640
@@ -704,8 +654,6 @@ void TPAL_SetPhy10Force(struct et131x_adapter *etdev)
704 654
705 /* Power up PHY */ 655 /* Power up PHY */
706 ET1310_PhyPowerDown(etdev, 0); 656 ET1310_PhyPowerDown(etdev, 0);
707
708 DBG_LEAVE(et131x_dbginfo);
709} 657}
710 658
711/** 659/**
@@ -716,8 +664,6 @@ void TPAL_SetPhy10Force(struct et131x_adapter *etdev)
716 */ 664 */
717void TPAL_SetPhy100HalfDuplex(struct et131x_adapter *etdev) 665void TPAL_SetPhy100HalfDuplex(struct et131x_adapter *etdev)
718{ 666{
719 DBG_ENTER(et131x_dbginfo);
720
721 /* Power down PHY */ 667 /* Power down PHY */
722 ET1310_PhyPowerDown(etdev, 1); 668 ET1310_PhyPowerDown(etdev, 1);
723 669
@@ -734,8 +680,6 @@ void TPAL_SetPhy100HalfDuplex(struct et131x_adapter *etdev)
734 680
735 /* Power up PHY */ 681 /* Power up PHY */
736 ET1310_PhyPowerDown(etdev, 0); 682 ET1310_PhyPowerDown(etdev, 0);
737
738 DBG_LEAVE(et131x_dbginfo);
739} 683}
740 684
741/** 685/**
@@ -746,8 +690,6 @@ void TPAL_SetPhy100HalfDuplex(struct et131x_adapter *etdev)
746 */ 690 */
747void TPAL_SetPhy100FullDuplex(struct et131x_adapter *etdev) 691void TPAL_SetPhy100FullDuplex(struct et131x_adapter *etdev)
748{ 692{
749 DBG_ENTER(et131x_dbginfo);
750
751 /* Power down PHY */ 693 /* Power down PHY */
752 ET1310_PhyPowerDown(etdev, 1); 694 ET1310_PhyPowerDown(etdev, 1);
753 695
@@ -761,8 +703,6 @@ void TPAL_SetPhy100FullDuplex(struct et131x_adapter *etdev)
761 703
762 /* Power up PHY */ 704 /* Power up PHY */
763 ET1310_PhyPowerDown(etdev, 0); 705 ET1310_PhyPowerDown(etdev, 0);
764
765 DBG_LEAVE(et131x_dbginfo);
766} 706}
767 707
768/** 708/**
@@ -771,8 +711,6 @@ void TPAL_SetPhy100FullDuplex(struct et131x_adapter *etdev)
771 */ 711 */
772void TPAL_SetPhy100Force(struct et131x_adapter *etdev) 712void TPAL_SetPhy100Force(struct et131x_adapter *etdev)
773{ 713{
774 DBG_ENTER(et131x_dbginfo);
775
776 /* Power down PHY */ 714 /* Power down PHY */
777 ET1310_PhyPowerDown(etdev, 1); 715 ET1310_PhyPowerDown(etdev, 1);
778 716
@@ -792,8 +730,6 @@ void TPAL_SetPhy100Force(struct et131x_adapter *etdev)
792 730
793 /* Power up PHY */ 731 /* Power up PHY */
794 ET1310_PhyPowerDown(etdev, 0); 732 ET1310_PhyPowerDown(etdev, 0);
795
796 DBG_LEAVE(et131x_dbginfo);
797} 733}
798 734
799/** 735/**
@@ -804,8 +740,6 @@ void TPAL_SetPhy100Force(struct et131x_adapter *etdev)
804 */ 740 */
805void TPAL_SetPhy1000FullDuplex(struct et131x_adapter *etdev) 741void TPAL_SetPhy1000FullDuplex(struct et131x_adapter *etdev)
806{ 742{
807 DBG_ENTER(et131x_dbginfo);
808
809 /* Power down PHY */ 743 /* Power down PHY */
810 ET1310_PhyPowerDown(etdev, 1); 744 ET1310_PhyPowerDown(etdev, 1);
811 745
@@ -819,8 +753,6 @@ void TPAL_SetPhy1000FullDuplex(struct et131x_adapter *etdev)
819 753
820 /* power up PHY */ 754 /* power up PHY */
821 ET1310_PhyPowerDown(etdev, 0); 755 ET1310_PhyPowerDown(etdev, 0);
822
823 DBG_LEAVE(et131x_dbginfo);
824} 756}
825 757
826/** 758/**
@@ -829,8 +761,6 @@ void TPAL_SetPhy1000FullDuplex(struct et131x_adapter *etdev)
829 */ 761 */
830void TPAL_SetPhyAutoNeg(struct et131x_adapter *etdev) 762void TPAL_SetPhyAutoNeg(struct et131x_adapter *etdev)
831{ 763{
832 DBG_ENTER(et131x_dbginfo);
833
834 /* Power down PHY */ 764 /* Power down PHY */
835 ET1310_PhyPowerDown(etdev, 1); 765 ET1310_PhyPowerDown(etdev, 1);
836 766
@@ -849,8 +779,6 @@ void TPAL_SetPhyAutoNeg(struct et131x_adapter *etdev)
849 779
850 /* Power up PHY */ 780 /* Power up PHY */
851 ET1310_PhyPowerDown(etdev, 0); 781 ET1310_PhyPowerDown(etdev, 0);
852
853 DBG_LEAVE(et131x_dbginfo);
854} 782}
855 783
856 784
diff --git a/drivers/staging/et131x/et1310_pm.c b/drivers/staging/et131x/et1310_pm.c
index f4c942c7b881..7d0772359291 100644
--- a/drivers/staging/et131x/et1310_pm.c
+++ b/drivers/staging/et131x/et1310_pm.c
@@ -56,7 +56,6 @@
56 */ 56 */
57 57
58#include "et131x_version.h" 58#include "et131x_version.h"
59#include "et131x_debug.h"
60#include "et131x_defs.h" 59#include "et131x_defs.h"
61 60
62#include <linux/init.h> 61#include <linux/init.h>
@@ -92,11 +91,6 @@
92#include "et131x_adapter.h" 91#include "et131x_adapter.h"
93#include "et131x_initpci.h" 92#include "et131x_initpci.h"
94 93
95/* Data for debugging facilities */
96#ifdef CONFIG_ET131X_DEBUG
97extern dbg_info_t *et131x_dbginfo;
98#endif /* CONFIG_ET131X_DEBUG */
99
100/** 94/**
101 * EnablePhyComa - called when network cable is unplugged 95 * EnablePhyComa - called when network cable is unplugged
102 * @etdev: pointer to our adapter structure 96 * @etdev: pointer to our adapter structure
@@ -122,8 +116,6 @@ void EnablePhyComa(struct et131x_adapter *etdev)
122 unsigned long flags; 116 unsigned long flags;
123 u32 GlobalPmCSR; 117 u32 GlobalPmCSR;
124 118
125 DBG_ENTER(et131x_dbginfo);
126
127 GlobalPmCSR = readl(&etdev->regs->global.pm_csr); 119 GlobalPmCSR = readl(&etdev->regs->global.pm_csr);
128 120
129 /* Save the GbE PHY speed and duplex modes. Need to restore this 121 /* Save the GbE PHY speed and duplex modes. Need to restore this
@@ -146,8 +138,6 @@ void EnablePhyComa(struct et131x_adapter *etdev)
146 /* Program gigE PHY in to Coma mode */ 138 /* Program gigE PHY in to Coma mode */
147 GlobalPmCSR |= ET_PM_PHY_SW_COMA; 139 GlobalPmCSR |= ET_PM_PHY_SW_COMA;
148 writel(GlobalPmCSR, &etdev->regs->global.pm_csr); 140 writel(GlobalPmCSR, &etdev->regs->global.pm_csr);
149
150 DBG_LEAVE(et131x_dbginfo);
151} 141}
152 142
153/** 143/**
@@ -158,8 +148,6 @@ void DisablePhyComa(struct et131x_adapter *etdev)
158{ 148{
159 u32 GlobalPmCSR; 149 u32 GlobalPmCSR;
160 150
161 DBG_ENTER(et131x_dbginfo);
162
163 GlobalPmCSR = readl(&etdev->regs->global.pm_csr); 151 GlobalPmCSR = readl(&etdev->regs->global.pm_csr);
164 152
165 /* Disable phy_sw_coma register and re-enable JAGCore clocks */ 153 /* Disable phy_sw_coma register and re-enable JAGCore clocks */
@@ -193,7 +181,5 @@ void DisablePhyComa(struct et131x_adapter *etdev)
193 181
194 /* Need to re-enable Rx. */ 182 /* Need to re-enable Rx. */
195 et131x_rx_dma_enable(etdev); 183 et131x_rx_dma_enable(etdev);
196
197 DBG_LEAVE(et131x_dbginfo);
198} 184}
199 185
diff --git a/drivers/staging/et131x/et1310_rx.c b/drivers/staging/et131x/et1310_rx.c
index 54a7ecfd4901..8f2e91fa0a86 100644
--- a/drivers/staging/et131x/et1310_rx.c
+++ b/drivers/staging/et131x/et1310_rx.c
@@ -56,7 +56,6 @@
56 */ 56 */
57 57
58#include "et131x_version.h" 58#include "et131x_version.h"
59#include "et131x_debug.h"
60#include "et131x_defs.h" 59#include "et131x_defs.h"
61 60
62#include <linux/pci.h> 61#include <linux/pci.h>
@@ -93,11 +92,6 @@
93 92
94#include "et1310_rx.h" 93#include "et1310_rx.h"
95 94
96/* Data for debugging facilities */
97#ifdef CONFIG_ET131X_DEBUG
98extern dbg_info_t *et131x_dbginfo;
99#endif /* CONFIG_ET131X_DEBUG */
100
101 95
102void nic_return_rfd(struct et131x_adapter *etdev, PMP_RFD pMpRfd); 96void nic_return_rfd(struct et131x_adapter *etdev, PMP_RFD pMpRfd);
103 97
@@ -117,8 +111,6 @@ int et131x_rx_dma_memory_alloc(struct et131x_adapter *adapter)
117 uint32_t pktStatRingSize, FBRChunkSize; 111 uint32_t pktStatRingSize, FBRChunkSize;
118 RX_RING_t *rx_ring; 112 RX_RING_t *rx_ring;
119 113
120 DBG_ENTER(et131x_dbginfo);
121
122 /* Setup some convenience pointers */ 114 /* Setup some convenience pointers */
123 rx_ring = (RX_RING_t *) &adapter->RxRing; 115 rx_ring = (RX_RING_t *) &adapter->RxRing;
124 116
@@ -183,9 +175,8 @@ int et131x_rx_dma_memory_alloc(struct et131x_adapter *adapter)
183 bufsize, 175 bufsize,
184 &rx_ring->pFbr1RingPa); 176 &rx_ring->pFbr1RingPa);
185 if (!rx_ring->pFbr1RingVa) { 177 if (!rx_ring->pFbr1RingVa) {
186 DBG_ERROR(et131x_dbginfo, 178 dev_err(&adapter->pdev->dev,
187 "Cannot alloc memory for Free Buffer Ring 1\n"); 179 "Cannot alloc memory for Free Buffer Ring 1\n");
188 DBG_LEAVE(et131x_dbginfo);
189 return -ENOMEM; 180 return -ENOMEM;
190 } 181 }
191 182
@@ -213,9 +204,8 @@ int et131x_rx_dma_memory_alloc(struct et131x_adapter *adapter)
213 bufsize, 204 bufsize,
214 &rx_ring->pFbr0RingPa); 205 &rx_ring->pFbr0RingPa);
215 if (!rx_ring->pFbr0RingVa) { 206 if (!rx_ring->pFbr0RingVa) {
216 DBG_ERROR(et131x_dbginfo, 207 dev_err(&adapter->pdev->dev,
217 "Cannot alloc memory for Free Buffer Ring 0\n"); 208 "Cannot alloc memory for Free Buffer Ring 0\n");
218 DBG_LEAVE(et131x_dbginfo);
219 return -ENOMEM; 209 return -ENOMEM;
220 } 210 }
221 211
@@ -262,8 +252,8 @@ int et131x_rx_dma_memory_alloc(struct et131x_adapter *adapter)
262 &rx_ring->Fbr1MemPa[OuterLoop]); 252 &rx_ring->Fbr1MemPa[OuterLoop]);
263 253
264 if (!rx_ring->Fbr1MemVa[OuterLoop]) { 254 if (!rx_ring->Fbr1MemVa[OuterLoop]) {
265 DBG_ERROR(et131x_dbginfo, "Could not alloc memory\n"); 255 dev_err(&adapter->pdev->dev,
266 DBG_LEAVE(et131x_dbginfo); 256 "Could not alloc memory\n");
267 return -ENOMEM; 257 return -ENOMEM;
268 } 258 }
269 259
@@ -313,8 +303,8 @@ int et131x_rx_dma_memory_alloc(struct et131x_adapter *adapter)
313 &rx_ring->Fbr0MemPa[OuterLoop]); 303 &rx_ring->Fbr0MemPa[OuterLoop]);
314 304
315 if (!rx_ring->Fbr0MemVa[OuterLoop]) { 305 if (!rx_ring->Fbr0MemVa[OuterLoop]) {
316 DBG_ERROR(et131x_dbginfo, "Could not alloc memory\n"); 306 dev_err(&adapter->pdev->dev,
317 DBG_LEAVE(et131x_dbginfo); 307 "Could not alloc memory\n");
318 return -ENOMEM; 308 return -ENOMEM;
319 } 309 }
320 310
@@ -356,9 +346,8 @@ int et131x_rx_dma_memory_alloc(struct et131x_adapter *adapter)
356 &rx_ring->pPSRingPa); 346 &rx_ring->pPSRingPa);
357 347
358 if (!rx_ring->pPSRingVa) { 348 if (!rx_ring->pPSRingVa) {
359 DBG_ERROR(et131x_dbginfo, 349 dev_err(&adapter->pdev->dev,
360 "Cannot alloc memory for Packet Status Ring\n"); 350 "Cannot alloc memory for Packet Status Ring\n");
361 DBG_LEAVE(et131x_dbginfo);
362 return -ENOMEM; 351 return -ENOMEM;
363 } 352 }
364 353
@@ -384,9 +373,8 @@ int et131x_rx_dma_memory_alloc(struct et131x_adapter *adapter)
384 sizeof(RX_STATUS_BLOCK_t) + 373 sizeof(RX_STATUS_BLOCK_t) +
385 0x7, &rx_ring->pRxStatusPa); 374 0x7, &rx_ring->pRxStatusPa);
386 if (!rx_ring->pRxStatusVa) { 375 if (!rx_ring->pRxStatusVa) {
387 DBG_ERROR(et131x_dbginfo, 376 dev_err(&adapter->pdev->dev,
388 "Cannot alloc memory for Status Block\n"); 377 "Cannot alloc memory for Status Block\n");
389 DBG_LEAVE(et131x_dbginfo);
390 return -ENOMEM; 378 return -ENOMEM;
391 } 379 }
392 380
@@ -422,8 +410,6 @@ int et131x_rx_dma_memory_alloc(struct et131x_adapter *adapter)
422 */ 410 */
423 INIT_LIST_HEAD(&rx_ring->RecvList); 411 INIT_LIST_HEAD(&rx_ring->RecvList);
424 INIT_LIST_HEAD(&rx_ring->RecvPendingList); 412 INIT_LIST_HEAD(&rx_ring->RecvPendingList);
425
426 DBG_LEAVE(et131x_dbginfo);
427 return 0; 413 return 0;
428} 414}
429 415
@@ -439,13 +425,11 @@ void et131x_rx_dma_memory_free(struct et131x_adapter *adapter)
439 PMP_RFD pMpRfd; 425 PMP_RFD pMpRfd;
440 RX_RING_t *rx_ring; 426 RX_RING_t *rx_ring;
441 427
442 DBG_ENTER(et131x_dbginfo);
443
444 /* Setup some convenience pointers */ 428 /* Setup some convenience pointers */
445 rx_ring = (RX_RING_t *) &adapter->RxRing; 429 rx_ring = (RX_RING_t *) &adapter->RxRing;
446 430
447 /* Free RFDs and associated packet descriptors */ 431 /* Free RFDs and associated packet descriptors */
448 DBG_ASSERT(rx_ring->nReadyRecv == rx_ring->NumRfd); 432 WARN_ON(rx_ring->nReadyRecv != rx_ring->NumRfd);
449 433
450 while (!list_empty(&rx_ring->RecvList)) { 434 while (!list_empty(&rx_ring->RecvList)) {
451 pMpRfd = (MP_RFD *) list_entry(rx_ring->RecvList.next, 435 pMpRfd = (MP_RFD *) list_entry(rx_ring->RecvList.next,
@@ -583,8 +567,6 @@ void et131x_rx_dma_memory_free(struct et131x_adapter *adapter)
583 567
584 /* Reset Counters */ 568 /* Reset Counters */
585 rx_ring->nReadyRecv = 0; 569 rx_ring->nReadyRecv = 0;
586
587 DBG_LEAVE(et131x_dbginfo);
588} 570}
589 571
590/** 572/**
@@ -601,8 +583,6 @@ int et131x_init_recv(struct et131x_adapter *adapter)
601 uint32_t TotalNumRfd = 0; 583 uint32_t TotalNumRfd = 0;
602 RX_RING_t *rx_ring = NULL; 584 RX_RING_t *rx_ring = NULL;
603 585
604 DBG_ENTER(et131x_dbginfo);
605
606 /* Setup some convenience pointers */ 586 /* Setup some convenience pointers */
607 rx_ring = (RX_RING_t *) &adapter->RxRing; 587 rx_ring = (RX_RING_t *) &adapter->RxRing;
608 588
@@ -612,7 +592,7 @@ int et131x_init_recv(struct et131x_adapter *adapter)
612 GFP_ATOMIC | GFP_DMA); 592 GFP_ATOMIC | GFP_DMA);
613 593
614 if (!pMpRfd) { 594 if (!pMpRfd) {
615 DBG_ERROR(et131x_dbginfo, 595 dev_err(&adapter->pdev->dev,
616 "Couldn't alloc RFD out of kmem_cache\n"); 596 "Couldn't alloc RFD out of kmem_cache\n");
617 status = -ENOMEM; 597 status = -ENOMEM;
618 continue; 598 continue;
@@ -620,7 +600,7 @@ int et131x_init_recv(struct et131x_adapter *adapter)
620 600
621 status = et131x_rfd_resources_alloc(adapter, pMpRfd); 601 status = et131x_rfd_resources_alloc(adapter, pMpRfd);
622 if (status != 0) { 602 if (status != 0) {
623 DBG_ERROR(et131x_dbginfo, 603 dev_err(&adapter->pdev->dev,
624 "Couldn't alloc packet for RFD\n"); 604 "Couldn't alloc packet for RFD\n");
625 kmem_cache_free(rx_ring->RecvLookaside, pMpRfd); 605 kmem_cache_free(rx_ring->RecvLookaside, pMpRfd);
626 continue; 606 continue;
@@ -641,11 +621,9 @@ int et131x_init_recv(struct et131x_adapter *adapter)
641 621
642 if (status != 0) { 622 if (status != 0) {
643 kmem_cache_free(rx_ring->RecvLookaside, pMpRfd); 623 kmem_cache_free(rx_ring->RecvLookaside, pMpRfd);
644 DBG_ERROR(et131x_dbginfo, 624 dev_err(&adapter->pdev->dev,
645 "Allocation problems in et131x_init_recv\n"); 625 "Allocation problems in et131x_init_recv\n");
646 } 626 }
647
648 DBG_LEAVE(et131x_dbginfo);
649 return status; 627 return status;
650} 628}
651 629
@@ -687,8 +665,6 @@ void ConfigRxDmaRegs(struct et131x_adapter *etdev)
687 RXDMA_PSR_NUM_DES_t psr_num_des; 665 RXDMA_PSR_NUM_DES_t psr_num_des;
688 unsigned long flags; 666 unsigned long flags;
689 667
690 DBG_ENTER(et131x_dbginfo);
691
692 /* Halt RXDMA to perform the reconfigure. */ 668 /* Halt RXDMA to perform the reconfigure. */
693 et131x_rx_dma_disable(etdev); 669 et131x_rx_dma_disable(etdev);
694 670
@@ -786,8 +762,6 @@ void ConfigRxDmaRegs(struct et131x_adapter *etdev)
786 writel(PARM_RX_TIME_INT_DEF, &rx_dma->max_pkt_time.value); 762 writel(PARM_RX_TIME_INT_DEF, &rx_dma->max_pkt_time.value);
787 763
788 spin_unlock_irqrestore(&etdev->RcvLock, flags); 764 spin_unlock_irqrestore(&etdev->RcvLock, flags);
789
790 DBG_LEAVE(et131x_dbginfo);
791} 765}
792 766
793/** 767/**
@@ -814,8 +788,6 @@ void et131x_rx_dma_disable(struct et131x_adapter *etdev)
814{ 788{
815 RXDMA_CSR_t csr; 789 RXDMA_CSR_t csr;
816 790
817 DBG_ENTER(et131x_dbginfo);
818
819 /* Setup the receive dma configuration register */ 791 /* Setup the receive dma configuration register */
820 writel(0x00002001, &etdev->regs->rxdma.csr.value); 792 writel(0x00002001, &etdev->regs->rxdma.csr.value);
821 csr.value = readl(&etdev->regs->rxdma.csr.value); 793 csr.value = readl(&etdev->regs->rxdma.csr.value);
@@ -823,12 +795,10 @@ void et131x_rx_dma_disable(struct et131x_adapter *etdev)
823 udelay(5); 795 udelay(5);
824 csr.value = readl(&etdev->regs->rxdma.csr.value); 796 csr.value = readl(&etdev->regs->rxdma.csr.value);
825 if (csr.bits.halt_status != 1) 797 if (csr.bits.halt_status != 1)
826 DBG_ERROR(et131x_dbginfo, 798 dev_err(&etdev->pdev->dev,
827 "RX Dma failed to enter halt state. CSR 0x%08x\n", 799 "RX Dma failed to enter halt state. CSR 0x%08x\n",
828 csr.value); 800 csr.value);
829 } 801 }
830
831 DBG_LEAVE(et131x_dbginfo);
832} 802}
833 803
834/** 804/**
@@ -837,8 +807,6 @@ void et131x_rx_dma_disable(struct et131x_adapter *etdev)
837 */ 807 */
838void et131x_rx_dma_enable(struct et131x_adapter *etdev) 808void et131x_rx_dma_enable(struct et131x_adapter *etdev)
839{ 809{
840 DBG_RX_ENTER(et131x_dbginfo);
841
842 if (etdev->RegistryPhyLoopbk) 810 if (etdev->RegistryPhyLoopbk)
843 /* RxDMA is disabled for loopback operation. */ 811 /* RxDMA is disabled for loopback operation. */
844 writel(0x1, &etdev->regs->rxdma.csr.value); 812 writel(0x1, &etdev->regs->rxdma.csr.value);
@@ -869,14 +837,12 @@ void et131x_rx_dma_enable(struct et131x_adapter *etdev)
869 udelay(5); 837 udelay(5);
870 csr.value = readl(&etdev->regs->rxdma.csr.value); 838 csr.value = readl(&etdev->regs->rxdma.csr.value);
871 if (csr.bits.halt_status != 0) { 839 if (csr.bits.halt_status != 0) {
872 DBG_ERROR(et131x_dbginfo, 840 dev_err(&etdev->pdev->dev,
873 "RX Dma failed to exit halt state. CSR 0x%08x\n", 841 "RX Dma failed to exit halt state. CSR 0x%08x\n",
874 csr.value); 842 csr.value);
875 } 843 }
876 } 844 }
877 } 845 }
878
879 DBG_RX_LEAVE(et131x_dbginfo);
880} 846}
881 847
882/** 848/**
@@ -905,9 +871,6 @@ PMP_RFD nic_rx_pkts(struct et131x_adapter *etdev)
905 uint32_t localLen; 871 uint32_t localLen;
906 PKT_STAT_DESC_WORD0_t Word0; 872 PKT_STAT_DESC_WORD0_t Word0;
907 873
908
909 DBG_RX_ENTER(et131x_dbginfo);
910
911 /* RX Status block is written by the DMA engine prior to every 874 /* RX Status block is written by the DMA engine prior to every
912 * interrupt. It contains the next to be used entry in the Packet 875 * interrupt. It contains the next to be used entry in the Packet
913 * Status Ring, and also the two Free Buffer rings. 876 * Status Ring, and also the two Free Buffer rings.
@@ -919,8 +882,6 @@ PMP_RFD nic_rx_pkts(struct et131x_adapter *etdev)
919 pRxStatusBlock->Word1.bits.PSRwrap == 882 pRxStatusBlock->Word1.bits.PSRwrap ==
920 pRxLocal->local_psr_full.bits.psr_full_wrap) { 883 pRxLocal->local_psr_full.bits.psr_full_wrap) {
921 /* Looks like this ring is not updated yet */ 884 /* Looks like this ring is not updated yet */
922 DBG_RX(et131x_dbginfo, "(0)\n");
923 DBG_RX_LEAVE(et131x_dbginfo);
924 return NULL; 885 return NULL;
925 } 886 }
926 887
@@ -937,23 +898,6 @@ PMP_RFD nic_rx_pkts(struct et131x_adapter *etdev)
937 bufferIndex = (uint16_t) pPSREntry->word1.bits.bi; 898 bufferIndex = (uint16_t) pPSREntry->word1.bits.bi;
938 Word0 = pPSREntry->word0; 899 Word0 = pPSREntry->word0;
939 900
940 DBG_RX(et131x_dbginfo, "RX PACKET STATUS\n");
941 DBG_RX(et131x_dbginfo, "\tlength : %d\n", localLen);
942 DBG_RX(et131x_dbginfo, "\tringIndex : %d\n", ringIndex);
943 DBG_RX(et131x_dbginfo, "\tbufferIndex : %d\n", bufferIndex);
944 DBG_RX(et131x_dbginfo, "\tword0 : 0x%08x\n", Word0.value);
945
946#if 0
947 /* Check the Status Word that the MAC has appended to the PSR
948 * entry in case the MAC has detected errors.
949 */
950 if (Word0.value & ALCATEL_BAD_STATUS) {
951 DBG_ERROR(et131x_dbginfo,
952 "NICRxPkts >> Alcatel Status Word error."
953 "Value 0x%08x\n", pPSREntry->word0.value);
954 }
955#endif
956
957 /* Indicate that we have used this PSR entry. */ 901 /* Indicate that we have used this PSR entry. */
958 if (++pRxLocal->local_psr_full.bits.psr_full > 902 if (++pRxLocal->local_psr_full.bits.psr_full >
959 pRxLocal->PsrNumEntries - 1) { 903 pRxLocal->PsrNumEntries - 1) {
@@ -966,11 +910,6 @@ PMP_RFD nic_rx_pkts(struct et131x_adapter *etdev)
966 910
967#ifndef USE_FBR0 911#ifndef USE_FBR0
968 if (ringIndex != 1) { 912 if (ringIndex != 1) {
969 DBG_ERROR(et131x_dbginfo,
970 "NICRxPkts PSR Entry %d indicates "
971 "Buffer Ring 0 in use\n",
972 pRxLocal->local_psr_full.bits.psr_full);
973 DBG_RX_LEAVE(et131x_dbginfo);
974 return NULL; 913 return NULL;
975 } 914 }
976#endif 915#endif
@@ -987,12 +926,11 @@ PMP_RFD nic_rx_pkts(struct et131x_adapter *etdev)
987#endif 926#endif
988 { 927 {
989 /* Illegal buffer or ring index cannot be used by S/W*/ 928 /* Illegal buffer or ring index cannot be used by S/W*/
990 DBG_ERROR(et131x_dbginfo, 929 dev_err(&etdev->pdev->dev,
991 "NICRxPkts PSR Entry %d indicates " 930 "NICRxPkts PSR Entry %d indicates "
992 "length of %d and/or bad bi(%d)\n", 931 "length of %d and/or bad bi(%d)\n",
993 pRxLocal->local_psr_full.bits.psr_full, 932 pRxLocal->local_psr_full.bits.psr_full,
994 localLen, bufferIndex); 933 localLen, bufferIndex);
995 DBG_RX_LEAVE(et131x_dbginfo);
996 return NULL; 934 return NULL;
997 } 935 }
998 936
@@ -1004,9 +942,6 @@ PMP_RFD nic_rx_pkts(struct et131x_adapter *etdev)
1004 pMpRfd = (PMP_RFD) list_entry(element, MP_RFD, list_node); 942 pMpRfd = (PMP_RFD) list_entry(element, MP_RFD, list_node);
1005 943
1006 if (pMpRfd == NULL) { 944 if (pMpRfd == NULL) {
1007 DBG_RX(et131x_dbginfo,
1008 "NULL RFD returned from RecvList via list_entry()\n");
1009 DBG_RX_LEAVE(et131x_dbginfo);
1010 spin_unlock_irqrestore(&etdev->RcvLock, flags); 945 spin_unlock_irqrestore(&etdev->RcvLock, flags);
1011 return NULL; 946 return NULL;
1012 } 947 }
@@ -1040,19 +975,6 @@ PMP_RFD nic_rx_pkts(struct et131x_adapter *etdev)
1040 etdev->ReplicaPhyLoopbkPF = 1; 975 etdev->ReplicaPhyLoopbkPF = 1;
1041 } 976 }
1042 } 977 }
1043 DBG_WARNING(et131x_dbginfo,
1044 "pBufVa:\t%02x:%02x:%02x:%02x:%02x:%02x\n",
1045 pBufVa[6], pBufVa[7], pBufVa[8],
1046 pBufVa[9], pBufVa[10], pBufVa[11]);
1047
1048 DBG_WARNING(et131x_dbginfo,
1049 "CurrentAddr:\t%02x:%02x:%02x:%02x:%02x:%02x\n",
1050 etdev->CurrentAddress[0],
1051 etdev->CurrentAddress[1],
1052 etdev->CurrentAddress[2],
1053 etdev->CurrentAddress[3],
1054 etdev->CurrentAddress[4],
1055 etdev->CurrentAddress[5]);
1056 } 978 }
1057 979
1058 /* Determine if this is a multicast packet coming in */ 980 /* Determine if this is a multicast packet coming in */
@@ -1127,9 +1049,8 @@ PMP_RFD nic_rx_pkts(struct et131x_adapter *etdev)
1127 1049
1128 skb = dev_alloc_skb(pMpRfd->PacketSize + 2); 1050 skb = dev_alloc_skb(pMpRfd->PacketSize + 2);
1129 if (!skb) { 1051 if (!skb) {
1130 DBG_ERROR(et131x_dbginfo, 1052 dev_err(&etdev->pdev->dev,
1131 "Couldn't alloc an SKB for Rx\n"); 1053 "Couldn't alloc an SKB for Rx\n");
1132 DBG_RX_LEAVE(et131x_dbginfo);
1133 return NULL; 1054 return NULL;
1134 } 1055 }
1135 1056
@@ -1149,9 +1070,6 @@ PMP_RFD nic_rx_pkts(struct et131x_adapter *etdev)
1149 } 1070 }
1150 1071
1151 nic_return_rfd(etdev, pMpRfd); 1072 nic_return_rfd(etdev, pMpRfd);
1152
1153 DBG_RX(et131x_dbginfo, "(1)\n");
1154 DBG_RX_LEAVE(et131x_dbginfo);
1155 return pMpRfd; 1073 return pMpRfd;
1156} 1074}
1157 1075
@@ -1166,9 +1084,7 @@ void et131x_reset_recv(struct et131x_adapter *etdev)
1166 PMP_RFD pMpRfd; 1084 PMP_RFD pMpRfd;
1167 struct list_head *element; 1085 struct list_head *element;
1168 1086
1169 DBG_ENTER(et131x_dbginfo); 1087 WARN_ON(list_empty(&etdev->RxRing.RecvList));
1170
1171 DBG_ASSERT(!list_empty(&etdev->RxRing.RecvList));
1172 1088
1173 /* Take all the RFD's from the pending list, and stick them on the 1089 /* Take all the RFD's from the pending list, and stick them on the
1174 * RecvList. 1090 * RecvList.
@@ -1180,8 +1096,6 @@ void et131x_reset_recv(struct et131x_adapter *etdev)
1180 1096
1181 list_move_tail(&pMpRfd->list_node, &etdev->RxRing.RecvList); 1097 list_move_tail(&pMpRfd->list_node, &etdev->RxRing.RecvList);
1182 } 1098 }
1183
1184 DBG_LEAVE(et131x_dbginfo);
1185} 1099}
1186 1100
1187/** 1101/**
@@ -1200,15 +1114,12 @@ void et131x_handle_recv_interrupt(struct et131x_adapter *etdev)
1200 uint32_t PacketFreeCount = 0; 1114 uint32_t PacketFreeCount = 0;
1201 bool TempUnfinishedRec = false; 1115 bool TempUnfinishedRec = false;
1202 1116
1203 DBG_RX_ENTER(et131x_dbginfo);
1204
1205 PacketsToHandle = NUM_PACKETS_HANDLED; 1117 PacketsToHandle = NUM_PACKETS_HANDLED;
1206 1118
1207 /* Process up to available RFD's */ 1119 /* Process up to available RFD's */
1208 while (PacketArrayCount < PacketsToHandle) { 1120 while (PacketArrayCount < PacketsToHandle) {
1209 if (list_empty(&etdev->RxRing.RecvList)) { 1121 if (list_empty(&etdev->RxRing.RecvList)) {
1210 DBG_ASSERT(etdev->RxRing.nReadyRecv == 0); 1122 WARN_ON(etdev->RxRing.nReadyRecv != 0);
1211 DBG_ERROR(et131x_dbginfo, "NO RFD's !!!!!!!!!!!!!\n");
1212 TempUnfinishedRec = true; 1123 TempUnfinishedRec = true;
1213 break; 1124 break;
1214 } 1125 }
@@ -1246,8 +1157,8 @@ void et131x_handle_recv_interrupt(struct et131x_adapter *etdev)
1246 RFDFreeArray[PacketFreeCount] = pMpRfd; 1157 RFDFreeArray[PacketFreeCount] = pMpRfd;
1247 PacketFreeCount++; 1158 PacketFreeCount++;
1248 1159
1249 DBG_WARNING(et131x_dbginfo, 1160 dev_warn(&etdev->pdev->dev,
1250 "RFD's are running out !!!!!!!!!!!!!\n"); 1161 "RFD's are running out\n");
1251 } 1162 }
1252 1163
1253 PacketArray[PacketArrayCount] = pMpRfd->Packet; 1164 PacketArray[PacketArrayCount] = pMpRfd->Packet;
@@ -1262,8 +1173,6 @@ void et131x_handle_recv_interrupt(struct et131x_adapter *etdev)
1262 /* Watchdog timer will disable itself if appropriate. */ 1173 /* Watchdog timer will disable itself if appropriate. */
1263 etdev->RxRing.UnfinishedReceives = false; 1174 etdev->RxRing.UnfinishedReceives = false;
1264 } 1175 }
1265
1266 DBG_RX_LEAVE(et131x_dbginfo);
1267} 1176}
1268 1177
1269static inline u32 bump_fbr(u32 *fbr, u32 limit) 1178static inline u32 bump_fbr(u32 *fbr, u32 limit)
@@ -1289,8 +1198,6 @@ void nic_return_rfd(struct et131x_adapter *etdev, PMP_RFD pMpRfd)
1289 uint8_t ri = pMpRfd->ringindex; 1198 uint8_t ri = pMpRfd->ringindex;
1290 unsigned long flags; 1199 unsigned long flags;
1291 1200
1292 DBG_RX_ENTER(et131x_dbginfo);
1293
1294 /* We don't use any of the OOB data besides status. Otherwise, we 1201 /* We don't use any of the OOB data besides status. Otherwise, we
1295 * need to clean up OOB data 1202 * need to clean up OOB data
1296 */ 1203 */
@@ -1339,7 +1246,7 @@ void nic_return_rfd(struct et131x_adapter *etdev, PMP_RFD pMpRfd)
1339#endif 1246#endif
1340 spin_unlock_irqrestore(&etdev->FbrLock, flags); 1247 spin_unlock_irqrestore(&etdev->FbrLock, flags);
1341 } else { 1248 } else {
1342 DBG_ERROR(et131x_dbginfo, 1249 dev_err(&etdev->pdev->dev,
1343 "NICReturnRFD illegal Buffer Index returned\n"); 1250 "NICReturnRFD illegal Buffer Index returned\n");
1344 } 1251 }
1345 1252
@@ -1351,6 +1258,5 @@ void nic_return_rfd(struct et131x_adapter *etdev, PMP_RFD pMpRfd)
1351 rx_local->nReadyRecv++; 1258 rx_local->nReadyRecv++;
1352 spin_unlock_irqrestore(&etdev->RcvLock, flags); 1259 spin_unlock_irqrestore(&etdev->RcvLock, flags);
1353 1260
1354 DBG_ASSERT(rx_local->nReadyRecv <= rx_local->NumRfd); 1261 WARN_ON(rx_local->nReadyRecv > rx_local->NumRfd);
1355 DBG_RX_LEAVE(et131x_dbginfo);
1356} 1262}
diff --git a/drivers/staging/et131x/et1310_tx.c b/drivers/staging/et131x/et1310_tx.c
index 4c18e9a2d2e8..387a697c4af8 100644
--- a/drivers/staging/et131x/et1310_tx.c
+++ b/drivers/staging/et131x/et1310_tx.c
@@ -56,7 +56,6 @@
56 */ 56 */
57 57
58#include "et131x_version.h" 58#include "et131x_version.h"
59#include "et131x_debug.h"
60#include "et131x_defs.h" 59#include "et131x_defs.h"
61 60
62#include <linux/pci.h> 61#include <linux/pci.h>
@@ -95,11 +94,6 @@
95#include "et1310_tx.h" 94#include "et1310_tx.h"
96 95
97 96
98/* Data for debugging facilities */
99#ifdef CONFIG_ET131X_DEBUG
100extern dbg_info_t *et131x_dbginfo;
101#endif /* CONFIG_ET131X_DEBUG */
102
103static void et131x_update_tcb_list(struct et131x_adapter *etdev); 97static void et131x_update_tcb_list(struct et131x_adapter *etdev);
104static void et131x_check_send_wait_list(struct et131x_adapter *etdev); 98static void et131x_check_send_wait_list(struct et131x_adapter *etdev);
105static inline void et131x_free_send_packet(struct et131x_adapter *etdev, 99static inline void et131x_free_send_packet(struct et131x_adapter *etdev,
@@ -125,14 +119,11 @@ int et131x_tx_dma_memory_alloc(struct et131x_adapter *adapter)
125 int desc_size = 0; 119 int desc_size = 0;
126 TX_RING_t *tx_ring = &adapter->TxRing; 120 TX_RING_t *tx_ring = &adapter->TxRing;
127 121
128 DBG_ENTER(et131x_dbginfo);
129
130 /* Allocate memory for the TCB's (Transmit Control Block) */ 122 /* Allocate memory for the TCB's (Transmit Control Block) */
131 adapter->TxRing.MpTcbMem = (MP_TCB *)kcalloc(NUM_TCB, sizeof(MP_TCB), 123 adapter->TxRing.MpTcbMem = (MP_TCB *)kcalloc(NUM_TCB, sizeof(MP_TCB),
132 GFP_ATOMIC | GFP_DMA); 124 GFP_ATOMIC | GFP_DMA);
133 if (!adapter->TxRing.MpTcbMem) { 125 if (!adapter->TxRing.MpTcbMem) {
134 DBG_ERROR(et131x_dbginfo, "Cannot alloc memory for TCBs\n"); 126 dev_err(&adapter->pdev->dev, "Cannot alloc memory for TCBs\n");
135 DBG_LEAVE(et131x_dbginfo);
136 return -ENOMEM; 127 return -ENOMEM;
137 } 128 }
138 129
@@ -144,8 +135,7 @@ int et131x_tx_dma_memory_alloc(struct et131x_adapter *adapter)
144 (PTX_DESC_ENTRY_t) pci_alloc_consistent(adapter->pdev, desc_size, 135 (PTX_DESC_ENTRY_t) pci_alloc_consistent(adapter->pdev, desc_size,
145 &tx_ring->pTxDescRingPa); 136 &tx_ring->pTxDescRingPa);
146 if (!adapter->TxRing.pTxDescRingVa) { 137 if (!adapter->TxRing.pTxDescRingVa) {
147 DBG_ERROR(et131x_dbginfo, "Cannot alloc memory for Tx Ring\n"); 138 dev_err(&adapter->pdev->dev, "Cannot alloc memory for Tx Ring\n");
148 DBG_LEAVE(et131x_dbginfo);
149 return -ENOMEM; 139 return -ENOMEM;
150 } 140 }
151 141
@@ -170,9 +160,8 @@ int et131x_tx_dma_memory_alloc(struct et131x_adapter *adapter)
170 sizeof(TX_STATUS_BLOCK_t), 160 sizeof(TX_STATUS_BLOCK_t),
171 &tx_ring->pTxStatusPa); 161 &tx_ring->pTxStatusPa);
172 if (!adapter->TxRing.pTxStatusPa) { 162 if (!adapter->TxRing.pTxStatusPa) {
173 DBG_ERROR(et131x_dbginfo, 163 dev_err(&adapter->pdev->dev,
174 "Cannot alloc memory for Tx status block\n"); 164 "Cannot alloc memory for Tx status block\n");
175 DBG_LEAVE(et131x_dbginfo);
176 return -ENOMEM; 165 return -ENOMEM;
177 } 166 }
178 167
@@ -181,13 +170,11 @@ int et131x_tx_dma_memory_alloc(struct et131x_adapter *adapter)
181 NIC_MIN_PACKET_SIZE, 170 NIC_MIN_PACKET_SIZE,
182 &tx_ring->pTxDummyBlkPa); 171 &tx_ring->pTxDummyBlkPa);
183 if (!adapter->TxRing.pTxDummyBlkPa) { 172 if (!adapter->TxRing.pTxDummyBlkPa) {
184 DBG_ERROR(et131x_dbginfo, 173 dev_err(&adapter->pdev->dev,
185 "Cannot alloc memory for Tx dummy buffer\n"); 174 "Cannot alloc memory for Tx dummy buffer\n");
186 DBG_LEAVE(et131x_dbginfo);
187 return -ENOMEM; 175 return -ENOMEM;
188 } 176 }
189 177
190 DBG_LEAVE(et131x_dbginfo);
191 return 0; 178 return 0;
192} 179}
193 180
@@ -201,8 +188,6 @@ void et131x_tx_dma_memory_free(struct et131x_adapter *adapter)
201{ 188{
202 int desc_size = 0; 189 int desc_size = 0;
203 190
204 DBG_ENTER(et131x_dbginfo);
205
206 if (adapter->TxRing.pTxDescRingVa) { 191 if (adapter->TxRing.pTxDescRingVa) {
207 /* Free memory relating to Tx rings here */ 192 /* Free memory relating to Tx rings here */
208 adapter->TxRing.pTxDescRingVa -= adapter->TxRing.TxDescOffset; 193 adapter->TxRing.pTxDescRingVa -= adapter->TxRing.TxDescOffset;
@@ -240,8 +225,6 @@ void et131x_tx_dma_memory_free(struct et131x_adapter *adapter)
240 225
241 /* Free the memory for MP_TCB structures */ 226 /* Free the memory for MP_TCB structures */
242 kfree(adapter->TxRing.MpTcbMem); 227 kfree(adapter->TxRing.MpTcbMem);
243
244 DBG_LEAVE(et131x_dbginfo);
245} 228}
246 229
247/** 230/**
@@ -252,8 +235,6 @@ void ConfigTxDmaRegs(struct et131x_adapter *etdev)
252{ 235{
253 struct _TXDMA_t __iomem *txdma = &etdev->regs->txdma; 236 struct _TXDMA_t __iomem *txdma = &etdev->regs->txdma;
254 237
255 DBG_ENTER(et131x_dbginfo);
256
257 /* Load the hardware with the start of the transmit descriptor ring. */ 238 /* Load the hardware with the start of the transmit descriptor ring. */
258 writel((uint32_t) (etdev->TxRing.pTxDescRingAdjustedPa >> 32), 239 writel((uint32_t) (etdev->TxRing.pTxDescRingAdjustedPa >> 32),
259 &txdma->pr_base_hi); 240 &txdma->pr_base_hi);
@@ -277,8 +258,6 @@ void ConfigTxDmaRegs(struct et131x_adapter *etdev)
277 258
278 writel(0, &txdma->service_request); 259 writel(0, &txdma->service_request);
279 etdev->TxRing.txDmaReadyToSend = 0; 260 etdev->TxRing.txDmaReadyToSend = 0;
280
281 DBG_LEAVE(et131x_dbginfo);
282} 261}
283 262
284/** 263/**
@@ -287,12 +266,8 @@ void ConfigTxDmaRegs(struct et131x_adapter *etdev)
287 */ 266 */
288void et131x_tx_dma_disable(struct et131x_adapter *etdev) 267void et131x_tx_dma_disable(struct et131x_adapter *etdev)
289{ 268{
290 DBG_ENTER(et131x_dbginfo);
291
292 /* Setup the tramsmit dma configuration register */ 269 /* Setup the tramsmit dma configuration register */
293 writel(0x101, &etdev->regs->txdma.csr.value); 270 writel(0x101, &etdev->regs->txdma.csr.value);
294
295 DBG_LEAVE(et131x_dbginfo);
296} 271}
297 272
298/** 273/**
@@ -303,8 +278,6 @@ void et131x_tx_dma_disable(struct et131x_adapter *etdev)
303 */ 278 */
304void et131x_tx_dma_enable(struct et131x_adapter *etdev) 279void et131x_tx_dma_enable(struct et131x_adapter *etdev)
305{ 280{
306 DBG_ENTER(et131x_dbginfo);
307
308 if (etdev->RegistryPhyLoopbk) { 281 if (etdev->RegistryPhyLoopbk) {
309 /* TxDMA is disabled for loopback operation. */ 282 /* TxDMA is disabled for loopback operation. */
310 writel(0x101, &etdev->regs->txdma.csr.value); 283 writel(0x101, &etdev->regs->txdma.csr.value);
@@ -319,8 +292,6 @@ void et131x_tx_dma_enable(struct et131x_adapter *etdev)
319 csr.bits.cache_thrshld = PARM_DMA_CACHE_DEF; 292 csr.bits.cache_thrshld = PARM_DMA_CACHE_DEF;
320 writel(csr.value, &etdev->regs->txdma.csr.value); 293 writel(csr.value, &etdev->regs->txdma.csr.value);
321 } 294 }
322
323 DBG_LEAVE(et131x_dbginfo);
324} 295}
325 296
326/** 297/**
@@ -333,8 +304,6 @@ void et131x_init_send(struct et131x_adapter *adapter)
333 uint32_t TcbCount; 304 uint32_t TcbCount;
334 TX_RING_t *tx_ring; 305 TX_RING_t *tx_ring;
335 306
336 DBG_ENTER(et131x_dbginfo);
337
338 /* Setup some convenience pointers */ 307 /* Setup some convenience pointers */
339 tx_ring = &adapter->TxRing; 308 tx_ring = &adapter->TxRing;
340 pMpTcb = adapter->TxRing.MpTcbMem; 309 pMpTcb = adapter->TxRing.MpTcbMem;
@@ -364,8 +333,6 @@ void et131x_init_send(struct et131x_adapter *adapter)
364 tx_ring->CurrSendTail = (PMP_TCB) NULL; 333 tx_ring->CurrSendTail = (PMP_TCB) NULL;
365 334
366 INIT_LIST_HEAD(&adapter->TxRing.SendWaitQueue); 335 INIT_LIST_HEAD(&adapter->TxRing.SendWaitQueue);
367
368 DBG_LEAVE(et131x_dbginfo);
369} 336}
370 337
371/** 338/**
@@ -380,8 +347,6 @@ int et131x_send_packets(struct sk_buff *skb, struct net_device *netdev)
380 int status = 0; 347 int status = 0;
381 struct et131x_adapter *etdev = NULL; 348 struct et131x_adapter *etdev = NULL;
382 349
383 DBG_TX_ENTER(et131x_dbginfo);
384
385 etdev = netdev_priv(netdev); 350 etdev = netdev_priv(netdev);
386 351
387 /* Send these packets 352 /* Send these packets
@@ -397,7 +362,6 @@ int et131x_send_packets(struct sk_buff *skb, struct net_device *netdev)
397 * packet under Linux; if we just send an error up to the 362 * packet under Linux; if we just send an error up to the
398 * netif layer, it will resend the skb to us. 363 * netif layer, it will resend the skb to us.
399 */ 364 */
400 DBG_VERBOSE(et131x_dbginfo, "TCB Resources Not Available\n");
401 status = -ENOMEM; 365 status = -ENOMEM;
402 } else { 366 } else {
403 /* We need to see if the link is up; if it's not, make the 367 /* We need to see if the link is up; if it's not, make the
@@ -409,9 +373,6 @@ int et131x_send_packets(struct sk_buff *skb, struct net_device *netdev)
409 */ 373 */
410 if (MP_SHOULD_FAIL_SEND(etdev) || etdev->DriverNoPhyAccess 374 if (MP_SHOULD_FAIL_SEND(etdev) || etdev->DriverNoPhyAccess
411 || !netif_carrier_ok(netdev)) { 375 || !netif_carrier_ok(netdev)) {
412 DBG_VERBOSE(et131x_dbginfo,
413 "Can't Tx, Link is DOWN; drop the packet\n");
414
415 dev_kfree_skb_any(skb); 376 dev_kfree_skb_any(skb);
416 skb = NULL; 377 skb = NULL;
417 378
@@ -426,24 +387,16 @@ int et131x_send_packets(struct sk_buff *skb, struct net_device *netdev)
426 * send an error up to the netif layer, it 387 * send an error up to the netif layer, it
427 * will resend the skb to us. 388 * will resend the skb to us.
428 */ 389 */
429 DBG_WARNING(et131x_dbginfo,
430 "Resources problem, Queue tx packet\n");
431 } else if (status != 0) { 390 } else if (status != 0) {
432 /* On any other error, make netif think we're 391 /* On any other error, make netif think we're
433 * OK and drop the packet 392 * OK and drop the packet
434 */ 393 */
435 DBG_WARNING(et131x_dbginfo,
436 "General error, drop packet\n");
437
438 dev_kfree_skb_any(skb); 394 dev_kfree_skb_any(skb);
439 skb = NULL; 395 skb = NULL;
440
441 etdev->net_stats.tx_dropped++; 396 etdev->net_stats.tx_dropped++;
442 } 397 }
443 } 398 }
444 } 399 }
445
446 DBG_TX_LEAVE(et131x_dbginfo);
447 return status; 400 return status;
448} 401}
449 402
@@ -464,21 +417,8 @@ static int et131x_send_packet(struct sk_buff *skb,
464 uint16_t *shbufva; 417 uint16_t *shbufva;
465 unsigned long flags; 418 unsigned long flags;
466 419
467 DBG_TX_ENTER(et131x_dbginfo);
468
469 /* Is our buffer scattered, or continuous? */
470 if (skb_shinfo(skb)->nr_frags == 0) {
471 DBG_TX(et131x_dbginfo, "Scattered buffer: NO\n");
472 } else {
473 DBG_TX(et131x_dbginfo, "Scattered buffer: YES, Num Frags: %d\n",
474 skb_shinfo(skb)->nr_frags);
475 }
476
477 /* All packets must have at least a MAC address and a protocol type */ 420 /* All packets must have at least a MAC address and a protocol type */
478 if (skb->len < ETH_HLEN) { 421 if (skb->len < ETH_HLEN) {
479 DBG_ERROR(et131x_dbginfo,
480 "Packet size < ETH_HLEN (14 bytes)\n");
481 DBG_LEAVE(et131x_dbginfo);
482 return -EIO; 422 return -EIO;
483 } 423 }
484 424
@@ -489,9 +429,6 @@ static int et131x_send_packet(struct sk_buff *skb,
489 429
490 if (pMpTcb == NULL) { 430 if (pMpTcb == NULL) {
491 spin_unlock_irqrestore(&etdev->TCBReadyQLock, flags); 431 spin_unlock_irqrestore(&etdev->TCBReadyQLock, flags);
492
493 DBG_WARNING(et131x_dbginfo, "Can't obtain a TCB\n");
494 DBG_TX_LEAVE(et131x_dbginfo);
495 return -ENOMEM; 432 return -ENOMEM;
496 } 433 }
497 434
@@ -533,16 +470,10 @@ static int et131x_send_packet(struct sk_buff *skb,
533 } 470 }
534 471
535 etdev->TxRing.TCBReadyQueueTail = pMpTcb; 472 etdev->TxRing.TCBReadyQueueTail = pMpTcb;
536
537 spin_unlock_irqrestore(&etdev->TCBReadyQLock, flags); 473 spin_unlock_irqrestore(&etdev->TCBReadyQLock, flags);
538
539 DBG_TX_LEAVE(et131x_dbginfo);
540 return status; 474 return status;
541 } 475 }
542 476 WARN_ON(etdev->TxRing.nBusySend > NUM_TCB);
543 DBG_ASSERT(etdev->TxRing.nBusySend <= NUM_TCB);
544
545 DBG_TX_LEAVE(et131x_dbginfo);
546 return 0; 477 return 0;
547} 478}
548 479
@@ -564,8 +495,6 @@ static int nic_send_packet(struct et131x_adapter *etdev, PMP_TCB pMpTcb)
564 struct skb_frag_struct *pFragList = &skb_shinfo(pPacket)->frags[0]; 495 struct skb_frag_struct *pFragList = &skb_shinfo(pPacket)->frags[0];
565 unsigned long flags; 496 unsigned long flags;
566 497
567 DBG_TX_ENTER(et131x_dbginfo);
568
569 /* Part of the optimizations of this send routine restrict us to 498 /* Part of the optimizations of this send routine restrict us to
570 * sending 24 fragments at a pass. In practice we should never see 499 * sending 24 fragments at a pass. In practice we should never see
571 * more than 5 fragments. 500 * more than 5 fragments.
@@ -575,7 +504,6 @@ static int nic_send_packet(struct et131x_adapter *etdev, PMP_TCB pMpTcb)
575 * although it is less efficient. 504 * although it is less efficient.
576 */ 505 */
577 if (FragListCount > 23) { 506 if (FragListCount > 23) {
578 DBG_TX_LEAVE(et131x_dbginfo);
579 return -EIO; 507 return -EIO;
580 } 508 }
581 509
@@ -596,15 +524,7 @@ static int nic_send_packet(struct et131x_adapter *etdev, PMP_TCB pMpTcb)
596 * doesn't seem to like large fragments. 524 * doesn't seem to like large fragments.
597 */ 525 */
598 if ((pPacket->len - pPacket->data_len) <= 1514) { 526 if ((pPacket->len - pPacket->data_len) <= 1514) {
599 DBG_TX(et131x_dbginfo,
600 "Got packet of length %d, "
601 "filling desc entry %d, "
602 "TCB: 0x%p\n",
603 (pPacket->len - pPacket->data_len),
604 etdev->TxRing.txDmaReadyToSend, pMpTcb);
605
606 CurDesc[FragmentNumber].DataBufferPtrHigh = 0; 527 CurDesc[FragmentNumber].DataBufferPtrHigh = 0;
607
608 CurDesc[FragmentNumber].word2.bits. 528 CurDesc[FragmentNumber].word2.bits.
609 length_in_bytes = 529 length_in_bytes =
610 pPacket->len - pPacket->data_len; 530 pPacket->len - pPacket->data_len;
@@ -624,15 +544,7 @@ static int nic_send_packet(struct et131x_adapter *etdev, PMP_TCB pMpTcb)
624 pPacket->data_len, 544 pPacket->data_len,
625 PCI_DMA_TODEVICE); 545 PCI_DMA_TODEVICE);
626 } else { 546 } else {
627 DBG_TX(et131x_dbginfo,
628 "Got packet of length %d, "
629 "filling desc entry %d, "
630 "TCB: 0x%p\n",
631 (pPacket->len - pPacket->data_len),
632 etdev->TxRing.txDmaReadyToSend, pMpTcb);
633
634 CurDesc[FragmentNumber].DataBufferPtrHigh = 0; 547 CurDesc[FragmentNumber].DataBufferPtrHigh = 0;
635
636 CurDesc[FragmentNumber].word2.bits. 548 CurDesc[FragmentNumber].word2.bits.
637 length_in_bytes = 549 length_in_bytes =
638 ((pPacket->len - pPacket->data_len) / 2); 550 ((pPacket->len - pPacket->data_len) / 2);
@@ -675,16 +587,7 @@ static int nic_send_packet(struct et131x_adapter *etdev, PMP_TCB pMpTcb)
675 PCI_DMA_TODEVICE); 587 PCI_DMA_TODEVICE);
676 } 588 }
677 } else { 589 } else {
678 DBG_TX(et131x_dbginfo,
679 "Got packet of length %d,"
680 "filling desc entry %d\n"
681 "TCB: 0x%p\n",
682 pFragList[loopIndex].size,
683 etdev->TxRing.txDmaReadyToSend,
684 pMpTcb);
685
686 CurDesc[FragmentNumber].DataBufferPtrHigh = 0; 590 CurDesc[FragmentNumber].DataBufferPtrHigh = 0;
687
688 CurDesc[FragmentNumber].word2.bits.length_in_bytes = 591 CurDesc[FragmentNumber].word2.bits.length_in_bytes =
689 pFragList[loopIndex - 1].size; 592 pFragList[loopIndex - 1].size;
690 593
@@ -703,10 +606,8 @@ static int nic_send_packet(struct et131x_adapter *etdev, PMP_TCB pMpTcb)
703 } 606 }
704 } 607 }
705 608
706 if (FragmentNumber == 0) { 609 if (FragmentNumber == 0)
707 DBG_WARNING(et131x_dbginfo, "No. frags is 0\n");
708 return -EIO; 610 return -EIO;
709 }
710 611
711 if (etdev->linkspeed == TRUEPHY_SPEED_1000MBPS) { 612 if (etdev->linkspeed == TRUEPHY_SPEED_1000MBPS) {
712 if (++etdev->TxRing.TxPacketsSinceLastinterrupt == 613 if (++etdev->TxRing.TxPacketsSinceLastinterrupt ==
@@ -774,7 +675,7 @@ static int nic_send_packet(struct et131x_adapter *etdev, PMP_TCB pMpTcb)
774 675
775 etdev->TxRing.CurrSendTail = pMpTcb; 676 etdev->TxRing.CurrSendTail = pMpTcb;
776 677
777 DBG_ASSERT(pMpTcb->Next == NULL); 678 WARN_ON(pMpTcb->Next != NULL);
778 679
779 etdev->TxRing.nBusySend++; 680 etdev->TxRing.nBusySend++;
780 681
@@ -791,432 +692,11 @@ static int nic_send_packet(struct et131x_adapter *etdev, PMP_TCB pMpTcb)
791 writel(PARM_TX_TIME_INT_DEF * NANO_IN_A_MICRO, 692 writel(PARM_TX_TIME_INT_DEF * NANO_IN_A_MICRO,
792 &etdev->regs->global.watchdog_timer); 693 &etdev->regs->global.watchdog_timer);
793 } 694 }
794
795 spin_unlock_irqrestore(&etdev->SendHWLock, flags); 695 spin_unlock_irqrestore(&etdev->SendHWLock, flags);
796 696
797 DBG_TX_LEAVE(et131x_dbginfo);
798 return 0; 697 return 0;
799} 698}
800 699
801/*
802 * NOTE: For now, keep this older version of NICSendPacket around for
803 * reference, even though it's not used
804 */
805#if 0
806
807/**
808 * NICSendPacket - NIC specific send handler.
809 * @etdev: pointer to our adapter
810 * @pMpTcb: pointer to MP_TCB
811 *
812 * Returns 0 on succes, errno on failure.
813 *
814 * This version of the send routine is designed for version A silicon.
815 * Assumption - Send spinlock has been acquired.
816 */
817static int nic_send_packet(struct et131x_adapter *etdev, PMP_TCB pMpTcb)
818{
819 uint32_t loopIndex, fragIndex, loopEnd;
820 uint32_t splitfirstelem = 0;
821 uint32_t SegmentSize = 0;
822 TX_DESC_ENTRY_t CurDesc;
823 TX_DESC_ENTRY_t *CurDescPostCopy = NULL;
824 uint32_t SlotsAvailable;
825 DMA10W_t ServiceComplete;
826 unsigned int flags;
827 struct sk_buff *pPacket = pMpTcb->Packet;
828 uint32_t FragListCount = skb_shinfo(pPacket)->nr_frags + 1;
829 struct skb_frag_struct *pFragList = &skb_shinfo(pPacket)->frags[0];
830
831 DBG_TX_ENTER(et131x_dbginfo);
832
833 ServiceComplete.value =
834 readl(&etdev->regs->txdma.NewServiceComplete.value);
835
836 /*
837 * Attempt to fix TWO hardware bugs:
838 * 1) NEVER write an odd number of descriptors.
839 * 2) If packet length is less than NIC_MIN_PACKET_SIZE, then pad the
840 * packet to NIC_MIN_PACKET_SIZE bytes by adding a new last
841 * descriptor IN HALF DUPLEX MODE ONLY
842 * NOTE that (2) interacts with (1). If the packet is less than
843 * NIC_MIN_PACKET_SIZE bytes then we will append a descriptor.
844 * Therefore if it is even now, it will eventually end up odd, and
845 * so will need adjusting.
846 *
847 * VLAN tags get involved since VLAN tags add another one or two
848 * segments.
849 */
850 DBG_TX(et131x_dbginfo,
851 "pMpTcb->PacketLength: %d\n", pMpTcb->PacketLength);
852
853 if ((etdev->duplex_mode == 0)
854 && (pMpTcb->PacketLength < NIC_MIN_PACKET_SIZE)) {
855 DBG_TX(et131x_dbginfo,
856 "HALF DUPLEX mode AND len < MIN_PKT_SIZE\n");
857 if ((FragListCount & 0x1) == 0) {
858 DBG_TX(et131x_dbginfo,
859 "Even number of descs, split 1st elem\n");
860 splitfirstelem = 1;
861 /* SegmentSize = pFragList[0].size / 2; */
862 SegmentSize = (pPacket->len - pPacket->data_len) / 2;
863 }
864 } else if (FragListCount & 0x1) {
865 DBG_TX(et131x_dbginfo, "Odd number of descs, split 1st elem\n");
866
867 splitfirstelem = 1;
868 /* SegmentSize = pFragList[0].size / 2; */
869 SegmentSize = (pPacket->len - pPacket->data_len) / 2;
870 }
871
872 spin_lock_irqsave(&etdev->SendHWLock, flags);
873
874 if (etdev->TxRing.txDmaReadyToSend.bits.serv_req_wrap ==
875 ServiceComplete.bits.serv_cpl_wrap) {
876 /* The ring hasn't wrapped. Slots available should be
877 * (RING_SIZE) - the difference between the two pointers.
878 */
879 SlotsAvailable = NUM_DESC_PER_RING_TX -
880 (etdev->TxRing.txDmaReadyToSend.bits.serv_req -
881 ServiceComplete.bits.serv_cpl);
882 } else {
883 /* The ring has wrapped. Slots available should be the
884 * difference between the two pointers.
885 */
886 SlotsAvailable = ServiceComplete.bits.serv_cpl -
887 etdev->TxRing.txDmaReadyToSend.bits.serv_req;
888 }
889
890 if ((FragListCount + splitfirstelem) > SlotsAvailable) {
891 DBG_WARNING(et131x_dbginfo,
892 "Not Enough Space in Tx Desc Ring\n");
893 spin_unlock_irqrestore(&etdev->SendHWLock, flags);
894 return -ENOMEM;
895 }
896
897 loopEnd = (FragListCount) + splitfirstelem;
898 fragIndex = 0;
899
900 DBG_TX(et131x_dbginfo,
901 "TCB : 0x%p\n"
902 "Packet (SKB) : 0x%p\t Packet->len: %d\t Packet->data_len: %d\n"
903 "FragListCount : %d\t splitfirstelem: %d\t loopEnd:%d\n",
904 pMpTcb,
905 pPacket, pPacket->len, pPacket->data_len,
906 FragListCount, splitfirstelem, loopEnd);
907
908 for (loopIndex = 0; loopIndex < loopEnd; loopIndex++) {
909 if (loopIndex > splitfirstelem)
910 fragIndex++;
911
912 DBG_TX(et131x_dbginfo,
913 "In loop, loopIndex: %d\t fragIndex: %d\n", loopIndex,
914 fragIndex);
915
916 /* If there is something in this element, let's get a
917 * descriptor from the ring and get the necessary data
918 */
919 DBG_TX(et131x_dbginfo,
920 "Packet Length %d,"
921 "filling desc entry %d\n",
922 pPacket->len,
923 etdev->TxRing.txDmaReadyToSend.bits.serv_req);
924
925 /*
926 * NOTE - Should we do a paranoia check here to make sure the fragment
927 * actually has a length? It's HIGHLY unlikely the fragment would
928 * contain no data...
929 */
930 if (1) {
931 /* NOTE - Currently always getting 32-bit addrs, and
932 * dma_addr_t is only 32-bit, so leave "high" ptr
933 * value out for now
934 * CurDesc.DataBufferPtrHigh = 0;
935 */
936
937 CurDesc.word2.value = 0;
938 CurDesc.word3.value = 0;
939
940 if (fragIndex == 0) {
941 if (splitfirstelem) {
942 DBG_TX(et131x_dbginfo,
943 "Split first element: YES\n");
944
945 if (loopIndex == 0) {
946 DBG_TX(et131x_dbginfo,
947 "Got fragment of length %d, fragIndex: %d\n",
948 pPacket->len -
949 pPacket->data_len,
950 fragIndex);
951 DBG_TX(et131x_dbginfo,
952 "SegmentSize: %d\n",
953 SegmentSize);
954
955 CurDesc.word2.bits.
956 length_in_bytes =
957 SegmentSize;
958 CurDesc.DataBufferPtrLow =
959 pci_map_single(etdev->
960 pdev,
961 pPacket->
962 data,
963 SegmentSize,
964 PCI_DMA_TODEVICE);
965 DBG_TX(et131x_dbginfo,
966 "pci_map_single() returns: 0x%08x\n",
967 CurDesc.
968 DataBufferPtrLow);
969 } else {
970 DBG_TX(et131x_dbginfo,
971 "Got fragment of length %d, fragIndex: %d\n",
972 pPacket->len -
973 pPacket->data_len,
974 fragIndex);
975 DBG_TX(et131x_dbginfo,
976 "Leftover Size: %d\n",
977 (pPacket->len -
978 pPacket->data_len -
979 SegmentSize));
980
981 CurDesc.word2.bits.
982 length_in_bytes =
983 ((pPacket->len -
984 pPacket->data_len) -
985 SegmentSize);
986 CurDesc.DataBufferPtrLow =
987 pci_map_single(etdev->
988 pdev,
989 (pPacket->
990 data +
991 SegmentSize),
992 (pPacket->
993 len -
994 pPacket->
995 data_len -
996 SegmentSize),
997 PCI_DMA_TODEVICE);
998 DBG_TX(et131x_dbginfo,
999 "pci_map_single() returns: 0x%08x\n",
1000 CurDesc.
1001 DataBufferPtrLow);
1002 }
1003 } else {
1004 DBG_TX(et131x_dbginfo,
1005 "Split first element: NO\n");
1006
1007 CurDesc.word2.bits.length_in_bytes =
1008 pPacket->len - pPacket->data_len;
1009
1010 CurDesc.DataBufferPtrLow =
1011 pci_map_single(etdev->pdev,
1012 pPacket->data,
1013 (pPacket->len -
1014 pPacket->data_len),
1015 PCI_DMA_TODEVICE);
1016 DBG_TX(et131x_dbginfo,
1017 "pci_map_single() returns: 0x%08x\n",
1018 CurDesc.DataBufferPtrLow);
1019 }
1020 } else {
1021
1022 CurDesc.word2.bits.length_in_bytes =
1023 pFragList[fragIndex - 1].size;
1024 CurDesc.DataBufferPtrLow =
1025 pci_map_page(etdev->pdev,
1026 pFragList[fragIndex - 1].page,
1027 pFragList[fragIndex -
1028 1].page_offset,
1029 pFragList[fragIndex - 1].size,
1030 PCI_DMA_TODEVICE);
1031 DBG_TX(et131x_dbginfo,
1032 "pci_map_page() returns: 0x%08x\n",
1033 CurDesc.DataBufferPtrLow);
1034 }
1035
1036 if (loopIndex == 0) {
1037 /* This is the first descriptor of the packet
1038 *
1039 * Set the "f" bit to indicate this is the
1040 * first descriptor in the packet.
1041 */
1042 DBG_TX(et131x_dbginfo,
1043 "This is our FIRST descriptor\n");
1044 CurDesc.word3.bits.f = 1;
1045
1046 pMpTcb->WrIndexStart =
1047 etdev->TxRing.txDmaReadyToSend;
1048 }
1049
1050 if ((loopIndex == (loopEnd - 1)) &&
1051 (etdev->duplex_mode ||
1052 (pMpTcb->PacketLength >= NIC_MIN_PACKET_SIZE))) {
1053 /* This is the Last descriptor of the packet */
1054 DBG_TX(et131x_dbginfo,
1055 "THIS is our LAST descriptor\n");
1056
1057 if (etdev->linkspeed ==
1058 TRUEPHY_SPEED_1000MBPS) {
1059 if (++etdev->TxRing.
1060 TxPacketsSinceLastinterrupt >=
1061 PARM_TX_NUM_BUFS_DEF) {
1062 CurDesc.word3.value = 0x5;
1063 etdev->TxRing.
1064 TxPacketsSinceLastinterrupt
1065 = 0;
1066 } else {
1067 CurDesc.word3.value = 0x1;
1068 }
1069 } else {
1070 CurDesc.word3.value = 0x5;
1071 }
1072
1073 /* Following index will be used during freeing
1074 * of packet
1075 */
1076 pMpTcb->WrIndex =
1077 etdev->TxRing.txDmaReadyToSend;
1078 pMpTcb->PacketStaleCount = 0;
1079 }
1080
1081 /* Copy the descriptor (filled above) into the
1082 * descriptor ring at the next free entry. Advance
1083 * the "next free entry" variable
1084 */
1085 memcpy(etdev->TxRing.pTxDescRingVa +
1086 etdev->TxRing.txDmaReadyToSend.bits.serv_req,
1087 &CurDesc, sizeof(TX_DESC_ENTRY_t));
1088
1089 CurDescPostCopy =
1090 etdev->TxRing.pTxDescRingVa +
1091 etdev->TxRing.txDmaReadyToSend.bits.serv_req;
1092
1093 DBG_TX(et131x_dbginfo,
1094 "CURRENT DESCRIPTOR\n"
1095 "\tAddress : 0x%p\n"
1096 "\tDataBufferPtrHigh : 0x%08x\n"
1097 "\tDataBufferPtrLow : 0x%08x\n"
1098 "\tword2 : 0x%08x\n"
1099 "\tword3 : 0x%08x\n",
1100 CurDescPostCopy,
1101 CurDescPostCopy->DataBufferPtrHigh,
1102 CurDescPostCopy->DataBufferPtrLow,
1103 CurDescPostCopy->word2.value,
1104 CurDescPostCopy->word3.value);
1105
1106 if (++etdev->TxRing.txDmaReadyToSend.bits.serv_req >=
1107 NUM_DESC_PER_RING_TX) {
1108 if (etdev->TxRing.txDmaReadyToSend.bits.
1109 serv_req_wrap) {
1110 etdev->TxRing.txDmaReadyToSend.
1111 value = 0;
1112 } else {
1113 etdev->TxRing.txDmaReadyToSend.
1114 value = 0x400;
1115 }
1116 }
1117 }
1118 }
1119
1120 if (etdev->duplex_mode == 0 &&
1121 pMpTcb->PacketLength < NIC_MIN_PACKET_SIZE) {
1122 /* NOTE - Same 32/64-bit issue as above... */
1123 CurDesc.DataBufferPtrHigh = 0x0;
1124 CurDesc.DataBufferPtrLow = etdev->TxRing.pTxDummyBlkPa;
1125 CurDesc.word2.value = 0;
1126
1127 if (etdev->linkspeed == TRUEPHY_SPEED_1000MBPS) {
1128 if (++etdev->TxRing.TxPacketsSinceLastinterrupt >=
1129 PARM_TX_NUM_BUFS_DEF) {
1130 CurDesc.word3.value = 0x5;
1131 etdev->TxRing.TxPacketsSinceLastinterrupt =
1132 0;
1133 } else {
1134 CurDesc.word3.value = 0x1;
1135 }
1136 } else {
1137 CurDesc.word3.value = 0x5;
1138 }
1139
1140 CurDesc.word2.bits.length_in_bytes =
1141 NIC_MIN_PACKET_SIZE - pMpTcb->PacketLength;
1142
1143 pMpTcb->WrIndex = etdev->TxRing.txDmaReadyToSend;
1144
1145 memcpy(etdev->TxRing.pTxDescRingVa +
1146 etdev->TxRing.txDmaReadyToSend.bits.serv_req,
1147 &CurDesc, sizeof(TX_DESC_ENTRY_t));
1148
1149 CurDescPostCopy =
1150 etdev->TxRing.pTxDescRingVa +
1151 etdev->TxRing.txDmaReadyToSend.bits.serv_req;
1152
1153 DBG_TX(et131x_dbginfo,
1154 "CURRENT DESCRIPTOR\n"
1155 "\tAddress : 0x%p\n"
1156 "\tDataBufferPtrHigh : 0x%08x\n"
1157 "\tDataBufferPtrLow : 0x%08x\n"
1158 "\tword2 : 0x%08x\n"
1159 "\tword3 : 0x%08x\n",
1160 CurDescPostCopy,
1161 CurDescPostCopy->DataBufferPtrHigh,
1162 CurDescPostCopy->DataBufferPtrLow,
1163 CurDescPostCopy->word2.value,
1164 CurDescPostCopy->word3.value);
1165
1166 if (++etdev->TxRing.txDmaReadyToSend.bits.serv_req >=
1167 NUM_DESC_PER_RING_TX) {
1168 if (etdev->TxRing.txDmaReadyToSend.bits.
1169 serv_req_wrap) {
1170 etdev->TxRing.txDmaReadyToSend.value = 0;
1171 } else {
1172 etdev->TxRing.txDmaReadyToSend.value = 0x400;
1173 }
1174 }
1175
1176 DBG_TX(et131x_dbginfo, "Padding descriptor %d by %d bytes\n",
1177 /* etdev->TxRing.txDmaReadyToSend.value, */
1178 etdev->TxRing.txDmaReadyToSend.bits.serv_req,
1179 NIC_MIN_PACKET_SIZE - pMpTcb->PacketLength);
1180 }
1181
1182 spin_lock(&etdev->TCBSendQLock);
1183
1184 if (etdev->TxRing.CurrSendTail)
1185 etdev->TxRing.CurrSendTail->Next = pMpTcb;
1186 else
1187 etdev->TxRing.CurrSendHead = pMpTcb;
1188
1189 etdev->TxRing.CurrSendTail = pMpTcb;
1190
1191 DBG_ASSERT(pMpTcb->Next == NULL);
1192
1193 etdev->TxRing.nBusySend++;
1194
1195 spin_unlock(&etdev->TCBSendQLock);
1196
1197 /* Write the new write pointer back to the device. */
1198 writel(etdev->TxRing.txDmaReadyToSend.value,
1199 &etdev->regs->txdma.service_request.value);
1200
1201#ifdef CONFIG_ET131X_DEBUG
1202 DumpDeviceBlock(DBG_TX_ON, etdev, 1);
1203#endif
1204
1205 /* For Gig only, we use Tx Interrupt coalescing. Enable the software
1206 * timer to wake us up if this packet isn't followed by N more.
1207 */
1208 if (etdev->linkspeed == TRUEPHY_SPEED_1000MBPS) {
1209 writel(PARM_TX_TIME_INT_DEF * NANO_IN_A_MICRO,
1210 &etdev->regs->global.watchdog_timer);
1211 }
1212
1213 spin_unlock_irqrestore(&etdev->SendHWLock, flags);
1214
1215 DBG_TX_LEAVE(et131x_dbginfo);
1216 return 0;
1217}
1218
1219#endif
1220 700
1221/** 701/**
1222 * et131x_free_send_packet - Recycle a MP_TCB, complete the packet if necessary 702 * et131x_free_send_packet - Recycle a MP_TCB, complete the packet if necessary
@@ -1246,37 +726,11 @@ inline void et131x_free_send_packet(struct et131x_adapter *etdev,
1246 * corresponding to this packet and umap the fragments 726 * corresponding to this packet and umap the fragments
1247 * they point to 727 * they point to
1248 */ 728 */
1249 DBG_TX(et131x_dbginfo,
1250 "Unmap descriptors Here\n"
1251 "TCB : 0x%p\n"
1252 "TCB Next : 0x%p\n"
1253 "TCB PacketLength : %d\n"
1254 "TCB WrIndexS.value : 0x%08x\n"
1255 "TCB WrIndex.value : 0x%08x\n",
1256 pMpTcb,
1257 pMpTcb->Next,
1258 pMpTcb->PacketLength,
1259 pMpTcb->WrIndexStart,
1260 pMpTcb->WrIndex);
1261
1262 do { 729 do {
1263 desc = 730 desc =
1264 (TX_DESC_ENTRY_t *) (etdev->TxRing.pTxDescRingVa + 731 (TX_DESC_ENTRY_t *) (etdev->TxRing.pTxDescRingVa +
1265 INDEX10(pMpTcb->WrIndexStart)); 732 INDEX10(pMpTcb->WrIndexStart));
1266 733
1267 DBG_TX(et131x_dbginfo,
1268 "CURRENT DESCRIPTOR\n"
1269 "\tAddress : 0x%p\n"
1270 "\tDataBufferPtrHigh : 0x%08x\n"
1271 "\tDataBufferPtrLow : 0x%08x\n"
1272 "\tword2 : 0x%08x\n"
1273 "\tword3 : 0x%08x\n",
1274 desc,
1275 desc->DataBufferPtrHigh,
1276 desc->DataBufferPtrLow,
1277 desc->word2.value,
1278 desc->word3.value);
1279
1280 pci_unmap_single(etdev->pdev, 734 pci_unmap_single(etdev->pdev,
1281 desc->DataBufferPtrLow, 735 desc->DataBufferPtrLow,
1282 desc->word2.value, PCI_DMA_TODEVICE); 736 desc->word2.value, PCI_DMA_TODEVICE);
@@ -1290,9 +744,6 @@ inline void et131x_free_send_packet(struct et131x_adapter *etdev,
1290 } while (desc != (etdev->TxRing.pTxDescRingVa + 744 } while (desc != (etdev->TxRing.pTxDescRingVa +
1291 INDEX10(pMpTcb->WrIndex))); 745 INDEX10(pMpTcb->WrIndex)));
1292 746
1293 DBG_TX(et131x_dbginfo,
1294 "Free Packet (SKB) : 0x%p\n", pMpTcb->Packet);
1295
1296 dev_kfree_skb_any(pMpTcb->Packet); 747 dev_kfree_skb_any(pMpTcb->Packet);
1297 } 748 }
1298 749
@@ -1313,8 +764,7 @@ inline void et131x_free_send_packet(struct et131x_adapter *etdev,
1313 etdev->TxRing.TCBReadyQueueTail = pMpTcb; 764 etdev->TxRing.TCBReadyQueueTail = pMpTcb;
1314 765
1315 spin_unlock_irqrestore(&etdev->TCBReadyQLock, flags); 766 spin_unlock_irqrestore(&etdev->TCBReadyQLock, flags);
1316 767 WARN_ON(etdev->TxRing.nBusySend < 0);
1317 DBG_ASSERT(etdev->TxRing.nBusySend >= 0);
1318} 768}
1319 769
1320/** 770/**
@@ -1330,8 +780,6 @@ void et131x_free_busy_send_packets(struct et131x_adapter *etdev)
1330 unsigned long flags; 780 unsigned long flags;
1331 uint32_t FreeCounter = 0; 781 uint32_t FreeCounter = 0;
1332 782
1333 DBG_ENTER(et131x_dbginfo);
1334
1335 while (!list_empty(&etdev->TxRing.SendWaitQueue)) { 783 while (!list_empty(&etdev->TxRing.SendWaitQueue)) {
1336 spin_lock_irqsave(&etdev->SendWaitLock, flags); 784 spin_lock_irqsave(&etdev->SendWaitLock, flags);
1337 785
@@ -1360,8 +808,6 @@ void et131x_free_busy_send_packets(struct et131x_adapter *etdev)
1360 808
1361 spin_unlock_irqrestore(&etdev->TCBSendQLock, flags); 809 spin_unlock_irqrestore(&etdev->TCBSendQLock, flags);
1362 810
1363 DBG_VERBOSE(et131x_dbginfo, "pMpTcb = 0x%p\n", pMpTcb);
1364
1365 FreeCounter++; 811 FreeCounter++;
1366 et131x_free_send_packet(etdev, pMpTcb); 812 et131x_free_send_packet(etdev, pMpTcb);
1367 813
@@ -1370,17 +816,11 @@ void et131x_free_busy_send_packets(struct et131x_adapter *etdev)
1370 pMpTcb = etdev->TxRing.CurrSendHead; 816 pMpTcb = etdev->TxRing.CurrSendHead;
1371 } 817 }
1372 818
1373 if (FreeCounter == NUM_TCB) { 819 WARN_ON(FreeCounter == NUM_TCB);
1374 DBG_ERROR(et131x_dbginfo,
1375 "MpFreeBusySendPackets exited loop for a bad reason\n");
1376 BUG();
1377 }
1378 820
1379 spin_unlock_irqrestore(&etdev->TCBSendQLock, flags); 821 spin_unlock_irqrestore(&etdev->TCBSendQLock, flags);
1380 822
1381 etdev->TxRing.nBusySend = 0; 823 etdev->TxRing.nBusySend = 0;
1382
1383 DBG_LEAVE(et131x_dbginfo);
1384} 824}
1385 825
1386/** 826/**
@@ -1394,8 +834,6 @@ void et131x_free_busy_send_packets(struct et131x_adapter *etdev)
1394 */ 834 */
1395void et131x_handle_send_interrupt(struct et131x_adapter *etdev) 835void et131x_handle_send_interrupt(struct et131x_adapter *etdev)
1396{ 836{
1397 DBG_TX_ENTER(et131x_dbginfo);
1398
1399 /* Mark as completed any packets which have been sent by the device. */ 837 /* Mark as completed any packets which have been sent by the device. */
1400 et131x_update_tcb_list(etdev); 838 et131x_update_tcb_list(etdev);
1401 839
@@ -1403,8 +841,6 @@ void et131x_handle_send_interrupt(struct et131x_adapter *etdev)
1403 * dequeue and send those packets now, as long as we have free TCBs. 841 * dequeue and send those packets now, as long as we have free TCBs.
1404 */ 842 */
1405 et131x_check_send_wait_list(etdev); 843 et131x_check_send_wait_list(etdev);
1406
1407 DBG_TX_LEAVE(et131x_dbginfo);
1408} 844}
1409 845
1410/** 846/**
@@ -1487,15 +923,9 @@ static void et131x_check_send_wait_list(struct et131x_adapter *etdev)
1487 MP_TCB_RESOURCES_AVAILABLE(etdev)) { 923 MP_TCB_RESOURCES_AVAILABLE(etdev)) {
1488 struct list_head *entry; 924 struct list_head *entry;
1489 925
1490 DBG_VERBOSE(et131x_dbginfo, "Tx packets on the wait queue\n");
1491
1492 entry = etdev->TxRing.SendWaitQueue.next; 926 entry = etdev->TxRing.SendWaitQueue.next;
1493 927
1494 etdev->TxRing.nWaitSend--; 928 etdev->TxRing.nWaitSend--;
1495
1496 DBG_WARNING(et131x_dbginfo,
1497 "MpHandleSendInterrupt - sent a queued pkt. Waiting %d\n",
1498 etdev->TxRing.nWaitSend);
1499 } 929 }
1500 930
1501 spin_unlock_irqrestore(&etdev->SendWaitLock, flags); 931 spin_unlock_irqrestore(&etdev->SendWaitLock, flags);
diff --git a/drivers/staging/et131x/et131x_adapter.h b/drivers/staging/et131x/et131x_adapter.h
index 4e795f0b076e..1dfe06f1b1a7 100644
--- a/drivers/staging/et131x/et131x_adapter.h
+++ b/drivers/staging/et131x/et131x_adapter.h
@@ -176,13 +176,6 @@ typedef struct _ce_stats_t {
176 u32 code_violations; 176 u32 code_violations;
177 u32 other_errors; 177 u32 other_errors;
178 178
179#ifdef CONFIG_ET131X_DEBUG
180 u32 UnhandledInterruptsPerSec;
181 u32 RxDmaInterruptsPerSec;
182 u32 TxDmaInterruptsPerSec;
183 u32 WatchDogInterruptsPerSec;
184#endif /* CONFIG_ET131X_DEBUG */
185
186 u32 SynchrounousIterations; 179 u32 SynchrounousIterations;
187 u32 InterruptStatus; 180 u32 InterruptStatus;
188} CE_STATS_t, *PCE_STATS_t; 181} CE_STATS_t, *PCE_STATS_t;
diff --git a/drivers/staging/et131x/et131x_debug.c b/drivers/staging/et131x/et131x_debug.c
deleted file mode 100644
index 945b4b542ada..000000000000
--- a/drivers/staging/et131x/et131x_debug.c
+++ /dev/null
@@ -1,208 +0,0 @@
1/*
2 * Agere Systems Inc.
3 * 10/100/1000 Base-T Ethernet Driver for the ET1301 and ET131x series MACs
4 *
5 * Copyright © 2005 Agere Systems Inc.
6 * All rights reserved.
7 * http://www.agere.com
8 *
9 *------------------------------------------------------------------------------
10 *
11 * et131x_debug.c - Routines used for debugging.
12 *
13 *------------------------------------------------------------------------------
14 *
15 * SOFTWARE LICENSE
16 *
17 * This software is provided subject to the following terms and conditions,
18 * which you should read carefully before using the software. Using this
19 * software indicates your acceptance of these terms and conditions. If you do
20 * not agree with these terms and conditions, do not use the software.
21 *
22 * Copyright © 2005 Agere Systems Inc.
23 * All rights reserved.
24 *
25 * Redistribution and use in source or binary forms, with or without
26 * modifications, are permitted provided that the following conditions are met:
27 *
28 * . Redistributions of source code must retain the above copyright notice, this
29 * list of conditions and the following Disclaimer as comments in the code as
30 * well as in the documentation and/or other materials provided with the
31 * distribution.
32 *
33 * . Redistributions in binary form must reproduce the above copyright notice,
34 * this list of conditions and the following Disclaimer in the documentation
35 * and/or other materials provided with the distribution.
36 *
37 * . Neither the name of Agere Systems Inc. nor the names of the contributors
38 * may be used to endorse or promote products derived from this software
39 * without specific prior written permission.
40 *
41 * Disclaimer
42 *
43 * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
44 * INCLUDING, BUT NOT LIMITED TO, INFRINGEMENT AND THE IMPLIED WARRANTIES OF
45 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. ANY
46 * USE, MODIFICATION OR DISTRIBUTION OF THIS SOFTWARE IS SOLELY AT THE USERS OWN
47 * RISK. IN NO EVENT SHALL AGERE SYSTEMS INC. OR CONTRIBUTORS BE LIABLE FOR ANY
48 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
49 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
50 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
51 * ON ANY THEORY OF LIABILITY, INCLUDING, BUT NOT LIMITED TO, CONTRACT, STRICT
52 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
53 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
54 * DAMAGE.
55 *
56 */
57
58#ifdef CONFIG_ET131X_DEBUG
59
60#include "et131x_version.h"
61#include "et131x_debug.h"
62#include "et131x_defs.h"
63
64#include <linux/pci.h>
65#include <linux/init.h>
66#include <linux/module.h>
67#include <linux/types.h>
68#include <linux/kernel.h>
69
70#include <linux/sched.h>
71#include <linux/ptrace.h>
72#include <linux/slab.h>
73#include <linux/ctype.h>
74#include <linux/string.h>
75#include <linux/timer.h>
76#include <linux/interrupt.h>
77#include <linux/in.h>
78#include <linux/delay.h>
79#include <linux/io.h>
80#include <linux/bitops.h>
81#include <asm/system.h>
82
83#include <linux/netdevice.h>
84#include <linux/etherdevice.h>
85#include <linux/skbuff.h>
86#include <linux/if_arp.h>
87#include <linux/ioport.h>
88#include <linux/random.h>
89
90#include "et1310_phy.h"
91#include "et1310_pm.h"
92#include "et1310_jagcore.h"
93
94#include "et131x_adapter.h"
95#include "et131x_netdev.h"
96#include "et131x_config.h"
97#include "et131x_isr.h"
98
99#include "et1310_address_map.h"
100#include "et1310_tx.h"
101#include "et1310_rx.h"
102#include "et1310_mac.h"
103
104/* Data for debugging facilities */
105extern dbg_info_t *et131x_dbginfo;
106
107/**
108 * DumpTxQueueContents - Dump out the tx queue and the shadow pointers
109 * @etdev: pointer to our adapter structure
110 */
111void DumpTxQueueContents(int debug, struct et131x_adapter *etdev)
112{
113 MMC_t __iomem *mmc = &etdev->regs->mmc;
114 u32 txq_addr;
115
116 if (DBG_FLAGS(et131x_dbginfo) & debug) {
117 for (txq_addr = 0x200; txq_addr < 0x3ff; txq_addr++) {
118 u32 sram_access = readl(&mmc->sram_access);
119 sram_access &= 0xFFFF;
120 sram_access |= (txq_addr << 16) | ET_SRAM_REQ_ACCESS;
121 writel(sram_access, &mmc->sram_access);
122
123 DBG_PRINT("Addr 0x%x, Access 0x%08x\t"
124 "Value 1 0x%08x, Value 2 0x%08x, "
125 "Value 3 0x%08x, Value 4 0x%08x, \n",
126 txq_addr,
127 readl(&mmc->sram_access),
128 readl(&mmc->sram_word1),
129 readl(&mmc->sram_word2),
130 readl(&mmc->sram_word3),
131 readl(&mmc->sram_word4));
132 }
133
134 DBG_PRINT("Shadow Pointers 0x%08x\n",
135 readl(&etdev->regs->txmac.shadow_ptr.value));
136 }
137}
138
139#define NUM_BLOCKS 8
140
141static const char *BlockNames[NUM_BLOCKS] = {
142 "Global", "Tx DMA", "Rx DMA", "Tx MAC",
143 "Rx MAC", "MAC", "MAC Stat", "MMC"
144};
145
146
147/**
148 * DumpDeviceBlock
149 * @etdev: pointer to our adapter
150 *
151 * Dumps the first 64 regs of each block of the et-1310 (each block is
152 * mapped to a new page, each page is 4096 bytes).
153 */
154void DumpDeviceBlock(int debug, struct et131x_adapter *etdev,
155 u32 block)
156{
157 u32 addr1, addr2;
158 u32 __iomem *regs = (u32 __iomem *) etdev->regs;
159
160 /* Output the debug counters to the debug terminal */
161 if (DBG_FLAGS(et131x_dbginfo) & debug) {
162 DBG_PRINT("%s block\n", BlockNames[block]);
163 regs += block * 1024;
164 for (addr1 = 0; addr1 < 8; addr1++) {
165 for (addr2 = 0; addr2 < 8; addr2++) {
166 if (block == 0 &&
167 (addr1 * 8 + addr2) == 6)
168 DBG_PRINT(" ISR , ");
169 else
170 DBG_PRINT("0x%08x, ", readl(regs++));
171 }
172 DBG_PRINT("\n");
173 }
174 DBG_PRINT("\n");
175 }
176}
177
178/**
179 * DumpDeviceReg
180 * @etdev: pointer to our adapter
181 *
182 * Dumps the first 64 regs of each block of the et-1310 (each block is
183 * mapped to a new page, each page is 4096 bytes).
184 */
185void DumpDeviceReg(int debug, struct et131x_adapter *etdev)
186{
187 u32 addr1, addr2;
188 u32 block;
189 u32 __iomem *regs = (u32 __iomem *)etdev->regs;
190 u32 __iomem *p;
191
192 /* Output the debug counters to the debug terminal */
193 if (DBG_FLAGS(et131x_dbginfo) & debug) {
194 for (block = 0; block < NUM_BLOCKS; block++) {
195 DBG_PRINT("%s block\n", BlockNames[block]);
196 p = regs + block * 1024;
197
198 for (addr1 = 0; addr1 < 8; addr1++) {
199 for (addr2 = 0; addr2 < 8; addr2++)
200 DBG_PRINT("0x%08x, ", readl(p++));
201 DBG_PRINT("\n");
202 }
203 DBG_PRINT("\n");
204 }
205 }
206}
207
208#endif /* CONFIG_ET131X_DEBUG */
diff --git a/drivers/staging/et131x/et131x_debug.h b/drivers/staging/et131x/et131x_debug.h
deleted file mode 100644
index 7c70e230ccd2..000000000000
--- a/drivers/staging/et131x/et131x_debug.h
+++ /dev/null
@@ -1,255 +0,0 @@
1/*
2 * Agere Systems Inc.
3 * 10/100/1000 Base-T Ethernet Driver for the ET1301 and ET131x series MACs
4 *
5 * Copyright © 2005 Agere Systems Inc.
6 * All rights reserved.
7 * http://www.agere.com
8 *
9 *------------------------------------------------------------------------------
10 *
11 * et131x_debug.h - Defines, structs, enums, prototypes, etc. used for
12 * outputting debug messages to the system logging facility
13 * (ksyslogd)
14 *
15 *------------------------------------------------------------------------------
16 *
17 * SOFTWARE LICENSE
18 *
19 * This software is provided subject to the following terms and conditions,
20 * which you should read carefully before using the software. Using this
21 * software indicates your acceptance of these terms and conditions. If you do
22 * not agree with these terms and conditions, do not use the software.
23 *
24 * Copyright © 2005 Agere Systems Inc.
25 * All rights reserved.
26 *
27 * Redistribution and use in source or binary forms, with or without
28 * modifications, are permitted provided that the following conditions are met:
29 *
30 * . Redistributions of source code must retain the above copyright notice, this
31 * list of conditions and the following Disclaimer as comments in the code as
32 * well as in the documentation and/or other materials provided with the
33 * distribution.
34 *
35 * . Redistributions in binary form must reproduce the above copyright notice,
36 * this list of conditions and the following Disclaimer in the documentation
37 * and/or other materials provided with the distribution.
38 *
39 * . Neither the name of Agere Systems Inc. nor the names of the contributors
40 * may be used to endorse or promote products derived from this software
41 * without specific prior written permission.
42 *
43 * Disclaimer
44 *
45 * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
46 * INCLUDING, BUT NOT LIMITED TO, INFRINGEMENT AND THE IMPLIED WARRANTIES OF
47 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. ANY
48 * USE, MODIFICATION OR DISTRIBUTION OF THIS SOFTWARE IS SOLELY AT THE USERS OWN
49 * RISK. IN NO EVENT SHALL AGERE SYSTEMS INC. OR CONTRIBUTORS BE LIABLE FOR ANY
50 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
51 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
52 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
53 * ON ANY THEORY OF LIABILITY, INCLUDING, BUT NOT LIMITED TO, CONTRACT, STRICT
54 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
55 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
56 * DAMAGE.
57 *
58 */
59
60#ifndef __ET131X_DBG_H__
61#define __ET131X_DBG_H__
62
63/* Define Masks for debugging types/levels */
64#define DBG_ERROR_ON 0x00000001L
65#define DBG_WARNING_ON 0x00000002L
66#define DBG_NOTICE_ON 0x00000004L
67#define DBG_TRACE_ON 0x00000008L
68#define DBG_VERBOSE_ON 0x00000010L
69#define DBG_PARAM_ON 0x00000020L
70#define DBG_BREAK_ON 0x00000040L
71#define DBG_RX_ON 0x00000100L
72#define DBG_TX_ON 0x00000200L
73
74#ifdef CONFIG_ET131X_DEBUG
75
76/*
77 * Set the level of debugging if not done with a preprocessor define. See
78 * et131x_main.c, function et131x_init_module() for how the debug level
79 * translates into the types of messages displayed.
80 */
81#ifndef DBG_LVL
82#define DBG_LVL 3
83#endif /* DBG_LVL */
84
85#define DBG_DEFAULTS (DBG_ERROR_ON | DBG_WARNING_ON | DBG_BREAK_ON)
86
87#define DBG_FLAGS(A) ((A)->dbgFlags)
88#define DBG_NAME(A) ((A)->dbgName)
89#define DBG_LEVEL(A) ((A)->dbgLevel)
90
91#ifndef DBG_PRINT
92#define DBG_PRINT(S...) printk(KERN_DEBUG S)
93#endif /* DBG_PRINT */
94
95#ifndef DBG_PRINTC
96#define DBG_PRINTC(S...) printk(S)
97#endif /* DBG_PRINTC */
98
99#ifndef DBG_TRAP
100#define DBG_TRAP do {} while (0) /* BUG() */
101#endif /* DBG_TRAP */
102
103#define _ENTER_STR ">>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>"
104#define _LEAVE_STR "<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<"
105
106#define _DBG_ENTER(A) printk(KERN_DEBUG "%s:%.*s:%s\n", DBG_NAME(A), \
107 ++DBG_LEVEL(A), _ENTER_STR, __func__)
108#define _DBG_LEAVE(A) printk(KERN_DEBUG "%s:%.*s:%s\n", DBG_NAME(A), \
109 DBG_LEVEL(A)--, _LEAVE_STR, __func__)
110
111#define DBG_ENTER(A) \
112 do { \
113 if (DBG_FLAGS(A) & DBG_TRACE_ON) \
114 _DBG_ENTER(A); \
115 } while (0)
116
117#define DBG_LEAVE(A) \
118 do { \
119 if (DBG_FLAGS(A) & DBG_TRACE_ON) \
120 _DBG_LEAVE(A); \
121 } while (0)
122
123#define DBG_PARAM(A, N, F, S...) \
124 do { \
125 if (DBG_FLAGS(A) & DBG_PARAM_ON) \
126 DBG_PRINT(" %s -- "F" ", N, S); \
127 } while (0)
128
129#define DBG_ERROR(A, S...) \
130 do { \
131 if (DBG_FLAGS(A) & DBG_ERROR_ON) { \
132 DBG_PRINT("%s:ERROR:%s ", DBG_NAME(A), __func__);\
133 DBG_PRINTC(S); \
134 DBG_TRAP; \
135 } \
136 } while (0)
137
138#define DBG_WARNING(A, S...) \
139 do { \
140 if (DBG_FLAGS(A) & DBG_WARNING_ON) { \
141 DBG_PRINT("%s:WARNING:%s ", DBG_NAME(A), __func__); \
142 DBG_PRINTC(S); \
143 } \
144 } while (0)
145
146#define DBG_NOTICE(A, S...) \
147 do { \
148 if (DBG_FLAGS(A) & DBG_NOTICE_ON) { \
149 DBG_PRINT("%s:NOTICE:%s ", DBG_NAME(A), __func__); \
150 DBG_PRINTC(S); \
151 } \
152 } while (0)
153
154#define DBG_TRACE(A, S...) \
155 do { \
156 if (DBG_FLAGS(A) & DBG_TRACE_ON) { \
157 DBG_PRINT("%s:TRACE:%s ", DBG_NAME(A), __func__); \
158 DBG_PRINTC(S); \
159 } \
160 } while (0)
161
162#define DBG_VERBOSE(A, S...) \
163 do { \
164 if (DBG_FLAGS(A) & DBG_VERBOSE_ON) { \
165 DBG_PRINT("%s:VERBOSE:%s ", DBG_NAME(A), __func__); \
166 DBG_PRINTC(S); \
167 } \
168 } while (0)
169
170#define DBG_RX(A, S...) \
171 do { \
172 if (DBG_FLAGS(A) & DBG_RX_ON) \
173 DBG_PRINT(S); \
174 } while (0)
175
176#define DBG_RX_ENTER(A) \
177 do { \
178 if (DBG_FLAGS(A) & DBG_RX_ON) \
179 _DBG_ENTER(A); \
180 } while (0)
181
182#define DBG_RX_LEAVE(A) \
183 do { \
184 if (DBG_FLAGS(A) & DBG_RX_ON) \
185 _DBG_LEAVE(A); \
186 } while (0)
187
188#define DBG_TX(A, S...) \
189 do { \
190 if (DBG_FLAGS(A) & DBG_TX_ON) \
191 DBG_PRINT(S); \
192 } while (0)
193
194#define DBG_TX_ENTER(A) \
195 do { \
196 if (DBG_FLAGS(A) & DBG_TX_ON) \
197 _DBG_ENTER(A); \
198 } while (0)
199
200#define DBG_TX_LEAVE(A) \
201 do { \
202 if (DBG_FLAGS(A) & DBG_TX_ON) \
203 _DBG_LEAVE(A); \
204 } while (0)
205
206#define DBG_ASSERT(C) \
207 do { \
208 if (!(C)) { \
209 DBG_PRINT("ASSERT(%s) -- %s#%d (%s) ", \
210 #C, __FILE__, __LINE__, __func__); \
211 DBG_TRAP; \
212 } \
213 } while (0)
214
215#define STATIC
216
217typedef struct {
218 char *dbgName;
219 int dbgLevel;
220 unsigned long dbgFlags;
221} dbg_info_t;
222
223#else /* CONFIG_ET131X_DEBUG */
224
225#define DBG_DEFN
226#define DBG_TRAP
227#define DBG_PRINT(S...)
228#define DBG_ENTER(A)
229#define DBG_LEAVE(A)
230#define DBG_PARAM(A, N, F, S...)
231#define DBG_ERROR(A, S...)
232#define DBG_WARNING(A, S...)
233#define DBG_NOTICE(A, S...)
234#define DBG_TRACE(A, S...)
235#define DBG_VERBOSE(A, S...)
236#define DBG_RX(A, S...)
237#define DBG_RX_ENTER(A)
238#define DBG_RX_LEAVE(A)
239#define DBG_TX(A, S...)
240#define DBG_TX_ENTER(A)
241#define DBG_TX_LEAVE(A)
242#define DBG_ASSERT(C)
243#define STATIC static
244
245#endif /* CONFIG_ET131X_DEBUG */
246
247/* Forward declaration of the private adapter structure */
248struct et131x_adapter;
249
250void DumpTxQueueContents(int dbgLvl, struct et131x_adapter *adapter);
251void DumpDeviceBlock(int dbgLvl, struct et131x_adapter *adapter,
252 unsigned int Block);
253void DumpDeviceReg(int dbgLvl, struct et131x_adapter *adapter);
254
255#endif /* __ET131X_DBG_H__ */
diff --git a/drivers/staging/et131x/et131x_initpci.c b/drivers/staging/et131x/et131x_initpci.c
index 0662e7ff964e..2d8b62f066a8 100644
--- a/drivers/staging/et131x/et131x_initpci.c
+++ b/drivers/staging/et131x/et131x_initpci.c
@@ -58,7 +58,6 @@
58 */ 58 */
59 59
60#include "et131x_version.h" 60#include "et131x_version.h"
61#include "et131x_debug.h"
62#include "et131x_defs.h" 61#include "et131x_defs.h"
63 62
64#include <linux/pci.h> 63#include <linux/pci.h>
@@ -113,33 +112,6 @@ MODULE_AUTHOR(DRIVER_AUTHOR);
113MODULE_DESCRIPTION(DRIVER_INFO); 112MODULE_DESCRIPTION(DRIVER_INFO);
114MODULE_LICENSE(DRIVER_LICENSE); 113MODULE_LICENSE(DRIVER_LICENSE);
115 114
116/* Module Parameters and related data for debugging facilities */
117#ifdef CONFIG_ET131X_DEBUG
118static u32 et131x_debug_level = DBG_LVL;
119static u32 et131x_debug_flags = DBG_DEFAULTS;
120
121/*
122et131x_debug_level :
123 Level of debugging desired (0-7)
124 7 : DBG_RX_ON | DBG_TX_ON
125 6 : DBG_PARAM_ON
126 5 : DBG_VERBOSE_ON
127 4 : DBG_TRACE_ON
128 3 : DBG_NOTICE_ON
129 2 : no debug info
130 1 : no debug info
131 0 : no debug info
132*/
133
134module_param(et131x_debug_level, uint, 0);
135module_param(et131x_debug_flags, uint, 0);
136
137MODULE_PARM_DESC(et131x_debug_level, "Level of debugging desired (0-7)");
138
139static dbg_info_t et131x_info = { DRIVER_NAME_EXT, 0, 0 };
140dbg_info_t *et131x_dbginfo = &et131x_info;
141#endif /* CONFIG_ET131X_DEBUG */
142
143/* Defines for Parameter Default/Min/Max vaules */ 115/* Defines for Parameter Default/Min/Max vaules */
144#define PARM_SPEED_DUPLEX_MIN 0 116#define PARM_SPEED_DUPLEX_MIN 0
145#define PARM_SPEED_DUPLEX_MAX 5 117#define PARM_SPEED_DUPLEX_MAX 5
@@ -196,71 +168,29 @@ static struct pci_driver et131x_driver = {
196 * 168 *
197 * Returns 0 on success, errno on failure (as defined in errno.h) 169 * Returns 0 on success, errno on failure (as defined in errno.h)
198 */ 170 */
199int et131x_init_module(void) 171static int et131x_init_module(void)
200{ 172{
201 int result;
202
203#ifdef CONFIG_ET131X_DEBUG
204 /* Set the level of debug messages displayed using the module
205 * parameter
206 */
207 et131x_dbginfo->dbgFlags = et131x_debug_flags;
208
209 switch (et131x_debug_level) {
210 case 7:
211 et131x_dbginfo->dbgFlags |= (DBG_RX_ON | DBG_TX_ON);
212
213 case 6:
214 et131x_dbginfo->dbgFlags |= DBG_PARAM_ON;
215
216 case 5:
217 et131x_dbginfo->dbgFlags |= DBG_VERBOSE_ON;
218
219 case 4:
220 et131x_dbginfo->dbgFlags |= DBG_TRACE_ON;
221
222 case 3:
223 et131x_dbginfo->dbgFlags |= DBG_NOTICE_ON;
224
225 case 2:
226 case 1:
227 case 0:
228 default:
229 break;
230 }
231#endif /* CONFIG_ET131X_DEBUG */
232
233 DBG_ENTER(et131x_dbginfo);
234 DBG_PRINT("%s\n", DRIVER_INFO);
235
236 if (et131x_speed_set < PARM_SPEED_DUPLEX_MIN || 173 if (et131x_speed_set < PARM_SPEED_DUPLEX_MIN ||
237 et131x_speed_set > PARM_SPEED_DUPLEX_MAX) { 174 et131x_speed_set > PARM_SPEED_DUPLEX_MAX) {
238 printk(KERN_WARNING "et131x: invalid speed setting ignored.\n"); 175 printk(KERN_WARNING "et131x: invalid speed setting ignored.\n");
239 et131x_speed_set = 0; 176 et131x_speed_set = 0;
240 } 177 }
241 178 return pci_register_driver(&et131x_driver);
242 result = pci_register_driver(&et131x_driver);
243
244 DBG_LEAVE(et131x_dbginfo);
245 return result;
246} 179}
247 180
248/** 181/**
249 * et131x_cleanup_module - The entry point called on driver cleanup 182 * et131x_cleanup_module - The entry point called on driver cleanup
250 */ 183 */
251void et131x_cleanup_module(void) 184static void et131x_cleanup_module(void)
252{ 185{
253 DBG_ENTER(et131x_dbginfo);
254
255 pci_unregister_driver(&et131x_driver); 186 pci_unregister_driver(&et131x_driver);
256
257 DBG_LEAVE(et131x_dbginfo);
258} 187}
259 188
260/* 189/*
261 * These macros map the driver-specific init_module() and cleanup_module() 190 * These macros map the driver-specific init_module() and cleanup_module()
262 * routines so they can be called by the kernel. 191 * routines so they can be called by the kernel.
263 */ 192 */
193
264module_init(et131x_init_module); 194module_init(et131x_init_module);
265module_exit(et131x_cleanup_module); 195module_exit(et131x_cleanup_module);
266 196
@@ -279,8 +209,6 @@ int et131x_find_adapter(struct et131x_adapter *adapter, struct pci_dev *pdev)
279 uint8_t read_size_reg; 209 uint8_t read_size_reg;
280 u8 rev; 210 u8 rev;
281 211
282 DBG_ENTER(et131x_dbginfo);
283
284 /* Allow disabling of Non-Maskable Interrupts in I/O space, to 212 /* Allow disabling of Non-Maskable Interrupts in I/O space, to
285 * support validation. 213 * support validation.
286 */ 214 */
@@ -311,9 +239,8 @@ int et131x_find_adapter(struct et131x_adapter *adapter, struct pci_dev *pdev)
311 result = pci_read_config_byte(pdev, ET1310_PCI_EEPROM_STATUS, 239 result = pci_read_config_byte(pdev, ET1310_PCI_EEPROM_STATUS,
312 &eepromStat); 240 &eepromStat);
313 if (result != PCIBIOS_SUCCESSFUL) { 241 if (result != PCIBIOS_SUCCESSFUL) {
314 DBG_ERROR(et131x_dbginfo, "Could not read PCI config space for " 242 dev_err(&pdev->dev, "Could not read PCI config space for "
315 "EEPROM Status\n"); 243 "EEPROM Status\n");
316 DBG_LEAVE(et131x_dbginfo);
317 return -EIO; 244 return -EIO;
318 } 245 }
319 246
@@ -323,10 +250,9 @@ int et131x_find_adapter(struct et131x_adapter *adapter, struct pci_dev *pdev)
323 if (eepromStat & 0x4C) { 250 if (eepromStat & 0x4C) {
324 result = pci_read_config_byte(pdev, PCI_REVISION_ID, &rev); 251 result = pci_read_config_byte(pdev, PCI_REVISION_ID, &rev);
325 if (result != PCIBIOS_SUCCESSFUL) { 252 if (result != PCIBIOS_SUCCESSFUL) {
326 DBG_ERROR(et131x_dbginfo, 253 dev_err(&pdev->dev,
327 "Could not read PCI config space for " 254 "Could not read PCI config space for "
328 "Revision ID\n"); 255 "Revision ID\n");
329 DBG_LEAVE(et131x_dbginfo);
330 return -EIO; 256 return -EIO;
331 } else if (rev == 0x01) { 257 } else if (rev == 0x01) {
332 int32_t nLoop; 258 int32_t nLoop;
@@ -341,8 +267,7 @@ int et131x_find_adapter(struct et131x_adapter *adapter, struct pci_dev *pdev)
341 } 267 }
342 } 268 }
343 269
344 DBG_ERROR(et131x_dbginfo, 270 dev_err(&pdev->dev, "Fatal EEPROM Status Error - 0x%04x\n", eepromStat);
345 "Fatal EEPROM Status Error - 0x%04x\n", eepromStat);
346 271
347 /* This error could mean that there was an error reading the 272 /* This error could mean that there was an error reading the
348 * eeprom or that the eeprom doesn't exist. We will treat 273 * eeprom or that the eeprom doesn't exist. We will treat
@@ -351,14 +276,9 @@ int et131x_find_adapter(struct et131x_adapter *adapter, struct pci_dev *pdev)
351 * MAC Address 276 * MAC Address
352 */ 277 */
353 adapter->has_eeprom = 0; 278 adapter->has_eeprom = 0;
354
355 DBG_LEAVE(et131x_dbginfo);
356 return -EIO; 279 return -EIO;
357 } else { 280 } else
358 DBG_TRACE(et131x_dbginfo, "EEPROM Status Code - 0x%04x\n",
359 eepromStat);
360 adapter->has_eeprom = 1; 281 adapter->has_eeprom = 1;
361 }
362 282
363 /* Read the EEPROM for information regarding LED behavior. Refer to 283 /* Read the EEPROM for information regarding LED behavior. Refer to
364 * ET1310_phy.c, et131x_xcvr_init(), for its use. 284 * ET1310_phy.c, et131x_xcvr_init(), for its use.
@@ -375,9 +295,8 @@ int et131x_find_adapter(struct et131x_adapter *adapter, struct pci_dev *pdev)
375 */ 295 */
376 result = pci_read_config_byte(pdev, ET1310_PCI_MAX_PYLD, &maxPayload); 296 result = pci_read_config_byte(pdev, ET1310_PCI_MAX_PYLD, &maxPayload);
377 if (result != PCIBIOS_SUCCESSFUL) { 297 if (result != PCIBIOS_SUCCESSFUL) {
378 DBG_ERROR(et131x_dbginfo, "Could not read PCI config space for " 298 dev_err(&pdev->dev,
379 "Max Payload Size\n"); 299 "Could not read PCI config space for Max Payload Size\n");
380 DBG_LEAVE(et131x_dbginfo);
381 return -EIO; 300 return -EIO;
382 } 301 }
383 302
@@ -391,20 +310,16 @@ int et131x_find_adapter(struct et131x_adapter *adapter, struct pci_dev *pdev)
391 result = pci_write_config_word(pdev, ET1310_PCI_ACK_NACK, 310 result = pci_write_config_word(pdev, ET1310_PCI_ACK_NACK,
392 AckNak[maxPayload]); 311 AckNak[maxPayload]);
393 if (result != PCIBIOS_SUCCESSFUL) { 312 if (result != PCIBIOS_SUCCESSFUL) {
394 DBG_ERROR(et131x_dbginfo, 313 dev_err(&pdev->dev,
395 "Could not write PCI config space " 314 "Could not write PCI config space for ACK/NAK\n");
396 "for ACK/NAK\n");
397 DBG_LEAVE(et131x_dbginfo);
398 return -EIO; 315 return -EIO;
399 } 316 }
400 317
401 result = pci_write_config_word(pdev, ET1310_PCI_REPLAY, 318 result = pci_write_config_word(pdev, ET1310_PCI_REPLAY,
402 Replay[maxPayload]); 319 Replay[maxPayload]);
403 if (result != PCIBIOS_SUCCESSFUL) { 320 if (result != PCIBIOS_SUCCESSFUL) {
404 DBG_ERROR(et131x_dbginfo, 321 dev_err(&pdev->dev,
405 "Could not write PCI config space " 322 "Could not write PCI config space for Replay Timer\n");
406 "for Replay Timer\n");
407 DBG_LEAVE(et131x_dbginfo);
408 return -EIO; 323 return -EIO;
409 } 324 }
410 } 325 }
@@ -414,19 +329,16 @@ int et131x_find_adapter(struct et131x_adapter *adapter, struct pci_dev *pdev)
414 */ 329 */
415 result = pci_write_config_byte(pdev, ET1310_PCI_L0L1LATENCY, 0x11); 330 result = pci_write_config_byte(pdev, ET1310_PCI_L0L1LATENCY, 0x11);
416 if (result != PCIBIOS_SUCCESSFUL) { 331 if (result != PCIBIOS_SUCCESSFUL) {
417 DBG_ERROR(et131x_dbginfo, 332 dev_err(&pdev->dev,
418 "Could not write PCI config space for " 333 "Could not write PCI config space for Latency Timers\n");
419 "Latency Timers\n");
420 DBG_LEAVE(et131x_dbginfo);
421 return -EIO; 334 return -EIO;
422 } 335 }
423 336
424 /* Change the max read size to 2k */ 337 /* Change the max read size to 2k */
425 result = pci_read_config_byte(pdev, 0x51, &read_size_reg); 338 result = pci_read_config_byte(pdev, 0x51, &read_size_reg);
426 if (result != PCIBIOS_SUCCESSFUL) { 339 if (result != PCIBIOS_SUCCESSFUL) {
427 DBG_ERROR(et131x_dbginfo, 340 dev_err(&pdev->dev,
428 "Could not read PCI config space for Max read size\n"); 341 "Could not read PCI config space for Max read size\n");
429 DBG_LEAVE(et131x_dbginfo);
430 return -EIO; 342 return -EIO;
431 } 343 }
432 344
@@ -435,9 +347,8 @@ int et131x_find_adapter(struct et131x_adapter *adapter, struct pci_dev *pdev)
435 347
436 result = pci_write_config_byte(pdev, 0x51, read_size_reg); 348 result = pci_write_config_byte(pdev, 0x51, read_size_reg);
437 if (result != PCIBIOS_SUCCESSFUL) { 349 if (result != PCIBIOS_SUCCESSFUL) {
438 DBG_ERROR(et131x_dbginfo, 350 dev_err(&pdev->dev,
439 "Could not write PCI config space for Max read size\n"); 351 "Could not write PCI config space for Max read size\n");
440 DBG_LEAVE(et131x_dbginfo);
441 return -EIO; 352 return -EIO;
442 } 353 }
443 354
@@ -452,15 +363,11 @@ int et131x_find_adapter(struct et131x_adapter *adapter, struct pci_dev *pdev)
452 pdev, ET1310_PCI_MAC_ADDRESS + i, 363 pdev, ET1310_PCI_MAC_ADDRESS + i,
453 adapter->PermanentAddress + i); 364 adapter->PermanentAddress + i);
454 if (result != PCIBIOS_SUCCESSFUL) { 365 if (result != PCIBIOS_SUCCESSFUL) {
455 DBG_ERROR(et131x_dbginfo, 366 dev_err(&pdev->dev, ";Could not read PCI config space for MAC address\n");
456 "Could not read PCI config space for MAC address\n");
457 DBG_LEAVE(et131x_dbginfo);
458 return -EIO; 367 return -EIO;
459 } 368 }
460 } 369 }
461 } 370 }
462
463 DBG_LEAVE(et131x_dbginfo);
464 return 0; 371 return 0;
465} 372}
466 373
@@ -481,9 +388,8 @@ void et131x_error_timer_handler(unsigned long data)
481 if ((pm_csr & ET_PM_PHY_SW_COMA) == 0) 388 if ((pm_csr & ET_PM_PHY_SW_COMA) == 0)
482 UpdateMacStatHostCounters(etdev); 389 UpdateMacStatHostCounters(etdev);
483 else 390 else
484 DBG_VERBOSE(et131x_dbginfo, 391 dev_err(&etdev->pdev->dev,
485 "No interrupts, in PHY coma, pm_csr = 0x%x\n", 392 "No interrupts, in PHY coma, pm_csr = 0x%x\n", pm_csr);
486 pm_csr);
487 393
488 if (!etdev->Bmsr.bits.link_status && 394 if (!etdev->Bmsr.bits.link_status &&
489 etdev->RegistryPhyComa && 395 etdev->RegistryPhyComa &&
@@ -541,8 +447,6 @@ void ConfigGlobalRegs(struct et131x_adapter *etdev)
541{ 447{
542 struct _GLOBAL_t __iomem *regs = &etdev->regs->global; 448 struct _GLOBAL_t __iomem *regs = &etdev->regs->global;
543 449
544 DBG_ENTER(et131x_dbginfo);
545
546 if (etdev->RegistryPhyLoopbk == false) { 450 if (etdev->RegistryPhyLoopbk == false) {
547 if (etdev->RegistryJumboPacket < 2048) { 451 if (etdev->RegistryJumboPacket < 2048) {
548 /* Tx / RxDMA and Tx/Rx MAC interfaces have a 1k word 452 /* Tx / RxDMA and Tx/Rx MAC interfaces have a 1k word
@@ -596,8 +500,6 @@ void ConfigGlobalRegs(struct et131x_adapter *etdev)
596 * a packet is queued. 500 * a packet is queued.
597 */ 501 */
598 writel(0, &regs->watchdog_timer); 502 writel(0, &regs->watchdog_timer);
599
600 DBG_LEAVE(et131x_dbginfo);
601} 503}
602 504
603 505
@@ -611,8 +513,6 @@ int et131x_adapter_setup(struct et131x_adapter *etdev)
611{ 513{
612 int status = 0; 514 int status = 0;
613 515
614 DBG_ENTER(et131x_dbginfo);
615
616 /* Configure the JAGCore */ 516 /* Configure the JAGCore */
617 ConfigGlobalRegs(etdev); 517 ConfigGlobalRegs(etdev);
618 518
@@ -634,7 +534,7 @@ int et131x_adapter_setup(struct et131x_adapter *etdev)
634 status = et131x_xcvr_find(etdev); 534 status = et131x_xcvr_find(etdev);
635 535
636 if (status != 0) 536 if (status != 0)
637 DBG_WARNING(et131x_dbginfo, "Could not find the xcvr\n"); 537 dev_warn(&etdev->pdev->dev, "Could not find the xcvr\n");
638 538
639 /* Prepare the TRUEPHY library. */ 539 /* Prepare the TRUEPHY library. */
640 ET1310_PhyInit(etdev); 540 ET1310_PhyInit(etdev);
@@ -658,9 +558,7 @@ int et131x_adapter_setup(struct et131x_adapter *etdev)
658 ET1310_PhyPowerDown(etdev, 0); 558 ET1310_PhyPowerDown(etdev, 0);
659 559
660 et131x_setphy_normal(etdev); 560 et131x_setphy_normal(etdev);
661 561; return status;
662 DBG_LEAVE(et131x_dbginfo);
663 return status;
664} 562}
665 563
666/** 564/**
@@ -669,8 +567,6 @@ int et131x_adapter_setup(struct et131x_adapter *etdev)
669 */ 567 */
670void et131x_setup_hardware_properties(struct et131x_adapter *adapter) 568void et131x_setup_hardware_properties(struct et131x_adapter *adapter)
671{ 569{
672 DBG_ENTER(et131x_dbginfo);
673
674 /* If have our default mac from registry and no mac address from 570 /* If have our default mac from registry and no mac address from
675 * EEPROM then we need to generate the last octet and set it on the 571 * EEPROM then we need to generate the last octet and set it on the
676 * device 572 * device
@@ -702,8 +598,6 @@ void et131x_setup_hardware_properties(struct et131x_adapter *adapter)
702 memcpy(adapter->CurrentAddress, 598 memcpy(adapter->CurrentAddress,
703 adapter->PermanentAddress, ETH_ALEN); 599 adapter->PermanentAddress, ETH_ALEN);
704 } 600 }
705
706 DBG_LEAVE(et131x_dbginfo);
707} 601}
708 602
709/** 603/**
@@ -712,8 +606,6 @@ void et131x_setup_hardware_properties(struct et131x_adapter *adapter)
712 */ 606 */
713void et131x_soft_reset(struct et131x_adapter *adapter) 607void et131x_soft_reset(struct et131x_adapter *adapter)
714{ 608{
715 DBG_ENTER(et131x_dbginfo);
716
717 /* Disable MAC Core */ 609 /* Disable MAC Core */
718 writel(0xc00f0000, &adapter->regs->mac.cfg1.value); 610 writel(0xc00f0000, &adapter->regs->mac.cfg1.value);
719 611
@@ -721,8 +613,6 @@ void et131x_soft_reset(struct et131x_adapter *adapter)
721 writel(0x7F, &adapter->regs->global.sw_reset); 613 writel(0x7F, &adapter->regs->global.sw_reset);
722 writel(0x000f0000, &adapter->regs->mac.cfg1.value); 614 writel(0x000f0000, &adapter->regs->mac.cfg1.value);
723 writel(0x00000000, &adapter->regs->mac.cfg1.value); 615 writel(0x00000000, &adapter->regs->mac.cfg1.value);
724
725 DBG_LEAVE(et131x_dbginfo);
726} 616}
727 617
728/** 618/**
@@ -738,8 +628,6 @@ void et131x_align_allocated_memory(struct et131x_adapter *adapter,
738{ 628{
739 uint64_t new_addr; 629 uint64_t new_addr;
740 630
741 DBG_ENTER(et131x_dbginfo);
742
743 *offset = 0; 631 *offset = 0;
744 632
745 new_addr = *phys_addr & ~mask; 633 new_addr = *phys_addr & ~mask;
@@ -752,8 +640,6 @@ void et131x_align_allocated_memory(struct et131x_adapter *adapter,
752 /* Return new physical address */ 640 /* Return new physical address */
753 *phys_addr = new_addr; 641 *phys_addr = new_addr;
754 } 642 }
755
756 DBG_LEAVE(et131x_dbginfo);
757} 643}
758 644
759/** 645/**
@@ -768,13 +654,11 @@ int et131x_adapter_memory_alloc(struct et131x_adapter *adapter)
768{ 654{
769 int status = 0; 655 int status = 0;
770 656
771 DBG_ENTER(et131x_dbginfo);
772
773 do { 657 do {
774 /* Allocate memory for the Tx Ring */ 658 /* Allocate memory for the Tx Ring */
775 status = et131x_tx_dma_memory_alloc(adapter); 659 status = et131x_tx_dma_memory_alloc(adapter);
776 if (status != 0) { 660 if (status != 0) {
777 DBG_ERROR(et131x_dbginfo, 661 dev_err(&adapter->pdev->dev,
778 "et131x_tx_dma_memory_alloc FAILED\n"); 662 "et131x_tx_dma_memory_alloc FAILED\n");
779 break; 663 break;
780 } 664 }
@@ -782,7 +666,7 @@ int et131x_adapter_memory_alloc(struct et131x_adapter *adapter)
782 /* Receive buffer memory allocation */ 666 /* Receive buffer memory allocation */
783 status = et131x_rx_dma_memory_alloc(adapter); 667 status = et131x_rx_dma_memory_alloc(adapter);
784 if (status != 0) { 668 if (status != 0) {
785 DBG_ERROR(et131x_dbginfo, 669 dev_err(&adapter->pdev->dev,
786 "et131x_rx_dma_memory_alloc FAILED\n"); 670 "et131x_rx_dma_memory_alloc FAILED\n");
787 et131x_tx_dma_memory_free(adapter); 671 et131x_tx_dma_memory_free(adapter);
788 break; 672 break;
@@ -791,14 +675,13 @@ int et131x_adapter_memory_alloc(struct et131x_adapter *adapter)
791 /* Init receive data structures */ 675 /* Init receive data structures */
792 status = et131x_init_recv(adapter); 676 status = et131x_init_recv(adapter);
793 if (status != 0) { 677 if (status != 0) {
794 DBG_ERROR(et131x_dbginfo, "et131x_init_recv FAILED\n"); 678 dev_err(&adapter->pdev->dev,
679 "et131x_init_recv FAILED\n");
795 et131x_tx_dma_memory_free(adapter); 680 et131x_tx_dma_memory_free(adapter);
796 et131x_rx_dma_memory_free(adapter); 681 et131x_rx_dma_memory_free(adapter);
797 break; 682 break;
798 } 683 }
799 } while (0); 684 } while (0);
800
801 DBG_LEAVE(et131x_dbginfo);
802 return status; 685 return status;
803} 686}
804 687
@@ -808,13 +691,9 @@ int et131x_adapter_memory_alloc(struct et131x_adapter *adapter)
808 */ 691 */
809void et131x_adapter_memory_free(struct et131x_adapter *adapter) 692void et131x_adapter_memory_free(struct et131x_adapter *adapter)
810{ 693{
811 DBG_ENTER(et131x_dbginfo);
812
813 /* Free DMA memory */ 694 /* Free DMA memory */
814 et131x_tx_dma_memory_free(adapter); 695 et131x_tx_dma_memory_free(adapter);
815 et131x_rx_dma_memory_free(adapter); 696 et131x_rx_dma_memory_free(adapter);
816
817 DBG_LEAVE(et131x_dbginfo);
818} 697}
819 698
820/** 699/**
@@ -830,8 +709,6 @@ void __devexit et131x_pci_remove(struct pci_dev *pdev)
830 struct net_device *netdev; 709 struct net_device *netdev;
831 struct et131x_adapter *adapter; 710 struct et131x_adapter *adapter;
832 711
833 DBG_ENTER(et131x_dbginfo);
834
835 /* Retrieve the net_device pointer from the pci_dev struct, as well 712 /* Retrieve the net_device pointer from the pci_dev struct, as well
836 * as the private adapter struct 713 * as the private adapter struct
837 */ 714 */
@@ -846,8 +723,6 @@ void __devexit et131x_pci_remove(struct pci_dev *pdev)
846 free_netdev(netdev); 723 free_netdev(netdev);
847 pci_release_regions(pdev); 724 pci_release_regions(pdev);
848 pci_disable_device(pdev); 725 pci_disable_device(pdev);
849
850 DBG_LEAVE(et131x_dbginfo);
851} 726}
852 727
853/** 728/**
@@ -866,11 +741,9 @@ void et131x_config_parse(struct et131x_adapter *etdev)
866 static const u8 duplex[] = { 0, 1, 2, 1, 2, 2 }; 741 static const u8 duplex[] = { 0, 1, 2, 1, 2, 2 };
867 static const u16 speed[] = { 0, 10, 10, 100, 100, 1000 }; 742 static const u16 speed[] = { 0, 10, 10, 100, 100, 1000 };
868 743
869 DBG_ENTER(et131x_dbginfo);
870
871 if (et131x_speed_set) 744 if (et131x_speed_set)
872 DBG_VERBOSE(et131x_dbginfo, "Speed set manually to : %d \n", 745 dev_info(&etdev->pdev->dev,
873 et131x_speed_set); 746 "Speed set manually to : %d \n", et131x_speed_set);
874 747
875 etdev->SpeedDuplex = et131x_speed_set; 748 etdev->SpeedDuplex = et131x_speed_set;
876 etdev->RegistryJumboPacket = 1514; /* 1514-9216 */ 749 etdev->RegistryJumboPacket = 1514; /* 1514-9216 */
@@ -894,8 +767,6 @@ void et131x_config_parse(struct et131x_adapter *etdev)
894 767
895 etdev->AiForceSpeed = speed[etdev->SpeedDuplex]; 768 etdev->AiForceSpeed = speed[etdev->SpeedDuplex];
896 etdev->AiForceDpx = duplex[etdev->SpeedDuplex]; /* Auto FDX */ 769 etdev->AiForceDpx = duplex[etdev->SpeedDuplex]; /* Auto FDX */
897
898 DBG_LEAVE(et131x_dbginfo);
899} 770}
900 771
901 772
@@ -920,18 +791,17 @@ int __devinit et131x_pci_setup(struct pci_dev *pdev,
920 struct net_device *netdev = NULL; 791 struct net_device *netdev = NULL;
921 struct et131x_adapter *adapter = NULL; 792 struct et131x_adapter *adapter = NULL;
922 793
923 DBG_ENTER(et131x_dbginfo);
924
925 /* Enable the device via the PCI subsystem */ 794 /* Enable the device via the PCI subsystem */
926 result = pci_enable_device(pdev); 795 result = pci_enable_device(pdev);
927 if (result != 0) { 796 if (result != 0) {
928 DBG_ERROR(et131x_dbginfo, "pci_enable_device() failed\n"); 797 dev_err(&adapter->pdev->dev,
798 "pci_enable_device() failed\n");
929 goto out; 799 goto out;
930 } 800 }
931 801
932 /* Perform some basic PCI checks */ 802 /* Perform some basic PCI checks */
933 if (!(pci_resource_flags(pdev, 0) & IORESOURCE_MEM)) { 803 if (!(pci_resource_flags(pdev, 0) & IORESOURCE_MEM)) {
934 DBG_ERROR(et131x_dbginfo, 804 dev_err(&adapter->pdev->dev,
935 "Can't find PCI device's base address\n"); 805 "Can't find PCI device's base address\n");
936 result = -ENODEV; 806 result = -ENODEV;
937 goto out; 807 goto out;
@@ -939,12 +809,12 @@ int __devinit et131x_pci_setup(struct pci_dev *pdev,
939 809
940 result = pci_request_regions(pdev, DRIVER_NAME); 810 result = pci_request_regions(pdev, DRIVER_NAME);
941 if (result != 0) { 811 if (result != 0) {
942 DBG_ERROR(et131x_dbginfo, "Can't get PCI resources\n"); 812 dev_err(&adapter->pdev->dev,
813 "Can't get PCI resources\n");
943 goto err_disable; 814 goto err_disable;
944 } 815 }
945 816
946 /* Enable PCI bus mastering */ 817 /* Enable PCI bus mastering */
947 DBG_TRACE(et131x_dbginfo, "Setting PCI Bus Mastering...\n");
948 pci_set_master(pdev); 818 pci_set_master(pdev);
949 819
950 /* Query PCI for Power Mgmt Capabilities 820 /* Query PCI for Power Mgmt Capabilities
@@ -954,7 +824,7 @@ int __devinit et131x_pci_setup(struct pci_dev *pdev,
954 */ 824 */
955 pm_cap = pci_find_capability(pdev, PCI_CAP_ID_PM); 825 pm_cap = pci_find_capability(pdev, PCI_CAP_ID_PM);
956 if (pm_cap == 0) { 826 if (pm_cap == 0) {
957 DBG_ERROR(et131x_dbginfo, 827 dev_err(&adapter->pdev->dev,
958 "Cannot find Power Management capabilities\n"); 828 "Cannot find Power Management capabilities\n");
959 result = -EIO; 829 result = -EIO;
960 goto err_release_res; 830 goto err_release_res;
@@ -962,40 +832,34 @@ int __devinit et131x_pci_setup(struct pci_dev *pdev,
962 832
963 /* Check the DMA addressing support of this device */ 833 /* Check the DMA addressing support of this device */
964 if (!pci_set_dma_mask(pdev, 0xffffffffffffffffULL)) { 834 if (!pci_set_dma_mask(pdev, 0xffffffffffffffffULL)) {
965 DBG_TRACE(et131x_dbginfo, "64-bit DMA addressing supported\n");
966 pci_using_dac = true; 835 pci_using_dac = true;
967 836
968 result = 837 result =
969 pci_set_consistent_dma_mask(pdev, 0xffffffffffffffffULL); 838 pci_set_consistent_dma_mask(pdev, 0xffffffffffffffffULL);
970 if (result != 0) { 839 if (result != 0) {
971 DBG_ERROR(et131x_dbginfo, 840 dev_err(&pdev->dev,
972 "Unable to obtain 64 bit DMA for consistent allocations\n"); 841 "Unable to obtain 64 bit DMA for consistent allocations\n");
973 goto err_release_res; 842 goto err_release_res;
974 } 843 }
975 } else if (!pci_set_dma_mask(pdev, 0xffffffffULL)) { 844 } else if (!pci_set_dma_mask(pdev, 0xffffffffULL)) {
976 DBG_TRACE(et131x_dbginfo,
977 "64-bit DMA addressing NOT supported\n");
978 DBG_TRACE(et131x_dbginfo,
979 "32-bit DMA addressing will be used\n");
980 pci_using_dac = false; 845 pci_using_dac = false;
981 } else { 846 } else {
982 DBG_ERROR(et131x_dbginfo, "No usable DMA addressing method\n"); 847 dev_err(&adapter->pdev->dev,
848 "No usable DMA addressing method\n");
983 result = -EIO; 849 result = -EIO;
984 goto err_release_res; 850 goto err_release_res;
985 } 851 }
986 852
987 /* Allocate netdev and private adapter structs */ 853 /* Allocate netdev and private adapter structs */
988 DBG_TRACE(et131x_dbginfo,
989 "Allocate netdev and private adapter structs...\n");
990 netdev = et131x_device_alloc(); 854 netdev = et131x_device_alloc();
991 if (netdev == NULL) { 855 if (netdev == NULL) {
992 DBG_ERROR(et131x_dbginfo, "Couldn't alloc netdev struct\n"); 856 dev_err(&adapter->pdev->dev,
857 "Couldn't alloc netdev struct\n");
993 result = -ENOMEM; 858 result = -ENOMEM;
994 goto err_release_res; 859 goto err_release_res;
995 } 860 }
996 861
997 /* Setup the fundamental net_device and private adapter structure elements */ 862 /* Setup the fundamental net_device and private adapter structure elements */
998 DBG_TRACE(et131x_dbginfo, "Setting fundamental net_device info...\n");
999 SET_NETDEV_DEV(netdev, &pdev->dev); 863 SET_NETDEV_DEV(netdev, &pdev->dev);
1000 /* 864 /*
1001 if (pci_using_dac) { 865 if (pci_using_dac) {
@@ -1036,8 +900,6 @@ int __devinit et131x_pci_setup(struct pci_dev *pdev,
1036 netdev->base_addr = pdev->resource[0].start; 900 netdev->base_addr = pdev->resource[0].start;
1037 901
1038 /* Initialize spinlocks here */ 902 /* Initialize spinlocks here */
1039 DBG_TRACE(et131x_dbginfo, "Initialize spinlocks...\n");
1040
1041 spin_lock_init(&adapter->Lock); 903 spin_lock_init(&adapter->Lock);
1042 spin_lock_init(&adapter->TCBSendQLock); 904 spin_lock_init(&adapter->TCBSendQLock);
1043 spin_lock_init(&adapter->TCBReadyQLock); 905 spin_lock_init(&adapter->TCBReadyQLock);
@@ -1061,13 +923,11 @@ int __devinit et131x_pci_setup(struct pci_dev *pdev,
1061 et131x_find_adapter(adapter, pdev); 923 et131x_find_adapter(adapter, pdev);
1062 924
1063 /* Map the bus-relative registers to system virtual memory */ 925 /* Map the bus-relative registers to system virtual memory */
1064 DBG_TRACE(et131x_dbginfo,
1065 "Mapping bus-relative registers to virtual memory...\n");
1066 926
1067 adapter->regs = ioremap_nocache(pci_resource_start(pdev, 0), 927 adapter->regs = ioremap_nocache(pci_resource_start(pdev, 0),
1068 pci_resource_len(pdev, 0)); 928 pci_resource_len(pdev, 0));
1069 if (adapter->regs == NULL) { 929 if (adapter->regs == NULL) {
1070 DBG_ERROR(et131x_dbginfo, "Cannot map device registers\n"); 930 dev_err(&pdev->dev, "Cannot map device registers\n");
1071 result = -ENOMEM; 931 result = -ENOMEM;
1072 goto err_free_dev; 932 goto err_free_dev;
1073 } 933 }
@@ -1078,23 +938,19 @@ int __devinit et131x_pci_setup(struct pci_dev *pdev,
1078 writel(ET_PMCSR_INIT, &adapter->regs->global.pm_csr); 938 writel(ET_PMCSR_INIT, &adapter->regs->global.pm_csr);
1079 939
1080 /* Issue a global reset to the et1310 */ 940 /* Issue a global reset to the et1310 */
1081 DBG_TRACE(et131x_dbginfo, "Issuing soft reset...\n");
1082 et131x_soft_reset(adapter); 941 et131x_soft_reset(adapter);
1083 942
1084 /* Disable all interrupts (paranoid) */ 943 /* Disable all interrupts (paranoid) */
1085 DBG_TRACE(et131x_dbginfo, "Disable device interrupts...\n");
1086 et131x_disable_interrupts(adapter); 944 et131x_disable_interrupts(adapter);
1087 945
1088 /* Allocate DMA memory */ 946 /* Allocate DMA memory */
1089 result = et131x_adapter_memory_alloc(adapter); 947 result = et131x_adapter_memory_alloc(adapter);
1090 if (result != 0) { 948 if (result != 0) {
1091 DBG_ERROR(et131x_dbginfo, 949 dev_err(&pdev->dev, "Could not alloc adapater memory (DMA)\n");
1092 "Could not alloc adapater memory (DMA)\n");
1093 goto err_iounmap; 950 goto err_iounmap;
1094 } 951 }
1095 952
1096 /* Init send data structures */ 953 /* Init send data structures */
1097 DBG_TRACE(et131x_dbginfo, "Init send data structures...\n");
1098 et131x_init_send(adapter); 954 et131x_init_send(adapter);
1099 955
1100 /* Register the interrupt 956 /* Register the interrupt
@@ -1109,13 +965,11 @@ int __devinit et131x_pci_setup(struct pci_dev *pdev,
1109 INIT_WORK(&adapter->task, et131x_isr_handler); 965 INIT_WORK(&adapter->task, et131x_isr_handler);
1110 966
1111 /* Determine MAC Address, and copy into the net_device struct */ 967 /* Determine MAC Address, and copy into the net_device struct */
1112 DBG_TRACE(et131x_dbginfo, "Retrieve MAC address...\n");
1113 et131x_setup_hardware_properties(adapter); 968 et131x_setup_hardware_properties(adapter);
1114 969
1115 memcpy(netdev->dev_addr, adapter->CurrentAddress, ETH_ALEN); 970 memcpy(netdev->dev_addr, adapter->CurrentAddress, ETH_ALEN);
1116 971
1117 /* Setup et1310 as per the documentation */ 972 /* Setup et1310 as per the documentation */
1118 DBG_TRACE(et131x_dbginfo, "Setup the adapter...\n");
1119 et131x_adapter_setup(adapter); 973 et131x_adapter_setup(adapter);
1120 974
1121 /* Create a timer to count errors received by the NIC */ 975 /* Create a timer to count errors received by the NIC */
@@ -1140,10 +994,9 @@ int __devinit et131x_pci_setup(struct pci_dev *pdev,
1140 */ 994 */
1141 995
1142 /* Register the net_device struct with the Linux network layer */ 996 /* Register the net_device struct with the Linux network layer */
1143 DBG_TRACE(et131x_dbginfo, "Registering net_device...\n");
1144 result = register_netdev(netdev); 997 result = register_netdev(netdev);
1145 if (result != 0) { 998 if (result != 0) {
1146 DBG_ERROR(et131x_dbginfo, "register_netdev() failed\n"); 999 dev_err(&pdev->dev, "register_netdev() failed\n");
1147 goto err_mem_free; 1000 goto err_mem_free;
1148 } 1001 }
1149 1002
@@ -1156,7 +1009,6 @@ int __devinit et131x_pci_setup(struct pci_dev *pdev,
1156 pci_save_state(adapter->pdev); 1009 pci_save_state(adapter->pdev);
1157 1010
1158out: 1011out:
1159 DBG_LEAVE(et131x_dbginfo);
1160 return result; 1012 return result;
1161 1013
1162err_mem_free: 1014err_mem_free:
diff --git a/drivers/staging/et131x/et131x_isr.c b/drivers/staging/et131x/et131x_isr.c
index 878fd205e415..2943178a7a36 100644
--- a/drivers/staging/et131x/et131x_isr.c
+++ b/drivers/staging/et131x/et131x_isr.c
@@ -57,7 +57,6 @@
57 */ 57 */
58 58
59#include "et131x_version.h" 59#include "et131x_version.h"
60#include "et131x_debug.h"
61#include "et131x_defs.h" 60#include "et131x_defs.h"
62 61
63#include <linux/init.h> 62#include <linux/init.h>
@@ -76,6 +75,7 @@
76#include <linux/delay.h> 75#include <linux/delay.h>
77#include <linux/io.h> 76#include <linux/io.h>
78#include <linux/bitops.h> 77#include <linux/bitops.h>
78#include <linux/pci.h>
79#include <asm/system.h> 79#include <asm/system.h>
80 80
81#include <linux/netdevice.h> 81#include <linux/netdevice.h>
@@ -91,11 +91,6 @@
91 91
92#include "et131x_adapter.h" 92#include "et131x_adapter.h"
93 93
94/* Data for debugging facilities */
95#ifdef CONFIG_ET131X_DEBUG
96extern dbg_info_t *et131x_dbginfo;
97#endif /* CONFIG_ET131X_DEBUG */
98
99/** 94/**
100 * et131x_enable_interrupts - enable interrupt 95 * et131x_enable_interrupts - enable interrupt
101 * @adapter: et131x device 96 * @adapter: et131x device
@@ -151,9 +146,7 @@ irqreturn_t et131x_isr(int irq, void *dev_id)
151 struct et131x_adapter *adapter = NULL; 146 struct et131x_adapter *adapter = NULL;
152 u32 status; 147 u32 status;
153 148
154 if (netdev == NULL || !netif_device_present(netdev)) { 149 if (!netif_device_present(netdev)) {
155 DBG_WARNING(et131x_dbginfo,
156 "No net_device struct or device not present\n");
157 handled = false; 150 handled = false;
158 goto out; 151 goto out;
159 } 152 }
@@ -181,23 +174,12 @@ irqreturn_t et131x_isr(int irq, void *dev_id)
181 174
182 /* Make sure this is our interrupt */ 175 /* Make sure this is our interrupt */
183 if (!status) { 176 if (!status) {
184#ifdef CONFIG_ET131X_DEBUG
185 adapter->Stats.UnhandledInterruptsPerSec++;
186#endif
187 handled = false; 177 handled = false;
188 DBG_VERBOSE(et131x_dbginfo, "NOT OUR INTERRUPT\n");
189 et131x_enable_interrupts(adapter); 178 et131x_enable_interrupts(adapter);
190 goto out; 179 goto out;
191 } 180 }
192 181
193 /* This is our interrupt, so process accordingly */ 182 /* This is our interrupt, so process accordingly */
194#ifdef CONFIG_ET131X_DEBUG
195 if (status & ET_INTR_RXDMA_XFR_DONE)
196 adapter->Stats.RxDmaInterruptsPerSec++;
197
198 if (status & ET_INTR_TXDMA_ISR)
199 adapter->Stats.TxDmaInterruptsPerSec++;
200#endif
201 183
202 if (status & ET_INTR_WATCHDOG) { 184 if (status & ET_INTR_WATCHDOG) {
203 PMP_TCB pMpTcb = adapter->TxRing.CurrSendHead; 185 PMP_TCB pMpTcb = adapter->TxRing.CurrSendHead;
@@ -212,9 +194,6 @@ irqreturn_t et131x_isr(int irq, void *dev_id)
212 writel(0, &adapter->regs->global.watchdog_timer); 194 writel(0, &adapter->regs->global.watchdog_timer);
213 195
214 status &= ~ET_INTR_WATCHDOG; 196 status &= ~ET_INTR_WATCHDOG;
215#ifdef CONFIG_ET131X_DEBUG
216 adapter->Stats.WatchDogInterruptsPerSec++;
217#endif
218 } 197 }
219 198
220 if (status == 0) { 199 if (status == 0) {
@@ -263,13 +242,11 @@ void et131x_isr_handler(struct work_struct *work)
263 */ 242 */
264 /* Handle all the completed Transmit interrupts */ 243 /* Handle all the completed Transmit interrupts */
265 if (status & ET_INTR_TXDMA_ISR) { 244 if (status & ET_INTR_TXDMA_ISR) {
266 DBG_TX(et131x_dbginfo, "TXDMA_ISR interrupt\n");
267 et131x_handle_send_interrupt(etdev); 245 et131x_handle_send_interrupt(etdev);
268 } 246 }
269 247
270 /* Handle all the completed Receives interrupts */ 248 /* Handle all the completed Receives interrupts */
271 if (status & ET_INTR_RXDMA_XFR_DONE) { 249 if (status & ET_INTR_RXDMA_XFR_DONE) {
272 DBG_RX(et131x_dbginfo, "RXDMA_XFR_DONE interrupt\n");
273 et131x_handle_recv_interrupt(etdev); 250 et131x_handle_recv_interrupt(etdev);
274 } 251 }
275 252
@@ -283,7 +260,7 @@ void et131x_isr_handler(struct work_struct *work)
283 /* Following read also clears the register (COR) */ 260 /* Following read also clears the register (COR) */
284 TxDmaErr.value = readl(&iomem->txdma.TxDmaError.value); 261 TxDmaErr.value = readl(&iomem->txdma.TxDmaError.value);
285 262
286 DBG_WARNING(et131x_dbginfo, 263 dev_warn(&etdev->pdev->dev,
287 "TXDMA_ERR interrupt, error = %d\n", 264 "TXDMA_ERR interrupt, error = %d\n",
288 TxDmaErr.value); 265 TxDmaErr.value);
289 } 266 }
@@ -304,9 +281,6 @@ void et131x_isr_handler(struct work_struct *work)
304 * ET1310 for re-use. This interrupt is one method of 281 * ET1310 for re-use. This interrupt is one method of
305 * returning resources. 282 * returning resources.
306 */ 283 */
307 DBG_WARNING(et131x_dbginfo,
308 "RXDMA_FB_RING0_LOW or "
309 "RXDMA_FB_RING1_LOW interrupt\n");
310 284
311 /* If the user has flow control on, then we will 285 /* If the user has flow control on, then we will
312 * send a pause packet, otherwise just exit 286 * send a pause packet, otherwise just exit
@@ -332,8 +306,6 @@ void et131x_isr_handler(struct work_struct *work)
332 306
333 /* Handle Packet Status Ring Low Interrupt */ 307 /* Handle Packet Status Ring Low Interrupt */
334 if (status & ET_INTR_RXDMA_STAT_LOW) { 308 if (status & ET_INTR_RXDMA_STAT_LOW) {
335 DBG_WARNING(et131x_dbginfo,
336 "RXDMA_PKT_STAT_RING_LOW interrupt\n");
337 309
338 /* 310 /*
339 * Same idea as with the two Free Buffer Rings. 311 * Same idea as with the two Free Buffer Rings.
@@ -370,7 +342,7 @@ void et131x_isr_handler(struct work_struct *work)
370 342
371 etdev->TxMacTest.value = 343 etdev->TxMacTest.value =
372 readl(&iomem->txmac.tx_test.value); 344 readl(&iomem->txmac.tx_test.value);
373 DBG_WARNING(et131x_dbginfo, 345 dev_warn(&etdev->pdev->dev,
374 "RxDMA_ERR interrupt, error %x\n", 346 "RxDMA_ERR interrupt, error %x\n",
375 etdev->TxMacTest.value); 347 etdev->TxMacTest.value);
376 } 348 }
@@ -384,7 +356,7 @@ void et131x_isr_handler(struct work_struct *work)
384 * message when we are in DBG mode, otherwise we 356 * message when we are in DBG mode, otherwise we
385 * will ignore it. 357 * will ignore it.
386 */ 358 */
387 DBG_ERROR(et131x_dbginfo, "WAKE_ON_LAN interrupt\n"); 359 dev_err(&etdev->pdev->dev, "WAKE_ON_LAN interrupt\n");
388 } 360 }
389 361
390 /* Handle the PHY interrupt */ 362 /* Handle the PHY interrupt */
@@ -393,8 +365,6 @@ void et131x_isr_handler(struct work_struct *work)
393 MI_BMSR_t BmsrInts, BmsrData; 365 MI_BMSR_t BmsrInts, BmsrData;
394 MI_ISR_t myIsr; 366 MI_ISR_t myIsr;
395 367
396 DBG_VERBOSE(et131x_dbginfo, "PHY interrupt\n");
397
398 /* If we are in coma mode when we get this interrupt, 368 /* If we are in coma mode when we get this interrupt,
399 * we need to disable it. 369 * we need to disable it.
400 */ 370 */
@@ -405,9 +375,6 @@ void et131x_isr_handler(struct work_struct *work)
405 * so, disable it because we will not be able 375 * so, disable it because we will not be able
406 * to read PHY values until we are out. 376 * to read PHY values until we are out.
407 */ 377 */
408 DBG_VERBOSE(et131x_dbginfo,
409 "Device is in COMA mode, "
410 "need to wake up\n");
411 DisablePhyComa(etdev); 378 DisablePhyComa(etdev);
412 } 379 }
413 380
@@ -426,11 +393,6 @@ void et131x_isr_handler(struct work_struct *work)
426 etdev->Bmsr.value ^ BmsrData.value; 393 etdev->Bmsr.value ^ BmsrData.value;
427 etdev->Bmsr.value = BmsrData.value; 394 etdev->Bmsr.value = BmsrData.value;
428 395
429 DBG_VERBOSE(et131x_dbginfo,
430 "Bmsr.value = 0x%04x,"
431 "Bmsr_ints.value = 0x%04x\n",
432 BmsrData.value, BmsrInts.value);
433
434 /* Do all the cable in / cable out stuff */ 396 /* Do all the cable in / cable out stuff */
435 et131x_Mii_check(etdev, BmsrData, BmsrInts); 397 et131x_Mii_check(etdev, BmsrData, BmsrInts);
436 } 398 }
@@ -451,7 +413,7 @@ void et131x_isr_handler(struct work_struct *work)
451 * a nutshell, the whole Tx path will have to be reset 413 * a nutshell, the whole Tx path will have to be reset
452 * and re-configured afterwards. 414 * and re-configured afterwards.
453 */ 415 */
454 DBG_WARNING(et131x_dbginfo, 416 dev_warn(&etdev->pdev->dev,
455 "TXMAC interrupt, error 0x%08x\n", 417 "TXMAC interrupt, error 0x%08x\n",
456 etdev->TxRing.TxMacErr.value); 418 etdev->TxRing.TxMacErr.value);
457 419
@@ -459,7 +421,6 @@ void et131x_isr_handler(struct work_struct *work)
459 * otherwise we just want the device to be reset and 421 * otherwise we just want the device to be reset and
460 * continue 422 * continue
461 */ 423 */
462 /* DBG_TRAP(); */
463 } 424 }
464 425
465 /* Handle RXMAC Interrupt */ 426 /* Handle RXMAC Interrupt */
@@ -473,11 +434,11 @@ void et131x_isr_handler(struct work_struct *work)
473 /* MP_SET_FLAG( etdev, 434 /* MP_SET_FLAG( etdev,
474 fMP_ADAPTER_HARDWARE_ERROR); */ 435 fMP_ADAPTER_HARDWARE_ERROR); */
475 436
476 DBG_WARNING(et131x_dbginfo, 437 dev_warn(&etdev->pdev->dev,
477 "RXMAC interrupt, error 0x%08x. Requesting reset\n", 438 "RXMAC interrupt, error 0x%08x. Requesting reset\n",
478 readl(&iomem->rxmac.err_reg.value)); 439 readl(&iomem->rxmac.err_reg.value));
479 440
480 DBG_WARNING(et131x_dbginfo, 441 dev_warn(&etdev->pdev->dev,
481 "Enable 0x%08x, Diag 0x%08x\n", 442 "Enable 0x%08x, Diag 0x%08x\n",
482 readl(&iomem->rxmac.ctrl.value), 443 readl(&iomem->rxmac.ctrl.value),
483 readl(&iomem->rxmac.rxq_diag.value)); 444 readl(&iomem->rxmac.rxq_diag.value));
@@ -487,7 +448,6 @@ void et131x_isr_handler(struct work_struct *work)
487 * otherwise we just want the device to be reset and 448 * otherwise we just want the device to be reset and
488 * continue 449 * continue
489 */ 450 */
490 /* TRAP(); */
491 } 451 }
492 452
493 /* Handle MAC_STAT Interrupt */ 453 /* Handle MAC_STAT Interrupt */
@@ -498,7 +458,6 @@ void et131x_isr_handler(struct work_struct *work)
498 * to maintain the top, software managed bits of the 458 * to maintain the top, software managed bits of the
499 * counter(s). 459 * counter(s).
500 */ 460 */
501 DBG_VERBOSE(et131x_dbginfo, "MAC_STAT interrupt\n");
502 HandleMacStatInterrupt(etdev); 461 HandleMacStatInterrupt(etdev);
503 } 462 }
504 463
@@ -513,7 +472,6 @@ void et131x_isr_handler(struct work_struct *work)
513 * addressed module is in a power-down state and 472 * addressed module is in a power-down state and
514 * can't respond. 473 * can't respond.
515 */ 474 */
516 DBG_VERBOSE(et131x_dbginfo, "SLV_TIMEOUT interrupt\n");
517 } 475 }
518 } 476 }
519 et131x_enable_interrupts(etdev); 477 et131x_enable_interrupts(etdev);
diff --git a/drivers/staging/et131x/et131x_netdev.c b/drivers/staging/et131x/et131x_netdev.c
index 2a4b9ac9539e..8c7612f63f91 100644
--- a/drivers/staging/et131x/et131x_netdev.c
+++ b/drivers/staging/et131x/et131x_netdev.c
@@ -56,7 +56,6 @@
56 */ 56 */
57 57
58#include "et131x_version.h" 58#include "et131x_version.h"
59#include "et131x_debug.h"
60#include "et131x_defs.h" 59#include "et131x_defs.h"
61 60
62#include <linux/init.h> 61#include <linux/init.h>
@@ -75,6 +74,7 @@
75#include <linux/delay.h> 74#include <linux/delay.h>
76#include <linux/io.h> 75#include <linux/io.h>
77#include <linux/bitops.h> 76#include <linux/bitops.h>
77#include <linux/pci.h>
78#include <asm/system.h> 78#include <asm/system.h>
79 79
80#include <linux/mii.h> 80#include <linux/mii.h>
@@ -94,11 +94,6 @@
94#include "et131x_isr.h" 94#include "et131x_isr.h"
95#include "et131x_initpci.h" 95#include "et131x_initpci.h"
96 96
97/* Data for debugging facilities */
98#ifdef CONFIG_ET131X_DEBUG
99extern dbg_info_t *et131x_dbginfo;
100#endif /* CONFIG_ET131X_DEBUG */
101
102struct net_device_stats *et131x_stats(struct net_device *netdev); 97struct net_device_stats *et131x_stats(struct net_device *netdev);
103int et131x_open(struct net_device *netdev); 98int et131x_open(struct net_device *netdev);
104int et131x_close(struct net_device *netdev); 99int et131x_close(struct net_device *netdev);
@@ -138,15 +133,11 @@ struct net_device *et131x_device_alloc(void)
138{ 133{
139 struct net_device *netdev; 134 struct net_device *netdev;
140 135
141 DBG_ENTER(et131x_dbginfo);
142
143 /* Alloc net_device and adapter structs */ 136 /* Alloc net_device and adapter structs */
144 netdev = alloc_etherdev(sizeof(struct et131x_adapter)); 137 netdev = alloc_etherdev(sizeof(struct et131x_adapter));
145 138
146 if (netdev == NULL) { 139 if (netdev == NULL) {
147 DBG_ERROR(et131x_dbginfo, 140 printk(KERN_ERR "et131x: Alloc of net_device struct failed\n");
148 "Alloc of net_device struct failed\n");
149 DBG_LEAVE(et131x_dbginfo);
150 return NULL; 141 return NULL;
151 } 142 }
152 143
@@ -163,8 +154,6 @@ struct net_device *et131x_device_alloc(void)
163 /* Poll? */ 154 /* Poll? */
164 /* netdev->poll = &et131x_poll; */ 155 /* netdev->poll = &et131x_poll; */
165 /* netdev->poll_controller = &et131x_poll_controller; */ 156 /* netdev->poll_controller = &et131x_poll_controller; */
166
167 DBG_LEAVE(et131x_dbginfo);
168 return netdev; 157 return netdev;
169} 158}
170 159
@@ -180,8 +169,6 @@ struct net_device_stats *et131x_stats(struct net_device *netdev)
180 struct net_device_stats *stats = &adapter->net_stats; 169 struct net_device_stats *stats = &adapter->net_stats;
181 CE_STATS_t *devstat = &adapter->Stats; 170 CE_STATS_t *devstat = &adapter->Stats;
182 171
183 DBG_ENTER(et131x_dbginfo);
184
185 stats->rx_packets = devstat->ipackets; 172 stats->rx_packets = devstat->ipackets;
186 stats->tx_packets = devstat->opackets; 173 stats->tx_packets = devstat->opackets;
187 stats->rx_errors = devstat->length_err + devstat->alignment_err + 174 stats->rx_errors = devstat->length_err + devstat->alignment_err +
@@ -213,8 +200,6 @@ struct net_device_stats *et131x_stats(struct net_device *netdev)
213 /* stats->tx_fifo_errors = devstat->; */ 200 /* stats->tx_fifo_errors = devstat->; */
214 /* stats->tx_heartbeat_errors = devstat->; */ 201 /* stats->tx_heartbeat_errors = devstat->; */
215 /* stats->tx_window_errors = devstat->; */ 202 /* stats->tx_window_errors = devstat->; */
216
217 DBG_LEAVE(et131x_dbginfo);
218 return stats; 203 return stats;
219} 204}
220 205
@@ -229,20 +214,15 @@ int et131x_open(struct net_device *netdev)
229 int result = 0; 214 int result = 0;
230 struct et131x_adapter *adapter = netdev_priv(netdev); 215 struct et131x_adapter *adapter = netdev_priv(netdev);
231 216
232 DBG_ENTER(et131x_dbginfo);
233
234 /* Start the timer to track NIC errors */ 217 /* Start the timer to track NIC errors */
235 add_timer(&adapter->ErrorTimer); 218 add_timer(&adapter->ErrorTimer);
236 219
237 /* Register our ISR */ 220 /* Register our IRQ */
238 DBG_TRACE(et131x_dbginfo, "Registering ISR...\n"); 221 result = request_irq(netdev->irq, et131x_isr, IRQF_SHARED,
239 222 netdev->name, netdev);
240 result =
241 request_irq(netdev->irq, et131x_isr, IRQF_SHARED, netdev->name,
242 netdev);
243 if (result) { 223 if (result) {
244 DBG_ERROR(et131x_dbginfo, "Could not register ISR\n"); 224 dev_err(&adapter->pdev->dev, "c ould not register IRQ %d\n",
245 DBG_LEAVE(et131x_dbginfo); 225 netdev->irq);
246 return result; 226 return result;
247 } 227 }
248 228
@@ -257,8 +237,6 @@ int et131x_open(struct net_device *netdev)
257 237
258 /* We're ready to move some data, so start the queue */ 238 /* We're ready to move some data, so start the queue */
259 netif_start_queue(netdev); 239 netif_start_queue(netdev);
260
261 DBG_LEAVE(et131x_dbginfo);
262 return result; 240 return result;
263} 241}
264 242
@@ -272,8 +250,6 @@ int et131x_close(struct net_device *netdev)
272{ 250{
273 struct et131x_adapter *adapter = netdev_priv(netdev); 251 struct et131x_adapter *adapter = netdev_priv(netdev);
274 252
275 DBG_ENTER(et131x_dbginfo);
276
277 /* First thing is to stop the queue */ 253 /* First thing is to stop the queue */
278 netif_stop_queue(netdev); 254 netif_stop_queue(netdev);
279 255
@@ -286,14 +262,10 @@ int et131x_close(struct net_device *netdev)
286 262
287 /* Deregistering ISR */ 263 /* Deregistering ISR */
288 adapter->Flags &= ~fMP_ADAPTER_INTERRUPT_IN_USE; 264 adapter->Flags &= ~fMP_ADAPTER_INTERRUPT_IN_USE;
289
290 DBG_TRACE(et131x_dbginfo, "Deregistering ISR...\n");
291 free_irq(netdev->irq, netdev); 265 free_irq(netdev->irq, netdev);
292 266
293 /* Stop the error timer */ 267 /* Stop the error timer */
294 del_timer_sync(&adapter->ErrorTimer); 268 del_timer_sync(&adapter->ErrorTimer);
295
296 DBG_LEAVE(et131x_dbginfo);
297 return 0; 269 return 0;
298} 270}
299 271
@@ -311,39 +283,30 @@ int et131x_ioctl_mii(struct net_device *netdev, struct ifreq *reqbuf, int cmd)
311 struct et131x_adapter *etdev = netdev_priv(netdev); 283 struct et131x_adapter *etdev = netdev_priv(netdev);
312 struct mii_ioctl_data *data = if_mii(reqbuf); 284 struct mii_ioctl_data *data = if_mii(reqbuf);
313 285
314 DBG_ENTER(et131x_dbginfo);
315
316 switch (cmd) { 286 switch (cmd) {
317 case SIOCGMIIPHY: 287 case SIOCGMIIPHY:
318 DBG_VERBOSE(et131x_dbginfo, "SIOCGMIIPHY\n");
319 data->phy_id = etdev->Stats.xcvr_addr; 288 data->phy_id = etdev->Stats.xcvr_addr;
320 break; 289 break;
321 290
322 case SIOCGMIIREG: 291 case SIOCGMIIREG:
323 DBG_VERBOSE(et131x_dbginfo, "SIOCGMIIREG\n"); 292 if (!capable(CAP_NET_ADMIN))
324 if (!capable(CAP_NET_ADMIN)) {
325 status = -EPERM; 293 status = -EPERM;
326 } else { 294 else
327 status = MiRead(etdev, 295 status = MiRead(etdev,
328 data->reg_num, &data->val_out); 296 data->reg_num, &data->val_out);
329 }
330 break; 297 break;
331 298
332 case SIOCSMIIREG: 299 case SIOCSMIIREG:
333 DBG_VERBOSE(et131x_dbginfo, "SIOCSMIIREG\n"); 300 if (!capable(CAP_NET_ADMIN))
334 if (!capable(CAP_NET_ADMIN)) {
335 status = -EPERM; 301 status = -EPERM;
336 } else { 302 else
337 status = MiWrite(etdev, data->reg_num, 303 status = MiWrite(etdev, data->reg_num,
338 data->val_in); 304 data->val_in);
339 }
340 break; 305 break;
341 306
342 default: 307 default:
343 status = -EOPNOTSUPP; 308 status = -EOPNOTSUPP;
344 } 309 }
345
346 DBG_LEAVE(et131x_dbginfo);
347 return status; 310 return status;
348} 311}
349 312
@@ -359,8 +322,6 @@ int et131x_ioctl(struct net_device *netdev, struct ifreq *reqbuf, int cmd)
359{ 322{
360 int status = 0; 323 int status = 0;
361 324
362 DBG_ENTER(et131x_dbginfo);
363
364 switch (cmd) { 325 switch (cmd) {
365 case SIOCGMIIPHY: 326 case SIOCGMIIPHY:
366 case SIOCGMIIREG: 327 case SIOCGMIIREG:
@@ -369,12 +330,8 @@ int et131x_ioctl(struct net_device *netdev, struct ifreq *reqbuf, int cmd)
369 break; 330 break;
370 331
371 default: 332 default:
372 DBG_WARNING(et131x_dbginfo, "Unhandled IOCTL Code: 0x%04x\n",
373 cmd);
374 status = -EOPNOTSUPP; 333 status = -EOPNOTSUPP;
375 } 334 }
376
377 DBG_LEAVE(et131x_dbginfo);
378 return status; 335 return status;
379} 336}
380 337
@@ -391,8 +348,6 @@ int et131x_set_packet_filter(struct et131x_adapter *adapter)
391 RXMAC_CTRL_t ctrl; 348 RXMAC_CTRL_t ctrl;
392 RXMAC_PF_CTRL_t pf_ctrl; 349 RXMAC_PF_CTRL_t pf_ctrl;
393 350
394 DBG_ENTER(et131x_dbginfo);
395
396 ctrl.value = readl(&adapter->regs->rxmac.ctrl.value); 351 ctrl.value = readl(&adapter->regs->rxmac.ctrl.value);
397 pf_ctrl.value = readl(&adapter->regs->rxmac.pf_ctrl.value); 352 pf_ctrl.value = readl(&adapter->regs->rxmac.pf_ctrl.value);
398 353
@@ -415,12 +370,8 @@ int et131x_set_packet_filter(struct et131x_adapter *adapter)
415 * multicast entries or (3) we receive none. 370 * multicast entries or (3) we receive none.
416 */ 371 */
417 if (filter & ET131X_PACKET_TYPE_ALL_MULTICAST) { 372 if (filter & ET131X_PACKET_TYPE_ALL_MULTICAST) {
418 DBG_VERBOSE(et131x_dbginfo,
419 "Multicast filtering OFF (Rx ALL MULTICAST)\n");
420 pf_ctrl.bits.filter_multi_en = 0; 373 pf_ctrl.bits.filter_multi_en = 0;
421 } else { 374 } else {
422 DBG_VERBOSE(et131x_dbginfo,
423 "Multicast filtering ON\n");
424 SetupDeviceForMulticast(adapter); 375 SetupDeviceForMulticast(adapter);
425 pf_ctrl.bits.filter_multi_en = 1; 376 pf_ctrl.bits.filter_multi_en = 1;
426 ctrl.bits.pkt_filter_disable = 0; 377 ctrl.bits.pkt_filter_disable = 0;
@@ -428,7 +379,6 @@ int et131x_set_packet_filter(struct et131x_adapter *adapter)
428 379
429 /* Set us up with Unicast packet filtering */ 380 /* Set us up with Unicast packet filtering */
430 if (filter & ET131X_PACKET_TYPE_DIRECTED) { 381 if (filter & ET131X_PACKET_TYPE_DIRECTED) {
431 DBG_VERBOSE(et131x_dbginfo, "Unicast Filtering ON\n");
432 SetupDeviceForUnicast(adapter); 382 SetupDeviceForUnicast(adapter);
433 pf_ctrl.bits.filter_uni_en = 1; 383 pf_ctrl.bits.filter_uni_en = 1;
434 ctrl.bits.pkt_filter_disable = 0; 384 ctrl.bits.pkt_filter_disable = 0;
@@ -436,12 +386,9 @@ int et131x_set_packet_filter(struct et131x_adapter *adapter)
436 386
437 /* Set us up with Broadcast packet filtering */ 387 /* Set us up with Broadcast packet filtering */
438 if (filter & ET131X_PACKET_TYPE_BROADCAST) { 388 if (filter & ET131X_PACKET_TYPE_BROADCAST) {
439 DBG_VERBOSE(et131x_dbginfo, "Broadcast Filtering ON\n");
440 pf_ctrl.bits.filter_broad_en = 1; 389 pf_ctrl.bits.filter_broad_en = 1;
441 ctrl.bits.pkt_filter_disable = 0; 390 ctrl.bits.pkt_filter_disable = 0;
442 } else { 391 } else {
443 DBG_VERBOSE(et131x_dbginfo,
444 "Broadcast Filtering OFF\n");
445 pf_ctrl.bits.filter_broad_en = 0; 392 pf_ctrl.bits.filter_broad_en = 0;
446 } 393 }
447 394
@@ -453,8 +400,6 @@ int et131x_set_packet_filter(struct et131x_adapter *adapter)
453 &adapter->regs->rxmac.pf_ctrl.value); 400 &adapter->regs->rxmac.pf_ctrl.value);
454 writel(ctrl.value, &adapter->regs->rxmac.ctrl.value); 401 writel(ctrl.value, &adapter->regs->rxmac.ctrl.value);
455 } 402 }
456
457 DBG_LEAVE(et131x_dbginfo);
458 return status; 403 return status;
459} 404}
460 405
@@ -470,8 +415,6 @@ void et131x_multicast(struct net_device *netdev)
470 unsigned long flags; 415 unsigned long flags;
471 struct dev_mc_list *mclist = netdev->mc_list; 416 struct dev_mc_list *mclist = netdev->mc_list;
472 417
473 DBG_ENTER(et131x_dbginfo);
474
475 spin_lock_irqsave(&adapter->Lock, flags); 418 spin_lock_irqsave(&adapter->Lock, flags);
476 419
477 /* Before we modify the platform-independent filter flags, store them 420 /* Before we modify the platform-independent filter flags, store them
@@ -490,35 +433,25 @@ void et131x_multicast(struct net_device *netdev)
490 /* Check the net_device flags and set the device independent flags 433 /* Check the net_device flags and set the device independent flags
491 * accordingly 434 * accordingly
492 */ 435 */
493 DBG_VERBOSE(et131x_dbginfo,
494 "MULTICAST ADDR COUNT: %d\n", netdev->mc_count);
495 436
496 if (netdev->flags & IFF_PROMISC) { 437 if (netdev->flags & IFF_PROMISC) {
497 DBG_VERBOSE(et131x_dbginfo, "Request: PROMISCUOUS MODE ON\n");
498 adapter->PacketFilter |= ET131X_PACKET_TYPE_PROMISCUOUS; 438 adapter->PacketFilter |= ET131X_PACKET_TYPE_PROMISCUOUS;
499 } else { 439 } else {
500 DBG_VERBOSE(et131x_dbginfo, "Request: PROMISCUOUS MODE OFF\n");
501 adapter->PacketFilter &= ~ET131X_PACKET_TYPE_PROMISCUOUS; 440 adapter->PacketFilter &= ~ET131X_PACKET_TYPE_PROMISCUOUS;
502 } 441 }
503 442
504 if (netdev->flags & IFF_ALLMULTI) { 443 if (netdev->flags & IFF_ALLMULTI) {
505 DBG_VERBOSE(et131x_dbginfo, "Request: ACCEPT ALL MULTICAST\n");
506 adapter->PacketFilter |= ET131X_PACKET_TYPE_ALL_MULTICAST; 444 adapter->PacketFilter |= ET131X_PACKET_TYPE_ALL_MULTICAST;
507 } 445 }
508 446
509 if (netdev->mc_count > NIC_MAX_MCAST_LIST) { 447 if (netdev->mc_count > NIC_MAX_MCAST_LIST) {
510 DBG_WARNING(et131x_dbginfo,
511 "ACCEPT ALL MULTICAST for now, as there's more Multicast addresses than the HW supports\n");
512 adapter->PacketFilter |= ET131X_PACKET_TYPE_ALL_MULTICAST; 448 adapter->PacketFilter |= ET131X_PACKET_TYPE_ALL_MULTICAST;
513 } 449 }
514 450
515 if (netdev->mc_count < 1) { 451 if (netdev->mc_count < 1) {
516 DBG_VERBOSE(et131x_dbginfo, "Request: REJECT ALL MULTICAST\n");
517 adapter->PacketFilter &= ~ET131X_PACKET_TYPE_ALL_MULTICAST; 452 adapter->PacketFilter &= ~ET131X_PACKET_TYPE_ALL_MULTICAST;
518 adapter->PacketFilter &= ~ET131X_PACKET_TYPE_MULTICAST; 453 adapter->PacketFilter &= ~ET131X_PACKET_TYPE_MULTICAST;
519 } else { 454 } else {
520 DBG_VERBOSE(et131x_dbginfo,
521 "Request: SET MULTICAST FILTER(S)\n");
522 adapter->PacketFilter |= ET131X_PACKET_TYPE_MULTICAST; 455 adapter->PacketFilter |= ET131X_PACKET_TYPE_MULTICAST;
523 } 456 }
524 457
@@ -526,14 +459,8 @@ void et131x_multicast(struct net_device *netdev)
526 adapter->MCAddressCount = netdev->mc_count; 459 adapter->MCAddressCount = netdev->mc_count;
527 460
528 if (netdev->mc_count) { 461 if (netdev->mc_count) {
529 if (mclist->dmi_addrlen != ETH_ALEN) 462 count = netdev->mc_count - 1;
530 DBG_WARNING(et131x_dbginfo, 463 memcpy(adapter->MCList[count], mclist->dmi_addr, ETH_ALEN);
531 "Multicast addrs are not ETH_ALEN in size\n");
532 else {
533 count = netdev->mc_count - 1;
534 memcpy(adapter->MCList[count], mclist->dmi_addr,
535 ETH_ALEN);
536 }
537 } 464 }
538 465
539 /* Are the new flags different from the previous ones? If not, then no 466 /* Are the new flags different from the previous ones? If not, then no
@@ -544,17 +471,9 @@ void et131x_multicast(struct net_device *netdev)
544 */ 471 */
545 if (PacketFilter != adapter->PacketFilter) { 472 if (PacketFilter != adapter->PacketFilter) {
546 /* Call the device's filter function */ 473 /* Call the device's filter function */
547 DBG_VERBOSE(et131x_dbginfo, "UPDATE REQUIRED, FLAGS changed\n");
548
549 et131x_set_packet_filter(adapter); 474 et131x_set_packet_filter(adapter);
550 } else {
551 DBG_VERBOSE(et131x_dbginfo,
552 "NO UPDATE REQUIRED, FLAGS didn't change\n");
553 } 475 }
554
555 spin_unlock_irqrestore(&adapter->Lock, flags); 476 spin_unlock_irqrestore(&adapter->Lock, flags);
556
557 DBG_LEAVE(et131x_dbginfo);
558} 477}
559 478
560/** 479/**
@@ -568,8 +487,6 @@ int et131x_tx(struct sk_buff *skb, struct net_device *netdev)
568{ 487{
569 int status = 0; 488 int status = 0;
570 489
571 DBG_TX_ENTER(et131x_dbginfo);
572
573 /* Save the timestamp for the TX timeout watchdog */ 490 /* Save the timestamp for the TX timeout watchdog */
574 netdev->trans_start = jiffies; 491 netdev->trans_start = jiffies;
575 492
@@ -579,22 +496,15 @@ int et131x_tx(struct sk_buff *skb, struct net_device *netdev)
579 /* Check status and manage the netif queue if necessary */ 496 /* Check status and manage the netif queue if necessary */
580 if (status != 0) { 497 if (status != 0) {
581 if (status == -ENOMEM) { 498 if (status == -ENOMEM) {
582 DBG_VERBOSE(et131x_dbginfo,
583 "OUT OF TCBs; STOP NETIF QUEUE\n");
584
585 /* Put the queue to sleep until resources are 499 /* Put the queue to sleep until resources are
586 * available 500 * available
587 */ 501 */
588 netif_stop_queue(netdev); 502 netif_stop_queue(netdev);
589 status = NETDEV_TX_BUSY; 503 status = NETDEV_TX_BUSY;
590 } else { 504 } else {
591 DBG_WARNING(et131x_dbginfo,
592 "Misc error; drop packet\n");
593 status = NETDEV_TX_OK; 505 status = NETDEV_TX_OK;
594 } 506 }
595 } 507 }
596
597 DBG_TX_LEAVE(et131x_dbginfo);
598 return status; 508 return status;
599} 509}
600 510
@@ -612,25 +522,19 @@ void et131x_tx_timeout(struct net_device *netdev)
612 PMP_TCB pMpTcb; 522 PMP_TCB pMpTcb;
613 unsigned long flags; 523 unsigned long flags;
614 524
615 DBG_WARNING(et131x_dbginfo, "TX TIMEOUT\n");
616
617 /* Just skip this part if the adapter is doing link detection */ 525 /* Just skip this part if the adapter is doing link detection */
618 if (etdev->Flags & fMP_ADAPTER_LINK_DETECTION) { 526 if (etdev->Flags & fMP_ADAPTER_LINK_DETECTION)
619 DBG_ERROR(et131x_dbginfo, "Still doing link detection\n");
620 return; 527 return;
621 }
622 528
623 /* Any nonrecoverable hardware error? 529 /* Any nonrecoverable hardware error?
624 * Checks adapter->flags for any failure in phy reading 530 * Checks adapter->flags for any failure in phy reading
625 */ 531 */
626 if (etdev->Flags & fMP_ADAPTER_NON_RECOVER_ERROR) { 532 if (etdev->Flags & fMP_ADAPTER_NON_RECOVER_ERROR)
627 DBG_WARNING(et131x_dbginfo, "Non recoverable error - remove\n");
628 return; 533 return;
629 }
630 534
631 /* Hardware failure? */ 535 /* Hardware failure? */
632 if (etdev->Flags & fMP_ADAPTER_HARDWARE_ERROR) { 536 if (etdev->Flags & fMP_ADAPTER_HARDWARE_ERROR) {
633 DBG_WARNING(et131x_dbginfo, "hardware error - reset\n"); 537 dev_err(&etdev->pdev->dev, "hardware error - reset\n");
634 return; 538 return;
635 } 539 }
636 540
@@ -643,13 +547,6 @@ void et131x_tx_timeout(struct net_device *netdev)
643 pMpTcb->Count++; 547 pMpTcb->Count++;
644 548
645 if (pMpTcb->Count > NIC_SEND_HANG_THRESHOLD) { 549 if (pMpTcb->Count > NIC_SEND_HANG_THRESHOLD) {
646#ifdef CONFIG_ET131X_DEBUG
647 TX_STATUS_BLOCK_t txDmaComplete =
648 *(etdev->TxRing.pTxStatusVa);
649 PTX_DESC_ENTRY_t pDesc =
650 etdev->TxRing.pTxDescRingVa +
651 INDEX10(pMpTcb->WrIndex);
652#endif
653 TX_DESC_ENTRY_t StuckDescriptors[10]; 550 TX_DESC_ENTRY_t StuckDescriptors[10];
654 551
655 if (INDEX10(pMpTcb->WrIndex) > 7) { 552 if (INDEX10(pMpTcb->WrIndex) > 7) {
@@ -662,26 +559,11 @@ void et131x_tx_timeout(struct net_device *netdev)
662 spin_unlock_irqrestore(&etdev->TCBSendQLock, 559 spin_unlock_irqrestore(&etdev->TCBSendQLock,
663 flags); 560 flags);
664 561
665 DBG_WARNING(et131x_dbginfo, 562 dev_warn(&etdev->pdev->dev,
666 "Send stuck - reset. pMpTcb->WrIndex %x, Flags 0x%08x\n", 563 "Send stuck - reset. pMpTcb->WrIndex %x, Flags 0x%08x\n",
667 pMpTcb->WrIndex, 564 pMpTcb->WrIndex,
668 pMpTcb->Flags); 565 pMpTcb->Flags);
669 566
670 DBG_WARNING(et131x_dbginfo,
671 "pDesc 0x%08x, 0x%08x, 0x%08x, 0x%08x\n",
672 pDesc->DataBufferPtrHigh,
673 pDesc->DataBufferPtrLow, pDesc->word2.value,
674 pDesc->word3.value);
675
676 DBG_WARNING(et131x_dbginfo,
677 "WbStatus 0x%08x\n", txDmaComplete.value);
678
679#ifdef CONFIG_ET131X_DEBUG
680 DumpDeviceBlock(DBG_WARNING_ON, etdev, 0);
681 DumpDeviceBlock(DBG_WARNING_ON, etdev, 1);
682 DumpDeviceBlock(DBG_WARNING_ON, etdev, 3);
683 DumpDeviceBlock(DBG_WARNING_ON, etdev, 5);
684#endif
685 et131x_close(netdev); 567 et131x_close(netdev);
686 et131x_open(netdev); 568 et131x_open(netdev);
687 569
@@ -704,13 +586,9 @@ int et131x_change_mtu(struct net_device *netdev, int new_mtu)
704 int result = 0; 586 int result = 0;
705 struct et131x_adapter *adapter = netdev_priv(netdev); 587 struct et131x_adapter *adapter = netdev_priv(netdev);
706 588
707 DBG_ENTER(et131x_dbginfo);
708
709 /* Make sure the requested MTU is valid */ 589 /* Make sure the requested MTU is valid */
710 if (new_mtu == 0 || new_mtu > 9216) { 590 if (new_mtu < 64 || new_mtu > 9216)
711 DBG_LEAVE(et131x_dbginfo);
712 return -EINVAL; 591 return -EINVAL;
713 }
714 592
715 /* Stop the netif queue */ 593 /* Stop the netif queue */
716 netif_stop_queue(netdev); 594 netif_stop_queue(netdev);
@@ -737,7 +615,7 @@ int et131x_change_mtu(struct net_device *netdev, int new_mtu)
737 /* Alloc and init Rx DMA memory */ 615 /* Alloc and init Rx DMA memory */
738 result = et131x_adapter_memory_alloc(adapter); 616 result = et131x_adapter_memory_alloc(adapter);
739 if (result != 0) { 617 if (result != 0) {
740 DBG_WARNING(et131x_dbginfo, 618 dev_warn(&adapter->pdev->dev,
741 "Change MTU failed; couldn't re-alloc DMA memory\n"); 619 "Change MTU failed; couldn't re-alloc DMA memory\n");
742 return result; 620 return result;
743 } 621 }
@@ -760,8 +638,6 @@ int et131x_change_mtu(struct net_device *netdev, int new_mtu)
760 638
761 /* Restart the netif queue */ 639 /* Restart the netif queue */
762 netif_wake_queue(netdev); 640 netif_wake_queue(netdev);
763
764 DBG_LEAVE(et131x_dbginfo);
765 return result; 641 return result;
766} 642}
767 643
@@ -780,20 +656,14 @@ int et131x_set_mac_addr(struct net_device *netdev, void *new_mac)
780 struct et131x_adapter *adapter = netdev_priv(netdev); 656 struct et131x_adapter *adapter = netdev_priv(netdev);
781 struct sockaddr *address = new_mac; 657 struct sockaddr *address = new_mac;
782 658
783 DBG_ENTER(et131x_dbginfo);
784 /* begin blux */ 659 /* begin blux */
785 /* DBG_VERBOSE( et131x_dbginfo, "Function not implemented!!\n" ); */
786 660
787 if (adapter == NULL) { 661 if (adapter == NULL)
788 DBG_LEAVE(et131x_dbginfo);
789 return -ENODEV; 662 return -ENODEV;
790 }
791 663
792 /* Make sure the requested MAC is valid */ 664 /* Make sure the requested MAC is valid */
793 if (!is_valid_ether_addr(address->sa_data)) { 665 if (!is_valid_ether_addr(address->sa_data))
794 DBG_LEAVE(et131x_dbginfo);
795 return -EINVAL; 666 return -EINVAL;
796 }
797 667
798 /* Stop the netif queue */ 668 /* Stop the netif queue */
799 netif_stop_queue(netdev); 669 netif_stop_queue(netdev);
@@ -832,7 +702,7 @@ int et131x_set_mac_addr(struct net_device *netdev, void *new_mac)
832 /* Alloc and init Rx DMA memory */ 702 /* Alloc and init Rx DMA memory */
833 result = et131x_adapter_memory_alloc(adapter); 703 result = et131x_adapter_memory_alloc(adapter);
834 if (result != 0) { 704 if (result != 0) {
835 DBG_WARNING(et131x_dbginfo, 705 dev_err(&adapter->pdev->dev,
836 "Change MAC failed; couldn't re-alloc DMA memory\n"); 706 "Change MAC failed; couldn't re-alloc DMA memory\n");
837 return result; 707 return result;
838 } 708 }
@@ -856,7 +726,5 @@ int et131x_set_mac_addr(struct net_device *netdev, void *new_mac)
856 726
857 /* Restart the netif queue */ 727 /* Restart the netif queue */
858 netif_wake_queue(netdev); 728 netif_wake_queue(netdev);
859
860 DBG_LEAVE(et131x_dbginfo);
861 return result; 729 return result;
862} 730}