llvm-project/clang/lib/CodeGen
Eli Friedman 3346582bca Change -mno-mmx to be more compatible with gcc. Specifically, -mno-mmx should not imply -mno-sse.
Note that because we don't usually touch the MMX registers anyway, all -mno-mmx needs to do is tweak the x86-32 calling convention a little for vectors that look like MMX vectors, and prevent the definition of __MMX__.

clang doesn't actually stop the user from using MMX inline asm operands or MMX builtins in -mno-mmx mode; as a QOI issue, it would be nice to diagnose, but I doubt it really matters much.

<rdar://problem/9694837>

llvm-svn: 134770
2011-07-08 23:31:17 +00:00
..
ABIInfo.h Fix Whitespace. 2010-10-19 06:39:39 +00:00
BackendUtil.cpp Add the ObjC ARC optimization passes manually, now that they're not 2011-07-05 22:02:36 +00:00
CGBlocks.cpp revert patch for // rdar://9227352 2011-07-06 21:05:11 +00:00
CGBlocks.h Remove more unnecessary #include <llvm/ADT/SmallVector.h> 2011-06-20 06:11:46 +00:00
CGBuilder.h Make CGBuilderTy a typedef again; its functionality has been rolled back 2010-07-06 18:43:48 +00:00
CGBuiltin.cpp Introduce __builtin_expect() intrinsic support. 2011-07-08 22:45:14 +00:00
CGCXX.cpp Revert r131434, my commit disabling the complete-object constructor 2011-05-17 21:05:49 +00:00
CGCXXABI.cpp After some discussion with Doug, we decided that it made a lot more sense 2011-04-12 00:42:48 +00:00
CGCXXABI.h After some discussion with Doug, we decided that it made a lot more sense 2011-04-12 00:42:48 +00:00
CGCall.cpp LValue carries a type now, so simplify the main EmitLoad/Store APIs 2011-06-25 02:11:03 +00:00
CGCall.h Automatic Reference Counting. 2011-06-15 23:02:42 +00:00
CGClass.cpp LValue carries a type now, so simplify the main EmitLoad/Store APIs 2011-06-25 02:11:03 +00:00
CGCleanup.cpp Change how PHINodes store their operands. 2011-06-20 14:38:01 +00:00
CGCleanup.h Move all the cleanups framework code into a single file. 2011-01-28 11:13:47 +00:00
CGDebugInfo.cpp Fix struct member's scope. Patch by Xi Wang. 2011-06-24 22:00:59 +00:00
CGDebugInfo.h Fix struct member's scope. Patch by Xi Wang. 2011-06-24 22:00:59 +00:00
CGDecl.cpp Don't zero-initialize default-initialized local variables that have 2011-07-01 21:08:19 +00:00
CGDeclCXX.cpp Emit guard variables for any weak global that has a run-time 2011-07-01 21:54:36 +00:00
CGException.cpp Call objc_terminate() instead of abort() when a cleanup throws an 2011-07-06 01:22:26 +00:00
CGException.h Fix Objective-C++ exceptions (GNU runtime). 2011-03-20 21:35:39 +00:00
CGExpr.cpp In ARC, reclaim all return values of retainable type, not just those 2011-07-07 06:58:02 +00:00
CGExprAgg.cpp In ARC, reclaim all return values of retainable type, not just those 2011-07-07 06:58:02 +00:00
CGExprCXX.cpp Restore correct use of GC barriers. 2011-06-16 04:16:24 +00:00
CGExprComplex.cpp In ARC, reclaim all return values of retainable type, not just those 2011-07-07 06:58:02 +00:00
CGExprConstant.cpp In ARC, reclaim all return values of retainable type, not just those 2011-07-07 06:58:02 +00:00
CGExprScalar.cpp Layout the code for trapping arithmetic so that the overflow case comes after 2011-07-07 21:13:10 +00:00
CGObjC.cpp In ARC, reclaim all return values of retainable type, not just those 2011-07-07 06:58:02 +00:00
CGObjCGNU.cpp If we're using the pure non-fragile ABI, then skip some of the contortions required to support the transitional ABI. 2011-07-07 12:34:51 +00:00
CGObjCMac.cpp Eliminate most uses of ShallowCollectObjCIvars which requires 2011-06-28 18:05:25 +00:00
CGObjCRuntime.cpp Eliminate most uses of ShallowCollectObjCIvars which requires 2011-06-28 18:05:25 +00:00
CGObjCRuntime.h Support for catching objc pointer objects in c++ catch-statement 2011-06-23 19:00:08 +00:00
CGRTTI.cpp Update to match mainline ConstantStruct::get API change. Also, use 2011-06-20 04:01:35 +00:00
CGRecordLayout.h Convert AccessInfo::AccessAlignment to CharUnits. No change in functionality 2011-04-24 10:13:17 +00:00
CGRecordLayoutBuilder.cpp IRgen: Add a -fuse-register-sized-bitfield-access option, for testing. 2011-06-21 18:54:46 +00:00
CGStmt.cpp Split out logic for valid clobbers and valid inline asm registers. 2011-06-28 18:20:53 +00:00
CGTemporaries.cpp Fix some obvious bugs in the conditional-cleanup code and then make the 2011-01-26 19:15:39 +00:00
CGVTT.cpp Replace the existing forms of ConstantArray::get() with a single form 2011-06-22 09:24:39 +00:00
CGVTables.cpp Replace the existing forms of ConstantArray::get() with a single form 2011-06-22 09:24:39 +00:00
CGVTables.h Move GlobalDecl to AST 2011-06-14 04:02:39 +00:00
CGValue.h Restore correct use of GC barriers. 2011-06-16 04:16:24 +00:00
CMakeLists.txt Wire up the -ftest-coverage and -fprofile-arcs flags to .gcno file emission (at 2011-04-21 23:44:07 +00:00
CodeGenAction.cpp Add the ObjC ARC optimization passes manually, now that they're not 2011-07-05 22:02:36 +00:00
CodeGenFunction.cpp Change the IR-generation of VLAs so that we capture bounds, 2011-06-24 21:55:10 +00:00
CodeGenFunction.h LValue carries a type now, so simplify the main EmitLoad/Store APIs 2011-06-25 02:11:03 +00:00
CodeGenModule.cpp r134634 causes a failure on MultiSource/Benchmarks/Olden/bh with TEST=nightly, 2011-07-07 21:03:28 +00:00
CodeGenModule.h Change the IR-generation of VLAs so that we capture bounds, 2011-06-24 21:55:10 +00:00
CodeGenTBAA.cpp PR9214: Convert Metadata API to use ArrayRef. 2011-04-21 19:59:12 +00:00
CodeGenTBAA.h Move name mangling support from CodeGen to AST. In the 2011-01-13 18:57:25 +00:00
CodeGenTypes.cpp IRgen: Add CGOptions to CGTypes. 2011-06-21 18:54:39 +00:00
CodeGenTypes.h IRgen: Add CGOptions to CGTypes. 2011-06-21 18:54:39 +00:00
ItaniumCXXABI.cpp Update to match mainline ConstantStruct::get API change. Also, use 2011-06-20 04:01:35 +00:00
Makefile BUILD_ARCHIVE is the default for libraries, no need to set it. 2010-07-18 00:14:47 +00:00
MicrosoftCXXABI.cpp fix a bunch of comment typos found by codespell. Patch by 2011-04-15 05:22:18 +00:00
ModuleBuilder.cpp Modify some deleted function methods to better reflect reality: 2011-05-06 20:44:56 +00:00
README.txt These IRgen improvements have been done. 2009-07-23 03:03:07 +00:00
TargetInfo.cpp Change -mno-mmx to be more compatible with gcc. Specifically, -mno-mmx should not imply -mno-sse. 2011-07-08 23:31:17 +00:00
TargetInfo.h Automatic Reference Counting. 2011-06-15 23:02:42 +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!

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