summaryrefslogtreecommitdiffstats
path: root/booster/src/booster.c
diff options
context:
space:
mode:
authorRaghavendra G <raghavendra@gluster.com>2009-10-23 13:03:04 +0000
committerAnand V. Avati <avati@dev.gluster.com>2009-10-26 07:09:35 -0700
commit544333a14af7a0ff9595072b86716474d6e48632 (patch)
treec1c4a53fd2e75b70d55e11736b6c4472c4664bc8 /booster/src/booster.c
parentef9a28bb2dd57f06c8c4ff75615aba894f2d0bf7 (diff)
booster: seperate out the implementations of readdir and readdir64.
- readdir and readdir64 should not call same procedure booster_readdir in their implementation, since the layout of dirent structures returned by libc implementations of readdir and readdir64 is different (readdir returns struct dirent *, where as readdir64 returns struct dirent64 *). Signed-off-by: Anand V. Avati <avati@dev.gluster.com> BUG: 333 (ls on paths not on virtual mounts report wrong directory contents) URL: http://bugs.gluster.com/cgi-bin/bugzilla3/show_bug.cgi?id=333
Diffstat (limited to 'booster/src/booster.c')
-rw-r--r--booster/src/booster.c42
1 files changed, 41 insertions, 1 deletions
diff --git a/booster/src/booster.c b/booster/src/booster.c
index 8d3a1dedb..3f171646c 100644
--- a/booster/src/booster.c
+++ b/booster/src/booster.c
@@ -151,6 +151,7 @@ static int (*real_readlink) (const char *path, char *buf, size_t bufsize);
static char * (*real_realpath) (const char *path, char *resolved);
static DIR * (*real_opendir) (const char *path);
static struct dirent * (*real_readdir) (DIR *dir);
+static struct dirent64 * (*real_readdir64) (DIR *dir);
static int (*real_readdir_r) (DIR *dir, struct dirent *entry,
struct dirent **result);
static int (*real_readdir64_r) (DIR *dir, struct dirent64 *entry,
@@ -1686,7 +1687,13 @@ out:
}
struct dirent *
-booster_readdir (DIR *dir)
+__REDIRECT (booster_false_readdir, (DIR *dir), readdir) __nonnull ((1));
+
+struct dirent64 *
+__REDIRECT (booster_false_readdir64, (DIR *dir), readdir64) __nonnull ((1));
+
+struct dirent *
+booster_false_readdir (DIR *dir)
{
struct booster_dir_handle *bh = (struct booster_dir_handle *)dir;
struct dirent *dirp = NULL;
@@ -1717,6 +1724,38 @@ out:
return dirp;
}
+struct dirent64 *
+booster_false_readdir64 (DIR *dir)
+{
+ struct booster_dir_handle *bh = (struct booster_dir_handle *)dir;
+ struct dirent64 *dirp = NULL;
+
+ if (!bh) {
+ errno = EFAULT;
+ goto out;
+ }
+
+ if (bh->type == BOOSTER_GL_DIR) {
+ gf_log ("booster", GF_LOG_TRACE, "readdir on gluster");
+ dirp = glusterfs_readdir ((glusterfs_dir_t)bh->dirh);
+ } else if (bh->type == BOOSTER_POSIX_DIR) {
+ gf_log ("booster", GF_LOG_TRACE, "readdir on posix");
+ if (real_readdir == NULL) {
+ errno = ENOSYS;
+ dirp = NULL;
+ goto out;
+ }
+
+ dirp = real_readdir64 ((DIR *)bh->dirh);
+ } else {
+ dirp = NULL;
+ errno = EINVAL;
+ }
+
+out:
+ return dirp;
+}
+
int
closedir (DIR *dh)
{
@@ -2696,6 +2735,7 @@ booster_lib_init (void)
RESOLVE (realpath);
RESOLVE (opendir);
RESOLVE (readdir);
+ RESOLVE (readdir64);
RESOLVE (closedir);
RESOLVE (__xstat);
RESOLVE (__xstat64);