aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/bnx2.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/bnx2.c')
-rw-r--r--drivers/net/bnx2.c36
1 files changed, 23 insertions, 13 deletions
diff --git a/drivers/net/bnx2.c b/drivers/net/bnx2.c
index 78ed633ceb8..da767d3d5af 100644
--- a/drivers/net/bnx2.c
+++ b/drivers/net/bnx2.c
@@ -26,7 +26,7 @@
26#include <linux/etherdevice.h> 26#include <linux/etherdevice.h>
27#include <linux/skbuff.h> 27#include <linux/skbuff.h>
28#include <linux/dma-mapping.h> 28#include <linux/dma-mapping.h>
29#include <asm/bitops.h> 29#include <linux/bitops.h>
30#include <asm/io.h> 30#include <asm/io.h>
31#include <asm/irq.h> 31#include <asm/irq.h>
32#include <linux/delay.h> 32#include <linux/delay.h>
@@ -56,8 +56,8 @@
56 56
57#define DRV_MODULE_NAME "bnx2" 57#define DRV_MODULE_NAME "bnx2"
58#define PFX DRV_MODULE_NAME ": " 58#define PFX DRV_MODULE_NAME ": "
59#define DRV_MODULE_VERSION "1.6.7" 59#define DRV_MODULE_VERSION "1.6.8"
60#define DRV_MODULE_RELDATE "October 10, 2007" 60#define DRV_MODULE_RELDATE "October 17, 2007"
61 61
62#define RUN_AT(x) (jiffies + (x)) 62#define RUN_AT(x) (jiffies + (x))
63 63
@@ -3079,14 +3079,18 @@ bnx2_set_power_state(struct bnx2 *bp, pci_power_t state)
3079 autoneg = bp->autoneg; 3079 autoneg = bp->autoneg;
3080 advertising = bp->advertising; 3080 advertising = bp->advertising;
3081 3081
3082 bp->autoneg = AUTONEG_SPEED; 3082 if (bp->phy_port == PORT_TP) {
3083 bp->advertising = ADVERTISED_10baseT_Half | 3083 bp->autoneg = AUTONEG_SPEED;
3084 ADVERTISED_10baseT_Full | 3084 bp->advertising = ADVERTISED_10baseT_Half |
3085 ADVERTISED_100baseT_Half | 3085 ADVERTISED_10baseT_Full |
3086 ADVERTISED_100baseT_Full | 3086 ADVERTISED_100baseT_Half |
3087 ADVERTISED_Autoneg; 3087 ADVERTISED_100baseT_Full |
3088 ADVERTISED_Autoneg;
3089 }
3088 3090
3089 bnx2_setup_copper_phy(bp); 3091 spin_lock_bh(&bp->phy_lock);
3092 bnx2_setup_phy(bp, bp->phy_port);
3093 spin_unlock_bh(&bp->phy_lock);
3090 3094
3091 bp->autoneg = autoneg; 3095 bp->autoneg = autoneg;
3092 bp->advertising = advertising; 3096 bp->advertising = advertising;
@@ -3097,10 +3101,16 @@ bnx2_set_power_state(struct bnx2 *bp, pci_power_t state)
3097 3101
3098 /* Enable port mode. */ 3102 /* Enable port mode. */
3099 val &= ~BNX2_EMAC_MODE_PORT; 3103 val &= ~BNX2_EMAC_MODE_PORT;
3100 val |= BNX2_EMAC_MODE_PORT_MII | 3104 val |= BNX2_EMAC_MODE_MPKT_RCVD |
3101 BNX2_EMAC_MODE_MPKT_RCVD |
3102 BNX2_EMAC_MODE_ACPI_RCVD | 3105 BNX2_EMAC_MODE_ACPI_RCVD |
3103 BNX2_EMAC_MODE_MPKT; 3106 BNX2_EMAC_MODE_MPKT;
3107 if (bp->phy_port == PORT_TP)
3108 val |= BNX2_EMAC_MODE_PORT_MII;
3109 else {
3110 val |= BNX2_EMAC_MODE_PORT_GMII;
3111 if (bp->line_speed == SPEED_2500)
3112 val |= BNX2_EMAC_MODE_25G_MODE;
3113 }
3104 3114
3105 REG_WR(bp, BNX2_EMAC_MODE, val); 3115 REG_WR(bp, BNX2_EMAC_MODE, val);
3106 3116
@@ -6428,7 +6438,7 @@ bnx2_init_board(struct pci_dev *pdev, struct net_device *dev)
6428 /* enable device (incl. PCI PM wakeup), and bus-mastering */ 6438 /* enable device (incl. PCI PM wakeup), and bus-mastering */
6429 rc = pci_enable_device(pdev); 6439 rc = pci_enable_device(pdev);
6430 if (rc) { 6440 if (rc) {
6431 dev_err(&pdev->dev, "Cannot enable PCI device, aborting."); 6441 dev_err(&pdev->dev, "Cannot enable PCI device, aborting.\n");
6432 goto err_out; 6442 goto err_out;
6433 } 6443 }
6434 6444