#define __set_bit(n,p) set_bit(n,p)
#define __clear_bit(n,p) clear_bit(n,p)
+#define BITS_PER_WORD 32
#define BIT(nr) (1UL << (nr))
-#define BIT_MASK(nr) (1UL << ((nr) % BITS_PER_LONG))
-#define BIT_WORD(nr) ((nr) / BITS_PER_LONG)
+#define BIT_MASK(nr) (1UL << ((nr) % BITS_PER_WORD))
+#define BIT_WORD(nr) ((nr) / BITS_PER_WORD)
#define BITS_PER_BYTE 8
-#define ADDR (*(volatile long *) addr)
-#define CONST_ADDR (*(const volatile long *) addr)
+#define ADDR (*(volatile int *) addr)
+#define CONST_ADDR (*(const volatile int *) addr)
#if defined(CONFIG_ARM_32)
# include <asm/arm32/bitops.h>
*/
static inline int __test_and_set_bit(int nr, volatile void *addr)
{
- unsigned long mask = BIT_MASK(nr);
- volatile unsigned long *p =
- ((volatile unsigned long *)addr) + BIT_WORD(nr);
- unsigned long old = *p;
+ unsigned int mask = BIT_MASK(nr);
+ volatile unsigned int *p =
+ ((volatile unsigned int *)addr) + BIT_WORD(nr);
+ unsigned int old = *p;
*p = old | mask;
return (old & mask) != 0;
*/
static inline int __test_and_clear_bit(int nr, volatile void *addr)
{
- unsigned long mask = BIT_MASK(nr);
- volatile unsigned long *p =
- ((volatile unsigned long *)addr) + BIT_WORD(nr);
- unsigned long old = *p;
+ unsigned int mask = BIT_MASK(nr);
+ volatile unsigned int *p =
+ ((volatile unsigned int *)addr) + BIT_WORD(nr);
+ unsigned int old = *p;
*p = old & ~mask;
return (old & mask) != 0;
static inline int __test_and_change_bit(int nr,
volatile void *addr)
{
- unsigned long mask = BIT_MASK(nr);
- volatile unsigned long *p =
- ((volatile unsigned long *)addr) + BIT_WORD(nr);
- unsigned long old = *p;
+ unsigned int mask = BIT_MASK(nr);
+ volatile unsigned int *p =
+ ((volatile unsigned int *)addr) + BIT_WORD(nr);
+ unsigned int old = *p;
*p = old ^ mask;
return (old & mask) != 0;
*/
static inline int test_bit(int nr, const volatile void *addr)
{
- const volatile unsigned long *p = (const volatile unsigned long *)addr;
- return 1UL & (p[BIT_WORD(nr)] >> (nr & (BITS_PER_LONG-1)));
+ const volatile unsigned int *p = (const volatile unsigned int *)addr;
+ return 1UL & (p[BIT_WORD(nr)] >> (nr & (BITS_PER_WORD-1)));
}
static inline int constant_fls(int x)