diff options
Diffstat (limited to 'arch')
-rw-r--r-- | arch/parisc/kernel/process.c | 6 | ||||
-rw-r--r-- | arch/parisc/kernel/smp.c | 2 |
2 files changed, 4 insertions, 4 deletions
diff --git a/arch/parisc/kernel/process.c b/arch/parisc/kernel/process.c index 4eb70a40ec7e..5da41677e70b 100644 --- a/arch/parisc/kernel/process.c +++ b/arch/parisc/kernel/process.c | |||
@@ -295,7 +295,7 @@ copy_thread(int nr, unsigned long clone_flags, unsigned long usp, | |||
295 | struct task_struct * p, struct pt_regs * pregs) | 295 | struct task_struct * p, struct pt_regs * pregs) |
296 | { | 296 | { |
297 | struct pt_regs * cregs = &(p->thread.regs); | 297 | struct pt_regs * cregs = &(p->thread.regs); |
298 | struct thread_info *ti = p->thread_info; | 298 | void *stack = task_stack_page(p); |
299 | 299 | ||
300 | /* We have to use void * instead of a function pointer, because | 300 | /* We have to use void * instead of a function pointer, because |
301 | * function pointers aren't a pointer to the function on 64-bit. | 301 | * function pointers aren't a pointer to the function on 64-bit. |
@@ -322,7 +322,7 @@ copy_thread(int nr, unsigned long clone_flags, unsigned long usp, | |||
322 | */ | 322 | */ |
323 | if (usp == 1) { | 323 | if (usp == 1) { |
324 | /* kernel thread */ | 324 | /* kernel thread */ |
325 | cregs->ksp = (((unsigned long)(ti)) + THREAD_SZ_ALGN); | 325 | cregs->ksp = (unsigned long)stack + THREAD_SZ_ALGN; |
326 | /* Must exit via ret_from_kernel_thread in order | 326 | /* Must exit via ret_from_kernel_thread in order |
327 | * to call schedule_tail() | 327 | * to call schedule_tail() |
328 | */ | 328 | */ |
@@ -344,7 +344,7 @@ copy_thread(int nr, unsigned long clone_flags, unsigned long usp, | |||
344 | */ | 344 | */ |
345 | 345 | ||
346 | /* Use same stack depth as parent */ | 346 | /* Use same stack depth as parent */ |
347 | cregs->ksp = ((unsigned long)(ti)) | 347 | cregs->ksp = (unsigned long)stack |
348 | + (pregs->gr[21] & (THREAD_SIZE - 1)); | 348 | + (pregs->gr[21] & (THREAD_SIZE - 1)); |
349 | cregs->gr[30] = usp; | 349 | cregs->gr[30] = usp; |
350 | if (p->personality == PER_HPUX) { | 350 | if (p->personality == PER_HPUX) { |
diff --git a/arch/parisc/kernel/smp.c b/arch/parisc/kernel/smp.c index 17f23c26f1ca..25564b7ca6bb 100644 --- a/arch/parisc/kernel/smp.c +++ b/arch/parisc/kernel/smp.c | |||
@@ -517,7 +517,7 @@ int __init smp_boot_one_cpu(int cpuid) | |||
517 | if (IS_ERR(idle)) | 517 | if (IS_ERR(idle)) |
518 | panic("SMP: fork failed for CPU:%d", cpuid); | 518 | panic("SMP: fork failed for CPU:%d", cpuid); |
519 | 519 | ||
520 | idle->thread_info->cpu = cpuid; | 520 | task_thread_info(idle)->cpu = cpuid; |
521 | 521 | ||
522 | /* Let _start know what logical CPU we're booting | 522 | /* Let _start know what logical CPU we're booting |
523 | ** (offset into init_tasks[],cpu_data[]) | 523 | ** (offset into init_tasks[],cpu_data[]) |