llvm-project/clang/lib/CodeGen
Alexey Bataev b205978100 [OPENMP] Codegen for 'num_threads' clause in 'parallel' directive.
This patch generates call to "kmpc_push_num_threads(ident_t *loc, kmp_int32 global_tid, kmp_int32 num_threads);" library function before calling "kmpc_fork_call" each time there is an associated "num_threads" clause in the "omp parallel" directive.
Differential Revision: http://reviews.llvm.org/D5145

llvm-svn: 219599
2014-10-13 08:23:51 +00:00
..
ABIInfo.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
BackendUtil.cpp CFE Knob for: Add a thread-model knob for lowering atomics on baremetal & single threaded systems 2014-10-03 21:57:44 +00:00
CGAtomic.cpp CodeGen: Don't completely mess-up optimized atomic libcalls 2014-08-29 07:27:49 +00:00
CGBlocks.cpp Fix a crash when compiling blocks in OpenCL with multiple 2014-08-14 09:37:50 +00:00
CGBlocks.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGBuilder.h typo 2014-09-10 16:59:01 +00:00
CGBuiltin.cpp Add __sync_fetch_and_nand (again) 2014-10-02 20:53:50 +00:00
CGCUDANV.cpp [C++11] Add 'override' keyword to virtual methods that override their base class. 2014-03-12 06:41:41 +00:00
CGCUDARuntime.cpp Pass expressions instead of argument ranges to EmitCall/EmitCXXConstructorCall. 2014-08-21 20:26:47 +00:00
CGCUDARuntime.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGCXX.cpp Allow dllexport alias to base destructors. 2014-10-07 13:34:42 +00:00
CGCXXABI.cpp MS ABI: Implement thread_local for global variables 2014-10-05 05:05:40 +00:00
CGCXXABI.h MS ABI: Implement thread_local for global variables 2014-10-05 05:05:40 +00:00
CGCall.cpp Promote null pointer constants used as arguments to variadic functions 2014-10-10 00:05:45 +00:00
CGCall.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGClass.cpp CodeGen: FieldMemcpyizer didn't handle copies starting inside bitfields 2014-10-10 18:57:10 +00:00
CGCleanup.cpp Revert r218865 because it introduced PR21236, a crash in codegen emitting the try block. 2014-10-10 04:05:00 +00:00
CGCleanup.h Replace a destructor of EHCleanupScope with a Destroy() method to reflect the current usage. 2014-10-08 18:31:54 +00:00
CGDebugInfo.cpp Using an explicit cast to work around MSVC 2013 not picking the conversion operator as expected. NFC, should fix the MSVC build bots. 2014-10-06 12:42:31 +00:00
CGDebugInfo.h Include debug info for types referenced only via explicit cast expressions. 2014-09-24 17:01:27 +00:00
CGDecl.cpp Revert r218865 because it introduced PR21236, a crash in codegen emitting the try block. 2014-10-10 04:05:00 +00:00
CGDeclCXX.cpp MS ABI: Implement thread_local for global variables 2014-10-05 05:05:40 +00:00
CGException.cpp CodeGen: Strip qualifiers from qualified array types in catches 2014-10-12 06:58:22 +00:00
CGExpr.cpp Revert r218865 because it introduced PR21236, a crash in codegen emitting the try block. 2014-10-10 04:05:00 +00:00
CGExprAgg.cpp PR18097: Support initializing an _Atomic(T) from an object of C++ class type T 2014-07-31 06:31:19 +00:00
CGExprCXX.cpp Fix bug 20116 - http://llvm.org/bugs/show_bug.cgi?id=20116 2014-09-29 10:32:21 +00:00
CGExprComplex.cpp [complex] Use the much more powerful EmitCall routine to call libcalls 2014-10-11 09:24:41 +00:00
CGExprConstant.cpp Fix IRGen for referencing a static local before emitting its decl 2014-10-08 01:07:54 +00:00
CGExprScalar.cpp Suppress a warning about an unused variable in NDEBUG builds. 2014-10-11 11:29:26 +00:00
CGLoopInfo.cpp Rename metadata llvm.loop.vectorize.unroll to llvm.loop.vectorize.interleave. 2014-07-21 23:10:56 +00:00
CGLoopInfo.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGObjC.cpp Simplify creation of a bunch of ArrayRefs by using None, makeArrayRef or just letting them be implicitly created. 2014-08-27 06:28:36 +00:00
CGObjCGNU.cpp Fix some cases where StringRef was being passed by const reference. Remove const from some other StringRefs since its implicitly const already. 2014-08-30 16:55:52 +00:00
CGObjCMac.cpp Allow protocols to be just declared. 2014-09-12 20:14:20 +00:00
CGObjCRuntime.cpp Update for llvm api change. 2014-06-04 18:51:46 +00:00
CGObjCRuntime.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGOpenCLRuntime.cpp [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +00:00
CGOpenCLRuntime.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGOpenMPRuntime.cpp [OPENMP] Codegen for 'num_threads' clause in 'parallel' directive. 2014-10-13 08:23:51 +00:00
CGOpenMPRuntime.h [OPENMP] Codegen for 'num_threads' clause in 'parallel' directive. 2014-10-13 08:23:51 +00:00
CGRecordLayout.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGRecordLayoutBuilder.cpp CodeGen: Don't crash when initializing pointer-to-member fields in bases 2014-09-28 06:39:30 +00:00
CGStmt.cpp Allow constant expressions in pragma loop hints. 2014-10-12 20:46:07 +00:00
CGStmtOpenMP.cpp [OPENMP] Codegen for 'num_threads' clause in 'parallel' directive. 2014-10-13 08:23:51 +00:00
CGVTT.cpp Remove the -fhidden-weak-vtables -cc1 option. It was dead, 2014-02-08 00:41:16 +00:00
CGVTables.cpp Simplify a few loops over CallArgList/FunctionArgList. NFC 2014-08-13 20:06:24 +00:00
CGVTables.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGValue.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CMakeLists.txt [CMake] clangCodeGen: Update libdeps to add clangLex for PPChainedCallbacks. 2014-08-05 15:01:12 +00:00
CodeGenABITypes.cpp Add coverage mapping generation. 2014-08-04 18:41:51 +00:00
CodeGenAction.cpp Unique_ptrify PPCallbacks ownership. 2014-09-10 04:53:53 +00:00
CodeGenFunction.cpp Revert r218865 because it introduced PR21236, a crash in codegen emitting the try block. 2014-10-10 04:05:00 +00:00
CodeGenFunction.h Unfriend CGOpenMPRegionInfo so it can go into an anonymous namespace. 2014-10-10 13:57:57 +00:00
CodeGenModule.cpp Fix for bug http://llvm.org/PR17427. 2014-10-09 08:45:04 +00:00
CodeGenModule.h Fix for bug http://llvm.org/PR17427. 2014-10-09 08:45:04 +00:00
CodeGenPGO.cpp Reapply "InstrProf: Update for the LLVM API change in r218879" 2014-10-02 16:44:01 +00:00
CodeGenPGO.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CodeGenTBAA.cpp [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +00:00
CodeGenTBAA.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CodeGenTypes.cpp MS ABI: Don't ICE for pointers to pointers to members of incomplete classes 2014-09-18 22:05:54 +00:00
CodeGenTypes.h Use ClangToLLVMArgsMapping in CodeGenTypes::GetFunctionType(). NFC. 2014-09-29 22:08:00 +00:00
CoverageMappingGen.cpp Reapply "InstrProf: Update for the LLVM API change in r218879" 2014-10-02 16:44:01 +00:00
CoverageMappingGen.h Reapply "InstrProf: Update for the LLVM API change in r218879" 2014-10-02 16:44:01 +00:00
EHScopeStack.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
ItaniumCXXABI.cpp MS ABI: Implement thread_local for global variables 2014-10-05 05:05:40 +00:00
Makefile
MicrosoftCXXABI.cpp MS ABI: Implement thread_local for global variables 2014-10-05 05:05:40 +00:00
ModuleBuilder.cpp [modules] Fix a rejects-valid resulting from emitting an inline function 2014-08-13 21:15:09 +00:00
README.txt
SanitizerBlacklist.cpp Fix some cases where StringRef was being passed by const reference. Remove const from some other StringRefs since its implicitly const already. 2014-08-30 16:55:52 +00:00
SanitizerBlacklist.h Fix for LLVM API change to SpecialCaseList::create 2014-09-02 18:13:58 +00:00
SanitizerMetadata.cpp [clang/asan] call __asan_poison_cxx_array_cookie after operator new[] 2014-08-26 02:29:59 +00:00
SanitizerMetadata.h [clang/asan] call __asan_poison_cxx_array_cookie after operator new[] 2014-08-26 02:29:59 +00:00
TargetInfo.cpp Add getOpenMPSimdDefaultAlignment for PowerPC 2014-10-03 17:45:20 +00:00
TargetInfo.h [OPENMP] Codegen of the ‘aligned’ clause for the ‘omp simd’ directive. 2014-09-30 05:29:28 +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!

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