blob: c8db653c72d2c05f75046026cf1bc1621599d92e [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
Mike Frysingerae41f322011-06-17 16:20:36 -040014#include <linux/linkage.h>
Graf Yang6b3087c2009-01-07 23:14:39 +080015
16asmlinkage int __raw_uncached_fetch_asm(const volatile int *ptr);
Graf Yang6b3087c2009-01-07 23:14:39 +080017asmlinkage int __raw_atomic_update_asm(volatile int *ptr, int value);
Graf Yang6b3087c2009-01-07 23:14:39 +080018asmlinkage int __raw_atomic_clear_asm(volatile int *ptr, int value);
Graf Yang6b3087c2009-01-07 23:14:39 +080019asmlinkage int __raw_atomic_set_asm(volatile int *ptr, int value);
Graf Yang6b3087c2009-01-07 23:14:39 +080020asmlinkage int __raw_atomic_xor_asm(volatile int *ptr, int value);
Graf Yang6b3087c2009-01-07 23:14:39 +080021asmlinkage int __raw_atomic_test_asm(const volatile int *ptr, int value);
22
Mike Frysingerae41f322011-06-17 16:20:36 -040023#define atomic_read(v) __raw_uncached_fetch_asm(&(v)->counter)
Graf Yang6b3087c2009-01-07 23:14:39 +080024
Mike Frysingerae41f322011-06-17 16:20:36 -040025#define atomic_add_return(i, v) __raw_atomic_update_asm(&(v)->counter, i)
26#define atomic_sub_return(i, v) __raw_atomic_update_asm(&(v)->counter, -(i))
Graf Yang6b3087c2009-01-07 23:14:39 +080027
Mike Frysingerae41f322011-06-17 16:20:36 -040028#define atomic_clear_mask(m, v) __raw_atomic_clear_asm(&(v)->counter, m)
29#define atomic_set_mask(m, v) __raw_atomic_set_asm(&(v)->counter, m)
Bryan Wu1394f032007-05-06 14:50:22 -070030
Mike Frysinger3d150632009-06-13 11:21:51 -040031#endif
32
Mike Frysingerae41f322011-06-17 16:20:36 -040033#include <asm-generic/atomic.h>
34
Mike Frysinger3d150632009-06-13 11:21:51 -040035#endif