aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net
diff options
context:
space:
mode:
authorRafał Miłecki <zajec5@gmail.com>2013-02-07 00:40:38 -0500
committerDavid S. Miller <davem@davemloft.net>2013-02-08 17:44:01 -0500
commite9ba103931950da7bc87d58ffe39612df17d47af (patch)
treebb60336c756598c512aa6877e7ba1b79ba92840e /drivers/net
parentd166f218ff2bae0f6adae9ce5444a889a1d749e2 (diff)
bgmac: fix "cmdcfg" calls for promisc and loopback modes
The last (bool) parameter in bgmac_cmdcfg_maskset says if the write should be made, even if value didn't change. Currently driver doesn't match the specs about (not) forcing some changes. This makes it follow them. Reported-by: Nathan Hintz <nlhintz@hotmail.com> Signed-off-by: Rafał Miłecki <zajec5@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/ethernet/broadcom/bgmac.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/drivers/net/ethernet/broadcom/bgmac.c b/drivers/net/ethernet/broadcom/bgmac.c
index 380084bad129..7bc8017ccf47 100644
--- a/drivers/net/ethernet/broadcom/bgmac.c
+++ b/drivers/net/ethernet/broadcom/bgmac.c
@@ -776,9 +776,9 @@ static void bgmac_set_rx_mode(struct net_device *net_dev)
776 struct bgmac *bgmac = netdev_priv(net_dev); 776 struct bgmac *bgmac = netdev_priv(net_dev);
777 777
778 if (net_dev->flags & IFF_PROMISC) 778 if (net_dev->flags & IFF_PROMISC)
779 bgmac_cmdcfg_maskset(bgmac, ~0, BGMAC_CMDCFG_PROM, false); 779 bgmac_cmdcfg_maskset(bgmac, ~0, BGMAC_CMDCFG_PROM, true);
780 else 780 else
781 bgmac_cmdcfg_maskset(bgmac, ~BGMAC_CMDCFG_PROM, 0, false); 781 bgmac_cmdcfg_maskset(bgmac, ~BGMAC_CMDCFG_PROM, 0, true);
782} 782}
783 783
784#if 0 /* We don't use that regs yet */ 784#if 0 /* We don't use that regs yet */
@@ -1039,9 +1039,9 @@ static void bgmac_chip_init(struct bgmac *bgmac, bool full_init)
1039 bgmac_write_mac_address(bgmac, bgmac->net_dev->dev_addr); 1039 bgmac_write_mac_address(bgmac, bgmac->net_dev->dev_addr);
1040 1040
1041 if (bgmac->loopback) 1041 if (bgmac->loopback)
1042 bgmac_cmdcfg_maskset(bgmac, ~0, BGMAC_CMDCFG_ML, true); 1042 bgmac_cmdcfg_maskset(bgmac, ~0, BGMAC_CMDCFG_ML, false);
1043 else 1043 else
1044 bgmac_cmdcfg_maskset(bgmac, ~BGMAC_CMDCFG_ML, 0, true); 1044 bgmac_cmdcfg_maskset(bgmac, ~BGMAC_CMDCFG_ML, 0, false);
1045 1045
1046 bgmac_write(bgmac, BGMAC_RXMAX_LENGTH, 32 + ETHER_MAX_LEN); 1046 bgmac_write(bgmac, BGMAC_RXMAX_LENGTH, 32 + ETHER_MAX_LEN);
1047 1047