From 7348aa7faf2ccbea2aae6726b2131fe02fc75cd4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fran=C3=A7ois-Xavier=20Coudert?= Date: Sun, 4 Mar 2007 08:10:25 +0000 Subject: [PATCH] re PR target/30406 ([4.1 only] ICE in LOGICAL(8) functions) PR target/30406 * config/rs6000/rs6000.c (rs6000_function_value): Look at bit size instead of precision. * gfortran.dg/logical_3.f90: New test. From-SVN: r122523 --- gcc/ChangeLog | 6 ++++++ gcc/config/rs6000/rs6000.c | 6 ++---- gcc/testsuite/ChangeLog | 5 +++++ gcc/testsuite/gfortran.dg/logical_3.f90 | 10 ++++++++++ 4 files changed, 23 insertions(+), 4 deletions(-) create mode 100644 gcc/testsuite/gfortran.dg/logical_3.f90 diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 2c9edd2c77c..67eb439ada9 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2007-03-04 Andrew Pinski + + PR target/30406 + * config/rs6000/rs6000.c (rs6000_function_value): Look at bit size + instead of precision. + 2007-03-04 Roman Zippel Nathan Sidwell diff --git a/gcc/config/rs6000/rs6000.c b/gcc/config/rs6000/rs6000.c index f21d5f1d7c3..fd1b8358a9b 100644 --- a/gcc/config/rs6000/rs6000.c +++ b/gcc/config/rs6000/rs6000.c @@ -20562,12 +20562,10 @@ rs6000_function_value (tree valtype, tree func ATTRIBUTE_UNUSED) GEN_INT (12)))); } - if ((INTEGRAL_TYPE_P (valtype) - && TYPE_PRECISION (valtype) < BITS_PER_WORD) + mode = TYPE_MODE (valtype); + if ((INTEGRAL_TYPE_P (valtype) && GET_MODE_BITSIZE (mode) < BITS_PER_WORD) || POINTER_TYPE_P (valtype)) mode = TARGET_32BIT ? SImode : DImode; - else - mode = TYPE_MODE (valtype); if (DECIMAL_FLOAT_MODE_P (mode)) { diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 309ea4ac6e9..5b717af41db 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2007-03-04 Francois-Xavier Coudert + + PR target/30406 + * gfortran.dg/logical_3.f90: New test. + 2007-03-04 Thomas Koenig PR libfortran/30981 diff --git a/gcc/testsuite/gfortran.dg/logical_3.f90 b/gcc/testsuite/gfortran.dg/logical_3.f90 new file mode 100644 index 00000000000..f4d069e9a4c --- /dev/null +++ b/gcc/testsuite/gfortran.dg/logical_3.f90 @@ -0,0 +1,10 @@ +! { dg-do compile } +! This checks the fix for PR30406. +! +! Contributed by Francois-Xavier Coudert +!=============================================================== + +function f() + logical(8) :: f + f = .false._8 +end function f