This is the mail archive of the
gcc-bugs@gcc.gnu.org
mailing list for the GCC project.
[Bug target/64379] VFP register restore in ARM epilogue can break indirect tailcalls
- From: "ramana at gcc dot gnu.org" <gcc-bugzilla at gcc dot gnu dot org>
- To: gcc-bugs at gcc dot gnu dot org
- Date: Tue, 13 Jan 2015 16:16:28 +0000
- Subject: [Bug target/64379] VFP register restore in ARM epilogue can break indirect tailcalls
- Auto-submitted: auto-generated
- References: <bug-64379-4 at http dot gcc dot gnu dot org/bugzilla/>
https://gcc.gnu.org/bugzilla/show_bug.cgi?id=64379
--- Comment #10 from Ramana Radhakrishnan <ramana at gcc dot gnu.org> ---
(In reply to Eric Botcazou from comment #9)
> > Uggh - these ancient options in the backend. mapcs-frame is quite ancient
> > and isn't really something that's tested very often, no wonder it's rotting.
> > In this case we seem to have regressed something that worked earlier,
>
> Yes, indirect tailcalls used to be rejected by the back-end.
Indeed.
>
> > I do wonder if the fix here is to just turn IP regnum into a fixed register in
> > the presence of mapcs-frame.
>
> This would only turn the problem into an ICE here.
Hmmmm not sure.
> I think this needs to be
> fixed in arm_function_ok_for_sibcall, either in a big-hammer-ish way
> (disable again indirect tailcalls with -mapcs-frame) or in a more precise
> way.
Sure that would work too but it feels like a rather big hammer. In the absence
of anything else, I'm happy to review a patch if someone could post this
upstream and get it tested, I won't have time to work on this bug for the next
week or 2.
While we are here, what's the thought on deprecating mapcs-frame in the
arm-wrs-vxworks community ? It is not really something that's part of the ABI
(it predates EABI), doesn't work with Thumb2 and not tested regularly and we
keep finding issues with this.
Can arm-wrs-vxworks move to using the EHABI information and unwinding
information from there to handle such backtraces - after all libunwind has the
capability now for unwinding ARM EHABI tables if you needed a generic library
to do this ?
regards
Ramana