]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
c++: Prevent overwriting arguments when merging duplicates [PR112588]
authorNathaniel Shead <nathanieloshead@gmail.com>
Sat, 16 Dec 2023 10:34:45 +0000 (21:34 +1100)
committerNathaniel Shead <nathanieloshead@gmail.com>
Wed, 17 Jan 2024 23:06:09 +0000 (10:06 +1100)
When merging duplicate instantiations of function templates, currently
read_function_def overwrites the arguments with that of the existing
duplicate. This is problematic, however, since this means that the
PARM_DECLs in the body of the function definition no longer match with
the PARM_DECLs in the argument list, which causes issues when it comes
to generating RTL.

There doesn't seem to be any reason to do this replacement, so this
patch removes that logic.

PR c++/112588

gcc/cp/ChangeLog:

* module.cc (trees_in::read_function_def): Don't overwrite
arguments.

gcc/testsuite/ChangeLog:

* g++.dg/modules/merge-16.h: New test.
* g++.dg/modules/merge-16_a.C: New test.
* g++.dg/modules/merge-16_b.C: New test.

Signed-off-by: Nathaniel Shead <nathanieloshead@gmail.com>
gcc/cp/module.cc
gcc/testsuite/g++.dg/modules/merge-16.h [new file with mode: 0644]
gcc/testsuite/g++.dg/modules/merge-16_a.C [new file with mode: 0644]
gcc/testsuite/g++.dg/modules/merge-16_b.C [new file with mode: 0644]

index 350ad15dc623c2bb1f05895aaf40569ddf1d941c..8db662c0267f85bb9649b1174daa6ada2a76c0be 100644 (file)
@@ -11703,8 +11703,6 @@ trees_in::read_function_def (tree decl, tree maybe_template)
       DECL_RESULT (decl) = result;
       DECL_INITIAL (decl) = initial;
       DECL_SAVED_TREE (decl) = saved;
-      if (maybe_dup)
-       DECL_ARGUMENTS (decl) = DECL_ARGUMENTS (maybe_dup);
 
       if (context)
        SET_DECL_FRIEND_CONTEXT (decl, context);
diff --git a/gcc/testsuite/g++.dg/modules/merge-16.h b/gcc/testsuite/g++.dg/modules/merge-16.h
new file mode 100644 (file)
index 0000000..fdb3855
--- /dev/null
@@ -0,0 +1,10 @@
+// PR c++/112588
+
+void f(int*);
+
+template <typename T>
+struct S {
+  void g(int n) { f(&n); }
+};
+
+template struct S<void>;
diff --git a/gcc/testsuite/g++.dg/modules/merge-16_a.C b/gcc/testsuite/g++.dg/modules/merge-16_a.C
new file mode 100644 (file)
index 0000000..c243224
--- /dev/null
@@ -0,0 +1,7 @@
+// PR c++/112588
+// { dg-additional-options "-fmodules-ts" }
+// { dg-module-cmi merge16 }
+
+module;
+#include "merge-16.h"
+export module merge16;
diff --git a/gcc/testsuite/g++.dg/modules/merge-16_b.C b/gcc/testsuite/g++.dg/modules/merge-16_b.C
new file mode 100644 (file)
index 0000000..8c7b1f0
--- /dev/null
@@ -0,0 +1,5 @@
+// PR c++/112588
+// { dg-additional-options "-fmodules-ts" }
+
+#include "merge-16.h"
+import merge16;