From 3005ed604835834534b61ea4a8f8be29f6868627 Mon Sep 17 00:00:00 2001 From: Evan Cheng Date: Mon, 13 Apr 2009 20:04:24 +0000 Subject: [PATCH] PR3934: Fix a bogus two-address pass assertion. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@68979 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/TwoAddressInstructionPass.cpp | 18 ++++++++++-------- test/CodeGen/X86/2009-04-13-2AddrAssert.ll | 16 ++++++++++++++++ 2 files changed, 26 insertions(+), 8 deletions(-) create mode 100644 test/CodeGen/X86/2009-04-13-2AddrAssert.ll diff --git a/lib/CodeGen/TwoAddressInstructionPass.cpp b/lib/CodeGen/TwoAddressInstructionPass.cpp index 20770a17ef2..8a18dc0fc79 100644 --- a/lib/CodeGen/TwoAddressInstructionPass.cpp +++ b/lib/CodeGen/TwoAddressInstructionPass.cpp @@ -628,10 +628,10 @@ void TwoAddressInstructionPass::ProcessCopy(MachineInstr *MI, if (IsDstPhys && !IsSrcPhys) DstRegMap.insert(std::make_pair(SrcReg, DstReg)); else if (!IsDstPhys && IsSrcPhys) { - bool isNew = - SrcRegMap.insert(std::make_pair(DstReg, SrcReg)).second; - isNew = isNew; // Silence compiler warning. - assert(isNew && "Can't map to two src physical registers!"); + bool isNew = SrcRegMap.insert(std::make_pair(DstReg, SrcReg)).second; + if (!isNew) + assert(SrcRegMap[DstReg] == SrcReg && + "Can't map to two src physical registers!"); SmallVector VirtRegPairs; bool isCopy = false; @@ -653,8 +653,9 @@ void TwoAddressInstructionPass::ProcessCopy(MachineInstr *MI, break; } bool isNew = SrcRegMap.insert(std::make_pair(NewReg, DstReg)).second; - isNew = isNew; // Silence compiler warning. - assert(isNew && "Can't map to two src physical registers!"); + if (!isNew) + assert(SrcRegMap[NewReg] == DstReg && + "Can't map to two src physical registers!"); VirtRegPairs.push_back(NewReg); DstReg = NewReg; } @@ -666,8 +667,9 @@ void TwoAddressInstructionPass::ProcessCopy(MachineInstr *MI, unsigned FromReg = VirtRegPairs.back(); VirtRegPairs.pop_back(); bool isNew = DstRegMap.insert(std::make_pair(FromReg, ToReg)).second; - isNew = isNew; // Silence compiler warning. - assert(isNew && "Can't map to two dst physical registers!"); + if (!isNew) + assert(DstRegMap[FromReg] == ToReg && + "Can't map to two dst physical registers!"); ToReg = FromReg; } } diff --git a/test/CodeGen/X86/2009-04-13-2AddrAssert.ll b/test/CodeGen/X86/2009-04-13-2AddrAssert.ll new file mode 100644 index 00000000000..7f94c6ca947 --- /dev/null +++ b/test/CodeGen/X86/2009-04-13-2AddrAssert.ll @@ -0,0 +1,16 @@ +; RUN: llvm-as < %s | llc +; rdar://6781755 +; PR3934 + +target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128" +target triple = "x86_64-undermydesk-freebsd8.0" + +define i32 @main(i32 %argc, i8** nocapture %argv) nounwind { +entry: + %call = tail call i32 (...)* @getpid() ; [#uses=1] + %conv = trunc i32 %call to i16 ; [#uses=1] + %0 = tail call i16 asm "xchgb ${0:h}, ${0:b}","=Q,0,~{dirflag},~{fpsr},~{flags}"(i16 %conv) nounwind ; [#uses=0] + ret i32 undef +} + +declare i32 @getpid(...)