[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20170616091659.3361b5d0@xeon-e3>
Date: Fri, 16 Jun 2017 09:16:59 -0700
From: Stephen Hemminger <stephen@...workplumber.org>
To: Serhey Popovych <serhe.popovych@...il.com>
Cc: netdev@...r.kernel.org
Subject: Re: [PATCH 2/3] dev: Avoid infinite loop on network device index
exhaustion
On Fri, 16 Jun 2017 17:23:52 +0300
Serhey Popovych <serhe.popovych@...il.com> wrote:
> If network device indexes exhaust in namespace dev_new_index()
> can loop indefinitely since there is no condition to exit
> except case where free index is found.
>
> Since all it's caller hold RTNL mutex this may completely
> lock down network subsystem configuration operations.
>
> Instead of retrying with ifindex == 1 (LOOPBACK_IFINDEX)
> in dev_new_index() we should fail and return invalid
> index value (0).
>
> Adjust callers to correctly handle error case of dev_new_index().
>
> Signed-off-by: Serhey Popovych <serhe.popovych@...il.com>
This breaks existing semantics.
Today on Linux the ifindex allocator intentionally wraps around back to 1.
This is to handle the case of long running system with things like VPN's
that create and destroy lots of devices.
Powered by blists - more mailing lists