From b7c44c8fd26941ef5aa419fa3862b5a2c4e02c13 Mon Sep 17 00:00:00 2001 From: Jerry DeLisle Date: Wed, 29 Nov 2017 03:07:43 +0000 Subject: [PATCH] re PR libfortran/83168 (FAIL: gfortran.dg/fmt_f0_2.f90 with a sanitized libgfortran) 2017-11-28 Jerry DeLisle PR libgfortran/83168 * io/write.c (select_string): Bump size by one to avoid overrun. From-SVN: r255225 --- libgfortran/ChangeLog | 6 ++++++ libgfortran/io/write.c | 2 +- 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/libgfortran/ChangeLog b/libgfortran/ChangeLog index 6940f79..251e6b4 100644 --- a/libgfortran/ChangeLog +++ b/libgfortran/ChangeLog @@ -1,3 +1,9 @@ +2017-11-28 Jerry DeLisle + + PR libgfortran/83168 + * io/write.c (select_string): Bump size by one to avoid + overrun. + 2017-11-24 Janne Blomqvist PR fortran/36313 diff --git a/libgfortran/io/write.c b/libgfortran/io/write.c index f417202..582d196 100644 --- a/libgfortran/io/write.c +++ b/libgfortran/io/write.c @@ -1552,7 +1552,7 @@ select_string (st_parameter_dt *dtp, const fnode *f, char *buf, size_t *size, int kind) { char *result; - *size = size_from_kind (dtp, f, kind) + f->u.real.d; + *size = size_from_kind (dtp, f, kind) + f->u.real.d + 1; if (*size > BUF_STACK_SZ) result = xmalloc (*size); else -- 2.7.4