diff options
author | Krutika Dhananjay <kdhananj@redhat.com> | 2015-06-24 08:02:51 +0530 |
---|---|---|
committer | Pranith Kumar Karampuri <pkarampu@redhat.com> | 2015-06-25 19:36:41 -0700 |
commit | 7a99dacc0eb5c31ba2d95615f4fe787c03a311df (patch) | |
tree | 7e0b69de9b11a0d868847be5ed3b123f46467f84 /libglusterfs/src | |
parent | 90f5a6cd669660785213a187c9fa7a587cd15257 (diff) |
cluster/afr: Pick gfid from poststat during fresh lookup for read child calculation
Backport of: http://review.gluster.org/11373
Change-Id: I3ddc70cb0e7dbd1ef8adb352393b5ec16464fc94
BUG: 1212842
Signed-off-by: Krutika Dhananjay <kdhananj@redhat.com>
Reviewed-on: http://review.gluster.org/11391
Tested-by: NetBSD Build System <jenkins@build.gluster.org>
Tested-by: Gluster Build System <jenkins@build.gluster.com>
Reviewed-by: Pranith Kumar Karampuri <pkarampu@redhat.com>
Diffstat (limited to 'libglusterfs/src')
-rw-r--r-- | libglusterfs/src/inode.c | 22 | ||||
-rw-r--r-- | libglusterfs/src/inode.h | 3 |
2 files changed, 25 insertions, 0 deletions
diff --git a/libglusterfs/src/inode.c b/libglusterfs/src/inode.c index 7c548653ebf..7d3215ed16e 100644 --- a/libglusterfs/src/inode.c +++ b/libglusterfs/src/inode.c @@ -2126,6 +2126,28 @@ inode_ctx_reset0 (inode_t *inode, xlator_t *xlator, uint64_t *value1_p) return ret; } +int +inode_is_linked (inode_t *inode) +{ + int ret = 0; + inode_table_t *table = NULL; + + if (!inode) { + gf_log_callingfn (THIS->name, GF_LOG_WARNING, + "inode not found"); + return 0; + } + + table = inode->table; + + pthread_mutex_lock (&table->lock); + { + ret = __is_inode_hashed (inode); + } + pthread_mutex_unlock (&table->lock); + + return ret; +} void inode_dump (inode_t *inode, char *prefix) diff --git a/libglusterfs/src/inode.h b/libglusterfs/src/inode.h index 50815599347..474dc3992fc 100644 --- a/libglusterfs/src/inode.h +++ b/libglusterfs/src/inode.h @@ -269,4 +269,7 @@ inode_table_set_lru_limit (inode_table_t *table, uint32_t lru_limit); void inode_ctx_merge (fd_t *fd, inode_t *inode, inode_t *linked_inode); +int +inode_is_linked (inode_t *inode); + #endif /* _INODE_H */ |