| 
									
										
										
										
											2006-03-26 01:39:10 -08:00
										 |  |  | #ifndef _ASM_GENERIC_BITOPS_FLS64_H_
 | 
					
						
							|  |  |  | #define _ASM_GENERIC_BITOPS_FLS64_H_
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-03-26 01:39:14 -08:00
										 |  |  | #include <asm/types.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-15 18:32:36 +01:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * fls64 - find last set bit in a 64-bit word | 
					
						
							|  |  |  |  * @x: the word to search | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This is defined in a similar way as the libc and compiler builtin | 
					
						
							|  |  |  |  * ffsll, but returns the position of the most significant set bit. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * fls64(value) returns 0 if value is 0 or the position of the last | 
					
						
							|  |  |  |  * set bit if value is nonzero. The last (most significant) bit is | 
					
						
							|  |  |  |  * at position 64. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #if BITS_PER_LONG == 32
 | 
					
						
							| 
									
										
										
										
											2009-01-12 23:01:15 +01:00
										 |  |  | static __always_inline int fls64(__u64 x) | 
					
						
							| 
									
										
										
										
											2006-03-26 01:39:10 -08:00
										 |  |  | { | 
					
						
							|  |  |  | 	__u32 h = x >> 32; | 
					
						
							|  |  |  | 	if (h) | 
					
						
							|  |  |  | 		return fls(h) + 32; | 
					
						
							|  |  |  | 	return fls(x); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2008-03-15 18:32:36 +01:00
										 |  |  | #elif BITS_PER_LONG == 64
 | 
					
						
							| 
									
										
										
										
											2009-01-12 23:01:15 +01:00
										 |  |  | static __always_inline int fls64(__u64 x) | 
					
						
							| 
									
										
										
										
											2008-03-15 18:32:36 +01:00
										 |  |  | { | 
					
						
							|  |  |  | 	if (x == 0) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	return __fls(x) + 1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #error BITS_PER_LONG not 32 or 64
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2006-03-26 01:39:10 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | #endif /* _ASM_GENERIC_BITOPS_FLS64_H_ */
 |