Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
qemu
提交
d4b0d468
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看板
提交
d4b0d468
编写于
5月 10, 2009
作者:
B
Blue Swirl
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Convert sub
Signed-off-by:
N
Blue Swirl
<
blauwirbel@gmail.com
>
上级
38482a77
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
83 addition
and
37 deletion
+83
-37
target-sparc/op_helper.c
target-sparc/op_helper.c
+72
-0
target-sparc/translate.c
target-sparc/translate.c
+11
-37
未找到文件。
target-sparc/op_helper.c
浏览文件 @
d4b0d468
...
...
@@ -902,6 +902,76 @@ static uint32_t compute_C_addx_xcc(void)
}
#endif
static
inline
uint32_t
get_C_sub_icc
(
target_ulong
src1
,
target_ulong
src2
)
{
uint32_t
ret
=
0
;
if
((
src1
&
0xffffffffULL
)
<
(
src2
&
0xffffffffULL
))
ret
|=
PSR_CARRY
;
return
ret
;
}
static
inline
uint32_t
get_V_sub_icc
(
target_ulong
dst
,
target_ulong
src1
,
target_ulong
src2
)
{
uint32_t
ret
=
0
;
if
(((
src1
^
src2
)
&
(
src1
^
dst
))
&
(
1ULL
<<
31
))
ret
|=
PSR_OVF
;
return
ret
;
}
static
uint32_t
compute_all_sub
(
void
)
{
uint32_t
ret
;
ret
=
get_NZ_icc
(
CC_DST
);
ret
|=
get_C_sub_icc
(
CC_SRC
,
CC_SRC2
);
ret
|=
get_V_sub_icc
(
CC_DST
,
CC_SRC
,
CC_SRC2
);
return
ret
;
}
static
uint32_t
compute_C_sub
(
void
)
{
return
get_C_sub_icc
(
CC_SRC
,
CC_SRC2
);
}
#ifdef TARGET_SPARC64
static
inline
uint32_t
get_C_sub_xcc
(
target_ulong
src1
,
target_ulong
src2
)
{
uint32_t
ret
=
0
;
if
(
src1
<
src2
)
ret
|=
PSR_CARRY
;
return
ret
;
}
static
inline
uint32_t
get_V_sub_xcc
(
target_ulong
dst
,
target_ulong
src1
,
target_ulong
src2
)
{
uint32_t
ret
=
0
;
if
(((
src1
^
src2
)
&
(
src1
^
dst
))
&
(
1ULL
<<
63
))
ret
|=
PSR_OVF
;
return
ret
;
}
static
uint32_t
compute_all_sub_xcc
(
void
)
{
uint32_t
ret
;
ret
=
get_NZ_xcc
(
CC_DST
);
ret
|=
get_C_sub_xcc
(
CC_SRC
,
CC_SRC2
);
ret
|=
get_V_sub_xcc
(
CC_DST
,
CC_SRC
,
CC_SRC2
);
return
ret
;
}
static
uint32_t
compute_C_sub_xcc
(
void
)
{
return
get_C_sub_xcc
(
CC_SRC
,
CC_SRC2
);
}
#endif
static
uint32_t
compute_all_logic
(
void
)
{
return
get_NZ_icc
(
CC_DST
);
...
...
@@ -929,6 +999,7 @@ static const CCTable icc_table[CC_OP_NB] = {
[
CC_OP_FLAGS
]
=
{
compute_all_flags
,
compute_C_flags
},
[
CC_OP_ADD
]
=
{
compute_all_add
,
compute_C_add
},
[
CC_OP_ADDX
]
=
{
compute_all_addx
,
compute_C_addx
},
[
CC_OP_SUB
]
=
{
compute_all_sub
,
compute_C_sub
},
[
CC_OP_LOGIC
]
=
{
compute_all_logic
,
compute_C_logic
},
};
...
...
@@ -938,6 +1009,7 @@ static const CCTable xcc_table[CC_OP_NB] = {
[
CC_OP_FLAGS
]
=
{
compute_all_flags_xcc
,
compute_C_flags_xcc
},
[
CC_OP_ADD
]
=
{
compute_all_add_xcc
,
compute_C_add_xcc
},
[
CC_OP_ADDX
]
=
{
compute_all_addx_xcc
,
compute_C_addx_xcc
},
[
CC_OP_SUB
]
=
{
compute_all_sub_xcc
,
compute_C_sub_xcc
},
[
CC_OP_LOGIC
]
=
{
compute_all_logic_xcc
,
compute_C_logic
},
};
#endif
...
...
target-sparc/translate.c
浏览文件 @
d4b0d468
...
...
@@ -432,18 +432,6 @@ static inline void gen_cc_V_tag(TCGv src1, TCGv src2)
gen_set_label
(
l1
);
}
static
inline
void
gen_op_logic_cc
(
TCGv
dst
)
{
tcg_gen_mov_tl
(
cpu_cc_dst
,
dst
);
gen_cc_clear_icc
();
gen_cc_NZ_icc
(
cpu_cc_dst
);
#ifdef TARGET_SPARC64
gen_cc_clear_xcc
();
gen_cc_NZ_xcc
(
cpu_cc_dst
);
#endif
}
static
inline
void
gen_tag_tv
(
TCGv
src1
,
TCGv
src2
)
{
int
l1
;
...
...
@@ -623,32 +611,20 @@ static inline void gen_sub_tv(TCGv dst, TCGv src1, TCGv src2)
tcg_temp_free
(
r_temp
);
}
static
inline
void
gen_op_sub_cc2
(
TCGv
dst
)
{
gen_cc_clear_icc
();
gen_cc_NZ_icc
(
cpu_cc_dst
);
gen_cc_C_sub_icc
(
cpu_cc_src
,
cpu_cc_src2
);
gen_cc_V_sub_icc
(
cpu_cc_dst
,
cpu_cc_src
,
cpu_cc_src2
);
#ifdef TARGET_SPARC64
gen_cc_clear_xcc
();
gen_cc_NZ_xcc
(
cpu_cc_dst
);
gen_cc_C_sub_xcc
(
cpu_cc_src
,
cpu_cc_src2
);
gen_cc_V_sub_xcc
(
cpu_cc_dst
,
cpu_cc_src
,
cpu_cc_src2
);
#endif
tcg_gen_mov_tl
(
dst
,
cpu_cc_dst
);
}
static
inline
void
gen_op_subi_cc
(
TCGv
dst
,
TCGv
src1
,
target_long
src2
)
static
inline
void
gen_op_subi_cc
(
TCGv
dst
,
TCGv
src1
,
target_long
src2
,
DisasContext
*
dc
)
{
tcg_gen_mov_tl
(
cpu_cc_src
,
src1
);
tcg_gen_movi_tl
(
cpu_cc_src2
,
src2
);
if
(
src2
==
0
)
{
tcg_gen_mov_tl
(
dst
,
src1
);
gen_op_logic_cc
(
dst
);
tcg_gen_mov_tl
(
cpu_cc_dst
,
src1
);
tcg_gen_movi_i32
(
cpu_cc_op
,
CC_OP_LOGIC
);
dc
->
cc_op
=
CC_OP_LOGIC
;
}
else
{
tcg_gen_subi_tl
(
cpu_cc_dst
,
cpu_cc_src
,
src2
);
gen_op_sub_cc2
(
dst
);
tcg_gen_movi_i32
(
cpu_cc_op
,
CC_OP_SUB
);
dc
->
cc_op
=
CC_OP_SUB
;
}
tcg_gen_mov_tl
(
dst
,
cpu_cc_dst
);
}
static
inline
void
gen_op_sub_cc
(
TCGv
dst
,
TCGv
src1
,
TCGv
src2
)
...
...
@@ -656,7 +632,7 @@ static inline void gen_op_sub_cc(TCGv dst, TCGv src1, TCGv src2)
tcg_gen_mov_tl
(
cpu_cc_src
,
src1
);
tcg_gen_mov_tl
(
cpu_cc_src2
,
src2
);
tcg_gen_sub_tl
(
cpu_cc_dst
,
cpu_cc_src
,
cpu_cc_src2
);
gen_op_sub_cc2
(
dst
);
tcg_gen_mov_tl
(
dst
,
cpu_cc_
dst
);
}
static
inline
void
gen_op_subx_cc2
(
TCGv
dst
)
...
...
@@ -3171,17 +3147,15 @@ static void disas_sparc_insn(DisasContext * dc)
if
(
IS_IMM
)
{
simm
=
GET_FIELDs
(
insn
,
19
,
31
);
if
(
xop
&
0x10
)
{
gen_op_subi_cc
(
cpu_dst
,
cpu_src1
,
simm
);
tcg_gen_movi_i32
(
cpu_cc_op
,
CC_OP_FLAGS
);
dc
->
cc_op
=
CC_OP_FLAGS
;
gen_op_subi_cc
(
cpu_dst
,
cpu_src1
,
simm
,
dc
);
}
else
{
tcg_gen_subi_tl
(
cpu_dst
,
cpu_src1
,
simm
);
}
}
else
{
if
(
xop
&
0x10
)
{
gen_op_sub_cc
(
cpu_dst
,
cpu_src1
,
cpu_src2
);
tcg_gen_movi_i32
(
cpu_cc_op
,
CC_OP_
FLAGS
);
dc
->
cc_op
=
CC_OP_
FLAGS
;
tcg_gen_movi_i32
(
cpu_cc_op
,
CC_OP_
SUB
);
dc
->
cc_op
=
CC_OP_
SUB
;
}
else
{
tcg_gen_sub_tl
(
cpu_dst
,
cpu_src1
,
cpu_src2
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录