arch/s390/include/asm/atomic.h
Source file repositories/reference/linux-study-clean/arch/s390/include/asm/atomic.h
File Facts
- System
- Linux kernel
- Corpus path
arch/s390/include/asm/atomic.h- Extension
.h- Size
- 6770 bytes
- Lines
- 231
- Domain
- Architecture Layer
- Bucket
- arch/s390
- Inferred role
- Architecture Layer: implementation source
- Status
- source implementation candidate
Why This File Exists
CPU and platform-specific kernel glue: boot entry, traps, syscall entry, interrupts, page tables, context switch, and low-level barriers.
- CPU and platform-specific kernel glue: boot entry, traps, syscall entry, interrupts, page tables, context switch, and low-level barriers.
- Uses kernel synchronization; read lock ordering, sleepability, and interrupt context assumptions before translating.
Dependency Surface
linux/compiler.hlinux/types.hasm/atomic_ops.hasm/barrier.hasm/cmpxchg.h
Detected Declarations
function Authorfunction arch_atomic_setfunction arch_atomic_add_returnfunction arch_atomic_fetch_addfunction arch_atomic_addfunction arch_atomic_incfunction arch_atomic_decfunction arch_atomic_sub_and_testfunction arch_atomic_dec_and_testfunction arch_atomic_inc_and_testfunction arch_atomic_xchgfunction arch_atomic_cmpxchgfunction arch_atomic_try_cmpxchgfunction arch_atomic64_readfunction arch_atomic64_setfunction arch_atomic64_add_returnfunction arch_atomic64_fetch_addfunction arch_atomic64_addfunction arch_atomic64_incfunction arch_atomic64_decfunction arch_atomic64_sub_and_testfunction arch_atomic64_dec_and_testfunction arch_atomic64_inc_and_testfunction arch_atomic64_xchgfunction arch_atomic64_cmpxchgfunction arch_atomic64_try_cmpxchg
Annotated Snippet
#ifndef __ARCH_S390_ATOMIC__
#define __ARCH_S390_ATOMIC__
#include <linux/compiler.h>
#include <linux/types.h>
#include <asm/atomic_ops.h>
#include <asm/barrier.h>
#include <asm/cmpxchg.h>
static __always_inline int arch_atomic_read(const atomic_t *v)
{
return __atomic_read(&v->counter);
}
#define arch_atomic_read arch_atomic_read
static __always_inline void arch_atomic_set(atomic_t *v, int i)
{
__atomic_set(&v->counter, i);
}
#define arch_atomic_set arch_atomic_set
static __always_inline int arch_atomic_add_return(int i, atomic_t *v)
{
return __atomic_add_barrier(i, &v->counter) + i;
}
#define arch_atomic_add_return arch_atomic_add_return
static __always_inline int arch_atomic_fetch_add(int i, atomic_t *v)
{
return __atomic_add_barrier(i, &v->counter);
}
#define arch_atomic_fetch_add arch_atomic_fetch_add
static __always_inline void arch_atomic_add(int i, atomic_t *v)
{
__atomic_add(i, &v->counter);
}
#define arch_atomic_add arch_atomic_add
static __always_inline void arch_atomic_inc(atomic_t *v)
{
__atomic_add_const(1, &v->counter);
}
#define arch_atomic_inc arch_atomic_inc
static __always_inline void arch_atomic_dec(atomic_t *v)
{
__atomic_add_const(-1, &v->counter);
}
#define arch_atomic_dec arch_atomic_dec
static __always_inline bool arch_atomic_sub_and_test(int i, atomic_t *v)
{
return __atomic_add_and_test_barrier(-i, &v->counter);
}
#define arch_atomic_sub_and_test arch_atomic_sub_and_test
static __always_inline bool arch_atomic_dec_and_test(atomic_t *v)
{
return __atomic_add_const_and_test_barrier(-1, &v->counter);
}
#define arch_atomic_dec_and_test arch_atomic_dec_and_test
static __always_inline bool arch_atomic_inc_and_test(atomic_t *v)
{
return __atomic_add_const_and_test_barrier(1, &v->counter);
}
#define arch_atomic_inc_and_test arch_atomic_inc_and_test
#define arch_atomic_sub(_i, _v) arch_atomic_add(-(int)(_i), _v)
#define arch_atomic_sub_return(_i, _v) arch_atomic_add_return(-(int)(_i), _v)
#define arch_atomic_fetch_sub(_i, _v) arch_atomic_fetch_add(-(int)(_i), _v)
#define ATOMIC_OPS(op) \
static __always_inline void arch_atomic_##op(int i, atomic_t *v) \
{ \
__atomic_##op(i, &v->counter); \
} \
static __always_inline int arch_atomic_fetch_##op(int i, atomic_t *v) \
{ \
return __atomic_##op##_barrier(i, &v->counter); \
}
ATOMIC_OPS(and)
ATOMIC_OPS(or)
ATOMIC_OPS(xor)
#undef ATOMIC_OPS
#define arch_atomic_and arch_atomic_and
Annotation
- Immediate include surface: `linux/compiler.h`, `linux/types.h`, `asm/atomic_ops.h`, `asm/barrier.h`, `asm/cmpxchg.h`.
- Detected declarations: `function Author`, `function arch_atomic_set`, `function arch_atomic_add_return`, `function arch_atomic_fetch_add`, `function arch_atomic_add`, `function arch_atomic_inc`, `function arch_atomic_dec`, `function arch_atomic_sub_and_test`, `function arch_atomic_dec_and_test`, `function arch_atomic_inc_and_test`.
- Atlas domain: Architecture Layer / arch/s390.
- Implementation status: source implementation candidate.
- Synchronization appears in or near this file; preserve lock ordering, sleepability, and interrupt-context constraints.
Implementation Notes
- This generated page is the file-by-file coverage layer; curated subsystem chapters should link here when they synthesize a multi-file control flow.
- Core OS pages should be promoted from atlas-only to deep-reviewed when they explain data structures, invariants, locking, lifecycle, and C implementation snippets.
- Driver-family pages are intentionally pattern-oriented unless they are part of the selected PCIe/NVMe representative device path.