diff options
author | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-10-18 17:40:30 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-10-18 17:40:30 -0400 |
commit | a57793651ff1a09ef18bade998632435ca2dc13f (patch) | |
tree | fffc839d7b001f196421f09f0a06491588835fe1 /drivers/net/bnx2.c | |
parent | 9cf52b2921fbe62566b6b2ee79f71203749c9e5e (diff) | |
parent | 52f095ee88d8851866bc7694ab991ca5abf21d5e (diff) |
Merge branch 'master' of master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6
* 'master' of master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6: (51 commits)
[IPV6]: Fix again the fl6_sock_lookup() fixed locking
[NETFILTER]: nf_conntrack_tcp: fix connection reopening fix
[IPV6]: Fix race in ipv6_flowlabel_opt() when inserting two labels
[IPV6]: Lost locking in fl6_sock_lookup
[IPV6]: Lost locking when inserting a flowlabel in ipv6_fl_list
[NETFILTER]: xt_sctp: fix mistake to pass a pointer where array is required
[NET]: Fix OOPS due to missing check in dev_parse_header().
[TCP]: Remove lost_retrans zero seqno special cases
[NET]: fix carrier-on bug?
[NET]: Fix uninitialised variable in ip_frag_reasm()
[IPSEC]: Rename mode to outer_mode and add inner_mode
[IPSEC]: Disallow combinations of RO and AH/ESP/IPCOMP
[IPSEC]: Use the top IPv4 route's peer instead of the bottom
[IPSEC]: Store afinfo pointer in xfrm_mode
[IPSEC]: Add missing BEET checks
[IPSEC]: Move type and mode map into xfrm_state.c
[IPSEC]: Fix length check in xfrm_parse_spi
[IPSEC]: Move ip_summed zapping out of xfrm6_rcv_spi
[IPSEC]: Get nexthdr from caller in xfrm6_rcv_spi
[IPSEC]: Move tunnel parsing for IPv4 out of xfrm4_input
...
Diffstat (limited to 'drivers/net/bnx2.c')
-rw-r--r-- | drivers/net/bnx2.c | 32 |
1 files changed, 21 insertions, 11 deletions
diff --git a/drivers/net/bnx2.c b/drivers/net/bnx2.c index fa0d69ab908e..96cee4badd28 100644 --- a/drivers/net/bnx2.c +++ b/drivers/net/bnx2.c | |||
@@ -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 | ||