diff --git a/llvm/lib/CodeGen/AtomicExpandPass.cpp b/llvm/lib/CodeGen/AtomicExpandPass.cpp --- a/llvm/lib/CodeGen/AtomicExpandPass.cpp +++ b/llvm/lib/CodeGen/AtomicExpandPass.cpp @@ -1030,7 +1030,7 @@ Builder.SetInsertPoint(CI); Value *FinalOldVal = extractMaskedValue(Builder, OldVal, PMV); - Value *Res = UndefValue::get(CI->getType()); + Value *Res = PoisonValue::get(CI->getType()); Res = Builder.CreateInsertValue(Res, FinalOldVal, 0); Res = Builder.CreateInsertValue(Res, Success, 1); @@ -1094,7 +1094,7 @@ Builder, CI, PMV.AlignedAddr, CmpVal_Shifted, NewVal_Shifted, PMV.Mask, CI->getMergedOrdering()); Value *FinalOldVal = extractMaskedValue(Builder, OldVal, PMV); - Value *Res = UndefValue::get(CI->getType()); + Value *Res = PoisonValue::get(CI->getType()); Res = Builder.CreateInsertValue(Res, FinalOldVal, 0); Value *Success = Builder.CreateICmpEQ( CmpVal_Shifted, Builder.CreateAnd(OldVal, PMV.Mask), "Success"); @@ -1186,7 +1186,7 @@ OldVal = Builder.CreateIntToPtr(OldVal, CI->getCompareOperand()->getType()); - Value *Res = UndefValue::get(CI->getType()); + Value *Res = PoisonValue::get(CI->getType()); Res = Builder.CreateInsertValue(Res, OldVal, 0); Res = Builder.CreateInsertValue(Res, Succ, 1); @@ -1430,7 +1430,7 @@ // Some use of the full struct return that we don't understand has happened, // so we've got to reconstruct it properly. Value *Res; - Res = Builder.CreateInsertValue(UndefValue::get(CI->getType()), Loaded, 0); + Res = Builder.CreateInsertValue(PoisonValue::get(CI->getType()), Loaded, 0); Res = Builder.CreateInsertValue(Res, Success, 1); CI->replaceAllUsesWith(Res); @@ -1923,7 +1923,7 @@ // The final result from the CAS is {load of 'expected' alloca, bool result // from call} Type *FinalResultTy = I->getType(); - Value *V = UndefValue::get(FinalResultTy); + Value *V = PoisonValue::get(FinalResultTy); Value *ExpectedOut = Builder.CreateAlignedLoad( CASExpected->getType(), AllocaCASExpected, AllocaAlignment); Builder.CreateLifetimeEnd(AllocaCASExpected_i8, SizeVal64); diff --git a/llvm/test/Transforms/AtomicExpand/X86/expand-atomic-non-integer.ll b/llvm/test/Transforms/AtomicExpand/X86/expand-atomic-non-integer.ll --- a/llvm/test/Transforms/AtomicExpand/X86/expand-atomic-non-integer.ll +++ b/llvm/test/Transforms/AtomicExpand/X86/expand-atomic-non-integer.ll @@ -88,7 +88,7 @@ ; CHECK: %4 = extractvalue { i64, i1 } %3, 0 ; CHECK: %5 = extractvalue { i64, i1 } %3, 1 ; CHECK: %6 = inttoptr i64 %4 to i8* -; CHECK: %7 = insertvalue { i8*, i1 } undef, i8* %6, 0 +; CHECK: %7 = insertvalue { i8*, i1 } poison, i8* %6, 0 ; CHECK: %8 = insertvalue { i8*, i1 } %7, i1 %5, 1 cmpxchg i8** %ptr, i8* null, i8* %v seq_cst monotonic ret void @@ -102,7 +102,7 @@ ; CHECK: %4 = extractvalue { i64, i1 } %3, 0 ; CHECK: %5 = extractvalue { i64, i1 } %3, 1 ; CHECK: %6 = inttoptr i64 %4 to i8* -; CHECK: %7 = insertvalue { i8*, i1 } undef, i8* %6, 0 +; CHECK: %7 = insertvalue { i8*, i1 } poison, i8* %6, 0 ; CHECK: %8 = insertvalue { i8*, i1 } %7, i1 %5, 1 cmpxchg i8** %ptr, i8* null, i8* %v release monotonic ret void @@ -116,7 +116,7 @@ ; CHECK: %4 = extractvalue { i64, i1 } %3, 0 ; CHECK: %5 = extractvalue { i64, i1 } %3, 1 ; CHECK: %6 = inttoptr i64 %4 to i8* -; CHECK: %7 = insertvalue { i8*, i1 } undef, i8* %6, 0 +; CHECK: %7 = insertvalue { i8*, i1 } poison, i8* %6, 0 ; CHECK: %8 = insertvalue { i8*, i1 } %7, i1 %5, 1 cmpxchg i8** %ptr, i8* null, i8* %v seq_cst seq_cst ret void @@ -130,7 +130,7 @@ ; CHECK: %4 = extractvalue { i64, i1 } %3, 0 ; CHECK: %5 = extractvalue { i64, i1 } %3, 1 ; CHECK: %6 = inttoptr i64 %4 to i8* -; CHECK: %7 = insertvalue { i8*, i1 } undef, i8* %6, 0 +; CHECK: %7 = insertvalue { i8*, i1 } poison, i8* %6, 0 ; CHECK: %8 = insertvalue { i8*, i1 } %7, i1 %5, 1 cmpxchg weak i8** %ptr, i8* null, i8* %v seq_cst seq_cst ret void @@ -144,7 +144,7 @@ ; CHECK: %4 = extractvalue { i64, i1 } %3, 0 ; CHECK: %5 = extractvalue { i64, i1 } %3, 1 ; CHECK: %6 = inttoptr i64 %4 to i8* -; CHECK: %7 = insertvalue { i8*, i1 } undef, i8* %6, 0 +; CHECK: %7 = insertvalue { i8*, i1 } poison, i8* %6, 0 ; CHECK: %8 = insertvalue { i8*, i1 } %7, i1 %5, 1 cmpxchg volatile i8** %ptr, i8* null, i8* %v seq_cst seq_cst ret void @@ -159,7 +159,7 @@ ; CHECK: %4 = extractvalue { i64, i1 } %3, 0 ; CHECK: %5 = extractvalue { i64, i1 } %3, 1 ; CHECK: %6 = inttoptr i64 %4 to i8 addrspace(2)* -; CHECK: %7 = insertvalue { i8 addrspace(2)*, i1 } undef, i8 addrspace(2)* %6, 0 +; CHECK: %7 = insertvalue { i8 addrspace(2)*, i1 } poison, i8 addrspace(2)* %6, 0 ; CHECK: %8 = insertvalue { i8 addrspace(2)*, i1 } %7, i1 %5, 1 cmpxchg i8 addrspace(2)* addrspace(1)* %ptr, i8 addrspace(2)* null, i8 addrspace(2)* %v seq_cst seq_cst ret void