llvm-project/clang/lib/CodeGen
Daniel Sanders aa748a8db5 Preserve early clobber flag when using named registers in inline assembly.
Summary:
Named registers with the constraint "=&r" currently lose the early clobber flag
and turn into "=r" when converted to LLVM-IR. This patch correctly passes it on.

Reviewers: atanasyan

Reviewed By: atanasyan

Subscribers: cfe-commits

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

llvm-svn: 228143
2015-02-04 14:25:47 +00:00
..
ABIInfo.h Fix invalid calling convention used for libcalls on ARM. 2014-12-02 16:04:58 +00:00
BackendUtil.cpp [multiversion] Update Clang for the API change in LLVM r227731. 2015-02-01 12:26:23 +00:00
CGAtomic.cpp [OPENMP] CodeGen for "omp atomic read [seq_cst]" directive. 2015-01-22 06:17:56 +00:00
CGBlocks.cpp Address review feedback for r228003. 2015-02-03 20:00:54 +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 MS ABI: Implement proper support for setjmp 2015-01-29 09:29:21 +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 Don't use a doc comment in a function body. 2015-01-12 21:22:27 +00:00
CGCXXABI.cpp MS ABI: Implement thread_local for global variables 2014-10-05 05:05:40 +00:00
CGCXXABI.h MS ABI: Add CodeGen support for rethrowing MS C++ exceptions 2014-11-25 07:20:20 +00:00
CGCall.cpp Sema: Add support for __declspec(restrict) 2015-02-04 07:23:21 +00:00
CGCall.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGClass.cpp CodeGen: Copy-ctorm must obey the destination's alignment requirement 2015-02-03 23:04:06 +00:00
CGCleanup.cpp Address review feedback for r228003. 2015-02-03 20:00:54 +00:00
CGCleanup.h Update for LLVM API change to make Small(Ptr)Set::insert return pair<iterator, bool> as per the C++ standard's associative container concept. 2014-11-19 07:49:47 +00:00
CGDebugInfo.cpp CodeGen: Update for LLVM API change in r228030 2015-02-03 21:25:34 +00:00
CGDebugInfo.h CodeGen: Update for LLVM API change in r228030 2015-02-03 21:25:34 +00:00
CGDecl.cpp Address review feedback for r228003. 2015-02-03 20:00:54 +00:00
CGDeclCXX.cpp Address review feedback for r228003. 2015-02-03 20:00:54 +00:00
CGException.cpp SEH: Track users of __try so we can pick a per-func EH personality 2015-02-03 22:52:35 +00:00
CGExpr.cpp DebugInfo: Attribute calls to overloaded operators with the operator, not the start of the whole expression 2015-01-25 01:25:37 +00:00
CGExprAgg.cpp DebugInfo: Use the preferred location rather than the start location for expression line info 2015-01-25 01:19:10 +00:00
CGExprCXX.cpp DebugInfo: Use the preferred location rather than the start location for expression line info 2015-01-25 01:19:10 +00:00
CGExprComplex.cpp DebugInfo: Use the preferred location rather than the start location for expression line info 2015-01-25 01:19:10 +00:00
CGExprConstant.cpp CodeGen: Optimize emssion of zeroinitialzied arrays 2014-12-28 23:46:59 +00:00
CGExprScalar.cpp DebugInfo: Ensure calls to functions with default arguments which themselves have default arguments, still have locations. 2015-02-03 22:37:17 +00:00
CGLoopInfo.cpp CodeGen: Update LoopAttributes for LLVM API change 2015-01-19 21:30:48 +00:00
CGLoopInfo.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGObjC.cpp DebugInof: Correct the location of exception cleanups in global ctors/dtors and ObjC methods 2015-01-14 07:10:46 +00:00
CGObjCGNU.cpp Replace size() calls on containers with empty() calls where appropriate. NFC 2015-01-23 15:36:10 +00:00
CGObjCMac.cpp Implement the __builtin_call_with_static_chain GNU extension. 2014-12-12 23:41:25 +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 Support ‘omp for’ with static chunked schedule kind. 2015-01-22 08:49:35 +00:00
CGOpenMPRuntime.h Support ‘omp for’ with static chunked schedule kind. 2015-01-22 08:49:35 +00:00
CGRecordLayout.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGRecordLayoutBuilder.cpp CodeGen: Cleanup CGRecordLowering::lowerUnion a little 2014-10-15 16:36:11 +00:00
CGStmt.cpp Preserve early clobber flag when using named registers in inline assembly. 2015-02-04 14:25:47 +00:00
CGStmtOpenMP.cpp Address review feedback for r228003. 2015-02-03 20:00:54 +00:00
CGVTT.cpp Use a trivial comdat for C++ tables. 2015-01-15 23:18:01 +00:00
CGVTables.cpp Add comdat to thunks. 2015-01-19 14:02:14 +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: Prune a redundant "Target" out of libdeps. It is supplied by Analysis. 2015-01-15 08:51:01 +00:00
CodeGenABITypes.cpp Implement the __builtin_call_with_static_chain GNU extension. 2014-12-12 23:41:25 +00:00
CodeGenAction.cpp Make a codegen warning a real warning instead of a getCustomDiagID(). 2015-01-29 06:25:59 +00:00
CodeGenFunction.cpp DebugInfo: Fix line table for comparisons harder/better for the sake of C (& the GDB buildbot) 2015-01-31 01:10:11 +00:00
CodeGenFunction.h CodeGen: Copy-ctorm must obey the destination's alignment requirement 2015-02-03 23:04:06 +00:00
CodeGenModule.cpp MS ABI: Records with fields with required aligmnet shouldn't be common 2015-02-03 08:49:32 +00:00
CodeGenModule.h [pr22293] Don't crash during codegen of a recursive destructor. 2015-01-23 05:26:38 +00:00
CodeGenPGO.cpp InstrProf: Avoid creating profile names for symbols in system headers 2015-01-22 02:17:23 +00:00
CodeGenPGO.h InstrProf: Use LLVM's -instrprof pass for profiling 2014-12-08 19:04:51 +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 Use nullptr to silence -Wsentinel when self-hosting on Windows 2014-12-01 22:02:27 +00:00
CodeGenTypes.h Implement the __builtin_call_with_static_chain GNU extension. 2014-12-12 23:41:25 +00:00
CoverageMappingGen.cpp InstrProf: Update for LLVM API change 2015-02-03 23:59:48 +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 Silence a warning from MSVC "14" by making an enum unsigned 2014-10-31 23:33:56 +00:00
ItaniumCXXABI.cpp Use a trivial comdat for C++ tables. 2015-01-15 23:18:01 +00:00
Makefile
MicrosoftCXXABI.cpp MS ABI: Implement support for 'novtable' 2015-02-02 10:22:20 +00:00
ModuleBuilder.cpp Wrap to 80 columns. No behavior change. 2015-01-17 02:27:54 +00:00
README.txt
SanitizerMetadata.cpp IR: Update clang for Metadata/Value split in r223802 2014-12-09 18:39:32 +00:00
SanitizerMetadata.h [cleanup] Re-sort *all* #include lines with llvm/utils/sort_includes.py 2015-01-14 11:29:14 +00:00
TargetInfo.cpp CodeGen: create a WindowsARMTargetCodeGenInfo 2015-01-30 23:29:19 +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!

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