mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-18 22:14:16 +00:00 
			
		
		
		
	 53b8a315b7
			
		
	
	
		53b8a315b7
		
	
	
	
	
		
			
			We frequently need the maximum number of possible processors in order to allocate arrays for all processors. So far this was done using highest_possible_processor_id(). However, we do need the number of processors not the highest id. Moreover the number was so far dynamically calculated on each invokation. The number of possible processors does not change when the system is running. We can therefore calculate that number once. Signed-off-by: Christoph Lameter <clameter@sgi.com> Cc: Frederik Deweerdt <frederik.deweerdt@gmail.com> Cc: Neil Brown <neilb@suse.de> Cc: Trond Myklebust <trond.myklebust@fys.uio.no> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
		
			
				
	
	
		
			31 lines
		
	
	
	
		
			609 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			31 lines
		
	
	
	
		
			609 B
		
	
	
	
		
			C
		
	
	
	
	
	
| #include <linux/kernel.h>
 | |
| #include <linux/bitops.h>
 | |
| #include <linux/cpumask.h>
 | |
| #include <linux/module.h>
 | |
| 
 | |
| int __first_cpu(const cpumask_t *srcp)
 | |
| {
 | |
| 	return min_t(int, NR_CPUS, find_first_bit(srcp->bits, NR_CPUS));
 | |
| }
 | |
| EXPORT_SYMBOL(__first_cpu);
 | |
| 
 | |
| int __next_cpu(int n, const cpumask_t *srcp)
 | |
| {
 | |
| 	return min_t(int, NR_CPUS, find_next_bit(srcp->bits, NR_CPUS, n+1));
 | |
| }
 | |
| EXPORT_SYMBOL(__next_cpu);
 | |
| 
 | |
| int nr_cpu_ids;
 | |
| EXPORT_SYMBOL(nr_cpu_ids);
 | |
| 
 | |
| int __any_online_cpu(const cpumask_t *mask)
 | |
| {
 | |
| 	int cpu;
 | |
| 
 | |
| 	for_each_cpu_mask(cpu, *mask) {
 | |
| 		if (cpu_online(cpu))
 | |
| 			break;
 | |
| 	}
 | |
| 	return cpu;
 | |
| }
 | |
| EXPORT_SYMBOL(__any_online_cpu);
 |