From d6bcbb40dd475624be371de4d86e9054a5934fc9 Mon Sep 17 00:00:00 2001 From: Kai Tietz Date: Fri, 7 Jan 2011 13:50:15 +0000 Subject: [PATCH] decl.c (java_init_decl_processing): Setup va_list_type_node. 2011-01-07 Kai Tietz * decl.c (java_init_decl_processing): Setup va_list_type_node. From-SVN: r168569 --- gcc/java/ChangeLog | 4 ++++ gcc/java/decl.c | 13 +++++++++++++ 2 files changed, 17 insertions(+) diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog index b6125774061..0f27ff76a4e 100644 --- a/gcc/java/ChangeLog +++ b/gcc/java/ChangeLog @@ -1,3 +1,7 @@ +2011-01-07 Kai Tietz + + * decl.c (java_init_decl_processing): Setup va_list_type_node. + 2011-01-03 Jakub Jelinek * jcf-dump.c (version): Update copyright notice dates. diff --git a/gcc/java/decl.c b/gcc/java/decl.c index a17b826696b..c91ddbb9b57 100644 --- a/gcc/java/decl.c +++ b/gcc/java/decl.c @@ -1154,6 +1154,19 @@ java_init_decl_processing (void) = add_builtin_function ("_Jv_remJ", t, 0, NOT_BUILT_IN, NULL, NULL_TREE); + /* Initialize va_list_type_node. */ + t = targetm.build_builtin_va_list (); + + /* Many back-ends define record types without setting TYPE_NAME. + If we copied the record type here, we'd keep the original + record type without a name. This breaks name mangling. So, + don't copy record types and let c_common_nodes_and_builtins() + declare the type to be __builtin_va_list. */ + if (TREE_CODE (t) != RECORD_TYPE) + t = build_variant_type_copy (t); + + va_list_type_node = t; + initialize_builtins (); soft_fmod_node = built_in_decls[BUILT_IN_FMOD];