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: KOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
55dd23eca6
commit
fb1fece5da
16 changed files with 115 additions and 105 deletions
|
@ -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)
|
||||||
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)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 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,
|
||||||
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,
|
||||||
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,
|
||||||
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,
|
||||||
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,
|
||||||
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,
|
||||||
|
|
||||||
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)
|
||||||
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)
|
||||||
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)
|
||||||
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,
|
||||||
{
|
{
|
||||||
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,
|
||||||
|
|
||||||
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,
|
||||||
|
|
||||||
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
|
||||||
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,
|
||||||
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,
|
||||||
|
|
||||||
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)
|
||||||
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)
|
||||||
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,
|
||||||
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,
|
||||||
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)
|
||||||
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)
|
||||||
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)
|
||||||
|
|
||||||
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)
|
||||||
};
|
};
|
||||||
|
|
||||||
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)
|
||||||
/* 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
|
||||||
|
|
||||||
/* 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
|
||||||
/* 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;
|
||||||
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;
|
||||||
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)
|
||||||
}
|
}
|
||||||
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)
|
||||||
}
|
}
|
||||||
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)
|
||||||
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)
|
||||||
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)
|
||||||
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)
|
||||||
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)
|
||||||
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)
|
||||||
|
|
||||||
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)
|
||||||
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)
|
||||||
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)
|
||||||
|
|
||||||
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,
|
||||||
{
|
{
|
||||||
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,
|
||||||
|
|
||||||
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,
|
||||||
|
|
||||||
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)
|
||||||
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,
|
||||||
{
|
{
|
||||||
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,
|
||||||
|
|
||||||
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,
|
||||||
|
|
||||||
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,
|
||||||
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)
|
||||||
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)
|
||||||
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)
|
||||||
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)
|
||||||
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)
|
||||||
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,
|
||||||
{
|
{
|
||||||
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,
|
||||||
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,
|
||||||
|
|
||||||
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)
|
||||||
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;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue