diff options
| author | Glenn Elliott <gelliott@cs.unc.edu> | 2012-03-04 19:47:13 -0500 |
|---|---|---|
| committer | Glenn Elliott <gelliott@cs.unc.edu> | 2012-03-04 19:47:13 -0500 |
| commit | c71c03bda1e86c9d5198c5d83f712e695c4f2a1e (patch) | |
| tree | ecb166cb3e2b7e2adb3b5e292245fefd23381ac8 /include/linux/mount.h | |
| parent | ea53c912f8a86a8567697115b6a0d8152beee5c8 (diff) | |
| parent | 6a00f206debf8a5c8899055726ad127dbeeed098 (diff) | |
Merge branch 'mpi-master' into wip-k-fmlpwip-k-fmlp
Conflicts:
litmus/sched_cedf.c
Diffstat (limited to 'include/linux/mount.h')
| -rw-r--r-- | include/linux/mount.h | 58 |
1 files changed, 16 insertions, 42 deletions
diff --git a/include/linux/mount.h b/include/linux/mount.h index 5e7a59408dd4..604f122a2326 100644 --- a/include/linux/mount.h +++ b/include/linux/mount.h | |||
| @@ -13,6 +13,7 @@ | |||
| 13 | #include <linux/list.h> | 13 | #include <linux/list.h> |
| 14 | #include <linux/nodemask.h> | 14 | #include <linux/nodemask.h> |
| 15 | #include <linux/spinlock.h> | 15 | #include <linux/spinlock.h> |
| 16 | #include <linux/seqlock.h> | ||
| 16 | #include <asm/atomic.h> | 17 | #include <asm/atomic.h> |
| 17 | 18 | ||
| 18 | struct super_block; | 19 | struct super_block; |
| @@ -46,12 +47,24 @@ struct mnt_namespace; | |||
| 46 | 47 | ||
| 47 | #define MNT_INTERNAL 0x4000 | 48 | #define MNT_INTERNAL 0x4000 |
| 48 | 49 | ||
| 50 | struct mnt_pcp { | ||
| 51 | int mnt_count; | ||
| 52 | int mnt_writers; | ||
| 53 | }; | ||
| 54 | |||
| 49 | struct vfsmount { | 55 | struct vfsmount { |
| 50 | struct list_head mnt_hash; | 56 | struct list_head mnt_hash; |
| 51 | struct vfsmount *mnt_parent; /* fs we are mounted on */ | 57 | struct vfsmount *mnt_parent; /* fs we are mounted on */ |
| 52 | struct dentry *mnt_mountpoint; /* dentry of mountpoint */ | 58 | struct dentry *mnt_mountpoint; /* dentry of mountpoint */ |
| 53 | struct dentry *mnt_root; /* root of the mounted tree */ | 59 | struct dentry *mnt_root; /* root of the mounted tree */ |
| 54 | struct super_block *mnt_sb; /* pointer to superblock */ | 60 | struct super_block *mnt_sb; /* pointer to superblock */ |
| 61 | #ifdef CONFIG_SMP | ||
| 62 | struct mnt_pcp __percpu *mnt_pcp; | ||
| 63 | atomic_t mnt_longterm; /* how many of the refs are longterm */ | ||
| 64 | #else | ||
| 65 | int mnt_count; | ||
| 66 | int mnt_writers; | ||
| 67 | #endif | ||
| 55 | struct list_head mnt_mounts; /* list of children, anchored here */ | 68 | struct list_head mnt_mounts; /* list of children, anchored here */ |
| 56 | struct list_head mnt_child; /* and going through their mnt_child */ | 69 | struct list_head mnt_child; /* and going through their mnt_child */ |
| 57 | int mnt_flags; | 70 | int mnt_flags; |
| @@ -70,57 +83,23 @@ struct vfsmount { | |||
| 70 | struct mnt_namespace *mnt_ns; /* containing namespace */ | 83 | struct mnt_namespace *mnt_ns; /* containing namespace */ |
| 71 | int mnt_id; /* mount identifier */ | 84 | int mnt_id; /* mount identifier */ |
| 72 | int mnt_group_id; /* peer group identifier */ | 85 | int mnt_group_id; /* peer group identifier */ |
| 73 | /* | ||
| 74 | * We put mnt_count & mnt_expiry_mark at the end of struct vfsmount | ||
| 75 | * to let these frequently modified fields in a separate cache line | ||
| 76 | * (so that reads of mnt_flags wont ping-pong on SMP machines) | ||
| 77 | */ | ||
| 78 | atomic_t mnt_count; | ||
| 79 | int mnt_expiry_mark; /* true if marked for expiry */ | 86 | int mnt_expiry_mark; /* true if marked for expiry */ |
| 80 | int mnt_pinned; | 87 | int mnt_pinned; |
| 81 | int mnt_ghosts; | 88 | int mnt_ghosts; |
| 82 | #ifdef CONFIG_SMP | ||
| 83 | int __percpu *mnt_writers; | ||
| 84 | #else | ||
| 85 | int mnt_writers; | ||
| 86 | #endif | ||
| 87 | }; | 89 | }; |
| 88 | 90 | ||
| 89 | static inline int *get_mnt_writers_ptr(struct vfsmount *mnt) | ||
| 90 | { | ||
| 91 | #ifdef CONFIG_SMP | ||
| 92 | return mnt->mnt_writers; | ||
| 93 | #else | ||
| 94 | return &mnt->mnt_writers; | ||
| 95 | #endif | ||
| 96 | } | ||
| 97 | |||
| 98 | static inline struct vfsmount *mntget(struct vfsmount *mnt) | ||
| 99 | { | ||
| 100 | if (mnt) | ||
| 101 | atomic_inc(&mnt->mnt_count); | ||
| 102 | return mnt; | ||
| 103 | } | ||
| 104 | |||
| 105 | struct file; /* forward dec */ | 91 | struct file; /* forward dec */ |
| 106 | 92 | ||
| 107 | extern int mnt_want_write(struct vfsmount *mnt); | 93 | extern int mnt_want_write(struct vfsmount *mnt); |
| 108 | extern int mnt_want_write_file(struct file *file); | 94 | extern int mnt_want_write_file(struct file *file); |
| 109 | extern int mnt_clone_write(struct vfsmount *mnt); | 95 | extern int mnt_clone_write(struct vfsmount *mnt); |
| 110 | extern void mnt_drop_write(struct vfsmount *mnt); | 96 | extern void mnt_drop_write(struct vfsmount *mnt); |
| 111 | extern void mntput_no_expire(struct vfsmount *mnt); | 97 | extern void mntput(struct vfsmount *mnt); |
| 98 | extern struct vfsmount *mntget(struct vfsmount *mnt); | ||
| 112 | extern void mnt_pin(struct vfsmount *mnt); | 99 | extern void mnt_pin(struct vfsmount *mnt); |
| 113 | extern void mnt_unpin(struct vfsmount *mnt); | 100 | extern void mnt_unpin(struct vfsmount *mnt); |
| 114 | extern int __mnt_is_readonly(struct vfsmount *mnt); | 101 | extern int __mnt_is_readonly(struct vfsmount *mnt); |
| 115 | 102 | ||
| 116 | static inline void mntput(struct vfsmount *mnt) | ||
| 117 | { | ||
| 118 | if (mnt) { | ||
| 119 | mnt->mnt_expiry_mark = 0; | ||
| 120 | mntput_no_expire(mnt); | ||
| 121 | } | ||
| 122 | } | ||
| 123 | |||
| 124 | extern struct vfsmount *do_kern_mount(const char *fstype, int flags, | 103 | extern struct vfsmount *do_kern_mount(const char *fstype, int flags, |
| 125 | const char *name, void *data); | 104 | const char *name, void *data); |
| 126 | 105 | ||
| @@ -129,12 +108,7 @@ extern struct vfsmount *vfs_kern_mount(struct file_system_type *type, | |||
| 129 | int flags, const char *name, | 108 | int flags, const char *name, |
| 130 | void *data); | 109 | void *data); |
| 131 | 110 | ||
| 132 | struct nameidata; | 111 | extern void mnt_set_expiry(struct vfsmount *mnt, struct list_head *expiry_list); |
| 133 | |||
| 134 | struct path; | ||
| 135 | extern int do_add_mount(struct vfsmount *newmnt, struct path *path, | ||
| 136 | int mnt_flags, struct list_head *fslist); | ||
| 137 | |||
| 138 | extern void mark_mounts_for_expiry(struct list_head *mounts); | 112 | extern void mark_mounts_for_expiry(struct list_head *mounts); |
| 139 | 113 | ||
| 140 | extern dev_t name_to_dev_t(char *name); | 114 | extern dev_t name_to_dev_t(char *name); |
