Let MachineVerifier be aware of mem-to-mem instructions.
authorJonas Paulsson <jonas.paulsson@ericsson.com>
Wed, 21 Oct 2015 07:39:47 +0000 (07:39 +0000)
committerJonas Paulsson <jonas.paulsson@ericsson.com>
Wed, 21 Oct 2015 07:39:47 +0000 (07:39 +0000)
A mem-to-mem instruction (that both loads and stores), which store to an
FI, cannot pass the verifier since it thinks it is loading from the FI.

For the mem-to-mem instruction, do a looser check in visitMachineOperand()
and only check liveness at the reg-slot while analyzing a frame index operand.

Needed to make CodeGen/SystemZ/xor-01.ll pass with -verify-machineinstrs,
which now runs with this flag.

Reviewed by Evan Cheng and Quentin Colombet.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@250885 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/MachineVerifier.cpp
test/CodeGen/SystemZ/xor-01.ll

index c21b875a082c917917163a35a2e6ebfc4b92dd34..b9ca0c51d76feb5d813bf4444e562ec2731be0e1 100644 (file)
@@ -994,11 +994,17 @@ MachineVerifier::visitMachineOperand(const MachineOperand *MO, unsigned MONum) {
         LiveInts && !LiveInts->isNotInMIMap(MI)) {
       LiveInterval &LI = LiveStks->getInterval(MO->getIndex());
       SlotIndex Idx = LiveInts->getInstructionIndex(MI);
-      if (MI->mayLoad() && !LI.liveAt(Idx.getRegSlot(true))) {
+
+      // For a memory-to-memory move, we don't know if MI is using
+      // this frame index for loading or storing, so check for
+      // liveness at reg-slot only in the simple load case.
+      bool stores = MI->mayStore();
+      bool simpleLoad = (MI->mayLoad() && !stores);
+      if (simpleLoad && !LI.liveAt(Idx.getRegSlot(true))) {
         report("Instruction loads from dead spill slot", MO, MONum);
         errs() << "Live stack: " << LI << '\n';
       }
-      if (MI->mayStore() && !LI.liveAt(Idx.getRegSlot())) {
+      if (stores && !LI.liveAt(Idx.getRegSlot())) {
         report("Instruction stores to dead spill slot", MO, MONum);
         errs() << "Live stack: " << LI << '\n';
       }
index e0aaffbb257ec7f6d6ce6def08d823e4aaf4fd72..281f386ce955ce821af2abbe3a604cda3efe4cc3 100644 (file)
@@ -1,6 +1,6 @@
 ; Test 32-bit XORs in which the second operand is variable.
 ;
-; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z10 | FileCheck %s
+; RUN: llc < %s -verify-machineinstrs -mtriple=s390x-linux-gnu -mcpu=z10 | FileCheck %s
 ; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z196 | FileCheck %s
 
 declare i32 @foo()