From ad2432dc6831cf4324bb4b78589a87616e6476b4 Mon Sep 17 00:00:00 2001 From: Milan Broz Date: Mon, 17 Oct 2011 13:15:35 +0000 Subject: [PATCH] Fix alignment warning in bitcount calculation for raid segment. --- WHATS_NEW_DM | 1 + libdm/libdm-deptree.c | 8 ++++---- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/WHATS_NEW_DM b/WHATS_NEW_DM index 9de4a3d4f..0c0d93210 100644 --- a/WHATS_NEW_DM +++ b/WHATS_NEW_DM @@ -1,5 +1,6 @@ Version 1.02.68 - ================================== + Fix alignment warning in bitcount calculation for raid segment. Allocate dm_tree structure from dm_tree pool. Update debug logging for _resume_node. Add functions to support thin provisioning target (API unstable). diff --git a/libdm/libdm-deptree.c b/libdm/libdm-deptree.c index af72c4aa7..9cadfc64d 100644 --- a/libdm/libdm-deptree.c +++ b/libdm/libdm-deptree.c @@ -1856,7 +1856,7 @@ static int _raid_emit_segment_line(struct dm_task *dmt, uint32_t major, uint64_t *seg_start, char *params, size_t paramsize) { - uint32_t i, *tmp; + uint32_t i; int param_count = 1; /* mandatory 'chunk size'/'stripe size' arg */ int pos = 0; @@ -1866,9 +1866,9 @@ static int _raid_emit_segment_line(struct dm_task *dmt, uint32_t major, if (seg->region_size) param_count += 2; - tmp = (uint32_t *)(&seg->rebuilds); /* rebuilds is 64-bit */ - param_count += 2 * hweight32(tmp[0]); - param_count += 2 * hweight32(tmp[1]); + /* rebuilds is 64-bit */ + param_count += 2 * hweight32(seg->rebuilds & 0xFFFFFFFF); + param_count += 2 * hweight32(seg->rebuilds >> 32); if ((seg->type == SEG_RAID1) && seg->stripe_size) log_error("WARNING: Ignoring RAID1 stripe size");