hc
2023-12-09 958e46acc8e900e8569dd467c1af9b8d2d019394
kernel/include/asm-generic/atomic64.h
....@@ -1,37 +1,33 @@
1
+/* SPDX-License-Identifier: GPL-2.0-or-later */
12 /*
23 * Generic implementation of 64-bit atomics using spinlocks,
34 * useful on processors that don't have 64-bit atomic instructions.
45 *
56 * Copyright © 2009 Paul Mackerras, IBM Corp. <paulus@au1.ibm.com>
6
- *
7
- * This program is free software; you can redistribute it and/or
8
- * modify it under the terms of the GNU General Public License
9
- * as published by the Free Software Foundation; either version
10
- * 2 of the License, or (at your option) any later version.
117 */
128 #ifndef _ASM_GENERIC_ATOMIC64_H
139 #define _ASM_GENERIC_ATOMIC64_H
1410 #include <linux/types.h>
1511
1612 typedef struct {
17
- long long counter;
13
+ s64 counter;
1814 } atomic64_t;
1915
2016 #define ATOMIC64_INIT(i) { (i) }
2117
22
-extern long long atomic64_read(const atomic64_t *v);
23
-extern void atomic64_set(atomic64_t *v, long long i);
18
+extern s64 atomic64_read(const atomic64_t *v);
19
+extern void atomic64_set(atomic64_t *v, s64 i);
2420
2521 #define atomic64_set_release(v, i) atomic64_set((v), (i))
2622
2723 #define ATOMIC64_OP(op) \
28
-extern void atomic64_##op(long long a, atomic64_t *v);
24
+extern void atomic64_##op(s64 a, atomic64_t *v);
2925
3026 #define ATOMIC64_OP_RETURN(op) \
31
-extern long long atomic64_##op##_return(long long a, atomic64_t *v);
27
+extern s64 atomic64_##op##_return(s64 a, atomic64_t *v);
3228
3329 #define ATOMIC64_FETCH_OP(op) \
34
-extern long long atomic64_fetch_##op(long long a, atomic64_t *v);
30
+extern s64 atomic64_fetch_##op(s64 a, atomic64_t *v);
3531
3632 #define ATOMIC64_OPS(op) ATOMIC64_OP(op) ATOMIC64_OP_RETURN(op) ATOMIC64_FETCH_OP(op)
3733
....@@ -50,11 +46,11 @@
5046 #undef ATOMIC64_OP_RETURN
5147 #undef ATOMIC64_OP
5248
53
-extern long long atomic64_dec_if_positive(atomic64_t *v);
49
+extern s64 atomic64_dec_if_positive(atomic64_t *v);
5450 #define atomic64_dec_if_positive atomic64_dec_if_positive
55
-extern long long atomic64_cmpxchg(atomic64_t *v, long long o, long long n);
56
-extern long long atomic64_xchg(atomic64_t *v, long long new);
57
-extern long long atomic64_fetch_add_unless(atomic64_t *v, long long a, long long u);
51
+extern s64 atomic64_cmpxchg(atomic64_t *v, s64 o, s64 n);
52
+extern s64 atomic64_xchg(atomic64_t *v, s64 new);
53
+extern s64 atomic64_fetch_add_unless(atomic64_t *v, s64 a, s64 u);
5854 #define atomic64_fetch_add_unless atomic64_fetch_add_unless
5955
6056 #endif /* _ASM_GENERIC_ATOMIC64_H */