Index: llvm/lib/CodeGen/AtomicExpandPass.cpp =================================================================== --- llvm/lib/CodeGen/AtomicExpandPass.cpp +++ 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); Index: llvm/test/Transforms/AtomicExpand/AArch64/pcsections.ll =================================================================== --- llvm/test/Transforms/AtomicExpand/AArch64/pcsections.ll +++ llvm/test/Transforms/AtomicExpand/AArch64/pcsections.ll @@ -3345,7 +3345,7 @@ ; CHECK-NEXT: [[TMP4:%.*]] = extractvalue { i64, i1 } [[TMP3]], 0, !pcsections !0 ; CHECK-NEXT: [[TMP5:%.*]] = extractvalue { i64, i1 } [[TMP3]], 1, !pcsections !0 ; CHECK-NEXT: [[TMP6:%.*]] = inttoptr i64 [[TMP4]] to i8*, !pcsections !0 -; CHECK-NEXT: [[TMP7:%.*]] = insertvalue { i8*, i1 } undef, i8* [[TMP6]], 0, !pcsections !0 +; CHECK-NEXT: [[TMP7:%.*]] = insertvalue { i8*, i1 } poison, i8* [[TMP6]], 0, !pcsections !0 ; CHECK-NEXT: [[TMP8:%.*]] = insertvalue { i8*, i1 } [[TMP7]], i1 [[TMP5]], 1, !pcsections !0 ; CHECK-NEXT: ret void ; Index: llvm/test/Transforms/AtomicExpand/AMDGPU/expand-atomic-i16.ll =================================================================== --- llvm/test/Transforms/AtomicExpand/AMDGPU/expand-atomic-i16.ll +++ llvm/test/Transforms/AtomicExpand/AMDGPU/expand-atomic-i16.ll @@ -418,7 +418,7 @@ ; CHECK: partword.cmpxchg.end: ; CHECK-NEXT: [[SHIFTED:%.*]] = lshr i32 [[TMP13]], [[SHIFTAMT]] ; CHECK-NEXT: [[EXTRACTED:%.*]] = trunc i32 [[SHIFTED]] to i16 -; CHECK-NEXT: [[TMP17:%.*]] = insertvalue { i16, i1 } undef, i16 [[EXTRACTED]], 0 +; CHECK-NEXT: [[TMP17:%.*]] = insertvalue { i16, i1 } poison, i16 [[EXTRACTED]], 0 ; CHECK-NEXT: [[TMP18:%.*]] = insertvalue { i16, i1 } [[TMP17]], i1 [[TMP14]], 1 ; CHECK-NEXT: [[EXTRACT:%.*]] = extractvalue { i16, i1 } [[TMP18]], 0 ; CHECK-NEXT: ret i16 [[EXTRACT]] @@ -452,7 +452,7 @@ ; CHECK-NEXT: br i1 [[TMP12]], label [[PARTWORD_CMPXCHG_LOOP]], label [[PARTWORD_CMPXCHG_END]] ; CHECK: partword.cmpxchg.end: ; CHECK-NEXT: [[EXTRACTED:%.*]] = trunc i32 [[TMP9]] to i16 -; CHECK-NEXT: [[TMP13:%.*]] = insertvalue { i16, i1 } undef, i16 [[EXTRACTED]], 0 +; CHECK-NEXT: [[TMP13:%.*]] = insertvalue { i16, i1 } poison, i16 [[EXTRACTED]], 0 ; CHECK-NEXT: [[TMP14:%.*]] = insertvalue { i16, i1 } [[TMP13]], i1 [[TMP10]], 1 ; CHECK-NEXT: [[EXTRACT:%.*]] = extractvalue { i16, i1 } [[TMP14]], 0 ; CHECK-NEXT: ret i16 [[EXTRACT]] @@ -525,7 +525,7 @@ ; CHECK: partword.cmpxchg.end: ; CHECK-NEXT: [[SHIFTED:%.*]] = lshr i32 [[TMP13]], [[TMP2]] ; CHECK-NEXT: [[EXTRACTED:%.*]] = trunc i32 [[SHIFTED]] to i16 -; CHECK-NEXT: [[TMP17:%.*]] = insertvalue { i16, i1 } undef, i16 [[EXTRACTED]], 0 +; CHECK-NEXT: [[TMP17:%.*]] = insertvalue { i16, i1 } poison, i16 [[EXTRACTED]], 0 ; CHECK-NEXT: [[TMP18:%.*]] = insertvalue { i16, i1 } [[TMP17]], i1 [[TMP14]], 1 ; CHECK-NEXT: [[EXTRACT:%.*]] = extractvalue { i16, i1 } [[TMP18]], 0 ; CHECK-NEXT: ret i16 [[EXTRACT]] Index: llvm/test/Transforms/AtomicExpand/AMDGPU/expand-atomic-i8.ll =================================================================== --- llvm/test/Transforms/AtomicExpand/AMDGPU/expand-atomic-i8.ll +++ llvm/test/Transforms/AtomicExpand/AMDGPU/expand-atomic-i8.ll @@ -427,7 +427,7 @@ ; CHECK: partword.cmpxchg.end: ; CHECK-NEXT: [[SHIFTED:%.*]] = lshr i32 [[TMP13]], [[SHIFTAMT]] ; CHECK-NEXT: [[EXTRACTED:%.*]] = trunc i32 [[SHIFTED]] to i8 -; CHECK-NEXT: [[TMP17:%.*]] = insertvalue { i8, i1 } undef, i8 [[EXTRACTED]], 0 +; CHECK-NEXT: [[TMP17:%.*]] = insertvalue { i8, i1 } poison, i8 [[EXTRACTED]], 0 ; CHECK-NEXT: [[TMP18:%.*]] = insertvalue { i8, i1 } [[TMP17]], i1 [[TMP14]], 1 ; CHECK-NEXT: [[EXTRACT:%.*]] = extractvalue { i8, i1 } [[TMP18]], 0 ; CHECK-NEXT: ret i8 [[EXTRACT]] @@ -471,7 +471,7 @@ ; CHECK: partword.cmpxchg.end: ; CHECK-NEXT: [[SHIFTED:%.*]] = lshr i32 [[TMP13]], [[SHIFTAMT]] ; CHECK-NEXT: [[EXTRACTED:%.*]] = trunc i32 [[SHIFTED]] to i8 -; CHECK-NEXT: [[TMP17:%.*]] = insertvalue { i8, i1 } undef, i8 [[EXTRACTED]], 0 +; CHECK-NEXT: [[TMP17:%.*]] = insertvalue { i8, i1 } poison, i8 [[EXTRACTED]], 0 ; CHECK-NEXT: [[TMP18:%.*]] = insertvalue { i8, i1 } [[TMP17]], i1 [[TMP14]], 1 ; CHECK-NEXT: [[EXTRACT:%.*]] = extractvalue { i8, i1 } [[TMP18]], 0 ; CHECK-NEXT: ret i8 [[EXTRACT]] Index: llvm/test/Transforms/AtomicExpand/PowerPC/cmpxchg.ll =================================================================== --- llvm/test/Transforms/AtomicExpand/PowerPC/cmpxchg.ll +++ llvm/test/Transforms/AtomicExpand/PowerPC/cmpxchg.ll @@ -23,7 +23,7 @@ ; CHECK-NEXT: [[HI64:%.*]] = zext i64 [[HI]] to i128 ; CHECK-NEXT: [[TMP4:%.*]] = shl i128 [[HI64]], 64 ; CHECK-NEXT: [[VAL64:%.*]] = or i128 [[LO64]], [[TMP4]] -; CHECK-NEXT: [[TMP5:%.*]] = insertvalue { i128, i1 } undef, i128 [[VAL64]], 0 +; CHECK-NEXT: [[TMP5:%.*]] = insertvalue { i128, i1 } poison, i128 [[VAL64]], 0 ; CHECK-NEXT: [[SUCCESS:%.*]] = icmp eq i128 [[DESIRE]], [[VAL64]] ; CHECK-NEXT: [[TMP6:%.*]] = insertvalue { i128, i1 } [[TMP5]], i1 [[SUCCESS]], 1 ; CHECK-NEXT: [[SUCC:%.*]] = extractvalue { i128, i1 } [[TMP6]], 1 @@ -44,7 +44,7 @@ ; PWR7-NEXT: call void @llvm.lifetime.end.p0i8(i64 16, i8* [[TMP4]]) ; PWR7-NEXT: [[TMP6:%.*]] = load i128, i128* [[TMP1]], align 8 ; PWR7-NEXT: call void @llvm.lifetime.end.p0i8(i64 16, i8* [[TMP2]]) -; PWR7-NEXT: [[TMP7:%.*]] = insertvalue { i128, i1 } undef, i128 [[TMP6]], 0 +; PWR7-NEXT: [[TMP7:%.*]] = insertvalue { i128, i1 } poison, i128 [[TMP6]], 0 ; PWR7-NEXT: [[TMP8:%.*]] = insertvalue { i128, i1 } [[TMP7]], i1 [[TMP5]], 1 ; PWR7-NEXT: [[SUCC:%.*]] = extractvalue { i128, i1 } [[TMP8]], 1 ; PWR7-NEXT: ret i1 [[SUCC]] Index: llvm/test/Transforms/AtomicExpand/RISCV/atomicrmw-fp.ll =================================================================== --- llvm/test/Transforms/AtomicExpand/RISCV/atomicrmw-fp.ll +++ llvm/test/Transforms/AtomicExpand/RISCV/atomicrmw-fp.ll @@ -17,7 +17,7 @@ ; CHECK-NEXT: [[TMP6:%.*]] = call zeroext i1 @__atomic_compare_exchange_4(i8* [[TMP3]], i8* [[TMP4]], i32 [[TMP5]], i32 5, i32 5) ; CHECK-NEXT: [[TMP7:%.*]] = load float, float* [[TMP1]], align 4 ; CHECK-NEXT: call void @llvm.lifetime.end.p0i8(i64 4, i8* [[TMP4]]) -; CHECK-NEXT: [[TMP8:%.*]] = insertvalue { float, i1 } undef, float [[TMP7]], 0 +; CHECK-NEXT: [[TMP8:%.*]] = insertvalue { float, i1 } poison, float [[TMP7]], 0 ; CHECK-NEXT: [[TMP9:%.*]] = insertvalue { float, i1 } [[TMP8]], i1 [[TMP6]], 1 ; CHECK-NEXT: [[SUCCESS:%.*]] = extractvalue { float, i1 } [[TMP9]], 1 ; CHECK-NEXT: [[NEWLOADED]] = extractvalue { float, i1 } [[TMP9]], 0 @@ -45,7 +45,7 @@ ; CHECK-NEXT: [[TMP6:%.*]] = call zeroext i1 @__atomic_compare_exchange_4(i8* [[TMP3]], i8* [[TMP4]], i32 [[TMP5]], i32 5, i32 5) ; CHECK-NEXT: [[TMP7:%.*]] = load float, float* [[TMP1]], align 4 ; CHECK-NEXT: call void @llvm.lifetime.end.p0i8(i64 4, i8* [[TMP4]]) -; CHECK-NEXT: [[TMP8:%.*]] = insertvalue { float, i1 } undef, float [[TMP7]], 0 +; CHECK-NEXT: [[TMP8:%.*]] = insertvalue { float, i1 } poison, float [[TMP7]], 0 ; CHECK-NEXT: [[TMP9:%.*]] = insertvalue { float, i1 } [[TMP8]], i1 [[TMP6]], 1 ; CHECK-NEXT: [[SUCCESS:%.*]] = extractvalue { float, i1 } [[TMP9]], 1 ; CHECK-NEXT: [[NEWLOADED]] = extractvalue { float, i1 } [[TMP9]], 0 Index: llvm/test/Transforms/AtomicExpand/SPARC/libcalls.ll =================================================================== --- llvm/test/Transforms/AtomicExpand/SPARC/libcalls.ll +++ llvm/test/Transforms/AtomicExpand/SPARC/libcalls.ll @@ -48,7 +48,7 @@ ; CHECK: %4 = call zeroext i1 @__atomic_compare_exchange_2(i8* %1, i8* %3, i16 %new, i32 5, i32 0) ; CHECK: %5 = load i16, i16* %2, align 2 ; CHECK: call void @llvm.lifetime.end.p0i8(i64 2, i8* %3) -; CHECK: %6 = insertvalue { i16, i1 } undef, i16 %5, 0 +; CHECK: %6 = insertvalue { i16, i1 } poison, i16 %5, 0 ; CHECK: %7 = insertvalue { i16, i1 } %6, i1 %4, 1 ; CHECK: %ret = extractvalue { i16, i1 } %7, 0 ; CHECK: ret i16 %ret @@ -133,7 +133,7 @@ ; CHECK: call void @llvm.lifetime.end.p0i8(i64 16, i8* %5) ; CHECK: %7 = load i128, i128* %2, align 8 ; CHECK: call void @llvm.lifetime.end.p0i8(i64 16, i8* %3) -; CHECK: %8 = insertvalue { i128, i1 } undef, i128 %7, 0 +; CHECK: %8 = insertvalue { i128, i1 } poison, i128 %7, 0 ; CHECK: %9 = insertvalue { i128, i1 } %8, i1 %6, 1 ; CHECK: %ret = extractvalue { i128, i1 } %9, 0 ; CHECK: ret i128 %ret @@ -166,7 +166,7 @@ ; CHECK: call void @llvm.lifetime.end.p0i8(i64 16, i8* %6) ; CHECK: %8 = load i128, i128* %1, align 8 ; CHECK: call void @llvm.lifetime.end.p0i8(i64 16, i8* %5) -; CHECK: %9 = insertvalue { i128, i1 } undef, i128 %8, 0 +; CHECK: %9 = insertvalue { i128, i1 } poison, i128 %8, 0 ; CHECK: %10 = insertvalue { i128, i1 } %9, i1 %7, 1 ; CHECK: %success = extractvalue { i128, i1 } %10, 1 ; CHECK: %newloaded = extractvalue { i128, i1 } %10, 0 @@ -210,7 +210,7 @@ ; CHECK: %5 = call zeroext i1 @__atomic_compare_exchange_4(i8* %1, i8* %3, i32 %4, i32 5, i32 2) ; CHECK: %6 = load i16*, i16** %2, align 4 ; CHECK: call void @llvm.lifetime.end.p0i8(i64 4, i8* %3) -; CHECK: %7 = insertvalue { i16*, i1 } undef, i16* %6, 0 +; CHECK: %7 = insertvalue { i16*, i1 } poison, i16* %6, 0 ; CHECK: %8 = insertvalue { i16*, i1 } %7, i1 %5, 1 ; CHECK: %ret = extractvalue { i16*, i1 } %8, 0 ; CHECK: ret i16* %ret Index: llvm/test/Transforms/AtomicExpand/SPARC/partword.ll =================================================================== --- llvm/test/Transforms/AtomicExpand/SPARC/partword.ll +++ llvm/test/Transforms/AtomicExpand/SPARC/partword.ll @@ -44,7 +44,7 @@ ; CHECK: partword.cmpxchg.end: ; CHECK-NEXT: [[SHIFTED:%.*]] = lshr i32 [[TMP13]], [[SHIFTAMT]] ; CHECK-NEXT: [[EXTRACTED:%.*]] = trunc i32 [[SHIFTED]] to i8 -; CHECK-NEXT: [[TMP17:%.*]] = insertvalue { i8, i1 } undef, i8 [[EXTRACTED]], 0 +; CHECK-NEXT: [[TMP17:%.*]] = insertvalue { i8, i1 } poison, i8 [[EXTRACTED]], 0 ; CHECK-NEXT: [[TMP18:%.*]] = insertvalue { i8, i1 } [[TMP17]], i1 [[TMP14]], 1 ; CHECK-NEXT: fence seq_cst ; CHECK-NEXT: [[RET:%.*]] = extractvalue { i8, i1 } [[TMP18]], 0 @@ -91,7 +91,7 @@ ; CHECK: partword.cmpxchg.end: ; CHECK-NEXT: [[SHIFTED:%.*]] = lshr i32 [[TMP13]], [[SHIFTAMT]] ; CHECK-NEXT: [[EXTRACTED:%.*]] = trunc i32 [[SHIFTED]] to i16 -; CHECK-NEXT: [[TMP17:%.*]] = insertvalue { i16, i1 } undef, i16 [[EXTRACTED]], 0 +; CHECK-NEXT: [[TMP17:%.*]] = insertvalue { i16, i1 } poison, i16 [[EXTRACTED]], 0 ; CHECK-NEXT: [[TMP18:%.*]] = insertvalue { i16, i1 } [[TMP17]], i1 [[TMP14]], 1 ; CHECK-NEXT: fence seq_cst ; CHECK-NEXT: [[RET:%.*]] = extractvalue { i16, i1 } [[TMP18]], 0 Index: llvm/test/Transforms/AtomicExpand/X86/expand-atomic-non-integer.ll =================================================================== --- llvm/test/Transforms/AtomicExpand/X86/expand-atomic-non-integer.ll +++ 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