New testcases to ensure sub's are maximally reassociable

llvm-svn: 2633
This commit is contained in:
Chris Lattner 2002-05-15 21:59:31 +00:00
parent 8f143b68e0
commit d88f3e8d97
2 changed files with 29 additions and 0 deletions

View File

@ -0,0 +1,14 @@
; With sub reassociation, constant folding can eliminate all of the constants.
;
; RUN: if as < %s | opt -reassociate -constprop -instcombine -dce | dis | grep add
; RUN: then exit 1
; RUN: else exit 0
; RUN: fi
int "test"(int %A, int %B) {
%W = add int -5, %B
%X = add int -7, %A
%Y = sub int %X, %W
%Z = add int %Y, 12
ret int %Z
}

View File

@ -0,0 +1,15 @@
; With sub reassociation, constant folding can eliminate the two 12 constants.
;
; RUN: if as < %s | opt -reassociate -constprop -dce | dis | grep 12
; RUN: then exit 1
; RUN: else exit 0
; RUN: fi
int "test"(int %A, int %B, int %C, int %D) {
%M = add int %A, 12
%N = add int %M, %B
%O = add int %N, %C
%P = sub int %D, %O
%Q = add int %P, 12
ret int %Q
}