; RUN: llc < %s -mtriple=powerpc64-apple-darwin | FileCheck %s | |
; TODO: These could use 'andc'. | |
define i1 @and_cmp1(i32 %x, i32 %y) { | |
; CHECK-LABEL: and_cmp1: | |
; CHECK: ; BB#0: | |
; CHECK-NEXT: and r2, r3, r4 | |
; CHECK-NEXT: li r3, 1 | |
; CHECK-NEXT: cmpw cr0, r2, r4 | |
; CHECK-NEXT: bclr 12, 2, 0 | |
; CHECK-NEXT: ; BB#1: | |
; CHECK-NEXT: li r3, 0 | |
; CHECK-NEXT: blr | |
; | |
%and = and i32 %x, %y | |
%cmp = icmp eq i32 %and, %y | |
ret i1 %cmp | |
} | |
define i1 @and_cmp_const(i32 %x) { | |
; CHECK-LABEL: and_cmp_const: | |
; CHECK: ; BB#0: | |
; CHECK-NEXT: andi. r2, r3, 43 | |
; CHECK-NEXT: li r3, 1 | |
; CHECK-NEXT: cmpwi r2, 43 | |
; CHECK-NEXT: bclr 12, 2, 0 | |
; CHECK-NEXT: ; BB#1: | |
; CHECK-NEXT: li r3, 0 | |
; CHECK-NEXT: blr | |
; | |
%and = and i32 %x, 43 | |
%cmp = icmp eq i32 %and, 43 | |
ret i1 %cmp | |
} | |