diff options
| author | Al Viro <viro@zeniv.linux.org.uk> | 2013-01-31 12:34:58 -0500 |
|---|---|---|
| committer | Al Viro <viro@zeniv.linux.org.uk> | 2013-02-26 02:46:05 -0500 |
| commit | 38baba9ea02780c2df35c7a02552fddeb8576e16 (patch) | |
| tree | 8e6cd8ecf1c6f1488dceab90015b76e349d4e2af /fs/9p | |
| parent | 8add862fad426469a04c879bf5bb01f666a3c58e (diff) | |
9p: add fid-based variant of v9fs_xattr_set()
... making v9fs_xattr_set() a wrapper for it.
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs/9p')
| -rw-r--r-- | fs/9p/xattr.c | 33 | ||||
| -rw-r--r-- | fs/9p/xattr.h | 2 |
2 files changed, 20 insertions, 15 deletions
diff --git a/fs/9p/xattr.c b/fs/9p/xattr.c index 29653b70a9c3..c45e016b190f 100644 --- a/fs/9p/xattr.c +++ b/fs/9p/xattr.c | |||
| @@ -111,19 +111,26 @@ ssize_t v9fs_xattr_get(struct dentry *dentry, const char *name, | |||
| 111 | int v9fs_xattr_set(struct dentry *dentry, const char *name, | 111 | int v9fs_xattr_set(struct dentry *dentry, const char *name, |
| 112 | const void *value, size_t value_len, int flags) | 112 | const void *value, size_t value_len, int flags) |
| 113 | { | 113 | { |
| 114 | struct p9_fid *fid = v9fs_fid_lookup(dentry); | ||
| 115 | if (IS_ERR(fid)) | ||
| 116 | return PTR_ERR(fid); | ||
| 117 | return v9fs_fid_xattr_set(fid, name, value, value_len, flags); | ||
| 118 | } | ||
| 119 | |||
| 120 | int v9fs_fid_xattr_set(struct p9_fid *fid, const char *name, | ||
| 121 | const void *value, size_t value_len, int flags) | ||
| 122 | { | ||
| 114 | u64 offset = 0; | 123 | u64 offset = 0; |
| 115 | int retval, msize, write_count; | 124 | int retval, msize, write_count; |
| 116 | struct p9_fid *fid = NULL; | ||
| 117 | 125 | ||
| 118 | p9_debug(P9_DEBUG_VFS, "name = %s value_len = %zu flags = %d\n", | 126 | p9_debug(P9_DEBUG_VFS, "name = %s value_len = %zu flags = %d\n", |
| 119 | name, value_len, flags); | 127 | name, value_len, flags); |
| 120 | 128 | ||
| 121 | fid = v9fs_fid_clone(dentry); | 129 | /* Clone it */ |
| 122 | if (IS_ERR(fid)) { | 130 | fid = p9_client_walk(fid, 0, NULL, 1); |
| 123 | retval = PTR_ERR(fid); | 131 | if (IS_ERR(fid)) |
| 124 | fid = NULL; | 132 | return PTR_ERR(fid); |
| 125 | goto error; | 133 | |
| 126 | } | ||
| 127 | /* | 134 | /* |
| 128 | * On success fid points to xattr | 135 | * On success fid points to xattr |
| 129 | */ | 136 | */ |
| @@ -131,7 +138,8 @@ int v9fs_xattr_set(struct dentry *dentry, const char *name, | |||
| 131 | if (retval < 0) { | 138 | if (retval < 0) { |
| 132 | p9_debug(P9_DEBUG_VFS, "p9_client_xattrcreate failed %d\n", | 139 | p9_debug(P9_DEBUG_VFS, "p9_client_xattrcreate failed %d\n", |
| 133 | retval); | 140 | retval); |
| 134 | goto error; | 141 | p9_client_clunk(fid); |
| 142 | return retval; | ||
| 135 | } | 143 | } |
| 136 | msize = fid->clnt->msize; | 144 | msize = fid->clnt->msize; |
| 137 | while (value_len) { | 145 | while (value_len) { |
| @@ -144,17 +152,12 @@ int v9fs_xattr_set(struct dentry *dentry, const char *name, | |||
| 144 | if (write_count < 0) { | 152 | if (write_count < 0) { |
| 145 | /* error in xattr write */ | 153 | /* error in xattr write */ |
| 146 | retval = write_count; | 154 | retval = write_count; |
| 147 | goto error; | 155 | break; |
| 148 | } | 156 | } |
| 149 | offset += write_count; | 157 | offset += write_count; |
| 150 | value_len -= write_count; | 158 | value_len -= write_count; |
| 151 | } | 159 | } |
| 152 | /* Total read xattr bytes */ | 160 | return p9_client_clunk(fid); |
| 153 | retval = offset; | ||
| 154 | error: | ||
| 155 | if (fid) | ||
| 156 | retval = p9_client_clunk(fid); | ||
| 157 | return retval; | ||
| 158 | } | 161 | } |
| 159 | 162 | ||
| 160 | ssize_t v9fs_listxattr(struct dentry *dentry, char *buffer, size_t buffer_size) | 163 | ssize_t v9fs_listxattr(struct dentry *dentry, char *buffer, size_t buffer_size) |
diff --git a/fs/9p/xattr.h b/fs/9p/xattr.h index eaa837c53bd5..eec348a3df71 100644 --- a/fs/9p/xattr.h +++ b/fs/9p/xattr.h | |||
| @@ -27,6 +27,8 @@ extern ssize_t v9fs_fid_xattr_get(struct p9_fid *, const char *, | |||
| 27 | void *, size_t); | 27 | void *, size_t); |
| 28 | extern ssize_t v9fs_xattr_get(struct dentry *, const char *, | 28 | extern ssize_t v9fs_xattr_get(struct dentry *, const char *, |
| 29 | void *, size_t); | 29 | void *, size_t); |
| 30 | extern int v9fs_fid_xattr_set(struct p9_fid *, const char *, | ||
| 31 | const void *, size_t, int); | ||
| 30 | extern int v9fs_xattr_set(struct dentry *, const char *, | 32 | extern int v9fs_xattr_set(struct dentry *, const char *, |
| 31 | const void *, size_t, int); | 33 | const void *, size_t, int); |
| 32 | extern ssize_t v9fs_listxattr(struct dentry *, char *, size_t); | 34 | extern ssize_t v9fs_listxattr(struct dentry *, char *, size_t); |
