Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
qemu
提交
ba1d0b44
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看板
提交
ba1d0b44
编写于
10月 09, 2017
作者:
R
Richard Henderson
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
target/hppa: Disable gateway page emulation for system mode
Signed-off-by:
N
Richard Henderson
<
richard.henderson@linaro.org
>
上级
fa57e327
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
17 addition
and
10 deletion
+17
-10
target/hppa/translate.c
target/hppa/translate.c
+17
-10
未找到文件。
target/hppa/translate.c
浏览文件 @
ba1d0b44
...
...
@@ -1543,6 +1543,7 @@ static DisasJumpType do_ibranch(DisasContext *ctx, TCGv dest,
return
DISAS_NEXT
;
}
#ifdef CONFIG_USER_ONLY
/* On Linux, page zero is normally marked execute only + gateway.
Therefore normal read or write is supposed to fail, but specific
offsets have kernel code mapped to raise permissions to implement
...
...
@@ -1600,6 +1601,7 @@ static DisasJumpType do_page_zero(DisasContext *ctx)
return
DISAS_NORETURN
;
}
}
#endif
static
DisasJumpType
trans_nop
(
DisasContext
*
ctx
,
uint32_t
insn
,
const
DisasInsn
*
di
)
...
...
@@ -3787,10 +3789,13 @@ static void hppa_tr_translate_insn(DisasContextBase *dcbase, CPUState *cs)
int
i
,
n
;
/* Execute one insn. */
#ifdef CONFIG_USER_ONLY
if
(
ctx
->
iaoq_f
<
TARGET_PAGE_SIZE
)
{
ret
=
do_page_zero
(
ctx
);
assert
(
ret
!=
DISAS_NEXT
);
}
else
{
}
else
#endif
{
/* Always fetch the insn, even if nullified, so that we check
the page permissions for execute. */
uint32_t
insn
=
cpu_ldl_code
(
env
,
ctx
->
iaoq_f
);
...
...
@@ -3885,25 +3890,27 @@ static void hppa_tr_tb_stop(DisasContextBase *dcbase, CPUState *cs)
static
void
hppa_tr_disas_log
(
const
DisasContextBase
*
dcbase
,
CPUState
*
cs
)
{
TranslationBlock
*
tb
=
dcbase
->
tb
;
target_ulong
pc
=
tb
->
pc
;
switch
(
tb
->
pc
)
{
#ifdef CONFIG_USER_ONLY
switch
(
pc
)
{
case
0x00
:
qemu_log
(
"IN:
\n
0x00000000: (null)
\n
"
);
break
;
return
;
case
0xb0
:
qemu_log
(
"IN:
\n
0x000000b0: light-weight-syscall
\n
"
);
break
;
return
;
case
0xe0
:
qemu_log
(
"IN:
\n
0x000000e0: set-thread-pointer-syscall
\n
"
);
break
;
return
;
case
0x100
:
qemu_log
(
"IN:
\n
0x00000100: syscall
\n
"
);
break
;
default:
qemu_log
(
"IN: %s
\n
"
,
lookup_symbol
(
tb
->
pc
));
log_target_disas
(
cs
,
tb
->
pc
,
tb
->
size
);
break
;
return
;
}
#endif
qemu_log
(
"IN: %s
\n
"
,
lookup_symbol
(
pc
));
log_target_disas
(
cs
,
pc
,
tb
->
size
);
}
static
const
TranslatorOps
hppa_tr_ops
=
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录