Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Raise -fomit-frame-pointer into the Clang driver? #824

Closed
DanAlbert opened this issue Oct 17, 2018 · 12 comments
Closed

Raise -fomit-frame-pointer into the Clang driver? #824

DanAlbert opened this issue Oct 17, 2018 · 12 comments
Labels

Comments

@DanAlbert
Copy link
Member

The only identified size difference between GCC and Clang remaining is that GCC defaulted to -fomit-frame-pointer whereas Clang does not: #133

Should we enable this by default in the driver for Android targets? iirc ASan needs frame pointers to give reasonable performance, so perhaps not.

@rprichard @stephenhines @pirama-arumuga-nainar

@DanAlbert
Copy link
Member Author

Clang's defaults here are weird. For Linux targets (including Android), frame pointers are disabled when optimizations are enabled on x86/x86_64 (and a bunch of other things we don't support), but always on for arm/arm64.

My instinct is to not differ from existing Linux behavior, but given that this is free code size (and the few users that do need it can enable it, we can re-enable if asan is used, etc), maybe we should?

Apple targets don't support the flag at all. I couldn't work out whether they were always on or always off.

Triaging to r23 to have either send the patch upstream or close won't fix by then.

@DanAlbert DanAlbert modified the milestones: unplanned, r23 Apr 14, 2020
@enh-google
Copy link
Collaborator

https://developer.apple.com/library/archive/documentation/Xcode/Conceptual/iPhoneOSABIReference/Articles/ARM64FunctionCallingConventions.html says:

"The frame pointer register (x29) must always address a valid frame record, although some functions—such as leaf functions or tail calls—may elect not to create an entry in this list. As a result, stack traces will always be meaningful, even without debug information."

which is what i'd want as a developer too. i support having people explicitly opt-out of frame pointers.

@DanAlbert
Copy link
Member Author

i support having people explicitly opt-out of frame pointers.

In other words we should upstream a patch, but one to change x86/x86_64 to be always on?

BTW, the leaf node behavior is default for clang as far as I can tell: https://github.com/llvm/llvm-project/blob/9d2d6e71f096ad43b178c576adf94fc922034c73/clang/lib/Driver/ToolChains/Clang.cpp#L594

@DanAlbert
Copy link
Member Author

@enh-google
Copy link
Collaborator

In other words we should upstream a patch, but one to change x86/x86_64 to be always on?

oh, interesting. i hadn't thought that far ahead. i'm leaning towards "leave x86-64 alone until we have a reason to change it"?

@nickdesaulniers
Copy link
Member

I've touched this part of Clang multiple times. What specifically is the issue here? Note that we do not implicitly set -fomit-frame-pointer for 32b ARM android targets. useFramePointerForTargetByDefault is the relevant function in Clang.

@DanAlbert
Copy link
Member Author

Just hadn't come to a conclusion on whether we wanted to change this, and if we did how we'd want to do that. Whether we want to be consistent with Apple, with GNU, or with ourselves across architectures was undecided. Mostly no decision because no one had strong feelings :)

@stephenhines
Copy link
Collaborator

http://b/157669376 has a larger discussion about whether we should change things (re: frame pointers) for Android platform builds. I do not think we should be adjusting the Android defaults here.

@nickdesaulniers
Copy link
Member

I think it's ok to close this bug then. Please feel free to reopen it though!

@DanAlbert DanAlbert removed this from the r23 milestone Jan 8, 2021
@HaiPhan2002
Copy link

Hello @DanAlbert,
As the discussion here, fno-omit-frame-pointer is default for Android? for all android-ndk versions until now?
Thanks,
Hai

@DanAlbert
Copy link
Member Author

Idk about all versions but I believe that's currently the case. I'm not even sure about non-arm32 targets.

@HaiPhan2002
Copy link

Thank you for information.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

5 participants