On 10/24/18 9:02 AM, David Ahern wrote:
> On 10/24/18 3:36 AM, Li RongQing wrote:
>> put net when input a invalid ifindex, otherwise it will be leaked
>>
>> Fixes: 5fcd266a9f64("net/ipv4: Add support for dumping addresses for a 
>> specific device")
>> Cc: David Ahern <dsah...@gmail.com>
>> Signed-off-by: Zhang Yu <zhangy...@baidu.com>
>> Signed-off-by: Li RongQing <lirongq...@baidu.com>
>> ---
>>  net/ipv4/devinet.c | 4 +++-
>>  1 file changed, 3 insertions(+), 1 deletion(-)
>>
>> diff --git a/net/ipv4/devinet.c b/net/ipv4/devinet.c
>> index 63d5b58fbfdb..fd0c5a47e742 100644
>> --- a/net/ipv4/devinet.c
>> +++ b/net/ipv4/devinet.c
>> @@ -1775,8 +1775,10 @@ static int inet_dump_ifaddr(struct sk_buff *skb, 
>> struct netlink_callback *cb)
>>  
>>              if (fillargs.ifindex) {
>>                      dev = __dev_get_by_index(tgt_net, fillargs.ifindex);
>> -                    if (!dev)
>> +                    if (!dev) {
>> +                            put_net(tgt_net);
>>                              return -ENODEV;
>> +                    }
>>  
>>                      in_dev = __in_dev_get_rtnl(dev);
>>                      if (in_dev) {
>>
> 
> Good catch. IPv6 has the same problem. Will fix that one.
> 
Actually remove that 'Reviewed-by'. You should only call put_net if
(fillargs.netnsid >= 0)

DaveM: just want to call this out since I mistakenly added the
Reviewed-by. This patch should be dropped.

Reply via email to