Commit caf2c520 authored by Michael Zhivich's avatar Michael Zhivich Committed by David S. Miller

broadcom: tg3: fix use of SPEED_UNKNOWN ethtool constant

tg3 driver uses u16 to store SPEED_UKNOWN ethtool constant,
which is defined as -1, resulting in value truncation and
thus incorrect test results against SPEED_UNKNOWN.

For example, the following test will print "False":

	u16 speed = SPEED_UNKNOWN;

	if (speed == SPEED_UNKNOWN)
	    printf("True");
	else
	    printf("False");

Change storage of speed to use u32 to avoid this issue.
Signed-off-by: default avatarMichael Zhivich <mzhivich@akamai.com>
Reviewed-by: default avatarAndrew Lunn <andrew@lunn.ch>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent afe64245
...@@ -4283,7 +4283,7 @@ static void tg3_power_down(struct tg3 *tp) ...@@ -4283,7 +4283,7 @@ static void tg3_power_down(struct tg3 *tp)
pci_set_power_state(tp->pdev, PCI_D3hot); pci_set_power_state(tp->pdev, PCI_D3hot);
} }
static void tg3_aux_stat_to_speed_duplex(struct tg3 *tp, u32 val, u16 *speed, u8 *duplex) static void tg3_aux_stat_to_speed_duplex(struct tg3 *tp, u32 val, u32 *speed, u8 *duplex)
{ {
switch (val & MII_TG3_AUX_STAT_SPDMASK) { switch (val & MII_TG3_AUX_STAT_SPDMASK) {
case MII_TG3_AUX_STAT_10HALF: case MII_TG3_AUX_STAT_10HALF:
...@@ -4787,7 +4787,7 @@ static int tg3_setup_copper_phy(struct tg3 *tp, bool force_reset) ...@@ -4787,7 +4787,7 @@ static int tg3_setup_copper_phy(struct tg3 *tp, bool force_reset)
bool current_link_up; bool current_link_up;
u32 bmsr, val; u32 bmsr, val;
u32 lcl_adv, rmt_adv; u32 lcl_adv, rmt_adv;
u16 current_speed; u32 current_speed;
u8 current_duplex; u8 current_duplex;
int i, err; int i, err;
...@@ -5719,7 +5719,7 @@ static bool tg3_setup_fiber_by_hand(struct tg3 *tp, u32 mac_status) ...@@ -5719,7 +5719,7 @@ static bool tg3_setup_fiber_by_hand(struct tg3 *tp, u32 mac_status)
static int tg3_setup_fiber_phy(struct tg3 *tp, bool force_reset) static int tg3_setup_fiber_phy(struct tg3 *tp, bool force_reset)
{ {
u32 orig_pause_cfg; u32 orig_pause_cfg;
u16 orig_active_speed; u32 orig_active_speed;
u8 orig_active_duplex; u8 orig_active_duplex;
u32 mac_status; u32 mac_status;
bool current_link_up; bool current_link_up;
...@@ -5823,7 +5823,7 @@ static int tg3_setup_fiber_mii_phy(struct tg3 *tp, bool force_reset) ...@@ -5823,7 +5823,7 @@ static int tg3_setup_fiber_mii_phy(struct tg3 *tp, bool force_reset)
{ {
int err = 0; int err = 0;
u32 bmsr, bmcr; u32 bmsr, bmcr;
u16 current_speed = SPEED_UNKNOWN; u32 current_speed = SPEED_UNKNOWN;
u8 current_duplex = DUPLEX_UNKNOWN; u8 current_duplex = DUPLEX_UNKNOWN;
bool current_link_up = false; bool current_link_up = false;
u32 local_adv, remote_adv, sgsr; u32 local_adv, remote_adv, sgsr;
......
...@@ -2873,7 +2873,7 @@ struct tg3_tx_ring_info { ...@@ -2873,7 +2873,7 @@ struct tg3_tx_ring_info {
struct tg3_link_config { struct tg3_link_config {
/* Describes what we're trying to get. */ /* Describes what we're trying to get. */
u32 advertising; u32 advertising;
u16 speed; u32 speed;
u8 duplex; u8 duplex;
u8 autoneg; u8 autoneg;
u8 flowctrl; u8 flowctrl;
...@@ -2882,7 +2882,7 @@ struct tg3_link_config { ...@@ -2882,7 +2882,7 @@ struct tg3_link_config {
u8 active_flowctrl; u8 active_flowctrl;
u8 active_duplex; u8 active_duplex;
u16 active_speed; u32 active_speed;
u32 rmt_adv; u32 rmt_adv;
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment