tcg/ppc: Use the Set Boolean Extension
The SETBC family of instructions requires exactly two insns for all comparisions, saving 0-3 insns per (neg)setcond. Tested-by: Nicholas Piggin <npiggin@gmail.com> Reviewed-by: Daniel Henrique Barboza <danielhb413@gmail.com> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
parent
cba10bb3c8
commit
72fa954a63
@ -447,6 +447,11 @@ static bool tcg_target_const_match(int64_t val, TCGType type, int ct)
|
|||||||
#define TW XO31( 4)
|
#define TW XO31( 4)
|
||||||
#define TRAP (TW | TO(31))
|
#define TRAP (TW | TO(31))
|
||||||
|
|
||||||
|
#define SETBC XO31(384) /* v3.10 */
|
||||||
|
#define SETBCR XO31(416) /* v3.10 */
|
||||||
|
#define SETNBC XO31(448) /* v3.10 */
|
||||||
|
#define SETNBCR XO31(480) /* v3.10 */
|
||||||
|
|
||||||
#define NOP ORI /* ori 0,0,0 */
|
#define NOP ORI /* ori 0,0,0 */
|
||||||
|
|
||||||
#define LVX XO31(103)
|
#define LVX XO31(103)
|
||||||
@ -1624,6 +1629,23 @@ static void tcg_out_setcond(TCGContext *s, TCGType type, TCGCond cond,
|
|||||||
arg2 = (uint32_t)arg2;
|
arg2 = (uint32_t)arg2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* With SETBC/SETBCR, we can always implement with 2 insns. */
|
||||||
|
if (have_isa_3_10) {
|
||||||
|
tcg_insn_unit bi, opc;
|
||||||
|
|
||||||
|
tcg_out_cmp(s, cond, arg1, arg2, const_arg2, 7, type);
|
||||||
|
|
||||||
|
/* Re-use tcg_to_bc for BI and BO_COND_{TRUE,FALSE}. */
|
||||||
|
bi = tcg_to_bc[cond] & (0x1f << 16);
|
||||||
|
if (tcg_to_bc[cond] & BO(8)) {
|
||||||
|
opc = neg ? SETNBC : SETBC;
|
||||||
|
} else {
|
||||||
|
opc = neg ? SETNBCR : SETBCR;
|
||||||
|
}
|
||||||
|
tcg_out32(s, opc | RT(arg0) | bi);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
/* Handle common and trivial cases before handling anything else. */
|
/* Handle common and trivial cases before handling anything else. */
|
||||||
if (arg2 == 0) {
|
if (arg2 == 0) {
|
||||||
switch (cond) {
|
switch (cond) {
|
||||||
|
Loading…
Reference in New Issue
Block a user