1// RUN: %clang_cc1 -triple powerpc64-unknown-linux-gnu -O2 -emit-llvm -o - %s | FileCheck %s
2
3_Bool test_wc_i1(_Bool b1, _Bool b2) {
4  _Bool o;
5  asm("crand %0, %1, %2" : "=wc"(o) : "wc"(b1), "wc"(b2) : );
6  return o;
7// CHECK-LABEL: define zeroext i1 @test_wc_i1(i1 zeroext %b1, i1 zeroext %b2)
8// CHECK: call i8 asm "crand $0, $1, $2", "=^wc,^wc,^wc"(i1 %b1, i1 %b2)
9}
10
11int test_wc_i32(int b1, int b2) {
12  int o;
13  asm("crand %0, %1, %2" : "=wc"(o) : "wc"(b1), "wc"(b2) : );
14  return o;
15// CHECK-LABEL: signext i32 @test_wc_i32(i32 signext %b1, i32 signext %b2)
16// CHECK: call i32 asm "crand $0, $1, $2", "=^wc,^wc,^wc"(i32 %b1, i32 %b2)
17}
18
19unsigned char test_wc_i8(unsigned char b1, unsigned char b2) {
20  unsigned char o;
21  asm("crand %0, %1, %2" : "=wc"(o) : "wc"(b1), "wc"(b2) : );
22  return o;
23// CHECK-LABEL: zeroext i8 @test_wc_i8(i8 zeroext %b1, i8 zeroext %b2)
24// CHECK: call i8 asm "crand $0, $1, $2", "=^wc,^wc,^wc"(i8 %b1, i8 %b2)
25}
26
27