[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <95d6f5e9-cd87-6e23-6476-746243d4014e@gmail.com>
Date: Wed, 19 Oct 2016 21:44:26 +0800
From: Baozeng Ding <sploving1@...il.com>
To: Cong Wang <xiyou.wangcong@...il.com>, sploving1@...il.com
Cc: Linux Kernel Network Developers <netdev@...r.kernel.org>
Subject: Re: net/ipv6: potential deadlock in do_ipv6_setsockopt
It fixes the issue for me.
Tested-by: Baozeng Ding <sploving1@...il.com>
On 2016/10/17 17:54, Baozeng Ding wrote:
> Applied the patch to my test tree. I will tell you the result a few days later. Thank you.
>
> On 2016/10/17 2:50, Cong Wang wrote:
>> On Sun, Oct 16, 2016 at 6:34 AM, Baozeng Ding <sploving1@...il.com> wrote:
>>> Possible unsafe locking scenario:
>>>
>>> CPU0 CPU1
>>> ---- ----
>>> lock([ 165.136033] sk_lock-AF_INET6
>>> );
>>> lock([ 165.136033] rtnl_mutex
>>> );
>>> lock([ 165.136033] sk_lock-AF_INET6
>>> );
>>> lock([ 165.136033] rtnl_mutex
>>> );
>>>
>>> *** DEADLOCK ***
>>
>> This is caused by the conditional rtnl locking in do_ipv6_setsockopt().
>> It looks like we miss the case of IPV6_ADDRFORM.
>>
>> Please try the attached patch.
>>
Powered by blists - more mailing lists