diff options
author | Thomas Koenig <tkoenig@gcc.gnu.org> | 2017-12-26 23:29:20 +0000 |
---|---|---|
committer | Thomas Koenig <tkoenig@gcc.gnu.org> | 2017-12-26 23:29:20 +0000 |
commit | 62227a69b33b515058c929ac0dfe75ece9809ece (patch) | |
tree | a6d14470e38ef1c80e447256045a58ba5c0a368b /gcc | |
parent | fa9d9dc25d68f8dfa11377f4f7caa8aa38643efd (diff) | |
download | gcc-62227a69b33b515058c929ac0dfe75ece9809ece.zip gcc-62227a69b33b515058c929ac0dfe75ece9809ece.tar.gz gcc-62227a69b33b515058c929ac0dfe75ece9809ece.tar.bz2 |
re PR fortran/83540 (Invalid code with MATMUL, -fno-realloc-lhs -ffrontend-optimize)
2017-12-26 Thomas Koenig <tkoenig@gcc.gnu.org>
PR fortran/83540
* frontend-passes.c (create_var): If an array to be created
has unknown size and -fno-realloc-lhs is in effect,
return NULL.
2017-12-26 Thomas Koenig <tkoenig@gcc.gnu.org>
PR fortran/83540
* gfortran.dg/inline_matmul_20.f90: New test.
From-SVN: r256003
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/fortran/ChangeLog | 7 | ||||
-rw-r--r-- | gcc/fortran/frontend-passes.c | 5 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/inline_matmul_20.f90 | 14 |
4 files changed, 31 insertions, 0 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index d0cbc37..c28f4fe 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,10 @@ +2017-12-26 Thomas Koenig <tkoenig@gcc.gnu.org> + + PR fortran/83540 + * frontend-passes.c (create_var): If an array to be created + has unknown size and -fno-realloc-lhs is in effect, + return NULL. + 2017-12-22 Bernhard Reutner-Fischer <aldot@gcc.gnu.org> Eric Botcazou <ebotcazou@adacore.com> diff --git a/gcc/fortran/frontend-passes.c b/gcc/fortran/frontend-passes.c index 3382058..7c515f6 100644 --- a/gcc/fortran/frontend-passes.c +++ b/gcc/fortran/frontend-passes.c @@ -720,6 +720,11 @@ create_var (gfc_expr * e, const char *vname) if (e->expr_type == EXPR_CONSTANT || is_fe_temp (e)) return gfc_copy_expr (e); + /* Creation of an array of unknown size requires realloc on assignment. + If that is not possible, just return NULL. */ + if (flag_realloc_lhs == 0 && e->rank > 0 && e->shape == NULL) + return NULL; + ns = insert_block (); if (vname) diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index e43e9ed..14e8e3f 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2017-12-26 Thomas Koenig <tkoenig@gcc.gnu.org> + + PR fortran/83540 + * gfortran.dg/inline_matmul_20.f90: New test. + 2017-12-26 Tom de Vries <tom@codesourcery.com> * c-c++-common/unroll-5.c: Use relative line number. diff --git a/gcc/testsuite/gfortran.dg/inline_matmul_20.f90 b/gcc/testsuite/gfortran.dg/inline_matmul_20.f90 new file mode 100644 index 0000000..0f8728a --- /dev/null +++ b/gcc/testsuite/gfortran.dg/inline_matmul_20.f90 @@ -0,0 +1,14 @@ +! { dg-do run } +! { dg-additional-options "-fno-realloc-lhs -ffrontend-optimize" } +! This used to segfault at runtime. +! Original test case by Harald Anlauf. +program gfcbug142 + implicit none + real, allocatable :: b(:,:) + integer :: n = 5 + character(len=20) :: line + allocate (b(n,n)) + call random_number (b) + write (unit=line,fmt='(2I5)') shape (matmul (b, transpose (b))) + if (line /= ' 5 5') call abort +end program gfcbug142 |