forked from OSchip/llvm-project
New testcases to ensure sub's are maximally reassociable
llvm-svn: 2633
This commit is contained in:
parent
8f143b68e0
commit
d88f3e8d97
|
@ -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
|
||||
}
|
|
@ -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
|
||||
}
|
Loading…
Reference in New Issue