llvm-project/llvm/lib
Ulrich Weigand b32f3656d2 [SystemZ] Do not use glue to represent condition code dependencies
Currently, an instruction setting the condition code is linked to
the instruction using the condition code via a "glue" link in the
SelectionDAG.  This has a number of drawbacks; in particular, it
means the same CC cannot be used by multiple users.  It also makes
it more difficult to efficiently implement SADDO et. al.

This patch changes the back-end to represent CC dependencies as
normal values during SelectionDAG matching, along the lines of
how this is handled in the X86 back-end already.

In addition to the core mechanics of updating all relevant patterns,
this requires a number of additional changes:

- We now need to be able to spill/restore a CC value into a GPR
  if necessary.  This means providing a copyPhysReg implementation
  for moves involving CC, and defining getCrossCopyRegClass.

- Since we still prefer to avoid such spills, we provide an override
  for IsProfitableToFold to avoid creating a merged LOAD / ICMP if
  this would result in multiple users of the CC.

- combineCCMask no longer requires a single CC user, and no longer
  need to be careful about preventing invalid glue/chain cycles.

- emitSelect needs to be more careful in marking CC live-in to
  the basic block it generates.  Also, we can now optimize the
  case of multiple subsequent selects with the same condition
  just like X86 does.

llvm-svn: 331202
2018-04-30 17:52:32 +00:00
..
Analysis IWYU for llvm-config.h in llvm, additions. 2018-04-30 14:59:11 +00:00
AsmParser Add the ShadowCallStack attribute 2018-04-03 20:10:40 +00:00
BinaryFormat Fix build broken by r328090 2018-03-21 12:18:03 +00:00
Bitcode IWYU for llvm-config.h in llvm, additions. 2018-04-30 14:59:11 +00:00
CodeGen Fix infinite loop after r331115 2018-04-30 17:20:01 +00:00
DebugInfo [DebugInfo] Prevent infinite recursion for malformed DWARF 2018-04-30 17:02:41 +00:00
Demangle [demangler] Add a partial demangling API for LLDB. 2018-04-12 20:41:38 +00:00
ExecutionEngine IWYU for llvm-config.h in llvm, additions. 2018-04-30 14:59:11 +00:00
FuzzMutate [llvm-opt-fuzzer] Add irce to the fuzzing options 2018-03-20 11:32:13 +00:00
Fuzzer [libFuzzer] Delete llvm/lib/Fuzzer 2017-10-16 20:48:19 +00:00
IR IWYU for llvm-config.h in llvm, additions. 2018-04-30 14:59:11 +00:00
IRReader LLParser: add an argument for overriding data layout and do not check alloca addr space 2018-01-30 22:32:39 +00:00
LTO IWYU for llvm-config.h in llvm, additions. 2018-04-30 14:59:11 +00:00
LineEditor
Linker [ThinLTO] Recommit of import global variables 2018-03-12 10:30:50 +00:00
MC IWYU for llvm-config.h in llvm, additions. 2018-04-30 14:59:11 +00:00
Object IWYU for llvm-config.h in llvm, additions. 2018-04-30 14:59:11 +00:00
ObjectYAML [WebAssembly] Write DWARF data into wasm object file 2018-04-26 19:27:28 +00:00
Option IWYU for llvm-config.h in llvm, additions. 2018-04-30 14:59:11 +00:00
Passes NFC, Avoid a warning on pointer casting in PassPlugin.cpp 2018-04-30 14:21:28 +00:00
ProfileData IWYU for llvm-config.h in llvm, additions. 2018-04-30 14:59:11 +00:00
Support IWYU for llvm-config.h, removals. Also see r331184. 2018-04-30 15:26:01 +00:00
TableGen IWYU for llvm-config.h in llvm, additions. 2018-04-30 14:59:11 +00:00
Target [SystemZ] Do not use glue to represent condition code dependencies 2018-04-30 17:52:32 +00:00
Testing [LLVMTestingSupport] Add explicit linkage to LLVMSupport 2018-04-08 06:49:17 +00:00
ToolDrivers [COFF] Keep the underscore on exported decorated stdcall functions in MSVC mode 2018-01-20 11:44:32 +00:00
Transforms [SLPVectorizer] Debug info shouldn't impact spill cost computation. 2018-04-30 16:57:33 +00:00
WindowsManifest Convert line endings of lib/WindowsManifest/CMakeLists.txt to unix. 2018-04-07 04:28:08 +00:00
XRay [XRay] clarify error messages when parsing broken traces 2018-01-30 13:41:34 +00:00
CMakeLists.txt
LLVMBuild.txt