llvm-project/clang/test/CodeGenCXX/atomic-inline.cpp
Logikable 5fdd094837
[clang][CodeGen] Emit atomic IR in place of optimized libcalls. (#73176)
In the beginning, Clang only emitted atomic IR for operations it knew
the
underlying microarch had instructions for, meaning it required
significant
knowledge of the target. Later, the backend acquired the ability to
lower
IR to libcalls. To avoid duplicating logic and improve logic locality,
we'd like to move as much as possible to the backend.

There are many ways to describe this change. For example, this change
reduces the variables Clang uses to decide whether to emit libcalls or
IR, down to only the atomic's size.
2024-02-12 09:33:09 -08:00

69 lines
1.8 KiB
C++

// RUN: %clang_cc1 %s -std=c++11 -emit-llvm -o - -triple=x86_64-linux-gnu | FileCheck %s
// RUN: %clang_cc1 %s -std=c++11 -emit-llvm -o - -triple=x86_64-linux-gnu -target-cpu core2 | FileCheck %s --check-prefix=CORE2
// Check the atomic code generation for cpu targets w/wo cx16 support.
struct alignas(8) AM8 {
int f1, f2;
};
AM8 m8;
AM8 load8() {
AM8 am;
// CHECK-LABEL: @_Z5load8v
// CHECK: load atomic i64, {{.*}} monotonic, align 8
// CORE2-LABEL: @_Z5load8v
// CORE2: load atomic i64, {{.*}} monotonic, align 8
__atomic_load(&m8, &am, 0);
return am;
}
AM8 s8;
void store8() {
// CHECK-LABEL: @_Z6store8v
// CHECK: store atomic i64 {{.*}} monotonic, align 8
// CORE2-LABEL: @_Z6store8v
// CORE2: store atomic i64 {{.*}} monotonic, align 8
__atomic_store(&m8, &s8, 0);
}
bool cmpxchg8() {
AM8 am;
// CHECK-LABEL: @_Z8cmpxchg8v
// CHECK: cmpxchg ptr {{.*}} monotonic, align 8
// CORE2-LABEL: @_Z8cmpxchg8v
// CORE2: cmpxchg ptr {{.*}} monotonic, align 8
return __atomic_compare_exchange(&m8, &s8, &am, 0, 0, 0);
}
struct alignas(16) AM16 {
long f1, f2;
};
AM16 m16;
AM16 load16() {
AM16 am;
// CHECK-LABEL: @_Z6load16v
// CHECK: load atomic i128, {{.*}} monotonic, align 16
// CORE2-LABEL: @_Z6load16v
// CORE2: load atomic i128, {{.*}} monotonic, align 16
__atomic_load(&m16, &am, 0);
return am;
}
AM16 s16;
void store16() {
// CHECK-LABEL: @_Z7store16v
// CHECK: store atomic i128 {{.*}} monotonic, align 16
// CORE2-LABEL: @_Z7store16v
// CORE2: store atomic i128 {{.*}} monotonic, align 16
__atomic_store(&m16, &s16, 0);
}
bool cmpxchg16() {
AM16 am;
// CHECK-LABEL: @_Z9cmpxchg16v
// CHECK: cmpxchg ptr {{.*}} monotonic monotonic, align 16
// CORE2-LABEL: @_Z9cmpxchg16v
// CORE2: cmpxchg ptr {{.*}} monotonic monotonic, align 16
return __atomic_compare_exchange(&m16, &s16, &am, 0, 0, 0);
}