From da45bca096281c75becbd5c66d69c7e68f150769 Mon Sep 17 00:00:00 2001 From: Ivan Maidanski Date: Thu, 23 Mar 2017 22:44:11 +0300 Subject: [PATCH] Fix static assertion violation in LONG_MULT for 64-bit targets * include/private/gc_pmark.h [MARK_BIT_PER_OBJ] (PUSH_CONTENTS_HDR): Cast displ to unsigned32 when passed to LONG_MULT (it is safe because displ is less than HBLKSIZE). --- include/private/gc_pmark.h | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/include/private/gc_pmark.h b/include/private/gc_pmark.h index 4867fdee..297af965 100644 --- a/include/private/gc_pmark.h +++ b/include/private/gc_pmark.h @@ -294,9 +294,9 @@ GC_INNER mse * GC_signal_mark_stack_overflow(mse *msp); unsigned32 low_prod, high_prod; \ unsigned32 inv_sz = hhdr -> hb_inv_sz; \ ptr_t base = current; \ - LONG_MULT(high_prod, low_prod, displ, inv_sz); \ + LONG_MULT(high_prod, low_prod, (unsigned32)displ, inv_sz); \ /* product is > and within sz_in_bytes of displ * sz_in_bytes * 2**32 */ \ - if (EXPECT(low_prod >> 16 != 0, FALSE)) { \ + if (EXPECT(low_prod >> 16 != 0, FALSE)) { \ /* FIXME: fails if offset is a multiple of HBLKSIZE which becomes 0 */ \ if (inv_sz == LARGE_INV_SZ) { \ size_t obj_displ; \ -- 2.40.0