diff options
Diffstat (limited to 'net')
-rw-r--r-- | net/ipv6/addrconf.c | 21 |
1 files changed, 11 insertions, 10 deletions
diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c index b0e1430b64f1..764ad37ca070 100644 --- a/net/ipv6/addrconf.c +++ b/net/ipv6/addrconf.c | |||
@@ -2802,14 +2802,14 @@ static void addrconf_dad_start(struct inet6_ifaddr *ifp, u32 flags) | |||
2802 | read_lock_bh(&idev->lock); | 2802 | read_lock_bh(&idev->lock); |
2803 | if (ifp->dead) | 2803 | if (ifp->dead) |
2804 | goto out; | 2804 | goto out; |
2805 | spin_lock_bh(&ifp->lock); | ||
2806 | 2805 | ||
2806 | spin_lock(&ifp->lock); | ||
2807 | if (dev->flags&(IFF_NOARP|IFF_LOOPBACK) || | 2807 | if (dev->flags&(IFF_NOARP|IFF_LOOPBACK) || |
2808 | idev->cnf.accept_dad < 1 || | 2808 | idev->cnf.accept_dad < 1 || |
2809 | !(ifp->flags&IFA_F_TENTATIVE) || | 2809 | !(ifp->flags&IFA_F_TENTATIVE) || |
2810 | ifp->flags & IFA_F_NODAD) { | 2810 | ifp->flags & IFA_F_NODAD) { |
2811 | ifp->flags &= ~(IFA_F_TENTATIVE|IFA_F_OPTIMISTIC|IFA_F_DADFAILED); | 2811 | ifp->flags &= ~(IFA_F_TENTATIVE|IFA_F_OPTIMISTIC|IFA_F_DADFAILED); |
2812 | spin_unlock_bh(&ifp->lock); | 2812 | spin_unlock(&ifp->lock); |
2813 | read_unlock_bh(&idev->lock); | 2813 | read_unlock_bh(&idev->lock); |
2814 | 2814 | ||
2815 | addrconf_dad_completed(ifp); | 2815 | addrconf_dad_completed(ifp); |
@@ -2817,7 +2817,7 @@ static void addrconf_dad_start(struct inet6_ifaddr *ifp, u32 flags) | |||
2817 | } | 2817 | } |
2818 | 2818 | ||
2819 | if (!(idev->if_flags & IF_READY)) { | 2819 | if (!(idev->if_flags & IF_READY)) { |
2820 | spin_unlock_bh(&ifp->lock); | 2820 | spin_unlock(&ifp->lock); |
2821 | read_unlock_bh(&idev->lock); | 2821 | read_unlock_bh(&idev->lock); |
2822 | /* | 2822 | /* |
2823 | * If the device is not ready: | 2823 | * If the device is not ready: |
@@ -2837,7 +2837,7 @@ static void addrconf_dad_start(struct inet6_ifaddr *ifp, u32 flags) | |||
2837 | ip6_ins_rt(ifp->rt); | 2837 | ip6_ins_rt(ifp->rt); |
2838 | 2838 | ||
2839 | addrconf_dad_kick(ifp); | 2839 | addrconf_dad_kick(ifp); |
2840 | spin_unlock_bh(&ifp->lock); | 2840 | spin_unlock(&ifp->lock); |
2841 | out: | 2841 | out: |
2842 | read_unlock_bh(&idev->lock); | 2842 | read_unlock_bh(&idev->lock); |
2843 | } | 2843 | } |
@@ -2853,14 +2853,15 @@ static void addrconf_dad_timer(unsigned long data) | |||
2853 | read_unlock_bh(&idev->lock); | 2853 | read_unlock_bh(&idev->lock); |
2854 | goto out; | 2854 | goto out; |
2855 | } | 2855 | } |
2856 | spin_lock_bh(&ifp->lock); | 2856 | |
2857 | spin_lock(&ifp->lock); | ||
2857 | if (ifp->probes == 0) { | 2858 | if (ifp->probes == 0) { |
2858 | /* | 2859 | /* |
2859 | * DAD was successful | 2860 | * DAD was successful |
2860 | */ | 2861 | */ |
2861 | 2862 | ||
2862 | ifp->flags &= ~(IFA_F_TENTATIVE|IFA_F_OPTIMISTIC|IFA_F_DADFAILED); | 2863 | ifp->flags &= ~(IFA_F_TENTATIVE|IFA_F_OPTIMISTIC|IFA_F_DADFAILED); |
2863 | spin_unlock_bh(&ifp->lock); | 2864 | spin_unlock(&ifp->lock); |
2864 | read_unlock_bh(&idev->lock); | 2865 | read_unlock_bh(&idev->lock); |
2865 | 2866 | ||
2866 | addrconf_dad_completed(ifp); | 2867 | addrconf_dad_completed(ifp); |
@@ -2870,7 +2871,7 @@ static void addrconf_dad_timer(unsigned long data) | |||
2870 | 2871 | ||
2871 | ifp->probes--; | 2872 | ifp->probes--; |
2872 | addrconf_mod_timer(ifp, AC_DAD, ifp->idev->nd_parms->retrans_time); | 2873 | addrconf_mod_timer(ifp, AC_DAD, ifp->idev->nd_parms->retrans_time); |
2873 | spin_unlock_bh(&ifp->lock); | 2874 | spin_unlock(&ifp->lock); |
2874 | read_unlock_bh(&idev->lock); | 2875 | read_unlock_bh(&idev->lock); |
2875 | 2876 | ||
2876 | /* send a neighbour solicitation for our addr */ | 2877 | /* send a neighbour solicitation for our addr */ |
@@ -2918,12 +2919,12 @@ static void addrconf_dad_run(struct inet6_dev *idev) { | |||
2918 | 2919 | ||
2919 | read_lock_bh(&idev->lock); | 2920 | read_lock_bh(&idev->lock); |
2920 | for (ifp = idev->addr_list; ifp; ifp = ifp->if_next) { | 2921 | for (ifp = idev->addr_list; ifp; ifp = ifp->if_next) { |
2921 | spin_lock_bh(&ifp->lock); | 2922 | spin_lock(&ifp->lock); |
2922 | if (!(ifp->flags & IFA_F_TENTATIVE)) { | 2923 | if (!(ifp->flags & IFA_F_TENTATIVE)) { |
2923 | spin_unlock_bh(&ifp->lock); | 2924 | spin_unlock(&ifp->lock); |
2924 | continue; | 2925 | continue; |
2925 | } | 2926 | } |
2926 | spin_unlock_bh(&ifp->lock); | 2927 | spin_unlock(&ifp->lock); |
2927 | addrconf_dad_kick(ifp); | 2928 | addrconf_dad_kick(ifp); |
2928 | } | 2929 | } |
2929 | read_unlock_bh(&idev->lock); | 2930 | read_unlock_bh(&idev->lock); |