Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
5687580b
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看板
提交
5687580b
编写于
9月 22, 2012
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
c6x: switch to generic kernel_thread()
Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
680a1453
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
6 addition
and
21 deletion
+6
-21
arch/c6x/Kconfig
arch/c6x/Kconfig
+1
-0
arch/c6x/include/asm/processor.h
arch/c6x/include/asm/processor.h
+0
-2
arch/c6x/kernel/process.c
arch/c6x/kernel/process.c
+5
-19
未找到文件。
arch/c6x/Kconfig
浏览文件 @
5687580b
...
...
@@ -17,6 +17,7 @@ config C6X
select OF
select OF_EARLY_FLATTREE
select GENERIC_CLOCKEVENTS
select GENERIC_KERNEL_THREAD
config MMU
def_bool n
...
...
arch/c6x/include/asm/processor.h
浏览文件 @
5687580b
...
...
@@ -92,8 +92,6 @@ static inline void release_thread(struct task_struct *dead_task)
{
}
extern
int
kernel_thread
(
int
(
*
fn
)(
void
*
),
void
*
arg
,
unsigned
long
flags
);
#define copy_segments(tsk, mm) do { } while (0)
#define release_segments(mm) do { } while (0)
...
...
arch/c6x/kernel/process.c
浏览文件 @
5687580b
...
...
@@ -104,22 +104,6 @@ void machine_power_off(void)
halt_loop
();
}
/*
* Create a kernel thread
*/
int
kernel_thread
(
int
(
*
fn
)(
void
*
),
void
*
arg
,
unsigned
long
flags
)
{
struct
pt_regs
regs
=
{
.
a0
=
(
unsigned
long
)
fn
,
.
a1
=
(
unsigned
long
)
arg
,
.
tsr
=
0
,
/* kernel mode */
};
/* Ok, create the new process.. */
return
do_fork
(
flags
|
CLONE_VM
|
CLONE_UNTRACED
,
-
1
,
&
regs
,
0
,
NULL
,
NULL
);
}
void
flush_thread
(
void
)
{
}
...
...
@@ -177,14 +161,16 @@ int copy_thread(unsigned long clone_flags, unsigned long usp,
childregs
=
task_pt_regs
(
p
);
*
childregs
=
*
regs
;
if
(
usp
==
-
1
)
{
if
(
!
regs
)
{
/* case of __kernel_thread: we return to supervisor space */
memset
(
childregs
,
0
,
sizeof
(
struct
pt_regs
));
childregs
->
sp
=
(
unsigned
long
)(
childregs
+
1
);
p
->
thread
.
pc
=
(
unsigned
long
)
ret_from_kernel_thread
;
childregs
->
a0
=
usp
;
/* function */
childregs
->
a1
=
ustk_size
;
/* argument */
}
else
{
/* Otherwise use the given stack */
*
childregs
=
*
regs
;
childregs
->
sp
=
usp
;
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.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录