Avoid adding a duplicate def. This fixes PR4478.
authorEvan Cheng <evan.cheng@apple.com>
Mon, 6 Jul 2009 21:34:05 +0000 (21:34 +0000)
committerEvan Cheng <evan.cheng@apple.com>
Mon, 6 Jul 2009 21:34:05 +0000 (21:34 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@74857 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/LiveVariables.cpp
test/CodeGen/X86/2009-07-06-TwoAddrAssert.ll [new file with mode: 0644]

index bd845085bbf5ce427f9f4d667582fef74bed2a1a..bb72d80cb6ebaf399177521b179ee40da1a632b0 100644 (file)
@@ -369,8 +369,17 @@ bool LiveVariables::HandlePhysRegKill(unsigned Reg, MachineInstr *MI) {
     for (const unsigned *SubRegs = TRI->getSubRegisters(Reg);
          unsigned SubReg = *SubRegs; ++SubRegs) {
       if (PartUses.count(SubReg)) {
-        PhysRegDef[Reg]->addOperand(MachineOperand::CreateReg(SubReg,
-                                                              true, true));
+        bool NeedDef = true;
+        if (PhysRegDef[Reg] == PhysRegDef[SubReg]) {
+          MachineOperand *MO = PhysRegDef[Reg]->findRegisterDefOperand(SubReg);
+          if (MO) {
+            NeedDef = false;
+            assert(!MO->isDead());
+          }
+        }
+        if (NeedDef)
+          PhysRegDef[Reg]->addOperand(MachineOperand::CreateReg(SubReg,
+                                                                true, true));
         LastRefOrPartRef->addRegisterKilled(SubReg, TRI, true);
         for (const unsigned *SS = TRI->getSubRegisters(SubReg); *SS; ++SS)
           PartUses.erase(*SS);
diff --git a/test/CodeGen/X86/2009-07-06-TwoAddrAssert.ll b/test/CodeGen/X86/2009-07-06-TwoAddrAssert.ll
new file mode 100644 (file)
index 0000000..71b46f2
--- /dev/null
@@ -0,0 +1,137 @@
+; RUN: llvm-as < %s | llc -march=x86 -mtriple=x86_64-unknown-freebsd7.2
+; PR4478
+
+       %struct.sockaddr = type <{ i8, i8, [14 x i8] }>
+
+define i32 @main(i32 %argc, i8** %argv) nounwind {
+entry:
+       br label %while.cond
+
+while.cond:            ; preds = %sw.bb6, %entry
+       switch i32 undef, label %sw.default [
+               i32 -1, label %while.end
+               i32 119, label %sw.bb6
+       ]
+
+sw.bb6:                ; preds = %while.cond
+       br i1 undef, label %if.then, label %while.cond
+
+if.then:               ; preds = %sw.bb6
+       ret i32 1
+
+sw.default:            ; preds = %while.cond
+       ret i32 1
+
+while.end:             ; preds = %while.cond
+       br i1 undef, label %if.then15, label %if.end16
+
+if.then15:             ; preds = %while.end
+       ret i32 1
+
+if.end16:              ; preds = %while.end
+       br i1 undef, label %lor.lhs.false, label %if.then21
+
+lor.lhs.false:         ; preds = %if.end16
+       br i1 undef, label %if.end22, label %if.then21
+
+if.then21:             ; preds = %lor.lhs.false, %if.end16
+       ret i32 1
+
+if.end22:              ; preds = %lor.lhs.false
+       br i1 undef, label %lor.lhs.false27, label %if.then51
+
+lor.lhs.false27:               ; preds = %if.end22
+       br i1 undef, label %lor.lhs.false39, label %if.then51
+
+lor.lhs.false39:               ; preds = %lor.lhs.false27
+       br i1 undef, label %if.end52, label %if.then51
+
+if.then51:             ; preds = %lor.lhs.false39, %lor.lhs.false27, %if.end22
+       ret i32 1
+
+if.end52:              ; preds = %lor.lhs.false39
+       br i1 undef, label %if.then57, label %if.end58
+
+if.then57:             ; preds = %if.end52
+       ret i32 1
+
+if.end58:              ; preds = %if.end52
+       br i1 undef, label %if.then64, label %if.end65
+
+if.then64:             ; preds = %if.end58
+       ret i32 1
+
+if.end65:              ; preds = %if.end58
+       br i1 undef, label %if.then71, label %if.end72
+
+if.then71:             ; preds = %if.end65
+       ret i32 1
+
+if.end72:              ; preds = %if.end65
+       br i1 undef, label %if.then83, label %if.end84
+
+if.then83:             ; preds = %if.end72
+       ret i32 1
+
+if.end84:              ; preds = %if.end72
+       br i1 undef, label %if.then101, label %if.end102
+
+if.then101:            ; preds = %if.end84
+       ret i32 1
+
+if.end102:             ; preds = %if.end84
+       br i1 undef, label %if.then113, label %if.end114
+
+if.then113:            ; preds = %if.end102
+       ret i32 1
+
+if.end114:             ; preds = %if.end102
+       br i1 undef, label %if.then209, label %if.end210
+
+if.then209:            ; preds = %if.end114
+       ret i32 1
+
+if.end210:             ; preds = %if.end114
+       br i1 undef, label %if.then219, label %if.end220
+
+if.then219:            ; preds = %if.end210
+       ret i32 1
+
+if.end220:             ; preds = %if.end210
+       br i1 undef, label %if.end243, label %lor.lhs.false230
+
+lor.lhs.false230:              ; preds = %if.end220
+       unreachable
+
+if.end243:             ; preds = %if.end220
+       br i1 undef, label %if.then249, label %if.end250
+
+if.then249:            ; preds = %if.end243
+       ret i32 1
+
+if.end250:             ; preds = %if.end243
+       br i1 undef, label %if.end261, label %if.then260
+
+if.then260:            ; preds = %if.end250
+       ret i32 1
+
+if.end261:             ; preds = %if.end250
+       br i1 undef, label %if.then270, label %if.end271
+
+if.then270:            ; preds = %if.end261
+       ret i32 1
+
+if.end271:             ; preds = %if.end261
+       %call.i = call i32 @arc4random() nounwind               ; <i32> [#uses=1]
+       %rem.i = urem i32 %call.i, 16383                ; <i32> [#uses=1]
+       %rem1.i = trunc i32 %rem.i to i16               ; <i16> [#uses=1]
+       %conv2.i = or i16 %rem1.i, -16384               ; <i16> [#uses=1]
+       %0 = call i16 asm "xchgb ${0:h}, ${0:b}", "=Q,0,~{dirflag},~{fpsr},~{flags}"(i16 %conv2.i) nounwind             ; <i16> [#uses=1]
+       store i16 %0, i16* undef
+       %call281 = call i32 @bind(i32 undef, %struct.sockaddr* undef, i32 16) nounwind          ; <i32> [#uses=0]
+       unreachable
+}
+
+declare i32 @bind(i32, %struct.sockaddr*, i32)
+
+declare i32 @arc4random()