Fix weird uses of num_online_cpus().
authorRusty Russell <rusty@rustcorp.com.au>
Thu, 5 Mar 2015 00:19:19 +0000 (10:49 +1030)
committerRusty Russell <rusty@rustcorp.com.au>
Tue, 10 Mar 2015 03:24:42 +0000 (13:54 +1030)
This may be OK in archs with contiguous CPU numbers and without
hotplug CPUs, but it sets a terrible example.

And open-coding it like drivers/scsi/hpsa.c is just weird.

BTRFS has a weird comparison with num_online_cpus() too, but since
BTRFS just screwed up my test machines' root partition, I'm not
touching it :)

Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
Reported-by: Oleg Drokin <green@linuxhacker.ru>
arch/m32r/kernel/smpboot.c
arch/sh/include/asm/mmu_context.h
arch/sh/kernel/smp.c
arch/um/kernel/smp.c
drivers/scsi/hpsa.c

index bb21f4f63170053c3b2237ba6f73727d9e134d13..a468467542f453d170e2ded0ac2e339ad574198f 100644 (file)
@@ -376,7 +376,7 @@ void __init smp_cpus_done(unsigned int max_cpus)
        if (!cpumask_equal(&cpu_callin_map, cpu_online_mask))
                BUG();
 
-       for (cpu_id = 0 ; cpu_id < num_online_cpus() ; cpu_id++)
+       for_each_online_cpu(cpu_id)
                show_cpu_info(cpu_id);
 
        /*
index b9d9489a50125b8d732299cf707b009a37617927..9f417feaf6e80b86b0c1da4fc740b9d7fe76722a 100644 (file)
@@ -99,7 +99,7 @@ static inline int init_new_context(struct task_struct *tsk,
 {
        int i;
 
-       for (i = 0; i < num_online_cpus(); i++)
+       for_each_online_cpu(i)
                cpu_context(i, mm) = NO_CONTEXT;
 
        return 0;
index fc5acfc93c92bf9cbce40bfd306331c3075b75d8..de6be008fc0140ff7086bd4c153619f7213fc8cd 100644 (file)
@@ -363,7 +363,7 @@ void flush_tlb_mm(struct mm_struct *mm)
                smp_call_function(flush_tlb_mm_ipi, (void *)mm, 1);
        } else {
                int i;
-               for (i = 0; i < num_online_cpus(); i++)
+               for_each_online_cpu(i)
                        if (smp_processor_id() != i)
                                cpu_context(i, mm) = 0;
        }
@@ -400,7 +400,7 @@ void flush_tlb_range(struct vm_area_struct *vma,
                smp_call_function(flush_tlb_range_ipi, (void *)&fd, 1);
        } else {
                int i;
-               for (i = 0; i < num_online_cpus(); i++)
+               for_each_online_cpu(i)
                        if (smp_processor_id() != i)
                                cpu_context(i, mm) = 0;
        }
@@ -443,7 +443,7 @@ void flush_tlb_page(struct vm_area_struct *vma, unsigned long page)
                smp_call_function(flush_tlb_page_ipi, (void *)&fd, 1);
        } else {
                int i;
-               for (i = 0; i < num_online_cpus(); i++)
+               for_each_online_cpu(i)
                        if (smp_processor_id() != i)
                                cpu_context(i, vma->vm_mm) = 0;
        }
index 74077892b34a45c9efb47b9bcab9b8afb4e68352..525c3657a6af8da6d0b6576c6bd15b0ea77058c5 100644 (file)
@@ -45,7 +45,7 @@ void smp_send_stop(void)
        int i;
 
        printk(KERN_INFO "Stopping all CPUs...");
-       for (i = 0; i < num_online_cpus(); i++) {
+       for_each_online_cpu(i) {
                if (i == current_thread->cpu)
                        continue;
                os_write_file(cpu_data[i].ipi_pipe[1], "S", 1);
index a1cfbd3dda4713d05f254b0a9ef33131f6c12c0b..8eab107b53fbab2641a5545b964873ad57677072 100644 (file)
@@ -6632,14 +6632,12 @@ static void fail_all_outstanding_cmds(struct ctlr_info *h)
 
 static void set_lockup_detected_for_all_cpus(struct ctlr_info *h, u32 value)
 {
-       int i, cpu;
+       int cpu;
 
-       cpu = cpumask_first(cpu_online_mask);
-       for (i = 0; i < num_online_cpus(); i++) {
+       for_each_online_cpu(cpu) {
                u32 *lockup_detected;
                lockup_detected = per_cpu_ptr(h->lockup_detected, cpu);
                *lockup_detected = value;
-               cpu = cpumask_next(cpu, cpu_online_mask);
        }
        wmb(); /* be sure the per-cpu variables are out to memory */
 }