From: Jan Hubicka Date: Tue, 31 Mar 2015 17:03:16 +0000 (+0200) Subject: tree.c (need_assembler_name_p): Artificial types have no ODR names. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=36ceb0e3ccbac8324601234546210239d334bb0a;p=gcc.git tree.c (need_assembler_name_p): Artificial types have no ODR names. * tree.c (need_assembler_name_p): Artificial types have no ODR names. * ipa-devirt.c (warn_odr): Do not try to apply ODR cache when no caching is done. * lto.c (lto_read_decls): Move code registering odr types out of TYPE_CANONICAL conditional and also register polymorphic types. From-SVN: r221797 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 150525b7ba9..ea149b40f14 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2015-03-27 Jan Hubicka + + * tree.c (need_assembler_name_p): Artificial types have no ODR + names. + * ipa-devirt.c (warn_odr): Do not try to apply ODR cache when + no caching is done. + 2015-03-31 Martin Liska PR ipa/65557 diff --git a/gcc/ipa-devirt.c b/gcc/ipa-devirt.c index 534f6c0220d..6969f5a04be 100644 --- a/gcc/ipa-devirt.c +++ b/gcc/ipa-devirt.c @@ -939,7 +939,8 @@ warn_odr (tree t1, tree t2, tree st1, tree st2, /* ODR warnings are output druing LTO streaming; we must apply location cache for potential warnings to be output correctly. */ - lto_location_cache::current_cache->apply_location_cache (); + if (lto_location_cache::current_cache) + lto_location_cache::current_cache->apply_location_cache (); if (!warning_at (DECL_SOURCE_LOCATION (TYPE_NAME (t1)), OPT_Wodr, "type %qT violates one definition rule", diff --git a/gcc/lto/ChangeLog b/gcc/lto/ChangeLog index bf2b51bba62..085ce9f4a04 100644 --- a/gcc/lto/ChangeLog +++ b/gcc/lto/ChangeLog @@ -1,3 +1,8 @@ +2015-03-27 Jan Hubicka + + * lto.c (lto_read_decls): Move code registering odr types out + of TYPE_CANONICAL conditional and also register polymorphic types. + 2015-03-26 Jan Hubicka * lto-symtab.c (lto_symtab_merge_decls_2): Silence warning on diff --git a/gcc/tree.c b/gcc/tree.c index 0b8e8961b08..151e3e27bad 100644 --- a/gcc/tree.c +++ b/gcc/tree.c @@ -5139,6 +5139,7 @@ need_assembler_name_p (tree decl) && decl == TYPE_NAME (TREE_TYPE (decl)) && !is_lang_specific (TREE_TYPE (decl)) && AGGREGATE_TYPE_P (TREE_TYPE (decl)) + && !TYPE_ARTIFICIAL (TREE_TYPE (decl)) && !variably_modified_type_p (TREE_TYPE (decl), NULL_TREE) && !type_in_anonymous_namespace_p (TREE_TYPE (decl))) return !DECL_ASSEMBLER_NAME_SET_P (decl);