diff options
author | Richard Biener <rguenther@suse.de> | 2016-08-26 10:59:50 +0000 |
---|---|---|
committer | Richard Biener <rguenther@suse.de> | 2016-08-26 10:59:50 +0000 |
commit | 48957a3f881b8a610c050782074c63a7239978ba (patch) | |
tree | 586e07c7457f281ba53375508b1ba5ab761e9185 | |
parent | 51ef02400d80578ca82ccd75ce3a4f9c25c93d80 (diff) |
2016-08-26 Richard Biener <rguenther@suse.de>
java/
* mangle.c (java_mangle_decl): Re-sync with lhd_set_decl_assembler_name.
git-svn-id: https://gcc.gnu.org/svn/gcc/trunk@239774 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r-- | gcc/java/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/java/mangle.c | 16 |
2 files changed, 17 insertions, 4 deletions
diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog index ba2ab906312..74c5be8cc5d 100644 --- a/gcc/java/ChangeLog +++ b/gcc/java/ChangeLog @@ -1,3 +1,8 @@ +2016-08-26 Richard Biener <rguenther@suse.de> + + java/ + * mangle.c (java_mangle_decl): Re-sync with lhd_set_decl_assembler_name. + 2016-08-12 Marek Polacek <polacek@redhat.com> PR c/7652 diff --git a/gcc/java/mangle.c b/gcc/java/mangle.c index 6c33396c342..d61fc028ae0 100644 --- a/gcc/java/mangle.c +++ b/gcc/java/mangle.c @@ -74,15 +74,23 @@ static GTY(()) tree atms; void java_mangle_decl (tree decl) { - /* A copy of the check from the beginning of lhd_set_decl_assembler_name. - Only FUNCTION_DECLs and VAR_DECLs for variables with static storage - duration need a real DECL_ASSEMBLER_NAME. */ + /* A copy of the check from the beginning of lhd_set_decl_assembler_name. */ + + /* set_decl_assembler_name may be called on TYPE_DECL to record ODR + name for C++ types. By default types have no ODR names. */ + if (TREE_CODE (decl) == TYPE_DECL) + return; + + /* The language-independent code should never use the + DECL_ASSEMBLER_NAME for lots of DECLs. Only FUNCTION_DECLs and + VAR_DECLs for variables with static storage duration need a real + DECL_ASSEMBLER_NAME. */ gcc_assert (TREE_CODE (decl) == FUNCTION_DECL || (TREE_CODE (decl) == VAR_DECL && (TREE_STATIC (decl) || DECL_EXTERNAL (decl) || TREE_PUBLIC (decl)))); - + /* Mangling only applies to class members. */ if (DECL_CONTEXT (decl) && TYPE_P (DECL_CONTEXT (decl))) { |