Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
135c37b8
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
135c37b8
编写于
11月 13, 2012
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
bfin: switch to generic vfork, get rid of pointless wrappers
Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
3e41f9ba
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
7 addition
and
54 deletion
+7
-54
arch/blackfin/include/asm/unistd.h
arch/blackfin/include/asm/unistd.h
+1
-0
arch/blackfin/kernel/entry.S
arch/blackfin/kernel/entry.S
+0
-33
arch/blackfin/kernel/process.c
arch/blackfin/kernel/process.c
+3
-18
arch/blackfin/kernel/signal.c
arch/blackfin/kernel/signal.c
+2
-2
arch/blackfin/mach-common/entry.S
arch/blackfin/mach-common/entry.S
+1
-1
未找到文件。
arch/blackfin/include/asm/unistd.h
浏览文件 @
135c37b8
...
...
@@ -447,6 +447,7 @@
#define __ARCH_WANT_SYS_RT_SIGACTION
#define __ARCH_WANT_SYS_RT_SIGSUSPEND
#define __ARCH_WANT_SYS_EXECVE
#define __ARCH_WANT_SYS_VFORK
/*
* "Conditional" syscalls
...
...
arch/blackfin/kernel/entry.S
浏览文件 @
135c37b8
...
...
@@ -57,36 +57,3 @@ ENTRY(_ret_from_fork)
RESTORE_CONTEXT
rti
;
ENDPROC
(
_ret_from_fork
)
ENTRY
(
_sys_vfork
)
r0
=
sp
;
r0
+=
24
;
[--
sp
]
=
rets
;
SP
+=
-
12
;
pseudo_long_call
_bfin_vfork
,
p2
;
SP
+=
12
;
rets
=
[
sp
++]
;
rts
;
ENDPROC
(
_sys_vfork
)
ENTRY
(
_sys_clone
)
r0
=
sp
;
r0
+=
24
;
[--
sp
]
=
rets
;
SP
+=
-
12
;
pseudo_long_call
_bfin_clone
,
p2
;
SP
+=
12
;
rets
=
[
sp
++]
;
rts
;
ENDPROC
(
_sys_clone
)
ENTRY
(
_sys_rt_sigreturn
)
r0
=
sp
;
r0
+=
24
;
[--
sp
]
=
rets
;
SP
+=
-
12
;
pseudo_long_call
_do_rt_sigreturn
,
p2
;
SP
+=
12
;
rets
=
[
sp
++]
;
rts
;
ENDPROC
(
_sys_rt_sigreturn
)
arch/blackfin/kernel/process.c
浏览文件 @
135c37b8
...
...
@@ -127,28 +127,13 @@ void flush_thread(void)
{
}
asmlinkage
int
bfin_
vfork
(
struct
pt_regs
*
regs
)
asmlinkage
int
bfin_
clone
(
unsigned
long
clone_flags
,
unsigned
long
newsp
)
{
return
do_fork
(
CLONE_VFORK
|
CLONE_VM
|
SIGCHLD
,
rdusp
(),
regs
,
0
,
NULL
,
NULL
);
}
asmlinkage
int
bfin_clone
(
struct
pt_regs
*
regs
)
{
unsigned
long
clone_flags
;
unsigned
long
newsp
;
#ifdef __ARCH_SYNC_CORE_DCACHE
if
(
current
->
nr_cpus_allowed
==
num_possible_cpus
())
set_cpus_allowed_ptr
(
current
,
cpumask_of
(
smp_processor_id
()));
#endif
/* syscall2 puts clone_flags in r0 and usp in r1 */
clone_flags
=
regs
->
r0
;
newsp
=
regs
->
r1
;
if
(
!
newsp
)
newsp
=
rdusp
();
else
if
(
newsp
)
newsp
-=
12
;
return
do_fork
(
clone_flags
,
newsp
,
regs
,
0
,
NULL
,
NULL
);
}
...
...
@@ -174,7 +159,7 @@ copy_thread(unsigned long clone_flags,
}
else
{
*
childregs
=
*
regs
;
childregs
->
r0
=
0
;
p
->
thread
.
usp
=
usp
;
p
->
thread
.
usp
=
usp
?
:
rdusp
()
;
v
[
0
]
=
v
[
1
]
=
0
;
}
...
...
arch/blackfin/kernel/signal.c
浏览文件 @
135c37b8
...
...
@@ -82,9 +82,9 @@ rt_restore_sigcontext(struct pt_regs *regs, struct sigcontext __user *sc, int *p
return
err
;
}
asmlinkage
int
do_rt_sigreturn
(
unsigned
long
__unuse
d
)
asmlinkage
int
sys_rt_sigreturn
(
voi
d
)
{
struct
pt_regs
*
regs
=
(
struct
pt_regs
*
)
__unused
;
struct
pt_regs
*
regs
=
current_pt_regs
()
;
unsigned
long
usp
=
rdusp
();
struct
rt_sigframe
*
frame
=
(
struct
rt_sigframe
*
)(
usp
);
sigset_t
set
;
...
...
arch/blackfin/mach-common/entry.S
浏览文件 @
135c37b8
...
...
@@ -1431,7 +1431,7 @@ ENTRY(_sys_call_table)
.
long
_sys_ni_syscall
/*
old
sys_ipc
*/
.
long
_sys_fsync
.
long
_sys_ni_syscall
/*
old
sys_sigreturn
*/
.
long
_
sys
_clone
/*
120
*/
.
long
_
bfin
_clone
/*
120
*/
.
long
_sys_setdomainname
.
long
_sys_newuname
.
long
_sys_ni_syscall
/*
old
sys_modify_ldt
*/
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录