Fix roundup_pow_of_two(1)
1 is a power of two, therefore roundup_pow_of_two(1) should return 1. It does in case the argument is a variable but in case it's a constant it behaves wrong and returns 0. Probably nobody ever did it so this was never noticed. Signed-off-by: Rolf Eike Beer <eike-kernel@sf-tec.de> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
		
					parent
					
						
							
								18963c01b8
							
						
					
				
			
			
				commit
				
					
						1a06a52ee1
					
				
			
		
					 1 changed files with 1 additions and 1 deletions
				
			
		|  | @ -159,7 +159,7 @@ unsigned long __roundup_pow_of_two(unsigned long n) | ||||||
| #define roundup_pow_of_two(n)			\ | #define roundup_pow_of_two(n)			\ | ||||||
| (						\ | (						\ | ||||||
| 	__builtin_constant_p(n) ? (		\ | 	__builtin_constant_p(n) ? (		\ | ||||||
| 		(n == 1) ? 0 :			\ | 		(n == 1) ? 1 :			\ | ||||||
| 		(1UL << (ilog2((n) - 1) + 1))	\ | 		(1UL << (ilog2((n) - 1) + 1))	\ | ||||||
| 				   ) :		\ | 				   ) :		\ | ||||||
| 	__roundup_pow_of_two(n)			\ | 	__roundup_pow_of_two(n)			\ | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Rolf Eike Beer
				Rolf Eike Beer