#include <linux/mount.h>
#include <linux/pseudo_fs.h>
#include <linux/file.h>
#include <linux/fs.h>
#include <linux/proc_fs.h>
#include <linux/proc_ns.h>
#include <linux/magic.h>
#include <linux/ktime.h>
#include <linux/seq_file.h>
#include <linux/pid_namespace.h>
#include <linux/user_namespace.h>
#include <linux/nsfs.h>
#include <linux/uaccess.h>
#include "mount.h"
#include "internal.h"
static struct vfsmount *nsfs_mnt;
static long ns_ioctl(struct file *filp, unsigned int ioctl,
unsigned long arg);
static const struct file_operations ns_file_operations = …;
static char *ns_dname(struct dentry *dentry, char *buffer, int buflen)
{ … }
const struct dentry_operations ns_dentry_operations = …;
static void nsfs_evict(struct inode *inode)
{ … }
int ns_get_path_cb(struct path *path, ns_get_path_helper_t *ns_get_cb,
void *private_data)
{ … }
struct ns_get_path_task_args { … };
static struct ns_common *ns_get_path_task(void *private_data)
{ … }
int ns_get_path(struct path *path, struct task_struct *task,
const struct proc_ns_operations *ns_ops)
{ … }
int open_namespace(struct ns_common *ns)
{ … }
int open_related_ns(struct ns_common *ns,
struct ns_common *(*get_ns)(struct ns_common *ns))
{ … }
EXPORT_SYMBOL_GPL(…);
static long ns_ioctl(struct file *filp, unsigned int ioctl,
unsigned long arg)
{ … }
int ns_get_name(char *buf, size_t size, struct task_struct *task,
const struct proc_ns_operations *ns_ops)
{ … }
bool proc_ns_file(const struct file *file)
{ … }
bool ns_match(const struct ns_common *ns, dev_t dev, ino_t ino)
{ … }
static int nsfs_show_path(struct seq_file *seq, struct dentry *dentry)
{ … }
static const struct super_operations nsfs_ops = …;
static int nsfs_init_inode(struct inode *inode, void *data)
{ … }
static void nsfs_put_data(void *data)
{ … }
static const struct stashed_operations nsfs_stashed_ops = …;
static int nsfs_init_fs_context(struct fs_context *fc)
{ … }
static struct file_system_type nsfs = …;
void __init nsfs_init(void)
{ … }