]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/commit
net: initialize init_net earlier
authorEric Dumazet <edumazet@google.com>
Sat, 5 Feb 2022 17:01:25 +0000 (09:01 -0800)
committerStefan Bader <stefan.bader@canonical.com>
Fri, 20 May 2022 12:40:38 +0000 (14:40 +0200)
commitdd19134b7861030939db745d06b9ebddc3173054
tree57ebb1dd10073ff40fe557bec12dfa929e0bf42e
parent701b959660d912406d1c049781f3345cc494f2f5
net: initialize init_net earlier

BugLink: https://bugs.launchpad.net/bugs/1969107
[ Upstream commit 9c1be1935fb68b2413796cdc03d019b8cf35ab51 ]

While testing a patch that will follow later
("net: add netns refcount tracker to struct nsproxy")
I found that devtmpfs_init() was called before init_net
was initialized.

This is a bug, because devtmpfs_setup() calls
ksys_unshare(CLONE_NEWNS);

This has the effect of increasing init_net refcount,
which will be later overwritten to 1, as part of setup_net(&init_net)

We had too many prior patches [1] trying to work around the root cause.

Really, make sure init_net is in BSS section, and that net_ns_init()
is called earlier at boot time.

Note that another patch ("vfs: add netns refcount tracker
to struct fs_context") also will need net_ns_init() being called
before vfs_caches_init()

As a bonus, this patch saves around 4KB in .data section.

[1]

f8c46cb39079 ("netns: do not call pernet ops for not yet set up init_net namespace")
b5082df8019a ("net: Initialise init_net.count to 1")
734b65417b24 ("net: Statically initialize init_net.dev_base_head")

v2: fixed a build error reported by kernel build bots (CONFIG_NET=n)

Signed-off-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Sasha Levin <sashal@kernel.org>
(cherry picked from commit 9c1ace066f22fe490d240dba8e13aeee9a88c589)
Signed-off-by: Paolo Pisati <paolo.pisati@canonical.com>
include/net/net_namespace.h
init/main.c
net/core/dev.c
net/core/net_namespace.c