llvm-project/clang/lib/CodeGen
Alexey Bataev 1189bd0205 [OPENMP 4.5] Allow arrays in 'reduction' clause.
OpenMP 4.5, alogn with array sections, allows to use variables of array type in reductions.

llvm-svn: 258804
2016-01-26 12:20:39 +00:00
..
ABIInfo.h Support __builtin_ms_va_list. 2015-09-17 20:55:33 +00:00
Address.h PR25368: Replace workaround for build failure with modules enabled with a fix 2015-11-05 21:16:22 +00:00
BackendUtil.cpp [ThinLTO] Leverage new in-place renaming support 2016-01-08 17:04:29 +00:00
CGAtomic.cpp [MSVC Compat] Don't provide /volatile:ms semantics to types > pointer 2016-01-22 16:36:44 +00:00
CGBlocks.cpp Update for LLVM function name change. 2016-01-14 21:00:27 +00:00
CGBlocks.h Move BlockByrefHelpers back to CodeGenModule.h to placate MSVC. 2015-09-08 08:21:11 +00:00
CGBuilder.h Revert "Change memcpy/memset/memmove to have dest and source alignments." 2015-11-19 05:55:59 +00:00
CGBuiltin.cpp Recommit: R258773 [OpenCL] Pipe builtin functions 2016-01-26 04:03:48 +00:00
CGCUDABuiltin.cpp [CUDA] Make printf work. 2016-01-23 21:28:14 +00:00
CGCUDANV.cpp [CUDA] Invoke ptxas and fatbinary during compilation. 2016-01-14 21:41:27 +00:00
CGCUDARuntime.cpp Roll-back r250822. 2015-10-20 13:23:58 +00:00
CGCUDARuntime.h Revert r240270 ("Fixed/added namespace ending comments using clang-tidy"). 2015-06-22 23:07:51 +00:00
CGCXX.cpp [COFF] Don't try to emit weak aliases on COFF 2015-11-10 22:23:58 +00:00
CGCXXABI.cpp Add the `pass_object_size` attribute to clang. 2015-12-02 21:58:08 +00:00
CGCXXABI.h Fix use-after-free when a C++ thread_local variable gets replaced (because its 2015-12-01 01:10:48 +00:00
CGCall.cpp Clang changes for value profiling 2016-01-23 22:50:44 +00:00
CGCall.h Don't emit exceptional stackrestore cleanups around inalloca functions 2015-10-08 00:17:45 +00:00
CGClass.cpp [cfi] Cross-DSO CFI diagnostic mode (clang part) 2016-01-25 23:34:52 +00:00
CGCleanup.cpp Update for LLVM function name change. 2016-01-14 21:00:27 +00:00
CGCleanup.h Update for LLVM function name change. 2016-01-14 21:00:27 +00:00
CGDebugInfo.cpp Module debugging: Create a parent DIModule with the PCH name for types 2016-01-22 21:14:41 +00:00
CGDebugInfo.h Module debugging: Create a parent DIModule with the PCH name for types 2016-01-22 21:14:41 +00:00
CGDecl.cpp Correctly handle type mismatches in the __weak copy/move-initialization 2015-11-16 22:11:41 +00:00
CGDeclCXX.cpp Fix use-after-free when a C++ thread_local variable gets replaced (because its 2015-12-01 01:10:48 +00:00
CGException.cpp Reland "[SEH] Use llvm.x86.seh.recoverfp for SEH filters on x64 as well as 32bit" 2015-12-16 00:26:37 +00:00
CGExpr.cpp Fix use of constexpr std::pair that's not in C++11. 2016-01-25 23:45:37 +00:00
CGExprAgg.cpp [Bugfix] Fix ICE on constexpr vector splat. 2016-01-13 01:52:39 +00:00
CGExprCXX.cpp [MS ABI] Tolerate invokes of __RTDynamicCast 2015-11-23 03:01:14 +00:00
CGExprComplex.cpp [Bugfix] Fix ICE on constexpr vector splat. 2016-01-13 01:52:39 +00:00
CGExprConstant.cpp Update for LLVM function name change. 2016-01-14 21:00:27 +00:00
CGExprScalar.cpp [Bugfix] Fix ICE on constexpr vector splat. 2016-01-13 01:52:39 +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 [PGO] Instrument only base constructors and destructors. 2015-12-06 14:32:39 +00:00
CGObjCGNU.cpp Preserve exceptions information during calls code generation. 2015-11-23 22:04:44 +00:00
CGObjCMac.cpp Update comments to match the implementation. 2016-01-25 22:37:47 +00:00
CGObjCRuntime.cpp Update for LLVM function name change. 2016-01-14 21:00:27 +00:00
CGObjCRuntime.h Reapply "[CodeGen] Fix assignments of inline layouts into the byref structure" 2015-12-21 20:21:15 +00:00
CGOpenCLRuntime.cpp [OpenCL] Pipe type support 2016-01-09 12:53:17 +00:00
CGOpenCLRuntime.h [OpenCL] Pipe type support 2016-01-09 12:53:17 +00:00
CGOpenMPRuntime.cpp [OPENMP 4.5] Allow arrays in 'reduction' clause. 2016-01-26 12:20:39 +00:00
CGOpenMPRuntime.h Fix -Wmicrosoft-enum-value warning 2016-01-11 20:55:16 +00:00
CGRecordLayout.h Respect alignment of nested bitfields 2015-07-10 17:30:00 +00:00
CGRecordLayoutBuilder.cpp Update for LLVM function name change. 2016-01-14 21:00:27 +00:00
CGStmt.cpp [OpenMP] Parsing + sema for "target exit data" directive. 2016-01-19 20:04:50 +00:00
CGStmtOpenMP.cpp [OPENMP 4.5] Allow arrays in 'reduction' clause. 2016-01-26 12:20:39 +00:00
CGVTT.cpp Remove and forbid raw_svector_ostream::flush() calls. 2015-08-13 18:12:56 +00:00
CGVTables.cpp [Driver] Add support for -fno-builtin-foo options. 2016-01-06 14:35:46 +00:00
CGVTables.h [CodeGen] Remove dead code. NFC. 2015-10-15 15:29:40 +00:00
CGValue.h Introduce __builtin_nontemporal_store and __builtin_nontemporal_load. 2015-09-08 23:52:33 +00:00
CMakeLists.txt [CUDA] Make printf work. 2016-01-23 21:28:14 +00:00
CodeGenABITypes.cpp Add the `pass_object_size` attribute to clang. 2015-12-02 21:58:08 +00:00
CodeGenAction.cpp Introduce -fsanitize-stats flag. 2016-01-16 00:31:22 +00:00
CodeGenFunction.cpp Introduce -fsanitize-stats flag. 2016-01-16 00:31:22 +00:00
CodeGenFunction.h [OPENMP 4.5] Allow arrays in 'reduction' clause. 2016-01-26 12:20:39 +00:00
CodeGenModule.cpp [cfi] Cross-DSO CFI diagnostic mode (clang part) 2016-01-25 23:34:52 +00:00
CodeGenModule.h Introduce -fsanitize-stats flag. 2016-01-16 00:31:22 +00:00
CodeGenPGO.cpp Clang changes for value profiling 2016-01-23 22:50:44 +00:00
CodeGenPGO.h [PGO] Windows buildbot failure fix. [NFC] 2016-01-24 00:56:19 +00:00
CodeGenTBAA.cpp Roll-back r250822. 2015-10-20 13:23:58 +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] Pipe type support 2016-01-09 12:53:17 +00:00
CodeGenTypes.h Add the `pass_object_size` attribute to clang. 2015-12-02 21:58:08 +00:00
CoverageMappingGen.cpp [Coverage] Reduce complexity of adding function mapping records 2016-01-21 19:25:35 +00:00
CoverageMappingGen.h [Coverage] Reduce complexity of adding function mapping records 2016-01-21 19:25:35 +00:00
EHScopeStack.h Update clang to use the updated LLVM EH instructions 2015-12-12 05:39:21 +00:00
ItaniumCXXABI.cpp [cfi] Do not emit bit set entry for available_externally vtables. 2016-01-23 01:20:18 +00:00
Makefile
MicrosoftCXXABI.cpp Cross-DSO control flow integrity (Clang part). 2015-12-15 23:00:20 +00:00
ModuleBuilder.cpp Introduce -fsanitize-stats flag. 2016-01-16 00:31:22 +00:00
ObjectFilePCHContainerOperations.cpp Module Debugging: Canonicalize the file names used as PCH module names 2016-01-22 23:30:56 +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 [X86] Support 'interrupt' attribute for x86 2016-01-15 04:06:31 +00:00
TargetInfo.h Fix Clang-tidy modernize-use-nullptr warnings in headers and generated files; other minor cleanups. 2015-09-29 20:56:43 +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!

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