Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 107629
b: refs/heads/master
c: 1992663
h: refs/heads/master
i:
  107627: 737a9ec
v: v3
  • Loading branch information
David S. Miller committed Aug 4, 2008
1 parent a5536b1 commit ea7042c
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 24 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: cd5bc89debb4045d55eeffe325b97f2dfba4ddea
refs/heads/master: 199266305311d060b6e057fa5c7de01f218bb911
33 changes: 10 additions & 23 deletions trunk/arch/sparc64/kernel/smp.c
Original file line number Diff line number Diff line change
Expand Up @@ -792,16 +792,15 @@ extern unsigned long xcall_call_function;

void arch_send_call_function_ipi(cpumask_t mask)
{
smp_cross_call_masked(&xcall_call_function, 0, 0, 0, mask);
xcall_deliver((u64) &xcall_call_function, 0, 0, &mask);
}

extern unsigned long xcall_call_function_single;

void arch_send_call_function_single_ipi(int cpu)
{
cpumask_t mask = cpumask_of_cpu(cpu);

smp_cross_call_masked(&xcall_call_function_single, 0, 0, 0, mask);
xcall_deliver((u64) &xcall_call_function_single, 0, 0,
&cpumask_of_cpu(cpu));
}

/* Send cross call to all processors except self. */
Expand Down Expand Up @@ -959,24 +958,6 @@ void flush_dcache_page_all(struct mm_struct *mm, struct page *page)
put_cpu();
}

static void __smp_receive_signal_mask(cpumask_t mask)
{
smp_cross_call_masked(&xcall_receive_signal, 0, 0, 0, mask);
}

void smp_receive_signal(int cpu)
{
cpumask_t mask = cpumask_of_cpu(cpu);

if (cpu_online(cpu))
__smp_receive_signal_mask(mask);
}

void smp_receive_signal_client(int irq, struct pt_regs *regs)
{
clear_softint(1 << irq);
}

void smp_new_mmu_context_version_client(int irq, struct pt_regs *regs)
{
struct mm_struct *mm;
Expand Down Expand Up @@ -1374,7 +1355,13 @@ void __init smp_cpus_done(unsigned int max_cpus)

void smp_send_reschedule(int cpu)
{
smp_receive_signal(cpu);
xcall_deliver((u64) &xcall_receive_signal, 0, 0,
&cpumask_of_cpu(cpu));
}

void smp_receive_signal_client(int irq, struct pt_regs *regs)
{
clear_softint(1 << irq);
}

/* This is a nop because we capture all other cpus
Expand Down

0 comments on commit ea7042c

Please sign in to comment.