diff options
author | WANG Cong <xiyou.wangcong@gmail.com> | 2017-05-03 22:07:31 -0700 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2017-05-14 13:32:58 +0200 |
commit | 5117f03fd6e20d552daebe5f509a897b1df700a3 (patch) | |
tree | 34cf8d4a6eb0aed0b835d7e17a7c974f2d27c79e /include/linux/spinlock.h | |
parent | 545f144825390ab93fef326cfa99ab246c02955c (diff) | |
download | linux-stable-5117f03fd6e20d552daebe5f509a897b1df700a3.tar.gz linux-stable-5117f03fd6e20d552daebe5f509a897b1df700a3.tar.bz2 linux-stable-5117f03fd6e20d552daebe5f509a897b1df700a3.zip |
ipv6: initialize route null entry in addrconf_init()
[ Upstream commit 2f460933f58eee3393aba64f0f6d14acb08d1724 ]
Andrey reported a crash on init_net.ipv6.ip6_null_entry->rt6i_idev
since it is always NULL.
This is clearly wrong, we have code to initialize it to loopback_dev,
unfortunately the order is still not correct.
loopback_dev is registered very early during boot, we lose a chance
to re-initialize it in notifier. addrconf_init() is called after
ip6_route_init(), which means we have no chance to correct it.
Fix it by moving this initialization explicitly after
ipv6_add_dev(init_net.loopback_dev) in addrconf_init().
Reported-by: Andrey Konovalov <andreyknvl@google.com>
Signed-off-by: Cong Wang <xiyou.wangcong@gmail.com>
Tested-by: Andrey Konovalov <andreyknvl@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'include/linux/spinlock.h')
0 files changed, 0 insertions, 0 deletions