diff options
author | Martin Liska <mliska@suse.cz> | 2018-03-16 15:53:45 +0100 |
---|---|---|
committer | Martin Liska <marxin@gcc.gnu.org> | 2018-03-16 14:53:45 +0000 |
commit | d5aabfc9a629a7c323f59c9f19dd78519f2803ef (patch) | |
tree | 67a5da4911a7498436025b0b83f56f9960e607bd /gcc/multiple_target.c | |
parent | a9a98049847fd8bafbb352818dd3ac86ff6ebf07 (diff) | |
download | gcc-d5aabfc9a629a7c323f59c9f19dd78519f2803ef.zip gcc-d5aabfc9a629a7c323f59c9f19dd78519f2803ef.tar.gz gcc-d5aabfc9a629a7c323f59c9f19dd78519f2803ef.tar.bz2 |
Redirect reference in the symbol table (PR ipa/84833).
2018-03-16 Martin Liska <mliska@suse.cz>
PR ipa/84833
* multiple_target.c (create_dispatcher_calls): Redirect
reference in the symbol table.
2018-03-16 Martin Liska <mliska@suse.cz>
PR ipa/84833
* gcc.target/i386/mvc11.c: New test.
From-SVN: r258596
Diffstat (limited to 'gcc/multiple_target.c')
-rw-r--r-- | gcc/multiple_target.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/gcc/multiple_target.c b/gcc/multiple_target.c index 95297f3..b006a5a 100644 --- a/gcc/multiple_target.c +++ b/gcc/multiple_target.c @@ -144,6 +144,10 @@ create_dispatcher_calls (struct cgraph_node *node) if (ref->referring->decl != resolver_decl) walk_gimple_stmt (&it, NULL, replace_function_decl, &wi); } + + symtab_node *source = ref->referring; + ref->remove_reference (); + source->create_reference (inode, IPA_REF_ADDR); } else if (ref->use == IPA_REF_ALIAS) { |