x86: Introduce userspace API for shadow stack
Add three new arch_prctl() handles: - ARCH_SHSTK_ENABLE/DISABLE enables or disables the specified feature. Returns 0 on success or a negative value on error. - ARCH_SHSTK_LOCK prevents future disabling or enabling of the specified feature. Returns 0 on success or a negative value on error. The features are handled per-thread and inherited over fork(2)/clone(2), but reset on exec(). Co-developed-by: Kirill A. Shutemov <kirill.shutemov@linux.intel.com> Signed-off-by: Kirill A. Shutemov <kirill.shutemov@linux.intel.com> Signed-off-by: Rick Edgecombe <rick.p.edgecombe@intel.com> Signed-off-by: Dave Hansen <dave.hansen@linux.intel.com> Reviewed-by: Borislav Petkov (AMD) <bp@alien8.de> Reviewed-by: Kees Cook <keescook@chromium.org> Acked-by: Mike Rapoport (IBM) <rppt@kernel.org> Tested-by: Pengfei Xu <pengfei.xu@intel.com> Tested-by: John Allen <john.allen@amd.com> Tested-by: Kees Cook <keescook@chromium.org> Link: https://lore.kernel.org/all/20230613001108.3040476-27-rick.p.edgecombe%40intel.com
This commit is contained in:
committed by
Dave Hansen
parent
6ee836687a
commit
98cfa46309
44
arch/x86/kernel/shstk.c
Normal file
44
arch/x86/kernel/shstk.c
Normal file
@ -0,0 +1,44 @@
|
||||
// SPDX-License-Identifier: GPL-2.0
|
||||
/*
|
||||
* shstk.c - Intel shadow stack support
|
||||
*
|
||||
* Copyright (c) 2021, Intel Corporation.
|
||||
* Yu-cheng Yu <yu-cheng.yu@intel.com>
|
||||
*/
|
||||
|
||||
#include <linux/sched.h>
|
||||
#include <linux/bitops.h>
|
||||
#include <asm/prctl.h>
|
||||
|
||||
void reset_thread_features(void)
|
||||
{
|
||||
current->thread.features = 0;
|
||||
current->thread.features_locked = 0;
|
||||
}
|
||||
|
||||
long shstk_prctl(struct task_struct *task, int option, unsigned long features)
|
||||
{
|
||||
if (option == ARCH_SHSTK_LOCK) {
|
||||
task->thread.features_locked |= features;
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* Don't allow via ptrace */
|
||||
if (task != current)
|
||||
return -EINVAL;
|
||||
|
||||
/* Do not allow to change locked features */
|
||||
if (features & task->thread.features_locked)
|
||||
return -EPERM;
|
||||
|
||||
/* Only support enabling/disabling one feature at a time. */
|
||||
if (hweight_long(features) > 1)
|
||||
return -EINVAL;
|
||||
|
||||
if (option == ARCH_SHSTK_DISABLE) {
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
/* Handle ARCH_SHSTK_ENABLE */
|
||||
return -EINVAL;
|
||||
}
|
Reference in New Issue
Block a user