llvm-project/clang/lib/CodeGen
Yi Kong 1083eb5c11 AArch64: Resolve some FIXMEs in CGBuiltin left over from backend merge
Merge vrshr_n_v and vqshlu_n_v with ARM.

Remove FIXME comments for others as they can't actually be shared.

NFC.

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

llvm-svn: 214173
2014-07-29 09:25:17 +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 Use -enable-global-merge option to match llvm r210639. <rdar://problem/17803206> 2014-07-26 00:37:28 +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 AArch64: Resolve some FIXMEs in CGBuiltin left over from backend merge 2014-07-29 09:25:17 +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
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 MS compatibility: always emit dllexported in-class initialized static data members (PR20140) 2014-07-17 20:25:23 +00:00
CGCall.cpp MS ABI: Use musttail for vtable thunks that pass arguments by value 2014-07-26 01:34:32 +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 [Debug Info] add DISubroutineType and its creation takes DITypeArray. 2014-07-28 22:24:34 +00:00
CGDebugInfo.h Fix 'source-level' hyphenations 2014-07-09 14:06:35 +00:00
CGDecl.cpp MS ABI: Don't push destructor cleanups for aggregate parameters in thunks 2014-07-25 21:39:46 +00:00
CGDeclCXX.cpp -fms-extensions: Implement half of #pragma init_seg 2014-07-22 00:53:05 +00:00
CGException.cpp Add an AST node for __leave statements, hook it up. 2014-07-07 00:12:30 +00:00
CGExpr.cpp Revert "Emit column debug information for loads" 2014-07-29 06:53:14 +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 CodeGen: Properly null-check typeid expressions 2014-07-19 00:17:06 +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 [UBSan] Add !nosanitize metadata to the code generated by UBSan. 2014-07-17 18:46:27 +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 Rename metadata llvm.loop.vectorize.unroll to llvm.loop.vectorize.interleave. 2014-07-21 23:10:56 +00:00
CGObjC.cpp Track the difference between 2014-07-17 05:12:35 +00:00
CGObjCGNU.cpp Remove the overload of GetAddrOfConstantString method 2014-06-04 20:25:57 +00:00
CGObjCMac.cpp AArch64: update Clang for merged arm64/aarch64 triples. 2014-07-23 12:32:58 +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] Improved codegen for outlined functions for 'parallel' directives. 2014-07-25 07:55:17 +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 Add a location to MS inline asm blobs 2014-07-28 23:12:59 +00:00
CGStmtOpenMP.cpp [OPENMP] Initial parsing and sema analysis for 'atomic' directive. 2014-07-22 10:10:35 +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: Use musttail for vtable thunks that pass arguments by value 2014-07-26 01:34:32 +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 Recommit: Handle diagnostic warnings in Frontend diagnostic handler. 2014-07-18 19:40:19 +00:00
CodeGenFunction.cpp MS ABI: Don't push destructor cleanups for aggregate parameters in thunks 2014-07-25 21:39:46 +00:00
CodeGenFunction.h MS ABI: Use musttail for vtable thunks that pass arguments by value 2014-07-26 01:34:32 +00:00
CodeGenModule.cpp Make sure globals created by UBSan are not instrumented by ASan. 2014-07-18 17:50:06 +00:00
CodeGenModule.h -fms-extensions: Implement half of #pragma init_seg 2014-07-22 00:53:05 +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: Use musttail for vtable thunks that pass arguments by value 2014-07-26 01:34:32 +00:00
ModuleBuilder.cpp MS compatibility: always emit dllexported in-class initialized static data members (PR20140) 2014-07-17 20:25:23 +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] Support ELFv1/ELFv2 ABI selection via -mabi= option 2014-07-28 13:17:52 +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!

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