mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 1deab8ce2c
			
		
	
	
		1deab8ce2c
		
	
	
	
	
		
			
			Pull sparc updates from David Miller:
 1) Add missing cmpxchg64() for 32-bit sparc.
 2) Timer conversions from Allen Pais and Kees Cook.
 3) vDSO support, from Nagarathnam Muthusamy.
 4) Fix sparc64 huge page table walks based upon bug report by Al Viro,
    from Nitin Gupta.
 5) Optimized fls() for T4 and above, from Vijay Kumar.
* git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc:
  sparc64: Fix page table walk for PUD hugepages
  sparc64: Convert timers to user timer_setup()
  sparc64: convert mdesc_handle.refcnt from atomic_t to refcount_t
  sparc/led: Convert timers to use timer_setup()
  sparc64: Use sparc optimized fls and __fls for T4 and above
  sparc64: SPARC optimized __fls function
  sparc64: SPARC optimized fls function
  sparc64: Define SPARC default __fls function
  sparc64: Define SPARC default fls function
  vDSO for sparc
  sparc32: Add cmpxchg64().
  sbus: char: Move D7S_MINOR to include/linux/miscdevice.h
  sparc: time: Remove unneeded linux/miscdevice.h include
  sparc64: mmu_context: Add missing include files
		
	
			
		
			
				
	
	
		
			66 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| /*
 | |
|  * bitops.h: Bit string operations on the V9.
 | |
|  *
 | |
|  * Copyright 1996, 1997 David S. Miller (davem@caip.rutgers.edu)
 | |
|  */
 | |
| 
 | |
| #ifndef _SPARC64_BITOPS_H
 | |
| #define _SPARC64_BITOPS_H
 | |
| 
 | |
| #ifndef _LINUX_BITOPS_H
 | |
| #error only <linux/bitops.h> can be included directly
 | |
| #endif
 | |
| 
 | |
| #include <linux/compiler.h>
 | |
| #include <asm/byteorder.h>
 | |
| #include <asm/barrier.h>
 | |
| 
 | |
| int test_and_set_bit(unsigned long nr, volatile unsigned long *addr);
 | |
| int test_and_clear_bit(unsigned long nr, volatile unsigned long *addr);
 | |
| int test_and_change_bit(unsigned long nr, volatile unsigned long *addr);
 | |
| void set_bit(unsigned long nr, volatile unsigned long *addr);
 | |
| void clear_bit(unsigned long nr, volatile unsigned long *addr);
 | |
| void change_bit(unsigned long nr, volatile unsigned long *addr);
 | |
| 
 | |
| int fls(unsigned int word);
 | |
| int __fls(unsigned long word);
 | |
| 
 | |
| #include <asm-generic/bitops/non-atomic.h>
 | |
| 
 | |
| #include <asm-generic/bitops/fls64.h>
 | |
| 
 | |
| #ifdef __KERNEL__
 | |
| 
 | |
| int ffs(int x);
 | |
| unsigned long __ffs(unsigned long);
 | |
| 
 | |
| #include <asm-generic/bitops/ffz.h>
 | |
| #include <asm-generic/bitops/sched.h>
 | |
| 
 | |
| /*
 | |
|  * hweightN: returns the hamming weight (i.e. the number
 | |
|  * of bits set) of a N-bit word
 | |
|  */
 | |
| 
 | |
| unsigned long __arch_hweight64(__u64 w);
 | |
| unsigned int __arch_hweight32(unsigned int w);
 | |
| unsigned int __arch_hweight16(unsigned int w);
 | |
| unsigned int __arch_hweight8(unsigned int w);
 | |
| 
 | |
| #include <asm-generic/bitops/const_hweight.h>
 | |
| #include <asm-generic/bitops/lock.h>
 | |
| #endif /* __KERNEL__ */
 | |
| 
 | |
| #include <asm-generic/bitops/find.h>
 | |
| 
 | |
| #ifdef __KERNEL__
 | |
| 
 | |
| #include <asm-generic/bitops/le.h>
 | |
| 
 | |
| #include <asm-generic/bitops/ext2-atomic-setbit.h>
 | |
| 
 | |
| #endif /* __KERNEL__ */
 | |
| 
 | |
| #endif /* defined(_SPARC64_BITOPS_H) */
 |