[PATCH] D109967: Simplify handling of builtin with inline redefinition
serge via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Fri Sep 17 08:24:15 PDT 2021
serge-sans-paille created this revision.
serge-sans-paille added reviewers: rnk, nickdesaulniers, efriedma.
serge-sans-paille requested review of this revision.
Herald added a project: clang.
Herald added a subscriber: cfe-commits.
It is a common practice in glibc header to provide an inline redefinition of an
existing function. It is especially the case for fortified function.
Clang currently has an imperfect approach to the problem, using a combination of
trivially recursive function detection and noinline attribute.
Simplify the logic by suffixing these functions by `.inline` during codegen, so
that they are not recognized as builtin by llvm.
After that patch, clang passes all tests from:
https://github.com/serge-sans-paille/fortify-test-suite
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D109967
Files:
clang/lib/CodeGen/CodeGenFunction.cpp
clang/lib/CodeGen/CodeGenModule.cpp
clang/test/CodeGen/memcpy-inline-builtin.c
clang/test/CodeGen/memcpy-no-nobuiltin-if-not-emitted.c
clang/test/CodeGen/memcpy-nobuiltin.c
clang/test/CodeGen/pr9614.c
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D109967.373228.patch
Type: text/x-patch
Size: 5021 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20210917/1ff11db9/attachment-0001.bin>
More information about the cfe-commits
mailing list