diff options
author | Dan Gohman <dan433584@gmail.com> | 2017-02-27 22:38:58 +0000 |
---|---|---|
committer | Dan Gohman <dan433584@gmail.com> | 2017-02-27 22:38:58 +0000 |
commit | f52ee17a09eabe216562ef57115d8976b9d7f70e (patch) | |
tree | 46b42ff063a865164f78674660bf3b253d66f065 /llvm/lib/Target/WebAssembly/WebAssemblyUtilities.cpp | |
parent | 2d5841fa7334ac972fc89c12e60e17edf0612b1a (diff) | |
download | llvm-f52ee17a09eabe216562ef57115d8976b9d7f70e.zip llvm-f52ee17a09eabe216562ef57115d8976b9d7f70e.tar.gz llvm-f52ee17a09eabe216562ef57115d8976b9d7f70e.tar.bz2 |
[WebAssembly] Split CFG-sorting into its own pass. NFC.
CFG sorting was already an independent algorithm from block/loop insertion;
this change makes it more convenient to debug.
llvm-svn: 296399
Diffstat (limited to 'llvm/lib/Target/WebAssembly/WebAssemblyUtilities.cpp')
-rw-r--r-- | llvm/lib/Target/WebAssembly/WebAssemblyUtilities.cpp | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/llvm/lib/Target/WebAssembly/WebAssemblyUtilities.cpp b/llvm/lib/Target/WebAssembly/WebAssemblyUtilities.cpp index 2fb2327..e32772d 100644 --- a/llvm/lib/Target/WebAssembly/WebAssemblyUtilities.cpp +++ b/llvm/lib/Target/WebAssembly/WebAssemblyUtilities.cpp @@ -15,6 +15,7 @@ #include "WebAssemblyUtilities.h" #include "WebAssemblyMachineFunctionInfo.h" #include "llvm/CodeGen/MachineInstr.h" +#include "llvm/CodeGen/MachineLoopInfo.h" using namespace llvm; bool WebAssembly::isArgument(const MachineInstr &MI) { @@ -86,3 +87,11 @@ bool WebAssembly::isCallIndirect(const MachineInstr &MI) { return false; } } + +MachineBasicBlock *llvm::LoopBottom(const MachineLoop *Loop) { + MachineBasicBlock *Bottom = Loop->getHeader(); + for (MachineBasicBlock *MBB : Loop->blocks()) + if (MBB->getNumber() > Bottom->getNumber()) + Bottom = MBB; + return Bottom; +} |