Define test_and_set_bit and test_and_clear bit for ARM Needed for (e.g.) ubifs support to work.
Signed-off-by: Simon Kagstrom <simon.kagst...@netinsight.net> --- include/asm-arm/bitops.h | 27 ++++++++++++++++++++++++--- 1 files changed, 24 insertions(+), 3 deletions(-) diff --git a/include/asm-arm/bitops.h b/include/asm-arm/bitops.h index e98dd56..7ae7aab 100644 --- a/include/asm-arm/bitops.h +++ b/include/asm-arm/bitops.h @@ -18,6 +18,7 @@ #ifdef __KERNEL__ #include <asm/types.h> +#include <asm/proc/system.h> #define smp_mb__before_clear_bit() do { } while (0) #define smp_mb__after_clear_bit() do { } while (0) @@ -46,8 +47,6 @@ static inline void __change_bit(int nr, volatile void *addr) ((unsigned char *) addr)[nr >> 3] ^= (1U << (nr & 7)); } -extern int test_and_set_bit(int nr, volatile void * addr); - static inline int __test_and_set_bit(int nr, volatile void *addr) { unsigned int mask = 1 << (nr & 7); @@ -58,7 +57,17 @@ static inline int __test_and_set_bit(int nr, volatile void *addr) return oldval & mask; } -extern int test_and_clear_bit(int nr, volatile void * addr); +static inline int test_and_set_bit(int nr, volatile void * addr) +{ + unsigned long flags; + int out; + + local_irq_save(flags); + out = __test_and_set_bit(nr, addr); + local_irq_restore(flags); + + return out; +} static inline int __test_and_clear_bit(int nr, volatile void *addr) { @@ -70,6 +79,18 @@ static inline int __test_and_clear_bit(int nr, volatile void *addr) return oldval & mask; } +static inline int test_and_clear_bit(int nr, volatile void * addr) +{ + unsigned long flags; + int out; + + local_irq_save(flags); + out = __test_and_clear_bit(nr, addr); + local_irq_restore(flags); + + return out; +} + extern int test_and_change_bit(int nr, volatile void * addr); static inline int __test_and_change_bit(int nr, volatile void *addr) -- 1.6.0.4 _______________________________________________ U-Boot mailing list U-Boot@lists.denx.de http://lists.denx.de/mailman/listinfo/u-boot