This is an archive of the discontinued LLVM Phabricator instance.

[Clang] Mutate printf bulitin names under IEEE128 on PPC64
ClosedPublic

Authored by qiucf on Oct 24 2021, 10:27 PM.

Details

Summary

Glibc uses these new symbol names to support IEEE-754 128-bit float support.

Diff Detail

Event Timeline

qiucf created this revision.Oct 24 2021, 10:27 PM
qiucf requested review of this revision.Oct 24 2021, 10:27 PM
Herald added a project: Restricted Project. · View Herald TranscriptOct 24 2021, 10:27 PM
Herald added a subscriber: cfe-commits. · View Herald Transcript
qiucf updated this revision to Diff 381868.Oct 25 2021, 12:37 AM
qiucf added a reviewer: rjmccall.
jsji added inline comments.Oct 26 2021, 8:35 AM
clang/lib/CodeGen/CGBuiltin.cpp
100

Why only these printf builtins? I think there are full list of similar libcalls in GLIBC_2.32 and later?

118

How do we deal with the glibc version? Do we assume that user has glibc newer than GLIBC_2.32?

120

Do we have to do it here? Can we just update the libcall names in RuntimeLibcalls.def or setLibcallName similar to others?

qiucf updated this revision to Diff 383715.Oct 31 2021, 10:22 PM

Add nexttoward

qiucf added inline comments.Nov 1 2021, 2:20 AM
clang/lib/CodeGen/CGBuiltin.cpp
100

Yes, Glibc redirects all these functions depending on long double semantics, and GCC has corresponding builtins for almost all library functions (https://gcc.gnu.org/onlinedocs/gcc/Other-Builtins.html).

But currently clang doesn't have all of these builtins (for example, __builtin_scanf). It seems beyond this patch's scope to make the list complete.

118

I notice not all libcall symbols are implemented in compiler-rt, which means we don't need to always expect all libcalls emitted are available in current libc?

It's surprising that libc version are not checked in clang/driver/toolchain part. The only place checking libc version is in sanitizer. Maybe we can use that to emit warnings, like D112906.

120

I think we cannot fill these calls in backend's runtime libcall list, because it contains supplementary routine names for legalizing IR instruction/intrinsics. Here the builtins are just converted into normal function calls in IR.

jsji accepted this revision as: jsji.Nov 1 2021, 6:53 AM

LGTM. Please hold a few days to see whether there are inputs from other reviewers. Thanks.

clang/lib/CodeGen/CGBuiltin.cpp
100

OK. Thanks. Can we add a TODO note.

This revision is now accepted and ready to land.Nov 1 2021, 6:53 AM
This revision was landed with ongoing or failed builds.Dec 3 2021, 1:51 AM
This revision was automatically updated to reflect the committed changes.