mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 394e3902c5
			
		
	
	
		394e3902c5
		
	
	
	
	
		
			
			When we stop allocating percpu memory for not-possible CPUs we must not touch the percpu data for not-possible CPUs at all. The correct way of doing this is to test cpu_possible() or to use for_each_cpu(). This patch is a kernel-wide sweep of all instances of NR_CPUS. I found very few instances of this bug, if any. But the patch converts lots of open-coded test to use the preferred helper macros. Cc: Mikael Starvik <starvik@axis.com> Cc: David Howells <dhowells@redhat.com> Acked-by: Kyle McMartin <kyle@parisc-linux.org> Cc: Anton Blanchard <anton@samba.org> Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org> Cc: Paul Mackerras <paulus@samba.org> Cc: Martin Schwidefsky <schwidefsky@de.ibm.com> Cc: Heiko Carstens <heiko.carstens@de.ibm.com> Cc: Paul Mundt <lethal@linux-sh.org> Cc: "David S. Miller" <davem@davemloft.net> Cc: William Lee Irwin III <wli@holomorphy.com> Cc: Andi Kleen <ak@muc.de> Cc: Christian Zankel <chris@zankel.net> Cc: Philippe Elie <phil.el@wanadoo.fr> Cc: Nathan Scott <nathans@sgi.com> Cc: Jens Axboe <axboe@suse.de> Cc: Eric Dumazet <dada1@cosmosbay.com> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
		
			
				
	
	
		
			49 lines
		
	
	
		
			835 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			49 lines
		
	
	
		
			835 B
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef _ASM_ALPHA_TOPOLOGY_H
 | |
| #define _ASM_ALPHA_TOPOLOGY_H
 | |
| 
 | |
| #include <linux/smp.h>
 | |
| #include <linux/threads.h>
 | |
| #include <asm/machvec.h>
 | |
| 
 | |
| #ifdef CONFIG_NUMA
 | |
| static inline int cpu_to_node(int cpu)
 | |
| {
 | |
| 	int node;
 | |
| 	
 | |
| 	if (!alpha_mv.cpuid_to_nid)
 | |
| 		return 0;
 | |
| 
 | |
| 	node = alpha_mv.cpuid_to_nid(cpu);
 | |
| 
 | |
| #ifdef DEBUG_NUMA
 | |
| 	BUG_ON(node < 0);
 | |
| #endif
 | |
| 
 | |
| 	return node;
 | |
| }
 | |
| 
 | |
| static inline cpumask_t node_to_cpumask(int node)
 | |
| {
 | |
| 	cpumask_t node_cpu_mask = CPU_MASK_NONE;
 | |
| 	int cpu;
 | |
| 
 | |
| 	for_each_online_cpu(cpu) {
 | |
| 		if (cpu_to_node(cpu) == node)
 | |
| 			cpu_set(cpu, node_cpu_mask);
 | |
| 	}
 | |
| 
 | |
| #ifdef DEBUG_NUMA
 | |
| 	printk("node %d: cpu_mask: %016lx\n", node, node_cpu_mask);
 | |
| #endif
 | |
| 
 | |
| 	return node_cpu_mask;
 | |
| }
 | |
| 
 | |
| #define pcibus_to_cpumask(bus)	(cpu_online_map)
 | |
| 
 | |
| #else /* CONFIG_NUMA */
 | |
| # include <asm-generic/topology.h>
 | |
| #endif /* !CONFIG_NUMA */
 | |
| 
 | |
| #endif /* _ASM_ALPHA_TOPOLOGY_H */
 |