diff options
| author | Mark Brown <[email protected]> | 2015-10-12 18:09:27 +0100 | 
|---|---|---|
| committer | Mark Brown <[email protected]> | 2015-10-12 18:09:27 +0100 | 
| commit | 79828b4fa835f73cdaf4bffa48696abdcbea9d02 (patch) | |
| tree | 5e0fa7156acb75ba603022bc807df8f2fedb97a8 /kernel/ptrace.c | |
| parent | 721b51fcf91898299d96f4b72cb9434cda29dce6 (diff) | |
| parent | 8c1a9d6323abf0fb1e5dad96cf3f1c783505ea5a (diff) | |
Merge remote-tracking branch 'asoc/fix/rt5645' into asoc-fix-rt5645
Diffstat (limited to 'kernel/ptrace.c')
| -rw-r--r-- | kernel/ptrace.c | 13 | 
1 files changed, 13 insertions, 0 deletions
diff --git a/kernel/ptrace.c b/kernel/ptrace.c index c8e0e050a36a..787320de68e0 100644 --- a/kernel/ptrace.c +++ b/kernel/ptrace.c @@ -556,6 +556,19 @@ static int ptrace_setoptions(struct task_struct *child, unsigned long data)  	if (data & ~(unsigned long)PTRACE_O_MASK)  		return -EINVAL; +	if (unlikely(data & PTRACE_O_SUSPEND_SECCOMP)) { +		if (!config_enabled(CONFIG_CHECKPOINT_RESTORE) || +		    !config_enabled(CONFIG_SECCOMP)) +			return -EINVAL; + +		if (!capable(CAP_SYS_ADMIN)) +			return -EPERM; + +		if (seccomp_mode(¤t->seccomp) != SECCOMP_MODE_DISABLED || +		    current->ptrace & PT_SUSPEND_SECCOMP) +			return -EPERM; +	} +  	/* Avoid intermediate state when all opts are cleared */  	flags = child->ptrace;  	flags &= ~(PTRACE_O_MASK << PT_OPT_FLAG_SHIFT);  |