From 75da31ff156af209b040d14f04ed92f9cc38ba3f Mon Sep 17 00:00:00 2001 From: Ahmed Bougacha Date: Fri, 7 Nov 2014 02:50:00 +0000 Subject: [PATCH] [AArch64] Keep flags on condition vreg when instantiating a CB branch. Reversing a CB* instruction used to drop the flags on the condition. On the included testcase, this lead to a read from an undefined vreg. Using addOperand keeps the flags, here . Differential Revision: http://reviews.llvm.org/D6159 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@221507 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Target/AArch64/AArch64InstrInfo.cpp | 3 ++- test/CodeGen/AArch64/br-undef-cond.ll | 26 +++++++++++++++++++++++++ 2 files changed, 28 insertions(+), 1 deletion(-) create mode 100644 test/CodeGen/AArch64/br-undef-cond.ll diff --git a/lib/Target/AArch64/AArch64InstrInfo.cpp b/lib/Target/AArch64/AArch64InstrInfo.cpp index c5bf3c79477..1451407de0e 100644 --- a/lib/Target/AArch64/AArch64InstrInfo.cpp +++ b/lib/Target/AArch64/AArch64InstrInfo.cpp @@ -261,8 +261,9 @@ void AArch64InstrInfo::instantiateCondBranch( BuildMI(&MBB, DL, get(AArch64::Bcc)).addImm(Cond[0].getImm()).addMBB(TBB); } else { // Folded compare-and-branch + // Note that we use addOperand instead of addReg to keep the flags. const MachineInstrBuilder MIB = - BuildMI(&MBB, DL, get(Cond[1].getImm())).addReg(Cond[2].getReg()); + BuildMI(&MBB, DL, get(Cond[1].getImm())).addOperand(Cond[2]); if (Cond.size() > 3) MIB.addImm(Cond[3].getImm()); MIB.addMBB(TBB); diff --git a/test/CodeGen/AArch64/br-undef-cond.ll b/test/CodeGen/AArch64/br-undef-cond.ll new file mode 100644 index 00000000000..12d0da2e4fc --- /dev/null +++ b/test/CodeGen/AArch64/br-undef-cond.ll @@ -0,0 +1,26 @@ +; RUN: llc < %s -verify-machineinstrs + +; Make sure we don't end up with a CBNZ of an undef v-/phys-reg. + +target datalayout = "e-m:o-i64:64-i128:128-n32:64-S128" +target triple = "arm64-apple-ios" + +declare void @bar(i8*) + +define void @foo(i8* %m, i32 %off0) { +.thread1653: + br i1 undef, label %0, label %.thread1880 + + %1 = icmp eq i32 undef, 0 + %.not = xor i1 %1, true + %brmerge = or i1 %.not, undef + br i1 %brmerge, label %.thread1880, label %.thread1705 + +.thread1705: + ret void + +.thread1880: + %m1652.ph = phi i8* [ %m, %0 ], [ null, %.thread1653 ] + call void @bar(i8* %m1652.ph) + ret void +} -- 2.34.1