Archived
14
0
Fork 0

[BNX2]: Put MII register offsets in the bnx2 struct.

The 5709 Serdes device uses non-standard MII register offsets.  This
re-structuring will make it easier to support 5709 Serdes.

Signed-off-by: Michael Chan <mchan@broadcom.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Michael Chan 2007-05-03 13:22:52 -07:00 committed by David S. Miller
parent 4666f87a82
commit ca58c3af99
2 changed files with 58 additions and 47 deletions

View file

@ -572,8 +572,8 @@ bnx2_report_fw_link(struct bnx2 *bp)
if (bp->autoneg) { if (bp->autoneg) {
fw_link_status |= BNX2_LINK_STATUS_AN_ENABLED; fw_link_status |= BNX2_LINK_STATUS_AN_ENABLED;
bnx2_read_phy(bp, MII_BMSR, &bmsr); bnx2_read_phy(bp, bp->mii_bmsr, &bmsr);
bnx2_read_phy(bp, MII_BMSR, &bmsr); bnx2_read_phy(bp, bp->mii_bmsr, &bmsr);
if (!(bmsr & BMSR_ANEGCOMPLETE) || if (!(bmsr & BMSR_ANEGCOMPLETE) ||
bp->phy_flags & PHY_PARALLEL_DETECT_FLAG) bp->phy_flags & PHY_PARALLEL_DETECT_FLAG)
@ -654,8 +654,8 @@ bnx2_resolve_flow_ctrl(struct bnx2 *bp)
return; return;
} }
bnx2_read_phy(bp, MII_ADVERTISE, &local_adv); bnx2_read_phy(bp, bp->mii_adv, &local_adv);
bnx2_read_phy(bp, MII_LPA, &remote_adv); bnx2_read_phy(bp, bp->mii_lpa, &remote_adv);
if (bp->phy_flags & PHY_SERDES_FLAG) { if (bp->phy_flags & PHY_SERDES_FLAG) {
u32 new_local_adv = 0; u32 new_local_adv = 0;
@ -736,7 +736,7 @@ bnx2_5706s_linkup(struct bnx2 *bp)
bp->link_up = 1; bp->link_up = 1;
bp->line_speed = SPEED_1000; bp->line_speed = SPEED_1000;
bnx2_read_phy(bp, MII_BMCR, &bmcr); bnx2_read_phy(bp, bp->mii_bmcr, &bmcr);
if (bmcr & BMCR_FULLDPLX) { if (bmcr & BMCR_FULLDPLX) {
bp->duplex = DUPLEX_FULL; bp->duplex = DUPLEX_FULL;
} }
@ -748,8 +748,8 @@ bnx2_5706s_linkup(struct bnx2 *bp)
return 0; return 0;
} }
bnx2_read_phy(bp, MII_ADVERTISE, &local_adv); bnx2_read_phy(bp, bp->mii_adv, &local_adv);
bnx2_read_phy(bp, MII_LPA, &remote_adv); bnx2_read_phy(bp, bp->mii_lpa, &remote_adv);
common = local_adv & remote_adv; common = local_adv & remote_adv;
if (common & (ADVERTISE_1000XHALF | ADVERTISE_1000XFULL)) { if (common & (ADVERTISE_1000XHALF | ADVERTISE_1000XFULL)) {
@ -770,7 +770,7 @@ bnx2_copper_linkup(struct bnx2 *bp)
{ {
u32 bmcr; u32 bmcr;
bnx2_read_phy(bp, MII_BMCR, &bmcr); bnx2_read_phy(bp, bp->mii_bmcr, &bmcr);
if (bmcr & BMCR_ANENABLE) { if (bmcr & BMCR_ANENABLE) {
u32 local_adv, remote_adv, common; u32 local_adv, remote_adv, common;
@ -787,8 +787,8 @@ bnx2_copper_linkup(struct bnx2 *bp)
bp->duplex = DUPLEX_HALF; bp->duplex = DUPLEX_HALF;
} }
else { else {
bnx2_read_phy(bp, MII_ADVERTISE, &local_adv); bnx2_read_phy(bp, bp->mii_adv, &local_adv);
bnx2_read_phy(bp, MII_LPA, &remote_adv); bnx2_read_phy(bp, bp->mii_lpa, &remote_adv);
common = local_adv & remote_adv; common = local_adv & remote_adv;
if (common & ADVERTISE_100FULL) { if (common & ADVERTISE_100FULL) {
@ -911,8 +911,8 @@ bnx2_set_link(struct bnx2 *bp)
link_up = bp->link_up; link_up = bp->link_up;
bnx2_read_phy(bp, MII_BMSR, &bmsr); bnx2_read_phy(bp, bp->mii_bmsr, &bmsr);
bnx2_read_phy(bp, MII_BMSR, &bmsr); bnx2_read_phy(bp, bp->mii_bmsr, &bmsr);
if ((bp->phy_flags & PHY_SERDES_FLAG) && if ((bp->phy_flags & PHY_SERDES_FLAG) &&
(CHIP_NUM(bp) == CHIP_NUM_5706)) { (CHIP_NUM(bp) == CHIP_NUM_5706)) {
@ -971,13 +971,13 @@ bnx2_reset_phy(struct bnx2 *bp)
int i; int i;
u32 reg; u32 reg;
bnx2_write_phy(bp, MII_BMCR, BMCR_RESET); bnx2_write_phy(bp, bp->mii_bmcr, BMCR_RESET);
#define PHY_RESET_MAX_WAIT 100 #define PHY_RESET_MAX_WAIT 100
for (i = 0; i < PHY_RESET_MAX_WAIT; i++) { for (i = 0; i < PHY_RESET_MAX_WAIT; i++) {
udelay(10); udelay(10);
bnx2_read_phy(bp, MII_BMCR, &reg); bnx2_read_phy(bp, bp->mii_bmcr, &reg);
if (!(reg & BMCR_RESET)) { if (!(reg & BMCR_RESET)) {
udelay(20); udelay(20);
break; break;
@ -1033,10 +1033,10 @@ bnx2_setup_serdes_phy(struct bnx2 *bp)
u32 new_bmcr; u32 new_bmcr;
int force_link_down = 0; int force_link_down = 0;
bnx2_read_phy(bp, MII_ADVERTISE, &adv); bnx2_read_phy(bp, bp->mii_adv, &adv);
adv &= ~(ADVERTISE_1000XFULL | ADVERTISE_1000XHALF); adv &= ~(ADVERTISE_1000XFULL | ADVERTISE_1000XHALF);
bnx2_read_phy(bp, MII_BMCR, &bmcr); bnx2_read_phy(bp, bp->mii_bmcr, &bmcr);
new_bmcr = bmcr & ~(BMCR_ANENABLE | BCM5708S_BMCR_FORCE_2500); new_bmcr = bmcr & ~(BMCR_ANENABLE | BCM5708S_BMCR_FORCE_2500);
new_bmcr |= BMCR_SPEED1000; new_bmcr |= BMCR_SPEED1000;
if (bp->req_line_speed == SPEED_2500) { if (bp->req_line_speed == SPEED_2500) {
@ -1067,19 +1067,19 @@ bnx2_setup_serdes_phy(struct bnx2 *bp)
if ((new_bmcr != bmcr) || (force_link_down)) { if ((new_bmcr != bmcr) || (force_link_down)) {
/* Force a link down visible on the other side */ /* Force a link down visible on the other side */
if (bp->link_up) { if (bp->link_up) {
bnx2_write_phy(bp, MII_ADVERTISE, adv & bnx2_write_phy(bp, bp->mii_adv, adv &
~(ADVERTISE_1000XFULL | ~(ADVERTISE_1000XFULL |
ADVERTISE_1000XHALF)); ADVERTISE_1000XHALF));
bnx2_write_phy(bp, MII_BMCR, bmcr | bnx2_write_phy(bp, bp->mii_bmcr, bmcr |
BMCR_ANRESTART | BMCR_ANENABLE); BMCR_ANRESTART | BMCR_ANENABLE);
bp->link_up = 0; bp->link_up = 0;
netif_carrier_off(bp->dev); netif_carrier_off(bp->dev);
bnx2_write_phy(bp, MII_BMCR, new_bmcr); bnx2_write_phy(bp, bp->mii_bmcr, new_bmcr);
bnx2_report_link(bp); bnx2_report_link(bp);
} }
bnx2_write_phy(bp, MII_ADVERTISE, adv); bnx2_write_phy(bp, bp->mii_adv, adv);
bnx2_write_phy(bp, MII_BMCR, new_bmcr); bnx2_write_phy(bp, bp->mii_bmcr, new_bmcr);
} }
return 0; return 0;
} }
@ -1095,21 +1095,21 @@ bnx2_setup_serdes_phy(struct bnx2 *bp)
new_adv |= bnx2_phy_get_pause_adv(bp); new_adv |= bnx2_phy_get_pause_adv(bp);
bnx2_read_phy(bp, MII_ADVERTISE, &adv); bnx2_read_phy(bp, bp->mii_adv, &adv);
bnx2_read_phy(bp, MII_BMCR, &bmcr); bnx2_read_phy(bp, bp->mii_bmcr, &bmcr);
bp->serdes_an_pending = 0; bp->serdes_an_pending = 0;
if ((adv != new_adv) || ((bmcr & BMCR_ANENABLE) == 0)) { if ((adv != new_adv) || ((bmcr & BMCR_ANENABLE) == 0)) {
/* Force a link down visible on the other side */ /* Force a link down visible on the other side */
if (bp->link_up) { if (bp->link_up) {
bnx2_write_phy(bp, MII_BMCR, BMCR_LOOPBACK); bnx2_write_phy(bp, bp->mii_bmcr, BMCR_LOOPBACK);
spin_unlock_bh(&bp->phy_lock); spin_unlock_bh(&bp->phy_lock);
msleep(20); msleep(20);
spin_lock_bh(&bp->phy_lock); spin_lock_bh(&bp->phy_lock);
} }
bnx2_write_phy(bp, MII_ADVERTISE, new_adv); bnx2_write_phy(bp, bp->mii_adv, new_adv);
bnx2_write_phy(bp, MII_BMCR, bmcr | BMCR_ANRESTART | bnx2_write_phy(bp, bp->mii_bmcr, bmcr | BMCR_ANRESTART |
BMCR_ANENABLE); BMCR_ANENABLE);
/* Speed up link-up time when the link partner /* Speed up link-up time when the link partner
* does not autonegotiate which is very common * does not autonegotiate which is very common
@ -1146,14 +1146,14 @@ bnx2_setup_copper_phy(struct bnx2 *bp)
u32 bmcr; u32 bmcr;
u32 new_bmcr; u32 new_bmcr;
bnx2_read_phy(bp, MII_BMCR, &bmcr); bnx2_read_phy(bp, bp->mii_bmcr, &bmcr);
if (bp->autoneg & AUTONEG_SPEED) { if (bp->autoneg & AUTONEG_SPEED) {
u32 adv_reg, adv1000_reg; u32 adv_reg, adv1000_reg;
u32 new_adv_reg = 0; u32 new_adv_reg = 0;
u32 new_adv1000_reg = 0; u32 new_adv1000_reg = 0;
bnx2_read_phy(bp, MII_ADVERTISE, &adv_reg); bnx2_read_phy(bp, bp->mii_adv, &adv_reg);
adv_reg &= (PHY_ALL_10_100_SPEED | ADVERTISE_PAUSE_CAP | adv_reg &= (PHY_ALL_10_100_SPEED | ADVERTISE_PAUSE_CAP |
ADVERTISE_PAUSE_ASYM); ADVERTISE_PAUSE_ASYM);
@ -1179,9 +1179,9 @@ bnx2_setup_copper_phy(struct bnx2 *bp)
(adv_reg != new_adv_reg) || (adv_reg != new_adv_reg) ||
((bmcr & BMCR_ANENABLE) == 0)) { ((bmcr & BMCR_ANENABLE) == 0)) {
bnx2_write_phy(bp, MII_ADVERTISE, new_adv_reg); bnx2_write_phy(bp, bp->mii_adv, new_adv_reg);
bnx2_write_phy(bp, MII_CTRL1000, new_adv1000_reg); bnx2_write_phy(bp, MII_CTRL1000, new_adv1000_reg);
bnx2_write_phy(bp, MII_BMCR, BMCR_ANRESTART | bnx2_write_phy(bp, bp->mii_bmcr, BMCR_ANRESTART |
BMCR_ANENABLE); BMCR_ANENABLE);
} }
else if (bp->link_up) { else if (bp->link_up) {
@ -1204,21 +1204,21 @@ bnx2_setup_copper_phy(struct bnx2 *bp)
if (new_bmcr != bmcr) { if (new_bmcr != bmcr) {
u32 bmsr; u32 bmsr;
bnx2_read_phy(bp, MII_BMSR, &bmsr); bnx2_read_phy(bp, bp->mii_bmsr, &bmsr);
bnx2_read_phy(bp, MII_BMSR, &bmsr); bnx2_read_phy(bp, bp->mii_bmsr, &bmsr);
if (bmsr & BMSR_LSTATUS) { if (bmsr & BMSR_LSTATUS) {
/* Force link down */ /* Force link down */
bnx2_write_phy(bp, MII_BMCR, BMCR_LOOPBACK); bnx2_write_phy(bp, bp->mii_bmcr, BMCR_LOOPBACK);
spin_unlock_bh(&bp->phy_lock); spin_unlock_bh(&bp->phy_lock);
msleep(50); msleep(50);
spin_lock_bh(&bp->phy_lock); spin_lock_bh(&bp->phy_lock);
bnx2_read_phy(bp, MII_BMSR, &bmsr); bnx2_read_phy(bp, bp->mii_bmsr, &bmsr);
bnx2_read_phy(bp, MII_BMSR, &bmsr); bnx2_read_phy(bp, bp->mii_bmsr, &bmsr);
} }
bnx2_write_phy(bp, MII_BMCR, new_bmcr); bnx2_write_phy(bp, bp->mii_bmcr, new_bmcr);
/* Normally, the new speed is setup after the link has /* Normally, the new speed is setup after the link has
* gone down and up again. In some cases, link will not go * gone down and up again. In some cases, link will not go
@ -1396,6 +1396,11 @@ bnx2_init_phy(struct bnx2 *bp)
bp->phy_flags &= ~PHY_INT_MODE_MASK_FLAG; bp->phy_flags &= ~PHY_INT_MODE_MASK_FLAG;
bp->phy_flags |= PHY_INT_MODE_LINK_READY_FLAG; bp->phy_flags |= PHY_INT_MODE_LINK_READY_FLAG;
bp->mii_bmcr = MII_BMCR;
bp->mii_bmsr = MII_BMSR;
bp->mii_adv = MII_ADVERTISE;
bp->mii_lpa = MII_LPA;
REG_WR(bp, BNX2_EMAC_ATTENTION_ENA, BNX2_EMAC_ATTENTION_ENA_LINK); REG_WR(bp, BNX2_EMAC_ATTENTION_ENA, BNX2_EMAC_ATTENTION_ENA_LINK);
bnx2_reset_phy(bp); bnx2_reset_phy(bp);
@ -1442,7 +1447,7 @@ bnx2_set_phy_loopback(struct bnx2 *bp)
int rc, i; int rc, i;
spin_lock_bh(&bp->phy_lock); spin_lock_bh(&bp->phy_lock);
rc = bnx2_write_phy(bp, MII_BMCR, BMCR_LOOPBACK | BMCR_FULLDPLX | rc = bnx2_write_phy(bp, bp->mii_bmcr, BMCR_LOOPBACK | BMCR_FULLDPLX |
BMCR_SPEED1000); BMCR_SPEED1000);
spin_unlock_bh(&bp->phy_lock); spin_unlock_bh(&bp->phy_lock);
if (rc) if (rc)
@ -4185,8 +4190,8 @@ bnx2_test_link(struct bnx2 *bp)
u32 bmsr; u32 bmsr;
spin_lock_bh(&bp->phy_lock); spin_lock_bh(&bp->phy_lock);
bnx2_read_phy(bp, MII_BMSR, &bmsr); bnx2_read_phy(bp, bp->mii_bmsr, &bmsr);
bnx2_read_phy(bp, MII_BMSR, &bmsr); bnx2_read_phy(bp, bp->mii_bmsr, &bmsr);
spin_unlock_bh(&bp->phy_lock); spin_unlock_bh(&bp->phy_lock);
if (bmsr & BMSR_LSTATUS) { if (bmsr & BMSR_LSTATUS) {
@ -4236,7 +4241,7 @@ bnx2_5706_serdes_timer(struct bnx2 *bp)
bp->current_interval = bp->timer_interval; bp->current_interval = bp->timer_interval;
bnx2_read_phy(bp, MII_BMCR, &bmcr); bnx2_read_phy(bp, bp->mii_bmcr, &bmcr);
if (bmcr & BMCR_ANENABLE) { if (bmcr & BMCR_ANENABLE) {
u32 phy1, phy2; u32 phy1, phy2;
@ -4254,7 +4259,7 @@ bnx2_5706_serdes_timer(struct bnx2 *bp)
bmcr &= ~BMCR_ANENABLE; bmcr &= ~BMCR_ANENABLE;
bmcr |= BMCR_SPEED1000 | BMCR_FULLDPLX; bmcr |= BMCR_SPEED1000 | BMCR_FULLDPLX;
bnx2_write_phy(bp, MII_BMCR, bmcr); bnx2_write_phy(bp, bp->mii_bmcr, bmcr);
bp->phy_flags |= PHY_PARALLEL_DETECT_FLAG; bp->phy_flags |= PHY_PARALLEL_DETECT_FLAG;
} }
} }
@ -4268,9 +4273,9 @@ bnx2_5706_serdes_timer(struct bnx2 *bp)
if (phy2 & 0x20) { if (phy2 & 0x20) {
u32 bmcr; u32 bmcr;
bnx2_read_phy(bp, MII_BMCR, &bmcr); bnx2_read_phy(bp, bp->mii_bmcr, &bmcr);
bmcr |= BMCR_ANENABLE; bmcr |= BMCR_ANENABLE;
bnx2_write_phy(bp, MII_BMCR, bmcr); bnx2_write_phy(bp, bp->mii_bmcr, bmcr);
bp->phy_flags &= ~PHY_PARALLEL_DETECT_FLAG; bp->phy_flags &= ~PHY_PARALLEL_DETECT_FLAG;
} }
@ -4294,7 +4299,7 @@ bnx2_5708_serdes_timer(struct bnx2 *bp)
else if ((bp->link_up == 0) && (bp->autoneg & AUTONEG_SPEED)) { else if ((bp->link_up == 0) && (bp->autoneg & AUTONEG_SPEED)) {
u32 bmcr; u32 bmcr;
bnx2_read_phy(bp, MII_BMCR, &bmcr); bnx2_read_phy(bp, bp->mii_bmcr, &bmcr);
if (bmcr & BMCR_ANENABLE) { if (bmcr & BMCR_ANENABLE) {
bmcr &= ~BMCR_ANENABLE; bmcr &= ~BMCR_ANENABLE;
@ -5013,7 +5018,7 @@ bnx2_nway_reset(struct net_device *dev)
/* Force a link down visible on the other side */ /* Force a link down visible on the other side */
if (bp->phy_flags & PHY_SERDES_FLAG) { if (bp->phy_flags & PHY_SERDES_FLAG) {
bnx2_write_phy(bp, MII_BMCR, BMCR_LOOPBACK); bnx2_write_phy(bp, bp->mii_bmcr, BMCR_LOOPBACK);
spin_unlock_bh(&bp->phy_lock); spin_unlock_bh(&bp->phy_lock);
msleep(20); msleep(20);
@ -5025,9 +5030,9 @@ bnx2_nway_reset(struct net_device *dev)
mod_timer(&bp->timer, jiffies + bp->current_interval); mod_timer(&bp->timer, jiffies + bp->current_interval);
} }
bnx2_read_phy(bp, MII_BMCR, &bmcr); bnx2_read_phy(bp, bp->mii_bmcr, &bmcr);
bmcr &= ~BMCR_LOOPBACK; bmcr &= ~BMCR_LOOPBACK;
bnx2_write_phy(bp, MII_BMCR, bmcr | BMCR_ANRESTART | BMCR_ANENABLE); bnx2_write_phy(bp, bp->mii_bmcr, bmcr | BMCR_ANRESTART | BMCR_ANENABLE);
spin_unlock_bh(&bp->phy_lock); spin_unlock_bh(&bp->phy_lock);

View file

@ -6498,6 +6498,12 @@ struct bnx2 {
#define PHY_INT_MODE_LINK_READY_FLAG 0x200 #define PHY_INT_MODE_LINK_READY_FLAG 0x200
#define PHY_DIS_EARLY_DAC_FLAG 0x400 #define PHY_DIS_EARLY_DAC_FLAG 0x400
u32 mii_bmcr;
u32 mii_bmsr;
u32 mii_adv;
u32 mii_lpa;
u32 mii_up1;
u32 chip_id; u32 chip_id;
/* chip num:16-31, rev:12-15, metal:4-11, bond_id:0-3 */ /* chip num:16-31, rev:12-15, metal:4-11, bond_id:0-3 */
#define CHIP_NUM(bp) (((bp)->chip_id) & 0xffff0000) #define CHIP_NUM(bp) (((bp)->chip_id) & 0xffff0000)