diff options
author | Avi Kivity <avi@redhat.com> | 2009-09-19 02:40:22 -0400 |
---|---|---|
committer | H. Peter Anvin <hpa@zytor.com> | 2009-10-01 15:12:18 -0400 |
commit | 7c68af6e32c73992bad24107311f3433c89016e2 (patch) | |
tree | 9046ac5339f944e8ddccd34be226790b953dda61 /arch/x86/kernel/signal.c | |
parent | 817b33d38f81c8736d39283c35c886ae4668f1af (diff) |
core, x86: Add user return notifiers
Add a general per-cpu notifier that is called whenever the kernel is
about to return to userspace. The notifier uses a thread_info flag
and existing checks, so there is no impact on user return or context
switch fast paths.
This will be used initially to speed up KVM task switching by lazily
updating MSRs.
Signed-off-by: Avi Kivity <avi@redhat.com>
LKML-Reference: <1253342422-13811-1-git-send-email-avi@redhat.com>
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
Diffstat (limited to 'arch/x86/kernel/signal.c')
-rw-r--r-- | arch/x86/kernel/signal.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/arch/x86/kernel/signal.c b/arch/x86/kernel/signal.c index 6a44a76055ad..c49f90f7957a 100644 --- a/arch/x86/kernel/signal.c +++ b/arch/x86/kernel/signal.c | |||
@@ -19,6 +19,7 @@ | |||
19 | #include <linux/stddef.h> | 19 | #include <linux/stddef.h> |
20 | #include <linux/personality.h> | 20 | #include <linux/personality.h> |
21 | #include <linux/uaccess.h> | 21 | #include <linux/uaccess.h> |
22 | #include <linux/user-return-notifier.h> | ||
22 | 23 | ||
23 | #include <asm/processor.h> | 24 | #include <asm/processor.h> |
24 | #include <asm/ucontext.h> | 25 | #include <asm/ucontext.h> |
@@ -872,6 +873,8 @@ do_notify_resume(struct pt_regs *regs, void *unused, __u32 thread_info_flags) | |||
872 | if (current->replacement_session_keyring) | 873 | if (current->replacement_session_keyring) |
873 | key_replace_session_keyring(); | 874 | key_replace_session_keyring(); |
874 | } | 875 | } |
876 | if (thread_info_flags & _TIF_USER_RETURN_NOTIFY) | ||
877 | fire_user_return_notifiers(); | ||
875 | 878 | ||
876 | #ifdef CONFIG_X86_32 | 879 | #ifdef CONFIG_X86_32 |
877 | clear_thread_flag(TIF_IRET); | 880 | clear_thread_flag(TIF_IRET); |