Skip to content

Commit

Permalink
[SPARC64]: Fix leak when DR added cpu does not bootup.
Browse files Browse the repository at this point in the history
Signed-off-by: David S. Miller <davem@davemloft.net>
  • Loading branch information
David S. Miller committed Jul 16, 2007
1 parent b53bcb6 commit b37d40d
Showing 1 changed file with 6 additions and 6 deletions.
12 changes: 6 additions & 6 deletions arch/sparc64/kernel/smp.c
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,6 @@ static volatile unsigned long callin_flag = 0;
void __devinit smp_callin(void)
{
int cpuid = hard_smp_processor_id();
struct trap_per_cpu *tb = &trap_block[cpuid];;

__local_per_cpu_offset = __per_cpu_offset(cpuid);

Expand Down Expand Up @@ -119,11 +118,6 @@ void __devinit smp_callin(void)
atomic_inc(&init_mm.mm_count);
current->active_mm = &init_mm;

if (tb->hdesc) {
kfree(tb->hdesc);
tb->hdesc = NULL;
}

while (!cpu_isset(cpuid, smp_commenced_mask))
rmb();

Expand Down Expand Up @@ -345,6 +339,7 @@ static struct thread_info *cpu_new_thread = NULL;

static int __devinit smp_boot_one_cpu(unsigned int cpu)
{
struct trap_per_cpu *tb = &trap_block[cpu];
unsigned long entry =
(unsigned long)(&sparc64_cpu_startup);
unsigned long cookie =
Expand Down Expand Up @@ -389,6 +384,11 @@ static int __devinit smp_boot_one_cpu(unsigned int cpu)
}
cpu_new_thread = NULL;

if (tb->hdesc) {
kfree(tb->hdesc);
tb->hdesc = NULL;
}

return ret;
}

Expand Down

0 comments on commit b37d40d

Please sign in to comment.