diff options
author | aoliva <aoliva@138bc75d-0d04-0410-961f-82ee72b054a4> | 2001-12-04 10:34:40 +0000 |
---|---|---|
committer | aoliva <aoliva@138bc75d-0d04-0410-961f-82ee72b054a4> | 2001-12-04 10:34:40 +0000 |
commit | 9a0c59e912fa744add2f30f054c6268fe434b56d (patch) | |
tree | 5f796d4a540cf14b9ff9cbc2a69e91812776ca98 /gcc/tree.c | |
parent | 76249d8c52cdab1d03aa8ec915b4c757b0e1c800 (diff) | |
download | gcc-9a0c59e912fa744add2f30f054c6268fe434b56d.tar.gz |
* c-decl.c (duplicate_decls): Revert rth's patch. If newdecl
is in a different binding level, get its abstract origin to be
olddecl.
* tree-inline.c (expand_call_inline): Move DECL_INITIAL sanity
check earlier.
* tree.c (get_callee_fndecl): Follow DECL_ABSTRACT_ORIGIN if
DECL_INITIAL is NULL.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@47610 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/tree.c')
-rw-r--r-- | gcc/tree.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/gcc/tree.c b/gcc/tree.c index 3cc52c03f5f..87dac2d5eb5 100644 --- a/gcc/tree.c +++ b/gcc/tree.c @@ -4378,7 +4378,14 @@ get_callee_fndecl (call) that `f' is being called. */ if (TREE_CODE (addr) == ADDR_EXPR && TREE_CODE (TREE_OPERAND (addr, 0)) == FUNCTION_DECL) - return TREE_OPERAND (addr, 0); + { + addr = TREE_OPERAND (addr, 0); + + if (! DECL_INITIAL (addr) && DECL_ABSTRACT_ORIGIN (addr)) + addr = DECL_ABSTRACT_ORIGIN (addr); + + return addr; + } /* We couldn't figure out what was being called. */ return NULL_TREE; |