From: spop Date: Thu, 30 Sep 2010 21:16:25 +0000 (+0000) Subject: Generate in priority signed types for integer constants. X-Git-Tag: upstream/4.9.2~26255 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=be90fd3f09b9f10addce3cdaecea2a16d47b47cd;p=platform%2Fupstream%2Flinaro-gcc.git Generate in priority signed types for integer constants. 2010-07-29 Sebastian Pop * graphite-clast-to-gimple.c (gcc_type_for_interval): Generate in priority signed types. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@164772 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 20fa477..51522af 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,10 @@ 2010-09-30 Sebastian Pop + * graphite-clast-to-gimple.c (gcc_type_for_interval): Generate in + priority signed types. + +2010-09-30 Sebastian Pop + * graphite-clast-to-gimple.c (max_signed_precision_type): Remove the call to lang_hooks.types.type_for_size. Call build_nonstandard_integer_type. diff --git a/gcc/ChangeLog.graphite b/gcc/ChangeLog.graphite index dd37363..b469a12 100644 --- a/gcc/ChangeLog.graphite +++ b/gcc/ChangeLog.graphite @@ -1,5 +1,10 @@ 2010-07-29 Sebastian Pop + * graphite-clast-to-gimple.c (gcc_type_for_interval): Generate in + priority signed types. + +2010-07-29 Sebastian Pop + * graphite-clast-to-gimple.c (max_signed_precision_type): Remove the call to lang_hooks.types.type_for_size. Call build_nonstandard_integer_type. diff --git a/gcc/graphite-clast-to-gimple.c b/gcc/graphite-clast-to-gimple.c index 73bd971..88a72f1 100644 --- a/gcc/graphite-clast-to-gimple.c +++ b/gcc/graphite-clast-to-gimple.c @@ -459,9 +459,6 @@ gcc_type_for_interval (mpz_t low, mpz_t up) gcc_assert (mpz_cmp (low, up) <= 0); - if (mpz_sgn (low) < 0) - unsigned_p = false; - prec_up = precision_for_value (up); prec_int = precision_for_interval (low, up); precision = MAX (prec_up, prec_int); @@ -472,6 +469,15 @@ gcc_type_for_interval (mpz_t low, mpz_t up) return integer_type_node; } + if (mpz_sgn (low) <= 0) + unsigned_p = false; + + else if (precision < BITS_PER_WORD) + { + unsigned_p = false; + precision++; + } + mode = smallest_mode_for_size (precision, MODE_INT); precision = GET_MODE_PRECISION (mode); type = build_nonstandard_integer_type (precision, unsigned_p);