From: Tobias Burnus Date: Fri, 21 Jun 2013 21:24:59 +0000 (+0200) Subject: trans-array.c (gfc_alloc_allocatable_for_assignment): Allocate at least one byte. X-Git-Tag: releases/gcc-4.9.0~5284 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=6f556b07c95e830c322c1ba5ffaa2bbdaab51423;p=thirdparty%2Fgcc.git trans-array.c (gfc_alloc_allocatable_for_assignment): Allocate at least one byte. 2013-06-21 Tobias Burnus * trans-array.c (gfc_alloc_allocatable_for_assignment): Allocate at least one byte. * trans-expr.c (alloc_scalar_allocatable_for_assignment): Ditto. 2013-06-21 Tobias Burnus * gfortran.dg/realloc_on_assign_18.f90: New. From-SVN: r200320 --- diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 0ae3f37bc6b3..8e4b7a16bcb2 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,9 @@ +2013-06-21 Tobias Burnus + + * trans-array.c (gfc_alloc_allocatable_for_assignment): Allocate + at least one byte. + * trans-expr.c (alloc_scalar_allocatable_for_assignment): Ditto. + 2013-06-20 Tobias Burnus * resolve.c (get_temp_from_expr): Don't set FL_VARIABLE twice. diff --git a/gcc/fortran/trans-array.c b/gcc/fortran/trans-array.c index a4321cc3e26b..dc9637ae2f8d 100644 --- a/gcc/fortran/trans-array.c +++ b/gcc/fortran/trans-array.c @@ -8209,6 +8209,8 @@ gfc_alloc_allocatable_for_assignment (gfc_loopinfo *loop, gfc_array_index_type, tmp, size2); size2 = fold_convert (size_type_node, size2); + size2 = fold_build2_loc (input_location, MAX_EXPR, size_type_node, + size2, size_one_node); size2 = gfc_evaluate_now (size2, &fblock); /* Realloc expression. Note that the scalarizer uses desc.data diff --git a/gcc/fortran/trans-expr.c b/gcc/fortran/trans-expr.c index bd8886cdf550..56dc766b99cf 100644 --- a/gcc/fortran/trans-expr.c +++ b/gcc/fortran/trans-expr.c @@ -7574,6 +7574,9 @@ alloc_scalar_allocatable_for_assignment (stmtblock_t *block, size_in_bytes = size; } + size_in_bytes = fold_build2_loc (input_location, MAX_EXPR, size_type_node, + size_in_bytes, size_one_node); + if (expr1->ts.type == BT_DERIVED && expr1->ts.u.derived->attr.alloc_comp) { tmp = build_call_expr_loc (input_location, diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 9c3fe0efa14c..aca407482b3c 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2013-06-21 Tobias Burnus + + * gfortran.dg/realloc_on_assign_18.f90: New. + 2013-06-21 Balaji V. Iyer * c-c++-common/cilk-plus/AN/array_test1.c: Make this an execution test. diff --git a/gcc/testsuite/gfortran.dg/realloc_on_assign_18.f90 b/gcc/testsuite/gfortran.dg/realloc_on_assign_18.f90 new file mode 100644 index 000000000000..d1743551e368 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/realloc_on_assign_18.f90 @@ -0,0 +1,20 @@ +! { dg-do compile } +! { dg-options "-fdump-tree-original" } +! +! Ensure that for zero-sized array, nonzero memory is allocated +! +type t +end type t + +type(t), allocatable :: x, y(:) + +x = t() +y = [ t :: ] + +if (.not. allocated (x)) call abort () +if (.not. allocated (y)) call abort () +end + +! { dg-final { scan-tree-dump "x = \\(struct t .\\) __builtin_malloc \\(1\\);" "original" } } +! { dg-final { scan-tree-dump "y.data = \\(void . restrict\\) __builtin_malloc \\(1\\);" "original" } } +! { dg-final { cleanup-tree-dump "original" } }