llvm.org GIT mirror llvm / 9ad892c test / CodeGen / PowerPC / rlwimi-commute.ll
9ad892c

Tree @9ad892c (Download .tar.gz)

rlwimi-commute.ll @9ad892craw · history · blame

; RUN: llvm-upgrade < %s | llvm-as | llc -march=ppc32 | grep rlwimi
; RUN: llvm-upgrade < %s | llvm-as | 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
}