diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2010-06-06 20:08:56 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2010-08-09 16:48:10 -0400 |
commit | 39b743c6199a317ffac67fcae1dd05be3142633a (patch) | |
tree | 98e1ba53623f9844f192ab94df47717b4e00ed3b /fs | |
parent | 5e2df28cc62fdc3f4900de23f4ec69e6312f78a4 (diff) |
switch stat_file() to passing a single struct rather than fsckloads of pointers
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs')
-rw-r--r-- | fs/hostfs/hostfs.h | 20 | ||||
-rw-r--r-- | fs/hostfs/hostfs_kern.c | 31 | ||||
-rw-r--r-- | fs/hostfs/hostfs_user.c | 75 |
3 files changed, 58 insertions, 68 deletions
diff --git a/fs/hostfs/hostfs.h b/fs/hostfs/hostfs.h index 2f34f8f2134b..3a52edef9948 100644 --- a/fs/hostfs/hostfs.h +++ b/fs/hostfs/hostfs.h | |||
@@ -53,11 +53,21 @@ struct hostfs_iattr { | |||
53 | struct timespec ia_ctime; | 53 | struct timespec ia_ctime; |
54 | }; | 54 | }; |
55 | 55 | ||
56 | extern int stat_file(const char *path, unsigned long long *inode_out, | 56 | struct hostfs_stat { |
57 | int *mode_out, int *nlink_out, int *uid_out, int *gid_out, | 57 | unsigned long long ino; |
58 | unsigned long long *size_out, struct timespec *atime_out, | 58 | unsigned int mode; |
59 | struct timespec *mtime_out, struct timespec *ctime_out, | 59 | unsigned int nlink; |
60 | int *blksize_out, unsigned long long *blocks_out, int fd); | 60 | unsigned int uid; |
61 | unsigned int gid; | ||
62 | unsigned long long size; | ||
63 | struct timespec atime, mtime, ctime; | ||
64 | unsigned int blksize; | ||
65 | unsigned long long blocks; | ||
66 | unsigned int maj; | ||
67 | unsigned int min; | ||
68 | }; | ||
69 | |||
70 | extern int stat_file(const char *path, struct hostfs_stat *p, int fd); | ||
61 | extern int access_file(char *path, int r, int w, int x); | 71 | extern int access_file(char *path, int r, int w, int x); |
62 | extern int open_file(char *path, int r, int w, int append); | 72 | extern int open_file(char *path, int r, int w, int append); |
63 | extern int file_type(const char *path, int *maj, int *min); | 73 | extern int file_type(const char *path, int *maj, int *min); |
diff --git a/fs/hostfs/hostfs_kern.c b/fs/hostfs/hostfs_kern.c index 5a77ed3dfd7e..420a826ae0f2 100644 --- a/fs/hostfs/hostfs_kern.c +++ b/fs/hostfs/hostfs_kern.c | |||
@@ -131,28 +131,21 @@ static char *inode_name(struct inode *ino, int extra) | |||
131 | 131 | ||
132 | static int read_name(struct inode *ino, char *name) | 132 | static int read_name(struct inode *ino, char *name) |
133 | { | 133 | { |
134 | /* | 134 | struct hostfs_stat st; |
135 | * The non-int inode fields are copied into ints by stat_file and | 135 | int err = stat_file(name, &st, -1); |
136 | * then copied into the inode because passing the actual pointers | ||
137 | * in and having them treated as int * breaks on big-endian machines | ||
138 | */ | ||
139 | int err; | ||
140 | int i_mode, i_nlink, i_blksize; | ||
141 | unsigned long long i_size; | ||
142 | unsigned long long i_ino; | ||
143 | unsigned long long i_blocks; | ||
144 | |||
145 | err = stat_file(name, &i_ino, &i_mode, &i_nlink, &ino->i_uid, | ||
146 | &ino->i_gid, &i_size, &ino->i_atime, &ino->i_mtime, | ||
147 | &ino->i_ctime, &i_blksize, &i_blocks, -1); | ||
148 | if (err) | 136 | if (err) |
149 | return err; | 137 | return err; |
150 | 138 | ||
151 | ino->i_ino = i_ino; | 139 | ino->i_ino = st.ino; |
152 | ino->i_mode = i_mode; | 140 | ino->i_mode = st.mode; |
153 | ino->i_nlink = i_nlink; | 141 | ino->i_nlink = st.nlink; |
154 | ino->i_size = i_size; | 142 | ino->i_uid = st.uid; |
155 | ino->i_blocks = i_blocks; | 143 | ino->i_gid = st.gid; |
144 | ino->i_atime = st.atime; | ||
145 | ino->i_mtime = st.mtime; | ||
146 | ino->i_ctime = st.ctime; | ||
147 | ino->i_size = st.size; | ||
148 | ino->i_blocks = st.blocks; | ||
156 | return 0; | 149 | return 0; |
157 | } | 150 | } |
158 | 151 | ||
diff --git a/fs/hostfs/hostfs_user.c b/fs/hostfs/hostfs_user.c index 4b8c666ba28f..701d454a6791 100644 --- a/fs/hostfs/hostfs_user.c +++ b/fs/hostfs/hostfs_user.c | |||
@@ -19,11 +19,27 @@ | |||
19 | #include "user.h" | 19 | #include "user.h" |
20 | #include <utime.h> | 20 | #include <utime.h> |
21 | 21 | ||
22 | int stat_file(const char *path, unsigned long long *inode_out, int *mode_out, | 22 | static void stat64_to_hostfs(const struct stat64 *buf, struct hostfs_stat *p) |
23 | int *nlink_out, int *uid_out, int *gid_out, | 23 | { |
24 | unsigned long long *size_out, struct timespec *atime_out, | 24 | p->ino = buf->st_ino; |
25 | struct timespec *mtime_out, struct timespec *ctime_out, | 25 | p->mode = buf->st_mode; |
26 | int *blksize_out, unsigned long long *blocks_out, int fd) | 26 | p->nlink = buf->st_nlink; |
27 | p->uid = buf->st_uid; | ||
28 | p->gid = buf->st_gid; | ||
29 | p->size = buf->st_size; | ||
30 | p->atime.tv_sec = buf->st_atime; | ||
31 | p->atime.tv_nsec = 0; | ||
32 | p->ctime.tv_sec = buf->st_ctime; | ||
33 | p->ctime.tv_nsec = 0; | ||
34 | p->mtime.tv_sec = buf->st_mtime; | ||
35 | p->mtime.tv_nsec = 0; | ||
36 | p->blksize = buf->st_blksize; | ||
37 | p->blocks = buf->st_blocks; | ||
38 | p->maj = os_major(buf->st_rdev); | ||
39 | p->min = os_minor(buf->st_rdev); | ||
40 | } | ||
41 | |||
42 | int stat_file(const char *path, struct hostfs_stat *p, int fd) | ||
27 | { | 43 | { |
28 | struct stat64 buf; | 44 | struct stat64 buf; |
29 | 45 | ||
@@ -33,35 +49,7 @@ int stat_file(const char *path, unsigned long long *inode_out, int *mode_out, | |||
33 | } else if (lstat64(path, &buf) < 0) { | 49 | } else if (lstat64(path, &buf) < 0) { |
34 | return -errno; | 50 | return -errno; |
35 | } | 51 | } |
36 | 52 | stat64_to_hostfs(&buf, p); | |
37 | if (inode_out != NULL) | ||
38 | *inode_out = buf.st_ino; | ||
39 | if (mode_out != NULL) | ||
40 | *mode_out = buf.st_mode; | ||
41 | if (nlink_out != NULL) | ||
42 | *nlink_out = buf.st_nlink; | ||
43 | if (uid_out != NULL) | ||
44 | *uid_out = buf.st_uid; | ||
45 | if (gid_out != NULL) | ||
46 | *gid_out = buf.st_gid; | ||
47 | if (size_out != NULL) | ||
48 | *size_out = buf.st_size; | ||
49 | if (atime_out != NULL) { | ||
50 | atime_out->tv_sec = buf.st_atime; | ||
51 | atime_out->tv_nsec = 0; | ||
52 | } | ||
53 | if (mtime_out != NULL) { | ||
54 | mtime_out->tv_sec = buf.st_mtime; | ||
55 | mtime_out->tv_nsec = 0; | ||
56 | } | ||
57 | if (ctime_out != NULL) { | ||
58 | ctime_out->tv_sec = buf.st_ctime; | ||
59 | ctime_out->tv_nsec = 0; | ||
60 | } | ||
61 | if (blksize_out != NULL) | ||
62 | *blksize_out = buf.st_blksize; | ||
63 | if (blocks_out != NULL) | ||
64 | *blocks_out = buf.st_blocks; | ||
65 | return 0; | 53 | return 0; |
66 | } | 54 | } |
67 | 55 | ||
@@ -235,8 +223,8 @@ int file_create(char *name, int ur, int uw, int ux, int gr, | |||
235 | 223 | ||
236 | int set_attr(const char *file, struct hostfs_iattr *attrs, int fd) | 224 | int set_attr(const char *file, struct hostfs_iattr *attrs, int fd) |
237 | { | 225 | { |
226 | struct hostfs_stat st; | ||
238 | struct timeval times[2]; | 227 | struct timeval times[2]; |
239 | struct timespec atime_ts, mtime_ts; | ||
240 | int err, ma; | 228 | int err, ma; |
241 | 229 | ||
242 | if (attrs->ia_valid & HOSTFS_ATTR_MODE) { | 230 | if (attrs->ia_valid & HOSTFS_ATTR_MODE) { |
@@ -279,15 +267,14 @@ int set_attr(const char *file, struct hostfs_iattr *attrs, int fd) | |||
279 | */ | 267 | */ |
280 | ma = (HOSTFS_ATTR_ATIME_SET | HOSTFS_ATTR_MTIME_SET); | 268 | ma = (HOSTFS_ATTR_ATIME_SET | HOSTFS_ATTR_MTIME_SET); |
281 | if (attrs->ia_valid & ma) { | 269 | if (attrs->ia_valid & ma) { |
282 | err = stat_file(file, NULL, NULL, NULL, NULL, NULL, NULL, | 270 | err = stat_file(file, &st, fd); |
283 | &atime_ts, &mtime_ts, NULL, NULL, NULL, fd); | ||
284 | if (err != 0) | 271 | if (err != 0) |
285 | return err; | 272 | return err; |
286 | 273 | ||
287 | times[0].tv_sec = atime_ts.tv_sec; | 274 | times[0].tv_sec = st.atime.tv_sec; |
288 | times[0].tv_usec = atime_ts.tv_nsec / 1000; | 275 | times[0].tv_usec = st.atime.tv_nsec / 1000; |
289 | times[1].tv_sec = mtime_ts.tv_sec; | 276 | times[1].tv_sec = st.mtime.tv_sec; |
290 | times[1].tv_usec = mtime_ts.tv_nsec / 1000; | 277 | times[1].tv_usec = st.mtime.tv_nsec / 1000; |
291 | 278 | ||
292 | if (attrs->ia_valid & HOSTFS_ATTR_ATIME_SET) { | 279 | if (attrs->ia_valid & HOSTFS_ATTR_ATIME_SET) { |
293 | times[0].tv_sec = attrs->ia_atime.tv_sec; | 280 | times[0].tv_sec = attrs->ia_atime.tv_sec; |
@@ -308,9 +295,9 @@ int set_attr(const char *file, struct hostfs_iattr *attrs, int fd) | |||
308 | 295 | ||
309 | /* Note: ctime is not handled */ | 296 | /* Note: ctime is not handled */ |
310 | if (attrs->ia_valid & (HOSTFS_ATTR_ATIME | HOSTFS_ATTR_MTIME)) { | 297 | if (attrs->ia_valid & (HOSTFS_ATTR_ATIME | HOSTFS_ATTR_MTIME)) { |
311 | err = stat_file(file, NULL, NULL, NULL, NULL, NULL, NULL, | 298 | err = stat_file(file, &st, fd); |
312 | &attrs->ia_atime, &attrs->ia_mtime, NULL, | 299 | attrs->ia_atime = st.atime; |
313 | NULL, NULL, fd); | 300 | attrs->ia_mtime = st.mtime; |
314 | if (err != 0) | 301 | if (err != 0) |
315 | return err; | 302 | return err; |
316 | } | 303 | } |