From: Richard Kenner Date: Fri, 20 Oct 2000 17:51:52 +0000 (+0000) Subject: fold-const.c (force_fit_type): Unsigned values can overflow if they are sizetype. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=444751385724c1ed44e29047bfd96bcdba91f522;p=gcc.git fold-const.c (force_fit_type): Unsigned values can overflow if they are sizetype. * fold-const.c (force_fit_type): Unsigned values can overflow if they are sizetype. (int_const_binop): Don't use cache if overflows. * cp/typeck.c (dubious_conversion_warning): Suppress if TYPE_IS_SIZETYPE. From-SVN: r36970 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 5cd78f7f45f..eab623841c2 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +Fri Oct 20 13:33:16 2000 Richard Kenner + + * fold-const.c (force_fit_type): Unsigned values can overflow + if they are sizetype. + (int_const_binop): Don't use cache if overflows. 2000-10-20 Richard Henderson * function.c (locate_and_pad_parm): Zero alignment_pad. diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index cd6fafa7cc1..3c2e244fb90 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,7 @@ +Fri Oct 20 13:54:59 2000 Richard Kenner + + * typeck.c (dubious_conversion_warning): Suppress if TYPE_IS_SIZETYPE. + 2000-10-20 Jeffrey Oldham * decl.c (revert_static_member_fn): Fixed typo. diff --git a/gcc/cp/typeck.c b/gcc/cp/typeck.c index c26580836c8..d72d8e6c00d 100644 --- a/gcc/cp/typeck.c +++ b/gcc/cp/typeck.c @@ -6353,7 +6353,16 @@ dubious_conversion_warnings (type, expr, errtype, fndecl, parmnum) cp_warning ("%s of negative value `%E' to `%T'", errtype, expr, type); } - overflow_warning (expr); + + /* Suppress warning for a sizetype since we never used to issue it. + ??? This needs to be looked at more carefully someday. */ + if (TREE_CODE (expr) == INTEGER_CST + && TREE_CODE (TREE_TYPE (expr)) == INTEGER_TYPE + && TYPE_IS_SIZETYPE (TREE_TYPE (expr))) + TREE_OVERFLOW (expr) = TREE_CONSTANT_OVERFLOW (expr) = 0; + else + overflow_warning (expr); + if (TREE_CONSTANT (expr)) expr = fold (expr); } diff --git a/gcc/fold-const.c b/gcc/fold-const.c index c8b0fd2486d..efd1055b9e2 100644 --- a/gcc/fold-const.c +++ b/gcc/fold-const.c @@ -216,8 +216,11 @@ force_fit_type (t, overflow) TREE_INT_CST_LOW (t) &= ~((unsigned HOST_WIDE_INT) (-1) << prec); } - /* Unsigned types do not suffer sign extension or overflow. */ - if (TREE_UNSIGNED (TREE_TYPE (t))) + /* Unsigned types do not suffer sign extension or overflow unless they + are a sizetype. */ + if (TREE_UNSIGNED (TREE_TYPE (t)) + && ! (TREE_CODE (TREE_TYPE (t)) == INTEGER_TYPE + && TYPE_IS_SIZETYPE (TREE_TYPE (t)))) return overflow; /* If the value's sign bit is set, extend the sign. */ @@ -1604,7 +1607,8 @@ int_const_binop (code, arg1, arg2, notrunc, forsize) abort (); } - if (forsize && hi == 0 && low < 10000) + if (forsize && hi == 0 && low < 10000 + && overflow == 0 && ! TREE_OVERFLOW (arg1) && ! TREE_OVERFLOW (arg2)) return size_int_type_wide (low, TREE_TYPE (arg1)); else {