From: rguenth Date: Wed, 26 Oct 2011 11:48:09 +0000 (+0000) Subject: 2011-10-26 Richard Guenther X-Git-Tag: upstream/4.9.2~16768 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=eefcf076ad584a4dc4ea5a9b030fbcef2d7874dc;p=platform%2Fupstream%2Flinaro-gcc.git 2011-10-26 Richard Guenther * lto-wrapper.c (run_gcc): Properly init/free obstack. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@180521 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index d4c1986..0634954 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,7 @@ +2011-10-26 Richard Guenther + + * lto-wrapper.c (run_gcc): Properly init/free obstack. + 2011-10-26 Jakub Jelinek * config/i386/i386.md (UNSPEC_VSIBADDR): New. diff --git a/gcc/lto-wrapper.c b/gcc/lto-wrapper.c index f5f3dd2..f0a3cf3 100644 --- a/gcc/lto-wrapper.c +++ b/gcc/lto-wrapper.c @@ -339,7 +339,6 @@ run_gcc (unsigned argc, char *argv[]) char *list_option_full = NULL; const char *linker_output = NULL; const char *collect_gcc, *collect_gcc_options; - struct obstack env_obstack; int parallel = 0; int jobserver = 0; bool no_partition = false; @@ -517,11 +516,13 @@ run_gcc (unsigned argc, char *argv[]) { FILE *stream = fopen (ltrans_output_file, "r"); FILE *mstream = NULL; + struct obstack env_obstack; if (!stream) fatal_perror ("fopen: %s", ltrans_output_file); /* Parse the list of LTRANS inputs from the WPA stage. */ + obstack_init (&env_obstack); nr = 0; for (;;) { @@ -574,7 +575,6 @@ cont: /* Replace the .o suffix with a .ltrans.o suffix and write the resulting name to the LTRANS output list. */ - obstack_init (&env_obstack); obstack_grow (&env_obstack, input_name, strlen (input_name) - 2); obstack_grow (&env_obstack, ".ltrans.o", sizeof (".ltrans.o")); output_name = XOBFINISH (&env_obstack, char *); @@ -654,9 +654,8 @@ cont: free (output_names); free (input_names); free (list_option_full); + obstack_free (&env_obstack, NULL); } - - obstack_free (&env_obstack, NULL); }