From: Iain Sandoe Date: Thu, 30 Mar 2023 07:44:23 +0000 (+0530) Subject: c++,coroutines: Stabilize names of promoted slot vars [PR101118]. X-Git-Tag: basepoints/gcc-14~243 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=fc4cde2e6aa4d6ebdf7f70b7b4359fb59a1915ae;p=thirdparty%2Fgcc.git c++,coroutines: Stabilize names of promoted slot vars [PR101118]. When we need to 'promote' a value (i.e. store it in the coroutine frame) it is given a frame entry name. This was based on the DECL_UID for slot vars. However, when LTO is used, the names from multiple TUs become visible at the same time, and the DECL_UIDs usually differ between units. This leads to a "ODR mismatch" warning for the frame type. The fix here is to use the current promoted temporaries count to produce the name, this is stable between TUs and computed per coroutine. Signed-off-by: Iain Sandoe PR c++/101118 gcc/cp/ChangeLog: * coroutines.cc (flatten_await_stmt): Use the current count of promoted temporaries to build a unique name for the frame entries. --- diff --git a/gcc/cp/coroutines.cc b/gcc/cp/coroutines.cc index a2189e43db89..b307c8ca8b64 100644 --- a/gcc/cp/coroutines.cc +++ b/gcc/cp/coroutines.cc @@ -2889,7 +2889,7 @@ flatten_await_stmt (var_nest_node *n, hash_set *promoted, tree init = t; temps_used->add (init); tree var_type = TREE_TYPE (init); - char *buf = xasprintf ("D.%d", DECL_UID (TREE_OPERAND (init, 0))); + char *buf = xasprintf ("T%03u", (unsigned) temps_used->elements ()); tree var = build_lang_decl (VAR_DECL, get_identifier (buf), var_type); DECL_ARTIFICIAL (var) = true; free (buf);