llvm-project/clang/lib/CodeGen
Justin Bogner 4c5c99f91a CodeGen: Simplify CodeGenFunction::EmitCaseStmt
Way back in r129652 we tried to avoid emitting an empty block at -O0
for switch cases that did nothing but break. This led to a poor
debugging experience as reported in PR9796, so we disabled the
optimization for -O0 but left it in for higher optimization levels in
r154420.

Since the whole point of this was to improve -O0, it's silly to keep
the complexity at all.

llvm-svn: 199302
2014-01-15 07:30:30 +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 [cleanup] Update the include of Dominators.h to reflect its move to the 2014-01-13 09:26:48 +00:00
CGAtomic.cpp Add CodeGenABITypes.h for use in LLDB. 2013-10-30 21:53:58 +00:00
CGBlocks.cpp Fix a tranche of comment, test and doc typos 2013-12-05 16:25:25 +00:00
CGBlocks.h Remove useless 'llvm::' qualifier from names like StringRef and others that are 2013-01-12 19:30:44 +00:00
CGBuilder.h Rewrite #includes for llvm/Foo.h to llvm/IR/Foo.h as appropriate to 2013-01-02 11:45:17 +00:00
CGBuiltin.cpp [AArch64]The compare to zero intrinsics should be implemented by 'icmp/fcmp' and 'sext' not 'zext'. Modify the implementation by replacing zext with sext. 2013-12-23 02:44:00 +00:00
CGCUDANV.cpp Use the actual ABI-determined C calling convention for runtime 2013-02-28 19:01:20 +00:00
CGCUDARuntime.cpp CodeGen: Initial instrumentation based PGO implementation 2014-01-06 22:27:43 +00:00
CGCUDARuntime.h CUDA: IR generation support for device stubs 2011-10-06 18:51:56 +00:00
CGCXX.cpp [ms-abi] Always generate complete constructors in the Microsoft C++ ABI 2014-01-13 22:57:31 +00:00
CGCXXABI.cpp [ms-cxxabi] The 'most derived' ctor parameter usually comes last 2013-12-17 19:46:40 +00:00
CGCXXABI.h [ms-cxxabi] The 'most derived' ctor parameter usually comes last 2013-12-17 19:46:40 +00:00
CGCall.cpp CodeGen: Introduce CodeGenPGO::setCurrentRegionUnreachable 2014-01-13 21:24:18 +00:00
CGCall.h Add CodeGenABITypes.h for use in LLDB. 2013-10-30 21:53:58 +00:00
CGClass.cpp [ms-abi] Always generate complete constructors in the Microsoft C++ ABI 2014-01-13 22:57:31 +00:00
CGCleanup.cpp CodeGen: Simplify CodeGenFunction::EmitCaseStmt 2014-01-15 07:30:30 +00:00
CGCleanup.h Fix leak in lib/CodeGen/CGException.cpp, PR18318 2014-01-09 09:22:32 +00:00
CGDebugInfo.cpp Revert "Debug info: Ensure that the last stop point in a function is still within" 2014-01-07 22:05:52 +00:00
CGDebugInfo.h Revert "Debug info: Ensure that the last stop point in a function is still within" 2014-01-07 22:05:52 +00:00
CGDecl.cpp Fix a tranche of comment, test and doc typos 2013-12-05 16:25:25 +00:00
CGDeclCXX.cpp Switched code from using hasAttr followed by getAttr to simply call getAttr directly and check the resulting value. 2013-12-19 03:02:49 +00:00
CGException.cpp Fix leak in lib/CodeGen/CGException.cpp, PR18318 2014-01-09 09:22:32 +00:00
CGExpr.cpp CodeGen: Rename adjustFallThroughCount -> adjustForControlFlow 2014-01-13 21:24:22 +00:00
CGExprAgg.cpp CodeGen: Rename adjustFallThroughCount -> adjustForControlFlow 2014-01-13 21:24:22 +00:00
CGExprCXX.cpp [ms-abi] Refactor Microsoft Record Layout 2014-01-09 00:30:56 +00:00
CGExprComplex.cpp CodeGen: Rename adjustFallThroughCount -> adjustForControlFlow 2014-01-13 21:24:22 +00:00
CGExprConstant.cpp Rename isBuiltinCall() to getBuiltinCallee() 2013-12-28 21:59:02 +00:00
CGExprScalar.cpp CodeGen: Rename adjustFallThroughCount -> adjustForControlFlow 2014-01-13 21:24:22 +00:00
CGObjC.cpp Re-applying r198699 after reverting r198461. 2014-01-07 22:05:55 +00:00
CGObjCGNU.cpp Use getPointerSizeInBits. 2014-01-09 21:32:51 +00:00
CGObjCMac.cpp Improve comment. 2014-01-14 22:01:08 +00:00
CGObjCRuntime.cpp Add CodeGenABITypes.h for use in LLDB. 2013-10-30 21:53:58 +00:00
CGObjCRuntime.h Use the actual ABI-determined C calling convention for runtime 2013-02-28 19:01:20 +00:00
CGOpenCLRuntime.cpp The OpenCL specification states that images are allocated 2014-01-09 13:37:30 +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
CGRTTI.cpp Fix vbtable indices when a class shares the vbptr with a non-virtual base 2013-11-05 15:54:58 +00:00
CGRecordLayout.h Correct hyphenations in comments and assert messages 2013-12-05 04:47:09 +00:00
CGRecordLayoutBuilder.cpp CGRecordLayoutBuilder.cpp: Clarify if-else. [-Wdangling-else] 2014-01-10 00:54:50 +00:00
CGStmt.cpp CodeGen: Simplify CodeGenFunction::EmitCaseStmt 2014-01-15 07:30:30 +00:00
CGVTT.cpp Eliminate the ItaniumVTableContext object from CodeGenVTables 2013-12-20 23:58:52 +00:00
CGVTables.cpp Eliminate the ItaniumVTableContext object from CodeGenVTables 2013-12-20 23:58:52 +00:00
CGVTables.h Eliminate the ItaniumVTableContext object from CodeGenVTables 2013-12-20 23:58:52 +00:00
CGValue.h Simplify atomic load/store IRGen. 2013-07-11 01:32:21 +00:00
CMakeLists.txt Properly sort CMake list. NFC. 2014-01-06 23:20:52 +00:00
CodeGenABITypes.cpp Sort all the #include lines with LLVM's utils/sort_includes.py which 2014-01-07 11:51:46 +00:00
CodeGenAction.cpp Update for getLazyBitcodeModule API change. 2014-01-13 18:31:09 +00:00
CodeGenFunction.cpp Simplifying the OpenCL image attribute. It does not need a semantic integer parameter because the required information is encoded in the spelling. Added an appropriate subject to the attribute, and simplified the semantic checking (which will likely be expanded upon in a future patch). Also, removed the GNU spelling since it was unsupported in the first place. 2014-01-14 17:41:53 +00:00
CodeGenFunction.h CodeGen: Simplify CodeGenFunction::EmitCaseStmt 2014-01-15 07:30:30 +00:00
CodeGenModule.cpp Update CodeGen to use DLL storage class for dllimport/dllexport 2014-01-14 15:23:53 +00:00
CodeGenModule.h CodeGen: Initial instrumentation based PGO implementation 2014-01-06 22:27:43 +00:00
CodeGenPGO.cpp CodeGen: Include llvm/Config/config.h for strtoll on Windows 2014-01-07 03:43:15 +00:00
CodeGenPGO.h CodeGen: Rename adjustFallThroughCount -> adjustForControlFlow 2014-01-13 21:24:22 +00:00
CodeGenTBAA.cpp Add a mangler entry point for TBAA rather than using RTTI directly 2013-11-19 23:23:00 +00:00
CodeGenTBAA.h Fixed comment typo. 2013-06-08 00:27:19 +00:00
CodeGenTypes.cpp Add CodeGenABITypes.h for use in LLDB. 2013-10-30 21:53:58 +00:00
CodeGenTypes.h Fix Windows build by including CGFunctionInfo.h. 2013-10-30 23:40:28 +00:00
EHScopeStack.h Sort all the #include lines with LLVM's utils/sort_includes.py which 2014-01-07 11:51:46 +00:00
ItaniumCXXABI.cpp [ms-cxxabi] The 'most derived' ctor parameter usually comes last 2013-12-17 19:46:40 +00:00
Makefile
MicrosoftCXXABI.cpp [ms-abi] Remove duplicated vbptr offset code 2014-01-14 00:50:39 +00:00
ModuleBuilder.cpp Sort all the #include lines with LLVM's utils/sort_includes.py which 2014-01-07 11:51:46 +00:00
README.txt
TargetInfo.cpp SPARC passes non-trivial C++ objects indirectly like everybody else. 2014-01-12 06:54:56 +00:00
TargetInfo.h Sort all the #include lines with LLVM's utils/sort_includes.py which 2014-01-07 11:51:46 +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!

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