File: atomics.ll

package info (click to toggle)
llvm-toolchain-19 1%3A19.1.7-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, trixie
  • size: 1,998,520 kB
  • sloc: cpp: 6,951,680; ansic: 1,486,157; asm: 913,598; python: 232,024; f90: 80,126; objc: 75,281; lisp: 37,276; pascal: 16,990; sh: 10,009; ml: 5,058; perl: 4,724; awk: 3,523; makefile: 3,167; javascript: 2,504; xml: 892; fortran: 664; cs: 573
file content (69 lines) | stat: -rw-r--r-- 2,818 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
; 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

  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
}