Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
d03d0a57
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看板
提交
d03d0a57
编写于
8月 17, 2005
作者:
R
Ralf Baechle
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
MT bulletproofing.
Signed-off-by:
N
Ralf Baechle
<
ralf@linux-mips.org
>
上级
533330bf
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
75 addition
and
14 deletion
+75
-14
arch/mips/kernel/irq_cpu.c
arch/mips/kernel/irq_cpu.c
+67
-12
arch/mips/kernel/traps.c
arch/mips/kernel/traps.c
+8
-2
未找到文件。
arch/mips/kernel/irq_cpu.c
浏览文件 @
d03d0a57
...
...
@@ -33,6 +33,7 @@
#include <asm/irq_cpu.h>
#include <asm/mipsregs.h>
#include <asm/mipsmtregs.h>
#include <asm/system.h>
static
int
mips_cpu_irq_base
;
...
...
@@ -76,7 +77,7 @@ static unsigned int mips_cpu_irq_startup(unsigned int irq)
return
0
;
}
#define mips_cpu_irq_shutdown mips_cpu_irq_disable
#define mips_cpu_irq_shutdown
mips_cpu_irq_disable
/*
* While we ack the interrupt interrupts are disabled and thus we don't need
...
...
@@ -84,9 +85,6 @@ static unsigned int mips_cpu_irq_startup(unsigned int irq)
*/
static
void
mips_cpu_irq_ack
(
unsigned
int
irq
)
{
/* Only necessary for soft interrupts */
clear_c0_cause
(
0x100
<<
(
irq
-
mips_cpu_irq_base
));
mask_mips_irq
(
irq
);
}
...
...
@@ -97,15 +95,60 @@ static void mips_cpu_irq_end(unsigned int irq)
}
static
hw_irq_controller
mips_cpu_irq_controller
=
{
.
typename
=
"MIPS"
,
.
startup
=
mips_cpu_irq_startup
,
.
shutdown
=
mips_cpu_irq_shutdown
,
.
enable
=
mips_cpu_irq_enable
,
.
disable
=
mips_cpu_irq_disable
,
.
ack
=
mips_cpu_irq_ack
,
.
end
=
mips_cpu_irq_end
,
.
typename
=
"MIPS"
,
.
startup
=
mips_cpu_irq_startup
,
.
shutdown
=
mips_cpu_irq_shutdown
,
.
enable
=
mips_cpu_irq_enable
,
.
disable
=
mips_cpu_irq_disable
,
.
ack
=
mips_cpu_irq_ack
,
.
end
=
mips_cpu_irq_end
,
};
/*
* Basically the same as above but taking care of all the MT stuff
*/
#define unmask_mips_mt_irq unmask_mips_irq
#define mask_mips_mt_irq mask_mips_irq
#define mips_mt_cpu_irq_enable mips_cpu_irq_enable
#define mips_mt_cpu_irq_disable mips_cpu_irq_disable
static
unsigned
int
mips_mt_cpu_irq_startup
(
unsigned
int
irq
)
{
unsigned
int
vpflags
=
dvpe
();
clear_c0_cause
(
0x100
<<
(
irq
-
mips_cpu_irq_base
));
evpe
(
vpflags
);
mips_mt_cpu_irq_enable
(
irq
);
return
0
;
}
#define mips_mt_cpu_irq_shutdown mips_mt_cpu_irq_disable
/*
* While we ack the interrupt interrupts are disabled and thus we don't need
* to deal with concurrency issues. Same for mips_cpu_irq_end.
*/
static
void
mips_mt_cpu_irq_ack
(
unsigned
int
irq
)
{
unsigned
int
vpflags
=
dvpe
();
clear_c0_cause
(
0x100
<<
(
irq
-
mips_cpu_irq_base
));
evpe
(
vpflags
);
mask_mips_mt_irq
(
irq
);
}
#define mips_mt_cpu_irq_end mips_cpu_irq_end
static
hw_irq_controller
mips_mt_cpu_irq_controller
=
{
.
typename
=
"MIPS"
,
.
startup
=
mips_mt_cpu_irq_startup
,
.
shutdown
=
mips_mt_cpu_irq_shutdown
,
.
enable
=
mips_mt_cpu_irq_enable
,
.
disable
=
mips_mt_cpu_irq_disable
,
.
ack
=
mips_mt_cpu_irq_ack
,
.
end
=
mips_mt_cpu_irq_end
,
};
void
__init
mips_cpu_irq_init
(
int
irq_base
)
{
...
...
@@ -115,7 +158,19 @@ void __init mips_cpu_irq_init(int irq_base)
clear_c0_status
(
ST0_IM
);
clear_c0_cause
(
CAUSEF_IP
);
for
(
i
=
irq_base
;
i
<
irq_base
+
8
;
i
++
)
{
/*
* Only MT is using the software interrupts currently, so we just
* leave them uninitialized for other processors.
*/
if
(
cpu_has_mipsmt
)
for
(
i
=
irq_base
;
i
<
irq_base
+
2
;
i
++
)
{
irq_desc
[
i
].
status
=
IRQ_DISABLED
;
irq_desc
[
i
].
action
=
NULL
;
irq_desc
[
i
].
depth
=
1
;
irq_desc
[
i
].
handler
=
&
mips_mt_cpu_irq_controller
;
}
for
(
i
=
irq_base
+
2
;
i
<
irq_base
+
8
;
i
++
)
{
irq_desc
[
i
].
status
=
IRQ_DISABLED
;
irq_desc
[
i
].
action
=
NULL
;
irq_desc
[
i
].
depth
=
1
;
...
...
arch/mips/kernel/traps.c
浏览文件 @
d03d0a57
...
...
@@ -1186,8 +1186,14 @@ void __init per_cpu_trap_init(void)
/* Setting vector spacing enables EI/VI mode */
change_c0_intctl
(
0x3e0
,
VECTORSPACING
);
}
if
(
cpu_has_divec
)
set_c0_cause
(
CAUSEF_IV
);
if
(
cpu_has_divec
)
{
if
(
cpu_has_mipsmt
)
{
unsigned
int
vpflags
=
dvpe
();
set_c0_cause
(
CAUSEF_IV
);
evpe
(
vpflags
);
}
else
set_c0_cause
(
CAUSEF_IV
);
}
cpu_data
[
cpu
].
asid_cache
=
ASID_FIRST_VERSION
;
TLBMISS_HANDLER_SETUP
();
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录