llvm-project/clang/lib/CodeGen
John McCall 8460bcaa33 Honor the casted-to alignment of an explicit cast even when
Sema thinks the cast is a no-op, as it does when (e.g.) the
only thing that changes is an alignment attribute.

Fixed PR24944.

llvm-svn: 248775
2015-09-29 04:37:40 +00:00
..
ABIInfo.h Support __builtin_ms_va_list. 2015-09-17 20:55:33 +00:00
Address.h Compute and preserve alignment more faithfully in IR-generation. 2015-09-08 08:05:57 +00:00
BackendUtil.cpp Replace a loop and temporary string copying with llvm::join. 2015-09-26 01:25:08 +00:00
CGAtomic.cpp Decorating vptr load & stores with !invariant.group 2015-09-15 21:46:55 +00:00
CGBlocks.cpp When comparing two block captures for layout, don't crash 2015-09-11 22:00:51 +00:00
CGBlocks.h Move BlockByrefHelpers back to CodeGenModule.h to placate MSVC. 2015-09-08 08:21:11 +00:00
CGBuilder.h Remove unnecessary braces; this resolves against a 2015-09-08 08:57:00 +00:00
CGBuiltin.cpp [CUDA] Allow parsing of host and device code simultaneously. 2015-09-22 17:23:22 +00:00
CGCUDANV.cpp Compute and preserve alignment more faithfully in IR-generation. 2015-09-08 08:05:57 +00:00
CGCUDARuntime.cpp Pass expressions instead of argument ranges to EmitCall/EmitCXXConstructorCall. 2014-08-21 20:26:47 +00:00
CGCUDARuntime.h Revert r240270 ("Fixed/added namespace ending comments using clang-tidy"). 2015-06-22 23:07:51 +00:00
CGCXX.cpp Revert "Always_inline codegen rewrite" and 2 follow-ups. 2015-09-14 21:35:16 +00:00
CGCXXABI.cpp [WinEH] Pass the catch adjectives to catchpad directly 2015-09-16 20:15:55 +00:00
CGCXXABI.h [WinEH] Pass the catch adjectives to catchpad directly 2015-09-16 20:15:55 +00:00
CGCall.cpp Support __builtin_ms_va_list. 2015-09-17 20:55:33 +00:00
CGCall.h Compute and preserve alignment more faithfully in IR-generation. 2015-09-08 08:05:57 +00:00
CGClass.cpp Generate assume loads only with -fstrict-vtable-pointers 2015-09-28 20:30:22 +00:00
CGCleanup.cpp [SEH] Use cleanupendpad so that WinEHPrepare gets the coloring right 2015-09-10 22:11:13 +00:00
CGCleanup.h [WinEH] Pass the catch adjectives to catchpad directly 2015-09-16 20:15:55 +00:00
CGDebugInfo.cpp Module Debugging: Emit submodules as nested DW_TAG_modules. 2015-09-24 16:10:10 +00:00
CGDebugInfo.h Debug Info: Use the module pointer as key for the module cache. 2015-09-24 16:10:04 +00:00
CGDecl.cpp Fix a nasty bug with the partial destruction of nested arrays; 2015-09-14 18:57:08 +00:00
CGDeclCXX.cpp Compute and preserve alignment more faithfully in IR-generation. 2015-09-08 08:05:57 +00:00
CGException.cpp Use the MSVC SEH personalities on Mingw 2015-09-17 17:04:13 +00:00
CGExpr.cpp Honor the casted-to alignment of an explicit cast even when 2015-09-29 04:37:40 +00:00
CGExprAgg.cpp Support __builtin_ms_va_list. 2015-09-17 20:55:33 +00:00
CGExprCXX.cpp Decorating vptr load & stores with !invariant.group 2015-09-15 21:46:55 +00:00
CGExprComplex.cpp Support __builtin_ms_va_list. 2015-09-17 20:55:33 +00:00
CGExprConstant.cpp Compute and preserve alignment more faithfully in IR-generation. 2015-09-08 08:05:57 +00:00
CGExprScalar.cpp Support __builtin_ms_va_list. 2015-09-17 20:55:33 +00:00
CGLoopInfo.cpp Add new llvm.loop.unroll.enable metadata for use with "#pragma unroll". 2015-08-10 17:29:39 +00:00
CGLoopInfo.h Add new llvm.loop.unroll.enable metadata for use with "#pragma unroll". 2015-08-10 17:29:39 +00:00
CGObjC.cpp ARC: Fix the precise-lifetime suppression of returns_inner_pointer 2015-09-09 23:37:17 +00:00
CGObjCGNU.cpp Revert "[opaque pointer type] update for LLVM API change" 2015-09-14 18:02:04 +00:00
CGObjCMac.cpp Support noreturn in limited contexts on Objective-C message sends. 2015-09-10 22:27:50 +00:00
CGObjCRuntime.cpp Compute and preserve alignment more faithfully in IR-generation. 2015-09-08 08:05:57 +00:00
CGObjCRuntime.h Compute and preserve alignment more faithfully in IR-generation. 2015-09-08 08:05:57 +00:00
CGOpenCLRuntime.cpp [OpenCL] Add new types for OpenCL 2.0. 2015-09-15 11:18:52 +00:00
CGOpenCLRuntime.h Revert r240270 ("Fixed/added namespace ending comments using clang-tidy"). 2015-06-22 23:07:51 +00:00
CGOpenMPRuntime.cpp Remove 'const' from some ArrayRef arguments since they're passed by value anyway. NFC 2015-09-29 04:30:07 +00:00
CGOpenMPRuntime.h [OPENMP 4.1] Codegen for ‘simd’ clause in ‘ordered’ directive. 2015-09-29 03:48:57 +00:00
CGRecordLayout.h Respect alignment of nested bitfields 2015-07-10 17:30:00 +00:00
CGRecordLayoutBuilder.cpp Respect alignment of nested bitfields 2015-07-10 17:30:00 +00:00
CGStmt.cpp convert builtin_unpredictable on a switch into metadata for LLVM 2015-09-09 22:39:06 +00:00
CGStmtOpenMP.cpp [OPENMP 4.1] Codegen for ‘simd’ clause in ‘ordered’ directive. 2015-09-29 03:48:57 +00:00
CGVTT.cpp Remove and forbid raw_svector_ostream::flush() calls. 2015-08-13 18:12:56 +00:00
CGVTables.cpp Generating assumption loads of vptr after ctor call (fixed) 2015-09-15 00:37:06 +00:00
CGVTables.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGValue.h Introduce __builtin_nontemporal_store and __builtin_nontemporal_load. 2015-09-08 23:52:33 +00:00
CMakeLists.txt [CMake] Fill up required libs, corresponding to r241653. 2015-07-08 02:06:21 +00:00
CodeGenABITypes.cpp Unique-pointerify these pointers an plug a memory leak. 2015-09-28 23:56:10 +00:00
CodeGenAction.cpp [CUDA] Postprocess bitcode linked in during device-side CUDA compilation. 2015-09-10 18:24:23 +00:00
CodeGenFunction.cpp Support __builtin_ms_va_list. 2015-09-17 20:55:33 +00:00
CodeGenFunction.h Support __builtin_ms_va_list. 2015-09-17 20:55:33 +00:00
CodeGenModule.cpp Use llvm::makeArrayRef. NFC. 2015-09-27 03:44:08 +00:00
CodeGenModule.h [WinEH] Pass the catch adjectives to catchpad directly 2015-09-16 20:15:55 +00:00
CodeGenPGO.cpp Switch users of the 'for (StmtRange range = stmt->children(); range; ++range)‘ pattern to range for loops. 2015-07-02 21:03:14 +00:00
CodeGenPGO.h InstrProf: Cede ownership of createProfileWeights to CGF 2015-05-02 05:00:55 +00:00
CodeGenTBAA.cpp Remove and forbid raw_svector_ostream::flush() calls. 2015-08-13 18:12:56 +00:00
CodeGenTBAA.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CodeGenTypeCache.h Compute and preserve alignment more faithfully in IR-generation. 2015-09-08 08:05:57 +00:00
CodeGenTypes.cpp [OpenCL] Add new types for OpenCL 2.0. 2015-09-15 11:18:52 +00:00
CodeGenTypes.h Remove superfluous private:, TypeCache is private by default. 2015-08-13 07:12:03 +00:00
CoverageMappingGen.cpp Remove move constructor and assignment operator from SourceMappingRegion. The types of the fields are trivially copyable. NFC 2015-09-26 05:10:16 +00:00
CoverageMappingGen.h [cleanup] Re-sort *all* #include lines with llvm/utils/sort_includes.py 2015-01-14 11:29:14 +00:00
EHScopeStack.h [SEH] Use cleanupendpad so that WinEHPrepare gets the coloring right 2015-09-10 22:11:13 +00:00
ItaniumCXXABI.cpp [WinEH] Pass the catch adjectives to catchpad directly 2015-09-16 20:15:55 +00:00
Makefile
MicrosoftCXXABI.cpp [WinEH] Pass the catch adjectives to catchpad directly 2015-09-16 20:15:55 +00:00
ModuleBuilder.cpp Rename DescriptionString -> DataLayoutString as it matches the actual 2015-08-05 23:48:05 +00:00
ObjectFilePCHContainerOperations.cpp Module Debugging: Use the clang module signature as the module's dwo_id 2015-09-22 23:26:43 +00:00
README.txt
SanitizerMetadata.cpp [ASan] Initial support for Kernel AddressSanitizer 2015-06-19 12:19:07 +00:00
SanitizerMetadata.h Removing LLVM_DELETED_FUNCTION, as MSVC 2012 was the last reason for requiring the macro. NFC; Clang edition. 2015-02-15 22:54:08 +00:00
TargetInfo.cpp Support __builtin_ms_va_list. 2015-09-17 20:55:33 +00:00
TargetInfo.h [OPENMP] Introduced type trait "__builtin_omp_required_simd_align" for default simd alignment. 2015-07-02 03:40:19 +00:00

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!

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