summaryrefslogtreecommitdiff
path: root/gcc/ipa-inline-transform.c
diff options
context:
space:
mode:
authorienkovich <ienkovich@138bc75d-0d04-0410-961f-82ee72b054a4>2016-07-13 11:02:15 +0000
committerienkovich <ienkovich@138bc75d-0d04-0410-961f-82ee72b054a4>2016-07-13 11:02:15 +0000
commit839a6560a00e826242b4b265af1c07feed543bf4 (patch)
tree98e7d146f2b355e33ae56af0b7681f075865f375 /gcc/ipa-inline-transform.c
parent8f5f2788ad261b7372385807e62aae5d9a51c109 (diff)
downloadgcc-839a6560a00e826242b4b265af1c07feed543bf4.tar.gz
gcc/
PR ipa/71633 * ipa-inline-transform.c (inline_call): Support instrumented thunks. gcc/testsuite/ PR ipa/71633 * g++.dg/pr71633.C: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@238290 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/ipa-inline-transform.c')
-rw-r--r--gcc/ipa-inline-transform.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/gcc/ipa-inline-transform.c b/gcc/ipa-inline-transform.c
index 9ac1efc9192..98c7f96fbb6 100644
--- a/gcc/ipa-inline-transform.c
+++ b/gcc/ipa-inline-transform.c
@@ -319,10 +319,14 @@ inline_call (struct cgraph_edge *e, bool update_original,
to = to->global.inlined_to;
if (to->thunk.thunk_p)
{
+ struct cgraph_node *target = to->callees->callee;
if (in_lto_p)
to->get_untransformed_body ();
to->expand_thunk (false, true);
- e = to->callees;
+ /* When thunk is instrumented we may have multiple callees. */
+ for (e = to->callees; e && e->callee != target; e = e->next_callee)
+ ;
+ gcc_assert (e);
}