From: Chunwei Chen Date: Fri, 22 Jan 2016 20:23:55 +0000 (-0800) Subject: Remove wrong ASSERT in annotate_ecksum X-Git-Tag: zfs-0.7.0-rc1~253 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=093911f1945b5c164a45bb077103283dafdcae0c;p=zfs Remove wrong ASSERT in annotate_ecksum When using large blocks like 1M, there will be more than UINT16_MAX qwords in one block, so this ASSERT would go off. Also, it is possible for the histogram to overflow. We cap them to UINT16_MAX to prevent this. Signed-off-by: Chunwei Chen Signed-off-by: Brian Behlendorf Closes #4257 --- diff --git a/module/zfs/zfs_fm.c b/module/zfs/zfs_fm.c index 7e9c473d3..c7b718000 100644 --- a/module/zfs/zfs_fm.c +++ b/module/zfs/zfs_fm.c @@ -457,7 +457,8 @@ update_histogram(uint64_t value_arg, uint16_t *hist, uint32_t *count) /* We store the bits in big-endian (largest-first) order */ for (i = 0; i < 64; i++) { if (value & (1ull << i)) { - hist[63 - i]++; + if (hist[63 - i] < UINT16_MAX) + hist[63 - i]++; ++bits; } } @@ -615,7 +616,6 @@ annotate_ecksum(nvlist_t *ereport, zio_bad_cksum_t *info, if (badbuf == NULL || goodbuf == NULL) return (eip); - ASSERT3U(nui64s, <=, UINT16_MAX); ASSERT3U(size, ==, nui64s * sizeof (uint64_t)); ASSERT3U(size, <=, SPA_MAXBLOCKSIZE); ASSERT3U(size, <=, UINT32_MAX);