blob: 54c6e2887e9fbd742bea70bf5723404c5233c717 [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
Mike Frysingerae41f322011-06-17 16:20:36 -040010#ifdef CONFIG_SMP
Mike Frysinger3d150632009-06-13 11:21:51 -040011
Mike Frysingerae41f322011-06-17 16:20:36 -040012#include <linux/linkage.h>
Graf Yang6b3087c2009-01-07 23:14:39 +080013
14asmlinkage int __raw_uncached_fetch_asm(const volatile int *ptr);
Graf Yang6b3087c2009-01-07 23:14:39 +080015asmlinkage int __raw_atomic_update_asm(volatile int *ptr, int value);
Graf Yang6b3087c2009-01-07 23:14:39 +080016asmlinkage int __raw_atomic_clear_asm(volatile int *ptr, int value);
Graf Yang6b3087c2009-01-07 23:14:39 +080017asmlinkage int __raw_atomic_set_asm(volatile int *ptr, int value);
Graf Yang6b3087c2009-01-07 23:14:39 +080018asmlinkage int __raw_atomic_xor_asm(volatile int *ptr, int value);
Graf Yang6b3087c2009-01-07 23:14:39 +080019asmlinkage int __raw_atomic_test_asm(const volatile int *ptr, int value);
20
Mike Frysingerae41f322011-06-17 16:20:36 -040021#define atomic_read(v) __raw_uncached_fetch_asm(&(v)->counter)
Graf Yang6b3087c2009-01-07 23:14:39 +080022
Mike Frysingerae41f322011-06-17 16:20:36 -040023#define atomic_add_return(i, v) __raw_atomic_update_asm(&(v)->counter, i)
24#define atomic_sub_return(i, v) __raw_atomic_update_asm(&(v)->counter, -(i))
Graf Yang6b3087c2009-01-07 23:14:39 +080025
Mike Frysingerae41f322011-06-17 16:20:36 -040026#define atomic_clear_mask(m, v) __raw_atomic_clear_asm(&(v)->counter, m)
27#define atomic_set_mask(m, v) __raw_atomic_set_asm(&(v)->counter, m)
Bryan Wu1394f032007-05-06 14:50:22 -070028
Mike Frysinger3d150632009-06-13 11:21:51 -040029#endif
30
Mike Frysingerae41f322011-06-17 16:20:36 -040031#include <asm-generic/atomic.h>
32
Mike Frysinger3d150632009-06-13 11:21:51 -040033#endif