• Eric W. Biederman's avatar
    bpf: Use mount_nodev not mount_ns to mount the bpf filesystem · 5b7ea922
    Eric W. Biederman authored
    [ Upstream commit e27f4a94 ]
    
    While reviewing the filesystems that set FS_USERNS_MOUNT I spotted the
    bpf filesystem.  Looking at the code I saw a broken usage of mount_ns
    with current->nsproxy->mnt_ns. As the code does not acquire a
    reference to the mount namespace it can not possibly be correct to
    store the mount namespace on the superblock as it does.
    
    Replace mount_ns with mount_nodev so that each mount of the bpf
    filesystem returns a distinct instance, and the code is not buggy.
    
    In discussion with Hannes Frederic Sowa it was reported that the use
    of mount_ns was an attempt to have one bpf instance per mount
    namespace, in an attempt to keep resources that pin resources from
    hiding.  That intent simply does not work, the vfs is not built to
    allow that kind of behavior.  Which means that the bpf filesystem
    really is buggy both semantically and in it's implemenation as it does
    not nor can it implement the original intent.
    
    This change is userspace visible, but my experience with similar
    filesystems leads me to believe nothing will break with a model of each
    mount of the bpf filesystem is distinct from all others.
    
    Fixes: b2197755 ("bpf: add support for persistent maps/progs")
    Cc: Hannes Frederic Sowa <hannes@stressinduktion.org>
    Acked-by: default avatarDaniel Borkmann <daniel@iogearbox.net>
    Signed-off-by: default avatar"Eric W. Biederman" <ebiederm@xmission.com>
    Acked-by: default avatarHannes Frederic Sowa <hannes@stressinduktion.org>
    Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
    Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
    5b7ea922
inode.c 7.37 KB