From: Rusty Russell Anton: breaks PPC64, as it needs cpu_possible_mask, but fix is already in Ameslab tree. The for_each_cpu() and for_each_online_cpu() iterators take a mask, and noone uses them that way (except for arch/i386/mach-voyager, which uses for_each_cpu(cpu_online_mask). Make them more usable iterators, by dropping the "mask" arg. This requires that archs provide a cpu_possible_mask: most do, but PPC64 doesn't, so it is broken by this patch. The other archs use a #define to define it in asm/smp.h. Most places doing loops over cpus testing for cpu_online() should use for_each_cpu: it is synonymous at the moment, but with the CPU hotplug patch the difference becomes important. Followup patches will convert users. arch/i386/mach-voyager/voyager_smp.c | 12 ++++++------ include/asm-alpha/smp.h | 2 +- include/asm-i386/smp.h | 3 +-- include/asm-ia64/smp.h | 2 +- include/asm-mips/smp.h | 2 +- include/asm-parisc/smp.h | 2 +- include/asm-ppc/smp.h | 1 - include/asm-s390/smp.h | 1 - include/asm-sh/smp.h | 1 - include/asm-sparc64/smp.h | 2 +- include/asm-um/smp.h | 2 +- include/asm-x86_64/smp.h | 3 +-- include/linux/cpumask.h | 32 ++++++++++++++------------------ include/linux/smp.h | 1 - 14 files changed, 28 insertions(+), 38 deletions(-) diff -puN arch/i386/mach-voyager/voyager_smp.c~make-for_each_cpu-iterator-more-friendly arch/i386/mach-voyager/voyager_smp.c --- 25/arch/i386/mach-voyager/voyager_smp.c~make-for_each_cpu-iterator-more-friendly 2003-12-30 17:54:53.000000000 -0800 +++ 25-akpm/arch/i386/mach-voyager/voyager_smp.c 2003-12-30 17:54:53.000000000 -0800 @@ -130,7 +130,7 @@ send_QIC_CPI(__u32 cpuset, __u8 cpi) { int cpu; - for_each_cpu(cpu, cpu_online_map) { + for_each_online_cpu(cpu) { if(cpuset & (1<cpu) extern cpumask_t cpu_callout_map; - -#define cpu_possible(cpu) cpu_isset(cpu, cpu_callout_map) +#define cpu_possible_map cpu_callout_map /* We don't mark CPUs online until __cpu_up(), so we need another measure */ static inline int num_booting_cpus(void) diff -puN include/asm-ia64/smp.h~make-for_each_cpu-iterator-more-friendly include/asm-ia64/smp.h --- 25/include/asm-ia64/smp.h~make-for_each_cpu-iterator-more-friendly 2003-12-30 17:54:53.000000000 -0800 +++ 25-akpm/include/asm-ia64/smp.h 2003-12-30 17:54:53.000000000 -0800 @@ -48,7 +48,7 @@ extern volatile int ia64_cpu_to_sapicid[ extern unsigned long ap_wakeup_vector; -#define cpu_possible(cpu) cpu_isset(cpu, phys_cpu_present_map) +#define cpu_possible_map phys_cpu_present_map /* * Function to map hard smp processor id to logical id. Slow, so don't use this in diff -puN include/asm-mips/smp.h~make-for_each_cpu-iterator-more-friendly include/asm-mips/smp.h --- 25/include/asm-mips/smp.h~make-for_each_cpu-iterator-more-friendly 2003-12-30 17:54:53.000000000 -0800 +++ 25-akpm/include/asm-mips/smp.h 2003-12-30 17:54:53.000000000 -0800 @@ -48,8 +48,8 @@ extern struct call_data_struct *call_dat extern cpumask_t phys_cpu_present_map; extern cpumask_t cpu_online_map; +#define cpu_possible_map phys_cpu_present_map -#define cpu_possible(cpu) cpu_isset(cpu, phys_cpu_present_map) #define cpu_online(cpu) cpu_isset(cpu, cpu_online_map) static inline unsigned int num_online_cpus(void) diff -puN include/asm-parisc/smp.h~make-for_each_cpu-iterator-more-friendly include/asm-parisc/smp.h --- 25/include/asm-parisc/smp.h~make-for_each_cpu-iterator-more-friendly 2003-12-30 17:54:53.000000000 -0800 +++ 25-akpm/include/asm-parisc/smp.h 2003-12-30 17:54:53.000000000 -0800 @@ -54,7 +54,7 @@ extern unsigned long cpu_present_mask; #define smp_processor_id() (current_thread_info()->cpu) #define cpu_online(cpu) cpu_isset(cpu, cpu_online_map) -#define cpu_possible(cpu) cpu_isset(cpu, cpu_present_mask) +#define cpu_possible_map cpu_present_map #endif /* CONFIG_SMP */ diff -puN include/asm-ppc/smp.h~make-for_each_cpu-iterator-more-friendly include/asm-ppc/smp.h --- 25/include/asm-ppc/smp.h~make-for_each_cpu-iterator-more-friendly 2003-12-30 17:54:53.000000000 -0800 +++ 25-akpm/include/asm-ppc/smp.h 2003-12-30 17:54:53.000000000 -0800 @@ -48,7 +48,6 @@ extern void smp_local_timer_interrupt(st #define smp_processor_id() (current_thread_info()->cpu) #define cpu_online(cpu) cpu_isset(cpu, cpu_online_map) -#define cpu_possible(cpu) cpu_isset(cpu, cpu_possible_map) extern int __cpu_up(unsigned int cpu); diff -puN include/asm-s390/smp.h~make-for_each_cpu-iterator-more-friendly include/asm-s390/smp.h --- 25/include/asm-s390/smp.h~make-for_each_cpu-iterator-more-friendly 2003-12-30 17:54:53.000000000 -0800 +++ 25-akpm/include/asm-s390/smp.h 2003-12-30 17:54:53.000000000 -0800 @@ -49,7 +49,6 @@ extern cpumask_t cpu_possible_map; #define smp_processor_id() (S390_lowcore.cpu_data.cpu_nr) #define cpu_online(cpu) cpu_isset(cpu, cpu_online_map) -#define cpu_possible(cpu) cpu_isset(cpu, cpu_possible_map) extern __inline__ __u16 hard_smp_processor_id(void) { diff -puN include/asm-sh/smp.h~make-for_each_cpu-iterator-more-friendly include/asm-sh/smp.h --- 25/include/asm-sh/smp.h~make-for_each_cpu-iterator-more-friendly 2003-12-30 17:54:53.000000000 -0800 +++ 25-akpm/include/asm-sh/smp.h 2003-12-30 17:54:53.000000000 -0800 @@ -16,7 +16,6 @@ extern unsigned long cpu_online_map; #define cpu_online(cpu) (cpu_online_map & (1 << (cpu))) -#define cpu_possible(cpu) (cpu_online(cpu)) #define smp_processor_id() (current_thread_info()->cpu) diff -puN include/asm-sparc64/smp.h~make-for_each_cpu-iterator-more-friendly include/asm-sparc64/smp.h --- 25/include/asm-sparc64/smp.h~make-for_each_cpu-iterator-more-friendly 2003-12-30 17:54:53.000000000 -0800 +++ 25-akpm/include/asm-sparc64/smp.h 2003-12-30 17:54:53.000000000 -0800 @@ -33,7 +33,7 @@ extern unsigned char boot_cpu_id; extern cpumask_t phys_cpu_present_map; -#define cpu_possible(cpu) cpu_isset(cpu, phys_cpu_present_map) +#define cpu_possible_map phys_cpu_present_map #define cpu_online(cpu) cpu_isset(cpu, cpu_online_map) diff -puN include/asm-um/smp.h~make-for_each_cpu-iterator-more-friendly include/asm-um/smp.h --- 25/include/asm-um/smp.h~make-for_each_cpu-iterator-more-friendly 2003-12-30 17:54:53.000000000 -0800 +++ 25-akpm/include/asm-um/smp.h 2003-12-30 17:54:53.000000000 -0800 @@ -20,7 +20,7 @@ extern int hard_smp_processor_id(void); #define cpu_online(cpu) cpu_isset(cpu, cpu_online_map) extern int ncpus; -#define cpu_possible(cpu) (cpu < ncpus) + extern inline void smp_cpus_done(unsigned int maxcpus) { diff -puN include/asm-x86_64/smp.h~make-for_each_cpu-iterator-more-friendly include/asm-x86_64/smp.h --- 25/include/asm-x86_64/smp.h~make-for_each_cpu-iterator-more-friendly 2003-12-30 17:54:53.000000000 -0800 +++ 25-akpm/include/asm-x86_64/smp.h 2003-12-30 17:54:53.000000000 -0800 @@ -57,8 +57,7 @@ void smp_stop_cpu(void); */ extern cpumask_t cpu_callout_map; - -#define cpu_possible(cpu) cpu_isset(cpu, cpu_callout_map) +#define cpu_possible_map cpu_callout_map #define cpu_online(cpu) cpu_isset(cpu, cpu_online_map) static inline int num_booting_cpus(void) diff -puN include/linux/cpumask.h~make-for_each_cpu-iterator-more-friendly include/linux/cpumask.h --- 25/include/linux/cpumask.h~make-for_each_cpu-iterator-more-friendly 2003-12-30 17:54:53.000000000 -0800 +++ 25-akpm/include/linux/cpumask.h 2003-12-30 17:54:53.000000000 -0800 @@ -8,32 +8,28 @@ #ifdef CONFIG_SMP extern cpumask_t cpu_online_map; +extern cpumask_t cpu_possible_map; #define num_online_cpus() cpus_weight(cpu_online_map) #define cpu_online(cpu) cpu_isset(cpu, cpu_online_map) +#define cpu_possible(cpu) cpu_isset(cpu, cpu_possible_map) + +#define for_each_cpu_mask(cpu, mask) \ + for (cpu = first_cpu_const(mask); \ + cpu < NR_CPUS; \ + cpu = next_cpu_const(cpu, mask)) + +#define for_each_cpu(cpu) for_each_cpu_mask(cpu, cpu_possible_map) +#define for_each_online_cpu(cpu) for_each_cpu_mask(cpu, cpu_online_map) #else #define cpu_online_map cpumask_of_cpu(0) #define num_online_cpus() 1 #define cpu_online(cpu) ({ BUG_ON((cpu) != 0); 1; }) -#endif +#define cpu_possible(cpu) ({ BUG_ON((cpu) != 0); 1; }) -static inline int next_online_cpu(int cpu, cpumask_t map) -{ - do - cpu = next_cpu_const(cpu, mk_cpumask_const(map)); - while (cpu < NR_CPUS && !cpu_online(cpu)); - return cpu; -} - -#define for_each_cpu(cpu, map) \ - for (cpu = first_cpu_const(mk_cpumask_const(map)); \ - cpu < NR_CPUS; \ - cpu = next_cpu_const(cpu,mk_cpumask_const(map))) - -#define for_each_online_cpu(cpu, map) \ - for (cpu = first_cpu_const(mk_cpumask_const(map)); \ - cpu < NR_CPUS; \ - cpu = next_online_cpu(cpu,map)) +#define for_each_cpu(cpu) for (cpu = 0; cpu < 1; cpu++) +#define for_each_online_cpu(cpu) for (cpu = 0; cpu < 1; cpu++) +#endif extern int __mask_snprintf_len(char *buf, unsigned int buflen, const unsigned long *maskp, unsigned int maskbytes); diff -puN include/linux/smp.h~make-for_each_cpu-iterator-more-friendly include/linux/smp.h --- 25/include/linux/smp.h~make-for_each_cpu-iterator-more-friendly 2003-12-30 17:54:53.000000000 -0800 +++ 25-akpm/include/linux/smp.h 2003-12-30 17:54:53.000000000 -0800 @@ -103,7 +103,6 @@ void smp_prepare_boot_cpu(void); #define on_each_cpu(func,info,retry,wait) ({ func(info); 0; }) static inline void smp_send_reschedule(int cpu) { } #define num_booting_cpus() 1 -#define cpu_possible(cpu) ({ BUG_ON((cpu) != 0); 1; }) #define smp_prepare_boot_cpu() do {} while (0) #endif /* !SMP */ _