Two testcases for invalid transformations that instcombine is doing

llvm-svn: 16446
This commit is contained in:
Chris Lattner 2004-09-20 10:14:27 +00:00
parent 5ef171a5b1
commit 803fb3c2c3
2 changed files with 44 additions and 0 deletions

View File

@ -0,0 +1,20 @@
; RUN: llvm-as < %s | opt -instcombine -mem2reg | llvm-dis | not grep 'int 1'
; When propagating the load through the select, make sure that the load is
; inserted where the original load was, not where the select is. Not doing
; so could produce incorrect results!
implementation
int %test(bool %C) {
%X = alloca int
%X2 = alloca int
store int 1, int* %X
store int 2, int* %X2
%Y = select bool %C, int* %X, int* %X2
store int 3, int* %X
%Z = load int* %Y
ret int %Z
}

View File

@ -0,0 +1,24 @@
; RUN: llvm-as < %s | opt -instcombine -mem2reg -simplifycfg | llvm-dis | \
; RUN: grep -v store | not grep 'int 1'
; Test to make sure that instcombine does not accidentally propagate the load
; into the PHI, which would break the program.
int %test(bool %C) {
entry:
%X = alloca int
%X2 = alloca int
store int 1, int* %X
store int 2, int* %X2
br bool %C, label %cond_true.i, label %cond_continue.i
cond_true.i:
br label %cond_continue.i
cond_continue.i:
%mem_tmp.i.0 = phi int* [ %X, %cond_true.i ], [ %X2, %entry ]
store int 3, int* %X
%tmp.3 = load int* %mem_tmp.i.0
ret int %tmp.3
}