ixgbe: DCB, PFC not cleared until reset occurs

The PFC configuration is not cleared until the device is reset. This
has not been a problem because setting DCB attributes forced a
hardware reset. Now that we no longer require this reset to occur
PFC remains configured even after being disabled until the
device is reset.

This removes a goto in the PFC hardware set routines for 82598 and
82599 devices that was short circuiting the clear.

Signed-off-by: John Fastabend <john.r.fastabend@intel.com>
Tested-by: Ross Brattain <ross.b.brattain@intel.com>
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
This commit is contained in:
John Fastabend 2011-03-10 12:06:12 +00:00 committed by Jeff Kirsher
parent ff4ab20611
commit 1f4a0244ff
2 changed files with 43 additions and 47 deletions

View File

@ -233,21 +233,27 @@ s32 ixgbe_dcb_config_pfc_82598(struct ixgbe_hw *hw, u8 pfc_en)
u32 reg, rx_pba_size; u32 reg, rx_pba_size;
u8 i; u8 i;
if (!pfc_en) if (pfc_en) {
goto out; /* Enable Transmit Priority Flow Control */
reg = IXGBE_READ_REG(hw, IXGBE_RMCS);
reg &= ~IXGBE_RMCS_TFCE_802_3X;
/* correct the reporting of our flow control status */
reg |= IXGBE_RMCS_TFCE_PRIORITY;
IXGBE_WRITE_REG(hw, IXGBE_RMCS, reg);
/* Enable Transmit Priority Flow Control */ /* Enable Receive Priority Flow Control */
reg = IXGBE_READ_REG(hw, IXGBE_RMCS); reg = IXGBE_READ_REG(hw, IXGBE_FCTRL);
reg &= ~IXGBE_RMCS_TFCE_802_3X; reg &= ~IXGBE_FCTRL_RFCE;
/* correct the reporting of our flow control status */ reg |= IXGBE_FCTRL_RPFCE;
reg |= IXGBE_RMCS_TFCE_PRIORITY; IXGBE_WRITE_REG(hw, IXGBE_FCTRL, reg);
IXGBE_WRITE_REG(hw, IXGBE_RMCS, reg);
/* Enable Receive Priority Flow Control */ /* Configure pause time */
reg = IXGBE_READ_REG(hw, IXGBE_FCTRL); for (i = 0; i < (MAX_TRAFFIC_CLASS >> 1); i++)
reg &= ~IXGBE_FCTRL_RFCE; IXGBE_WRITE_REG(hw, IXGBE_FCTTV(i), 0x68006800);
reg |= IXGBE_FCTRL_RPFCE;
IXGBE_WRITE_REG(hw, IXGBE_FCTRL, reg); /* Configure flow control refresh threshold value */
IXGBE_WRITE_REG(hw, IXGBE_FCRTV, 0x3400);
}
/* /*
* Configure flow control thresholds and enable priority flow control * Configure flow control thresholds and enable priority flow control
@ -273,14 +279,6 @@ s32 ixgbe_dcb_config_pfc_82598(struct ixgbe_hw *hw, u8 pfc_en)
IXGBE_WRITE_REG(hw, IXGBE_FCRTH(i), reg); IXGBE_WRITE_REG(hw, IXGBE_FCRTH(i), reg);
} }
/* Configure pause time */
for (i = 0; i < (MAX_TRAFFIC_CLASS >> 1); i++)
IXGBE_WRITE_REG(hw, IXGBE_FCTTV(i), 0x68006800);
/* Configure flow control refresh threshold value */
IXGBE_WRITE_REG(hw, IXGBE_FCRTV, 0x3400);
out:
return 0; return 0;
} }

View File

@ -253,13 +253,6 @@ s32 ixgbe_dcb_config_pfc_82599(struct ixgbe_hw *hw, u8 pfc_en)
{ {
u32 i, reg, rx_pba_size; u32 i, reg, rx_pba_size;
/* If PFC is disabled globally then fall back to LFC. */
if (!pfc_en) {
for (i = 0; i < MAX_TRAFFIC_CLASS; i++)
hw->mac.ops.fc_enable(hw, i);
goto out;
}
/* Configure PFC Tx thresholds per TC */ /* Configure PFC Tx thresholds per TC */
for (i = 0; i < MAX_TRAFFIC_CLASS; i++) { for (i = 0; i < MAX_TRAFFIC_CLASS; i++) {
int enabled = pfc_en & (1 << i); int enabled = pfc_en & (1 << i);
@ -278,28 +271,33 @@ s32 ixgbe_dcb_config_pfc_82599(struct ixgbe_hw *hw, u8 pfc_en)
IXGBE_WRITE_REG(hw, IXGBE_FCRTH_82599(i), reg); IXGBE_WRITE_REG(hw, IXGBE_FCRTH_82599(i), reg);
} }
/* Configure pause time (2 TCs per register) */ if (pfc_en) {
reg = hw->fc.pause_time | (hw->fc.pause_time << 16); /* Configure pause time (2 TCs per register) */
for (i = 0; i < (MAX_TRAFFIC_CLASS / 2); i++) reg = hw->fc.pause_time | (hw->fc.pause_time << 16);
IXGBE_WRITE_REG(hw, IXGBE_FCTTV(i), reg); for (i = 0; i < (MAX_TRAFFIC_CLASS / 2); i++)
IXGBE_WRITE_REG(hw, IXGBE_FCTTV(i), reg);
/* Configure flow control refresh threshold value */ /* Configure flow control refresh threshold value */
IXGBE_WRITE_REG(hw, IXGBE_FCRTV, hw->fc.pause_time / 2); IXGBE_WRITE_REG(hw, IXGBE_FCRTV, hw->fc.pause_time / 2);
/* Enable Transmit PFC */
reg = IXGBE_FCCFG_TFCE_PRIORITY;
IXGBE_WRITE_REG(hw, IXGBE_FCCFG, reg);
/* reg = IXGBE_FCCFG_TFCE_PRIORITY;
* Enable Receive PFC IXGBE_WRITE_REG(hw, IXGBE_FCCFG, reg);
* We will always honor XOFF frames we receive when /*
* we are in PFC mode. * Enable Receive PFC
*/ * We will always honor XOFF frames we receive when
reg = IXGBE_READ_REG(hw, IXGBE_MFLCN); * we are in PFC mode.
reg &= ~IXGBE_MFLCN_RFCE; */
reg |= IXGBE_MFLCN_RPFCE | IXGBE_MFLCN_DPF; reg = IXGBE_READ_REG(hw, IXGBE_MFLCN);
IXGBE_WRITE_REG(hw, IXGBE_MFLCN, reg); reg &= ~IXGBE_MFLCN_RFCE;
out: reg |= IXGBE_MFLCN_RPFCE | IXGBE_MFLCN_DPF;
IXGBE_WRITE_REG(hw, IXGBE_MFLCN, reg);
} else {
for (i = 0; i < MAX_TRAFFIC_CLASS; i++)
hw->mac.ops.fc_enable(hw, i);
}
return 0; return 0;
} }