diff options
author | Alex Elder <elder@inktank.com> | 2012-08-24 00:22:06 -0400 |
---|---|---|
committer | Alex Elder <elder@inktank.com> | 2012-10-01 15:30:49 -0400 |
commit | 58c17b0e1b2278824aedc5d1201f6a43a38d6a48 (patch) | |
tree | a924fc7450e712bec4ca519d6d8bf8314cb7b3f6 /drivers/block/rbd.c | |
parent | 1f7ba3311530993801d6877889efff0382bcd641 (diff) |
rbd: don't over-allocate space for object prefix
In rbd_header_from_disk() the object prefix buffer is sized based on
the maximum size it's block_name equivalent on disk could be.
Instead, only allocate enough to hold null-terminated string from
the on-disk header--or the maximum size of no NUL is found.
Signed-off-by: Alex Elder <elder@inktank.com>
Reviewed-by: Yehuda Sadeh <yehuda@inktank.com>
Diffstat (limited to 'drivers/block/rbd.c')
-rw-r--r-- | drivers/block/rbd.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/drivers/block/rbd.c b/drivers/block/rbd.c index 15bd3ecbcf34..a27167942a92 100644 --- a/drivers/block/rbd.c +++ b/drivers/block/rbd.c | |||
@@ -519,18 +519,19 @@ static int rbd_header_from_disk(struct rbd_image_header *header, | |||
519 | struct rbd_image_header_ondisk *ondisk) | 519 | struct rbd_image_header_ondisk *ondisk) |
520 | { | 520 | { |
521 | u32 snap_count; | 521 | u32 snap_count; |
522 | size_t len; | ||
522 | size_t size; | 523 | size_t size; |
523 | 524 | ||
524 | memset(header, 0, sizeof (*header)); | 525 | memset(header, 0, sizeof (*header)); |
525 | 526 | ||
526 | snap_count = le32_to_cpu(ondisk->snap_count); | 527 | snap_count = le32_to_cpu(ondisk->snap_count); |
527 | 528 | ||
528 | size = sizeof (ondisk->object_prefix) + 1; | 529 | len = strnlen(ondisk->object_prefix, sizeof (ondisk->object_prefix)); |
529 | header->object_prefix = kmalloc(size, GFP_KERNEL); | 530 | header->object_prefix = kmalloc(len + 1, GFP_KERNEL); |
530 | if (!header->object_prefix) | 531 | if (!header->object_prefix) |
531 | return -ENOMEM; | 532 | return -ENOMEM; |
532 | memcpy(header->object_prefix, ondisk->object_prefix, size - 1); | 533 | memcpy(header->object_prefix, ondisk->object_prefix, len); |
533 | header->object_prefix[size - 1] = '\0'; | 534 | header->object_prefix[len] = '\0'; |
534 | 535 | ||
535 | if (snap_count) { | 536 | if (snap_count) { |
536 | header->snap_names_len = le64_to_cpu(ondisk->snap_names_len); | 537 | header->snap_names_len = le64_to_cpu(ondisk->snap_names_len); |