From aa830baff1650a2f56fafd0f0be869217120aa3c Mon Sep 17 00:00:00 2001 From: Richard Kenner Date: Tue, 13 Apr 1993 17:16:37 -0400 Subject: [PATCH] (size_int): NUMBER is unsigned so don't test for negative. (optimize_bit_field_compare, all_ones_mask_p): Add missing last arg to force_fit_type call. From-SVN: r4138 --- gcc/fold-const.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/gcc/fold-const.c b/gcc/fold-const.c index a7994aead79..d40e9c8253a 100644 --- a/gcc/fold-const.c +++ b/gcc/fold-const.c @@ -1437,10 +1437,10 @@ size_int (number) /* Type-size nodes already made for small sizes. */ static tree size_table[2*HOST_BITS_PER_WIDE_INT + 1]; - if (number >= 0 && number < 2*HOST_BITS_PER_WIDE_INT + 1 + if (number < 2*HOST_BITS_PER_WIDE_INT + 1 && size_table[number] != 0) return size_table[number]; - if (number >= 0 && number < 2*HOST_BITS_PER_WIDE_INT + 1) + if (number < 2*HOST_BITS_PER_WIDE_INT + 1) { push_obstacks_nochange (); /* Make this a permanent node. */ @@ -2309,7 +2309,7 @@ optimize_bit_field_compare (code, compare_type, lhs, rhs) /* Make the mask to be used against the extracted field. */ mask = build_int_2 (~0, ~0); TREE_TYPE (mask) = unsigned_type; - force_fit_type (mask); + force_fit_type (mask, 0); mask = convert (unsigned_type, mask); mask = const_binop (LSHIFT_EXPR, mask, size_int (lnbitsize - lbitsize), 0); mask = const_binop (RSHIFT_EXPR, mask, @@ -2471,7 +2471,7 @@ all_ones_mask_p (mask, size) tmask = build_int_2 (~0, ~0); TREE_TYPE (tmask) = signed_type (type); - force_fit_type (tmask); + force_fit_type (tmask, 0); return operand_equal_p (mask, const_binop (RSHIFT_EXPR,