blob: 1c1c42330c99c9e432991429778625be6e5235df [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 atomic_or(i, v) (void)__raw_atomic_or_asm(&(v)->counter, i)
32#define atomic_and(i, v) (void)__raw_atomic_and_asm(&(v)->counter, i)
33#define atomic_xor(i, v) (void)__raw_atomic_xor_asm(&(v)->counter, i)
34
Mike Frysinger3d150632009-06-13 11:21:51 -040035#endif
36
Mike Frysingerae41f322011-06-17 16:20:36 -040037#include <asm-generic/atomic.h>
38
Mike Frysinger3d150632009-06-13 11:21:51 -040039#endif