From: Martin Liska Date: Mon, 1 Nov 2021 15:28:34 +0000 (+0100) Subject: Reset when -gtoggle is used in gcc_options. X-Git-Tag: basepoints/gcc-13~3379 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=14c7041a1f00ef4ee9a036e0b369c97646db5b5c;p=thirdparty%2Fgcc.git Reset when -gtoggle is used in gcc_options. PR debug/102955 gcc/ChangeLog: * opts.c (finish_options): Reset flag_gtoggle when it is used. gcc/testsuite/ChangeLog: * g++.dg/pr102955.C: New test. --- diff --git a/gcc/opts.c b/gcc/opts.c index 3f80fce82bcc..caed62555009 100644 --- a/gcc/opts.c +++ b/gcc/opts.c @@ -1377,6 +1377,8 @@ finish_options (struct gcc_options *opts, struct gcc_options *opts_set, if (flag_gtoggle) { + /* Make sure to process -gtoggle only once. */ + flag_gtoggle = false; if (debug_info_level == DINFO_LEVEL_NONE) { debug_info_level = DINFO_LEVEL_NORMAL; diff --git a/gcc/testsuite/g++.dg/pr102955.C b/gcc/testsuite/g++.dg/pr102955.C new file mode 100644 index 000000000000..de9689edec47 --- /dev/null +++ b/gcc/testsuite/g++.dg/pr102955.C @@ -0,0 +1,14 @@ +/* PR debug/102955 */ +/* { dg-do compile } */ +/* { dg-options "-g -gtoggle" } */ + +#pragma GCC optimize "0" +struct j +{ + explicit j (); + ~j (); +}; +void g (void) +{ + new j(); +}