diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2014-11-01 19:30:41 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2014-12-10 21:32:13 -0500 |
commit | 1f55a6ec940fb45e3edaa52b6e9fc40cf8e18dcb (patch) | |
tree | 67cd7ee3eb2546116d1a322b4bbaf7b6f82a80f5 | |
parent | 707c5960f102f8cdafb9406047b158abc71b391f (diff) |
make nameidata completely opaque outside of fs/namei.c
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
-rw-r--r-- | fs/namei.c | 24 | ||||
-rw-r--r-- | include/linux/namei.h | 25 |
2 files changed, 27 insertions, 22 deletions
diff --git a/fs/namei.c b/fs/namei.c index db5fe86319e6..398a73b522cb 100644 --- a/fs/namei.c +++ b/fs/namei.c | |||
@@ -487,6 +487,18 @@ void path_put(const struct path *path) | |||
487 | } | 487 | } |
488 | EXPORT_SYMBOL(path_put); | 488 | EXPORT_SYMBOL(path_put); |
489 | 489 | ||
490 | struct nameidata { | ||
491 | struct path path; | ||
492 | struct qstr last; | ||
493 | struct path root; | ||
494 | struct inode *inode; /* path.dentry.d_inode */ | ||
495 | unsigned int flags; | ||
496 | unsigned seq, m_seq; | ||
497 | int last_type; | ||
498 | unsigned depth; | ||
499 | char *saved_names[MAX_NESTED_LINKS + 1]; | ||
500 | }; | ||
501 | |||
490 | /* | 502 | /* |
491 | * Path walking has 2 modes, rcu-walk and ref-walk (see | 503 | * Path walking has 2 modes, rcu-walk and ref-walk (see |
492 | * Documentation/filesystems/path-lookup.txt). In situations when we can't | 504 | * Documentation/filesystems/path-lookup.txt). In situations when we can't |
@@ -695,6 +707,18 @@ void nd_jump_link(struct nameidata *nd, struct path *path) | |||
695 | nd->flags |= LOOKUP_JUMPED; | 707 | nd->flags |= LOOKUP_JUMPED; |
696 | } | 708 | } |
697 | 709 | ||
710 | void nd_set_link(struct nameidata *nd, char *path) | ||
711 | { | ||
712 | nd->saved_names[nd->depth] = path; | ||
713 | } | ||
714 | EXPORT_SYMBOL(nd_set_link); | ||
715 | |||
716 | char *nd_get_link(struct nameidata *nd) | ||
717 | { | ||
718 | return nd->saved_names[nd->depth]; | ||
719 | } | ||
720 | EXPORT_SYMBOL(nd_get_link); | ||
721 | |||
698 | static inline void put_link(struct nameidata *nd, struct path *link, void *cookie) | 722 | static inline void put_link(struct nameidata *nd, struct path *link, void *cookie) |
699 | { | 723 | { |
700 | struct inode *inode = link->dentry->d_inode; | 724 | struct inode *inode = link->dentry->d_inode; |
diff --git a/include/linux/namei.h b/include/linux/namei.h index 492de72560fa..c8990779f0c3 100644 --- a/include/linux/namei.h +++ b/include/linux/namei.h | |||
@@ -7,21 +7,10 @@ | |||
7 | #include <linux/path.h> | 7 | #include <linux/path.h> |
8 | 8 | ||
9 | struct vfsmount; | 9 | struct vfsmount; |
10 | struct nameidata; | ||
10 | 11 | ||
11 | enum { MAX_NESTED_LINKS = 8 }; | 12 | enum { MAX_NESTED_LINKS = 8 }; |
12 | 13 | ||
13 | struct nameidata { | ||
14 | struct path path; | ||
15 | struct qstr last; | ||
16 | struct path root; | ||
17 | struct inode *inode; /* path.dentry.d_inode */ | ||
18 | unsigned int flags; | ||
19 | unsigned seq, m_seq; | ||
20 | int last_type; | ||
21 | unsigned depth; | ||
22 | char *saved_names[MAX_NESTED_LINKS + 1]; | ||
23 | }; | ||
24 | |||
25 | /* | 14 | /* |
26 | * Type of the last component on LOOKUP_PARENT | 15 | * Type of the last component on LOOKUP_PARENT |
27 | */ | 16 | */ |
@@ -82,16 +71,8 @@ extern struct dentry *lock_rename(struct dentry *, struct dentry *); | |||
82 | extern void unlock_rename(struct dentry *, struct dentry *); | 71 | extern void unlock_rename(struct dentry *, struct dentry *); |
83 | 72 | ||
84 | extern void nd_jump_link(struct nameidata *nd, struct path *path); | 73 | extern void nd_jump_link(struct nameidata *nd, struct path *path); |
85 | 74 | extern void nd_set_link(struct nameidata *nd, char *path); | |
86 | static inline void nd_set_link(struct nameidata *nd, char *path) | 75 | extern char *nd_get_link(struct nameidata *nd); |
87 | { | ||
88 | nd->saved_names[nd->depth] = path; | ||
89 | } | ||
90 | |||
91 | static inline char *nd_get_link(struct nameidata *nd) | ||
92 | { | ||
93 | return nd->saved_names[nd->depth]; | ||
94 | } | ||
95 | 76 | ||
96 | static inline void nd_terminate_link(void *name, size_t len, size_t maxlen) | 77 | static inline void nd_terminate_link(void *name, size_t len, size_t maxlen) |
97 | { | 78 | { |