diff options
| author | Amar Tumballi <amar@gluster.com> | 2010-10-12 04:09:35 +0000 | 
|---|---|---|
| committer | Vijay Bellur <vijay@dev.gluster.com> | 2010-10-12 03:04:09 -0700 | 
| commit | 6e6b4b4fd002347ca08691f73e10b961f693d754 (patch) | |
| tree | de58accf862f8a468e52b359054387f046c8a388 /xlators/storage/posix/src/posix.c | |
| parent | b9d6e0c879feb9d86cdadf4072a7ebeb5eb29798 (diff) | |
glusterd-rebalance: if file is open, don't do rebalancev3.1.0
Signed-off-by: Amar Tumballi <amar@gluster.com>
Signed-off-by: Vijay Bellur <vijay@dev.gluster.com>
BUG: 971 (dynamic volume management)
URL: http://bugs.gluster.com/cgi-bin/bugzilla3/show_bug.cgi?id=971
Diffstat (limited to 'xlators/storage/posix/src/posix.c')
| -rw-r--r-- | xlators/storage/posix/src/posix.c | 25 | 
1 files changed, 25 insertions, 0 deletions
| diff --git a/xlators/storage/posix/src/posix.c b/xlators/storage/posix/src/posix.c index fbdc2a13d77..28857b09fdf 100644 --- a/xlators/storage/posix/src/posix.c +++ b/xlators/storage/posix/src/posix.c @@ -3031,6 +3031,22 @@ posix_getxattr (call_frame_t *frame, xlator_t *this,                  goto out;          } +        if (loc->inode && !strcmp (name, GLUSTERFS_OPEN_FD_COUNT)) { +		if (!list_empty (&loc->inode->fd_list)) { +			ret = dict_set_uint32 (dict, (char *)name, 1); +                        if (ret < 0) +                                gf_log (this->name, GF_LOG_WARNING, +                                        "Failed to set dictionary value for %s", +                                        name); +		} else { +			ret = dict_set_uint32 (dict, (char *)name, 0); +                        if (ret < 0) +                                gf_log (this->name, GF_LOG_WARNING, +                                        "Failed to set dictionary value for %s", +                                        name); +		} +                goto done; +        }  	if (loc->inode && IA_ISREG (loc->inode->ia_type) && name &&  	    (strcmp (name, GF_XATTR_PATHINFO_KEY) == 0)) {                  snprintf (host_buf, 1024, "%s:%s", priv->hostname, @@ -3171,6 +3187,15 @@ posix_fgetxattr (call_frame_t *frame, xlator_t *this,                  goto out;          } +        if (!strcmp (name, GLUSTERFS_OPEN_FD_COUNT)) { +                ret = dict_set_uint32 (dict, (char *)name, 1); +                if (ret < 0) +                        gf_log (this->name, GF_LOG_WARNING, +                                "Failed to set dictionary value for %s", +                                name); +                goto done; +        } +          size = sys_flistxattr (_fd, NULL, 0);          if (size == -1) {                  op_errno = errno; | 
