aboutsummaryrefslogtreecommitdiff
path: root/gcc/fortran/iresolve.c
diff options
context:
space:
mode:
authorHarald Anlauf <anlauf@gmx.de>2020-06-24 21:03:47 +0200
committerHarald Anlauf <anlauf@gmx.de>2020-06-24 21:03:47 +0200
commita16d0924f18046704ef9a4b6d9593718594677f1 (patch)
tree92e77d79d3d32e20bf4026d9d4a3cb9a3bbaf245 /gcc/fortran/iresolve.c
parentc78907d514d65483c7ddfb4cb1f5c57f23da73d9 (diff)
downloadgcc-a16d0924f18046704ef9a4b6d9593718594677f1.zip
gcc-a16d0924f18046704ef9a4b6d9593718594677f1.tar.gz
gcc-a16d0924f18046704ef9a4b6d9593718594677f1.tar.bz2
PR fortran/95827 - Buffer overflows with submodules and coarrays
With submodules and coarrays, name mangling results in long internal symbols. Enlarge internal buffer. gcc/fortran/ PR fortran/95827 * iresolve.c (gfc_get_string): Enlarge internal buffer used in generating the mangled name.
Diffstat (limited to 'gcc/fortran/iresolve.c')
-rw-r--r--gcc/fortran/iresolve.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/gcc/fortran/iresolve.c b/gcc/fortran/iresolve.c
index aa9bb32..7376961 100644
--- a/gcc/fortran/iresolve.c
+++ b/gcc/fortran/iresolve.c
@@ -47,8 +47,8 @@ along with GCC; see the file COPYING3. If not see
const char *
gfc_get_string (const char *format, ...)
{
- /* Provide sufficient space to hold "_F.symbol.symbol_MOD_symbol". */
- char temp_name[4 + 2*GFC_MAX_SYMBOL_LEN + 5 + GFC_MAX_SYMBOL_LEN + 1];
+ /* Provide sufficient space for "_F.caf_token__symbol.symbol_MOD_symbol". */
+ char temp_name[15 + 2*GFC_MAX_SYMBOL_LEN + 5 + GFC_MAX_SYMBOL_LEN + 1];
const char *str;
va_list ap;
tree ident;