llvm-project/clang/lib/CodeGen
Yi Kong 4d5e23f53a ARM: Implement __builtin_arm_nop intrinsic
This patch implements __builtin_arm_nop intrinsic for AArch32 and AArch64,
which generates hint 0x0, the alias of NOP instruction.

This intrinsic is necessary to implement ACLE __nop intrinsic.

Differential Revision: http://reviews.llvm.org/D4495

llvm-svn: 212947
2014-07-14 15:20:09 +00:00
..
ABIInfo.h Sort all the #include lines with LLVM's utils/sort_includes.py which 2014-01-07 11:51:46 +00:00
BackendUtil.cpp [ASan] Completely remove sanitizer blacklist file from instrumentation pass. 2014-07-08 00:50:49 +00:00
CGAtomic.cpp Atomics: emit "cmpxchg weak" where possible 2014-06-13 19:43:04 +00:00
CGBlocks.cpp Implement -Wframe-larger-than backend diagnostic 2014-06-05 22:10:59 +00:00
CGBlocks.h Don't indent inside namespaces. 2014-05-09 00:26:20 +00:00
CGBuilder.h This patch adds a helper class (CGLoopInfo) for marking memory instructions with llvm.mem.parallel_loop_access metadata. 2014-05-22 08:54:05 +00:00
CGBuiltin.cpp ARM: Implement __builtin_arm_nop intrinsic 2014-07-14 15:20:09 +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 [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +00:00
CGCUDARuntime.h CUDA: IR generation support for device stubs 2011-10-06 18:51:56 +00:00
CGCXX.cpp Update for llvm API change. 2014-06-03 02:42:01 +00:00
CGCXXABI.cpp CodeGen: Refactor RTTI emission 2014-07-07 06:20:47 +00:00
CGCXXABI.h CodeGen: Refactor RTTI emission 2014-07-07 06:20:47 +00:00
CGCall.cpp Add nonnull in CodeGen for __attribute__((returns_nonnull)) 2014-07-12 04:51:04 +00:00
CGCall.h [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +00:00
CGClass.cpp Convert some function arguments to use ArrayRef. 2014-06-26 04:58:53 +00:00
CGCleanup.cpp [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +00:00
CGCleanup.h Update for llvm api change. 2014-06-04 18:51:46 +00:00
CGDebugInfo.cpp Add new debug kind LocTrackingOnly. 2014-06-24 17:02:17 +00:00
CGDebugInfo.h Fix 'source-level' hyphenations 2014-07-09 14:06:35 +00:00
CGDecl.cpp [ASan] Collect unmangled names of global variables in Clang to print them in error reports. 2014-07-12 00:42:52 +00:00
CGDeclCXX.cpp [Sanitizer] Reduce the usage of sanitizer blacklist in CodeGenModule 2014-07-07 23:34:34 +00:00
CGException.cpp Add an AST node for __leave statements, hook it up. 2014-07-07 00:12:30 +00:00
CGExpr.cpp [UBSan] Introduce type-based blacklisting. 2014-07-10 22:34:19 +00:00
CGExprAgg.cpp A non-trivial array-fill expression isn't necessarily a CXXConstructExpr. It 2014-06-13 23:04:49 +00:00
CGExprCXX.cpp Revert "Revert r211402 (and r211408,r211410), "CodeGen: Refactor dynamic_cast and typeid" It crashes msvc codegen in clang/test/SemaCXX/undefined-internal.cpp." 2014-06-22 19:05:33 +00:00
CGExprComplex.cpp [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +00:00
CGExprConstant.cpp [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +00:00
CGExprScalar.cpp Fix the dtor location issues in PR20038 harder. 2014-07-10 20:42:59 +00:00
CGLoopInfo.cpp Rename loop unrolling and loop vectorizer metadata to have a common prefix. 2014-06-25 15:42:16 +00:00
CGLoopInfo.h Rename loop unrolling and loop vectorizer metadata to have a common prefix. 2014-06-25 15:42:16 +00:00
CGObjC.cpp [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +00:00
CGObjCGNU.cpp Remove the overload of GetAddrOfConstantString method 2014-06-04 20:25:57 +00:00
CGObjCMac.cpp Don't assume StringRef.data() is null-terminated 2014-07-11 00:43:47 +00:00
CGObjCRuntime.cpp Update for llvm api change. 2014-06-04 18:51:46 +00:00
CGObjCRuntime.h [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +00:00
CGOpenCLRuntime.cpp [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +00:00
CGOpenCLRuntime.h Rewrite #includes for llvm/Foo.h to llvm/IR/Foo.h as appropriate to 2013-01-02 11:45:17 +00:00
CGOpenMPRuntime.cpp [OPENMP] Reformatting and code improvement. 2014-06-18 07:08:49 +00:00
CGOpenMPRuntime.h [OPENMP] Reformatting and code improvement. 2014-06-18 07:08:49 +00:00
CGRecordLayout.h When a module completes the definition of a class template specialization imported from another module, emit an update record, rather than using the broken decl rewriting mechanism. If multiple modules do this, merge the definitions together, much as we would if they were separate declarations. 2014-04-19 03:48:30 +00:00
CGRecordLayoutBuilder.cpp [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +00:00
CGStmt.cpp [OPENMP] Parsing and sema analysis for 'omp task' directive. 2014-07-11 11:25:16 +00:00
CGStmtOpenMP.cpp [OPENMP] Parsing and sema analysis for 'omp task' directive. 2014-07-11 11:25:16 +00:00
CGVTT.cpp Remove the -fhidden-weak-vtables -cc1 option. It was dead, 2014-02-08 00:41:16 +00:00
CGVTables.cpp MS ABI: Reference MSVC RTTI from the VFTable 2014-07-01 20:30:31 +00:00
CGVTables.h MS ABI: Reference MSVC RTTI from the VFTable 2014-07-01 20:30:31 +00:00
CGValue.h [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +00:00
CMakeLists.txt [CMake] Update libdeps. 2014-07-14 05:01:53 +00:00
CodeGenABITypes.cpp Remove llvm:: from uses of ArrayRef. 2014-06-28 23:22:23 +00:00
CodeGenAction.cpp CodeGenAction::ExecuteAction(): check for invalid LLVM source locations 2014-06-30 01:33:59 +00:00
CodeGenFunction.cpp Remove unnecessary check for NULL 2014-07-08 20:23:18 +00:00
CodeGenFunction.h [OPENMP] Parsing and sema analysis for 'omp task' directive. 2014-07-11 11:25:16 +00:00
CodeGenModule.cpp [ASan] Collect unmangled names of global variables in Clang to print them in error reports. 2014-07-12 00:42:52 +00:00
CodeGenModule.h [ASan] Collect unmangled names of global variables in Clang to print them in error reports. 2014-07-12 00:42:52 +00:00
CodeGenPGO.cpp CodeGen: Improve warnings about uninstrumented files when profiling 2014-06-26 01:45:07 +00:00
CodeGenPGO.h CodeGen: Improve warnings about uninstrumented files when profiling 2014-06-26 01:45:07 +00:00
CodeGenTBAA.cpp [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +00:00
CodeGenTBAA.h Fixed comment typo. 2013-06-08 00:27:19 +00:00
CodeGenTypes.cpp [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +00:00
CodeGenTypes.h Fix the comment which was backwards. 2014-06-17 17:09:24 +00:00
EHScopeStack.h [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +00:00
ItaniumCXXABI.cpp CodeGen: Don't emit a thread-wrapper if we can't touch the backing variable 2014-07-11 20:28:10 +00:00
Makefile
MicrosoftCXXABI.cpp MS ABI: Stick internal vftables in a comdat if they have RTTI data 2014-07-13 05:19:56 +00:00
ModuleBuilder.cpp Defer codegen of inline method definitions to the end of current top level declaration 2014-06-06 17:36:17 +00:00
README.txt
SanitizerBlacklist.cpp [UBSan] Introduce type-based blacklisting. 2014-07-10 22:34:19 +00:00
SanitizerBlacklist.h [UBSan] Introduce type-based blacklisting. 2014-07-10 22:34:19 +00:00
TargetInfo.cpp [PowerPC] ABI support for aligned by-value aggregates 2014-07-10 17:20:07 +00:00
TargetInfo.h [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +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!

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