|
| 1 | +// REQUIRES: powerpc-registered-target |
| 2 | +// RUN: %clang_cc1 -triple powerpc64le-unknown-linux-gnu -target-cpu pwr9 \ |
| 3 | +// RUN: -emit-llvm %s -o - | FileCheck %s |
| 4 | +// RUN: %clang_cc1 -triple powerpc64-ibm-aix -target-cpu pwr9 \ |
| 5 | +// RUN: -emit-llvm %s -o - | FileCheck %s |
| 6 | + |
| 7 | +#include <amo.h> |
| 8 | + |
| 9 | +uint32_t test_lwat_add(uint32_t *ptr, uint32_t val) { |
| 10 | + // CHECK-LABEL: @test_lwat_add |
| 11 | + // CHECK: call i32 @llvm.ppc.amo.lwat(ptr %{{.*}}, i32 %{{.*}}, i32 0) |
| 12 | + return amo_lwat_add(ptr, val); |
| 13 | +} |
| 14 | + |
| 15 | +uint32_t test_lwat_xor(uint32_t *ptr, uint32_t val) { |
| 16 | + // CHECK-LABEL: @test_lwat_xor |
| 17 | + // CHECK: call i32 @llvm.ppc.amo.lwat(ptr %{{.*}}, i32 %{{.*}}, i32 1) |
| 18 | + return amo_lwat_xor(ptr, val); |
| 19 | +} |
| 20 | + |
| 21 | +uint32_t test_lwat_ior(uint32_t *ptr, uint32_t val) { |
| 22 | + // CHECK-LABEL: @test_lwat_ior |
| 23 | + // CHECK: call i32 @llvm.ppc.amo.lwat(ptr %{{.*}}, i32 %{{.*}}, i32 2) |
| 24 | + return amo_lwat_ior(ptr, val); |
| 25 | +} |
| 26 | + |
| 27 | +uint32_t test_lwat_and(uint32_t *ptr, uint32_t val) { |
| 28 | + // CHECK-LABEL: @test_lwat_and |
| 29 | + // CHECK: call i32 @llvm.ppc.amo.lwat(ptr %{{.*}}, i32 %{{.*}}, i32 3) |
| 30 | + return amo_lwat_and(ptr, val); |
| 31 | +} |
| 32 | + |
| 33 | +uint32_t test_lwat_umax(uint32_t *ptr, uint32_t val) { |
| 34 | + // CHECK-LABEL: @test_lwat_umax |
| 35 | + // CHECK: call i32 @llvm.ppc.amo.lwat(ptr %{{.*}}, i32 %{{.*}}, i32 4) |
| 36 | + return amo_lwat_umax(ptr, val); |
| 37 | +} |
| 38 | + |
| 39 | +uint32_t test_lwat_umin(uint32_t *ptr, uint32_t val) { |
| 40 | + // CHECK-LABEL: @test_lwat_umin |
| 41 | + // CHECK: call i32 @llvm.ppc.amo.lwat(ptr %{{.*}}, i32 %{{.*}}, i32 6) |
| 42 | + return amo_lwat_umin(ptr, val); |
| 43 | +} |
| 44 | + |
| 45 | +uint32_t test_lwat_swap(uint32_t *ptr, uint32_t val) { |
| 46 | + // CHECK-LABEL: @test_lwat_swap |
| 47 | + // CHECK: call i32 @llvm.ppc.amo.lwat(ptr %{{.*}}, i32 %{{.*}}, i32 8) |
| 48 | + return amo_lwat_swap(ptr, val); |
| 49 | +} |
| 50 | + |
| 51 | +uint64_t test_ldat_add(uint64_t *ptr, uint64_t val) { |
| 52 | + // CHECK-LABEL: @test_ldat_add |
| 53 | + // CHECK: call i64 @llvm.ppc.amo.ldat(ptr %{{.*}}, i64 %{{.*}}, i32 0) |
| 54 | + return amo_ldat_add(ptr, val); |
| 55 | +} |
| 56 | + |
| 57 | +uint64_t test_ldat_xor(uint64_t *ptr, uint64_t val) { |
| 58 | + // CHECK-LABEL: @test_ldat_xor |
| 59 | + // CHECK: call i64 @llvm.ppc.amo.ldat(ptr %{{.*}}, i64 %{{.*}}, i32 1) |
| 60 | + return amo_ldat_xor(ptr, val); |
| 61 | +} |
| 62 | + |
| 63 | +uint64_t test_ldat_ior(uint64_t *ptr, uint64_t val) { |
| 64 | + // CHECK-LABEL: @test_ldat_ior |
| 65 | + // CHECK: call i64 @llvm.ppc.amo.ldat(ptr %{{.*}}, i64 %{{.*}}, i32 2) |
| 66 | + return amo_ldat_ior(ptr, val); |
| 67 | +} |
| 68 | + |
| 69 | +uint64_t test_ldat_and(uint64_t *ptr, uint64_t val) { |
| 70 | + // CHECK-LABEL: @test_ldat_and |
| 71 | + // CHECK: call i64 @llvm.ppc.amo.ldat(ptr %{{.*}}, i64 %{{.*}}, i32 3) |
| 72 | + return amo_ldat_and(ptr, val); |
| 73 | +} |
| 74 | + |
| 75 | +uint64_t test_ldat_umax(uint64_t *ptr, uint64_t val) { |
| 76 | + // CHECK-LABEL: @test_ldat_umax |
| 77 | + // CHECK: call i64 @llvm.ppc.amo.ldat(ptr %{{.*}}, i64 %{{.*}}, i32 4) |
| 78 | + return amo_ldat_umax(ptr, val); |
| 79 | +} |
| 80 | + |
| 81 | +uint64_t test_ldat_umin(uint64_t *ptr, uint64_t val) { |
| 82 | + // CHECK-LABEL: @test_ldat_umin |
| 83 | + // CHECK: call i64 @llvm.ppc.amo.ldat(ptr %{{.*}}, i64 %{{.*}}, i32 6) |
| 84 | + return amo_ldat_umin(ptr, val); |
| 85 | +} |
| 86 | + |
| 87 | +uint64_t test_ldat_swap(uint64_t *ptr, uint64_t val) { |
| 88 | + // CHECK-LABEL: @test_ldat_swap |
| 89 | + // CHECK: call i64 @llvm.ppc.amo.ldat(ptr %{{.*}}, i64 %{{.*}}, i32 8) |
| 90 | + return amo_ldat_swap(ptr, val); |
| 91 | +} |
0 commit comments