Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
qemu
提交
b8dd88b8
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看板
提交
b8dd88b8
编写于
3月 23, 2014
作者:
R
Richard Henderson
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
tcg-s390: Integrate endianness into TCGMemOp
Signed-off-by:
N
Richard Henderson
<
rth@twiddle.net
>
上级
a5a04f28
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
60 addition
and
64 deletion
+60
-64
tcg/s390/tcg-target.c
tcg/s390/tcg-target.c
+60
-64
未找到文件。
tcg/s390/tcg-target.c
浏览文件 @
b8dd88b8
...
@@ -1273,11 +1273,6 @@ static void tcg_out_call(TCGContext *s, tcg_insn_unit *dest)
...
@@ -1273,11 +1273,6 @@ static void tcg_out_call(TCGContext *s, tcg_insn_unit *dest)
static
void
tcg_out_qemu_ld_direct
(
TCGContext
*
s
,
TCGMemOp
opc
,
TCGReg
data
,
static
void
tcg_out_qemu_ld_direct
(
TCGContext
*
s
,
TCGMemOp
opc
,
TCGReg
data
,
TCGReg
base
,
TCGReg
index
,
int
disp
)
TCGReg
base
,
TCGReg
index
,
int
disp
)
{
{
#ifdef TARGET_WORDS_BIGENDIAN
const
int
bswap
=
0
;
#else
const
int
bswap
=
1
;
#endif
switch
(
opc
)
{
switch
(
opc
)
{
case
MO_UB
:
case
MO_UB
:
tcg_out_insn
(
s
,
RXY
,
LLGC
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RXY
,
LLGC
,
data
,
base
,
index
,
disp
);
...
@@ -1285,49 +1280,50 @@ static void tcg_out_qemu_ld_direct(TCGContext *s, TCGMemOp opc, TCGReg data,
...
@@ -1285,49 +1280,50 @@ static void tcg_out_qemu_ld_direct(TCGContext *s, TCGMemOp opc, TCGReg data,
case
MO_SB
:
case
MO_SB
:
tcg_out_insn
(
s
,
RXY
,
LGB
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RXY
,
LGB
,
data
,
base
,
index
,
disp
);
break
;
break
;
case
MO_UW
:
if
(
bswap
)
{
case
MO_UW
|
MO_BSWAP
:
/* swapped unsigned halfword load with upper bits zeroed */
/* swapped unsigned halfword load with upper bits zeroed */
tcg_out_insn
(
s
,
RXY
,
LRVH
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RXY
,
LRVH
,
data
,
base
,
index
,
disp
);
tgen_ext16u
(
s
,
TCG_TYPE_I64
,
data
,
data
);
tgen_ext16u
(
s
,
TCG_TYPE_I64
,
data
,
data
);
}
else
{
break
;
case
MO_UW
:
tcg_out_insn
(
s
,
RXY
,
LLGH
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RXY
,
LLGH
,
data
,
base
,
index
,
disp
);
}
break
;
break
;
case
MO_SW
:
if
(
bswap
)
{
case
MO_SW
|
MO_BSWAP
:
/* swapped sign-extended halfword load */
/* swapped sign-extended halfword load */
tcg_out_insn
(
s
,
RXY
,
LRVH
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RXY
,
LRVH
,
data
,
base
,
index
,
disp
);
tgen_ext16s
(
s
,
TCG_TYPE_I64
,
data
,
data
);
tgen_ext16s
(
s
,
TCG_TYPE_I64
,
data
,
data
);
}
else
{
break
;
case
MO_SW
:
tcg_out_insn
(
s
,
RXY
,
LGH
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RXY
,
LGH
,
data
,
base
,
index
,
disp
);
}
break
;
break
;
case
MO_UL
:
if
(
bswap
)
{
case
MO_UL
|
MO_BSWAP
:
/* swapped unsigned int load with upper bits zeroed */
/* swapped unsigned int load with upper bits zeroed */
tcg_out_insn
(
s
,
RXY
,
LRV
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RXY
,
LRV
,
data
,
base
,
index
,
disp
);
tgen_ext32u
(
s
,
data
,
data
);
tgen_ext32u
(
s
,
data
,
data
);
}
else
{
break
;
case
MO_UL
:
tcg_out_insn
(
s
,
RXY
,
LLGF
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RXY
,
LLGF
,
data
,
base
,
index
,
disp
);
}
break
;
break
;
case
MO_SL
:
if
(
bswap
)
{
case
MO_SL
|
MO_BSWAP
:
/* swapped sign-extended int load */
/* swapped sign-extended int load */
tcg_out_insn
(
s
,
RXY
,
LRV
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RXY
,
LRV
,
data
,
base
,
index
,
disp
);
tgen_ext32s
(
s
,
data
,
data
);
tgen_ext32s
(
s
,
data
,
data
);
}
else
{
break
;
case
MO_SL
:
tcg_out_insn
(
s
,
RXY
,
LGF
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RXY
,
LGF
,
data
,
base
,
index
,
disp
);
}
break
;
break
;
case
MO_Q
:
if
(
bswap
)
{
case
MO_Q
|
MO_BSWAP
:
tcg_out_insn
(
s
,
RXY
,
LRVG
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RXY
,
LRVG
,
data
,
base
,
index
,
disp
);
}
else
{
break
;
case
MO_Q
:
tcg_out_insn
(
s
,
RXY
,
LG
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RXY
,
LG
,
data
,
base
,
index
,
disp
);
}
break
;
break
;
default:
default:
tcg_abort
();
tcg_abort
();
}
}
...
@@ -1336,11 +1332,6 @@ static void tcg_out_qemu_ld_direct(TCGContext *s, TCGMemOp opc, TCGReg data,
...
@@ -1336,11 +1332,6 @@ static void tcg_out_qemu_ld_direct(TCGContext *s, TCGMemOp opc, TCGReg data,
static
void
tcg_out_qemu_st_direct
(
TCGContext
*
s
,
TCGMemOp
opc
,
TCGReg
data
,
static
void
tcg_out_qemu_st_direct
(
TCGContext
*
s
,
TCGMemOp
opc
,
TCGReg
data
,
TCGReg
base
,
TCGReg
index
,
int
disp
)
TCGReg
base
,
TCGReg
index
,
int
disp
)
{
{
#ifdef TARGET_WORDS_BIGENDIAN
const
int
bswap
=
0
;
#else
const
int
bswap
=
1
;
#endif
switch
(
opc
)
{
switch
(
opc
)
{
case
MO_UB
:
case
MO_UB
:
if
(
disp
>=
0
&&
disp
<
0x1000
)
{
if
(
disp
>=
0
&&
disp
<
0x1000
)
{
...
@@ -1349,31 +1340,36 @@ static void tcg_out_qemu_st_direct(TCGContext *s, TCGMemOp opc, TCGReg data,
...
@@ -1349,31 +1340,36 @@ static void tcg_out_qemu_st_direct(TCGContext *s, TCGMemOp opc, TCGReg data,
tcg_out_insn
(
s
,
RXY
,
STCY
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RXY
,
STCY
,
data
,
base
,
index
,
disp
);
}
}
break
;
break
;
case
MO_UW
:
if
(
bswap
)
{
case
MO_UW
|
MO_BSWAP
:
tcg_out_insn
(
s
,
RXY
,
STRVH
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RXY
,
STRVH
,
data
,
base
,
index
,
disp
);
}
else
if
(
disp
>=
0
&&
disp
<
0x1000
)
{
break
;
case
MO_UW
:
if
(
disp
>=
0
&&
disp
<
0x1000
)
{
tcg_out_insn
(
s
,
RX
,
STH
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RX
,
STH
,
data
,
base
,
index
,
disp
);
}
else
{
}
else
{
tcg_out_insn
(
s
,
RXY
,
STHY
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RXY
,
STHY
,
data
,
base
,
index
,
disp
);
}
}
break
;
break
;
case
MO_UL
:
if
(
bswap
)
{
case
MO_UL
|
MO_BSWAP
:
tcg_out_insn
(
s
,
RXY
,
STRV
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RXY
,
STRV
,
data
,
base
,
index
,
disp
);
}
else
if
(
disp
>=
0
&&
disp
<
0x1000
)
{
break
;
case
MO_UL
:
if
(
disp
>=
0
&&
disp
<
0x1000
)
{
tcg_out_insn
(
s
,
RX
,
ST
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RX
,
ST
,
data
,
base
,
index
,
disp
);
}
else
{
}
else
{
tcg_out_insn
(
s
,
RXY
,
STY
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RXY
,
STY
,
data
,
base
,
index
,
disp
);
}
}
break
;
break
;
case
MO_Q
:
if
(
bswap
)
{
case
MO_Q
|
MO_BSWAP
:
tcg_out_insn
(
s
,
RXY
,
STRVG
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RXY
,
STRVG
,
data
,
base
,
index
,
disp
);
}
else
{
break
;
case
MO_Q
:
tcg_out_insn
(
s
,
RXY
,
STG
,
data
,
base
,
index
,
disp
);
tcg_out_insn
(
s
,
RXY
,
STG
,
data
,
base
,
index
,
disp
);
}
break
;
break
;
default:
default:
tcg_abort
();
tcg_abort
();
}
}
...
@@ -1457,7 +1453,7 @@ static TCGReg tcg_prepare_qemu_ldst(TCGContext* s, TCGReg data_reg,
...
@@ -1457,7 +1453,7 @@ static TCGReg tcg_prepare_qemu_ldst(TCGContext* s, TCGReg data_reg,
tcg_out_call
(
s
,
qemu_ld_helpers
[
s_bits
]);
tcg_out_call
(
s
,
qemu_ld_helpers
[
s_bits
]);
/* sign extension */
/* sign extension */
switch
(
opc
)
{
switch
(
opc
&
MO_SSIZE
)
{
case
MO_SB
:
case
MO_SB
:
tgen_ext8s
(
s
,
TCG_TYPE_I64
,
data_reg
,
TCG_REG_R2
);
tgen_ext8s
(
s
,
TCG_TYPE_I64
,
data_reg
,
TCG_REG_R2
);
break
;
break
;
...
@@ -1808,30 +1804,30 @@ static inline void tcg_out_op(TCGContext *s, TCGOpcode opc,
...
@@ -1808,30 +1804,30 @@ static inline void tcg_out_op(TCGContext *s, TCGOpcode opc,
tcg_out_qemu_ld
(
s
,
args
,
MO_SB
);
tcg_out_qemu_ld
(
s
,
args
,
MO_SB
);
break
;
break
;
case
INDEX_op_qemu_ld16u
:
case
INDEX_op_qemu_ld16u
:
tcg_out_qemu_ld
(
s
,
args
,
MO_UW
);
tcg_out_qemu_ld
(
s
,
args
,
MO_
TE
UW
);
break
;
break
;
case
INDEX_op_qemu_ld16s
:
case
INDEX_op_qemu_ld16s
:
tcg_out_qemu_ld
(
s
,
args
,
MO_SW
);
tcg_out_qemu_ld
(
s
,
args
,
MO_
TE
SW
);
break
;
break
;
case
INDEX_op_qemu_ld32
:
case
INDEX_op_qemu_ld32
:
/* ??? Technically we can use a non-extending instruction. */
/* ??? Technically we can use a non-extending instruction. */
tcg_out_qemu_ld
(
s
,
args
,
MO_UL
);
tcg_out_qemu_ld
(
s
,
args
,
MO_
TE
UL
);
break
;
break
;
case
INDEX_op_qemu_ld64
:
case
INDEX_op_qemu_ld64
:
tcg_out_qemu_ld
(
s
,
args
,
MO_Q
);
tcg_out_qemu_ld
(
s
,
args
,
MO_
TE
Q
);
break
;
break
;
case
INDEX_op_qemu_st8
:
case
INDEX_op_qemu_st8
:
tcg_out_qemu_st
(
s
,
args
,
MO_UB
);
tcg_out_qemu_st
(
s
,
args
,
MO_UB
);
break
;
break
;
case
INDEX_op_qemu_st16
:
case
INDEX_op_qemu_st16
:
tcg_out_qemu_st
(
s
,
args
,
MO_UW
);
tcg_out_qemu_st
(
s
,
args
,
MO_
TE
UW
);
break
;
break
;
case
INDEX_op_qemu_st32
:
case
INDEX_op_qemu_st32
:
tcg_out_qemu_st
(
s
,
args
,
MO_UL
);
tcg_out_qemu_st
(
s
,
args
,
MO_
TE
UL
);
break
;
break
;
case
INDEX_op_qemu_st64
:
case
INDEX_op_qemu_st64
:
tcg_out_qemu_st
(
s
,
args
,
MO_Q
);
tcg_out_qemu_st
(
s
,
args
,
MO_
TE
Q
);
break
;
break
;
case
INDEX_op_ld16s_i64
:
case
INDEX_op_ld16s_i64
:
...
@@ -2028,10 +2024,10 @@ static inline void tcg_out_op(TCGContext *s, TCGOpcode opc,
...
@@ -2028,10 +2024,10 @@ static inline void tcg_out_op(TCGContext *s, TCGOpcode opc,
break
;
break
;
case
INDEX_op_qemu_ld32u
:
case
INDEX_op_qemu_ld32u
:
tcg_out_qemu_ld
(
s
,
args
,
MO_UL
);
tcg_out_qemu_ld
(
s
,
args
,
MO_
TE
UL
);
break
;
break
;
case
INDEX_op_qemu_ld32s
:
case
INDEX_op_qemu_ld32s
:
tcg_out_qemu_ld
(
s
,
args
,
MO_SL
);
tcg_out_qemu_ld
(
s
,
args
,
MO_
TE
SL
);
break
;
break
;
OP_32_64
(
deposit
)
:
OP_32_64
(
deposit
)
:
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录