aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/tg3.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/tg3.c')
-rw-r--r--drivers/net/tg3.c46
1 files changed, 23 insertions, 23 deletions
diff --git a/drivers/net/tg3.c b/drivers/net/tg3.c
index cad519910767..ddeaa0c78305 100644
--- a/drivers/net/tg3.c
+++ b/drivers/net/tg3.c
@@ -12464,6 +12464,28 @@ static int __devinit tg3_init_one(struct pci_dev *pdev,
12464 goto err_out_iounmap; 12464 goto err_out_iounmap;
12465 } 12465 }
12466 12466
12467 if (tp->tg3_flags3 & TG3_FLG3_ENABLE_APE) {
12468 if (!(pci_resource_flags(pdev, 2) & IORESOURCE_MEM)) {
12469 printk(KERN_ERR PFX "Cannot find proper PCI device "
12470 "base address for APE, aborting.\n");
12471 err = -ENODEV;
12472 goto err_out_iounmap;
12473 }
12474
12475 tg3reg_base = pci_resource_start(pdev, 2);
12476 tg3reg_len = pci_resource_len(pdev, 2);
12477
12478 tp->aperegs = ioremap_nocache(tg3reg_base, tg3reg_len);
12479 if (tp->aperegs == 0UL) {
12480 printk(KERN_ERR PFX "Cannot map APE registers, "
12481 "aborting.\n");
12482 err = -ENOMEM;
12483 goto err_out_iounmap;
12484 }
12485
12486 tg3_ape_lock_init(tp);
12487 }
12488
12467 /* 12489 /*
12468 * Reset chip in case UNDI or EFI driver did not shutdown 12490 * Reset chip in case UNDI or EFI driver did not shutdown
12469 * DMA self test will enable WDMAC and we'll see (spurious) 12491 * DMA self test will enable WDMAC and we'll see (spurious)
@@ -12478,7 +12500,7 @@ static int __devinit tg3_init_one(struct pci_dev *pdev,
12478 err = tg3_test_dma(tp); 12500 err = tg3_test_dma(tp);
12479 if (err) { 12501 if (err) {
12480 printk(KERN_ERR PFX "DMA engine test failed, aborting.\n"); 12502 printk(KERN_ERR PFX "DMA engine test failed, aborting.\n");
12481 goto err_out_iounmap; 12503 goto err_out_apeunmap;
12482 } 12504 }
12483 12505
12484 /* Tigon3 can do ipv4 only... and some chips have buggy 12506 /* Tigon3 can do ipv4 only... and some chips have buggy
@@ -12501,28 +12523,6 @@ static int __devinit tg3_init_one(struct pci_dev *pdev,
12501 12523
12502 tg3_init_coal(tp); 12524 tg3_init_coal(tp);
12503 12525
12504 if (tp->tg3_flags3 & TG3_FLG3_ENABLE_APE) {
12505 if (!(pci_resource_flags(pdev, 2) & IORESOURCE_MEM)) {
12506 printk(KERN_ERR PFX "Cannot find proper PCI device "
12507 "base address for APE, aborting.\n");
12508 err = -ENODEV;
12509 goto err_out_iounmap;
12510 }
12511
12512 tg3reg_base = pci_resource_start(pdev, 2);
12513 tg3reg_len = pci_resource_len(pdev, 2);
12514
12515 tp->aperegs = ioremap_nocache(tg3reg_base, tg3reg_len);
12516 if (tp->aperegs == 0UL) {
12517 printk(KERN_ERR PFX "Cannot map APE registers, "
12518 "aborting.\n");
12519 err = -ENOMEM;
12520 goto err_out_iounmap;
12521 }
12522
12523 tg3_ape_lock_init(tp);
12524 }
12525
12526 pci_set_drvdata(pdev, dev); 12526 pci_set_drvdata(pdev, dev);
12527 12527
12528 err = register_netdev(dev); 12528 err = register_netdev(dev);