llvm-project/clang/lib/CodeGen
Rong Xu db18f26567 [llvm-profdata] Handle internal linkage functions in profile supplementation
This patch has the following changes:
(1) Handling of internal linkage functions (static functions)
Static functions in FDO have a prefix of source file name, while they do not
have one in SampleFDO. Current implementation does not handle this and we are
not updating the profile for static functions. This patch fixes this.

(2) Handling of -funique-internal-linakge-symbols
Again this is for the internal linkage functions. Option
-funique-internal-linakge-symbols can now be applied to both FDO and SampleFDO
compilation. When it is used, it demangles internal linkage function names and
adds a hash value as the postfix.

When both SampleFDO and FDO profiles use this option, or both
not use this option, changes in (1) should handle this.

Here we also handle when the SampleFDO profile using this option while FDO
profile not using this option, or vice versa.

There is one case where this patch won't work: If one of the profiles used
mangled name and the other does not. For example, if the SampleFDO profile
uses clang c-compiler and without -funique-internal-linakge-symbols, while
the FDO profile uses -funique-internal-linakge-symbols. The SampleFDO profile
contains unmangled names while the FDO profile contains mangled names. If
both profiles use c++ compiler, this won't happen. We think this use case
is rare and does not justify the effort to fix.

Differential Revision: https://reviews.llvm.org/D132600
2022-08-29 16:15:12 -07:00
..
ABIInfo.h [clang][CodeGen] Factor out Swift ABI hooks (NFCI) 2022-08-08 00:23:23 +08:00
Address.h
BackendUtil.cpp [Debugify] Port verify-debuginfo-preserve to NewPM 2022-07-06 17:07:20 +02:00
CGAtomic.cpp [clang-cl] Expose the /volatile:{iso,ms} choice via _ISO_VOLATILE 2022-08-23 14:29:52 +00:00
CGBlocks.cpp
CGBlocks.h
CGBuilder.h [clang] Add support for __builtin_memset_inline 2022-06-10 13:13:59 +00:00
CGBuiltin.cpp Use std::clamp (NFC) 2022-08-27 09:53:13 -07:00
CGCUDANV.cpp [CUDA] Allow the new driver to compile CUDA in non-RDC mode 2022-07-13 21:49:15 -04:00
CGCUDARuntime.cpp
CGCUDARuntime.h [CUDA] Create offloading entries when using the new driver 2022-05-11 07:30:21 -04:00
CGCXX.cpp
CGCXXABI.cpp
CGCXXABI.h [CodeGen] Consider MangleCtx when move lazy emission States 2022-07-26 12:34:03 +08:00
CGCall.cpp KCFI sanitizer 2022-08-24 22:41:38 +00:00
CGCall.h [clang][CodeGen] Only include ABIInfo.h where required (NFC) 2022-07-22 10:45:02 -07:00
CGClass.cpp [clang] Create alloca to pass into static lambda 2022-08-23 13:53:17 -07:00
CGCleanup.cpp [NFC][Alignment] Use MaybeAlign in CGCleanup/CGExpr 2022-06-14 10:56:36 +00:00
CGCleanup.h
CGCoroutine.cpp [clang] LLVM_FALLTHROUGH => [[fallthrough]]. NFC 2022-08-08 09:12:46 -07:00
CGDebugInfo.cpp DebugInfo: Remove auto return type representation support 2022-08-17 00:35:05 +00:00
CGDebugInfo.h DebugInfo: Remove auto return type representation support 2022-08-17 00:35:05 +00:00
CGDecl.cpp [clang] LLVM_FALLTHROUGH => [[fallthrough]]. NFC 2022-08-08 09:12:46 -07:00
CGDeclCXX.cpp [CodeGen] Sort llvm.global_ctors by lexing order before emission 2022-08-22 16:00:14 -07:00
CGException.cpp [clang] LLVM_FALLTHROUGH => [[fallthrough]]. NFC 2022-08-08 09:12:46 -07:00
CGExpr.cpp [Clang][C++20] Support capturing structured bindings in lambdas 2022-08-04 10:12:53 +02:00
CGExprAgg.cpp [clang] LLVM_FALLTHROUGH => [[fallthrough]]. NFC 2022-08-08 09:12:46 -07:00
CGExprCXX.cpp [clang] LLVM_FALLTHROUGH => [[fallthrough]]. NFC 2022-08-08 09:12:46 -07:00
CGExprComplex.cpp Support of expression granularity for _Float16. 2022-08-25 08:26:53 -04:00
CGExprConstant.cpp [Clang] Propagate const context info when emitting compound literal 2022-08-18 11:25:20 +01:00
CGExprScalar.cpp Support of expression granularity for _Float16. 2022-08-25 08:26:53 -04:00
CGGPUBuiltin.cpp
CGHLSLRuntime.cpp [HLSL] Move DXIL validation version out of ModuleFlags 2022-08-26 09:20:45 -07:00
CGHLSLRuntime.h [HLSL] Initial codegen for SV_GroupIndex 2022-08-25 11:17:54 -05:00
CGLoopInfo.cpp
CGLoopInfo.h
CGNonTrivialStruct.cpp
CGObjC.cpp [clang] Don't use Optional::getValue (NFC) 2022-06-20 22:59:26 -07:00
CGObjCGNU.cpp Fix crash in ObjC codegen introduced with 5ab6ee7599 2022-07-24 13:59:45 +01:00
CGObjCMac.cpp [ObjC] type method metadata `_imp`, messenger routine at callsite with program address space 2022-08-04 05:40:32 -04:00
CGObjCRuntime.cpp [clang] LLVM_FALLTHROUGH => [[fallthrough]]. NFC 2022-08-08 09:12:46 -07:00
CGObjCRuntime.h [clang][CodeGen] Only include ABIInfo.h where required (NFC) 2022-07-22 10:45:02 -07:00
CGOpenCLRuntime.cpp
CGOpenCLRuntime.h
CGOpenMPRuntime.cpp [NFC][OpenMP] Simplify 2f9be69d84 2022-08-17 18:59:48 -07:00
CGOpenMPRuntime.h Revert "Use std::is_same_v instead of std::is_same (NFC)" 2022-08-20 23:00:39 -07:00
CGOpenMPRuntimeGPU.cpp [OpenMP] Add option to assert no nested OpenMP parallelism on the GPU 2022-08-23 14:09:51 -05:00
CGOpenMPRuntimeGPU.h Remove redundaunt virtual specifiers (NFC) 2022-07-25 23:00:59 -07:00
CGRecordLayout.h
CGRecordLayoutBuilder.cpp
CGStmt.cpp [CodeGen][inlineasm] assume the flag output of inline asm is boolean value 2022-08-02 11:49:01 -07:00
CGStmtOpenMP.cpp [Clang][OpenMP] Make copyin clause on combined and composite construct work (patch by Yuichiro Utsumi (utsumi.yuichiro@fujitsu.com)) 2022-08-23 07:58:35 -07:00
CGVTT.cpp [clang codegen] Add dso_local/hidden/etc. markings to VTT declarations 2022-06-24 09:58:31 -07:00
CGVTables.cpp [clang] Do not instrument the rtti_proxies under hwasan 2022-08-26 18:22:17 +00:00
CGVTables.h [clang] Do not instrument the rtti_proxies under hwasan 2022-08-26 18:22:17 +00:00
CGValue.h
CMakeLists.txt [HLSL][clang][Driver] Support validator version command line option. 2022-04-29 16:48:08 -07:00
CodeGenABITypes.cpp
CodeGenAction.cpp [CGDebugInfo] Access the current working directory from the `VFS` 2022-07-26 13:48:39 -07:00
CodeGenFunction.cpp [HLSL] Initial codegen for SV_GroupIndex 2022-08-25 11:17:54 -05:00
CodeGenFunction.h Support of expression granularity for _Float16. 2022-08-25 08:26:53 -04:00
CodeGenModule.cpp [llvm-profdata] Handle internal linkage functions in profile supplementation 2022-08-29 16:15:12 -07:00
CodeGenModule.h KCFI sanitizer 2022-08-24 22:41:38 +00:00
CodeGenPGO.cpp [InstrProf] Add the skipprofile attribute 2022-08-04 08:45:27 -07:00
CodeGenPGO.h
CodeGenTBAA.cpp [tbaa] Handle base classes in struct tbaa 2022-07-06 14:37:59 +02:00
CodeGenTBAA.h
CodeGenTypeCache.h
CodeGenTypes.cpp
CodeGenTypes.h
ConstantEmitter.h [Clang] Propagate const context info when emitting compound literal 2022-08-18 11:25:20 +01:00
ConstantInitBuilder.cpp [clang][CodeGen] Switch a few placeholders from UndefValue to PoisonValue 2022-06-12 19:07:59 +01:00
CoverageMappingGen.cpp [Clang] Fix crash in coverage of if consteval. 2022-08-26 17:46:53 +02:00
CoverageMappingGen.h [Clang][CoverageMapping] Fix compile time explosions by adjusting only appropriated skipped ranges 2022-06-08 23:13:39 -07:00
EHScopeStack.h
ItaniumCXXABI.cpp [clang] Do not instrument relative vtables under hwasan 2022-08-26 18:21:40 +00:00
MacroPPCallbacks.cpp [clang] LLVM_FALLTHROUGH => [[fallthrough]]. NFC 2022-08-08 09:12:46 -07:00
MacroPPCallbacks.h [clang][lex] NFCI: Use FileEntryRef in PPCallbacks::InclusionDirective() 2022-04-14 10:46:12 +02:00
MicrosoftCXXABI.cpp Remove redundaunt virtual specifiers (NFC) 2022-07-25 23:00:59 -07:00
ModuleBuilder.cpp [CGDebugInfo] Access the current working directory from the `VFS` 2022-07-26 13:48:39 -07:00
ObjectFilePCHContainerOperations.cpp [CGDebugInfo] Access the current working directory from the `VFS` 2022-07-26 13:48:39 -07:00
PatternInit.cpp
PatternInit.h
README.txt
SanitizerMetadata.cpp Remove 'no_sanitize_memtag'. Add 'sanitize_memtag'. 2022-07-13 08:54:41 -07:00
SanitizerMetadata.h [clang] Remove unused forward declarations (NFC) 2022-07-24 20:51:06 -07:00
SwiftCallingConv.cpp [clang][CodeGen] Factor out Swift ABI hooks (NFCI) 2022-08-08 00:23:23 +08:00
TargetInfo.cpp Use std::clamp (NFC) 2022-08-27 09:53:13 -07:00
TargetInfo.h [clang][CodeGen] Factor out Swift ABI hooks (NFCI) 2022-08-08 00:23:23 +08:00
VarBypassDetector.cpp [clang] LLVM_FALLTHROUGH => [[fallthrough]]. NFC 2022-08-08 09:12:46 -07:00
VarBypassDetector.h

README.txt

IRgen optimization opportunities.

//===---------------------------------------------------------------------===//

The common pattern of
--
short x; // or char, etc
(x == 10)
--
generates an zext/sext of x which can easily be avoided.

//===---------------------------------------------------------------------===//

Bitfields accesses can be shifted to simplify masking and sign
extension. For example, if the bitfield width is 8 and it is
appropriately aligned then is is a lot shorter to just load the char
directly.

//===---------------------------------------------------------------------===//

It may be worth avoiding creation of alloca's for formal arguments
for the common situation where the argument is never written to or has
its address taken. The idea would be to begin generating code by using
the argument directly and if its address is taken or it is stored to
then generate the alloca and patch up the existing code.

In theory, the same optimization could be a win for block local
variables as long as the declaration dominates all statements in the
block.

NOTE: The main case we care about this for is for -O0 -g compile time
performance, and in that scenario we will need to emit the alloca
anyway currently to emit proper debug info. So this is blocked by
being able to emit debug information which refers to an LLVM
temporary, not an alloca.

//===---------------------------------------------------------------------===//

We should try and avoid generating basic blocks which only contain
jumps. At -O0, this penalizes us all the way from IRgen (malloc &
instruction overhead), all the way down through code generation and
assembly time.

On 176.gcc:expr.ll, it looks like over 12% of basic blocks are just
direct branches!

//===---------------------------------------------------------------------===//