From 1a56f15b0fe047dfd85fa1a7aaddcc8504e403a6 Mon Sep 17 00:00:00 2001 From: Karel Zak Date: Wed, 22 May 2019 17:42:48 +0200 Subject: libfdisk: (sgi) improve checksum calculation [-Waddress-of-packed-member] Let's keep compilers and static analyzers happy. The idea is to use memcpy() to copy from buffer to variable and use all label as unsigned char rather than vectorize by uint32_t. Signed-off-by: Karel Zak --- include/pt-sgi.h | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) (limited to 'include') diff --git a/include/pt-sgi.h b/include/pt-sgi.h index 547b37a87..5d6b68f13 100644 --- a/include/pt-sgi.h +++ b/include/pt-sgi.h @@ -93,15 +93,20 @@ struct sgi_disklabel { static inline uint32_t sgi_pt_checksum(struct sgi_disklabel *label) { - int i; - uint32_t *ptr = (uint32_t *) label; + int count; uint32_t sum = 0; + unsigned char *ptr = (unsigned char *) label; - i = sizeof(*label) / sizeof(*ptr); + count = sizeof(*label) / sizeof(uint32_t); + ptr += sizeof(uint32_t) * (count - 1); - while (i) { - i--; - sum -= be32_to_cpu(ptr[i]); + while (count--) { + uint32_t val; + + memcpy(&val, ptr, sizeof(uint32_t)); + sum -= be32_to_cpu(val); + + ptr -= sizeof(uint32_t); } return sum; -- cgit v1.2.3-55-g7522