mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-01-20 21:41:04 +00:00
tcg: Expand TempOptInfo to 64-bits
This propagates the extended value of TCGTemp.val that we did before. In addition, it will be required for vector constants. Backports 54795544e4cfb2fa198f7ca244b5ea9eaad322d4
This commit is contained in:
parent
e84b88344a
commit
6100deaffd
|
@ -168,11 +168,11 @@ static bool args_are_copies(TCGArg arg1, TCGArg arg2)
|
||||||
return ts_are_copies(arg_temp(arg1), arg_temp(arg2));
|
return ts_are_copies(arg_temp(arg1), arg_temp(arg2));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void tcg_opt_gen_movi(TCGContext *s, TCGOp *op, TCGArg dst, TCGArg val)
|
static void tcg_opt_gen_movi(TCGContext *s, TCGOp *op, TCGArg dst, uint64_t val)
|
||||||
{
|
{
|
||||||
const TCGOpDef *def;
|
const TCGOpDef *def;
|
||||||
TCGOpcode new_op;
|
TCGOpcode new_op;
|
||||||
tcg_target_ulong mask;
|
uint64_t mask;
|
||||||
TempOptInfo *di = arg_info(dst);
|
TempOptInfo *di = arg_info(dst);
|
||||||
|
|
||||||
def = &s->tcg_op_defs[op->opc];
|
def = &s->tcg_op_defs[op->opc];
|
||||||
|
@ -207,7 +207,7 @@ static void tcg_opt_gen_mov(TCGContext *s, TCGOp *op, TCGArg dst, TCGArg src)
|
||||||
const TCGOpDef *def;
|
const TCGOpDef *def;
|
||||||
TempOptInfo *di;
|
TempOptInfo *di;
|
||||||
TempOptInfo *si;
|
TempOptInfo *si;
|
||||||
tcg_target_ulong mask;
|
uint64_t mask;
|
||||||
TCGOpcode new_op;
|
TCGOpcode new_op;
|
||||||
|
|
||||||
if (ts_are_copies(dst_ts, src_ts)) {
|
if (ts_are_copies(dst_ts, src_ts)) {
|
||||||
|
@ -251,7 +251,7 @@ static void tcg_opt_gen_mov(TCGContext *s, TCGOp *op, TCGArg dst, TCGArg src)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static TCGArg do_constant_folding_2(TCGOpcode op, TCGArg x, TCGArg y)
|
static uint64_t do_constant_folding_2(TCGOpcode op, uint64_t x, uint64_t y)
|
||||||
{
|
{
|
||||||
uint64_t l64, h64;
|
uint64_t l64, h64;
|
||||||
|
|
||||||
|
@ -414,10 +414,10 @@ static TCGArg do_constant_folding_2(TCGOpcode op, TCGArg x, TCGArg y)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static TCGArg do_constant_folding(TCGContext *s, TCGOpcode op, TCGArg x, TCGArg y)
|
static uint64_t do_constant_folding(TCGContext *s, TCGOpcode op, uint64_t x, uint64_t y)
|
||||||
{
|
{
|
||||||
const TCGOpDef *def = &s->tcg_op_defs[op];
|
const TCGOpDef *def = &s->tcg_op_defs[op];
|
||||||
TCGArg res = do_constant_folding_2(op, x, y);
|
uint64_t res = do_constant_folding_2(op, x, y);
|
||||||
if (!(def->flags & TCG_OPF_64BIT)) {
|
if (!(def->flags & TCG_OPF_64BIT)) {
|
||||||
res = (int32_t)res;
|
res = (int32_t)res;
|
||||||
}
|
}
|
||||||
|
@ -505,8 +505,9 @@ static bool do_constant_folding_cond_eq(TCGCond c)
|
||||||
static TCGArg do_constant_folding_cond(TCGContext *s, TCGOpcode op, TCGArg x,
|
static TCGArg do_constant_folding_cond(TCGContext *s, TCGOpcode op, TCGArg x,
|
||||||
TCGArg y, TCGCond c)
|
TCGArg y, TCGCond c)
|
||||||
{
|
{
|
||||||
tcg_target_ulong xv = arg_info(x)->val;
|
uint64_t xv = arg_info(x)->val;
|
||||||
tcg_target_ulong yv = arg_info(y)->val;
|
uint64_t yv = arg_info(y)->val;
|
||||||
|
|
||||||
if (arg_is_const(x) && arg_is_const(y)) {
|
if (arg_is_const(x) && arg_is_const(y)) {
|
||||||
const TCGOpDef *def = &s->tcg_op_defs[op];
|
const TCGOpDef *def = &s->tcg_op_defs[op];
|
||||||
tcg_debug_assert(!(def->flags & TCG_OPF_VECTOR));
|
tcg_debug_assert(!(def->flags & TCG_OPF_VECTOR));
|
||||||
|
@ -614,9 +615,8 @@ void tcg_optimize(TCGContext *s)
|
||||||
reset_all_temps(s, nb_temps);
|
reset_all_temps(s, nb_temps);
|
||||||
|
|
||||||
QTAILQ_FOREACH_SAFE(op, &s->ops, link, op_next) {
|
QTAILQ_FOREACH_SAFE(op, &s->ops, link, op_next) {
|
||||||
tcg_target_ulong mask, partmask, affected;
|
uint64_t mask, partmask, affected, tmp;
|
||||||
int nb_oargs, nb_iargs, i;
|
int nb_oargs, nb_iargs, i;
|
||||||
TCGArg tmp;
|
|
||||||
TCGOpcode opc = op->opc;
|
TCGOpcode opc = op->opc;
|
||||||
const TCGOpDef *def = &s->tcg_op_defs[opc];
|
const TCGOpDef *def = &s->tcg_op_defs[opc];
|
||||||
|
|
||||||
|
@ -1226,14 +1226,15 @@ void tcg_optimize(TCGContext *s)
|
||||||
|
|
||||||
CASE_OP_32_64(extract2):
|
CASE_OP_32_64(extract2):
|
||||||
if (arg_is_const(op->args[1]) && arg_is_const(op->args[2])) {
|
if (arg_is_const(op->args[1]) && arg_is_const(op->args[2])) {
|
||||||
TCGArg v1 = arg_info(op->args[1])->val;
|
uint64_t v1 = arg_info(op->args[1])->val;
|
||||||
TCGArg v2 = arg_info(op->args[2])->val;
|
uint64_t v2 = arg_info(op->args[2])->val;
|
||||||
|
int shr = op->args[3];
|
||||||
|
|
||||||
if (opc == INDEX_op_extract2_i64) {
|
if (opc == INDEX_op_extract2_i64) {
|
||||||
tmp = (v1 >> op->args[3]) | (v2 << (64 - op->args[3]));
|
tmp = (v1 >> shr) | (v2 << (64 - shr));
|
||||||
} else {
|
} else {
|
||||||
tmp = (int32_t)(((uint32_t)v1 >> op->args[3]) |
|
tmp = (int32_t)(((uint32_t)v1 >> shr) |
|
||||||
((uint32_t)v2 << (32 - op->args[3])));
|
((uint32_t)v2 << (32 - shr)));
|
||||||
}
|
}
|
||||||
tcg_opt_gen_movi(s, op, op->args[0], tmp);
|
tcg_opt_gen_movi(s, op, op->args[0], tmp);
|
||||||
break;
|
break;
|
||||||
|
@ -1272,9 +1273,10 @@ void tcg_optimize(TCGContext *s)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (arg_is_const(op->args[3]) && arg_is_const(op->args[4])) {
|
if (arg_is_const(op->args[3]) && arg_is_const(op->args[4])) {
|
||||||
tcg_target_ulong tv = arg_info(op->args[3])->val;
|
uint64_t tv = arg_info(op->args[3])->val;
|
||||||
tcg_target_ulong fv = arg_info(op->args[4])->val;
|
uint64_t fv = arg_info(op->args[4])->val;
|
||||||
TCGCond cond = op->args[5];
|
TCGCond cond = op->args[5];
|
||||||
|
|
||||||
if (fv == 1 && tv == 0) {
|
if (fv == 1 && tv == 0) {
|
||||||
cond = tcg_invert_cond(cond);
|
cond = tcg_invert_cond(cond);
|
||||||
} else if (!(tv == 1 && fv == 0)) {
|
} else if (!(tv == 1 && fv == 0)) {
|
||||||
|
|
|
@ -667,8 +667,8 @@ typedef struct TempOptInfo {
|
||||||
bool is_const;
|
bool is_const;
|
||||||
TCGTemp *prev_copy;
|
TCGTemp *prev_copy;
|
||||||
TCGTemp *next_copy;
|
TCGTemp *next_copy;
|
||||||
tcg_target_ulong val;
|
uint64_t val;
|
||||||
tcg_target_ulong mask;
|
uint64_t mask;
|
||||||
} TempOptInfo;
|
} TempOptInfo;
|
||||||
|
|
||||||
struct TCGContext {
|
struct TCGContext {
|
||||||
|
|
Loading…
Reference in a new issue