diff options
| author | Pranith Kumar K <pkarampu@redhat.com> | 2013-05-22 14:40:22 +0530 | 
|---|---|---|
| committer | Vijay Bellur <vbellur@redhat.com> | 2013-06-06 11:53:39 -0700 | 
| commit | b7ac8e415961c9e203ed3f56b4115b7eb215ab94 (patch) | |
| tree | db71b2c7bfedb31f8762cd63dd1c63f7c04effa0 /libglusterfs | |
| parent | fbdbe06a1df2f983f2ec7a3103db932f40653650 (diff) | |
cluster/afr: Avoid order mismatch in blocking entrylks
Problem:
When taking blocking entrylks, afr orders the entrylks based on
uuid_compare of gfids of parent dirs, if they are equal then it orders
them based on the basenames. While this approach works fine, the
implementation assumes loc->gfids to be populated at the time of
the comparison, but loc may have gfid in loc->inode->gfid instead
of loc->gfid which was leading to order mismatches and dead-locks.
Fix:
Implemented loc_gfid which gives gfid by checking both loc->gfid,
loc->inode->gfid. Used this for ordering the blocking entrylks.
Change-Id: I2743fcaff3d670fbeb6b8e0a496f106a3585dde1
BUG: 965987
Signed-off-by: Pranith Kumar K <pkarampu@redhat.com>
Reviewed-on: http://review.gluster.org/5063
Reviewed-by: Krishnan Parthasarathi <kparthas@redhat.com>
Tested-by: Gluster Build System <jenkins@build.gluster.com>
Reviewed-by: Vijay Bellur <vbellur@redhat.com>
Diffstat (limited to 'libglusterfs')
| -rw-r--r-- | libglusterfs/src/xlator.c | 17 | ||||
| -rw-r--r-- | libglusterfs/src/xlator.h | 1 | 
2 files changed, 18 insertions, 0 deletions
| diff --git a/libglusterfs/src/xlator.c b/libglusterfs/src/xlator.c index 7f29d180a..506724234 100644 --- a/libglusterfs/src/xlator.c +++ b/libglusterfs/src/xlator.c @@ -585,6 +585,23 @@ out:          return ret;  } +void +loc_gfid (loc_t *loc, uuid_t gfid) +{ +        if (!gfid) +                goto out; +        uuid_clear (gfid); + +        if (!loc) +                goto out; +        else if (!uuid_is_null (loc->gfid)) +                uuid_copy (gfid, loc->gfid); +        else if (loc->inode && (!uuid_is_null (loc->inode->gfid))) +                uuid_copy (gfid, loc->inode->gfid); +out: +        return; +} +  int  loc_copy (loc_t *dst, loc_t *src)  { diff --git a/libglusterfs/src/xlator.h b/libglusterfs/src/xlator.h index 1e21b63c5..6271cf7fa 100644 --- a/libglusterfs/src/xlator.h +++ b/libglusterfs/src/xlator.h @@ -873,6 +873,7 @@ int loc_copy (loc_t *dst, loc_t *src);  #define loc_dup(src, dst) loc_copy(dst, src)  void loc_wipe (loc_t *loc);  int loc_path (loc_t *loc, const char *bname); +void loc_gfid (loc_t *loc, uuid_t gfid);  int xlator_mem_acct_init (xlator_t *xl, int num_types);  int is_gf_log_command (xlator_t *trans, const char *name, char *value);  int glusterd_check_log_level (const char *value); | 
