[PATCH] make local_t signed
local_t's were defined to be unsigned. This increases confusion because atomic_t's are signed. The patch goes through and changes all implementations to use signed longs throughout. Also, x86-64 was using 32-bit quantities for the value passed into local_add() and local_sub(). Fixed. All (actually, both) existing users have been audited. (Also s/__inline__/inline/ in x86_64/local.h) Cc: Andi Kleen <ak@muc.de> Cc: Benjamin LaHaise <bcrl@kvack.org> Cc: Kyle McMartin <kyle@parisc-linux.org> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:

committed by
Linus Torvalds

parent
09ce3512dc
commit
2cf8d82d63
@@ -5,7 +5,7 @@
|
||||
|
||||
typedef struct
|
||||
{
|
||||
volatile unsigned long counter;
|
||||
volatile long counter;
|
||||
} local_t;
|
||||
|
||||
#define LOCAL_INIT(i) { (i) }
|
||||
@@ -29,7 +29,7 @@ static __inline__ void local_dec(local_t *v)
|
||||
:"m" (v->counter));
|
||||
}
|
||||
|
||||
static __inline__ void local_add(unsigned long i, local_t *v)
|
||||
static __inline__ void local_add(long i, local_t *v)
|
||||
{
|
||||
__asm__ __volatile__(
|
||||
"addl %1,%0"
|
||||
@@ -37,7 +37,7 @@ static __inline__ void local_add(unsigned long i, local_t *v)
|
||||
:"ir" (i), "m" (v->counter));
|
||||
}
|
||||
|
||||
static __inline__ void local_sub(unsigned long i, local_t *v)
|
||||
static __inline__ void local_sub(long i, local_t *v)
|
||||
{
|
||||
__asm__ __volatile__(
|
||||
"subl %1,%0"
|
||||
|
Reference in New Issue
Block a user