blob: eafa55b81a7b6953d15f80ec5ee07d5263e04075 [file] [log] [blame]
Robin Getz96f10502009-09-24 14:11:24 +00001/*
Mike Frysingerae41f322011-06-17 16:20:36 -04002 * Copyright 2004-2011 Analog Devices Inc.
Mike Frysinger96956452011-06-17 17:54:40 -04003 *
4 * Licensed under the GPL-2 or later.
5 */
Robin Getz96f10502009-09-24 14:11:24 +00006
Bryan Wu1394f032007-05-06 14:50:22 -07007#ifndef __ARCH_BLACKFIN_ATOMIC__
8#define __ARCH_BLACKFIN_ATOMIC__
9
David Howells3bed8d62012-03-12 23:36:56 +000010#include <asm/cmpxchg.h>
11
Mike Frysingerae41f322011-06-17 16:20:36 -040012#ifdef CONFIG_SMP
Mike Frysinger3d150632009-06-13 11:21:51 -040013
Steven Miao5b083092013-05-08 18:06:59 +080014#include <asm/barrier.h>
Mike Frysingerae41f322011-06-17 16:20:36 -040015#include <linux/linkage.h>
Steven Miao5b083092013-05-08 18:06:59 +080016#include <linux/types.h>
Graf Yang6b3087c2009-01-07 23:14:39 +080017
18asmlinkage int __raw_uncached_fetch_asm(const volatile int *ptr);
Peter Zijlstrad835b6c2015-04-23 21:44:42 +020019asmlinkage int __raw_atomic_add_asm(volatile int *ptr, int value);
20
21asmlinkage int __raw_atomic_and_asm(volatile int *ptr, int value);
22asmlinkage int __raw_atomic_or_asm(volatile int *ptr, int value);
Graf Yang6b3087c2009-01-07 23:14:39 +080023asmlinkage int __raw_atomic_xor_asm(volatile int *ptr, int value);
Graf Yang6b3087c2009-01-07 23:14:39 +080024asmlinkage int __raw_atomic_test_asm(const volatile int *ptr, int value);
25
Mike Frysingerae41f322011-06-17 16:20:36 -040026#define atomic_read(v) __raw_uncached_fetch_asm(&(v)->counter)
Graf Yang6b3087c2009-01-07 23:14:39 +080027
Peter Zijlstrad835b6c2015-04-23 21:44:42 +020028#define atomic_add_return(i, v) __raw_atomic_add_asm(&(v)->counter, i)
29#define atomic_sub_return(i, v) __raw_atomic_add_asm(&(v)->counter, -(i))
Graf Yang6b3087c2009-01-07 23:14:39 +080030
Peter Zijlstrad835b6c2015-04-23 21:44:42 +020031#define CONFIG_ARCH_HAS_ATOMIC_OR
32
33#define atomic_or(i, v) (void)__raw_atomic_or_asm(&(v)->counter, i)
34#define atomic_and(i, v) (void)__raw_atomic_and_asm(&(v)->counter, i)
35#define atomic_xor(i, v) (void)__raw_atomic_xor_asm(&(v)->counter, i)
36
37static inline __deprecated void atomic_clear_mask(unsigned int mask, atomic_t *v)
38{
39 atomic_and(~mask, v);
40}
41
42static inline __deprecated void atomic_set_mask(unsigned int mask, atomic_t *v)
43{
44 atomic_or(mask, v);
45}
Bryan Wu1394f032007-05-06 14:50:22 -070046
Mike Frysinger3d150632009-06-13 11:21:51 -040047#endif
48
Mike Frysingerae41f322011-06-17 16:20:36 -040049#include <asm-generic/atomic.h>
50
Mike Frysinger3d150632009-06-13 11:21:51 -040051#endif