diff options
| author | Krutika Dhananjay <kdhananj@redhat.com> | 2019-09-12 11:07:10 +0530 | 
|---|---|---|
| committer | Rinku Kothiya <rkothiya@redhat.com> | 2020-07-13 06:43:52 +0000 | 
| commit | c5159b8da1462a8d56188bbec48be95b742a4709 (patch) | |
| tree | 00c467c2e43d07acd6f02caeecd143e186748320 | |
| parent | 328f909ca81274843fba76e82f96712998d02b66 (diff) | |
features/shard: Convert shard block indices to uint64
This patch fixes a crash in FOPs that operate on really large sharded
files where number of participant shards could sometimes exceed
signed int32 max.
The patch also adds GF_ASSERTs to ensure that number of participating
shards is always greater than 0 for files that do have more than one
shard.
Change-Id: I354de58796f350eb1aa42fcdf8092ca2e69ccbb6
Fixes: #1348
Signed-off-by: Krutika Dhananjay <kdhananj@redhat.com>
(cherry picked from commit cdf01cc47eb2efb427b5855732d9607eec2abc8a)
| -rw-r--r-- | xlators/features/shard/src/shard.c | 11 | ||||
| -rw-r--r-- | xlators/features/shard/src/shard.h | 6 | 
2 files changed, 10 insertions, 7 deletions
diff --git a/xlators/features/shard/src/shard.c b/xlators/features/shard/src/shard.c index 2c141c537b9..c11dd819578 100644 --- a/xlators/features/shard/src/shard.c +++ b/xlators/features/shard/src/shard.c @@ -2018,8 +2018,8 @@ shard_truncate_last_shard(call_frame_t *frame, xlator_t *this, inode_t *inode)       */      if (!inode) {          gf_msg_debug(this->name, 0, -                     "Last shard to be truncated absent in backend: %d of " -                     "gfid %s. Directly proceeding to update file size", +                     "Last shard to be truncated absent in backend: %" PRIu64 +                     " of gfid %s. Directly proceeding to update file size",                       local->first_block, uuid_utoa(local->loc.inode->gfid));          shard_update_file_size(frame, this, NULL, &local->loc,                                 shard_post_update_size_truncate_handler); @@ -2577,6 +2577,7 @@ shard_truncate_begin(call_frame_t *frame, xlator_t *this)                                            local->block_size);      local->num_blocks = local->last_block - local->first_block + 1; +    GF_ASSERT(local->num_blocks > 0);      local->resolver_base_inode = (local->fop == GF_FOP_TRUNCATE)                                       ? local->loc.inode                                       : local->fd->inode; @@ -5153,6 +5154,7 @@ shard_post_lookup_readv_handler(call_frame_t *frame, xlator_t *this)                                            local->block_size);      local->num_blocks = local->last_block - local->first_block + 1; +    GF_ASSERT(local->num_blocks > 0);      local->resolver_base_inode = local->loc.inode;      local->inode_list = GF_CALLOC(local->num_blocks, sizeof(inode_t *), @@ -5643,6 +5645,7 @@ shard_common_inode_write_post_lookup_handler(call_frame_t *frame,      local->last_block = get_highest_block(local->offset, local->total_size,                                            local->block_size);      local->num_blocks = local->last_block - local->first_block + 1; +    GF_ASSERT(local->num_blocks > 0);      local->inode_list = GF_CALLOC(local->num_blocks, sizeof(inode_t *),                                    gf_shard_mt_inode_list);      if (!local->inode_list) { @@ -5651,9 +5654,9 @@ shard_common_inode_write_post_lookup_handler(call_frame_t *frame,      }      gf_msg_trace(this->name, 0, -                 "%s: gfid=%s first_block=%" PRIu32 +                 "%s: gfid=%s first_block=%" PRIu64                   " " -                 "last_block=%" PRIu32 " num_blocks=%" PRIu32 " offset=%" PRId64 +                 "last_block=%" PRIu64 " num_blocks=%" PRIu64 " offset=%" PRId64                   " total_size=%zu flags=%" PRId32 "",                   gf_fop_list[local->fop],                   uuid_utoa(local->resolver_base_inode->gfid), diff --git a/xlators/features/shard/src/shard.h b/xlators/features/shard/src/shard.h index 17214177882..4fe181b64d5 100644 --- a/xlators/features/shard/src/shard.h +++ b/xlators/features/shard/src/shard.h @@ -254,9 +254,9 @@ typedef int32_t (*shard_post_update_size_fop_handler_t)(call_frame_t *frame,  typedef struct shard_local {      int op_ret;      int op_errno; -    int first_block; -    int last_block; -    int num_blocks; +    uint64_t first_block; +    uint64_t last_block; +    uint64_t num_blocks;      int call_count;      int eexist_count;      int create_count;  | 
