; RUN: llvm-as < %s | llvm-dis > %t.orig
; RUN: llvm-as < %s | llvm-c-test --echo > %t.echo
; RUN: diff -w %t.orig %t.echo
define void @fence_instrs() {
fence acquire
fence release
fence acq_rel
fence seq_cst
fence syncscope("singlethread") acquire
fence syncscope("singlethread") release
fence syncscope("singlethread") acq_rel
fence syncscope("singlethread") seq_cst
ret void
}
define void @atomic_load_store(ptr %word) {
; Test different atomic loads
%ld.1 = load atomic i32, ptr %word monotonic, align 4
%ld.2 = load atomic volatile i32, ptr %word acquire, align 4
%ld.3 = load atomic volatile i32, ptr %word seq_cst, align 4
%ld.4 = load atomic volatile i32, ptr %word syncscope("singlethread") acquire, align 4
%ld.5 = load atomic volatile i32, ptr %word syncscope("singlethread") seq_cst, align 4
%ld.6 = load atomic i32, ptr %word syncscope("singlethread") seq_cst, align 4
; Test different atomic stores
store atomic i32 1, ptr %word monotonic, align 4
store atomic volatile i32 2, ptr %word release, align 4
store atomic volatile i32 3, ptr %word seq_cst, align 4
store atomic volatile i32 4, ptr %word syncscope("singlethread") release, align 4
store atomic volatile i32 5, ptr %word syncscope("singlethread") seq_cst, align 4
store atomic i32 6, ptr %word syncscope("singlethread") seq_cst, align 4
ret void
}
define void @atomic_rmw_ops(ptr %p, i32 %i, float %f) {
; Test all atomicrmw operations
%a.xchg = atomicrmw xchg ptr %p, i32 %i acq_rel, align 8
%a.add = atomicrmw add ptr %p, i32 %i acq_rel, align 8
%a.sub = atomicrmw sub ptr %p, i32 %i acq_rel, align 8
%a.and = atomicrmw and ptr %p, i32 %i acq_rel, align 8
%a.nand = atomicrmw nand ptr %p, i32 %i acq_rel, align 8
%a.or = atomicrmw or ptr %p, i32 %i acq_rel, align 8
%a.xor = atomicrmw xor ptr %p, i32 %i acq_rel, align 8
%a.max = atomicrmw max ptr %p, i32 %i acq_rel, align 8
%a.min = atomicrmw min ptr %p, i32 %i acq_rel, align 8
%a.umax = atomicrmw umax ptr %p, i32 %i acq_rel, align 8
%a.umin = atomicrmw umin ptr %p, i32 %i acq_rel, align 8
%a.fadd = atomicrmw fadd ptr %p, float %f acq_rel, align 8
%a.fsub = atomicrmw fsub ptr %p, float %f acq_rel, align 8
%a.fmax = atomicrmw fmax ptr %p, float %f acq_rel, align 8
%a.fmin = atomicrmw fmin ptr %p, float %f acq_rel, align 8
%a.uinc_wrap = atomicrmw uinc_wrap ptr %p, i32 %i acq_rel, align 8
%a.udec_wrap = atomicrmw udec_wrap ptr %p, i32 %i acq_rel, align 8
%a.usub_sat = atomicrmw usub_sat ptr %p, i32 %i acq_rel, align 8
%a.usub_cond = atomicrmw usub_cond ptr %p, i32 %i acq_rel, align 8
ret void
}
define i32 @main() {
%1 = alloca i32, align 4
%2 = cmpxchg ptr %1, i32 2, i32 3 seq_cst acquire
%3 = extractvalue { i32, i1 } %2, 0
ret i32 %3
}