Reset when -gtoggle is used in gcc_options.
authorMartin Liska <mliska@suse.cz>
Mon, 1 Nov 2021 15:28:34 +0000 (16:28 +0100)
committerMartin Liska <mliska@suse.cz>
Fri, 5 Nov 2021 12:01:01 +0000 (13:01 +0100)
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.

gcc/opts.c
gcc/testsuite/g++.dg/pr102955.C [new file with mode: 0644]

index 3f80fce..caed625 100644 (file)
@@ -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 (file)
index 0000000..de9689e
--- /dev/null
@@ -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();
+}