net-sysfs: initialize uid and gid before calling net_ns_get_ownership
authorXin Long <lucien.xin@gmail.com>
Mon, 25 Oct 2021 06:31:48 +0000 (02:31 -0400)
committerDavid S. Miller <davem@davemloft.net>
Mon, 25 Oct 2021 15:17:32 +0000 (16:17 +0100)
Currently in net_ns_get_ownership() it may not be able to set uid or gid
if make_kuid or make_kgid returns an invalid value, and an uninit-value
issue can be triggered by this.

This patch is to fix it by initializing the uid and gid before calling
net_ns_get_ownership(), as it does in kobject_get_ownership()

Fixes: e6dee9f3893c ("net-sysfs: add netdev_change_owner()")
Reported-by: Paolo Abeni <pabeni@redhat.com>
Signed-off-by: Xin Long <lucien.xin@gmail.com>
Acked-by: Christian Brauner <christian.brauner@ubuntu.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/core/net-sysfs.c

index f6197774048b62460eebe9f34b4c01c8c7e2722d..b2e49eb7001d6cf14b9116fb1f10b64727063431 100644 (file)
@@ -1973,9 +1973,9 @@ int netdev_register_kobject(struct net_device *ndev)
 int netdev_change_owner(struct net_device *ndev, const struct net *net_old,
                        const struct net *net_new)
 {
+       kuid_t old_uid = GLOBAL_ROOT_UID, new_uid = GLOBAL_ROOT_UID;
+       kgid_t old_gid = GLOBAL_ROOT_GID, new_gid = GLOBAL_ROOT_GID;
        struct device *dev = &ndev->dev;
-       kuid_t old_uid, new_uid;
-       kgid_t old_gid, new_gid;
        int error;
 
        net_ns_get_ownership(net_old, &old_uid, &old_gid);