diff --git a/llvm/test/Instrumentation/PoisonChecking/ub-checks.ll b/llvm/test/Instrumentation/PoisonChecking/ub-checks.ll index fae262c05a257..a5703ae02e17d 100644 --- a/llvm/test/Instrumentation/PoisonChecking/ub-checks.ll +++ b/llvm/test/Instrumentation/PoisonChecking/ub-checks.ll @@ -13,7 +13,7 @@ define void @store(ptr %base, i32 %a) { ; CHECK-NEXT: [[P:%.*]] = getelementptr i8, ptr [[BASE:%.*]], i32 [[ADD]] ; CHECK-NEXT: [[TMP3:%.*]] = xor i1 [[TMP2]], true ; CHECK-NEXT: call void @__poison_checker_assert(i1 [[TMP3]]) -; CHECK-NEXT: store i8 0, ptr [[P]] +; CHECK-NEXT: store i8 0, ptr [[P]], align 1 ; CHECK-NEXT: ret void ; %add = add nsw i32 %a, 1 @@ -30,7 +30,7 @@ define void @load(ptr %base, i32 %a) { ; CHECK-NEXT: [[P:%.*]] = getelementptr i8, ptr [[BASE:%.*]], i32 [[ADD]] ; CHECK-NEXT: [[TMP3:%.*]] = xor i1 [[TMP2]], true ; CHECK-NEXT: call void @__poison_checker_assert(i1 [[TMP3]]) -; CHECK-NEXT: [[TMP4:%.*]] = load volatile i8, ptr [[P]] +; CHECK-NEXT: [[TMP4:%.*]] = load volatile i8, ptr [[P]], align 1 ; CHECK-NEXT: ret void ; %add = add nsw i32 %a, 1 @@ -47,7 +47,7 @@ define void @atomicrmw(ptr %base, i32 %a) { ; CHECK-NEXT: [[P:%.*]] = getelementptr i8, ptr [[BASE:%.*]], i32 [[ADD]] ; CHECK-NEXT: [[TMP3:%.*]] = xor i1 [[TMP2]], true ; CHECK-NEXT: call void @__poison_checker_assert(i1 [[TMP3]]) -; CHECK-NEXT: [[TMP4:%.*]] = atomicrmw add ptr [[P]], i8 1 seq_cst +; CHECK-NEXT: [[TMP4:%.*]] = atomicrmw add ptr [[P]], i8 1 seq_cst, align 1 ; CHECK-NEXT: ret void ; %add = add nsw i32 %a, 1 @@ -64,7 +64,7 @@ define void @cmpxchg(ptr %base, i32 %a) { ; CHECK-NEXT: [[P:%.*]] = getelementptr i8, ptr [[BASE:%.*]], i32 [[ADD]] ; CHECK-NEXT: [[TMP3:%.*]] = xor i1 [[TMP2]], true ; CHECK-NEXT: call void @__poison_checker_assert(i1 [[TMP3]]) -; CHECK-NEXT: [[TMP4:%.*]] = cmpxchg ptr [[P]], i8 1, i8 0 seq_cst seq_cst +; CHECK-NEXT: [[TMP4:%.*]] = cmpxchg ptr [[P]], i8 1, i8 0 seq_cst seq_cst, align 1 ; CHECK-NEXT: ret void ; %add = add nsw i32 %a, 1 @@ -133,5 +133,58 @@ define i32 @srem(ptr %base, i32 %a) { ret i32 %res } +define noundef i32 @select_cond_may_be_poison(i32 %a, i32 %b) { +; CHECK-LABEL: @select_cond_may_be_poison( +; CHECK-NEXT: [[TMP1:%.*]] = call { i32, i1 } @llvm.uadd.with.overflow.i32(i32 [[A:%.*]], i32 1) +; CHECK-NEXT: [[TMP2:%.*]] = extractvalue { i32, i1 } [[TMP1]], 1 +; CHECK-NEXT: [[ADD:%.*]] = add nuw i32 [[A]], 1 +; CHECK-NEXT: [[T:%.*]] = trunc i32 [[ADD]] to i1 +; CHECK-NEXT: [[SEL:%.*]] = select i1 [[T]], i32 [[ADD]], i32 [[B:%.*]] +; CHECK-NEXT: ret i32 [[SEL]] +; + %add = add nuw i32 %a, 1 + %t = trunc i32 %add to i1 + %sel = select i1 %t, i32 %add, i32 %b + ret i32 %sel +} + +define noundef i32 @select_cond_true_third_op_may_be_poison(i32 %a, i32 %b) { +; CHECK-LABEL: @select_cond_true_third_op_may_be_poison( +; CHECK-NEXT: [[TMP1:%.*]] = call { i32, i1 } @llvm.uadd.with.overflow.i32(i32 [[A:%.*]], i32 1) +; CHECK-NEXT: [[TMP2:%.*]] = extractvalue { i32, i1 } [[TMP1]], 1 +; CHECK-NEXT: [[ADD:%.*]] = add nuw i32 [[A]], 1 +; CHECK-NEXT: [[SEL:%.*]] = select i1 true, i32 [[B:%.*]], i32 [[ADD]] +; CHECK-NEXT: ret i32 [[SEL]] +; + %add = add nuw i32 %a, 1 + %sel = select i1 true, i32 %b, i32 %add + ret i32 %sel +} + +define noundef i32 @select_cond_false_second_op_may_be_poison(i1 %c, i32 %a, i32 %b) { +; CHECK-LABEL: @select_cond_false_second_op_may_be_poison( +; CHECK-NEXT: [[TMP1:%.*]] = call { i32, i1 } @llvm.uadd.with.overflow.i32(i32 [[A:%.*]], i32 1) +; CHECK-NEXT: [[TMP2:%.*]] = extractvalue { i32, i1 } [[TMP1]], 1 +; CHECK-NEXT: [[ADD:%.*]] = add nuw i32 [[A]], 1 +; CHECK-NEXT: [[SEL:%.*]] = select i1 false, i32 [[ADD]], i32 [[B:%.*]] +; CHECK-NEXT: ret i32 [[SEL]] +; + %add = add nuw i32 %a, 1 + %sel = select i1 false, i32 %add, i32 %b + ret i32 %sel +} + +define noundef i32 @select_unknown_true_third_op_may_be_poison(i1 %c, i32 %a, i32 %b) { +; CHECK-LABEL: @select_unknown_true_third_op_may_be_poison( +; CHECK-NEXT: [[TMP1:%.*]] = call { i32, i1 } @llvm.uadd.with.overflow.i32(i32 [[A:%.*]], i32 1) +; CHECK-NEXT: [[TMP2:%.*]] = extractvalue { i32, i1 } [[TMP1]], 1 +; CHECK-NEXT: [[ADD:%.*]] = add nuw i32 [[A]], 1 +; CHECK-NEXT: [[SEL:%.*]] = select i1 [[C:%.*]], i32 [[B:%.*]], i32 [[ADD]] +; CHECK-NEXT: ret i32 [[SEL]] +; + %add = add nuw i32 %a, 1 + %sel = select i1 %c, i32 %b, i32 %add + ret i32 %sel +}