Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
qemu
提交
63bb682a
Q
qemu
项目概览
openeuler
/
qemu
通知
10
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
Q
qemu
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
63bb682a
编写于
6月 15, 2012
作者:
M
malc
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'master' of
git://git.qemu.org/qemu
上级
1417d7e4
8219314b
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
18 addition
and
10 deletion
+18
-10
cpu-exec.c
cpu-exec.c
+12
-5
target-cris/cpu.h
target-cris/cpu.h
+2
-1
target-cris/helper.c
target-cris/helper.c
+2
-2
target-cris/op_helper.c
target-cris/op_helper.c
+2
-2
未找到文件。
cpu-exec.c
浏览文件 @
63bb682a
...
...
@@ -467,11 +467,18 @@ int cpu_exec(CPUArchState *env)
do_interrupt
(
env
);
next_tb
=
0
;
}
if
(
interrupt_request
&
CPU_INTERRUPT_NMI
&&
(
env
->
pregs
[
PR_CCS
]
&
M_FLAG
))
{
env
->
exception_index
=
EXCP_NMI
;
do_interrupt
(
env
);
next_tb
=
0
;
if
(
interrupt_request
&
CPU_INTERRUPT_NMI
)
{
unsigned
int
m_flag_archval
;
if
(
env
->
pregs
[
PR_VR
]
<
32
)
{
m_flag_archval
=
M_FLAG_V10
;
}
else
{
m_flag_archval
=
M_FLAG_V32
;
}
if
((
env
->
pregs
[
PR_CCS
]
&
m_flag_archval
))
{
env
->
exception_index
=
EXCP_NMI
;
do_interrupt
(
env
);
next_tb
=
0
;
}
}
#elif defined(TARGET_M68K)
if
(
interrupt_request
&
CPU_INTERRUPT_HARD
...
...
target-cris/cpu.h
浏览文件 @
63bb682a
...
...
@@ -69,13 +69,14 @@
/* CPU flags. */
#define Q_FLAG 0x80000000
#define M_FLAG 0x40000000
#define M_FLAG
_V32
0x40000000
#define PFIX_FLAG 0x800
/* CRISv10 Only. */
#define F_FLAG_V10 0x400
#define P_FLAG_V10 0x200
#define S_FLAG 0x200
#define R_FLAG 0x100
#define P_FLAG 0x80
#define M_FLAG_V10 0x80
#define U_FLAG 0x40
#define I_FLAG 0x20
#define X_FLAG 0x10
...
...
target-cris/helper.c
浏览文件 @
63bb682a
...
...
@@ -127,7 +127,7 @@ static void do_interruptv10(CPUCRISState *env)
case
EXCP_NMI
:
/* NMI is hardwired to vector zero. */
ex_vec
=
0
;
env
->
pregs
[
PR_CCS
]
&=
~
M_FLAG
;
env
->
pregs
[
PR_CCS
]
&=
~
M_FLAG
_V10
;
env
->
pregs
[
PRV10_BRP
]
=
env
->
pc
;
break
;
...
...
@@ -185,7 +185,7 @@ void do_interrupt(CPUCRISState *env)
case
EXCP_NMI
:
/* NMI is hardwired to vector zero. */
ex_vec
=
0
;
env
->
pregs
[
PR_CCS
]
&=
~
M_FLAG
;
env
->
pregs
[
PR_CCS
]
&=
~
M_FLAG
_V32
;
env
->
pregs
[
PR_NRP
]
=
env
->
pc
;
break
;
...
...
target-cris/op_helper.c
浏览文件 @
63bb682a
...
...
@@ -247,8 +247,8 @@ void helper_rfn(void)
if
(
!
rflag
)
env
->
pregs
[
PR_CCS
]
|=
P_FLAG
;
/* Always set the M flag. */
env
->
pregs
[
PR_CCS
]
|=
M_FLAG
;
/* Always set the M flag. */
env
->
pregs
[
PR_CCS
]
|=
M_FLAG_V32
;
}
uint32_t
helper_lz
(
uint32_t
t0
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录