[llvm-commits] 	CVS: llvm/test/Regression/CodeGen/PowerPC/rlwimi-commute.ll
    Chris Lattner 
    lattner at cs.uiuc.edu
       
    Fri Sep  9 10:49:09 PDT 2005
    
    
  
Changes in directory llvm/test/Regression/CodeGen/PowerPC:
rlwimi-commute.ll added (r1.1)
---
Log message:
New testcase, neither should require a register-register copy
---
Diffs of the changes:  (+26 -0)
 rlwimi-commute.ll |   26 ++++++++++++++++++++++++++
 1 files changed, 26 insertions(+)
Index: llvm/test/Regression/CodeGen/PowerPC/rlwimi-commute.ll
diff -c /dev/null llvm/test/Regression/CodeGen/PowerPC/rlwimi-commute.ll:1.1
*** /dev/null	Fri Sep  9 12:49:07 2005
--- llvm/test/Regression/CodeGen/PowerPC/rlwimi-commute.ll	Fri Sep  9 12:48:57 2005
***************
*** 0 ****
--- 1,26 ----
+ ; RUN: llvm-as < %s | llc -march=ppc32 | grep rlwimi &&
+ ; RUN: llvm-as < %s | llc -march=ppc32 | not grep 'or '
+ 
+ ; Make sure there is no register-register copies here.
+ 
+ void %test1(int *%A, int *%B, int *%D, int* %E) {
+ 	%A = load int* %A
+ 	%B = load int* %B
+ 	%X = and int %A, 15
+ 	%Y = and int %B, -16
+ 	%Z = or int %X, %Y
+ 	store int %Z, int* %D
+ 	store int %A, int* %E
+ 	ret void
+ }
+ 
+ void %test2(int *%A, int *%B, int *%D, int* %E) {
+ 	%A = load int* %A
+ 	%B = load int* %B
+ 	%X = and int %A, 15
+ 	%Y = and int %B, -16
+ 	%Z = or int %X, %Y
+ 	store int %Z, int* %D
+ 	store int %B, int* %E
+ 	ret void
+ }
    
    
More information about the llvm-commits
mailing list