Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
qemu
提交
5bbd2cae
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看板
提交
5bbd2cae
编写于
9月 21, 2012
作者:
R
Richard Henderson
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
tcg-sparc: Fix and enable direct TB chaining.
Signed-off-by:
N
Richard Henderson
<
rth@twiddle.net
>
上级
26adfb75
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
24 addition
and
6 deletion
+24
-6
exec-all.h
exec-all.h
+6
-3
tcg/sparc/tcg-target.c
tcg/sparc/tcg-target.c
+18
-3
未找到文件。
exec-all.h
浏览文件 @
5bbd2cae
...
...
@@ -132,9 +132,10 @@ static inline void tlb_flush(CPUArchState *env, int flush_global)
#define CODE_GEN_AVG_BLOCK_SIZE 64
#endif
#if defined(_ARCH_PPC) || defined(__x86_64__) || defined(__arm__) || defined(__i386__)
#define USE_DIRECT_JUMP
#elif defined(CONFIG_TCG_INTERPRETER)
#if defined(__arm__) || defined(_ARCH_PPC) \
|| defined(__x86_64__) || defined(__i386__) \
|| defined(__sparc__) \
|| defined(CONFIG_TCG_INTERPRETER)
#define USE_DIRECT_JUMP
#endif
...
...
@@ -244,6 +245,8 @@ static inline void tb_set_jmp_target1(uintptr_t jmp_addr, uintptr_t addr)
__asm
__volatile__
(
"swi 0x9f0002"
:
:
"r"
(
_beg
),
"r"
(
_end
),
"r"
(
_flg
));
#endif
}
#elif defined(__sparc__)
void
tb_set_jmp_target1
(
uintptr_t
jmp_addr
,
uintptr_t
addr
);
#else
#error tb_set_jmp_target1 is missing
#endif
...
...
tcg/sparc/tcg-target.c
浏览文件 @
5bbd2cae
...
...
@@ -1072,10 +1072,10 @@ static inline void tcg_out_op(TCGContext *s, TCGOpcode opc, const TCGArg *args,
case
INDEX_op_goto_tb
:
if
(
s
->
tb_jmp_offset
)
{
/* direct jump method */
tcg_out_sethi
(
s
,
TCG_REG_T1
,
args
[
0
]
&
0xffffe000
);
tcg_out32
(
s
,
JMPL
|
INSN_RD
(
TCG_REG_G0
)
|
INSN_RS1
(
TCG_REG_T1
)
|
INSN_IMM13
((
args
[
0
]
&
0x1fff
)));
uint32_t
old_insn
=
*
(
uint32_t
*
)
s
->
code_ptr
;
s
->
tb_jmp_offset
[
args
[
0
]]
=
s
->
code_ptr
-
s
->
code_buf
;
/* Make sure to preserve links during retranslation. */
tcg_out32
(
s
,
CALL
|
(
old_insn
&
~
INSN_OP
(
-
1
)));
}
else
{
/* indirect jump method */
tcg_out_ld_ptr
(
s
,
TCG_REG_T1
,
...
...
@@ -1595,3 +1595,18 @@ void tcg_register_jit(void *buf, size_t buf_size)
tcg_register_jit_int
(
buf
,
buf_size
,
&
debug_frame
,
sizeof
(
debug_frame
));
}
void
tb_set_jmp_target1
(
uintptr_t
jmp_addr
,
uintptr_t
addr
)
{
uint32_t
*
ptr
=
(
uint32_t
*
)
jmp_addr
;
tcg_target_long
disp
=
(
tcg_target_long
)(
addr
-
jmp_addr
)
>>
2
;
/* We can reach the entire address space for 32-bit. For 64-bit
the code_gen_buffer can't be larger than 2GB. */
if
(
TCG_TARGET_REG_BITS
==
64
&&
!
check_fit_tl
(
disp
,
30
))
{
tcg_abort
();
}
*
ptr
=
CALL
|
(
disp
&
0x3fffffff
);
flush_icache_range
(
jmp_addr
,
jmp_addr
+
4
);
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录