| /* SPDX-License-Identifier: GPL-2.0-only */ |
| /* |
| * Copyright (C) 2004, 2007-2010, 2011-2012 Synopsys, Inc. (www.synopsys.com) |
| */ |
| |
| #ifndef _ASM_ARC_ATOMIC_H |
| #define _ASM_ARC_ATOMIC_H |
| |
| #ifndef __ASSEMBLY__ |
| |
| #include <linux/types.h> |
| #include <linux/compiler.h> |
| #include <asm/cmpxchg.h> |
| #include <asm/barrier.h> |
| #include <asm/smp.h> |
| |
| #define arch_atomic_read(v) READ_ONCE((v)->counter) |
| |
| #ifdef CONFIG_ARC_HAS_LLSC |
| #include <asm/atomic-llsc.h> |
| #else |
| #include <asm/atomic-spinlock.h> |
| #endif |
| |
| /* |
| * 64-bit atomics |
| */ |
| #ifdef CONFIG_GENERIC_ATOMIC64 |
| #include <asm-generic/atomic64.h> |
| #else |
| #include <asm/atomic64-arcv2.h> |
| #endif |
| |
| #endif /* !__ASSEMBLY__ */ |
| |
| #endif |