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

Tree @release_16 (Download .tar.gz)

rlwimi-commute.ll @release_16raw · history · blame

; 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
}