aboutsummaryrefslogtreecommitdiffstats
path: root/include/asm-x86/local_32.h
diff options
context:
space:
mode:
authorHarvey Harrison <harvey.harrison@gmail.com>2008-01-30 07:31:26 -0500
committerIngo Molnar <mingo@elte.hu>2008-01-30 07:31:26 -0500
commit4ad02718345783a3b84bae1895917666b779850d (patch)
treeffeb70f577b394a042f5816afd0de081560b98e6 /include/asm-x86/local_32.h
parentfe758fb1192790f8e465a7f59efe47ca73717d3e (diff)
x86: clean up local_{32|64}.h
Common prefix from both files moved to local.h Change __inline__ to inline Signed-off-by: Harvey Harrison <harvey.harrison@gmail.com> Signed-off-by: Ingo Molnar <mingo@elte.hu> Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'include/asm-x86/local_32.h')
-rw-r--r--include/asm-x86/local_32.h34
1 files changed, 10 insertions, 24 deletions
diff --git a/include/asm-x86/local_32.h b/include/asm-x86/local_32.h
index 6e85975b9ed2..33d9c7bf463c 100644
--- a/include/asm-x86/local_32.h
+++ b/include/asm-x86/local_32.h
@@ -1,35 +1,21 @@
1#ifndef _ARCH_I386_LOCAL_H 1#ifndef _ARCH_I386_LOCAL_H
2#define _ARCH_I386_LOCAL_H 2#define _ARCH_I386_LOCAL_H
3 3
4#include <linux/percpu.h> 4static inline void local_inc(local_t *l)
5#include <asm/system.h>
6#include <asm/atomic.h>
7
8typedef struct
9{
10 atomic_long_t a;
11} local_t;
12
13#define LOCAL_INIT(i) { ATOMIC_LONG_INIT(i) }
14
15#define local_read(l) atomic_long_read(&(l)->a)
16#define local_set(l,i) atomic_long_set(&(l)->a, (i))
17
18static __inline__ void local_inc(local_t *l)
19{ 5{
20 __asm__ __volatile__( 6 __asm__ __volatile__(
21 "incl %0" 7 "incl %0"
22 :"+m" (l->a.counter)); 8 :"+m" (l->a.counter));
23} 9}
24 10
25static __inline__ void local_dec(local_t *l) 11static inline void local_dec(local_t *l)
26{ 12{
27 __asm__ __volatile__( 13 __asm__ __volatile__(
28 "decl %0" 14 "decl %0"
29 :"+m" (l->a.counter)); 15 :"+m" (l->a.counter));
30} 16}
31 17
32static __inline__ void local_add(long i, local_t *l) 18static inline void local_add(long i, local_t *l)
33{ 19{
34 __asm__ __volatile__( 20 __asm__ __volatile__(
35 "addl %1,%0" 21 "addl %1,%0"
@@ -37,7 +23,7 @@ static __inline__ void local_add(long i, local_t *l)
37 :"ir" (i)); 23 :"ir" (i));
38} 24}
39 25
40static __inline__ void local_sub(long i, local_t *l) 26static inline void local_sub(long i, local_t *l)
41{ 27{
42 __asm__ __volatile__( 28 __asm__ __volatile__(
43 "subl %1,%0" 29 "subl %1,%0"
@@ -54,7 +40,7 @@ static __inline__ void local_sub(long i, local_t *l)
54 * true if the result is zero, or false for all 40 * true if the result is zero, or false for all
55 * other cases. 41 * other cases.
56 */ 42 */
57static __inline__ int local_sub_and_test(long i, local_t *l) 43static inline int local_sub_and_test(long i, local_t *l)
58{ 44{
59 unsigned char c; 45 unsigned char c;
60 46
@@ -73,7 +59,7 @@ static __inline__ int local_sub_and_test(long i, local_t *l)
73 * returns true if the result is 0, or false for all other 59 * returns true if the result is 0, or false for all other
74 * cases. 60 * cases.
75 */ 61 */
76static __inline__ int local_dec_and_test(local_t *l) 62static inline int local_dec_and_test(local_t *l)
77{ 63{
78 unsigned char c; 64 unsigned char c;
79 65
@@ -92,7 +78,7 @@ static __inline__ int local_dec_and_test(local_t *l)
92 * and returns true if the result is zero, or false for all 78 * and returns true if the result is zero, or false for all
93 * other cases. 79 * other cases.
94 */ 80 */
95static __inline__ int local_inc_and_test(local_t *l) 81static inline int local_inc_and_test(local_t *l)
96{ 82{
97 unsigned char c; 83 unsigned char c;
98 84
@@ -112,7 +98,7 @@ static __inline__ int local_inc_and_test(local_t *l)
112 * if the result is negative, or false when 98 * if the result is negative, or false when
113 * result is greater than or equal to zero. 99 * result is greater than or equal to zero.
114 */ 100 */
115static __inline__ int local_add_negative(long i, local_t *l) 101static inline int local_add_negative(long i, local_t *l)
116{ 102{
117 unsigned char c; 103 unsigned char c;
118 104
@@ -130,7 +116,7 @@ static __inline__ int local_add_negative(long i, local_t *l)
130 * 116 *
131 * Atomically adds @i to @l and returns @i + @l 117 * Atomically adds @i to @l and returns @i + @l
132 */ 118 */
133static __inline__ long local_add_return(long i, local_t *l) 119static inline long local_add_return(long i, local_t *l)
134{ 120{
135 long __i; 121 long __i;
136#ifdef CONFIG_M386 122#ifdef CONFIG_M386
@@ -156,7 +142,7 @@ no_xadd: /* Legacy 386 processor */
156#endif 142#endif
157} 143}
158 144
159static __inline__ long local_sub_return(long i, local_t *l) 145static inline long local_sub_return(long i, local_t *l)
160{ 146{
161 return local_add_return(-i,l); 147 return local_add_return(-i,l);
162} 148}