diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2008-05-07 20:04:49 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2008-05-07 20:04:49 -0400 |
| commit | 3de2403e6659d71b36ec820dc9b942762ddfe6eb (patch) | |
| tree | 55516c669ffc2cbe9fd52c3a4d2d6f8e90d4644a /arch/sparc64/kernel/process.c | |
| parent | e0164af66b6ec165836d1d862b3f800890713452 (diff) | |
| parent | 1e38c126c9252b612697e34f43b1b3371c8ee31d (diff) | |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc-2.6
* git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc-2.6:
sparc: Fix fork/clone/vfork system call restart.
sparc: Fix mmap VA span checking.
Diffstat (limited to 'arch/sparc64/kernel/process.c')
| -rw-r--r-- | arch/sparc64/kernel/process.c | 18 |
1 files changed, 15 insertions, 3 deletions
diff --git a/arch/sparc64/kernel/process.c b/arch/sparc64/kernel/process.c index 500ac6d483a0..4129c0449856 100644 --- a/arch/sparc64/kernel/process.c +++ b/arch/sparc64/kernel/process.c | |||
| @@ -503,6 +503,8 @@ asmlinkage long sparc_do_fork(unsigned long clone_flags, | |||
| 503 | unsigned long stack_size) | 503 | unsigned long stack_size) |
| 504 | { | 504 | { |
| 505 | int __user *parent_tid_ptr, *child_tid_ptr; | 505 | int __user *parent_tid_ptr, *child_tid_ptr; |
| 506 | unsigned long orig_i1 = regs->u_regs[UREG_I1]; | ||
| 507 | long ret; | ||
| 506 | 508 | ||
| 507 | #ifdef CONFIG_COMPAT | 509 | #ifdef CONFIG_COMPAT |
| 508 | if (test_thread_flag(TIF_32BIT)) { | 510 | if (test_thread_flag(TIF_32BIT)) { |
| @@ -515,9 +517,19 @@ asmlinkage long sparc_do_fork(unsigned long clone_flags, | |||
| 515 | child_tid_ptr = (int __user *) regs->u_regs[UREG_I4]; | 517 | child_tid_ptr = (int __user *) regs->u_regs[UREG_I4]; |
| 516 | } | 518 | } |
| 517 | 519 | ||
| 518 | return do_fork(clone_flags, stack_start, | 520 | ret = do_fork(clone_flags, stack_start, |
| 519 | regs, stack_size, | 521 | regs, stack_size, |
| 520 | parent_tid_ptr, child_tid_ptr); | 522 | parent_tid_ptr, child_tid_ptr); |
| 523 | |||
| 524 | /* If we get an error and potentially restart the system | ||
| 525 | * call, we're screwed because copy_thread() clobbered | ||
| 526 | * the parent's %o1. So detect that case and restore it | ||
| 527 | * here. | ||
| 528 | */ | ||
| 529 | if ((unsigned long)ret >= -ERESTART_RESTARTBLOCK) | ||
| 530 | regs->u_regs[UREG_I1] = orig_i1; | ||
| 531 | |||
| 532 | return ret; | ||
| 521 | } | 533 | } |
| 522 | 534 | ||
| 523 | /* Copy a Sparc thread. The fork() return value conventions | 535 | /* Copy a Sparc thread. The fork() return value conventions |
