Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
b9763ce3
cloud-kernel
项目概览
openanolis
/
cloud-kernel
大约 1 年 前同步成功
通知
158
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,发现更多精彩内容 >>
提交
b9763ce3
编写于
10月 21, 2012
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
frv: switch to generic fork/vfork/clone
Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
0bcfe540
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
8 addition
and
40 deletion
+8
-40
arch/frv/include/asm/unistd.h
arch/frv/include/asm/unistd.h
+3
-0
arch/frv/kernel/process.c
arch/frv/kernel/process.c
+5
-40
未找到文件。
arch/frv/include/asm/unistd.h
浏览文件 @
b9763ce3
...
...
@@ -30,6 +30,9 @@
#define __ARCH_WANT_SYS_RT_SIGACTION
#define __ARCH_WANT_SYS_RT_SIGSUSPEND
#define __ARCH_WANT_SYS_EXECVE
#define __ARCH_WANT_SYS_FORK
#define __ARCH_WANT_SYS_VFORK
#define __ARCH_WANT_SYS_CLONE
/*
* "Conditional" syscalls
...
...
arch/frv/kernel/process.c
浏览文件 @
b9763ce3
...
...
@@ -139,42 +139,12 @@ inline unsigned long user_stack(const struct pt_regs *regs)
return
user_mode
(
regs
)
?
regs
->
sp
:
0
;
}
asmlinkage
int
sys_fork
(
void
)
{
#ifndef CONFIG_MMU
/* fork almost works, enough to trick you into looking elsewhere:-( */
return
-
EINVAL
;
#else
return
do_fork
(
SIGCHLD
,
user_stack
(
__frame
),
__frame
,
0
,
NULL
,
NULL
);
#endif
}
asmlinkage
int
sys_vfork
(
void
)
{
return
do_fork
(
CLONE_VFORK
|
CLONE_VM
|
SIGCHLD
,
user_stack
(
__frame
),
__frame
,
0
,
NULL
,
NULL
);
}
/*****************************************************************************/
/*
* clone a process
* - tlsptr is retrieved by copy_thread()
*/
asmlinkage
int
sys_clone
(
unsigned
long
clone_flags
,
unsigned
long
newsp
,
int
__user
*
parent_tidptr
,
int
__user
*
child_tidptr
,
int
__user
*
tlsptr
)
{
if
(
!
newsp
)
newsp
=
user_stack
(
__frame
);
return
do_fork
(
clone_flags
,
newsp
,
__frame
,
0
,
parent_tidptr
,
child_tidptr
);
}
/* end sys_clone() */
/*
* set up the kernel stack and exception frames for a new process
*/
int
copy_thread
(
unsigned
long
clone_flags
,
unsigned
long
usp
,
unsigned
long
arg
,
struct
task_struct
*
p
,
struct
pt_regs
*
regs
)
struct
task_struct
*
p
,
struct
pt_regs
*
unused
)
{
struct
pt_regs
*
childregs
;
...
...
@@ -182,9 +152,7 @@ int copy_thread(unsigned long clone_flags,
(
task_stack_page
(
p
)
+
THREAD_SIZE
-
FRV_FRAME0_SIZE
);
/* set up the userspace frame (the only place that the USP is stored) */
*
childregs
=
*
__kernel_frame0_ptr
;
p
->
set_child_tid
=
p
->
clear_child_tid
=
NULL
;
*
childregs
=
*
current_pt_regs
();
p
->
thread
.
frame
=
childregs
;
p
->
thread
.
curr
=
p
;
...
...
@@ -193,18 +161,15 @@ int copy_thread(unsigned long clone_flags,
p
->
thread
.
lr
=
0
;
p
->
thread
.
frame0
=
childregs
;
if
(
unlikely
(
!
regs
))
{
if
(
unlikely
(
p
->
flags
&
PF_KTHREAD
))
{
childregs
->
gr9
=
usp
;
/* function */
childregs
->
gr8
=
arg
;
p
->
thread
.
pc
=
(
unsigned
long
)
ret_from_kernel_thread
;
save_user_regs
(
p
->
thread
.
user
);
return
0
;
}
/* set up the userspace frame (the only place that the USP is stored) */
*
childregs
=
*
regs
;
childregs
->
sp
=
usp
;
if
(
usp
)
childregs
->
sp
=
usp
;
childregs
->
next_frame
=
NULL
;
p
->
thread
.
pc
=
(
unsigned
long
)
ret_from_fork
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录