Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
58988b07
R
raspberrypi-kernel
项目概览
openeuler
/
raspberrypi-kernel
通知
13
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
raspberrypi-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
58988b07
编写于
12月 03, 2009
作者:
A
Avi Kivity
浏览文件
操作
浏览文件
下载
差异文件
Merge remote branch 'tip/x86/entry' into kvm-updates/2.6.33
Signed-off-by:
N
Avi Kivity
<
avi@redhat.com
>
上级
22763c5c
8e7cac79
变更
9
显示空白变更内容
内联
并排
Showing
9 changed file
with
119 addition
and
2 deletion
+119
-2
arch/Kconfig
arch/Kconfig
+10
-0
arch/x86/Kconfig
arch/x86/Kconfig
+1
-0
arch/x86/include/asm/thread_info.h
arch/x86/include/asm/thread_info.h
+5
-2
arch/x86/kernel/process.c
arch/x86/kernel/process.c
+2
-0
arch/x86/kernel/signal.c
arch/x86/kernel/signal.c
+3
-0
include/linux/user-return-notifier.h
include/linux/user-return-notifier.h
+49
-0
kernel/Makefile
kernel/Makefile
+1
-0
kernel/fork.c
kernel/fork.c
+2
-0
kernel/user-return-notifier.c
kernel/user-return-notifier.c
+46
-0
未找到文件。
arch/Kconfig
浏览文件 @
58988b07
...
...
@@ -83,6 +83,13 @@ config KRETPROBES
def_bool y
depends on KPROBES && HAVE_KRETPROBES
config USER_RETURN_NOTIFIER
bool
depends on HAVE_USER_RETURN_NOTIFIER
help
Provide a kernel-internal notification when a cpu is about to
switch to user mode.
config HAVE_IOREMAP_PROT
bool
...
...
@@ -126,4 +133,7 @@ config HAVE_DMA_API_DEBUG
config HAVE_DEFAULT_NO_SPIN_MUTEXES
bool
config HAVE_USER_RETURN_NOTIFIER
bool
source "kernel/gcov/Kconfig"
arch/x86/Kconfig
浏览文件 @
58988b07
...
...
@@ -50,6 +50,7 @@ config X86
select HAVE_KERNEL_BZIP2
select HAVE_KERNEL_LZMA
select HAVE_ARCH_KMEMCHECK
select HAVE_USER_RETURN_NOTIFIER
config OUTPUT_FORMAT
string
...
...
arch/x86/include/asm/thread_info.h
浏览文件 @
58988b07
...
...
@@ -83,6 +83,7 @@ struct thread_info {
#define TIF_SYSCALL_AUDIT 7
/* syscall auditing active */
#define TIF_SECCOMP 8
/* secure computing */
#define TIF_MCE_NOTIFY 10
/* notify userspace of an MCE */
#define TIF_USER_RETURN_NOTIFY 11
/* notify kernel of userspace return */
#define TIF_NOTSC 16
/* TSC is not accessible in userland */
#define TIF_IA32 17
/* 32bit process */
#define TIF_FORK 18
/* ret_from_fork */
...
...
@@ -107,6 +108,7 @@ struct thread_info {
#define _TIF_SYSCALL_AUDIT (1 << TIF_SYSCALL_AUDIT)
#define _TIF_SECCOMP (1 << TIF_SECCOMP)
#define _TIF_MCE_NOTIFY (1 << TIF_MCE_NOTIFY)
#define _TIF_USER_RETURN_NOTIFY (1 << TIF_USER_RETURN_NOTIFY)
#define _TIF_NOTSC (1 << TIF_NOTSC)
#define _TIF_IA32 (1 << TIF_IA32)
#define _TIF_FORK (1 << TIF_FORK)
...
...
@@ -142,13 +144,14 @@ struct thread_info {
/* Only used for 64 bit */
#define _TIF_DO_NOTIFY_MASK \
(_TIF_SIGPENDING|_TIF_MCE_NOTIFY|_TIF_NOTIFY_RESUME)
(_TIF_SIGPENDING | _TIF_MCE_NOTIFY | _TIF_NOTIFY_RESUME | \
_TIF_USER_RETURN_NOTIFY)
/* flags to check in __switch_to() */
#define _TIF_WORK_CTXSW \
(_TIF_IO_BITMAP|_TIF_DEBUGCTLMSR|_TIF_DS_AREA_MSR|_TIF_NOTSC)
#define _TIF_WORK_CTXSW_PREV
_TIF_WORK_CTXSW
#define _TIF_WORK_CTXSW_PREV
(_TIF_WORK_CTXSW|_TIF_USER_RETURN_NOTIFY)
#define _TIF_WORK_CTXSW_NEXT (_TIF_WORK_CTXSW|_TIF_DEBUG)
#define PREEMPT_ACTIVE 0x10000000
...
...
arch/x86/kernel/process.c
浏览文件 @
58988b07
...
...
@@ -9,6 +9,7 @@
#include <linux/pm.h>
#include <linux/clockchips.h>
#include <linux/random.h>
#include <linux/user-return-notifier.h>
#include <trace/events/power.h>
#include <asm/system.h>
#include <asm/apic.h>
...
...
@@ -224,6 +225,7 @@ void __switch_to_xtra(struct task_struct *prev_p, struct task_struct *next_p,
*/
memset
(
tss
->
io_bitmap
,
0xff
,
prev
->
io_bitmap_max
);
}
propagate_user_return_notify
(
prev_p
,
next_p
);
}
int
sys_fork
(
struct
pt_regs
*
regs
)
...
...
arch/x86/kernel/signal.c
浏览文件 @
58988b07
...
...
@@ -19,6 +19,7 @@
#include <linux/stddef.h>
#include <linux/personality.h>
#include <linux/uaccess.h>
#include <linux/user-return-notifier.h>
#include <asm/processor.h>
#include <asm/ucontext.h>
...
...
@@ -872,6 +873,8 @@ do_notify_resume(struct pt_regs *regs, void *unused, __u32 thread_info_flags)
if
(
current
->
replacement_session_keyring
)
key_replace_session_keyring
();
}
if
(
thread_info_flags
&
_TIF_USER_RETURN_NOTIFY
)
fire_user_return_notifiers
();
#ifdef CONFIG_X86_32
clear_thread_flag
(
TIF_IRET
);
...
...
include/linux/user-return-notifier.h
0 → 100644
浏览文件 @
58988b07
#ifndef _LINUX_USER_RETURN_NOTIFIER_H
#define _LINUX_USER_RETURN_NOTIFIER_H
#ifdef CONFIG_USER_RETURN_NOTIFIER
#include <linux/list.h>
#include <linux/sched.h>
struct
user_return_notifier
{
void
(
*
on_user_return
)(
struct
user_return_notifier
*
urn
);
struct
hlist_node
link
;
};
void
user_return_notifier_register
(
struct
user_return_notifier
*
urn
);
void
user_return_notifier_unregister
(
struct
user_return_notifier
*
urn
);
static
inline
void
propagate_user_return_notify
(
struct
task_struct
*
prev
,
struct
task_struct
*
next
)
{
if
(
test_tsk_thread_flag
(
prev
,
TIF_USER_RETURN_NOTIFY
))
{
clear_tsk_thread_flag
(
prev
,
TIF_USER_RETURN_NOTIFY
);
set_tsk_thread_flag
(
next
,
TIF_USER_RETURN_NOTIFY
);
}
}
void
fire_user_return_notifiers
(
void
);
static
inline
void
clear_user_return_notifier
(
struct
task_struct
*
p
)
{
clear_tsk_thread_flag
(
p
,
TIF_USER_RETURN_NOTIFY
);
}
#else
struct
user_return_notifier
{};
static
inline
void
propagate_user_return_notify
(
struct
task_struct
*
prev
,
struct
task_struct
*
next
)
{
}
static
inline
void
fire_user_return_notifiers
(
void
)
{}
static
inline
void
clear_user_return_notifier
(
struct
task_struct
*
p
)
{}
#endif
#endif
kernel/Makefile
浏览文件 @
58988b07
...
...
@@ -96,6 +96,7 @@ obj-$(CONFIG_SMP) += sched_cpupri.o
obj-$(CONFIG_SLOW_WORK)
+=
slow-work.o
obj-$(CONFIG_SLOW_WORK_DEBUG)
+=
slow-work-debugfs.o
obj-$(CONFIG_PERF_EVENTS)
+=
perf_event.o
obj-$(CONFIG_USER_RETURN_NOTIFIER)
+=
user-return-notifier.o
ifneq
($(CONFIG_SCHED_OMIT_FRAME_POINTER),y)
# According to Alan Modra <alan@linuxcare.com.au>, the -fno-omit-frame-pointer is
...
...
kernel/fork.c
浏览文件 @
58988b07
...
...
@@ -64,6 +64,7 @@
#include <linux/magic.h>
#include <linux/perf_event.h>
#include <linux/posix-timers.h>
#include <linux/user-return-notifier.h>
#include <asm/pgtable.h>
#include <asm/pgalloc.h>
...
...
@@ -249,6 +250,7 @@ static struct task_struct *dup_task_struct(struct task_struct *orig)
goto
out
;
setup_thread_stack
(
tsk
,
orig
);
clear_user_return_notifier
(
tsk
);
stackend
=
end_of_stack
(
tsk
);
*
stackend
=
STACK_END_MAGIC
;
/* for overflow detection */
...
...
kernel/user-return-notifier.c
0 → 100644
浏览文件 @
58988b07
#include <linux/user-return-notifier.h>
#include <linux/percpu.h>
#include <linux/sched.h>
#include <linux/module.h>
static
DEFINE_PER_CPU
(
struct
hlist_head
,
return_notifier_list
);
#define URN_LIST_HEAD per_cpu(return_notifier_list, raw_smp_processor_id())
/*
* Request a notification when the current cpu returns to userspace. Must be
* called in atomic context. The notifier will also be called in atomic
* context.
*/
void
user_return_notifier_register
(
struct
user_return_notifier
*
urn
)
{
set_tsk_thread_flag
(
current
,
TIF_USER_RETURN_NOTIFY
);
hlist_add_head
(
&
urn
->
link
,
&
URN_LIST_HEAD
);
}
EXPORT_SYMBOL_GPL
(
user_return_notifier_register
);
/*
* Removes a registered user return notifier. Must be called from atomic
* context, and from the same cpu registration occured in.
*/
void
user_return_notifier_unregister
(
struct
user_return_notifier
*
urn
)
{
hlist_del
(
&
urn
->
link
);
if
(
hlist_empty
(
&
URN_LIST_HEAD
))
clear_tsk_thread_flag
(
current
,
TIF_USER_RETURN_NOTIFY
);
}
EXPORT_SYMBOL_GPL
(
user_return_notifier_unregister
);
/* Calls registered user return notifiers */
void
fire_user_return_notifiers
(
void
)
{
struct
user_return_notifier
*
urn
;
struct
hlist_node
*
tmp1
,
*
tmp2
;
struct
hlist_head
*
head
;
head
=
&
get_cpu_var
(
return_notifier_list
);
hlist_for_each_entry_safe
(
urn
,
tmp1
,
tmp2
,
head
,
link
)
urn
->
on_user_return
(
urn
);
put_cpu_var
(
return_notifier_list
);
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录