On Tue, Oct 7, 2008 at 1:18 AM, Steve Ellcey <[EMAIL PROTECTED]> wrote:
> I have been looking at why g++.dg/tree-prof/indir-call-prof.C fails on
> IA64 (HP-UX and Linux).  It looks like the optimization (turning an
> indirect call into a direct call) does not happen because the initial
> run with -fprofile-generate is not generating any count data about
> indirect calls.
>
> Comparing x86 (where things work) and IA64 (where they do not), I see
> the test case, when compiled with -fprofile-generate, has calls
> __gcov_indirect_call_profiler in both cases.  But on IA64, cur_func is
> never equal to callee_func and so __gcov_one_value_profiler_body is
> never called.  On x86 we do have cur_func equal to callee_func and so
> __gcov_one_value_profiler_body is called to write out profile
> information.
>
> This is about as far as I have gotten.  I am not sure why there is this
> difference or how to fix it.  I *think* it may be related to the fact
> that IA64 GCC defines TARGET_VTABLE_USES_DESCRIPTORS but my only reason
> for thinking that is that IA64 is the only platform that defines this
> macro and I think that the profiler must be getting callee addresses out
> of the vtable (though I am not sure about that and I don't know where it
> would be doing it from).
>
> So this is a request to anyone who might know the profiling code to help
> me with some advise about what I should look at next or about how to go
> about fixing this bug.

If these testcases never worked on IA64 I suggest you XFAIL
them for IA64 and file a missed-optimization bugreport.

Richard.

> Steve Ellcey
> [EMAIL PROTECTED]
>

Reply via email to