mount.h 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. /*
  2. *
  3. * Definitions for mount interface. This describes the in the kernel build
  4. * linkedlist with mounted filesystems.
  5. *
  6. * Author: Marco van Wieringen <mvw@planets.elm.net>
  7. *
  8. */
  9. #ifndef _LINUX_MOUNT_H
  10. #define _LINUX_MOUNT_H
  11. #include <linux/types.h>
  12. #include <linux/list.h>
  13. #include <linux/nodemask.h>
  14. #include <linux/spinlock.h>
  15. #include <linux/seqlock.h>
  16. #include <linux/atomic.h>
  17. struct super_block;
  18. struct vfsmount;
  19. struct dentry;
  20. struct mnt_namespace;
  21. #define MNT_NOSUID 0x01
  22. #define MNT_NODEV 0x02
  23. #define MNT_NOEXEC 0x04
  24. #define MNT_NOATIME 0x08
  25. #define MNT_NODIRATIME 0x10
  26. #define MNT_RELATIME 0x20
  27. #define MNT_READONLY 0x40 /* does the user want this to be r/o? */
  28. #define MNT_SHRINKABLE 0x100
  29. #define MNT_WRITE_HOLD 0x200
  30. #define MNT_SHARED 0x1000 /* if the vfsmount is a shared mount */
  31. #define MNT_UNBINDABLE 0x2000 /* if the vfsmount is a unbindable mount */
  32. /*
  33. * MNT_SHARED_MASK is the set of flags that should be cleared when a
  34. * mount becomes shared. Currently, this is only the flag that says a
  35. * mount cannot be bind mounted, since this is how we create a mount
  36. * that shares events with another mount. If you add a new MNT_*
  37. * flag, consider how it interacts with shared mounts.
  38. */
  39. #define MNT_SHARED_MASK (MNT_UNBINDABLE)
  40. #define MNT_USER_SETTABLE_MASK (MNT_NOSUID | MNT_NODEV | MNT_NOEXEC \
  41. | MNT_NOATIME | MNT_NODIRATIME | MNT_RELATIME \
  42. | MNT_READONLY)
  43. #define MNT_ATIME_MASK (MNT_NOATIME | MNT_NODIRATIME | MNT_RELATIME )
  44. #define MNT_INTERNAL_FLAGS (MNT_SHARED | MNT_WRITE_HOLD | MNT_INTERNAL | \
  45. MNT_DOOMED | MNT_SYNC_UMOUNT | MNT_MARKED)
  46. #define MNT_INTERNAL 0x4000
  47. #define MNT_LOCK_ATIME 0x040000
  48. #define MNT_LOCK_NOEXEC 0x080000
  49. #define MNT_LOCK_NOSUID 0x100000
  50. #define MNT_LOCK_NODEV 0x200000
  51. #define MNT_LOCK_READONLY 0x400000
  52. #define MNT_LOCKED 0x800000
  53. #define MNT_DOOMED 0x1000000
  54. #define MNT_SYNC_UMOUNT 0x2000000
  55. #define MNT_MARKED 0x4000000
  56. struct vfsmount {
  57. struct dentry *mnt_root; /* root of the mounted tree */
  58. struct super_block *mnt_sb; /* pointer to superblock */
  59. int mnt_flags;
  60. };
  61. struct file; /* forward dec */
  62. struct path;
  63. extern int mnt_want_write(struct vfsmount *mnt);
  64. extern int mnt_want_write_file(struct file *file);
  65. extern int mnt_clone_write(struct vfsmount *mnt);
  66. extern void mnt_drop_write(struct vfsmount *mnt);
  67. extern void mnt_drop_write_file(struct file *file);
  68. extern void mntput(struct vfsmount *mnt);
  69. extern struct vfsmount *mntget(struct vfsmount *mnt);
  70. extern struct vfsmount *mnt_clone_internal(struct path *path);
  71. extern int __mnt_is_readonly(struct vfsmount *mnt);
  72. struct path;
  73. extern struct vfsmount *clone_private_mount(struct path *path);
  74. struct file_system_type;
  75. extern struct vfsmount *vfs_kern_mount(struct file_system_type *type,
  76. int flags, const char *name,
  77. void *data);
  78. extern void mnt_set_expiry(struct vfsmount *mnt, struct list_head *expiry_list);
  79. extern void mark_mounts_for_expiry(struct list_head *mounts);
  80. extern dev_t name_to_dev_t(char *name);
  81. #endif /* _LINUX_MOUNT_H */