diff options
author | Akinobu Mita <akinobu.mita@gmail.com> | 2013-03-23 10:05:29 -0400 |
---|---|---|
committer | Martin Schwidefsky <schwidefsky@de.ibm.com> | 2013-04-17 08:07:29 -0400 |
commit | 01c2475f6d959ed3beb9ce1b0bc6f8108179af65 (patch) | |
tree | 044c092597a2154d2fc8aa642f611f254ef891c2 /arch/s390/include/asm | |
parent | f7f8d7e51d3c31426ee006c38d5b0ae3c9b8733e (diff) |
s390/bitops: remove unnecessary macro definitions in asm/bitops.h
Remove unused __BITOPS_ALIGN, and replace __BITOPS_WORDSIZE with
BITS_PER_LONG.
Signed-off-by: Akinobu Mita <akinobu.mita@gmail.com>
Signed-off-by: Heiko Carstens <heiko.carstens@de.ibm.com>
Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Diffstat (limited to 'arch/s390/include/asm')
-rw-r--r-- | arch/s390/include/asm/bitops.h | 110 |
1 files changed, 53 insertions, 57 deletions
diff --git a/arch/s390/include/asm/bitops.h b/arch/s390/include/asm/bitops.h index 15422933c60b..2bc357408f43 100644 --- a/arch/s390/include/asm/bitops.h +++ b/arch/s390/include/asm/bitops.h | |||
@@ -61,8 +61,6 @@ extern const char _sb_findmap[]; | |||
61 | 61 | ||
62 | #ifndef CONFIG_64BIT | 62 | #ifndef CONFIG_64BIT |
63 | 63 | ||
64 | #define __BITOPS_ALIGN 3 | ||
65 | #define __BITOPS_WORDSIZE 32 | ||
66 | #define __BITOPS_OR "or" | 64 | #define __BITOPS_OR "or" |
67 | #define __BITOPS_AND "nr" | 65 | #define __BITOPS_AND "nr" |
68 | #define __BITOPS_XOR "xr" | 66 | #define __BITOPS_XOR "xr" |
@@ -81,8 +79,6 @@ extern const char _sb_findmap[]; | |||
81 | 79 | ||
82 | #else /* CONFIG_64BIT */ | 80 | #else /* CONFIG_64BIT */ |
83 | 81 | ||
84 | #define __BITOPS_ALIGN 7 | ||
85 | #define __BITOPS_WORDSIZE 64 | ||
86 | #define __BITOPS_OR "ogr" | 82 | #define __BITOPS_OR "ogr" |
87 | #define __BITOPS_AND "ngr" | 83 | #define __BITOPS_AND "ngr" |
88 | #define __BITOPS_XOR "xgr" | 84 | #define __BITOPS_XOR "xgr" |
@@ -101,7 +97,7 @@ extern const char _sb_findmap[]; | |||
101 | 97 | ||
102 | #endif /* CONFIG_64BIT */ | 98 | #endif /* CONFIG_64BIT */ |
103 | 99 | ||
104 | #define __BITOPS_WORDS(bits) (((bits)+__BITOPS_WORDSIZE-1)/__BITOPS_WORDSIZE) | 100 | #define __BITOPS_WORDS(bits) (((bits) + BITS_PER_LONG - 1) / BITS_PER_LONG) |
105 | #define __BITOPS_BARRIER() asm volatile("" : : : "memory") | 101 | #define __BITOPS_BARRIER() asm volatile("" : : : "memory") |
106 | 102 | ||
107 | #ifdef CONFIG_SMP | 103 | #ifdef CONFIG_SMP |
@@ -114,9 +110,9 @@ static inline void set_bit_cs(unsigned long nr, volatile unsigned long *ptr) | |||
114 | 110 | ||
115 | addr = (unsigned long) ptr; | 111 | addr = (unsigned long) ptr; |
116 | /* calculate address for CS */ | 112 | /* calculate address for CS */ |
117 | addr += (nr ^ (nr & (__BITOPS_WORDSIZE - 1))) >> 3; | 113 | addr += (nr ^ (nr & (BITS_PER_LONG - 1))) >> 3; |
118 | /* make OR mask */ | 114 | /* make OR mask */ |
119 | mask = 1UL << (nr & (__BITOPS_WORDSIZE - 1)); | 115 | mask = 1UL << (nr & (BITS_PER_LONG - 1)); |
120 | /* Do the atomic update. */ | 116 | /* Do the atomic update. */ |
121 | __BITOPS_LOOP(old, new, addr, mask, __BITOPS_OR); | 117 | __BITOPS_LOOP(old, new, addr, mask, __BITOPS_OR); |
122 | } | 118 | } |
@@ -130,9 +126,9 @@ static inline void clear_bit_cs(unsigned long nr, volatile unsigned long *ptr) | |||
130 | 126 | ||
131 | addr = (unsigned long) ptr; | 127 | addr = (unsigned long) ptr; |
132 | /* calculate address for CS */ | 128 | /* calculate address for CS */ |
133 | addr += (nr ^ (nr & (__BITOPS_WORDSIZE - 1))) >> 3; | 129 | addr += (nr ^ (nr & (BITS_PER_LONG - 1))) >> 3; |
134 | /* make AND mask */ | 130 | /* make AND mask */ |
135 | mask = ~(1UL << (nr & (__BITOPS_WORDSIZE - 1))); | 131 | mask = ~(1UL << (nr & (BITS_PER_LONG - 1))); |
136 | /* Do the atomic update. */ | 132 | /* Do the atomic update. */ |
137 | __BITOPS_LOOP(old, new, addr, mask, __BITOPS_AND); | 133 | __BITOPS_LOOP(old, new, addr, mask, __BITOPS_AND); |
138 | } | 134 | } |
@@ -146,9 +142,9 @@ static inline void change_bit_cs(unsigned long nr, volatile unsigned long *ptr) | |||
146 | 142 | ||
147 | addr = (unsigned long) ptr; | 143 | addr = (unsigned long) ptr; |
148 | /* calculate address for CS */ | 144 | /* calculate address for CS */ |
149 | addr += (nr ^ (nr & (__BITOPS_WORDSIZE - 1))) >> 3; | 145 | addr += (nr ^ (nr & (BITS_PER_LONG - 1))) >> 3; |
150 | /* make XOR mask */ | 146 | /* make XOR mask */ |
151 | mask = 1UL << (nr & (__BITOPS_WORDSIZE - 1)); | 147 | mask = 1UL << (nr & (BITS_PER_LONG - 1)); |
152 | /* Do the atomic update. */ | 148 | /* Do the atomic update. */ |
153 | __BITOPS_LOOP(old, new, addr, mask, __BITOPS_XOR); | 149 | __BITOPS_LOOP(old, new, addr, mask, __BITOPS_XOR); |
154 | } | 150 | } |
@@ -163,9 +159,9 @@ test_and_set_bit_cs(unsigned long nr, volatile unsigned long *ptr) | |||
163 | 159 | ||
164 | addr = (unsigned long) ptr; | 160 | addr = (unsigned long) ptr; |
165 | /* calculate address for CS */ | 161 | /* calculate address for CS */ |
166 | addr += (nr ^ (nr & (__BITOPS_WORDSIZE - 1))) >> 3; | 162 | addr += (nr ^ (nr & (BITS_PER_LONG - 1))) >> 3; |
167 | /* make OR/test mask */ | 163 | /* make OR/test mask */ |
168 | mask = 1UL << (nr & (__BITOPS_WORDSIZE - 1)); | 164 | mask = 1UL << (nr & (BITS_PER_LONG - 1)); |
169 | /* Do the atomic update. */ | 165 | /* Do the atomic update. */ |
170 | __BITOPS_LOOP(old, new, addr, mask, __BITOPS_OR); | 166 | __BITOPS_LOOP(old, new, addr, mask, __BITOPS_OR); |
171 | __BITOPS_BARRIER(); | 167 | __BITOPS_BARRIER(); |
@@ -182,9 +178,9 @@ test_and_clear_bit_cs(unsigned long nr, volatile unsigned long *ptr) | |||
182 | 178 | ||
183 | addr = (unsigned long) ptr; | 179 | addr = (unsigned long) ptr; |
184 | /* calculate address for CS */ | 180 | /* calculate address for CS */ |
185 | addr += (nr ^ (nr & (__BITOPS_WORDSIZE - 1))) >> 3; | 181 | addr += (nr ^ (nr & (BITS_PER_LONG - 1))) >> 3; |
186 | /* make AND/test mask */ | 182 | /* make AND/test mask */ |
187 | mask = ~(1UL << (nr & (__BITOPS_WORDSIZE - 1))); | 183 | mask = ~(1UL << (nr & (BITS_PER_LONG - 1))); |
188 | /* Do the atomic update. */ | 184 | /* Do the atomic update. */ |
189 | __BITOPS_LOOP(old, new, addr, mask, __BITOPS_AND); | 185 | __BITOPS_LOOP(old, new, addr, mask, __BITOPS_AND); |
190 | __BITOPS_BARRIER(); | 186 | __BITOPS_BARRIER(); |
@@ -201,9 +197,9 @@ test_and_change_bit_cs(unsigned long nr, volatile unsigned long *ptr) | |||
201 | 197 | ||
202 | addr = (unsigned long) ptr; | 198 | addr = (unsigned long) ptr; |
203 | /* calculate address for CS */ | 199 | /* calculate address for CS */ |
204 | addr += (nr ^ (nr & (__BITOPS_WORDSIZE - 1))) >> 3; | 200 | addr += (nr ^ (nr & (BITS_PER_LONG - 1))) >> 3; |
205 | /* make XOR/test mask */ | 201 | /* make XOR/test mask */ |
206 | mask = 1UL << (nr & (__BITOPS_WORDSIZE - 1)); | 202 | mask = 1UL << (nr & (BITS_PER_LONG - 1)); |
207 | /* Do the atomic update. */ | 203 | /* Do the atomic update. */ |
208 | __BITOPS_LOOP(old, new, addr, mask, __BITOPS_XOR); | 204 | __BITOPS_LOOP(old, new, addr, mask, __BITOPS_XOR); |
209 | __BITOPS_BARRIER(); | 205 | __BITOPS_BARRIER(); |
@@ -218,7 +214,7 @@ static inline void __set_bit(unsigned long nr, volatile unsigned long *ptr) | |||
218 | { | 214 | { |
219 | unsigned long addr; | 215 | unsigned long addr; |
220 | 216 | ||
221 | addr = (unsigned long) ptr + ((nr ^ (__BITOPS_WORDSIZE - 8)) >> 3); | 217 | addr = (unsigned long) ptr + ((nr ^ (BITS_PER_LONG - 8)) >> 3); |
222 | asm volatile( | 218 | asm volatile( |
223 | " oc %O0(1,%R0),%1" | 219 | " oc %O0(1,%R0),%1" |
224 | : "=Q" (*(char *) addr) : "Q" (_oi_bitmap[nr & 7]) : "cc" ); | 220 | : "=Q" (*(char *) addr) : "Q" (_oi_bitmap[nr & 7]) : "cc" ); |
@@ -229,7 +225,7 @@ __constant_set_bit(const unsigned long nr, volatile unsigned long *ptr) | |||
229 | { | 225 | { |
230 | unsigned long addr; | 226 | unsigned long addr; |
231 | 227 | ||
232 | addr = ((unsigned long) ptr) + ((nr ^ (__BITOPS_WORDSIZE - 8)) >> 3); | 228 | addr = ((unsigned long) ptr) + ((nr ^ (BITS_PER_LONG - 8)) >> 3); |
233 | *(unsigned char *) addr |= 1 << (nr & 7); | 229 | *(unsigned char *) addr |= 1 << (nr & 7); |
234 | } | 230 | } |
235 | 231 | ||
@@ -246,7 +242,7 @@ __clear_bit(unsigned long nr, volatile unsigned long *ptr) | |||
246 | { | 242 | { |
247 | unsigned long addr; | 243 | unsigned long addr; |
248 | 244 | ||
249 | addr = (unsigned long) ptr + ((nr ^ (__BITOPS_WORDSIZE - 8)) >> 3); | 245 | addr = (unsigned long) ptr + ((nr ^ (BITS_PER_LONG - 8)) >> 3); |
250 | asm volatile( | 246 | asm volatile( |
251 | " nc %O0(1,%R0),%1" | 247 | " nc %O0(1,%R0),%1" |
252 | : "=Q" (*(char *) addr) : "Q" (_ni_bitmap[nr & 7]) : "cc" ); | 248 | : "=Q" (*(char *) addr) : "Q" (_ni_bitmap[nr & 7]) : "cc" ); |
@@ -257,7 +253,7 @@ __constant_clear_bit(const unsigned long nr, volatile unsigned long *ptr) | |||
257 | { | 253 | { |
258 | unsigned long addr; | 254 | unsigned long addr; |
259 | 255 | ||
260 | addr = ((unsigned long) ptr) + ((nr ^ (__BITOPS_WORDSIZE - 8)) >> 3); | 256 | addr = ((unsigned long) ptr) + ((nr ^ (BITS_PER_LONG - 8)) >> 3); |
261 | *(unsigned char *) addr &= ~(1 << (nr & 7)); | 257 | *(unsigned char *) addr &= ~(1 << (nr & 7)); |
262 | } | 258 | } |
263 | 259 | ||
@@ -273,7 +269,7 @@ static inline void __change_bit(unsigned long nr, volatile unsigned long *ptr) | |||
273 | { | 269 | { |
274 | unsigned long addr; | 270 | unsigned long addr; |
275 | 271 | ||
276 | addr = (unsigned long) ptr + ((nr ^ (__BITOPS_WORDSIZE - 8)) >> 3); | 272 | addr = (unsigned long) ptr + ((nr ^ (BITS_PER_LONG - 8)) >> 3); |
277 | asm volatile( | 273 | asm volatile( |
278 | " xc %O0(1,%R0),%1" | 274 | " xc %O0(1,%R0),%1" |
279 | : "=Q" (*(char *) addr) : "Q" (_oi_bitmap[nr & 7]) : "cc" ); | 275 | : "=Q" (*(char *) addr) : "Q" (_oi_bitmap[nr & 7]) : "cc" ); |
@@ -284,7 +280,7 @@ __constant_change_bit(const unsigned long nr, volatile unsigned long *ptr) | |||
284 | { | 280 | { |
285 | unsigned long addr; | 281 | unsigned long addr; |
286 | 282 | ||
287 | addr = ((unsigned long) ptr) + ((nr ^ (__BITOPS_WORDSIZE - 8)) >> 3); | 283 | addr = ((unsigned long) ptr) + ((nr ^ (BITS_PER_LONG - 8)) >> 3); |
288 | *(unsigned char *) addr ^= 1 << (nr & 7); | 284 | *(unsigned char *) addr ^= 1 << (nr & 7); |
289 | } | 285 | } |
290 | 286 | ||
@@ -302,7 +298,7 @@ test_and_set_bit_simple(unsigned long nr, volatile unsigned long *ptr) | |||
302 | unsigned long addr; | 298 | unsigned long addr; |
303 | unsigned char ch; | 299 | unsigned char ch; |
304 | 300 | ||
305 | addr = (unsigned long) ptr + ((nr ^ (__BITOPS_WORDSIZE - 8)) >> 3); | 301 | addr = (unsigned long) ptr + ((nr ^ (BITS_PER_LONG - 8)) >> 3); |
306 | ch = *(unsigned char *) addr; | 302 | ch = *(unsigned char *) addr; |
307 | asm volatile( | 303 | asm volatile( |
308 | " oc %O0(1,%R0),%1" | 304 | " oc %O0(1,%R0),%1" |
@@ -321,7 +317,7 @@ test_and_clear_bit_simple(unsigned long nr, volatile unsigned long *ptr) | |||
321 | unsigned long addr; | 317 | unsigned long addr; |
322 | unsigned char ch; | 318 | unsigned char ch; |
323 | 319 | ||
324 | addr = (unsigned long) ptr + ((nr ^ (__BITOPS_WORDSIZE - 8)) >> 3); | 320 | addr = (unsigned long) ptr + ((nr ^ (BITS_PER_LONG - 8)) >> 3); |
325 | ch = *(unsigned char *) addr; | 321 | ch = *(unsigned char *) addr; |
326 | asm volatile( | 322 | asm volatile( |
327 | " nc %O0(1,%R0),%1" | 323 | " nc %O0(1,%R0),%1" |
@@ -340,7 +336,7 @@ test_and_change_bit_simple(unsigned long nr, volatile unsigned long *ptr) | |||
340 | unsigned long addr; | 336 | unsigned long addr; |
341 | unsigned char ch; | 337 | unsigned char ch; |
342 | 338 | ||
343 | addr = (unsigned long) ptr + ((nr ^ (__BITOPS_WORDSIZE - 8)) >> 3); | 339 | addr = (unsigned long) ptr + ((nr ^ (BITS_PER_LONG - 8)) >> 3); |
344 | ch = *(unsigned char *) addr; | 340 | ch = *(unsigned char *) addr; |
345 | asm volatile( | 341 | asm volatile( |
346 | " xc %O0(1,%R0),%1" | 342 | " xc %O0(1,%R0),%1" |
@@ -376,7 +372,7 @@ static inline int __test_bit(unsigned long nr, const volatile unsigned long *ptr | |||
376 | unsigned long addr; | 372 | unsigned long addr; |
377 | unsigned char ch; | 373 | unsigned char ch; |
378 | 374 | ||
379 | addr = (unsigned long) ptr + ((nr ^ (__BITOPS_WORDSIZE - 8)) >> 3); | 375 | addr = (unsigned long) ptr + ((nr ^ (BITS_PER_LONG - 8)) >> 3); |
380 | ch = *(volatile unsigned char *) addr; | 376 | ch = *(volatile unsigned char *) addr; |
381 | return (ch >> (nr & 7)) & 1; | 377 | return (ch >> (nr & 7)) & 1; |
382 | } | 378 | } |
@@ -384,7 +380,7 @@ static inline int __test_bit(unsigned long nr, const volatile unsigned long *ptr | |||
384 | static inline int | 380 | static inline int |
385 | __constant_test_bit(unsigned long nr, const volatile unsigned long *addr) { | 381 | __constant_test_bit(unsigned long nr, const volatile unsigned long *addr) { |
386 | return (((volatile char *) addr) | 382 | return (((volatile char *) addr) |
387 | [(nr^(__BITOPS_WORDSIZE-8))>>3] & (1<<(nr&7))) != 0; | 383 | [(nr^(BITS_PER_LONG-8))>>3] & (1<<(nr&7))) != 0; |
388 | } | 384 | } |
389 | 385 | ||
390 | #define test_bit(nr,addr) \ | 386 | #define test_bit(nr,addr) \ |
@@ -693,18 +689,18 @@ static inline int find_next_bit_left(const unsigned long *addr, | |||
693 | 689 | ||
694 | if (offset >= size) | 690 | if (offset >= size) |
695 | return size; | 691 | return size; |
696 | bit = offset & (__BITOPS_WORDSIZE - 1); | 692 | bit = offset & (BITS_PER_LONG - 1); |
697 | offset -= bit; | 693 | offset -= bit; |
698 | size -= offset; | 694 | size -= offset; |
699 | p = addr + offset / __BITOPS_WORDSIZE; | 695 | p = addr + offset / BITS_PER_LONG; |
700 | if (bit) { | 696 | if (bit) { |
701 | set = __flo_word(0, *p & (~0UL << bit)); | 697 | set = __flo_word(0, *p & (~0UL << bit)); |
702 | if (set >= size) | 698 | if (set >= size) |
703 | return size + offset; | 699 | return size + offset; |
704 | if (set < __BITOPS_WORDSIZE) | 700 | if (set < BITS_PER_LONG) |
705 | return set + offset; | 701 | return set + offset; |
706 | offset += __BITOPS_WORDSIZE; | 702 | offset += BITS_PER_LONG; |
707 | size -= __BITOPS_WORDSIZE; | 703 | size -= BITS_PER_LONG; |
708 | p++; | 704 | p++; |
709 | } | 705 | } |
710 | return offset + find_first_bit_left(p, size); | 706 | return offset + find_first_bit_left(p, size); |
@@ -736,22 +732,22 @@ static inline int find_next_zero_bit (const unsigned long * addr, | |||
736 | 732 | ||
737 | if (offset >= size) | 733 | if (offset >= size) |
738 | return size; | 734 | return size; |
739 | bit = offset & (__BITOPS_WORDSIZE - 1); | 735 | bit = offset & (BITS_PER_LONG - 1); |
740 | offset -= bit; | 736 | offset -= bit; |
741 | size -= offset; | 737 | size -= offset; |
742 | p = addr + offset / __BITOPS_WORDSIZE; | 738 | p = addr + offset / BITS_PER_LONG; |
743 | if (bit) { | 739 | if (bit) { |
744 | /* | 740 | /* |
745 | * __ffz_word returns __BITOPS_WORDSIZE | 741 | * __ffz_word returns BITS_PER_LONG |
746 | * if no zero bit is present in the word. | 742 | * if no zero bit is present in the word. |
747 | */ | 743 | */ |
748 | set = __ffz_word(bit, *p >> bit); | 744 | set = __ffz_word(bit, *p >> bit); |
749 | if (set >= size) | 745 | if (set >= size) |
750 | return size + offset; | 746 | return size + offset; |
751 | if (set < __BITOPS_WORDSIZE) | 747 | if (set < BITS_PER_LONG) |
752 | return set + offset; | 748 | return set + offset; |
753 | offset += __BITOPS_WORDSIZE; | 749 | offset += BITS_PER_LONG; |
754 | size -= __BITOPS_WORDSIZE; | 750 | size -= BITS_PER_LONG; |
755 | p++; | 751 | p++; |
756 | } | 752 | } |
757 | return offset + find_first_zero_bit(p, size); | 753 | return offset + find_first_zero_bit(p, size); |
@@ -773,22 +769,22 @@ static inline int find_next_bit (const unsigned long * addr, | |||
773 | 769 | ||
774 | if (offset >= size) | 770 | if (offset >= size) |
775 | return size; | 771 | return size; |
776 | bit = offset & (__BITOPS_WORDSIZE - 1); | 772 | bit = offset & (BITS_PER_LONG - 1); |
777 | offset -= bit; | 773 | offset -= bit; |
778 | size -= offset; | 774 | size -= offset; |
779 | p = addr + offset / __BITOPS_WORDSIZE; | 775 | p = addr + offset / BITS_PER_LONG; |
780 | if (bit) { | 776 | if (bit) { |
781 | /* | 777 | /* |
782 | * __ffs_word returns __BITOPS_WORDSIZE | 778 | * __ffs_word returns BITS_PER_LONG |
783 | * if no one bit is present in the word. | 779 | * if no one bit is present in the word. |
784 | */ | 780 | */ |
785 | set = __ffs_word(0, *p & (~0UL << bit)); | 781 | set = __ffs_word(0, *p & (~0UL << bit)); |
786 | if (set >= size) | 782 | if (set >= size) |
787 | return size + offset; | 783 | return size + offset; |
788 | if (set < __BITOPS_WORDSIZE) | 784 | if (set < BITS_PER_LONG) |
789 | return set + offset; | 785 | return set + offset; |
790 | offset += __BITOPS_WORDSIZE; | 786 | offset += BITS_PER_LONG; |
791 | size -= __BITOPS_WORDSIZE; | 787 | size -= BITS_PER_LONG; |
792 | p++; | 788 | p++; |
793 | } | 789 | } |
794 | return offset + find_first_bit(p, size); | 790 | return offset + find_first_bit(p, size); |
@@ -843,22 +839,22 @@ static inline int find_next_zero_bit_le(void *vaddr, unsigned long size, | |||
843 | 839 | ||
844 | if (offset >= size) | 840 | if (offset >= size) |
845 | return size; | 841 | return size; |
846 | bit = offset & (__BITOPS_WORDSIZE - 1); | 842 | bit = offset & (BITS_PER_LONG - 1); |
847 | offset -= bit; | 843 | offset -= bit; |
848 | size -= offset; | 844 | size -= offset; |
849 | p = addr + offset / __BITOPS_WORDSIZE; | 845 | p = addr + offset / BITS_PER_LONG; |
850 | if (bit) { | 846 | if (bit) { |
851 | /* | 847 | /* |
852 | * s390 version of ffz returns __BITOPS_WORDSIZE | 848 | * s390 version of ffz returns BITS_PER_LONG |
853 | * if no zero bit is present in the word. | 849 | * if no zero bit is present in the word. |
854 | */ | 850 | */ |
855 | set = __ffz_word(bit, __load_ulong_le(p, 0) >> bit); | 851 | set = __ffz_word(bit, __load_ulong_le(p, 0) >> bit); |
856 | if (set >= size) | 852 | if (set >= size) |
857 | return size + offset; | 853 | return size + offset; |
858 | if (set < __BITOPS_WORDSIZE) | 854 | if (set < BITS_PER_LONG) |
859 | return set + offset; | 855 | return set + offset; |
860 | offset += __BITOPS_WORDSIZE; | 856 | offset += BITS_PER_LONG; |
861 | size -= __BITOPS_WORDSIZE; | 857 | size -= BITS_PER_LONG; |
862 | p++; | 858 | p++; |
863 | } | 859 | } |
864 | return offset + find_first_zero_bit_le(p, size); | 860 | return offset + find_first_zero_bit_le(p, size); |
@@ -885,22 +881,22 @@ static inline int find_next_bit_le(void *vaddr, unsigned long size, | |||
885 | 881 | ||
886 | if (offset >= size) | 882 | if (offset >= size) |
887 | return size; | 883 | return size; |
888 | bit = offset & (__BITOPS_WORDSIZE - 1); | 884 | bit = offset & (BITS_PER_LONG - 1); |
889 | offset -= bit; | 885 | offset -= bit; |
890 | size -= offset; | 886 | size -= offset; |
891 | p = addr + offset / __BITOPS_WORDSIZE; | 887 | p = addr + offset / BITS_PER_LONG; |
892 | if (bit) { | 888 | if (bit) { |
893 | /* | 889 | /* |
894 | * s390 version of ffz returns __BITOPS_WORDSIZE | 890 | * s390 version of ffz returns BITS_PER_LONG |
895 | * if no zero bit is present in the word. | 891 | * if no zero bit is present in the word. |
896 | */ | 892 | */ |
897 | set = __ffs_word(0, __load_ulong_le(p, 0) & (~0UL << bit)); | 893 | set = __ffs_word(0, __load_ulong_le(p, 0) & (~0UL << bit)); |
898 | if (set >= size) | 894 | if (set >= size) |
899 | return size + offset; | 895 | return size + offset; |
900 | if (set < __BITOPS_WORDSIZE) | 896 | if (set < BITS_PER_LONG) |
901 | return set + offset; | 897 | return set + offset; |
902 | offset += __BITOPS_WORDSIZE; | 898 | offset += BITS_PER_LONG; |
903 | size -= __BITOPS_WORDSIZE; | 899 | size -= BITS_PER_LONG; |
904 | p++; | 900 | p++; |
905 | } | 901 | } |
906 | return offset + find_first_bit_le(p, size); | 902 | return offset + find_first_bit_le(p, size); |