Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
qemu
提交
a10c64e0
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看板
提交
a10c64e0
编写于
5月 14, 2014
作者:
R
Richard Henderson
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
tcg-s390: Implement direct chaining of TBs
Signed-off-by:
N
Richard Henderson
<
rth@twiddle.net
>
上级
061cdd81
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
12 addition
and
1 deletion
+12
-1
include/exec/exec-all.h
include/exec/exec-all.h
+9
-0
tcg/s390/tcg-target.c
tcg/s390/tcg-target.c
+3
-1
未找到文件。
include/exec/exec-all.h
浏览文件 @
a10c64e0
...
...
@@ -131,6 +131,7 @@ static inline void tlb_flush(CPUState *cpu, int flush_global)
#if defined(__arm__) || defined(_ARCH_PPC) \
|| defined(__x86_64__) || defined(__i386__) \
|| defined(__sparc__) || defined(__aarch64__) \
|| defined(__s390x__) \
|| defined(CONFIG_TCG_INTERPRETER)
#define USE_DIRECT_JUMP
#endif
...
...
@@ -232,6 +233,14 @@ static inline void tb_set_jmp_target1(uintptr_t jmp_addr, uintptr_t addr)
stl_le_p
((
void
*
)
jmp_addr
,
addr
-
(
jmp_addr
+
4
));
/* no need to flush icache explicitly */
}
#elif defined(__s390x__)
static
inline
void
tb_set_jmp_target1
(
uintptr_t
jmp_addr
,
uintptr_t
addr
)
{
/* patch the branch destination */
intptr_t
disp
=
addr
-
(
jmp_addr
-
2
);
stl_be_p
((
void
*
)
jmp_addr
,
disp
/
2
);
/* no need to flush icache explicitly */
}
#elif defined(__aarch64__)
void
aarch64_tb_set_jmp_target
(
uintptr_t
jmp_addr
,
uintptr_t
addr
);
#define tb_set_jmp_target1 aarch64_tb_set_jmp_target
...
...
tcg/s390/tcg-target.c
浏览文件 @
a10c64e0
...
...
@@ -1703,7 +1703,9 @@ static inline void tcg_out_op(TCGContext *s, TCGOpcode opc,
case
INDEX_op_goto_tb
:
if
(
s
->
tb_jmp_offset
)
{
tcg_abort
();
tcg_out16
(
s
,
RIL_BRCL
|
(
S390_CC_ALWAYS
<<
4
));
s
->
tb_jmp_offset
[
args
[
0
]]
=
tcg_current_code_size
(
s
);
s
->
code_ptr
+=
2
;
}
else
{
/* load address stored at s->tb_next + args[0] */
tcg_out_ld_abs
(
s
,
TCG_TYPE_PTR
,
TCG_TMP0
,
s
->
tb_next
+
args
[
0
]);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录