Skip to content

Commit fe2c4af

Browse files
committed
[DSE] Make test more robust (NFC)
If the allocation is not captured, then all the stores before the ret are dead anyway.
1 parent 83797c0 commit fe2c4af

File tree

1 file changed

+10
-10
lines changed

1 file changed

+10
-10
lines changed

llvm/test/Transforms/DeadStoreElimination/memset-unknown-sizes.ll

Lines changed: 10 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -6,37 +6,37 @@ declare i8* @_Znwm() local_unnamed_addr #0
66
; Function Attrs: argmemonly nounwind willreturn writeonly
77
declare void @llvm.memset.p0i8.i64(i8* nocapture writeonly, i8, i64, i1 immarg) #1
88

9-
define void @test1(i1 %c, i64 %N) {
9+
define i8* @test1(i1 %c, i64 %N) {
1010
; CHECK-LABEL: @test1(
1111
; CHECK-NEXT: entry:
1212
; CHECK-NEXT: br i1 [[C:%.*]], label [[COND_TRUE_I_I_I:%.*]], label [[COND_END_I_I_I:%.*]]
1313
; CHECK: cond.true.i.i.i:
14-
; CHECK-NEXT: ret void
14+
; CHECK-NEXT: ret i8* null
1515
; CHECK: cond.end.i.i.i:
1616
; CHECK-NEXT: [[ALLOC:%.*]] = tail call noalias nonnull i8* @_Znam() #[[ATTR2:[0-9]+]]
1717
; CHECK-NEXT: [[ALLOC_BC:%.*]] = bitcast i8* [[ALLOC]] to i64*
1818
; CHECK-NEXT: tail call void @llvm.memset.p0i8.i64(i8* nonnull align 8 [[ALLOC]], i8 0, i64 [[N:%.*]], i1 false) #[[ATTR3:[0-9]+]]
1919
; CHECK-NEXT: store i64 0, i64* [[ALLOC_BC]], align 8
20-
; CHECK-NEXT: ret void
20+
; CHECK-NEXT: ret i8* [[ALLOC]]
2121
;
2222
entry:
2323
br i1 %c, label %cond.true.i.i.i, label %cond.end.i.i.i
2424

2525
cond.true.i.i.i: ; preds = %entry
26-
ret void
26+
ret i8* null
2727

2828
cond.end.i.i.i: ; preds = %entry
2929
%alloc = tail call noalias nonnull i8* @_Znam() #2
3030
%alloc.bc = bitcast i8* %alloc to i64*
3131
tail call void @llvm.memset.p0i8.i64(i8* nonnull align 8 %alloc, i8 0, i64 %N, i1 false) #3
3232
store i64 0, i64* %alloc.bc, align 8
33-
ret void
33+
ret i8* %alloc
3434
}
3535

3636
declare i8* @_Znam()
3737

3838

39-
define void @test2(i1 %c, i64 %N) {
39+
define i8* @test2(i1 %c, i64 %N) {
4040
; CHECK-LABEL: @test2(
4141
; CHECK-NEXT: entry:
4242
; CHECK-NEXT: br i1 [[C:%.*]], label [[CLEANUP_CONT104:%.*]], label [[IF_THEN:%.*]]
@@ -46,9 +46,9 @@ define void @test2(i1 %c, i64 %N) {
4646
; CHECK-NEXT: [[ALLOC_BC:%.*]] = bitcast i8* [[ALLOC]] to i64*
4747
; CHECK-NEXT: store i64 0, i64* [[ALLOC_BC]], align 8
4848
; CHECK-NEXT: call void @llvm.memset.p0i8.i64(i8* nonnull align 8 [[ALLOC]], i8 0, i64 [[MUL]], i1 false) #[[ATTR3]]
49-
; CHECK-NEXT: ret void
49+
; CHECK-NEXT: ret i8* [[ALLOC]]
5050
; CHECK: cleanup.cont104:
51-
; CHECK-NEXT: ret void
51+
; CHECK-NEXT: ret i8* null
5252
;
5353
entry:
5454
br i1 %c, label %cleanup.cont104, label %if.then
@@ -59,10 +59,10 @@ if.then: ; preds = %entry
5959
%alloc.bc = bitcast i8* %alloc to i64*
6060
store i64 0, i64* %alloc.bc, align 8
6161
call void @llvm.memset.p0i8.i64(i8* nonnull align 8 %alloc, i8 0, i64 %mul, i1 false) #3
62-
ret void
62+
ret i8* %alloc
6363

6464
cleanup.cont104: ; preds = %entry
65-
ret void
65+
ret i8* null
6666
}
6767

6868
attributes #0 = { "use-soft-float"="false" }

0 commit comments

Comments
 (0)