mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-01-09 01:05:36 +00:00
tcg: Remove TCG_CT_REG
This wasn't actually used for anything, really. All variable operands must accept registers, and which are indicated by the set in TCGArgConstraint.regs. Backports commit 74a117906b87ff9220e4baae5a7431d6f4eadd45
This commit is contained in:
parent
ae075d324d
commit
71a34d84e5
|
@ -128,15 +128,12 @@ static const char *target_parse_constraint(TCGArgConstraint *ct,
|
||||||
{
|
{
|
||||||
switch (*ct_str++) {
|
switch (*ct_str++) {
|
||||||
case 'r': /* general registers */
|
case 'r': /* general registers */
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs |= 0xffffffffu;
|
ct->regs |= 0xffffffffu;
|
||||||
break;
|
break;
|
||||||
case 'w': /* advsimd registers */
|
case 'w': /* advsimd registers */
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs |= 0xffffffff00000000ull;
|
ct->regs |= 0xffffffff00000000ull;
|
||||||
break;
|
break;
|
||||||
case 'l': /* qemu_ld / qemu_st address, data_reg */
|
case 'l': /* qemu_ld / qemu_st address, data_reg */
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = 0xffffffffu;
|
ct->regs = 0xffffffffu;
|
||||||
#ifdef CONFIG_SOFTMMU
|
#ifdef CONFIG_SOFTMMU
|
||||||
/* x0 and x1 will be overwritten when reading the tlb entry,
|
/* x0 and x1 will be overwritten when reading the tlb entry,
|
||||||
|
|
|
@ -253,13 +253,11 @@ static const char *target_parse_constraint(TCGArgConstraint *ct,
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'r':
|
case 'r':
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = 0xffff;
|
ct->regs = 0xffff;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
/* qemu_ld address */
|
/* qemu_ld address */
|
||||||
case 'l':
|
case 'l':
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = 0xffff;
|
ct->regs = 0xffff;
|
||||||
#ifdef CONFIG_SOFTMMU
|
#ifdef CONFIG_SOFTMMU
|
||||||
/* r0-r2,lr will be overwritten when reading the tlb entry,
|
/* r0-r2,lr will be overwritten when reading the tlb entry,
|
||||||
|
@ -273,7 +271,6 @@ static const char *target_parse_constraint(TCGArgConstraint *ct,
|
||||||
|
|
||||||
/* qemu_st address & data */
|
/* qemu_st address & data */
|
||||||
case 's':
|
case 's':
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = 0xffff;
|
ct->regs = 0xffff;
|
||||||
/* r0-r2 will be overwritten when reading the tlb entry (softmmu only)
|
/* r0-r2 will be overwritten when reading the tlb entry (softmmu only)
|
||||||
and r0-r1 doing the byte swapping, so don't use these. */
|
and r0-r1 doing the byte swapping, so don't use these. */
|
||||||
|
|
|
@ -215,42 +215,33 @@ static const char *target_parse_constraint(TCGArgConstraint *ct,
|
||||||
{
|
{
|
||||||
switch(*ct_str++) {
|
switch(*ct_str++) {
|
||||||
case 'a':
|
case 'a':
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
tcg_regset_set_reg(ct->regs, TCG_REG_EAX);
|
tcg_regset_set_reg(ct->regs, TCG_REG_EAX);
|
||||||
break;
|
break;
|
||||||
case 'b':
|
case 'b':
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
tcg_regset_set_reg(ct->regs, TCG_REG_EBX);
|
tcg_regset_set_reg(ct->regs, TCG_REG_EBX);
|
||||||
break;
|
break;
|
||||||
case 'c':
|
case 'c':
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
tcg_regset_set_reg(ct->regs, TCG_REG_ECX);
|
tcg_regset_set_reg(ct->regs, TCG_REG_ECX);
|
||||||
break;
|
break;
|
||||||
case 'd':
|
case 'd':
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
tcg_regset_set_reg(ct->regs, TCG_REG_EDX);
|
tcg_regset_set_reg(ct->regs, TCG_REG_EDX);
|
||||||
break;
|
break;
|
||||||
case 'S':
|
case 'S':
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
tcg_regset_set_reg(ct->regs, TCG_REG_ESI);
|
tcg_regset_set_reg(ct->regs, TCG_REG_ESI);
|
||||||
break;
|
break;
|
||||||
case 'D':
|
case 'D':
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
tcg_regset_set_reg(ct->regs, TCG_REG_EDI);
|
tcg_regset_set_reg(ct->regs, TCG_REG_EDI);
|
||||||
break;
|
break;
|
||||||
case 'q':
|
case 'q':
|
||||||
/* A register that can be used as a byte operand. */
|
/* A register that can be used as a byte operand. */
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = TCG_TARGET_REG_BITS == 64 ? 0xffff : 0xf;
|
ct->regs = TCG_TARGET_REG_BITS == 64 ? 0xffff : 0xf;
|
||||||
break;
|
break;
|
||||||
case 'Q':
|
case 'Q':
|
||||||
/* A register with an addressable second byte (e.g. %ah). */
|
/* A register with an addressable second byte (e.g. %ah). */
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = 0xf;
|
ct->regs = 0xf;
|
||||||
break;
|
break;
|
||||||
case 'r':
|
case 'r':
|
||||||
/* A general register. */
|
/* A general register. */
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs |= ALL_GENERAL_REGS;
|
ct->regs |= ALL_GENERAL_REGS;
|
||||||
break;
|
break;
|
||||||
case 'W':
|
case 'W':
|
||||||
|
@ -259,13 +250,11 @@ static const char *target_parse_constraint(TCGArgConstraint *ct,
|
||||||
break;
|
break;
|
||||||
case 'x':
|
case 'x':
|
||||||
/* A vector register. */
|
/* A vector register. */
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs |= ALL_VECTOR_REGS;
|
ct->regs |= ALL_VECTOR_REGS;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
/* qemu_ld/st address constraint */
|
/* qemu_ld/st address constraint */
|
||||||
case 'L':
|
case 'L':
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = TCG_TARGET_REG_BITS == 64 ? 0xffff : 0xff;
|
ct->regs = TCG_TARGET_REG_BITS == 64 ? 0xffff : 0xff;
|
||||||
tcg_regset_reset_reg(ct->regs, TCG_REG_L0);
|
tcg_regset_reset_reg(ct->regs, TCG_REG_L0);
|
||||||
tcg_regset_reset_reg(ct->regs, TCG_REG_L1);
|
tcg_regset_reset_reg(ct->regs, TCG_REG_L1);
|
||||||
|
|
|
@ -195,11 +195,9 @@ static const char *target_parse_constraint(TCGArgConstraint *ct,
|
||||||
{
|
{
|
||||||
switch(*ct_str++) {
|
switch(*ct_str++) {
|
||||||
case 'r':
|
case 'r':
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = 0xffffffff;
|
ct->regs = 0xffffffff;
|
||||||
break;
|
break;
|
||||||
case 'L': /* qemu_ld input arg constraint */
|
case 'L': /* qemu_ld input arg constraint */
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = 0xffffffff;
|
ct->regs = 0xffffffff;
|
||||||
tcg_regset_reset_reg(ct->regs, TCG_REG_A0);
|
tcg_regset_reset_reg(ct->regs, TCG_REG_A0);
|
||||||
#if defined(CONFIG_SOFTMMU)
|
#if defined(CONFIG_SOFTMMU)
|
||||||
|
@ -209,7 +207,6 @@ static const char *target_parse_constraint(TCGArgConstraint *ct,
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
case 'S': /* qemu_st constraint */
|
case 'S': /* qemu_st constraint */
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = 0xffffffff;
|
ct->regs = 0xffffffff;
|
||||||
tcg_regset_reset_reg(ct->regs, TCG_REG_A0);
|
tcg_regset_reset_reg(ct->regs, TCG_REG_A0);
|
||||||
#if defined(CONFIG_SOFTMMU)
|
#if defined(CONFIG_SOFTMMU)
|
||||||
|
|
|
@ -226,15 +226,12 @@ static const char *target_parse_constraint(TCGArgConstraint *ct,
|
||||||
{
|
{
|
||||||
switch (*ct_str++) {
|
switch (*ct_str++) {
|
||||||
case 'A': case 'B': case 'C': case 'D':
|
case 'A': case 'B': case 'C': case 'D':
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
tcg_regset_set_reg(ct->regs, 3 + ct_str[0] - 'A');
|
tcg_regset_set_reg(ct->regs, 3 + ct_str[0] - 'A');
|
||||||
break;
|
break;
|
||||||
case 'r':
|
case 'r':
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = 0xffffffff;
|
ct->regs = 0xffffffff;
|
||||||
break;
|
break;
|
||||||
case 'L': /* qemu_ld constraint */
|
case 'L': /* qemu_ld constraint */
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = 0xffffffff;
|
ct->regs = 0xffffffff;
|
||||||
tcg_regset_reset_reg(ct->regs, TCG_REG_R3);
|
tcg_regset_reset_reg(ct->regs, TCG_REG_R3);
|
||||||
#ifdef CONFIG_SOFTMMU
|
#ifdef CONFIG_SOFTMMU
|
||||||
|
@ -243,7 +240,6 @@ static const char *target_parse_constraint(TCGArgConstraint *ct,
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
case 'S': /* qemu_st constraint */
|
case 'S': /* qemu_st constraint */
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = 0xffffffff;
|
ct->regs = 0xffffffff;
|
||||||
tcg_regset_reset_reg(ct->regs, TCG_REG_R3);
|
tcg_regset_reset_reg(ct->regs, TCG_REG_R3);
|
||||||
#ifdef CONFIG_SOFTMMU
|
#ifdef CONFIG_SOFTMMU
|
||||||
|
|
|
@ -414,23 +414,19 @@ static const char *target_parse_constraint(TCGArgConstraint *ct,
|
||||||
{
|
{
|
||||||
switch (*ct_str++) {
|
switch (*ct_str++) {
|
||||||
case 'r': /* all registers */
|
case 'r': /* all registers */
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = 0xffff;
|
ct->regs = 0xffff;
|
||||||
break;
|
break;
|
||||||
case 'L': /* qemu_ld/st constraint */
|
case 'L': /* qemu_ld/st constraint */
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = 0xffff;
|
ct->regs = 0xffff;
|
||||||
tcg_regset_reset_reg(ct->regs, TCG_REG_R2);
|
tcg_regset_reset_reg(ct->regs, TCG_REG_R2);
|
||||||
tcg_regset_reset_reg(ct->regs, TCG_REG_R3);
|
tcg_regset_reset_reg(ct->regs, TCG_REG_R3);
|
||||||
tcg_regset_reset_reg(ct->regs, TCG_REG_R4);
|
tcg_regset_reset_reg(ct->regs, TCG_REG_R4);
|
||||||
break;
|
break;
|
||||||
case 'a': /* force R2 for division */
|
case 'a': /* force R2 for division */
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = 0;
|
ct->regs = 0;
|
||||||
tcg_regset_set_reg(ct->regs, TCG_REG_R2);
|
tcg_regset_set_reg(ct->regs, TCG_REG_R2);
|
||||||
break;
|
break;
|
||||||
case 'b': /* force R3 for division */
|
case 'b': /* force R3 for division */
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = 0;
|
ct->regs = 0;
|
||||||
tcg_regset_set_reg(ct->regs, TCG_REG_R3);
|
tcg_regset_set_reg(ct->regs, TCG_REG_R3);
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -328,15 +328,12 @@ static const char *target_parse_constraint(TCGArgConstraint *ct,
|
||||||
{
|
{
|
||||||
switch (*ct_str++) {
|
switch (*ct_str++) {
|
||||||
case 'r':
|
case 'r':
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = 0xffffffff;
|
ct->regs = 0xffffffff;
|
||||||
break;
|
break;
|
||||||
case 'R':
|
case 'R':
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = ALL_64;
|
ct->regs = ALL_64;
|
||||||
break;
|
break;
|
||||||
case 'A': /* qemu_ld/st address constraint */
|
case 'A': /* qemu_ld/st address constraint */
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = TARGET_LONG_BITS == 64 ? ALL_64 : 0xffffffff;
|
ct->regs = TARGET_LONG_BITS == 64 ? ALL_64 : 0xffffffff;
|
||||||
reserve_helpers:
|
reserve_helpers:
|
||||||
tcg_regset_reset_reg(ct->regs, TCG_REG_O0);
|
tcg_regset_reset_reg(ct->regs, TCG_REG_O0);
|
||||||
|
@ -344,11 +341,9 @@ static const char *target_parse_constraint(TCGArgConstraint *ct,
|
||||||
tcg_regset_reset_reg(ct->regs, TCG_REG_O2);
|
tcg_regset_reset_reg(ct->regs, TCG_REG_O2);
|
||||||
break;
|
break;
|
||||||
case 's': /* qemu_st data 32-bit constraint */
|
case 's': /* qemu_st data 32-bit constraint */
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = 0xffffffff;
|
ct->regs = 0xffffffff;
|
||||||
goto reserve_helpers;
|
goto reserve_helpers;
|
||||||
case 'S': /* qemu_st data 64-bit constraint */
|
case 'S': /* qemu_st data 64-bit constraint */
|
||||||
ct->ct |= TCG_CT_REG;
|
|
||||||
ct->regs = ALL_64;
|
ct->regs = ALL_64;
|
||||||
goto reserve_helpers;
|
goto reserve_helpers;
|
||||||
case 'I':
|
case 'I':
|
||||||
|
|
|
@ -1587,21 +1587,14 @@ static void tcg_dump_ops(TCGContext *s, bool have_prefs)
|
||||||
/* we give more priority to constraints with less registers */
|
/* we give more priority to constraints with less registers */
|
||||||
static int get_constraint_priority(const TCGOpDef *def, int k)
|
static int get_constraint_priority(const TCGOpDef *def, int k)
|
||||||
{
|
{
|
||||||
const TCGArgConstraint *arg_ct;
|
const TCGArgConstraint *arg_ct = &def->args_ct[k];
|
||||||
|
int n;
|
||||||
|
|
||||||
int i, n;
|
|
||||||
arg_ct = &def->args_ct[k];
|
|
||||||
if (arg_ct->ct & TCG_CT_ALIAS) {
|
if (arg_ct->ct & TCG_CT_ALIAS) {
|
||||||
/* an alias is equivalent to a single register */
|
/* an alias is equivalent to a single register */
|
||||||
n = 1;
|
n = 1;
|
||||||
} else {
|
} else {
|
||||||
if (!(arg_ct->ct & TCG_CT_REG))
|
n = ctpop64(arg_ct->regs);
|
||||||
return 0;
|
|
||||||
n = 0;
|
|
||||||
for(i = 0; i < TCG_TARGET_NB_REGS; i++) {
|
|
||||||
if (tcg_regset_test_reg(arg_ct->regs, i))
|
|
||||||
n++;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return TCG_TARGET_NB_REGS - n + 1;
|
return TCG_TARGET_NB_REGS - n + 1;
|
||||||
}
|
}
|
||||||
|
@ -1678,7 +1671,7 @@ static void process_op_defs(TCGContext *s)
|
||||||
int oarg = *ct_str - '0';
|
int oarg = *ct_str - '0';
|
||||||
tcg_debug_assert(ct_str == tdefs->args_ct_str[i]);
|
tcg_debug_assert(ct_str == tdefs->args_ct_str[i]);
|
||||||
tcg_debug_assert(oarg < def->nb_oargs);
|
tcg_debug_assert(oarg < def->nb_oargs);
|
||||||
tcg_debug_assert(def->args_ct[oarg].ct & TCG_CT_REG);
|
tcg_debug_assert(def->args_ct[oarg].regs != 0);
|
||||||
/* TCG_CT_ALIAS is for the output arguments.
|
/* TCG_CT_ALIAS is for the output arguments.
|
||||||
The input is tagged with TCG_CT_IALIAS. */
|
The input is tagged with TCG_CT_IALIAS. */
|
||||||
def->args_ct[i] = def->args_ct[oarg];
|
def->args_ct[i] = def->args_ct[oarg];
|
||||||
|
|
|
@ -621,7 +621,6 @@ void tcg_dump_info(void);
|
||||||
#define TCG_CT_ALIAS 0x80
|
#define TCG_CT_ALIAS 0x80
|
||||||
#define TCG_CT_IALIAS 0x40
|
#define TCG_CT_IALIAS 0x40
|
||||||
#define TCG_CT_NEWREG 0x20 /* output requires a new register */
|
#define TCG_CT_NEWREG 0x20 /* output requires a new register */
|
||||||
#define TCG_CT_REG 0x01
|
|
||||||
#define TCG_CT_CONST 0x02 /* any constant of register size */
|
#define TCG_CT_CONST 0x02 /* any constant of register size */
|
||||||
|
|
||||||
typedef struct TCGArgConstraint {
|
typedef struct TCGArgConstraint {
|
||||||
|
|
Loading…
Reference in a new issue