llvm-project/clang/lib/CodeGen
Daniel Sanders 8d36a61f52 [mips] Correct alignment of vectors passed in varargs for the O32 ABI.
Summary:
Vectors are normally 16-byte aligned, however the O32 ABI enforces a
maximum alignment of 8-bytes since the base of the stack is 8-byte aligned.
Previously, this was enforced on the caller side, but not on the callee side.

This fixes the output of OpenCL's printf when given vectors.

Reviewers: atanasyan

Reviewed By: atanasyan

Subscribers: llvm-commits, pekka.jaaskelainen

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

llvm-svn: 218248
2014-09-22 13:27:06 +00:00
..
ABIInfo.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
BackendUtil.cpp Update for llvm api change. 2014-09-10 21:27:41 +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 __builtin_assume and __builtin_assume_aligned using @llvm.assume. 2014-09-07 22:58:14 +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 Reduce code duplication a bit more. NFC. 2014-09-15 19:34:18 +00:00
CGCXXABI.cpp Reverting r216675. This breaks some bots. Before this can be committed again, I have to explore runtime ABI requirements with libc++abi. 2014-08-28 17:24:14 +00:00
CGCXXABI.h MS ABI: Don't ICE for pointers to pointers to members of incomplete classes 2014-09-18 22:05:54 +00:00
CGCall.cpp Report source location of returns_nonnull attribute in UBSan reports. 2014-09-08 20:17:19 +00:00
CGCall.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGClass.cpp Add support for putting constructors and destructos in explicit comdats. 2014-09-16 15:18:21 +00:00
CGCleanup.cpp [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +00:00
CGCleanup.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGDebugInfo.cpp Debug info: Only emit C++ accessibility specifiers when they are diverging 2014-08-29 22:44:27 +00:00
CGDebugInfo.h Debug info: Only emit C++ accessibility specifiers when they are diverging 2014-08-29 22:44:27 +00:00
CGDecl.cpp DebugInfo: Blocks: Do not depend on LLVM argument numbering when choosing the debug info argument numbering. 2014-08-08 17:10:14 +00:00
CGDeclCXX.cpp Don't use the third field of llvm.global_ctors for MachO. 2014-09-19 01:54:22 +00:00
CGException.cpp Add -fseh-exceptions for MinGW-w64 2014-09-15 17:19:16 +00:00
CGExpr.cpp Merge GetAddrOfCXXConstructor and GetAddrOfCXXDonstructor. NFC. 2014-09-11 15:42:06 +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 Merge GetAddrOfCXXConstructor and GetAddrOfCXXDonstructor. NFC. 2014-09-11 15:42:06 +00:00
CGExprComplex.cpp [C++11] Use 'nullptr'. CodeGen edition. 2014-05-21 05:09:00 +00:00
CGExprConstant.cpp Allow __fp16 as a function arg or return type for AArch64 2014-08-27 16:31:57 +00:00
CGExprScalar.cpp Allow __fp16 as a function arg or return type for AArch64 2014-08-27 16:31:57 +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 removed unicode symbols from comments. 2014-09-22 12:32:31 +00:00
CGOpenMPRuntime.h removed unicode symbols from comments. 2014-09-22 12:32:31 +00:00
CGRecordLayout.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
CGRecordLayoutBuilder.cpp Revert "CodeGen: When bitfields fall on natural boundaries, split them up" 2014-08-14 15:44:29 +00:00
CGStmt.cpp [OPENMP] Initial parsing/sema analysis of 'target' directive. 2014-09-19 08:19:49 +00:00
CGStmtOpenMP.cpp [OPENMP] Codegen for 'omp critical' directive. 2014-09-22 10:01:53 +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 MS ABI: Don't ICE for pointers to pointers to members of incomplete classes 2014-09-18 22:05:54 +00:00
CodeGenFunction.h [OPENMP] Initial parsing/sema analysis of 'target' directive. 2014-09-19 08:19:49 +00:00
CodeGenModule.cpp Fix ctor/dtor aliases losing 'dllexport' (for Itanium ABI) 2014-09-19 22:06:24 +00:00
CodeGenModule.h Fix ctor/dtor aliases losing 'dllexport' (for Itanium ABI) 2014-09-19 22:06:24 +00:00
CodeGenPGO.cpp Coverage Mapping: store function's hash in coverage function records. 2014-08-21 19:25:27 +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 Add support for putting constructors and destructos in explicit comdats. 2014-09-16 15:18:21 +00:00
CoverageMappingGen.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
CoverageMappingGen.h Coverage Mapping: store function's hash in coverage function records. 2014-08-21 19:25:27 +00:00
EHScopeStack.h Header guard canonicalization, clang part. 2014-08-13 16:25:19 +00:00
ItaniumCXXABI.cpp Fix ctor/dtor aliases losing 'dllexport' (for Itanium ABI) 2014-09-19 22:06:24 +00:00
Makefile
MicrosoftCXXABI.cpp MS ABI: Don't ICE for pointers to pointers to members of incomplete classes 2014-09-18 22:05:54 +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 [mips] Correct alignment of vectors passed in varargs for the O32 ABI. 2014-09-22 13:27:06 +00:00
TargetInfo.h MS inline asm: Allow __asm blocks to set a return value 2014-09-04 20:04:38 +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!

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