From: Richard Biener Date: Fri, 13 Jan 2023 07:11:53 +0000 (+0100) Subject: Sync LTO type_for_mode with c-family/ X-Git-Tag: basepoints/gcc-14~2072 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=9b6c624820050cd5e11b2fbd9c997f94b691295a;p=thirdparty%2Fgcc.git Sync LTO type_for_mode with c-family/ The following adds _FloatN mode support to the LTO copy of c_common_type_for_mode and also implements the fix for PR94072. gcc/lto/ * lto-lang.cc (lto_type_for_mode): Sync with c_common_type_for_mode. --- diff --git a/gcc/lto/lto-lang.cc b/gcc/lto/lto-lang.cc index 7018dfae4a50..1b2a4a632bbc 100644 --- a/gcc/lto/lto-lang.cc +++ b/gcc/lto/lto-lang.cc @@ -1004,6 +1004,11 @@ lto_type_for_mode (machine_mode mode, int unsigned_p) if (mode == TYPE_MODE (long_double_type_node)) return long_double_type_node; + for (i = 0; i < NUM_FLOATN_NX_TYPES; i++) + if (FLOATN_NX_TYPE_NODE (i) != NULL_TREE + && mode == TYPE_MODE (FLOATN_NX_TYPE_NODE (i))) + return FLOATN_NX_TYPE_NODE (i); + if (mode == TYPE_MODE (void_type_node)) return void_type_node; @@ -1029,6 +1034,11 @@ lto_type_for_mode (machine_mode mode, int unsigned_p) if (mode == TYPE_MODE (complex_long_double_type_node)) return complex_long_double_type_node; + for (i = 0; i < NUM_FLOATN_NX_TYPES; i++) + if (COMPLEX_FLOATN_NX_TYPE_NODE (i) != NULL_TREE + && mode == TYPE_MODE (COMPLEX_FLOATN_NX_TYPE_NODE (i))) + return COMPLEX_FLOATN_NX_TYPE_NODE (i); + if (mode == TYPE_MODE (complex_integer_type_node) && !unsigned_p) return complex_integer_type_node; @@ -1154,9 +1164,13 @@ lto_type_for_mode (machine_mode mode, int unsigned_p) } for (t = registered_builtin_types; t; t = TREE_CHAIN (t)) - if (TYPE_MODE (TREE_VALUE (t)) == mode) - return TREE_VALUE (t); - + { + tree type = TREE_VALUE (t); + if (TYPE_MODE (type) == mode + && VECTOR_TYPE_P (type) == VECTOR_MODE_P (mode) + && !!unsigned_p == !!TYPE_UNSIGNED (type)) + return type; + } return NULL_TREE; }