aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHarald Anlauf <anlauf@gmx.de>2020-05-27 21:20:24 +0200
committerHarald Anlauf <anlauf@gmx.de>2020-05-27 21:20:24 +0200
commitc949ec9c4e88d2ff6dbd5b179abddf3703129577 (patch)
tree750dea8cbb687de15f40272d727eae1e5eeec402
parent7d014acc1ea263df7ed44aa6cb7f75bb8e512aed (diff)
downloadgcc-c949ec9c4e88d2ff6dbd5b179abddf3703129577.zip
gcc-c949ec9c4e88d2ff6dbd5b179abddf3703129577.tar.gz
gcc-c949ec9c4e88d2ff6dbd5b179abddf3703129577.tar.bz2
PR fortran/95090 - ICE: identifier overflow
For long module name, derive type and component name, the generated name-mangled symbol did not fit into a buffer when coarrays were enabled. Provide sufficiently large temporary. 2020-05-27 Harald Anlauf <anlauf@gmx.de> gcc/fortran/ PR fortran/95090 * iresolve.c (gfc_get_string): Enlarge temporary for name-mangling. gcc/testsuite/ PR fortran/95090 * gfortran.dg/pr95090.f90: New test.
-rw-r--r--gcc/fortran/iresolve.c3
-rw-r--r--gcc/testsuite/gfortran.dg/pr95090.f9019
2 files changed, 21 insertions, 1 deletions
diff --git a/gcc/fortran/iresolve.c b/gcc/fortran/iresolve.c
index 7ecb659..df4f226 100644
--- a/gcc/fortran/iresolve.c
+++ b/gcc/fortran/iresolve.c
@@ -47,7 +47,8 @@ along with GCC; see the file COPYING3. If not see
const char *
gfc_get_string (const char *format, ...)
{
- char temp_name[128];
+ /* Provide sufficient space to hold "_F.caf_token__symbol_MOD_symbol". */
+ char temp_name[14 + GFC_MAX_SYMBOL_LEN + 5 + GFC_MAX_SYMBOL_LEN + 1];
const char *str;
va_list ap;
tree ident;
diff --git a/gcc/testsuite/gfortran.dg/pr95090.f90 b/gcc/testsuite/gfortran.dg/pr95090.f90
new file mode 100644
index 0000000..ec77802
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/pr95090.f90
@@ -0,0 +1,19 @@
+! { dg-do compile }
+! { dg-options "-fcoarray=lib -fsecond-underscore" }
+! PR fortran/95090 - ICE: identifier overflow
+
+module m2345678901234567890123456789012345678901234567890123456789_123
+ type t2345678901234567890123456789012345678901234567890123456789_123 &
+ (n2345678901234567890123456789012345678901234567890123456789_123)
+ integer, len :: n2345678901234567890123456789012345678901234567890123456789_123 = 8
+ end type
+ integer :: a2345678901234567890123456789012345678901234567890123456789_123
+ integer :: b2345678901234567890123456789012345678901234567890123456789_123(3)[*]
+ data b2345678901234567890123456789012345678901234567890123456789_123 /1,2,3/
+contains
+ subroutine s2345678901234567890123456789012345678901234567890123456789_123
+ type(t2345678901234567890123456789012345678901234567890123456789_123 &
+ (n2345678901234567890123456789012345678901234567890123456789_123)) :: &
+ z2345678901234567890123456789012345678901234567890123456789_123
+ end
+end