This is the mail archive of the gcc-bugs@gcc.gnu.org mailing list for the GCC project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

[Bug target/64379] VFP register restore in ARM epilogue can break indirect tailcalls


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


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]