blob: ffc87561fa3c40d98be712737d634bf30aacffec [file] [log] [blame] [edit]
// REQUIRES: powerpc-registered-target
// RUN: %clang_cc1 -triple powerpc64le-unknown-linux-gnu -target-cpu pwr9 \
// RUN: -emit-llvm %s -o - | FileCheck %s
// RUN: %clang_cc1 -triple powerpc64-ibm-aix -target-cpu pwr9 \
// RUN: -emit-llvm %s -o - | FileCheck %s
#include <amo.h>
uint32_t test_lwat_add(uint32_t *ptr, uint32_t val) {
// CHECK-LABEL: @test_lwat_add
// CHECK: call i32 @llvm.ppc.amo.lwat(ptr %{{.*}}, i32 %{{.*}}, i32 0)
return amo_lwat_add(ptr, val);
}
uint32_t test_lwat_xor(uint32_t *ptr, uint32_t val) {
// CHECK-LABEL: @test_lwat_xor
// CHECK: call i32 @llvm.ppc.amo.lwat(ptr %{{.*}}, i32 %{{.*}}, i32 1)
return amo_lwat_xor(ptr, val);
}
uint32_t test_lwat_ior(uint32_t *ptr, uint32_t val) {
// CHECK-LABEL: @test_lwat_ior
// CHECK: call i32 @llvm.ppc.amo.lwat(ptr %{{.*}}, i32 %{{.*}}, i32 2)
return amo_lwat_ior(ptr, val);
}
uint32_t test_lwat_and(uint32_t *ptr, uint32_t val) {
// CHECK-LABEL: @test_lwat_and
// CHECK: call i32 @llvm.ppc.amo.lwat(ptr %{{.*}}, i32 %{{.*}}, i32 3)
return amo_lwat_and(ptr, val);
}
uint32_t test_lwat_umax(uint32_t *ptr, uint32_t val) {
// CHECK-LABEL: @test_lwat_umax
// CHECK: call i32 @llvm.ppc.amo.lwat(ptr %{{.*}}, i32 %{{.*}}, i32 4)
return amo_lwat_umax(ptr, val);
}
uint32_t test_lwat_umin(uint32_t *ptr, uint32_t val) {
// CHECK-LABEL: @test_lwat_umin
// CHECK: call i32 @llvm.ppc.amo.lwat(ptr %{{.*}}, i32 %{{.*}}, i32 6)
return amo_lwat_umin(ptr, val);
}
uint32_t test_lwat_swap(uint32_t *ptr, uint32_t val) {
// CHECK-LABEL: @test_lwat_swap
// CHECK: call i32 @llvm.ppc.amo.lwat(ptr %{{.*}}, i32 %{{.*}}, i32 8)
return amo_lwat_swap(ptr, val);
}
int32_t test_lwat_sadd(int32_t *ptr, int32_t val) {
// CHECK-LABEL: @test_lwat_sadd
// CHECK: call i32 @llvm.ppc.amo.lwat(ptr %{{.*}}, i32 %{{.*}}, i32 0)
return amo_lwat_sadd(ptr, val);
}
int32_t test_lwat_smax(int32_t *ptr, int32_t val) {
// CHECK-LABEL: @test_lwat_smax
// CHECK: call i32 @llvm.ppc.amo.lwat(ptr %{{.*}}, i32 %{{.*}}, i32 5)
return amo_lwat_smax(ptr, val);
}
int32_t test_lwat_smin(int32_t *ptr, int32_t val) {
// CHECK-LABEL: @test_lwat_smin
// CHECK: call i32 @llvm.ppc.amo.lwat(ptr %{{.*}}, i32 %{{.*}}, i32 7)
return amo_lwat_smin(ptr, val);
}
int32_t test_lwat_sswap(int32_t *ptr, int32_t val) {
// CHECK-LABEL: @test_lwat_sswap
// CHECK: call i32 @llvm.ppc.amo.lwat(ptr %{{.*}}, i32 %{{.*}}, i32 8)
return amo_lwat_sswap(ptr, val);
}
uint64_t test_ldat_add(uint64_t *ptr, uint64_t val) {
// CHECK-LABEL: @test_ldat_add
// CHECK: call i64 @llvm.ppc.amo.ldat(ptr %{{.*}}, i64 %{{.*}}, i32 0)
return amo_ldat_add(ptr, val);
}
uint64_t test_ldat_xor(uint64_t *ptr, uint64_t val) {
// CHECK-LABEL: @test_ldat_xor
// CHECK: call i64 @llvm.ppc.amo.ldat(ptr %{{.*}}, i64 %{{.*}}, i32 1)
return amo_ldat_xor(ptr, val);
}
uint64_t test_ldat_ior(uint64_t *ptr, uint64_t val) {
// CHECK-LABEL: @test_ldat_ior
// CHECK: call i64 @llvm.ppc.amo.ldat(ptr %{{.*}}, i64 %{{.*}}, i32 2)
return amo_ldat_ior(ptr, val);
}
uint64_t test_ldat_and(uint64_t *ptr, uint64_t val) {
// CHECK-LABEL: @test_ldat_and
// CHECK: call i64 @llvm.ppc.amo.ldat(ptr %{{.*}}, i64 %{{.*}}, i32 3)
return amo_ldat_and(ptr, val);
}
uint64_t test_ldat_umax(uint64_t *ptr, uint64_t val) {
// CHECK-LABEL: @test_ldat_umax
// CHECK: call i64 @llvm.ppc.amo.ldat(ptr %{{.*}}, i64 %{{.*}}, i32 4)
return amo_ldat_umax(ptr, val);
}
uint64_t test_ldat_umin(uint64_t *ptr, uint64_t val) {
// CHECK-LABEL: @test_ldat_umin
// CHECK: call i64 @llvm.ppc.amo.ldat(ptr %{{.*}}, i64 %{{.*}}, i32 6)
return amo_ldat_umin(ptr, val);
}
uint64_t test_ldat_swap(uint64_t *ptr, uint64_t val) {
// CHECK-LABEL: @test_ldat_swap
// CHECK: call i64 @llvm.ppc.amo.ldat(ptr %{{.*}}, i64 %{{.*}}, i32 8)
return amo_ldat_swap(ptr, val);
}
int64_t test_ldat_sadd(int64_t *ptr, int64_t val) {
// CHECK-LABEL: @test_ldat_sadd
// CHECK: call i64 @llvm.ppc.amo.ldat(ptr %{{.*}}, i64 %{{.*}}, i32 0)
return amo_ldat_sadd(ptr, val);
}
int64_t test_ldat_smax(int64_t *ptr, int64_t val) {
// CHECK-LABEL: @test_ldat_smax
// CHECK: call i64 @llvm.ppc.amo.ldat(ptr %{{.*}}, i64 %{{.*}}, i32 5)
return amo_ldat_smax(ptr, val);
}
int64_t test_ldat_smin(int64_t *ptr, int64_t val) {
// CHECK-LABEL: @test_ldat_smin
// CHECK: call i64 @llvm.ppc.amo.ldat(ptr %{{.*}}, i64 %{{.*}}, i32 7)
return amo_ldat_smin(ptr, val);
}
int64_t test_ldat_sswap(int64_t *ptr, int64_t val) {
// CHECK-LABEL: @test_ldat_sswap
// CHECK: call i64 @llvm.ppc.amo.ldat(ptr %{{.*}}, i64 %{{.*}}, i32 8)
return amo_ldat_sswap(ptr, val);
}