|
@@ -3460,7 +3460,8 @@ int do_sigaction(int sig, struct k_sigaction *act, struct k_sigaction *oact)
|
|
|
}
|
|
|
|
|
|
static int
|
|
|
-do_sigaltstack (const stack_t *ss, stack_t *oss, unsigned long sp)
|
|
|
+do_sigaltstack (const stack_t *ss, stack_t *oss, unsigned long sp,
|
|
|
+ size_t min_ss_size)
|
|
|
{
|
|
|
struct task_struct *t = current;
|
|
|
|
|
@@ -3490,7 +3491,7 @@ do_sigaltstack (const stack_t *ss, stack_t *oss, unsigned long sp)
|
|
|
ss_size = 0;
|
|
|
ss_sp = NULL;
|
|
|
} else {
|
|
|
- if (unlikely(ss_size < MINSIGSTKSZ))
|
|
|
+ if (unlikely(ss_size < min_ss_size))
|
|
|
return -ENOMEM;
|
|
|
}
|
|
|
|
|
@@ -3508,7 +3509,8 @@ SYSCALL_DEFINE2(sigaltstack,const stack_t __user *,uss, stack_t __user *,uoss)
|
|
|
if (uss && copy_from_user(&new, uss, sizeof(stack_t)))
|
|
|
return -EFAULT;
|
|
|
err = do_sigaltstack(uss ? &new : NULL, uoss ? &old : NULL,
|
|
|
- current_user_stack_pointer());
|
|
|
+ current_user_stack_pointer(),
|
|
|
+ MINSIGSTKSZ);
|
|
|
if (!err && uoss && copy_to_user(uoss, &old, sizeof(stack_t)))
|
|
|
err = -EFAULT;
|
|
|
return err;
|
|
@@ -3519,7 +3521,8 @@ int restore_altstack(const stack_t __user *uss)
|
|
|
stack_t new;
|
|
|
if (copy_from_user(&new, uss, sizeof(stack_t)))
|
|
|
return -EFAULT;
|
|
|
- (void)do_sigaltstack(&new, NULL, current_user_stack_pointer());
|
|
|
+ (void)do_sigaltstack(&new, NULL, current_user_stack_pointer(),
|
|
|
+ MINSIGSTKSZ);
|
|
|
/* squash all but EFAULT for now */
|
|
|
return 0;
|
|
|
}
|
|
@@ -3553,7 +3556,8 @@ static int do_compat_sigaltstack(const compat_stack_t __user *uss_ptr,
|
|
|
uss.ss_size = uss32.ss_size;
|
|
|
}
|
|
|
ret = do_sigaltstack(uss_ptr ? &uss : NULL, &uoss,
|
|
|
- compat_user_stack_pointer());
|
|
|
+ compat_user_stack_pointer(),
|
|
|
+ COMPAT_MINSIGSTKSZ);
|
|
|
if (ret >= 0 && uoss_ptr) {
|
|
|
compat_stack_t old;
|
|
|
memset(&old, 0, sizeof(old));
|