From 15a6e0be9bc1c56bd2a0a67c926b01f2f8631ae4 Mon Sep 17 00:00:00 2001 From: vinayak hegde Date: Wed, 11 Nov 2009 07:13:06 +0000 Subject: cluster/stripe: Set local->inode value before referring it. Signed-off-by: Vinayak Hegde Signed-off-by: Anand V. Avati BUG: 362 (GlusterFS crash while doing mkdir in stripe setup) URL: http://bugs.gluster.com/cgi-bin/bugzilla3/show_bug.cgi?id=362 --- xlators/cluster/stripe/src/stripe.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) (limited to 'xlators/cluster/stripe') diff --git a/xlators/cluster/stripe/src/stripe.c b/xlators/cluster/stripe/src/stripe.c index 253d2f8f17f..c2d500e922d 100644 --- a/xlators/cluster/stripe/src/stripe.c +++ b/xlators/cluster/stripe/src/stripe.c @@ -492,7 +492,8 @@ stripe_stack_unwind_inode_cbk (call_frame_t *frame, void *cookie, struct stat *postparent) { int32_t callcnt = 0; - stripe_local_t *local = NULL; + stripe_local_t *local = NULL; + inode_t *local_inode = NULL; local = frame->local; @@ -512,6 +513,8 @@ stripe_stack_unwind_inode_cbk (call_frame_t *frame, void *cookie, if (op_ret >= 0) { local->op_ret = 0; + if (!local->inode) + local->inode = inode_ref (inode); if (!local->post_buf.st_blksize) { local->post_buf = *buf; @@ -558,10 +561,13 @@ stripe_stack_unwind_inode_cbk (call_frame_t *frame, void *cookie, if (local->failed) local->op_ret = -1; + local_inode = local->inode; STACK_UNWIND (frame, local->op_ret, local->op_errno, local->inode, &local->post_buf, &local->pre_parent_buf, &local->post_parent_buf); + if (local_inode) + inode_unref (local_inode); } return 0; -- cgit