Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
44f4b56b
cloud-kernel
项目概览
openanolis
/
cloud-kernel
大约 1 年 前同步成功
通知
153
Star
36
Fork
7
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
10
列表
看板
标记
里程碑
合并请求
2
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
cloud-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
10
Issue
10
列表
看板
标记
里程碑
合并请求
2
合并请求
2
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
44f4b56b
编写于
5月 31, 2012
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
alpha: introduce ret_from_kernel_execve(), switch to generic kernel_execve()
Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
cba1ec7e
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
14 addition
and
19 deletion
+14
-19
arch/alpha/include/asm/unistd.h
arch/alpha/include/asm/unistd.h
+1
-0
arch/alpha/kernel/entry.S
arch/alpha/kernel/entry.S
+13
-0
arch/alpha/kernel/process.c
arch/alpha/kernel/process.c
+0
-19
未找到文件。
arch/alpha/include/asm/unistd.h
浏览文件 @
44f4b56b
...
...
@@ -482,6 +482,7 @@
#define __ARCH_WANT_SYS_SIGPENDING
#define __ARCH_WANT_SYS_RT_SIGSUSPEND
#define __ARCH_WANT_SYS_EXECVE
#define __ARCH_WANT_KERNEL_EXECVE
/* "Conditional" syscalls. What we want is
...
...
arch/alpha/kernel/entry.S
浏览文件 @
44f4b56b
...
...
@@ -626,6 +626,19 @@ ret_from_kernel_thread:
jmp
$
31
,
sys_exit
.
end
ret_from_kernel_thread
.
globl
ret_from_kernel_execve
.
align
4
.
ent
ret_from_kernel_execve
ret_from_kernel_execve
:
mov
$
16
,
$sp
/
*
Avoid
the
HAE
being
gratuitously
wrong
,
to
avoid
restoring
it
.
*/
ldq
$
2
,
alpha_mv
+
HAE_CACHE
stq
$
2
,
152
(
$sp
)
/*
HAE
*/
mov
$
31
,
$
19
/*
to
disable
syscall
restarts
*/
br
$
31
,
ret_to_user
.
end
ret_from_kernel_execve
/*
*
Special
system
calls
.
Most
of
these
are
special
in
that
they
either
...
...
arch/alpha/kernel/process.c
浏览文件 @
44f4b56b
...
...
@@ -435,22 +435,3 @@ get_wchan(struct task_struct *p)
}
return
pc
;
}
int
kernel_execve
(
const
char
*
path
,
const
char
*
const
argv
[],
const
char
*
const
envp
[])
{
/* Avoid the HAE being gratuitously wrong, which would cause us
to do the whole turn off interrupts thing and restore it. */
struct
pt_regs
regs
=
{.
hae
=
alpha_mv
.
hae_cache
};
int
err
=
do_execve
(
path
,
argv
,
envp
,
&
regs
);
if
(
!
err
)
{
struct
pt_regs
*
p
=
current_pt_regs
();
/* copy regs to normal position and off to userland we go... */
*
p
=
regs
;
__asm__
__volatile__
(
"mov %0, $sp;"
"br $31, ret_from_sys_call"
:
:
"r"
(
p
));
}
return
err
;
}
EXPORT_SYMBOL
(
kernel_execve
);
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录