diff options
author | KOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com> | 2011-05-24 20:12:58 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-05-25 11:39:39 -0400 |
commit | 8ea9716fd6aa761482caa5d4d64b256ed07ac09f (patch) | |
tree | 1dbe6d8bbb9557b27e0a6b0a7d0f3d6934926368 /arch/mn10300/kernel/smp.c | |
parent | 81ee42baa433881bcb471aa6366e2f885a33f2fb (diff) |
mn10300: convert old cpumask API into new one
Adapt to the new API.
We plan to remove old cpumask APIs later. Thus this patch converts them
into the new one.
Signed-off-by: KOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com>
Cc: David Howells <dhowells@redhat.com>
Cc: Koichi Yasutake <yasutake.koichi@jp.panasonic.com>
Cc: Hugh Dickins <hughd@google.com>
Cc: Chris Metcalf <cmetcalf@tilera.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'arch/mn10300/kernel/smp.c')
-rw-r--r-- | arch/mn10300/kernel/smp.c | 75 |
1 files changed, 39 insertions, 36 deletions
diff --git a/arch/mn10300/kernel/smp.c b/arch/mn10300/kernel/smp.c index 83fb27912231..9242e9fcc564 100644 --- a/arch/mn10300/kernel/smp.c +++ b/arch/mn10300/kernel/smp.c | |||
@@ -309,7 +309,7 @@ static void send_IPI_mask(const cpumask_t *cpumask, int irq) | |||
309 | u16 tmp; | 309 | u16 tmp; |
310 | 310 | ||
311 | for (i = 0; i < NR_CPUS; i++) { | 311 | for (i = 0; i < NR_CPUS; i++) { |
312 | if (cpu_isset(i, *cpumask)) { | 312 | if (cpumask_test_cpu(i, cpumask)) { |
313 | /* send IPI */ | 313 | /* send IPI */ |
314 | tmp = CROSS_GxICR(irq, i); | 314 | tmp = CROSS_GxICR(irq, i); |
315 | CROSS_GxICR(irq, i) = | 315 | CROSS_GxICR(irq, i) = |
@@ -342,8 +342,8 @@ void send_IPI_allbutself(int irq) | |||
342 | { | 342 | { |
343 | cpumask_t cpumask; | 343 | cpumask_t cpumask; |
344 | 344 | ||
345 | cpumask = cpu_online_map; | 345 | cpumask_copy(&cpumask, cpu_online_mask); |
346 | cpu_clear(smp_processor_id(), cpumask); | 346 | cpumask_clear_cpu(smp_processor_id(), &cpumask); |
347 | send_IPI_mask(&cpumask, irq); | 347 | send_IPI_mask(&cpumask, irq); |
348 | } | 348 | } |
349 | 349 | ||
@@ -393,8 +393,8 @@ int smp_nmi_call_function(smp_call_func_t func, void *info, int wait) | |||
393 | 393 | ||
394 | data.func = func; | 394 | data.func = func; |
395 | data.info = info; | 395 | data.info = info; |
396 | data.started = cpu_online_map; | 396 | cpumask_copy(&data.started, cpu_online_mask); |
397 | cpu_clear(smp_processor_id(), data.started); | 397 | cpumask_clear_cpu(smp_processor_id(), &data.started); |
398 | data.wait = wait; | 398 | data.wait = wait; |
399 | if (wait) | 399 | if (wait) |
400 | data.finished = data.started; | 400 | data.finished = data.started; |
@@ -410,14 +410,14 @@ int smp_nmi_call_function(smp_call_func_t func, void *info, int wait) | |||
410 | if (CALL_FUNCTION_NMI_IPI_TIMEOUT > 0) { | 410 | if (CALL_FUNCTION_NMI_IPI_TIMEOUT > 0) { |
411 | for (cnt = 0; | 411 | for (cnt = 0; |
412 | cnt < CALL_FUNCTION_NMI_IPI_TIMEOUT && | 412 | cnt < CALL_FUNCTION_NMI_IPI_TIMEOUT && |
413 | !cpus_empty(data.started); | 413 | !cpumask_empty(&data.started); |
414 | cnt++) | 414 | cnt++) |
415 | mdelay(1); | 415 | mdelay(1); |
416 | 416 | ||
417 | if (wait && cnt < CALL_FUNCTION_NMI_IPI_TIMEOUT) { | 417 | if (wait && cnt < CALL_FUNCTION_NMI_IPI_TIMEOUT) { |
418 | for (cnt = 0; | 418 | for (cnt = 0; |
419 | cnt < CALL_FUNCTION_NMI_IPI_TIMEOUT && | 419 | cnt < CALL_FUNCTION_NMI_IPI_TIMEOUT && |
420 | !cpus_empty(data.finished); | 420 | !cpumask_empty(&data.finished); |
421 | cnt++) | 421 | cnt++) |
422 | mdelay(1); | 422 | mdelay(1); |
423 | } | 423 | } |
@@ -428,10 +428,10 @@ int smp_nmi_call_function(smp_call_func_t func, void *info, int wait) | |||
428 | } else { | 428 | } else { |
429 | /* If timeout value is zero, wait until cpumask has been | 429 | /* If timeout value is zero, wait until cpumask has been |
430 | * cleared */ | 430 | * cleared */ |
431 | while (!cpus_empty(data.started)) | 431 | while (!cpumask_empty(&data.started)) |
432 | barrier(); | 432 | barrier(); |
433 | if (wait) | 433 | if (wait) |
434 | while (!cpus_empty(data.finished)) | 434 | while (!cpumask_empty(&data.finished)) |
435 | barrier(); | 435 | barrier(); |
436 | } | 436 | } |
437 | 437 | ||
@@ -472,12 +472,12 @@ void stop_this_cpu(void *unused) | |||
472 | #endif /* CONFIG_GDBSTUB */ | 472 | #endif /* CONFIG_GDBSTUB */ |
473 | 473 | ||
474 | flags = arch_local_cli_save(); | 474 | flags = arch_local_cli_save(); |
475 | cpu_clear(smp_processor_id(), cpu_online_map); | 475 | set_cpu_online(smp_processor_id(), false); |
476 | 476 | ||
477 | while (!stopflag) | 477 | while (!stopflag) |
478 | cpu_relax(); | 478 | cpu_relax(); |
479 | 479 | ||
480 | cpu_set(smp_processor_id(), cpu_online_map); | 480 | set_cpu_online(smp_processor_id(), true); |
481 | arch_local_irq_restore(flags); | 481 | arch_local_irq_restore(flags); |
482 | } | 482 | } |
483 | 483 | ||
@@ -529,12 +529,13 @@ void smp_nmi_call_function_interrupt(void) | |||
529 | * execute the function | 529 | * execute the function |
530 | */ | 530 | */ |
531 | smp_mb(); | 531 | smp_mb(); |
532 | cpu_clear(smp_processor_id(), nmi_call_data->started); | 532 | cpumask_clear_cpu(smp_processor_id(), &nmi_call_data->started); |
533 | (*func)(info); | 533 | (*func)(info); |
534 | 534 | ||
535 | if (wait) { | 535 | if (wait) { |
536 | smp_mb(); | 536 | smp_mb(); |
537 | cpu_clear(smp_processor_id(), nmi_call_data->finished); | 537 | cpumask_clear_cpu(smp_processor_id(), |
538 | &nmi_call_data->finished); | ||
538 | } | 539 | } |
539 | } | 540 | } |
540 | 541 | ||
@@ -657,7 +658,7 @@ int __init start_secondary(void *unused) | |||
657 | { | 658 | { |
658 | smp_cpu_init(); | 659 | smp_cpu_init(); |
659 | smp_callin(); | 660 | smp_callin(); |
660 | while (!cpu_isset(smp_processor_id(), smp_commenced_mask)) | 661 | while (!cpumask_test_cpu(smp_processor_id(), &smp_commenced_mask)) |
661 | cpu_relax(); | 662 | cpu_relax(); |
662 | 663 | ||
663 | local_flush_tlb(); | 664 | local_flush_tlb(); |
@@ -780,13 +781,14 @@ static int __init do_boot_cpu(int phy_id) | |||
780 | 781 | ||
781 | if (send_status == 0) { | 782 | if (send_status == 0) { |
782 | /* Allow AP to start initializing */ | 783 | /* Allow AP to start initializing */ |
783 | cpu_set(cpu_id, cpu_callout_map); | 784 | cpumask_set_cpu(cpu_id, &cpu_callout_map); |
784 | 785 | ||
785 | /* Wait for setting cpu_callin_map */ | 786 | /* Wait for setting cpu_callin_map */ |
786 | timeout = 0; | 787 | timeout = 0; |
787 | do { | 788 | do { |
788 | udelay(1000); | 789 | udelay(1000); |
789 | callin_status = cpu_isset(cpu_id, cpu_callin_map); | 790 | callin_status = cpumask_test_cpu(cpu_id, |
791 | &cpu_callin_map); | ||
790 | } while (callin_status == 0 && timeout++ < 5000); | 792 | } while (callin_status == 0 && timeout++ < 5000); |
791 | 793 | ||
792 | if (callin_status == 0) | 794 | if (callin_status == 0) |
@@ -796,9 +798,9 @@ static int __init do_boot_cpu(int phy_id) | |||
796 | } | 798 | } |
797 | 799 | ||
798 | if (send_status == GxICR_REQUEST || callin_status == 0) { | 800 | if (send_status == GxICR_REQUEST || callin_status == 0) { |
799 | cpu_clear(cpu_id, cpu_callout_map); | 801 | cpumask_clear_cpu(cpu_id, &cpu_callout_map); |
800 | cpu_clear(cpu_id, cpu_callin_map); | 802 | cpumask_clear_cpu(cpu_id, &cpu_callin_map); |
801 | cpu_clear(cpu_id, cpu_initialized); | 803 | cpumask_clear_cpu(cpu_id, &cpu_initialized); |
802 | cpucount--; | 804 | cpucount--; |
803 | return 1; | 805 | return 1; |
804 | } | 806 | } |
@@ -833,7 +835,7 @@ static void __init smp_callin(void) | |||
833 | cpu = smp_processor_id(); | 835 | cpu = smp_processor_id(); |
834 | timeout = jiffies + (2 * HZ); | 836 | timeout = jiffies + (2 * HZ); |
835 | 837 | ||
836 | if (cpu_isset(cpu, cpu_callin_map)) { | 838 | if (cpumask_test_cpu(cpu, &cpu_callin_map)) { |
837 | printk(KERN_ERR "CPU#%d already present.\n", cpu); | 839 | printk(KERN_ERR "CPU#%d already present.\n", cpu); |
838 | BUG(); | 840 | BUG(); |
839 | } | 841 | } |
@@ -841,7 +843,7 @@ static void __init smp_callin(void) | |||
841 | 843 | ||
842 | /* Wait for AP startup 2s total */ | 844 | /* Wait for AP startup 2s total */ |
843 | while (time_before(jiffies, timeout)) { | 845 | while (time_before(jiffies, timeout)) { |
844 | if (cpu_isset(cpu, cpu_callout_map)) | 846 | if (cpumask_test_cpu(cpu, &cpu_callout_map)) |
845 | break; | 847 | break; |
846 | cpu_relax(); | 848 | cpu_relax(); |
847 | } | 849 | } |
@@ -861,11 +863,11 @@ static void __init smp_callin(void) | |||
861 | smp_store_cpu_info(cpu); | 863 | smp_store_cpu_info(cpu); |
862 | 864 | ||
863 | /* Allow the boot processor to continue */ | 865 | /* Allow the boot processor to continue */ |
864 | cpu_set(cpu, cpu_callin_map); | 866 | cpumask_set_cpu(cpu, &cpu_callin_map); |
865 | } | 867 | } |
866 | 868 | ||
867 | /** | 869 | /** |
868 | * smp_online - Set cpu_online_map | 870 | * smp_online - Set cpu_online_mask |
869 | */ | 871 | */ |
870 | static void __init smp_online(void) | 872 | static void __init smp_online(void) |
871 | { | 873 | { |
@@ -875,7 +877,7 @@ static void __init smp_online(void) | |||
875 | 877 | ||
876 | local_irq_enable(); | 878 | local_irq_enable(); |
877 | 879 | ||
878 | cpu_set(cpu, cpu_online_map); | 880 | set_cpu_online(cpu, true); |
879 | smp_wmb(); | 881 | smp_wmb(); |
880 | } | 882 | } |
881 | 883 | ||
@@ -892,13 +894,13 @@ void __init smp_cpus_done(unsigned int max_cpus) | |||
892 | /* | 894 | /* |
893 | * smp_prepare_boot_cpu - Set up stuff for the boot processor. | 895 | * smp_prepare_boot_cpu - Set up stuff for the boot processor. |
894 | * | 896 | * |
895 | * Set up the cpu_online_map, cpu_callout_map and cpu_callin_map of the boot | 897 | * Set up the cpu_online_mask, cpu_callout_map and cpu_callin_map of the boot |
896 | * processor (CPU 0). | 898 | * processor (CPU 0). |
897 | */ | 899 | */ |
898 | void __devinit smp_prepare_boot_cpu(void) | 900 | void __devinit smp_prepare_boot_cpu(void) |
899 | { | 901 | { |
900 | cpu_set(0, cpu_callout_map); | 902 | cpumask_set_cpu(0, &cpu_callout_map); |
901 | cpu_set(0, cpu_callin_map); | 903 | cpumask_set_cpu(0, &cpu_callin_map); |
902 | current_thread_info()->cpu = 0; | 904 | current_thread_info()->cpu = 0; |
903 | } | 905 | } |
904 | 906 | ||
@@ -931,16 +933,16 @@ int __devinit __cpu_up(unsigned int cpu) | |||
931 | run_wakeup_cpu(cpu); | 933 | run_wakeup_cpu(cpu); |
932 | #endif /* CONFIG_HOTPLUG_CPU */ | 934 | #endif /* CONFIG_HOTPLUG_CPU */ |
933 | 935 | ||
934 | cpu_set(cpu, smp_commenced_mask); | 936 | cpumask_set_cpu(cpu, &smp_commenced_mask); |
935 | 937 | ||
936 | /* Wait 5s total for a response */ | 938 | /* Wait 5s total for a response */ |
937 | for (timeout = 0 ; timeout < 5000 ; timeout++) { | 939 | for (timeout = 0 ; timeout < 5000 ; timeout++) { |
938 | if (cpu_isset(cpu, cpu_online_map)) | 940 | if (cpu_online(cpu)) |
939 | break; | 941 | break; |
940 | udelay(1000); | 942 | udelay(1000); |
941 | } | 943 | } |
942 | 944 | ||
943 | BUG_ON(!cpu_isset(cpu, cpu_online_map)); | 945 | BUG_ON(!cpu_online(cpu)); |
944 | return 0; | 946 | return 0; |
945 | } | 947 | } |
946 | 948 | ||
@@ -986,7 +988,7 @@ int __cpu_disable(void) | |||
986 | return -EBUSY; | 988 | return -EBUSY; |
987 | 989 | ||
988 | migrate_irqs(); | 990 | migrate_irqs(); |
989 | cpu_clear(cpu, current->active_mm->cpu_vm_mask); | 991 | cpumask_clear_cpu(cpu, &mm_cpumask(current->active_mm)); |
990 | return 0; | 992 | return 0; |
991 | } | 993 | } |
992 | 994 | ||
@@ -1091,13 +1093,13 @@ static int hotplug_cpu_nmi_call_function(cpumask_t cpumask, | |||
1091 | do { | 1093 | do { |
1092 | mn10300_local_dcache_inv_range(start, end); | 1094 | mn10300_local_dcache_inv_range(start, end); |
1093 | barrier(); | 1095 | barrier(); |
1094 | } while (!cpus_empty(nmi_call_func_mask_data.started)); | 1096 | } while (!cpumask_empty(&nmi_call_func_mask_data.started)); |
1095 | 1097 | ||
1096 | if (wait) { | 1098 | if (wait) { |
1097 | do { | 1099 | do { |
1098 | mn10300_local_dcache_inv_range(start, end); | 1100 | mn10300_local_dcache_inv_range(start, end); |
1099 | barrier(); | 1101 | barrier(); |
1100 | } while (!cpus_empty(nmi_call_func_mask_data.finished)); | 1102 | } while (!cpumask_empty(&nmi_call_func_mask_data.finished)); |
1101 | } | 1103 | } |
1102 | 1104 | ||
1103 | spin_unlock(&smp_nmi_call_lock); | 1105 | spin_unlock(&smp_nmi_call_lock); |
@@ -1108,9 +1110,9 @@ static void restart_wakeup_cpu(void) | |||
1108 | { | 1110 | { |
1109 | unsigned int cpu = smp_processor_id(); | 1111 | unsigned int cpu = smp_processor_id(); |
1110 | 1112 | ||
1111 | cpu_set(cpu, cpu_callin_map); | 1113 | cpumask_set_cpu(cpu, &cpu_callin_map); |
1112 | local_flush_tlb(); | 1114 | local_flush_tlb(); |
1113 | cpu_set(cpu, cpu_online_map); | 1115 | set_cpu_online(cpu, true); |
1114 | smp_wmb(); | 1116 | smp_wmb(); |
1115 | } | 1117 | } |
1116 | 1118 | ||
@@ -1141,8 +1143,9 @@ static void sleep_cpu(void *unused) | |||
1141 | static void run_sleep_cpu(unsigned int cpu) | 1143 | static void run_sleep_cpu(unsigned int cpu) |
1142 | { | 1144 | { |
1143 | unsigned long flags; | 1145 | unsigned long flags; |
1144 | cpumask_t cpumask = cpumask_of(cpu); | 1146 | cpumask_t cpumask; |
1145 | 1147 | ||
1148 | cpumask_copy(&cpumask, &cpumask_of(cpu)); | ||
1146 | flags = arch_local_cli_save(); | 1149 | flags = arch_local_cli_save(); |
1147 | hotplug_cpu_nmi_call_function(cpumask, prepare_sleep_cpu, NULL, 1); | 1150 | hotplug_cpu_nmi_call_function(cpumask, prepare_sleep_cpu, NULL, 1); |
1148 | hotplug_cpu_nmi_call_function(cpumask, sleep_cpu, NULL, 0); | 1151 | hotplug_cpu_nmi_call_function(cpumask, sleep_cpu, NULL, 0); |