mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-12 17:32:19 +00:00
New testcase, neither should require a register-register copy
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@23290 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
3793709e89
commit
a4d9dc7392
26
test/CodeGen/PowerPC/rlwimi-commute.ll
Normal file
26
test/CodeGen/PowerPC/rlwimi-commute.ll
Normal file
@ -0,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
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user