Skip to content

Commit

Permalink
asm-generic: cmpxchg does not handle non-long arguments
Browse files Browse the repository at this point in the history
The version of cmpxchg defined in asm-generic/system.h does not handle
correctly non-long arguments. Use the version defined in cmpxchg.h
instead.

Signed-off-by: Mathieu Lacage <[email protected]>
Signed-off-by: Arnd Bergmann <[email protected]>
  • Loading branch information
Mathieu Lacage authored and arndb committed Oct 9, 2010
1 parent 8b9d406 commit c669112
Showing 1 changed file with 1 addition and 19 deletions.
20 changes: 1 addition & 19 deletions include/asm-generic/system.h
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
#include <linux/irqflags.h>

#include <asm/cmpxchg-local.h>
#include <asm/cmpxchg.h>

struct task_struct;

Expand Down Expand Up @@ -136,25 +137,6 @@ unsigned long __xchg(unsigned long x, volatile void *ptr, int size)
#define xchg(ptr, x) \
((__typeof__(*(ptr))) __xchg((unsigned long)(x), (ptr), sizeof(*(ptr))))

static inline unsigned long __cmpxchg(volatile unsigned long *m,
unsigned long old, unsigned long new)
{
unsigned long retval;
unsigned long flags;

local_irq_save(flags);
retval = *m;
if (retval == old)
*m = new;
local_irq_restore(flags);
return retval;
}

#define cmpxchg(ptr, o, n) \
((__typeof__(*(ptr))) __cmpxchg((unsigned long *)(ptr), \
(unsigned long)(o), \
(unsigned long)(n)))

#endif /* !__ASSEMBLY__ */

#endif /* __KERNEL__ */
Expand Down

0 comments on commit c669112

Please sign in to comment.