GCC Code Coverage Report


Directory: cvmfs/
File: cvmfs/util/atomic.h
Date: 2026-02-01 02:35:56
Exec Total Coverage
Lines: 41 43 95.3%
Branches: 8 8 100.0%

Line Branch Exec Source
1 /**
2 * This file is part of the CernVM File System.
3 *
4 * Defines wrapper functions for atomic integer operations. Atomic operations
5 * are handled by GCC.
6 */
7
8 #ifndef CVMFS_UTIL_ATOMIC_H_
9 #define CVMFS_UTIL_ATOMIC_H_
10
11 #include <stdint.h>
12
13 #ifdef CVMFS_NAMESPACE_GUARD
14 namespace CVMFS_NAMESPACE_GUARD {
15 #endif
16
17 typedef int32_t atomic_int32;
18 typedef int64_t atomic_int64;
19
20 24715360 static void inline __attribute__((used)) atomic_init32(atomic_int32 *a) {
21 24715360 *a = 0;
22 24715360 }
23
24 10197589 static void inline __attribute__((used)) atomic_init64(atomic_int64 *a) {
25 10197589 *a = 0;
26 10197589 }
27
28 2875813886 static int32_t inline __attribute__((used)) atomic_read32(atomic_int32 *a) {
29 2875813886 return __sync_fetch_and_add(a, 0);
30 }
31
32 1570016201 static int64_t inline __attribute__((used)) atomic_read64(atomic_int64 *a) {
33 1570016201 return __sync_fetch_and_add(a, 0);
34 }
35
36 565341870 static void inline __attribute__((used)) atomic_write32(atomic_int32 *a,
37 int32_t value) {
38
2/2
✓ Branch 1 taken 1002969981 times.
✓ Branch 2 taken 698310615 times.
1568311851 while (!__sync_bool_compare_and_swap(a, atomic_read32(a), value)) {
39 }
40 698310615 }
41
42 538672788 static void inline __attribute__((used)) atomic_write64(atomic_int64 *a,
43 int64_t value) {
44
2/2
✓ Branch 1 taken 1131309855 times.
✓ Branch 2 taken 669449928 times.
1669982643 while (!__sync_bool_compare_and_swap(a, atomic_read64(a), value)) {
45 }
46 669449928 }
47
48 294212687 static void inline __attribute__((used)) atomic_inc32(atomic_int32 *a) {
49 294212687 (void)__sync_fetch_and_add(a, 1);
50 294212687 }
51
52 442196193 static void inline __attribute__((used)) atomic_inc64(atomic_int64 *a) {
53 442196193 (void)__sync_fetch_and_add(a, 1);
54 442196193 }
55
56 196628979 static void inline __attribute__((used)) atomic_dec32(atomic_int32 *a) {
57 196628979 (void)__sync_fetch_and_sub(a, 1);
58 196628979 }
59
60 165993091 static void inline __attribute__((used)) atomic_dec64(atomic_int64 *a) {
61 165993091 (void)__sync_fetch_and_sub(a, 1);
62 165993091 }
63
64 38554749 static int32_t inline __attribute__((used)) atomic_xadd32(atomic_int32 *a,
65 int32_t offset) {
66
2/2
✓ Branch 0 taken 7436891 times.
✓ Branch 1 taken 31117858 times.
38554749 if (offset < 0)
67 7436891 return __sync_fetch_and_sub(a, -offset);
68 31117858 return __sync_fetch_and_add(a, offset);
69 }
70
71 133270806 static int64_t inline __attribute__((used)) atomic_xadd64(atomic_int64 *a,
72 int64_t offset) {
73
2/2
✓ Branch 0 taken 31923394 times.
✓ Branch 1 taken 101347412 times.
133270806 if (offset < 0)
74 31923394 return __sync_fetch_and_sub(a, -offset);
75 101347412 return __sync_fetch_and_add(a, offset);
76 }
77
78 4081530 static bool inline __attribute__((used)) atomic_cas32(atomic_int32 *a,
79 int32_t cmp,
80 int32_t newval) {
81 4081530 return __sync_bool_compare_and_swap(a, cmp, newval);
82 }
83
84 static bool inline __attribute__((used)) atomic_cas64(atomic_int64 *a,
85 int64_t cmp,
86 int64_t newval) {
87 // Clang 3.5 has a bug in optimized __sync_bool_compare_and_swap:
88 // https://bugs.llvm.org//show_bug.cgi?format=multiple&id=21499
89 return __sync_bool_compare_and_swap(a, cmp, newval);
90 }
91
92 492 static void inline __attribute__((used)) MemoryFence() {
93 492 asm __volatile__("" : : : "memory");
94 492 }
95
96 #ifdef CVMFS_NAMESPACE_GUARD
97 } // namespace CVMFS_NAMESPACE_GUARD
98 #endif
99
100 #endif // CVMFS_UTIL_ATOMIC_H_
101