]> www.infradead.org Git - users/jedix/linux-maple.git/commit
ixgbe: get pauseparam autoneg
authorMika Lansirinne <mika.lansirinne@stonesoft.com>
Fri, 16 Sep 2011 16:52:59 +0000 (16:52 +0000)
committerJoe Jin <joe.jin@oracle.com>
Thu, 17 May 2012 14:14:28 +0000 (22:14 +0800)
commit90ffb707d15e742ecd5b48a6a18367974199a561
tree700e8edc57530207781ad1cb6c9d97b70059145a
parent233edba0ff171708e14161d3b2ed5503968c0f34
ixgbe: get pauseparam autoneg

There is a problem in the ixgbe driver with the reporting of the flow
control parameters. The autoneg parameter is shown to be of if
*either* it really is off, or current modes for both tx and rx are off.

The problem is seen when the parameters are read or set when the link
is down. In this case, the driver sees that tx and rx are currently off
and therefore autoneg parameter is incorrectly reported to be off too.
Also, the ethtool binary can not set the autoneg off since it sees that
it already is. When a link later comes up, the autonegotiation is
carried out normally and the driver later on reports the autoneg
parameter to be on (as it is) and then it can also be changed with
ethtool.

The patch is made against v3.0 kernel, but the problem seems to be there
since v2.6.30-rc1.

Reviewer comments: What we are trying to do is to disable flow control
while the cable is disconnected. Since ixgbe defaults to full flow
control, we call ethtool -A autoneg off rx off tx off while the cable
is disconnected. This doesn't work, because the driver sets
hw->fc.current_mode = ixgbe_fc_none if the cable is unplugged.
ixgbe_get_pauseparam() then reports to ethtool that nothing needs to be
done. The code fixes this, but it might have some unknown consequences.

(cherry picked from commit 860502bf68bae1ab126fe25a72d038c6e205dedd)
Signed-off-by: Mika Lansirinne <mika.lansirinne@stonesoft.com>
Reviewed-by: Esa-Pekka Pyokkimies <esa-pekka.pyokkimies@stonesoft.com>
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
Signed-off-by: Joe Jin <joe.jin@oracle.com>
drivers/net/ixgbe/ixgbe_ethtool.c