]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
c++: mutable temps in rodata [PR116369]
authorMarek Polacek <polacek@redhat.com>
Thu, 29 Aug 2024 19:13:03 +0000 (15:13 -0400)
committerMarek Polacek <polacek@redhat.com>
Tue, 10 Sep 2024 15:48:15 +0000 (11:48 -0400)
Here we wrongly mark the reference temporary for g TREE_READONLY,
so it's put in .rodata and so we can't modify its subobject even
when the subobject is marked mutable.  This is so since r9-869.
r14-1785 fixed a similar problem, but not in set_up_extended_ref_temp.

PR c++/116369

gcc/cp/ChangeLog:

* call.cc (set_up_extended_ref_temp): Don't mark a temporary
TREE_READONLY if its type is TYPE_HAS_MUTABLE_P.

gcc/testsuite/ChangeLog:

* g++.dg/tree-ssa/initlist-opt7.C: New test.

gcc/cp/call.cc
gcc/testsuite/g++.dg/tree-ssa/initlist-opt7.C [new file with mode: 0644]

index fa7f05d76f6868051f8ed597e66c29cbe5bfce71..d30f36d49ff69c520e31a5b2c9fbb75eb76c4095 100644 (file)
@@ -13964,7 +13964,9 @@ set_up_extended_ref_temp (tree decl, tree expr, vec<tree, va_gc> **cleanups,
   init = cp_fully_fold (init);
   if (TREE_CONSTANT (init))
     {
-      if (literal_type_p (type) && CP_TYPE_CONST_NON_VOLATILE_P (type))
+      if (literal_type_p (type)
+         && CP_TYPE_CONST_NON_VOLATILE_P (type)
+         && !TYPE_HAS_MUTABLE_P (type))
        {
          /* 5.19 says that a constant expression can include an
             lvalue-rvalue conversion applied to "a glvalue of literal type
diff --git a/gcc/testsuite/g++.dg/tree-ssa/initlist-opt7.C b/gcc/testsuite/g++.dg/tree-ssa/initlist-opt7.C
new file mode 100644 (file)
index 0000000..2420db5
--- /dev/null
@@ -0,0 +1,13 @@
+// PR c++/116369
+// { dg-do run { target c++11 } }
+
+struct f{
+  mutable int t;
+};
+
+const f &g = {1};
+
+int main()
+{
+  g.t++;
+}