MIR: Allow parsing of empty machine functions

If you run llc -stop-after=codegenprepare and feed the resulting MIR
to llc -start-after=codegenprepare, you'll have an empty machine
function since we haven't run any isel yet. Of course, this only works
if the MIRParser believes you that this is okay.

This is essentially a revert of r241862 with a fix for the problem it
was papering over.

llvm-svn: 299975
This commit is contained in:
Justin Bogner 2017-04-11 19:32:41 +00:00
parent 203eef0ed5
commit 20dd36a48a
10 changed files with 21 additions and 46 deletions

View File

@ -367,9 +367,6 @@ bool MIRParserImpl::initializeMachineFunction(MachineFunction &MF) {
}
PFS.SM = &SM;
if (MF.empty())
return error(Twine("machine function '") + Twine(MF.getName()) +
"' requires at least one machine basic block in its body");
// Initialize the frame information after creating all the MBBs so that the
// MBB references in the frame information can be resolved.
if (initializeFrameInfo(PFS, YamlMF))

View File

@ -528,6 +528,7 @@ void MachineVerifier::visitMachineFunctionBefore() {
lastIndex = SlotIndex();
regsReserved = MRI->getReservedRegs();
if (!MF->empty())
markReachable(&MF->front());
// Build a set of the basic blocks in the function.
@ -548,6 +549,7 @@ void MachineVerifier::visitMachineFunctionBefore() {
// Check that the register use lists are sane.
MRI->verifyUseLists();
if (!MF->empty())
verifyStackFrame();
}

View File

@ -32,6 +32,4 @@
...
---
name: foo
body: |
bb.0:
...

View File

@ -4,6 +4,4 @@
---
# CHECK: name: foo
name: foo
body: |
bb.0:
...

View File

@ -1,15 +0,0 @@
# RUN: not llc -run-pass none -o /dev/null %s 2>&1 | FileCheck %s
# This test ensures that the MIR parser reports an error when it encounters a
# machine function with an empty body.
--- |
define i32 @foo() {
ret i32 0
}
...
---
# CHECK: machine function 'foo' requires at least one machine basic block in its body
name: foo
...

View File

@ -0,0 +1,15 @@
# RUN: llc -run-pass none -o - %s | FileCheck %s
# This test ensures that the MIR parser accepts files with llvm IR but
# no machine function body.
--- |
; CHECK: define i32 @foo()
define i32 @foo() {
ret i32 0
}
...
---
# CHECK: name: foo
name: foo
...

View File

@ -12,12 +12,8 @@
...
---
name: foo
body: |
bb.0:
...
---
# CHECK: function 'faa' isn't defined in the provided LLVM IR
name: faa
body: |
bb.0:
...

View File

@ -16,11 +16,7 @@
---
# CHECK: [[@LINE+1]]:1: missing required key 'name'
nme: foo
body: |
bb.0:
...
---
name: bar
body: |
bb.0:
...

View File

@ -26,8 +26,6 @@
# CHECK-NEXT: exposesReturnsTwice: false
# CHECK: ...
name: foo
body: |
bb.0:
...
---
# CHECK: name: bar
@ -35,8 +33,6 @@ body: |
# CHECK-NEXT: exposesReturnsTwice: false
# CHECK: ...
name: bar
body: |
bb.0:
...
---
# CHECK: name: func
@ -45,8 +41,6 @@ body: |
# CHECK: ...
name: func
alignment: 8
body: |
bb.0:
...
---
# CHECK: name: func2
@ -56,6 +50,4 @@ body: |
name: func2
alignment: 16
exposesReturnsTwice: true
body: |
bb.0:
...

View File

@ -20,8 +20,6 @@
# CHECK: tracksRegLiveness: false
# CHECK: ...
name: foo
body: |
bb.0:
...
---
# CHECK: name: bar
@ -29,6 +27,4 @@ body: |
# CHECK: ...
name: bar
tracksRegLiveness: true
body: |
bb.0:
...