提交 fb1fece5 编写于 作者: K KOSAKI Motohiro 提交者: David S. Miller

sparc: convert old cpumask API into new one

Adapt new API. Almost change is trivial, most important change are to
remove following like =operator.

 cpumask_t cpu_mask = *mm_cpumask(mm);
 cpus_allowed = current->cpus_allowed;

Because cpumask_var_t is =operator unsafe. These usage might prevent
kernel core improvement.

No functional change.
Signed-off-by: NKOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 55dd23ec
...@@ -68,17 +68,17 @@ BTFIXUPDEF_BLACKBOX(load_current) ...@@ -68,17 +68,17 @@ BTFIXUPDEF_BLACKBOX(load_current)
#define smp_cross_call(func,mask,arg1,arg2,arg3,arg4) BTFIXUP_CALL(smp_cross_call)(func,mask,arg1,arg2,arg3,arg4) #define smp_cross_call(func,mask,arg1,arg2,arg3,arg4) BTFIXUP_CALL(smp_cross_call)(func,mask,arg1,arg2,arg3,arg4)
static inline void xc0(smpfunc_t func) { smp_cross_call(func, cpu_online_map, 0, 0, 0, 0); } static inline void xc0(smpfunc_t func) { smp_cross_call(func, *cpu_online_mask, 0, 0, 0, 0); }
static inline void xc1(smpfunc_t func, unsigned long arg1) static inline void xc1(smpfunc_t func, unsigned long arg1)
{ smp_cross_call(func, cpu_online_map, arg1, 0, 0, 0); } { smp_cross_call(func, *cpu_online_mask, arg1, 0, 0, 0); }
static inline void xc2(smpfunc_t func, unsigned long arg1, unsigned long arg2) static inline void xc2(smpfunc_t func, unsigned long arg1, unsigned long arg2)
{ smp_cross_call(func, cpu_online_map, arg1, arg2, 0, 0); } { smp_cross_call(func, *cpu_online_mask, arg1, arg2, 0, 0); }
static inline void xc3(smpfunc_t func, unsigned long arg1, unsigned long arg2, static inline void xc3(smpfunc_t func, unsigned long arg1, unsigned long arg2,
unsigned long arg3) unsigned long arg3)
{ smp_cross_call(func, cpu_online_map, arg1, arg2, arg3, 0); } { smp_cross_call(func, *cpu_online_mask, arg1, arg2, arg3, 0); }
static inline void xc4(smpfunc_t func, unsigned long arg1, unsigned long arg2, static inline void xc4(smpfunc_t func, unsigned long arg1, unsigned long arg2,
unsigned long arg3, unsigned long arg4) unsigned long arg3, unsigned long arg4)
{ smp_cross_call(func, cpu_online_map, arg1, arg2, arg3, arg4); } { smp_cross_call(func, *cpu_online_mask, arg1, arg2, arg3, arg4); }
extern void arch_send_call_function_single_ipi(int cpu); extern void arch_send_call_function_single_ipi(int cpu);
extern void arch_send_call_function_ipi_mask(const struct cpumask *mask); extern void arch_send_call_function_ipi_mask(const struct cpumask *mask);
......
...@@ -202,7 +202,7 @@ static struct cpuinfo_tree *build_cpuinfo_tree(void) ...@@ -202,7 +202,7 @@ static struct cpuinfo_tree *build_cpuinfo_tree(void)
new_tree->total_nodes = n; new_tree->total_nodes = n;
memcpy(&new_tree->level, tmp_level, sizeof(tmp_level)); memcpy(&new_tree->level, tmp_level, sizeof(tmp_level));
prev_cpu = cpu = first_cpu(cpu_online_map); prev_cpu = cpu = cpumask_first(cpu_online_mask);
/* Initialize all levels in the tree with the first CPU */ /* Initialize all levels in the tree with the first CPU */
for (level = CPUINFO_LVL_PROC; level >= CPUINFO_LVL_ROOT; level--) { for (level = CPUINFO_LVL_PROC; level >= CPUINFO_LVL_ROOT; level--) {
...@@ -381,7 +381,7 @@ static int simple_map_to_cpu(unsigned int index) ...@@ -381,7 +381,7 @@ static int simple_map_to_cpu(unsigned int index)
} }
/* Impossible, since num_online_cpus() <= num_possible_cpus() */ /* Impossible, since num_online_cpus() <= num_possible_cpus() */
return first_cpu(cpu_online_map); return cpumask_first(cpu_online_mask);
} }
static int _map_to_cpu(unsigned int index) static int _map_to_cpu(unsigned int index)
......
...@@ -497,7 +497,7 @@ static void dr_cpu_init_response(struct ds_data *resp, u64 req_num, ...@@ -497,7 +497,7 @@ static void dr_cpu_init_response(struct ds_data *resp, u64 req_num,
tag->num_records = ncpus; tag->num_records = ncpus;
i = 0; i = 0;
for_each_cpu_mask(cpu, *mask) { for_each_cpu(cpu, mask) {
ent[i].cpu = cpu; ent[i].cpu = cpu;
ent[i].result = DR_CPU_RES_OK; ent[i].result = DR_CPU_RES_OK;
ent[i].stat = default_stat; ent[i].stat = default_stat;
...@@ -534,7 +534,7 @@ static int __cpuinit dr_cpu_configure(struct ds_info *dp, ...@@ -534,7 +534,7 @@ static int __cpuinit dr_cpu_configure(struct ds_info *dp,
int resp_len, ncpus, cpu; int resp_len, ncpus, cpu;
unsigned long flags; unsigned long flags;
ncpus = cpus_weight(*mask); ncpus = cpumask_weight(mask);
resp_len = dr_cpu_size_response(ncpus); resp_len = dr_cpu_size_response(ncpus);
resp = kzalloc(resp_len, GFP_KERNEL); resp = kzalloc(resp_len, GFP_KERNEL);
if (!resp) if (!resp)
...@@ -547,7 +547,7 @@ static int __cpuinit dr_cpu_configure(struct ds_info *dp, ...@@ -547,7 +547,7 @@ static int __cpuinit dr_cpu_configure(struct ds_info *dp,
mdesc_populate_present_mask(mask); mdesc_populate_present_mask(mask);
mdesc_fill_in_cpu_data(mask); mdesc_fill_in_cpu_data(mask);
for_each_cpu_mask(cpu, *mask) { for_each_cpu(cpu, mask) {
int err; int err;
printk(KERN_INFO "ds-%llu: Starting cpu %d...\n", printk(KERN_INFO "ds-%llu: Starting cpu %d...\n",
...@@ -593,7 +593,7 @@ static int dr_cpu_unconfigure(struct ds_info *dp, ...@@ -593,7 +593,7 @@ static int dr_cpu_unconfigure(struct ds_info *dp,
int resp_len, ncpus, cpu; int resp_len, ncpus, cpu;
unsigned long flags; unsigned long flags;
ncpus = cpus_weight(*mask); ncpus = cpumask_weight(mask);
resp_len = dr_cpu_size_response(ncpus); resp_len = dr_cpu_size_response(ncpus);
resp = kzalloc(resp_len, GFP_KERNEL); resp = kzalloc(resp_len, GFP_KERNEL);
if (!resp) if (!resp)
...@@ -603,7 +603,7 @@ static int dr_cpu_unconfigure(struct ds_info *dp, ...@@ -603,7 +603,7 @@ static int dr_cpu_unconfigure(struct ds_info *dp,
resp_len, ncpus, mask, resp_len, ncpus, mask,
DR_CPU_STAT_UNCONFIGURED); DR_CPU_STAT_UNCONFIGURED);
for_each_cpu_mask(cpu, *mask) { for_each_cpu(cpu, mask) {
int err; int err;
printk(KERN_INFO "ds-%llu: Shutting down cpu %d...\n", printk(KERN_INFO "ds-%llu: Shutting down cpu %d...\n",
...@@ -649,13 +649,13 @@ static void __cpuinit dr_cpu_data(struct ds_info *dp, ...@@ -649,13 +649,13 @@ static void __cpuinit dr_cpu_data(struct ds_info *dp,
purge_dups(cpu_list, tag->num_records); purge_dups(cpu_list, tag->num_records);
cpus_clear(mask); cpumask_clear(&mask);
for (i = 0; i < tag->num_records; i++) { for (i = 0; i < tag->num_records; i++) {
if (cpu_list[i] == CPU_SENTINEL) if (cpu_list[i] == CPU_SENTINEL)
continue; continue;
if (cpu_list[i] < nr_cpu_ids) if (cpu_list[i] < nr_cpu_ids)
cpu_set(cpu_list[i], mask); cpumask_set_cpu(cpu_list[i], &mask);
} }
if (tag->type == DR_CPU_CONFIGURE) if (tag->type == DR_CPU_CONFIGURE)
......
...@@ -224,13 +224,13 @@ static int irq_choose_cpu(unsigned int irq, const struct cpumask *affinity) ...@@ -224,13 +224,13 @@ static int irq_choose_cpu(unsigned int irq, const struct cpumask *affinity)
int cpuid; int cpuid;
cpumask_copy(&mask, affinity); cpumask_copy(&mask, affinity);
if (cpus_equal(mask, cpu_online_map)) { if (cpumask_equal(&mask, cpu_online_mask)) {
cpuid = map_to_cpu(irq); cpuid = map_to_cpu(irq);
} else { } else {
cpumask_t tmp; cpumask_t tmp;
cpus_and(tmp, cpu_online_map, mask); cpumask_and(&tmp, cpu_online_mask, &mask);
cpuid = cpus_empty(tmp) ? map_to_cpu(irq) : first_cpu(tmp); cpuid = cpumask_empty(&tmp) ? map_to_cpu(irq) : cpumask_first(&tmp);
} }
return cpuid; return cpuid;
......
...@@ -107,11 +107,11 @@ void __cpuinit leon_callin(void) ...@@ -107,11 +107,11 @@ void __cpuinit leon_callin(void)
atomic_inc(&init_mm.mm_count); atomic_inc(&init_mm.mm_count);
current->active_mm = &init_mm; current->active_mm = &init_mm;
while (!cpu_isset(cpuid, smp_commenced_mask)) while (!cpumask_test_cpu(cpuid, &smp_commenced_mask))
mb(); mb();
local_irq_enable(); local_irq_enable();
cpu_set(cpuid, cpu_online_map); set_cpu_online(cpuid, true);
} }
/* /*
...@@ -272,21 +272,21 @@ void __init leon_smp_done(void) ...@@ -272,21 +272,21 @@ void __init leon_smp_done(void)
local_flush_cache_all(); local_flush_cache_all();
/* Free unneeded trap tables */ /* Free unneeded trap tables */
if (!cpu_isset(1, cpu_present_map)) { if (!cpu_present(1)) {
ClearPageReserved(virt_to_page(&trapbase_cpu1)); ClearPageReserved(virt_to_page(&trapbase_cpu1));
init_page_count(virt_to_page(&trapbase_cpu1)); init_page_count(virt_to_page(&trapbase_cpu1));
free_page((unsigned long)&trapbase_cpu1); free_page((unsigned long)&trapbase_cpu1);
totalram_pages++; totalram_pages++;
num_physpages++; num_physpages++;
} }
if (!cpu_isset(2, cpu_present_map)) { if (!cpu_present(2)) {
ClearPageReserved(virt_to_page(&trapbase_cpu2)); ClearPageReserved(virt_to_page(&trapbase_cpu2));
init_page_count(virt_to_page(&trapbase_cpu2)); init_page_count(virt_to_page(&trapbase_cpu2));
free_page((unsigned long)&trapbase_cpu2); free_page((unsigned long)&trapbase_cpu2);
totalram_pages++; totalram_pages++;
num_physpages++; num_physpages++;
} }
if (!cpu_isset(3, cpu_present_map)) { if (!cpu_present(3)) {
ClearPageReserved(virt_to_page(&trapbase_cpu3)); ClearPageReserved(virt_to_page(&trapbase_cpu3));
init_page_count(virt_to_page(&trapbase_cpu3)); init_page_count(virt_to_page(&trapbase_cpu3));
free_page((unsigned long)&trapbase_cpu3); free_page((unsigned long)&trapbase_cpu3);
...@@ -440,10 +440,10 @@ static void leon_cross_call(smpfunc_t func, cpumask_t mask, unsigned long arg1, ...@@ -440,10 +440,10 @@ static void leon_cross_call(smpfunc_t func, cpumask_t mask, unsigned long arg1,
{ {
register int i; register int i;
cpu_clear(smp_processor_id(), mask); cpumask_clear_cpu(smp_processor_id(), &mask);
cpus_and(mask, cpu_online_map, mask); cpumask_and(&mask, cpu_online_mask, &mask);
for (i = 0; i <= high; i++) { for (i = 0; i <= high; i++) {
if (cpu_isset(i, mask)) { if (cpumask_test_cpu(i, &mask)) {
ccall_info.processors_in[i] = 0; ccall_info.processors_in[i] = 0;
ccall_info.processors_out[i] = 0; ccall_info.processors_out[i] = 0;
set_cpu_int(i, LEON3_IRQ_CROSS_CALL); set_cpu_int(i, LEON3_IRQ_CROSS_CALL);
...@@ -457,7 +457,7 @@ static void leon_cross_call(smpfunc_t func, cpumask_t mask, unsigned long arg1, ...@@ -457,7 +457,7 @@ static void leon_cross_call(smpfunc_t func, cpumask_t mask, unsigned long arg1,
i = 0; i = 0;
do { do {
if (!cpu_isset(i, mask)) if (!cpumask_test_cpu(i, &mask))
continue; continue;
while (!ccall_info.processors_in[i]) while (!ccall_info.processors_in[i])
...@@ -466,7 +466,7 @@ static void leon_cross_call(smpfunc_t func, cpumask_t mask, unsigned long arg1, ...@@ -466,7 +466,7 @@ static void leon_cross_call(smpfunc_t func, cpumask_t mask, unsigned long arg1,
i = 0; i = 0;
do { do {
if (!cpu_isset(i, mask)) if (!cpumask_test_cpu(i, &mask))
continue; continue;
while (!ccall_info.processors_out[i]) while (!ccall_info.processors_out[i])
......
...@@ -768,7 +768,7 @@ static void * __cpuinit mdesc_iterate_over_cpus(void *(*func)(struct mdesc_handl ...@@ -768,7 +768,7 @@ static void * __cpuinit mdesc_iterate_over_cpus(void *(*func)(struct mdesc_handl
cpuid, NR_CPUS); cpuid, NR_CPUS);
continue; continue;
} }
if (!cpu_isset(cpuid, *mask)) if (!cpumask_test_cpu(cpuid, mask))
continue; continue;
#endif #endif
......
...@@ -622,8 +622,9 @@ static unsigned int __init build_one_device_irq(struct platform_device *op, ...@@ -622,8 +622,9 @@ static unsigned int __init build_one_device_irq(struct platform_device *op,
out: out:
nid = of_node_to_nid(dp); nid = of_node_to_nid(dp);
if (nid != -1) { if (nid != -1) {
cpumask_t numa_mask = *cpumask_of_node(nid); cpumask_t numa_mask;
cpumask_copy(&numa_mask, cpumask_of_node(nid));
irq_set_affinity(irq, &numa_mask); irq_set_affinity(irq, &numa_mask);
} }
......
...@@ -284,8 +284,9 @@ static int bringup_one_msi_queue(struct pci_pbm_info *pbm, ...@@ -284,8 +284,9 @@ static int bringup_one_msi_queue(struct pci_pbm_info *pbm,
nid = pbm->numa_node; nid = pbm->numa_node;
if (nid != -1) { if (nid != -1) {
cpumask_t numa_mask = *cpumask_of_node(nid); cpumask_t numa_mask;
cpumask_copy(&numa_mask, cpumask_of_node(nid));
irq_set_affinity(irq, &numa_mask); irq_set_affinity(irq, &numa_mask);
} }
err = request_irq(irq, sparc64_msiq_interrupt, 0, err = request_irq(irq, sparc64_msiq_interrupt, 0,
......
...@@ -190,9 +190,10 @@ void smp_flush_tlb_all(void) ...@@ -190,9 +190,10 @@ void smp_flush_tlb_all(void)
void smp_flush_cache_mm(struct mm_struct *mm) void smp_flush_cache_mm(struct mm_struct *mm)
{ {
if(mm->context != NO_CONTEXT) { if(mm->context != NO_CONTEXT) {
cpumask_t cpu_mask = *mm_cpumask(mm); cpumask_t cpu_mask;
cpu_clear(smp_processor_id(), cpu_mask); cpumask_copy(&cpu_mask, mm_cpumask(mm));
if (!cpus_empty(cpu_mask)) cpumask_clear_cpu(smp_processor_id(), &cpu_mask);
if (!cpumask_empty(&cpu_mask))
xc1((smpfunc_t) BTFIXUP_CALL(local_flush_cache_mm), (unsigned long) mm); xc1((smpfunc_t) BTFIXUP_CALL(local_flush_cache_mm), (unsigned long) mm);
local_flush_cache_mm(mm); local_flush_cache_mm(mm);
} }
...@@ -201,9 +202,10 @@ void smp_flush_cache_mm(struct mm_struct *mm) ...@@ -201,9 +202,10 @@ void smp_flush_cache_mm(struct mm_struct *mm)
void smp_flush_tlb_mm(struct mm_struct *mm) void smp_flush_tlb_mm(struct mm_struct *mm)
{ {
if(mm->context != NO_CONTEXT) { if(mm->context != NO_CONTEXT) {
cpumask_t cpu_mask = *mm_cpumask(mm); cpumask_t cpu_mask;
cpu_clear(smp_processor_id(), cpu_mask); cpumask_copy(&cpu_mask, mm_cpumask(mm));
if (!cpus_empty(cpu_mask)) { cpumask_clear_cpu(smp_processor_id(), &cpu_mask);
if (!cpumask_empty(&cpu_mask)) {
xc1((smpfunc_t) BTFIXUP_CALL(local_flush_tlb_mm), (unsigned long) mm); xc1((smpfunc_t) BTFIXUP_CALL(local_flush_tlb_mm), (unsigned long) mm);
if(atomic_read(&mm->mm_users) == 1 && current->active_mm == mm) if(atomic_read(&mm->mm_users) == 1 && current->active_mm == mm)
cpumask_copy(mm_cpumask(mm), cpumask_copy(mm_cpumask(mm),
...@@ -219,9 +221,10 @@ void smp_flush_cache_range(struct vm_area_struct *vma, unsigned long start, ...@@ -219,9 +221,10 @@ void smp_flush_cache_range(struct vm_area_struct *vma, unsigned long start,
struct mm_struct *mm = vma->vm_mm; struct mm_struct *mm = vma->vm_mm;
if (mm->context != NO_CONTEXT) { if (mm->context != NO_CONTEXT) {
cpumask_t cpu_mask = *mm_cpumask(mm); cpumask_t cpu_mask;
cpu_clear(smp_processor_id(), cpu_mask); cpumask_copy(&cpu_mask, mm_cpumask(mm));
if (!cpus_empty(cpu_mask)) cpumask_clear_cpu(smp_processor_id(), &cpu_mask);
if (!cpumask_empty(&cpu_mask))
xc3((smpfunc_t) BTFIXUP_CALL(local_flush_cache_range), (unsigned long) vma, start, end); xc3((smpfunc_t) BTFIXUP_CALL(local_flush_cache_range), (unsigned long) vma, start, end);
local_flush_cache_range(vma, start, end); local_flush_cache_range(vma, start, end);
} }
...@@ -233,9 +236,10 @@ void smp_flush_tlb_range(struct vm_area_struct *vma, unsigned long start, ...@@ -233,9 +236,10 @@ void smp_flush_tlb_range(struct vm_area_struct *vma, unsigned long start,
struct mm_struct *mm = vma->vm_mm; struct mm_struct *mm = vma->vm_mm;
if (mm->context != NO_CONTEXT) { if (mm->context != NO_CONTEXT) {
cpumask_t cpu_mask = *mm_cpumask(mm); cpumask_t cpu_mask;
cpu_clear(smp_processor_id(), cpu_mask); cpumask_copy(&cpu_mask, mm_cpumask(mm));
if (!cpus_empty(cpu_mask)) cpumask_clear_cpu(smp_processor_id(), &cpu_mask);
if (!cpumask_empty(&cpu_mask))
xc3((smpfunc_t) BTFIXUP_CALL(local_flush_tlb_range), (unsigned long) vma, start, end); xc3((smpfunc_t) BTFIXUP_CALL(local_flush_tlb_range), (unsigned long) vma, start, end);
local_flush_tlb_range(vma, start, end); local_flush_tlb_range(vma, start, end);
} }
...@@ -246,9 +250,10 @@ void smp_flush_cache_page(struct vm_area_struct *vma, unsigned long page) ...@@ -246,9 +250,10 @@ void smp_flush_cache_page(struct vm_area_struct *vma, unsigned long page)
struct mm_struct *mm = vma->vm_mm; struct mm_struct *mm = vma->vm_mm;
if(mm->context != NO_CONTEXT) { if(mm->context != NO_CONTEXT) {
cpumask_t cpu_mask = *mm_cpumask(mm); cpumask_t cpu_mask;
cpu_clear(smp_processor_id(), cpu_mask); cpumask_copy(&cpu_mask, mm_cpumask(mm));
if (!cpus_empty(cpu_mask)) cpumask_clear_cpu(smp_processor_id(), &cpu_mask);
if (!cpumask_empty(&cpu_mask))
xc2((smpfunc_t) BTFIXUP_CALL(local_flush_cache_page), (unsigned long) vma, page); xc2((smpfunc_t) BTFIXUP_CALL(local_flush_cache_page), (unsigned long) vma, page);
local_flush_cache_page(vma, page); local_flush_cache_page(vma, page);
} }
...@@ -259,9 +264,10 @@ void smp_flush_tlb_page(struct vm_area_struct *vma, unsigned long page) ...@@ -259,9 +264,10 @@ void smp_flush_tlb_page(struct vm_area_struct *vma, unsigned long page)
struct mm_struct *mm = vma->vm_mm; struct mm_struct *mm = vma->vm_mm;
if(mm->context != NO_CONTEXT) { if(mm->context != NO_CONTEXT) {
cpumask_t cpu_mask = *mm_cpumask(mm); cpumask_t cpu_mask;
cpu_clear(smp_processor_id(), cpu_mask); cpumask_copy(&cpu_mask, mm_cpumask(mm));
if (!cpus_empty(cpu_mask)) cpumask_clear_cpu(smp_processor_id(), &cpu_mask);
if (!cpumask_empty(&cpu_mask))
xc2((smpfunc_t) BTFIXUP_CALL(local_flush_tlb_page), (unsigned long) vma, page); xc2((smpfunc_t) BTFIXUP_CALL(local_flush_tlb_page), (unsigned long) vma, page);
local_flush_tlb_page(vma, page); local_flush_tlb_page(vma, page);
} }
...@@ -283,9 +289,10 @@ void smp_flush_page_to_ram(unsigned long page) ...@@ -283,9 +289,10 @@ void smp_flush_page_to_ram(unsigned long page)
void smp_flush_sig_insns(struct mm_struct *mm, unsigned long insn_addr) void smp_flush_sig_insns(struct mm_struct *mm, unsigned long insn_addr)
{ {
cpumask_t cpu_mask = *mm_cpumask(mm); cpumask_t cpu_mask;
cpu_clear(smp_processor_id(), cpu_mask); cpumask_copy(&cpu_mask, mm_cpumask(mm));
if (!cpus_empty(cpu_mask)) cpumask_clear_cpu(smp_processor_id(), &cpu_mask);
if (!cpumask_empty(&cpu_mask))
xc2((smpfunc_t) BTFIXUP_CALL(local_flush_sig_insns), (unsigned long) mm, insn_addr); xc2((smpfunc_t) BTFIXUP_CALL(local_flush_sig_insns), (unsigned long) mm, insn_addr);
local_flush_sig_insns(mm, insn_addr); local_flush_sig_insns(mm, insn_addr);
} }
...@@ -439,7 +446,7 @@ int __cpuinit __cpu_up(unsigned int cpu) ...@@ -439,7 +446,7 @@ int __cpuinit __cpu_up(unsigned int cpu)
}; };
if (!ret) { if (!ret) {
cpu_set(cpu, smp_commenced_mask); cpumask_set_cpu(cpu, &smp_commenced_mask);
while (!cpu_online(cpu)) while (!cpu_online(cpu))
mb(); mb();
} }
......
...@@ -121,11 +121,11 @@ void __cpuinit smp_callin(void) ...@@ -121,11 +121,11 @@ void __cpuinit smp_callin(void)
/* inform the notifiers about the new cpu */ /* inform the notifiers about the new cpu */
notify_cpu_starting(cpuid); notify_cpu_starting(cpuid);
while (!cpu_isset(cpuid, smp_commenced_mask)) while (!cpumask_test_cpu(cpuid, &smp_commenced_mask))
rmb(); rmb();
ipi_call_lock_irq(); ipi_call_lock_irq();
cpu_set(cpuid, cpu_online_map); set_cpu_online(cpuid, true);
ipi_call_unlock_irq(); ipi_call_unlock_irq();
/* idle thread is expected to have preempt disabled */ /* idle thread is expected to have preempt disabled */
...@@ -785,7 +785,7 @@ static void xcall_deliver(u64 data0, u64 data1, u64 data2, const cpumask_t *mask ...@@ -785,7 +785,7 @@ static void xcall_deliver(u64 data0, u64 data1, u64 data2, const cpumask_t *mask
/* Send cross call to all processors mentioned in MASK_P /* Send cross call to all processors mentioned in MASK_P
* except self. Really, there are only two cases currently, * except self. Really, there are only two cases currently,
* "&cpu_online_map" and "&mm->cpu_vm_mask". * "cpu_online_mask" and "mm_cpumask(mm)".
*/ */
static void smp_cross_call_masked(unsigned long *func, u32 ctx, u64 data1, u64 data2, const cpumask_t *mask) static void smp_cross_call_masked(unsigned long *func, u32 ctx, u64 data1, u64 data2, const cpumask_t *mask)
{ {
...@@ -797,7 +797,7 @@ static void smp_cross_call_masked(unsigned long *func, u32 ctx, u64 data1, u64 d ...@@ -797,7 +797,7 @@ static void smp_cross_call_masked(unsigned long *func, u32 ctx, u64 data1, u64 d
/* Send cross call to all processors except self. */ /* Send cross call to all processors except self. */
static void smp_cross_call(unsigned long *func, u32 ctx, u64 data1, u64 data2) static void smp_cross_call(unsigned long *func, u32 ctx, u64 data1, u64 data2)
{ {
smp_cross_call_masked(func, ctx, data1, data2, &cpu_online_map); smp_cross_call_masked(func, ctx, data1, data2, cpu_online_mask);
} }
extern unsigned long xcall_sync_tick; extern unsigned long xcall_sync_tick;
...@@ -805,7 +805,7 @@ extern unsigned long xcall_sync_tick; ...@@ -805,7 +805,7 @@ extern unsigned long xcall_sync_tick;
static void smp_start_sync_tick_client(int cpu) static void smp_start_sync_tick_client(int cpu)
{ {
xcall_deliver((u64) &xcall_sync_tick, 0, 0, xcall_deliver((u64) &xcall_sync_tick, 0, 0,
&cpumask_of_cpu(cpu)); cpumask_of(cpu));
} }
extern unsigned long xcall_call_function; extern unsigned long xcall_call_function;
...@@ -820,7 +820,7 @@ extern unsigned long xcall_call_function_single; ...@@ -820,7 +820,7 @@ extern unsigned long xcall_call_function_single;
void arch_send_call_function_single_ipi(int cpu) void arch_send_call_function_single_ipi(int cpu)
{ {
xcall_deliver((u64) &xcall_call_function_single, 0, 0, xcall_deliver((u64) &xcall_call_function_single, 0, 0,
&cpumask_of_cpu(cpu)); cpumask_of(cpu));
} }
void __irq_entry smp_call_function_client(int irq, struct pt_regs *regs) void __irq_entry smp_call_function_client(int irq, struct pt_regs *regs)
...@@ -918,7 +918,7 @@ void smp_flush_dcache_page_impl(struct page *page, int cpu) ...@@ -918,7 +918,7 @@ void smp_flush_dcache_page_impl(struct page *page, int cpu)
} }
if (data0) { if (data0) {
xcall_deliver(data0, __pa(pg_addr), xcall_deliver(data0, __pa(pg_addr),
(u64) pg_addr, &cpumask_of_cpu(cpu)); (u64) pg_addr, cpumask_of(cpu));
#ifdef CONFIG_DEBUG_DCFLUSH #ifdef CONFIG_DEBUG_DCFLUSH
atomic_inc(&dcpage_flushes_xcall); atomic_inc(&dcpage_flushes_xcall);
#endif #endif
...@@ -954,7 +954,7 @@ void flush_dcache_page_all(struct mm_struct *mm, struct page *page) ...@@ -954,7 +954,7 @@ void flush_dcache_page_all(struct mm_struct *mm, struct page *page)
} }
if (data0) { if (data0) {
xcall_deliver(data0, __pa(pg_addr), xcall_deliver(data0, __pa(pg_addr),
(u64) pg_addr, &cpu_online_map); (u64) pg_addr, cpu_online_mask);
#ifdef CONFIG_DEBUG_DCFLUSH #ifdef CONFIG_DEBUG_DCFLUSH
atomic_inc(&dcpage_flushes_xcall); atomic_inc(&dcpage_flushes_xcall);
#endif #endif
...@@ -1197,32 +1197,32 @@ void __devinit smp_fill_in_sib_core_maps(void) ...@@ -1197,32 +1197,32 @@ void __devinit smp_fill_in_sib_core_maps(void)
for_each_present_cpu(i) { for_each_present_cpu(i) {
unsigned int j; unsigned int j;
cpus_clear(cpu_core_map[i]); cpumask_clear(&cpu_core_map[i]);
if (cpu_data(i).core_id == 0) { if (cpu_data(i).core_id == 0) {
cpu_set(i, cpu_core_map[i]); cpumask_set_cpu(i, &cpu_core_map[i]);
continue; continue;
} }
for_each_present_cpu(j) { for_each_present_cpu(j) {
if (cpu_data(i).core_id == if (cpu_data(i).core_id ==
cpu_data(j).core_id) cpu_data(j).core_id)
cpu_set(j, cpu_core_map[i]); cpumask_set_cpu(j, &cpu_core_map[i]);
} }
} }
for_each_present_cpu(i) { for_each_present_cpu(i) {
unsigned int j; unsigned int j;
cpus_clear(per_cpu(cpu_sibling_map, i)); cpumask_clear(&per_cpu(cpu_sibling_map, i));
if (cpu_data(i).proc_id == -1) { if (cpu_data(i).proc_id == -1) {
cpu_set(i, per_cpu(cpu_sibling_map, i)); cpumask_set_cpu(i, &per_cpu(cpu_sibling_map, i));
continue; continue;
} }
for_each_present_cpu(j) { for_each_present_cpu(j) {
if (cpu_data(i).proc_id == if (cpu_data(i).proc_id ==
cpu_data(j).proc_id) cpu_data(j).proc_id)
cpu_set(j, per_cpu(cpu_sibling_map, i)); cpumask_set_cpu(j, &per_cpu(cpu_sibling_map, i));
} }
} }
} }
...@@ -1232,10 +1232,10 @@ int __cpuinit __cpu_up(unsigned int cpu) ...@@ -1232,10 +1232,10 @@ int __cpuinit __cpu_up(unsigned int cpu)
int ret = smp_boot_one_cpu(cpu); int ret = smp_boot_one_cpu(cpu);
if (!ret) { if (!ret) {
cpu_set(cpu, smp_commenced_mask); cpumask_set_cpu(cpu, &smp_commenced_mask);
while (!cpu_isset(cpu, cpu_online_map)) while (!cpu_online(cpu))
mb(); mb();
if (!cpu_isset(cpu, cpu_online_map)) { if (!cpu_online(cpu)) {
ret = -ENODEV; ret = -ENODEV;
} else { } else {
/* On SUN4V, writes to %tick and %stick are /* On SUN4V, writes to %tick and %stick are
...@@ -1269,7 +1269,7 @@ void cpu_play_dead(void) ...@@ -1269,7 +1269,7 @@ void cpu_play_dead(void)
tb->nonresum_mondo_pa, 0); tb->nonresum_mondo_pa, 0);
} }
cpu_clear(cpu, smp_commenced_mask); cpumask_clear_cpu(cpu, &smp_commenced_mask);
membar_safe("#Sync"); membar_safe("#Sync");
local_irq_disable(); local_irq_disable();
...@@ -1290,13 +1290,13 @@ int __cpu_disable(void) ...@@ -1290,13 +1290,13 @@ int __cpu_disable(void)
cpuinfo_sparc *c; cpuinfo_sparc *c;
int i; int i;
for_each_cpu_mask(i, cpu_core_map[cpu]) for_each_cpu(i, &cpu_core_map[cpu])
cpu_clear(cpu, cpu_core_map[i]); cpumask_clear_cpu(cpu, &cpu_core_map[i]);
cpus_clear(cpu_core_map[cpu]); cpumask_clear(&cpu_core_map[cpu]);
for_each_cpu_mask(i, per_cpu(cpu_sibling_map, cpu)) for_each_cpu(i, &per_cpu(cpu_sibling_map, cpu))
cpu_clear(cpu, per_cpu(cpu_sibling_map, i)); cpumask_clear_cpu(cpu, &per_cpu(cpu_sibling_map, i));
cpus_clear(per_cpu(cpu_sibling_map, cpu)); cpumask_clear(&per_cpu(cpu_sibling_map, cpu));
c = &cpu_data(cpu); c = &cpu_data(cpu);
...@@ -1313,7 +1313,7 @@ int __cpu_disable(void) ...@@ -1313,7 +1313,7 @@ int __cpu_disable(void)
local_irq_disable(); local_irq_disable();
ipi_call_lock(); ipi_call_lock();
cpu_clear(cpu, cpu_online_map); set_cpu_online(cpu, false);
ipi_call_unlock(); ipi_call_unlock();
cpu_map_rebuild(); cpu_map_rebuild();
...@@ -1327,11 +1327,11 @@ void __cpu_die(unsigned int cpu) ...@@ -1327,11 +1327,11 @@ void __cpu_die(unsigned int cpu)
for (i = 0; i < 100; i++) { for (i = 0; i < 100; i++) {
smp_rmb(); smp_rmb();
if (!cpu_isset(cpu, smp_commenced_mask)) if (!cpumask_test_cpu(cpu, &smp_commenced_mask))
break; break;
msleep(100); msleep(100);
} }
if (cpu_isset(cpu, smp_commenced_mask)) { if (cpumask_test_cpu(cpu, &smp_commenced_mask)) {
printk(KERN_ERR "CPU %u didn't die...\n", cpu); printk(KERN_ERR "CPU %u didn't die...\n", cpu);
} else { } else {
#if defined(CONFIG_SUN_LDOMS) #if defined(CONFIG_SUN_LDOMS)
...@@ -1341,7 +1341,7 @@ void __cpu_die(unsigned int cpu) ...@@ -1341,7 +1341,7 @@ void __cpu_die(unsigned int cpu)
do { do {
hv_err = sun4v_cpu_stop(cpu); hv_err = sun4v_cpu_stop(cpu);
if (hv_err == HV_EOK) { if (hv_err == HV_EOK) {
cpu_clear(cpu, cpu_present_map); set_cpu_present(cpu, false);
break; break;
} }
} while (--limit > 0); } while (--limit > 0);
...@@ -1362,7 +1362,7 @@ void __init smp_cpus_done(unsigned int max_cpus) ...@@ -1362,7 +1362,7 @@ void __init smp_cpus_done(unsigned int max_cpus)
void smp_send_reschedule(int cpu) void smp_send_reschedule(int cpu)
{ {
xcall_deliver((u64) &xcall_receive_signal, 0, 0, xcall_deliver((u64) &xcall_receive_signal, 0, 0,
&cpumask_of_cpu(cpu)); cpumask_of(cpu));
} }
void __irq_entry smp_receive_signal_client(int irq, struct pt_regs *regs) void __irq_entry smp_receive_signal_client(int irq, struct pt_regs *regs)
......
...@@ -104,7 +104,7 @@ void __cpuinit smp4d_callin(void) ...@@ -104,7 +104,7 @@ void __cpuinit smp4d_callin(void)
local_irq_enable(); /* We don't allow PIL 14 yet */ local_irq_enable(); /* We don't allow PIL 14 yet */
while (!cpu_isset(cpuid, smp_commenced_mask)) while (!cpumask_test_cpu(cpuid, &smp_commenced_mask))
barrier(); barrier();
spin_lock_irqsave(&sun4d_imsk_lock, flags); spin_lock_irqsave(&sun4d_imsk_lock, flags);
...@@ -313,10 +313,10 @@ static void smp4d_cross_call(smpfunc_t func, cpumask_t mask, unsigned long arg1, ...@@ -313,10 +313,10 @@ static void smp4d_cross_call(smpfunc_t func, cpumask_t mask, unsigned long arg1,
{ {
register int i; register int i;
cpu_clear(smp_processor_id(), mask); cpumask_clear_cpu(smp_processor_id(), &mask);
cpus_and(mask, cpu_online_map, mask); cpumask_and(&mask, cpu_online_mask, &mask);
for (i = 0; i <= high; i++) { for (i = 0; i <= high; i++) {
if (cpu_isset(i, mask)) { if (cpumask_test_cpu(i, &mask)) {
ccall_info.processors_in[i] = 0; ccall_info.processors_in[i] = 0;
ccall_info.processors_out[i] = 0; ccall_info.processors_out[i] = 0;
sun4d_send_ipi(i, IRQ_CROSS_CALL); sun4d_send_ipi(i, IRQ_CROSS_CALL);
...@@ -329,7 +329,7 @@ static void smp4d_cross_call(smpfunc_t func, cpumask_t mask, unsigned long arg1, ...@@ -329,7 +329,7 @@ static void smp4d_cross_call(smpfunc_t func, cpumask_t mask, unsigned long arg1,
i = 0; i = 0;
do { do {
if (!cpu_isset(i, mask)) if (!cpumask_test_cpu(i, &mask))
continue; continue;
while (!ccall_info.processors_in[i]) while (!ccall_info.processors_in[i])
barrier(); barrier();
...@@ -337,7 +337,7 @@ static void smp4d_cross_call(smpfunc_t func, cpumask_t mask, unsigned long arg1, ...@@ -337,7 +337,7 @@ static void smp4d_cross_call(smpfunc_t func, cpumask_t mask, unsigned long arg1,
i = 0; i = 0;
do { do {
if (!cpu_isset(i, mask)) if (!cpumask_test_cpu(i, &mask))
continue; continue;
while (!ccall_info.processors_out[i]) while (!ccall_info.processors_out[i])
barrier(); barrier();
......
...@@ -72,7 +72,7 @@ void __cpuinit smp4m_callin(void) ...@@ -72,7 +72,7 @@ void __cpuinit smp4m_callin(void)
atomic_inc(&init_mm.mm_count); atomic_inc(&init_mm.mm_count);
current->active_mm = &init_mm; current->active_mm = &init_mm;
while (!cpu_isset(cpuid, smp_commenced_mask)) while (!cpumask_test_cpu(cpuid, &smp_commenced_mask))
mb(); mb();
local_irq_enable(); local_irq_enable();
...@@ -209,10 +209,10 @@ static void smp4m_cross_call(smpfunc_t func, cpumask_t mask, unsigned long arg1, ...@@ -209,10 +209,10 @@ static void smp4m_cross_call(smpfunc_t func, cpumask_t mask, unsigned long arg1,
{ {
register int i; register int i;
cpu_clear(smp_processor_id(), mask); cpumask_clear_cpu(smp_processor_id(), &mask);
cpus_and(mask, cpu_online_map, mask); cpumask_and(&mask, cpu_online_mask, &mask);
for (i = 0; i < ncpus; i++) { for (i = 0; i < ncpus; i++) {
if (cpu_isset(i, mask)) { if (cpumask_test_cpu(i, &mask)) {
ccall_info.processors_in[i] = 0; ccall_info.processors_in[i] = 0;
ccall_info.processors_out[i] = 0; ccall_info.processors_out[i] = 0;
set_cpu_int(i, IRQ_CROSS_CALL); set_cpu_int(i, IRQ_CROSS_CALL);
...@@ -228,7 +228,7 @@ static void smp4m_cross_call(smpfunc_t func, cpumask_t mask, unsigned long arg1, ...@@ -228,7 +228,7 @@ static void smp4m_cross_call(smpfunc_t func, cpumask_t mask, unsigned long arg1,
i = 0; i = 0;
do { do {
if (!cpu_isset(i, mask)) if (!cpumask_test_cpu(i, &mask))
continue; continue;
while (!ccall_info.processors_in[i]) while (!ccall_info.processors_in[i])
barrier(); barrier();
...@@ -236,7 +236,7 @@ static void smp4m_cross_call(smpfunc_t func, cpumask_t mask, unsigned long arg1, ...@@ -236,7 +236,7 @@ static void smp4m_cross_call(smpfunc_t func, cpumask_t mask, unsigned long arg1,
i = 0; i = 0;
do { do {
if (!cpu_isset(i, mask)) if (!cpumask_test_cpu(i, &mask))
continue; continue;
while (!ccall_info.processors_out[i]) while (!ccall_info.processors_out[i])
barrier(); barrier();
......
...@@ -103,9 +103,10 @@ static unsigned long run_on_cpu(unsigned long cpu, ...@@ -103,9 +103,10 @@ static unsigned long run_on_cpu(unsigned long cpu,
unsigned long (*func)(unsigned long), unsigned long (*func)(unsigned long),
unsigned long arg) unsigned long arg)
{ {
cpumask_t old_affinity = current->cpus_allowed; cpumask_t old_affinity;
unsigned long ret; unsigned long ret;
cpumask_copy(&old_affinity, tsk_cpus_allowed(current));
/* should return -EINVAL to userspace */ /* should return -EINVAL to userspace */
if (set_cpus_allowed_ptr(current, cpumask_of(cpu))) if (set_cpus_allowed_ptr(current, cpumask_of(cpu)))
return 0; return 0;
......
...@@ -237,7 +237,7 @@ static unsigned int us2e_freq_get(unsigned int cpu) ...@@ -237,7 +237,7 @@ static unsigned int us2e_freq_get(unsigned int cpu)
if (!cpu_online(cpu)) if (!cpu_online(cpu))
return 0; return 0;
cpus_allowed = current->cpus_allowed; cpumask_copy(&cpus_allowed, tsk_cpus_allowed(current));
set_cpus_allowed_ptr(current, cpumask_of(cpu)); set_cpus_allowed_ptr(current, cpumask_of(cpu));
clock_tick = sparc64_get_clock_tick(cpu) / 1000; clock_tick = sparc64_get_clock_tick(cpu) / 1000;
...@@ -258,7 +258,7 @@ static void us2e_set_cpu_divider_index(unsigned int cpu, unsigned int index) ...@@ -258,7 +258,7 @@ static void us2e_set_cpu_divider_index(unsigned int cpu, unsigned int index)
if (!cpu_online(cpu)) if (!cpu_online(cpu))
return; return;
cpus_allowed = current->cpus_allowed; cpumask_copy(&cpus_allowed, tsk_cpus_allowed(current));
set_cpus_allowed_ptr(current, cpumask_of(cpu)); set_cpus_allowed_ptr(current, cpumask_of(cpu));
new_freq = clock_tick = sparc64_get_clock_tick(cpu) / 1000; new_freq = clock_tick = sparc64_get_clock_tick(cpu) / 1000;
......
...@@ -85,7 +85,7 @@ static unsigned int us3_freq_get(unsigned int cpu) ...@@ -85,7 +85,7 @@ static unsigned int us3_freq_get(unsigned int cpu)
if (!cpu_online(cpu)) if (!cpu_online(cpu))
return 0; return 0;
cpus_allowed = current->cpus_allowed; cpumask_copy(&cpus_allowed, tsk_cpus_allowed(current));
set_cpus_allowed_ptr(current, cpumask_of(cpu)); set_cpus_allowed_ptr(current, cpumask_of(cpu));
reg = read_safari_cfg(); reg = read_safari_cfg();
...@@ -105,7 +105,7 @@ static void us3_set_cpu_divider_index(unsigned int cpu, unsigned int index) ...@@ -105,7 +105,7 @@ static void us3_set_cpu_divider_index(unsigned int cpu, unsigned int index)
if (!cpu_online(cpu)) if (!cpu_online(cpu))
return; return;
cpus_allowed = current->cpus_allowed; cpumask_copy(&cpus_allowed, tsk_cpus_allowed(current));
set_cpus_allowed_ptr(current, cpumask_of(cpu)); set_cpus_allowed_ptr(current, cpumask_of(cpu));
new_freq = sparc64_get_clock_tick(cpu) / 1000; new_freq = sparc64_get_clock_tick(cpu) / 1000;
......
...@@ -862,7 +862,7 @@ static void init_node_masks_nonnuma(void) ...@@ -862,7 +862,7 @@ static void init_node_masks_nonnuma(void)
for (i = 0; i < NR_CPUS; i++) for (i = 0; i < NR_CPUS; i++)
numa_cpu_lookup_table[i] = 0; numa_cpu_lookup_table[i] = 0;
numa_cpumask_lookup_table[0] = CPU_MASK_ALL; cpumask_setall(&numa_cpumask_lookup_table[0]);
} }
#ifdef CONFIG_NEED_MULTIPLE_NODES #ifdef CONFIG_NEED_MULTIPLE_NODES
...@@ -1080,7 +1080,7 @@ static void __init numa_parse_mdesc_group_cpus(struct mdesc_handle *md, ...@@ -1080,7 +1080,7 @@ static void __init numa_parse_mdesc_group_cpus(struct mdesc_handle *md,
{ {
u64 arc; u64 arc;
cpus_clear(*mask); cpumask_clear(mask);
mdesc_for_each_arc(arc, md, grp, MDESC_ARC_TYPE_BACK) { mdesc_for_each_arc(arc, md, grp, MDESC_ARC_TYPE_BACK) {
u64 target = mdesc_arc_target(md, arc); u64 target = mdesc_arc_target(md, arc);
...@@ -1091,7 +1091,7 @@ static void __init numa_parse_mdesc_group_cpus(struct mdesc_handle *md, ...@@ -1091,7 +1091,7 @@ static void __init numa_parse_mdesc_group_cpus(struct mdesc_handle *md,
continue; continue;
id = mdesc_get_property(md, target, "id", NULL); id = mdesc_get_property(md, target, "id", NULL);
if (*id < nr_cpu_ids) if (*id < nr_cpu_ids)
cpu_set(*id, *mask); cpumask_set_cpu(*id, mask);
} }
} }
...@@ -1153,13 +1153,13 @@ static int __init numa_parse_mdesc_group(struct mdesc_handle *md, u64 grp, ...@@ -1153,13 +1153,13 @@ static int __init numa_parse_mdesc_group(struct mdesc_handle *md, u64 grp,
numa_parse_mdesc_group_cpus(md, grp, &mask); numa_parse_mdesc_group_cpus(md, grp, &mask);
for_each_cpu_mask(cpu, mask) for_each_cpu(cpu, &mask)
numa_cpu_lookup_table[cpu] = index; numa_cpu_lookup_table[cpu] = index;
numa_cpumask_lookup_table[index] = mask; cpumask_copy(&numa_cpumask_lookup_table[index], &mask);
if (numa_debug) { if (numa_debug) {
printk(KERN_INFO "NUMA GROUP[%d]: cpus [ ", index); printk(KERN_INFO "NUMA GROUP[%d]: cpus [ ", index);
for_each_cpu_mask(cpu, mask) for_each_cpu(cpu, &mask)
printk("%d ", cpu); printk("%d ", cpu);
printk("]\n"); printk("]\n");
} }
...@@ -1218,7 +1218,7 @@ static int __init numa_parse_jbus(void) ...@@ -1218,7 +1218,7 @@ static int __init numa_parse_jbus(void)
index = 0; index = 0;
for_each_present_cpu(cpu) { for_each_present_cpu(cpu) {
numa_cpu_lookup_table[cpu] = index; numa_cpu_lookup_table[cpu] = index;
numa_cpumask_lookup_table[index] = cpumask_of_cpu(cpu); cpumask_copy(&numa_cpumask_lookup_table[index], cpumask_of(cpu));
node_masks[index].mask = ~((1UL << 36UL) - 1UL); node_masks[index].mask = ~((1UL << 36UL) - 1UL);
node_masks[index].val = cpu << 36UL; node_masks[index].val = cpu << 36UL;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册