https://gcc.gnu.org/g:01bd6e39c64f83c5fa09f5ef0af90164b2dbd529

commit 01bd6e39c64f83c5fa09f5ef0af90164b2dbd529
Author: Mikael Morin <mik...@gcc.gnu.org>
Date:   Mon May 19 16:41:03 2025 +0200

    Correction assumed_type_2

Diff:
---
 gcc/fortran/trans.cc                         | 11 +++++++++++
 gcc/testsuite/gfortran.dg/assumed_type_2.f90 | 10 +++++-----
 2 files changed, 16 insertions(+), 5 deletions(-)

diff --git a/gcc/fortran/trans.cc b/gcc/fortran/trans.cc
index 53283264a609..a4793d602435 100644
--- a/gcc/fortran/trans.cc
+++ b/gcc/fortran/trans.cc
@@ -423,6 +423,17 @@ gfc_build_array_ref (tree type, tree base, tree index, 
bool non_negative_offset,
 
   if (non_negative_offset)
     {
+      tree base_type = TREE_TYPE (base);
+      if (TREE_CODE (base_type) == ARRAY_TYPE
+         && tree_int_cst_equal (min_idx,
+                                TYPE_MIN_VALUE (TYPE_DOMAIN (base_type)))
+         && tree_int_cst_equal (spacing_bytes,
+                                TYPE_SIZE_UNIT (TREE_TYPE (base_type))))
+       {
+         min_idx = NULL_TREE;
+         spacing_bytes = NULL_TREE;
+       }
+
       tree spacing;
       if (spacing_bytes == NULL_TREE)
        spacing = NULL_TREE;
diff --git a/gcc/testsuite/gfortran.dg/assumed_type_2.f90 
b/gcc/testsuite/gfortran.dg/assumed_type_2.f90
index 5d3cd7eaece9..e33cbae341fe 100644
--- a/gcc/testsuite/gfortran.dg/assumed_type_2.f90
+++ b/gcc/testsuite/gfortran.dg/assumed_type_2.f90
@@ -147,22 +147,22 @@ end
 
 ! { dg-final { scan-tree-dump-times "sub_scalar .&scalar_int," 1 "original" } }
 ! { dg-final { scan-tree-dump-times "sub_scalar .&scalar_t1," 1 "original" } }
-! { dg-final { scan-tree-dump-times "sub_scalar .&array_int.1.," 1 "original" 
} }
+! { dg-final { scan-tree-dump-times {sub_scalar .&array_int.1.(?:{lb: 0 sz: 
4})?,} 1 "original" } }
 ! { dg-final { scan-tree-dump-times "sub_scalar .&scalar_t1," 1 "original" } }
 
 ! { dg-final { scan-tree-dump-times "sub_scalar .&\\(.\\(real.kind=4..0:. . 
restrict\\) array_real_alloc.data" 1 "original" } }
-! { dg-final { scan-tree-dump-times "sub_scalar .\\(character.kind=1..1:1. 
.\\) .array_char_ptr.data" 1 "original" } }
+! { dg-final { scan-tree-dump-times {sub_scalar .\(character.kind=1..1:1. .\) 
array_char_ptr.data \+} 1 "original" } }
 ! { dg-final { scan-tree-dump-times "sub_scalar .&\\(.\\(struct t2.0:. . 
restrict\\) array_t2_alloc.data" 1 "original" } }
-! { dg-final { scan-tree-dump-times "sub_scalar .\\(struct t3 .\\) 
.array_t3_ptr.data" 1 "original" } }
+! { dg-final { scan-tree-dump-times {sub_scalar .\(struct t3 .\) 
array_t3_ptr.data \+} 1 "original" } }
 ! { dg-final { scan-tree-dump-times "sub_scalar .\\(struct t1 .\\) 
array_class_t1_alloc._data.data" 1 "original" } }
-! { dg-final { scan-tree-dump-times "sub_scalar .\\(struct t1 .\\) 
\\(array_class_t1_ptr._data.dat" 1 "original" } }
+! { dg-final { scan-tree-dump-times {sub_scalar .\(struct t1 .\) 
array_class_t1_ptr._data.data \+} 1 "original" } }
 
 ! { dg-final { scan-tree-dump-times "sub_array_assumed \\(D" 4 "original" } }
 ! { dg-final { scan-tree-dump-times " = _gfortran_internal_pack \\(&parm" 1 
"original" } }
 ! { dg-final { scan-tree-dump-times "sub_array_assumed \\(&array_int\\)" 1 
"original" } }
 ! { dg-final { scan-tree-dump-times "sub_array_assumed 
\\(\\(real\\(kind=4\\).0:. . restrict\\) array_real_alloc.data" 1 "original" } }
 ! { dg-final { scan-tree-dump-times " = _gfortran_internal_pack 
\\(&array_char_ptr\\);" 1 "original" } }
-! { dg-final { scan-tree-dump-times "\\.data = \\(void .\\) &array_t1.0.;" 1 
"original" } }
+! { dg-final { scan-tree-dump-times {\.data = \(void .\) &array_t1.0.(?:{lb: 0 
sz: 4})?;} 1 "original" } }
 ! { dg-final { scan-tree-dump-times "sub_array_assumed \\(\\(struct t1.0:. 
.\\) parm" 1 "original" } }
 ! { dg-final { scan-tree-dump-times "sub_array_assumed \\(\\(struct t2.0:. . 
restrict\\) array_t2_alloc.data\\);" 1 "original" } }
 ! { dg-final { scan-tree-dump-times "sub_array_assumed \\(\\(struct t1.0:. . 
restrict\\) array_class_t1_alloc._data.data\\);" 1 "original" } }

Reply via email to