mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
synced 2025-08-27 06:50:37 +00:00

Several flags are updated and checked only under namespace_sem; we are already making use of that when we are checking them without mount_lock, but we have to hold mount_lock for all updates, which makes things clumsier than they have to be. Take MNT_SHARED, MNT_UNBINDABLE, MNT_MARKED and MNT_UMOUNT_CANDIDATE into a separate field (->mnt_t_flags), renaming them to T_SHARED, etc. to avoid confusion. All accesses must be under namespace_sem. That changes locking requirements for mnt_change_propagation() and set_mnt_shared() - only namespace_sem is needed now. The same goes for SET_MNT_MARKED et.al. There might be more flags moved from ->mnt_flags to that field; this is just the initial set. Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
114 lines
3.5 KiB
C
114 lines
3.5 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
*
|
|
* Definitions for mount interface. This describes the in the kernel build
|
|
* linkedlist with mounted filesystems.
|
|
*
|
|
* Author: Marco van Wieringen <mvw@planets.elm.net>
|
|
*
|
|
*/
|
|
#ifndef _LINUX_MOUNT_H
|
|
#define _LINUX_MOUNT_H
|
|
|
|
#include <linux/types.h>
|
|
#include <asm/barrier.h>
|
|
|
|
struct super_block;
|
|
struct dentry;
|
|
struct user_namespace;
|
|
struct mnt_idmap;
|
|
struct file_system_type;
|
|
struct fs_context;
|
|
struct file;
|
|
struct path;
|
|
|
|
enum mount_flags {
|
|
MNT_NOSUID = 0x01,
|
|
MNT_NODEV = 0x02,
|
|
MNT_NOEXEC = 0x04,
|
|
MNT_NOATIME = 0x08,
|
|
MNT_NODIRATIME = 0x10,
|
|
MNT_RELATIME = 0x20,
|
|
MNT_READONLY = 0x40, /* does the user want this to be r/o? */
|
|
MNT_NOSYMFOLLOW = 0x80,
|
|
|
|
MNT_SHRINKABLE = 0x100,
|
|
MNT_WRITE_HOLD = 0x200,
|
|
|
|
MNT_INTERNAL = 0x4000,
|
|
|
|
MNT_LOCK_ATIME = 0x040000,
|
|
MNT_LOCK_NOEXEC = 0x080000,
|
|
MNT_LOCK_NOSUID = 0x100000,
|
|
MNT_LOCK_NODEV = 0x200000,
|
|
MNT_LOCK_READONLY = 0x400000,
|
|
MNT_LOCKED = 0x800000,
|
|
MNT_DOOMED = 0x1000000,
|
|
MNT_SYNC_UMOUNT = 0x2000000,
|
|
MNT_UMOUNT = 0x8000000,
|
|
|
|
MNT_USER_SETTABLE_MASK = MNT_NOSUID | MNT_NODEV | MNT_NOEXEC
|
|
| MNT_NOATIME | MNT_NODIRATIME | MNT_RELATIME
|
|
| MNT_READONLY | MNT_NOSYMFOLLOW,
|
|
MNT_ATIME_MASK = MNT_NOATIME | MNT_NODIRATIME | MNT_RELATIME,
|
|
|
|
MNT_INTERNAL_FLAGS = MNT_WRITE_HOLD | MNT_INTERNAL | MNT_DOOMED |
|
|
MNT_SYNC_UMOUNT | MNT_LOCKED
|
|
};
|
|
|
|
struct vfsmount {
|
|
struct dentry *mnt_root; /* root of the mounted tree */
|
|
struct super_block *mnt_sb; /* pointer to superblock */
|
|
int mnt_flags;
|
|
struct mnt_idmap *mnt_idmap;
|
|
} __randomize_layout;
|
|
|
|
static inline struct mnt_idmap *mnt_idmap(const struct vfsmount *mnt)
|
|
{
|
|
/* Pairs with smp_store_release() in do_idmap_mount(). */
|
|
return READ_ONCE(mnt->mnt_idmap);
|
|
}
|
|
|
|
extern int mnt_want_write(struct vfsmount *mnt);
|
|
extern int mnt_want_write_file(struct file *file);
|
|
extern void mnt_drop_write(struct vfsmount *mnt);
|
|
extern void mnt_drop_write_file(struct file *file);
|
|
extern void mntput(struct vfsmount *mnt);
|
|
extern struct vfsmount *mntget(struct vfsmount *mnt);
|
|
extern void mnt_make_shortterm(struct vfsmount *mnt);
|
|
extern struct vfsmount *mnt_clone_internal(const struct path *path);
|
|
extern bool __mnt_is_readonly(struct vfsmount *mnt);
|
|
extern bool mnt_may_suid(struct vfsmount *mnt);
|
|
|
|
extern struct vfsmount *clone_private_mount(const struct path *path);
|
|
int mnt_get_write_access(struct vfsmount *mnt);
|
|
void mnt_put_write_access(struct vfsmount *mnt);
|
|
|
|
extern struct vfsmount *fc_mount(struct fs_context *fc);
|
|
extern struct vfsmount *fc_mount_longterm(struct fs_context *fc);
|
|
extern struct vfsmount *vfs_create_mount(struct fs_context *fc);
|
|
extern struct vfsmount *vfs_kern_mount(struct file_system_type *type,
|
|
int flags, const char *name,
|
|
void *data);
|
|
|
|
extern void mnt_set_expiry(struct vfsmount *mnt, struct list_head *expiry_list);
|
|
extern void mark_mounts_for_expiry(struct list_head *mounts);
|
|
|
|
extern bool path_is_mountpoint(const struct path *path);
|
|
|
|
extern bool our_mnt(struct vfsmount *mnt);
|
|
|
|
extern struct vfsmount *kern_mount(struct file_system_type *);
|
|
extern void kern_unmount(struct vfsmount *mnt);
|
|
extern int may_umount_tree(struct vfsmount *);
|
|
extern int may_umount(struct vfsmount *);
|
|
int do_mount(const char *, const char __user *,
|
|
const char *, unsigned long, void *);
|
|
extern struct path *collect_paths(const struct path *, struct path *, unsigned);
|
|
extern void drop_collected_paths(struct path *, struct path *);
|
|
extern void kern_unmount_array(struct vfsmount *mnt[], unsigned int num);
|
|
|
|
extern int cifs_root_data(char **dev, char **opts);
|
|
|
|
#endif /* _LINUX_MOUNT_H */
|