diff options
author | Eric W. Biederman <ebiederm@xmission.com> | 2014-03-14 00:26:42 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2014-03-14 22:41:36 -0400 |
commit | 57a7744e09867ebcfa0ccf1d6d529caa7728d552 (patch) | |
tree | 6407fee7138787a24bf9251abfeeae69a239028a /drivers/net/ethernet/broadcom/b44.c | |
parent | 85dcce7a73f1cc59f7a96fe52713b1630f4ca272 (diff) |
net: Replace u64_stats_fetch_begin_bh to u64_stats_fetch_begin_irq
Replace the bh safe variant with the hard irq safe variant.
We need a hard irq safe variant to deal with netpoll transmitting
packets from hard irq context, and we need it in most if not all of
the places using the bh safe variant.
Except on 32bit uni-processor the code is exactly the same so don't
bother with a bh variant, just have a hard irq safe variant that
everyone can use.
Signed-off-by: "Eric W. Biederman" <ebiederm@xmission.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet/broadcom/b44.c')
-rw-r--r-- | drivers/net/ethernet/broadcom/b44.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/drivers/net/ethernet/broadcom/b44.c b/drivers/net/ethernet/broadcom/b44.c index 8a7bf7dad898..05ba62589017 100644 --- a/drivers/net/ethernet/broadcom/b44.c +++ b/drivers/net/ethernet/broadcom/b44.c | |||
@@ -1685,7 +1685,7 @@ static struct rtnl_link_stats64 *b44_get_stats64(struct net_device *dev, | |||
1685 | unsigned int start; | 1685 | unsigned int start; |
1686 | 1686 | ||
1687 | do { | 1687 | do { |
1688 | start = u64_stats_fetch_begin_bh(&hwstat->syncp); | 1688 | start = u64_stats_fetch_begin_irq(&hwstat->syncp); |
1689 | 1689 | ||
1690 | /* Convert HW stats into rtnl_link_stats64 stats. */ | 1690 | /* Convert HW stats into rtnl_link_stats64 stats. */ |
1691 | nstat->rx_packets = hwstat->rx_pkts; | 1691 | nstat->rx_packets = hwstat->rx_pkts; |
@@ -1719,7 +1719,7 @@ static struct rtnl_link_stats64 *b44_get_stats64(struct net_device *dev, | |||
1719 | /* Carrier lost counter seems to be broken for some devices */ | 1719 | /* Carrier lost counter seems to be broken for some devices */ |
1720 | nstat->tx_carrier_errors = hwstat->tx_carrier_lost; | 1720 | nstat->tx_carrier_errors = hwstat->tx_carrier_lost; |
1721 | #endif | 1721 | #endif |
1722 | } while (u64_stats_fetch_retry_bh(&hwstat->syncp, start)); | 1722 | } while (u64_stats_fetch_retry_irq(&hwstat->syncp, start)); |
1723 | 1723 | ||
1724 | return nstat; | 1724 | return nstat; |
1725 | } | 1725 | } |
@@ -2073,12 +2073,12 @@ static void b44_get_ethtool_stats(struct net_device *dev, | |||
2073 | do { | 2073 | do { |
2074 | data_src = &hwstat->tx_good_octets; | 2074 | data_src = &hwstat->tx_good_octets; |
2075 | data_dst = data; | 2075 | data_dst = data; |
2076 | start = u64_stats_fetch_begin_bh(&hwstat->syncp); | 2076 | start = u64_stats_fetch_begin_irq(&hwstat->syncp); |
2077 | 2077 | ||
2078 | for (i = 0; i < ARRAY_SIZE(b44_gstrings); i++) | 2078 | for (i = 0; i < ARRAY_SIZE(b44_gstrings); i++) |
2079 | *data_dst++ = *data_src++; | 2079 | *data_dst++ = *data_src++; |
2080 | 2080 | ||
2081 | } while (u64_stats_fetch_retry_bh(&hwstat->syncp, start)); | 2081 | } while (u64_stats_fetch_retry_irq(&hwstat->syncp, start)); |
2082 | } | 2082 | } |
2083 | 2083 | ||
2084 | static void b44_get_wol(struct net_device *dev, struct ethtool_wolinfo *wol) | 2084 | static void b44_get_wol(struct net_device *dev, struct ethtool_wolinfo *wol) |