diff options
| author | Raghavendra G <raghavendra@gluster.com> | 2011-01-11 23:31:40 +0000 | 
|---|---|---|
| committer | Anand V. Avati <avati@dev.gluster.com> | 2011-01-11 23:58:42 -0800 | 
| commit | 5368b898fad7264405275adc2092859e3c87c14e (patch) | |
| tree | 35f588805fd0a197a2aa42a28aa02f5f4471e885 /xlators/performance/quick-read/src/quick-read.c | |
| parent | 29b664f062795614417b9348f40503360f9f9c56 (diff) | |
performance/quick-read: Fix unwinding of same frame twice when qr_loc_fill fails.v3.1.2qa4
Signed-off-by: Raghavendra G <raghavendra@gluster.com>
Signed-off-by: Anand V. Avati <avati@dev.gluster.com>
BUG: 2274 (crash in fd_unref)
URL: http://bugs.gluster.com/cgi-bin/bugzilla3/show_bug.cgi?id=2274
Diffstat (limited to 'xlators/performance/quick-read/src/quick-read.c')
| -rw-r--r-- | xlators/performance/quick-read/src/quick-read.c | 64 | 
1 files changed, 22 insertions, 42 deletions
| diff --git a/xlators/performance/quick-read/src/quick-read.c b/xlators/performance/quick-read/src/quick-read.c index b8b799e5c10..9b0afe1f55b 100644 --- a/xlators/performance/quick-read/src/quick-read.c +++ b/xlators/performance/quick-read/src/quick-read.c @@ -1125,10 +1125,8 @@ out:                  if (need_open) {                          op_ret = qr_loc_fill (&loc, fd->inode, path);                          if (op_ret == -1) { -                                need_unwind = 1; -                                op_errno = errno;                                  qr_resume_pending_ops (qr_fd_ctx); -                                goto out; +                                goto ret;                          }                          STACK_WIND (frame, qr_open_cbk, FIRST_CHILD(this), @@ -1145,6 +1143,7 @@ out:          } +ret:          if (vector) {                  GF_FREE (vector);          } @@ -1253,7 +1252,6 @@ qr_writev (call_frame_t *frame, xlator_t *this, fd_t *fd, struct iovec *vector,                  can_wind = 1;          } -out:          if (need_unwind) {                  QR_STACK_UNWIND (writev, frame, op_ret, op_errno, NULL,                                       NULL); @@ -1264,10 +1262,8 @@ out:          } else if (need_open) {                  op_ret = qr_loc_fill (&loc, fd->inode, path);                  if (op_ret == -1) { -                        need_unwind = 1; -                        op_errno = errno;                          qr_resume_pending_ops (qr_fd_ctx); -                        goto out; +                        goto ret;                  }                  STACK_WIND (frame, qr_open_cbk, FIRST_CHILD(this), @@ -1277,6 +1273,7 @@ out:                  qr_loc_wipe (&loc);          } +ret:          return 0;  } @@ -1351,7 +1348,6 @@ qr_fstat (call_frame_t *frame, xlator_t *this, fd_t *fd)                  can_wind = 1;          } -out:          if (need_unwind) {                  QR_STACK_UNWIND (fstat, frame, op_ret, op_errno, NULL);          } else if (can_wind) { @@ -1361,9 +1357,7 @@ out:                  op_ret = qr_loc_fill (&loc, fd->inode, path);                  if (op_ret == -1) {                          qr_resume_pending_ops (qr_fd_ctx); -                        need_unwind = 1; -                        op_errno = errno; -                        goto out; +                        goto ret;                  }                  STACK_WIND (frame, qr_open_cbk, FIRST_CHILD(this), @@ -1373,6 +1367,7 @@ out:                  qr_loc_wipe (&loc);          } +ret:          return 0;  } @@ -1453,7 +1448,6 @@ qr_fsetattr (call_frame_t *frame, xlator_t *this, fd_t *fd,                  can_wind = 1;          } -out:          if (need_unwind) {                  QR_STACK_UNWIND (fsetattr, frame, op_ret, op_errno, NULL,                                       NULL); @@ -1465,9 +1459,7 @@ out:                  op_ret = qr_loc_fill (&loc, fd->inode, path);                  if (op_ret == -1) {                          qr_resume_pending_ops (qr_fd_ctx); -                        need_unwind = 1; -                        op_errno = errno; -                        goto out; +                        goto ret;                  }                  STACK_WIND (frame, qr_open_cbk, FIRST_CHILD(this), @@ -1477,6 +1469,7 @@ out:                  qr_loc_wipe (&loc);          } +ret:          return 0;  } @@ -1554,7 +1547,6 @@ qr_fsetxattr (call_frame_t *frame, xlator_t *this, fd_t *fd, dict_t *dict,                  can_wind = 1;          } -out:          if (need_unwind) {                  QR_STACK_UNWIND (fsetxattr, frame, op_ret, op_errno);          } else if (can_wind) { @@ -1565,9 +1557,7 @@ out:                  op_ret = qr_loc_fill (&loc, fd->inode, path);                  if (op_ret == -1) {                          qr_resume_pending_ops (qr_fd_ctx); -                        op_errno = errno; -                        need_unwind = 1; -                        goto out; +                        goto ret;                  }                  STACK_WIND (frame, qr_open_cbk, FIRST_CHILD(this), @@ -1577,6 +1567,7 @@ out:                  qr_loc_wipe (&loc);          } +ret:          return 0;  } @@ -1658,7 +1649,6 @@ qr_fgetxattr (call_frame_t *frame, xlator_t *this, fd_t *fd, const char *name)                  can_wind = 1;          } -out:          if (need_unwind) {                  QR_STACK_UNWIND (open, frame, op_ret, op_errno, NULL);          } else if (can_wind) { @@ -1667,10 +1657,8 @@ out:          } else if (need_open) {                  op_ret = qr_loc_fill (&loc, fd->inode, path);                  if (op_ret == -1) { -                        need_unwind = 1; -                        op_errno = errno;                          qr_resume_pending_ops (qr_fd_ctx); -                        goto out; +                        goto ret;                  }                  STACK_WIND (frame, qr_open_cbk, FIRST_CHILD(this), @@ -1680,6 +1668,7 @@ out:                  qr_loc_wipe (&loc);          } +ret:          return 0;  } @@ -1831,7 +1820,6 @@ qr_fentrylk (call_frame_t *frame, xlator_t *this, const char *volume, fd_t *fd,                  can_wind = 1;          } -out:          if (need_unwind) {                  QR_STACK_UNWIND (fentrylk, frame, op_ret, op_errno);          } else if (can_wind) { @@ -1841,10 +1829,8 @@ out:          } else if (need_open) {                  op_ret = qr_loc_fill (&loc, fd->inode, path);                  if (op_ret == -1) { -                        need_unwind = 1; -                        op_errno = errno;                          qr_resume_pending_ops (qr_fd_ctx); -                        goto out; +                        goto ret;                  }                  STACK_WIND (frame, qr_open_cbk, FIRST_CHILD(this), @@ -1854,6 +1840,7 @@ out:                  qr_loc_wipe (&loc);          } +ret:          return 0;  } @@ -1933,7 +1920,6 @@ qr_finodelk (call_frame_t *frame, xlator_t *this, const char *volume, fd_t *fd,                  can_wind = 1;          } -out:          if (need_unwind) {                  QR_STACK_UNWIND (finodelk, frame, op_ret, op_errno);          } else if (can_wind) { @@ -1943,10 +1929,8 @@ out:          } else if (need_open) {                  op_ret = qr_loc_fill (&loc, fd->inode, path);                  if (op_ret == -1) { -                        need_unwind = 1; -                        op_errno = errno;                          qr_resume_pending_ops (qr_fd_ctx); -                        goto out; +                        goto ret;                  }                  STACK_WIND (frame, qr_open_cbk, FIRST_CHILD(this), @@ -1956,6 +1940,7 @@ out:                  qr_loc_wipe (&loc);          } +ret:          return 0;  } @@ -2029,7 +2014,6 @@ qr_fsync (call_frame_t *frame, xlator_t *this, fd_t *fd, int32_t flags)                  can_wind = 1;          } -out:          if (need_unwind) {                  QR_STACK_UNWIND (fsync, frame, op_ret, op_errno, NULL,                                       NULL); @@ -2039,10 +2023,8 @@ out:          } else if (need_open) {                  op_ret = qr_loc_fill (&loc, fd->inode, path);                  if (op_ret == -1) { -                        need_unwind = 1; -                        op_errno = errno;                          qr_resume_pending_ops (qr_fd_ctx); -                        goto out; +                        goto ret;                  }                  STACK_WIND (frame, qr_open_cbk, FIRST_CHILD(this), @@ -2052,6 +2034,7 @@ out:                  qr_loc_wipe (&loc);          } +ret:          return 0;  } @@ -2194,10 +2177,8 @@ out:          } else if (need_open) {                  op_ret = qr_loc_fill (&loc, fd->inode, path);                  if (op_ret == -1) { -                        need_unwind = 1; -                        op_errno = errno;                          qr_resume_pending_ops (qr_fd_ctx); -                        goto out; +                        goto ret;                  }                  STACK_WIND (frame, qr_open_cbk, FIRST_CHILD(this), @@ -2207,6 +2188,7 @@ out:                  qr_loc_wipe (&loc);          } +ret:          return 0;  } @@ -2284,7 +2266,6 @@ qr_lk (call_frame_t *frame, xlator_t *this, fd_t *fd, int32_t cmd,                  can_wind = 1;          } -out:          if (need_unwind) {                  QR_STACK_UNWIND (lk, frame, op_ret, op_errno, NULL);          } else if (can_wind) { @@ -2293,10 +2274,8 @@ out:          } else if (need_open) {                  op_ret = qr_loc_fill (&loc, fd->inode, path);                  if (op_ret == -1) { -                        op_errno = errno; -                        need_unwind = 1;                          qr_resume_pending_ops (qr_fd_ctx); -                        goto out; +                        goto ret;                  }                  STACK_WIND (frame, qr_open_cbk, FIRST_CHILD(this), @@ -2306,6 +2285,7 @@ out:                  qr_loc_wipe (&loc);          } +ret:          return 0;  } | 
