On Thu, Nov 28, 2013 at 10:27:00PM +0100, Hannes Frederic Sowa wrote:
> > > @@ -1524,8 +1524,8 @@ int ip6_push_pending_frames(struct sock *sk)
> > >   if (proto == IPPROTO_ICMPV6) {
> > >           struct inet6_dev *idev = ip6_dst_idev(skb_dst(skb));
> > >  
> > > -         ICMP6MSGOUT_INC_STATS_BH(net, idev, icmp6_hdr(skb)->icmp6_type);
> > > -         ICMP6_INC_STATS_BH(net, idev, ICMP6_MIB_OUTMSGS);
> > > +         ICMP6MSGOUT_INC_STATS(net, idev, icmp6_hdr(skb)->icmp6_type);
> > > +         ICMP6_INC_STATS(net, idev, ICMP6_MIB_OUTMSGS);
> > 
> > I am not sure we use a seqlock for ICMP stats.
> > 
> > seqlocks were used for 64bit IP stats
> 
> True, atomic longs get used here in both cases.

I don't really understand why we distinguish between _BH and plain ICMP stat
calls then.

The non-_BH versions deactivate interrupts when updating the per-cpu counter.

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to