| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #ifndef __ASM_SH_BITOPS_H
 | 
					
						
							|  |  |  | #define __ASM_SH_BITOPS_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __KERNEL__
 | 
					
						
							| 
									
										
										
										
											2007-10-18 23:40:26 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifndef _LINUX_BITOPS_H
 | 
					
						
							|  |  |  | #error only <linux/bitops.h> can be included directly
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /* For __swab32 */ | 
					
						
							|  |  |  | #include <asm/byteorder.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-11-30 16:12:36 +09:00
										 |  |  | #ifdef CONFIG_GUSA_RB
 | 
					
						
							|  |  |  | #include <asm/bitops-grb.h>
 | 
					
						
							| 
									
										
										
										
											2008-11-25 21:22:02 +09:00
										 |  |  | #elif defined(CONFIG_CPU_SH2A)
 | 
					
						
							|  |  |  | #include <asm-generic/bitops/atomic.h>
 | 
					
						
							|  |  |  | #include <asm/bitops-op32.h>
 | 
					
						
							| 
									
										
										
										
											2008-08-07 17:36:12 +09:00
										 |  |  | #elif defined(CONFIG_CPU_SH4A)
 | 
					
						
							|  |  |  | #include <asm/bitops-llsc.h>
 | 
					
						
							| 
									
										
										
										
											2007-11-30 16:12:36 +09:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2008-11-20 15:25:22 +09:00
										 |  |  | #include <asm-generic/bitops/atomic.h>
 | 
					
						
							|  |  |  | #include <asm-generic/bitops/non-atomic.h>
 | 
					
						
							| 
									
										
										
										
											2007-11-30 16:12:36 +09:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * clear_bit() doesn't provide any barrier for the compiler. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2009-10-18 15:36:02 +09:00
										 |  |  | #define smp_mb__before_clear_bit()	smp_mb()
 | 
					
						
							|  |  |  | #define smp_mb__after_clear_bit()	smp_mb()
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-11-11 17:28:18 +09:00
										 |  |  | #ifdef CONFIG_SUPERH32
 | 
					
						
							| 
									
										
										
										
											2006-09-27 12:31:01 +09:00
										 |  |  | static inline unsigned long ffz(unsigned long word) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							|  |  |  | 	unsigned long result; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	__asm__("1:\n\t" | 
					
						
							|  |  |  | 		"shlr	%1\n\t" | 
					
						
							|  |  |  | 		"bt/s	1b\n\t" | 
					
						
							|  |  |  | 		" add	#1, %0" | 
					
						
							|  |  |  | 		: "=r" (result), "=r" (word) | 
					
						
							|  |  |  | 		: "0" (~0L), "1" (word) | 
					
						
							|  |  |  | 		: "t"); | 
					
						
							|  |  |  | 	return result; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * __ffs - find first bit in word. | 
					
						
							|  |  |  |  * @word: The word to search | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Undefined if no bit exists, so code should check against 0 first. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2006-09-27 12:31:01 +09:00
										 |  |  | static inline unsigned long __ffs(unsigned long word) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							|  |  |  | 	unsigned long result; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	__asm__("1:\n\t" | 
					
						
							|  |  |  | 		"shlr	%1\n\t" | 
					
						
							|  |  |  | 		"bf/s	1b\n\t" | 
					
						
							|  |  |  | 		" add	#1, %0" | 
					
						
							|  |  |  | 		: "=r" (result), "=r" (word) | 
					
						
							|  |  |  | 		: "0" (~0L), "1" (word) | 
					
						
							|  |  |  | 		: "t"); | 
					
						
							|  |  |  | 	return result; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2007-11-11 17:28:18 +09:00
										 |  |  | #else
 | 
					
						
							|  |  |  | static inline unsigned long ffz(unsigned long word) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	unsigned long result, __d2, __d3; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         __asm__("gettr  tr0, %2\n\t" | 
					
						
							|  |  |  |                 "pta    $+32, tr0\n\t" | 
					
						
							|  |  |  |                 "andi   %1, 1, %3\n\t" | 
					
						
							|  |  |  |                 "beq    %3, r63, tr0\n\t" | 
					
						
							|  |  |  |                 "pta    $+4, tr0\n" | 
					
						
							|  |  |  |                 "0:\n\t" | 
					
						
							|  |  |  |                 "shlri.l        %1, 1, %1\n\t" | 
					
						
							|  |  |  |                 "addi   %0, 1, %0\n\t" | 
					
						
							|  |  |  |                 "andi   %1, 1, %3\n\t" | 
					
						
							|  |  |  |                 "beqi   %3, 1, tr0\n" | 
					
						
							|  |  |  |                 "1:\n\t" | 
					
						
							|  |  |  |                 "ptabs  %2, tr0\n\t" | 
					
						
							|  |  |  |                 : "=r" (result), "=r" (word), "=r" (__d2), "=r" (__d3) | 
					
						
							|  |  |  |                 : "0" (0L), "1" (word)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return result; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <asm-generic/bitops/__ffs.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
											
												[PATCH] bitops: sh: use generic bitops
- remove __{,test_and_}{set,clear,change}_bit() and test_bit()
- remove find_{next,first}{,_zero}_bit()
- remove generic_ffs()
- remove generic_hweight{32,16,8}()
- remove sched_find_first_bit()
- remove ext2_{set,clear,test,find_first_zero,find_next_zero}_bit()
- remove ext2_{set,clear}_bit_atomic()
- remove minix_{test,set,test_and_clear,test,find_first_zero}_bit()
- remove generic_fls()
- remove generic_fls64()
Signed-off-by: Akinobu Mita <mita@miraclelinux.com>
Cc: Paul Mundt <lethal@linux-sh.org>
Cc: Kazumoto Kojima <kkojima@rr.iij4u.or.jp>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
											
										 
											2006-03-26 01:39:35 -08:00
										 |  |  | #include <asm-generic/bitops/find.h>
 | 
					
						
							|  |  |  | #include <asm-generic/bitops/ffs.h>
 | 
					
						
							|  |  |  | #include <asm-generic/bitops/hweight.h>
 | 
					
						
							| 
									
										
										
										
											2007-10-18 03:06:39 -07:00
										 |  |  | #include <asm-generic/bitops/lock.h>
 | 
					
						
							| 
									
										
										
											
												[PATCH] bitops: sh: use generic bitops
- remove __{,test_and_}{set,clear,change}_bit() and test_bit()
- remove find_{next,first}{,_zero}_bit()
- remove generic_ffs()
- remove generic_hweight{32,16,8}()
- remove sched_find_first_bit()
- remove ext2_{set,clear,test,find_first_zero,find_next_zero}_bit()
- remove ext2_{set,clear}_bit_atomic()
- remove minix_{test,set,test_and_clear,test,find_first_zero}_bit()
- remove generic_fls()
- remove generic_fls64()
Signed-off-by: Akinobu Mita <mita@miraclelinux.com>
Cc: Paul Mundt <lethal@linux-sh.org>
Cc: Kazumoto Kojima <kkojima@rr.iij4u.or.jp>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
											
										 
											2006-03-26 01:39:35 -08:00
										 |  |  | #include <asm-generic/bitops/sched.h>
 | 
					
						
							| 
									
										
											  
											
												bitops: introduce little-endian bitops for most architectures
Introduce little-endian bit operations to the big-endian architectures
which do not have native little-endian bit operations and the
little-endian architectures.  (alpha, avr32, blackfin, cris, frv, h8300,
ia64, m32r, mips, mn10300, parisc, sh, sparc, tile, x86, xtensa)
These architectures can just include generic implementation
(asm-generic/bitops/le.h).
Signed-off-by: Akinobu Mita <akinobu.mita@gmail.com>
Cc: Richard Henderson <rth@twiddle.net>
Cc: Ivan Kokshaysky <ink@jurassic.park.msu.ru>
Cc: Mikael Starvik <starvik@axis.com>
Cc: David Howells <dhowells@redhat.com>
Cc: Yoshinori Sato <ysato@users.sourceforge.jp>
Cc: "Luck, Tony" <tony.luck@intel.com>
Cc: Ralf Baechle <ralf@linux-mips.org>
Cc: Kyle McMartin <kyle@mcmartin.ca>
Cc: Matthew Wilcox <willy@debian.org>
Cc: Grant Grundler <grundler@parisc-linux.org>
Cc: Paul Mundt <lethal@linux-sh.org>
Cc: Kazumoto Kojima <kkojima@rr.iij4u.or.jp>
Cc: Hirokazu Takata <takata@linux-m32r.org>
Cc: "David S. Miller" <davem@davemloft.net>
Cc: Chris Zankel <chris@zankel.net>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Thomas Gleixner <tglx@linutronix.de>
Acked-by: Hans-Christian Egtvedt <hans-christian.egtvedt@atmel.com>
Acked-by: "H. Peter Anvin" <hpa@zytor.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
											
										 
											2011-03-23 16:42:02 -07:00
										 |  |  | #include <asm-generic/bitops/le.h>
 | 
					
						
							| 
									
										
										
											
												[PATCH] bitops: sh: use generic bitops
- remove __{,test_and_}{set,clear,change}_bit() and test_bit()
- remove find_{next,first}{,_zero}_bit()
- remove generic_ffs()
- remove generic_hweight{32,16,8}()
- remove sched_find_first_bit()
- remove ext2_{set,clear,test,find_first_zero,find_next_zero}_bit()
- remove ext2_{set,clear}_bit_atomic()
- remove minix_{test,set,test_and_clear,test,find_first_zero}_bit()
- remove generic_fls()
- remove generic_fls64()
Signed-off-by: Akinobu Mita <mita@miraclelinux.com>
Cc: Paul Mundt <lethal@linux-sh.org>
Cc: Kazumoto Kojima <kkojima@rr.iij4u.or.jp>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
											
										 
											2006-03-26 01:39:35 -08:00
										 |  |  | #include <asm-generic/bitops/ext2-atomic.h>
 | 
					
						
							|  |  |  | #include <asm-generic/bitops/fls.h>
 | 
					
						
							| 
									
										
										
										
											2008-03-15 18:31:49 +01:00
										 |  |  | #include <asm-generic/bitops/__fls.h>
 | 
					
						
							| 
									
										
										
											
												[PATCH] bitops: sh: use generic bitops
- remove __{,test_and_}{set,clear,change}_bit() and test_bit()
- remove find_{next,first}{,_zero}_bit()
- remove generic_ffs()
- remove generic_hweight{32,16,8}()
- remove sched_find_first_bit()
- remove ext2_{set,clear,test,find_first_zero,find_next_zero}_bit()
- remove ext2_{set,clear}_bit_atomic()
- remove minix_{test,set,test_and_clear,test,find_first_zero}_bit()
- remove generic_fls()
- remove generic_fls64()
Signed-off-by: Akinobu Mita <mita@miraclelinux.com>
Cc: Paul Mundt <lethal@linux-sh.org>
Cc: Kazumoto Kojima <kkojima@rr.iij4u.or.jp>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
											
										 
											2006-03-26 01:39:35 -08:00
										 |  |  | #include <asm-generic/bitops/fls64.h>
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #endif /* __KERNEL__ */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* __ASM_SH_BITOPS_H */
 |