|
@@ -228,6 +228,12 @@ static bool tci_compare32(uint32_t u0, uint32_t u1, TCGCond condition)
|
|
|
case TCG_COND_GTU:
|
|
|
result = (u0 > u1);
|
|
|
break;
|
|
|
+ case TCG_COND_TSTEQ:
|
|
|
+ result = (u0 & u1) == 0;
|
|
|
+ break;
|
|
|
+ case TCG_COND_TSTNE:
|
|
|
+ result = (u0 & u1) != 0;
|
|
|
+ break;
|
|
|
default:
|
|
|
g_assert_not_reached();
|
|
|
}
|
|
@@ -270,6 +276,12 @@ static bool tci_compare64(uint64_t u0, uint64_t u1, TCGCond condition)
|
|
|
case TCG_COND_GTU:
|
|
|
result = (u0 > u1);
|
|
|
break;
|
|
|
+ case TCG_COND_TSTEQ:
|
|
|
+ result = (u0 & u1) == 0;
|
|
|
+ break;
|
|
|
+ case TCG_COND_TSTNE:
|
|
|
+ result = (u0 & u1) != 0;
|
|
|
+ break;
|
|
|
default:
|
|
|
g_assert_not_reached();
|
|
|
}
|
|
@@ -1041,6 +1053,8 @@ static const char *str_c(TCGCond c)
|
|
|
[TCG_COND_GEU] = "geu",
|
|
|
[TCG_COND_LEU] = "leu",
|
|
|
[TCG_COND_GTU] = "gtu",
|
|
|
+ [TCG_COND_TSTEQ] = "tsteq",
|
|
|
+ [TCG_COND_TSTNE] = "tstne",
|
|
|
};
|
|
|
|
|
|
assert((unsigned)c < ARRAY_SIZE(cond));
|