From 84a4211850e3d23a9d3a4f3b294752a3b30bc0ff Mon Sep 17 00:00:00 2001 From: Petr Baudis Date: Sun, 20 Feb 2011 07:59:49 -0500 Subject: [PATCH] Fix allocation when handling positional parameters in printf. --- ChangeLog | 8 ++++++++ stdio-common/Makefile | 2 +- stdio-common/bug23.c | 21 +++++++++++++++++++++ stdio-common/vfprintf.c | 5 +++-- 4 files changed, 33 insertions(+), 3 deletions(-) create mode 100644 stdio-common/bug23.c diff --git a/ChangeLog b/ChangeLog index b47a0133f5..77de743015 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,11 @@ +2011-01-27 Petr Baudis + Ulrich Drepper + + * stdio-common/vfprintf.c (vfprintf): Pass correct newlen + to extend_alloca(). + * stdio-common/bug23.c: New file. + * stdio-common/Makefile (tests): Add bug23. + 2010-09-28 Andreas Schwab Ulrich Drepper diff --git a/stdio-common/Makefile b/stdio-common/Makefile index 6aabfb6b54..6c71f1c37f 100644 --- a/stdio-common/Makefile +++ b/stdio-common/Makefile @@ -60,7 +60,7 @@ tests := tstscanf test_rdwr test-popen tstgetln test-fseek \ tst-popen tst-unlockedio tst-fmemopen2 tst-put-error tst-fgets \ tst-fwrite bug16 bug17 tst-swscanf tst-sprintf2 bug18 bug18a \ bug19 bug19a tst-popen2 scanf13 scanf14 scanf15 bug20 bug21 bug22 \ - scanf16 scanf17 tst-setvbuf1 tst-grouping + scanf16 scanf17 tst-setvbuf1 tst-grouping bug23 test-srcs = tst-unbputc tst-printf diff --git a/stdio-common/bug23.c b/stdio-common/bug23.c new file mode 100644 index 0000000000..dcc5428078 --- /dev/null +++ b/stdio-common/bug23.c @@ -0,0 +1,21 @@ +#include +#include + +static char buf[32768]; +static const char expected[] = "\ +\n\ +a\n\ +abbcd55%%%%%%%%%%%%%%%%%%%%%%%%%%\n"; + +static int +do_test (void) +{ + snprintf (buf, sizeof (buf), + "\n%1$s\n" "%1$s" "%2$s" "%2$s" "%3$s" "%4$s" "%5$d" "%5$d" + "%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\n", + "a", "b", "c", "d", 5); + return strcmp (buf, expected) != 0; +} + +#define TEST_FUNCTION do_test () +#include "../test-skeleton.c" diff --git a/stdio-common/vfprintf.c b/stdio-common/vfprintf.c index fc370e8cbc..cfa4c30b78 100644 --- a/stdio-common/vfprintf.c +++ b/stdio-common/vfprintf.c @@ -1,4 +1,4 @@ -/* Copyright (C) 1991-2008, 2009, 2010 Free Software Foundation, Inc. +/* Copyright (C) 1991-2008, 2009, 2010, 2011 Free Software Foundation, Inc. This file is part of the GNU C Library. The GNU C Library is free software; you can redistribute it and/or @@ -1682,7 +1682,8 @@ vfprintf (FILE *s, const CHAR_T *format, va_list ap) { /* Extend the array of format specifiers. */ struct printf_spec *old = specs; - specs = extend_alloca (specs, nspecs_max, 2 * nspecs_max); + specs = extend_alloca (specs, nspecs_max, + 2 * nspecs_max * sizeof (*specs)); /* Copy the old array's elements to the new space. */ memmove (specs, old, nspecs * sizeof (struct printf_spec));