| Akinobu Mita | 930ae74 | 2006-03-26 01:39:15 -0800 | [diff] [blame] | 1 | #ifndef _ASM_GENERIC_BITOPS_LE_H_ | 
 | 2 | #define _ASM_GENERIC_BITOPS_LE_H_ | 
 | 3 |  | 
 | 4 | #include <asm/types.h> | 
 | 5 | #include <asm/byteorder.h> | 
 | 6 |  | 
 | 7 | #define BITOP_WORD(nr)		((nr) / BITS_PER_LONG) | 
 | 8 | #define BITOP_LE_SWIZZLE	((BITS_PER_LONG-1) & ~0x7) | 
 | 9 |  | 
 | 10 | #if defined(__LITTLE_ENDIAN) | 
 | 11 |  | 
 | 12 | #define generic_test_le_bit(nr, addr) test_bit(nr, addr) | 
 | 13 | #define generic___set_le_bit(nr, addr) __set_bit(nr, addr) | 
 | 14 | #define generic___clear_le_bit(nr, addr) __clear_bit(nr, addr) | 
 | 15 |  | 
 | 16 | #define generic_test_and_set_le_bit(nr, addr) test_and_set_bit(nr, addr) | 
 | 17 | #define generic_test_and_clear_le_bit(nr, addr) test_and_clear_bit(nr, addr) | 
 | 18 |  | 
 | 19 | #define generic___test_and_set_le_bit(nr, addr) __test_and_set_bit(nr, addr) | 
 | 20 | #define generic___test_and_clear_le_bit(nr, addr) __test_and_clear_bit(nr, addr) | 
 | 21 |  | 
 | 22 | #define generic_find_next_zero_le_bit(addr, size, offset) find_next_zero_bit(addr, size, offset) | 
| Aneesh Kumar K.V | aa02ad6 | 2008-01-28 23:58:27 -0500 | [diff] [blame] | 23 | #define generic_find_next_le_bit(addr, size, offset) \ | 
 | 24 | 			find_next_bit(addr, size, offset) | 
| Akinobu Mita | 930ae74 | 2006-03-26 01:39:15 -0800 | [diff] [blame] | 25 |  | 
 | 26 | #elif defined(__BIG_ENDIAN) | 
 | 27 |  | 
 | 28 | #define generic_test_le_bit(nr, addr) \ | 
 | 29 | 	test_bit((nr) ^ BITOP_LE_SWIZZLE, (addr)) | 
 | 30 | #define generic___set_le_bit(nr, addr) \ | 
 | 31 | 	__set_bit((nr) ^ BITOP_LE_SWIZZLE, (addr)) | 
 | 32 | #define generic___clear_le_bit(nr, addr) \ | 
 | 33 | 	__clear_bit((nr) ^ BITOP_LE_SWIZZLE, (addr)) | 
 | 34 |  | 
 | 35 | #define generic_test_and_set_le_bit(nr, addr) \ | 
 | 36 | 	test_and_set_bit((nr) ^ BITOP_LE_SWIZZLE, (addr)) | 
 | 37 | #define generic_test_and_clear_le_bit(nr, addr) \ | 
 | 38 | 	test_and_clear_bit((nr) ^ BITOP_LE_SWIZZLE, (addr)) | 
 | 39 |  | 
 | 40 | #define generic___test_and_set_le_bit(nr, addr) \ | 
 | 41 | 	__test_and_set_bit((nr) ^ BITOP_LE_SWIZZLE, (addr)) | 
 | 42 | #define generic___test_and_clear_le_bit(nr, addr) \ | 
 | 43 | 	__test_and_clear_bit((nr) ^ BITOP_LE_SWIZZLE, (addr)) | 
 | 44 |  | 
 | 45 | extern unsigned long generic_find_next_zero_le_bit(const unsigned long *addr, | 
 | 46 | 		unsigned long size, unsigned long offset); | 
| Aneesh Kumar K.V | aa02ad6 | 2008-01-28 23:58:27 -0500 | [diff] [blame] | 47 | extern unsigned long generic_find_next_le_bit(const unsigned long *addr, | 
 | 48 | 		unsigned long size, unsigned long offset); | 
| Akinobu Mita | 930ae74 | 2006-03-26 01:39:15 -0800 | [diff] [blame] | 49 |  | 
 | 50 | #else | 
 | 51 | #error "Please fix <asm/byteorder.h>" | 
 | 52 | #endif | 
 | 53 |  | 
 | 54 | #define generic_find_first_zero_le_bit(addr, size) \ | 
 | 55 |         generic_find_next_zero_le_bit((addr), (size), 0) | 
 | 56 |  | 
 | 57 | #endif /* _ASM_GENERIC_BITOPS_LE_H_ */ |