]> git.ipfire.org Git - thirdparty/qemu.git/log
thirdparty/qemu.git
6 weeks agotcg/i386: Special case addci r, 0, 0
Richard Henderson [Sat, 18 Jan 2025 06:39:14 +0000 (22:39 -0800)] 
tcg/i386: Special case addci r, 0, 0

Using addci with two zeros as input in order to capture the value
of the carry-in bit is common.  Special case this with sbb+neg so
that we do not have to load 0 into a register first.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg/i386: Implement add/sub carry opcodes
Richard Henderson [Sat, 18 Jan 2025 06:24:56 +0000 (22:24 -0800)] 
tcg/i386: Implement add/sub carry opcodes

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg/i386: Honor carry_live in tcg_out_movi
Richard Henderson [Sat, 18 Jan 2025 06:05:48 +0000 (22:05 -0800)] 
tcg/i386: Honor carry_live in tcg_out_movi

Do not clobber flags if they're live.  Required in order
to perform register allocation on add/sub carry opcodes.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Use sub carry opcodes to expand sub2
Richard Henderson [Wed, 15 Jan 2025 02:58:05 +0000 (18:58 -0800)] 
tcg: Use sub carry opcodes to expand sub2

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Use add carry opcodes to expand add2
Richard Henderson [Tue, 14 Jan 2025 07:29:42 +0000 (23:29 -0800)] 
tcg: Use add carry opcodes to expand add2

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg/optimize: With two const operands, prefer 0 in arg1
Richard Henderson [Wed, 15 Jan 2025 07:08:24 +0000 (23:08 -0800)] 
tcg/optimize: With two const operands, prefer 0 in arg1

For most binary operands, two const operands fold.
However, the add/sub carry opcodes have a third input.
Prefer "reg, zero, const" since many risc hosts have a
zero register that can fit a "reg, reg, const" insn format.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg/optimize: Handle add/sub with carry opcodes
Richard Henderson [Wed, 15 Jan 2025 02:28:15 +0000 (18:28 -0800)] 
tcg/optimize: Handle add/sub with carry opcodes

Propagate known carry when possible, and simplify the opcodes
to not require carry-in when known.  The result will be cleaned
up further by the subsequent liveness analysis pass.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Add TCGOutOp structures for add/sub carry opcodes
Richard Henderson [Wed, 15 Jan 2025 07:27:53 +0000 (23:27 -0800)] 
tcg: Add TCGOutOp structures for add/sub carry opcodes

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Add add/sub with carry opcodes and infrastructure
Richard Henderson [Tue, 14 Jan 2025 21:58:39 +0000 (13:58 -0800)] 
tcg: Add add/sub with carry opcodes and infrastructure

Liveness needs to track carry-live state in order to
determine if the (hidden) output of the opcode is used.
Code generation needs to track carry-live state in order
to avoid clobbering cpu flags when loading constants.

So far, output routines and backends are unchanged.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Sink def, nb_iargs, nb_oargs loads in liveness_pass_1
Richard Henderson [Tue, 14 Jan 2025 21:12:35 +0000 (13:12 -0800)] 
tcg: Sink def, nb_iargs, nb_oargs loads in liveness_pass_1

Sink the sets of the def, nb_iargs, nb_oargs variables to
the default and do_not_remove labels.  They're not really
needed beforehand, and it avoids preceding code from having
to keep them up-to-date.  Note that def had *not* been kept
up-to-date; thankfully only def->flags had been used and
those bits were constant between opcode changes.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Move i into each for loop in liveness_pass_1
Richard Henderson [Tue, 14 Jan 2025 21:04:15 +0000 (13:04 -0800)] 
tcg: Move i into each for loop in liveness_pass_1

Use per-loop variables instead of one 'i' for the function.

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg/riscv: Drop support for add2/sub2
Richard Henderson [Tue, 14 Jan 2025 05:24:25 +0000 (21:24 -0800)] 
tcg/riscv: Drop support for add2/sub2

We now produce exactly the same code via generic expansion.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg/mips: Drop support for add2/sub2
Richard Henderson [Tue, 14 Jan 2025 05:16:40 +0000 (21:16 -0800)] 
tcg/mips: Drop support for add2/sub2

We now produce exactly the same code via generic expansion.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Do not default add2/sub2_i32 for 32-bit hosts
Richard Henderson [Tue, 14 Jan 2025 05:13:54 +0000 (21:13 -0800)] 
tcg: Do not default add2/sub2_i32 for 32-bit hosts

Require TCG_TARGET_HAS_{add2,sub2}_i32 be defined,
one way or another.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Expand fallback sub2 with 32-bit operations
Richard Henderson [Tue, 14 Jan 2025 04:21:09 +0000 (20:21 -0800)] 
tcg: Expand fallback sub2 with 32-bit operations

No need to expand to i64 to perform the subtract.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Expand fallback add2 with 32-bit operations
Richard Henderson [Tue, 14 Jan 2025 04:14:09 +0000 (20:14 -0800)] 
tcg: Expand fallback add2 with 32-bit operations

No need to expand to i64 to perform the add.
This is smaller on a loongarch64 host, e.g.

bstrpick_d  r28, r27, 31, 0
bstrpick_d  r29, r24, 31, 0
add_d       r28, r28, r29
addi_w      r29, r28, 0
srai_d      r28, r28, 32
  ---
add_w       r28, r27, r24
sltu        r29, r28, r24

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_extract2_{i32,i64}
Richard Henderson [Mon, 13 Jan 2025 05:40:43 +0000 (21:40 -0800)] 
tcg: Merge INDEX_op_extract2_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert extract2 to TCGOutOpExtract2
Richard Henderson [Mon, 13 Jan 2025 05:30:10 +0000 (21:30 -0800)] 
tcg: Convert extract2 to TCGOutOpExtract2

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_deposit_{i32,i64}
Richard Henderson [Mon, 13 Jan 2025 04:48:57 +0000 (20:48 -0800)] 
tcg: Merge INDEX_op_deposit_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg/aarch64: Improve deposit
Richard Henderson [Mon, 13 Jan 2025 04:42:13 +0000 (20:42 -0800)] 
tcg/aarch64: Improve deposit

Use ANDI for deposit 0 into a register.
Use UBFIZ, aka UBFM, for deposit register into 0.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert deposit to TCGOutOpDeposit
Richard Henderson [Mon, 13 Jan 2025 04:29:41 +0000 (20:29 -0800)] 
tcg: Convert deposit to TCGOutOpDeposit

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert extrh_i64_i32 to TCGOutOpUnary
Richard Henderson [Sun, 12 Jan 2025 21:37:28 +0000 (13:37 -0800)] 
tcg: Convert extrh_i64_i32 to TCGOutOpUnary

At the same time, make extrh_i64_i32 mandatory.  This closes a hole
in which move arguments could be cast between TCGv_i32 and TCGv_i64.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert extrl_i64_i32 to TCGOutOpUnary
Richard Henderson [Sun, 12 Jan 2025 20:57:13 +0000 (12:57 -0800)] 
tcg: Convert extrl_i64_i32 to TCGOutOpUnary

Drop the cast from TCGv_i64 to TCGv_i32 in tcg_gen_extrl_i64_i32
an emit extrl_i64_i32 unconditionally.  Move that special case
to tcg_gen_code when we find out if the output is live or dead.
In this way even hosts that canonicalize truncations can make
use of a store directly from the 64-bit host register.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert extu_i32_i64 to TCGOutOpUnary
Richard Henderson [Sun, 12 Jan 2025 20:34:45 +0000 (12:34 -0800)] 
tcg: Convert extu_i32_i64 to TCGOutOpUnary

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert ext_i32_i64 to TCGOutOpUnary
Richard Henderson [Sun, 12 Jan 2025 20:22:45 +0000 (12:22 -0800)] 
tcg: Convert ext_i32_i64 to TCGOutOpUnary

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_sextract_{i32,i64}
Richard Henderson [Sun, 12 Jan 2025 19:50:09 +0000 (11:50 -0800)] 
tcg: Merge INDEX_op_sextract_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert sextract to TCGOutOpExtract
Richard Henderson [Sun, 12 Jan 2025 19:44:30 +0000 (11:44 -0800)] 
tcg: Convert sextract to TCGOutOpExtract

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_extract_{i32,i64}
Richard Henderson [Sat, 11 Jan 2025 17:01:46 +0000 (09:01 -0800)] 
tcg: Merge INDEX_op_extract_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert extract to TCGOutOpExtract
Richard Henderson [Sat, 11 Jan 2025 15:55:47 +0000 (07:55 -0800)] 
tcg: Convert extract to TCGOutOpExtract

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Rename INDEX_op_bswap64_i64 to INDEX_op_bswap64
Richard Henderson [Sat, 11 Jan 2025 05:54:44 +0000 (21:54 -0800)] 
tcg: Rename INDEX_op_bswap64_i64 to INDEX_op_bswap64

Even though bswap64 can only be used with TCG_TYPE_I64,
rename the opcode to maintain uniformity.

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert bswap64 to TCGOutOpUnary
Richard Henderson [Sat, 11 Jan 2025 05:46:38 +0000 (21:46 -0800)] 
tcg: Convert bswap64 to TCGOutOpUnary

Use TCGOutOpUnary instead of TCGOutOpBswap because the
flags are not used with this opcode; they are merely
present for uniformity with the smaller bswaps.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_bswap32_{i32,i64}
Richard Henderson [Sat, 11 Jan 2025 03:53:51 +0000 (19:53 -0800)] 
tcg: Merge INDEX_op_bswap32_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert bswap32 to TCGOutOpBswap
Richard Henderson [Sat, 11 Jan 2025 03:49:20 +0000 (19:49 -0800)] 
tcg: Convert bswap32 to TCGOutOpBswap

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_bswap16_{i32,i64}
Richard Henderson [Sat, 11 Jan 2025 02:51:16 +0000 (18:51 -0800)] 
tcg: Merge INDEX_op_bswap16_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert bswap16 to TCGOutOpBswap
Richard Henderson [Sat, 11 Jan 2025 02:32:08 +0000 (18:32 -0800)] 
tcg: Convert bswap16 to TCGOutOpBswap

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert setcond2_i32 to TCGOutOpSetcond2
Richard Henderson [Sat, 11 Jan 2025 00:57:07 +0000 (16:57 -0800)] 
tcg: Convert setcond2_i32 to TCGOutOpSetcond2

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert brcond2_i32 to TCGOutOpBrcond2
Richard Henderson [Fri, 10 Jan 2025 23:51:26 +0000 (15:51 -0800)] 
tcg: Convert brcond2_i32 to TCGOutOpBrcond2

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg/ppc: Expand arguments to tcg_out_cmp2
Richard Henderson [Sat, 11 Jan 2025 00:41:26 +0000 (16:41 -0800)] 
tcg/ppc: Expand arguments to tcg_out_cmp2

Tested-by: Nicholas Piggin <npiggin@gmail.com>
Reviewed-by: Nicholas Piggin <npiggin@gmail.com>
Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg/arm: Expand arguments to tcg_out_cmp2
Richard Henderson [Fri, 10 Jan 2025 22:52:41 +0000 (14:52 -0800)] 
tcg/arm: Expand arguments to tcg_out_cmp2

Pass explicit arguments instead of arrays.

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg/ppc: Drop fallback constant loading in tcg_out_cmp
Richard Henderson [Fri, 10 Jan 2025 21:52:49 +0000 (13:52 -0800)] 
tcg/ppc: Drop fallback constant loading in tcg_out_cmp

Use U and C constraints for brcond2 and setcond2, so that tcg_out_cmp2
automatically passes in-range constants to tcg_out_cmp.

Tested-by: Nicholas Piggin <npiggin@gmail.com>
Reviewed-by: Nicholas Piggin <npiggin@gmail.com>
Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_movcond_{i32,i64}
Richard Henderson [Fri, 10 Jan 2025 21:41:25 +0000 (13:41 -0800)] 
tcg: Merge INDEX_op_movcond_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert movcond to TCGOutOpMovcond
Richard Henderson [Fri, 10 Jan 2025 21:29:39 +0000 (13:29 -0800)] 
tcg: Convert movcond to TCGOutOpMovcond

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_brcond_{i32,i64}
Richard Henderson [Fri, 10 Jan 2025 19:49:22 +0000 (11:49 -0800)] 
tcg: Merge INDEX_op_brcond_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert brcond to TCGOutOpBrcond
Richard Henderson [Fri, 10 Jan 2025 19:40:06 +0000 (11:40 -0800)] 
tcg: Convert brcond to TCGOutOpBrcond

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_{neg}setcond_{i32,i64}`
Richard Henderson [Fri, 10 Jan 2025 17:26:44 +0000 (09:26 -0800)] 
tcg: Merge INDEX_op_{neg}setcond_{i32,i64}`

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert setcond, negsetcond to TCGOutOpSetcond
Richard Henderson [Fri, 10 Jan 2025 17:12:06 +0000 (09:12 -0800)] 
tcg: Convert setcond, negsetcond to TCGOutOpSetcond

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Remove TCG_TARGET_HAS_negsetcond_{i32,i64}
Richard Henderson [Thu, 9 Jan 2025 20:48:21 +0000 (12:48 -0800)] 
tcg: Remove TCG_TARGET_HAS_negsetcond_{i32,i64}

All targets now provide negsetcond, so remove the conditional.

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg/tci: Support negsetcond
Richard Henderson [Thu, 9 Jan 2025 20:42:13 +0000 (12:42 -0800)] 
tcg/tci: Support negsetcond

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg/mips: Support negsetcond
Richard Henderson [Thu, 9 Jan 2025 20:36:32 +0000 (12:36 -0800)] 
tcg/mips: Support negsetcond

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg/loongarch64: Support negsetcond
Richard Henderson [Thu, 9 Jan 2025 20:22:55 +0000 (20:22 +0000)] 
tcg/loongarch64: Support negsetcond

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_mulu2_{i32,i64}
Richard Henderson [Thu, 9 Jan 2025 17:11:53 +0000 (09:11 -0800)] 
tcg: Merge INDEX_op_mulu2_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert mulu2 to TCGOutOpMul2
Richard Henderson [Thu, 9 Jan 2025 16:59:52 +0000 (08:59 -0800)] 
tcg: Convert mulu2 to TCGOutOpMul2

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_muls2_{i32,i64}
Richard Henderson [Thu, 9 Jan 2025 15:24:32 +0000 (07:24 -0800)] 
tcg: Merge INDEX_op_muls2_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert muls2 to TCGOutOpMul2
Richard Henderson [Thu, 9 Jan 2025 05:52:03 +0000 (21:52 -0800)] 
tcg: Convert muls2 to TCGOutOpMul2

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_ctpop_{i32,i64}
Richard Henderson [Thu, 9 Jan 2025 02:37:43 +0000 (18:37 -0800)] 
tcg: Merge INDEX_op_ctpop_{i32,i64}

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert ctpop to TCGOutOpUnary
Richard Henderson [Thu, 9 Jan 2025 01:56:01 +0000 (17:56 -0800)] 
tcg: Convert ctpop to TCGOutOpUnary

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_ctz_{i32,i64}
Richard Henderson [Thu, 9 Jan 2025 01:07:01 +0000 (17:07 -0800)] 
tcg: Merge INDEX_op_ctz_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert ctz to TCGOutOpBinary
Richard Henderson [Thu, 9 Jan 2025 01:02:13 +0000 (17:02 -0800)] 
tcg: Convert ctz to TCGOutOpBinary

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_clz_{i32,i64}
Richard Henderson [Thu, 9 Jan 2025 00:12:46 +0000 (16:12 -0800)] 
tcg: Merge INDEX_op_clz_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert clz to TCGOutOpBinary
Richard Henderson [Wed, 8 Jan 2025 22:16:04 +0000 (14:16 -0800)] 
tcg: Convert clz to TCGOutOpBinary

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_rot{l,r}_{i32,i64}
Richard Henderson [Wed, 8 Jan 2025 18:42:16 +0000 (10:42 -0800)] 
tcg: Merge INDEX_op_rot{l,r}_{i32,i64}

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert rotl, rotr to TCGOutOpBinary
Richard Henderson [Wed, 8 Jan 2025 18:22:53 +0000 (10:22 -0800)] 
tcg: Convert rotl, rotr to TCGOutOpBinary

For aarch64, arm, loongarch64, mips, we can drop rotl.
For ppc, s390x we can drop rotr.
Only x86, riscv, tci have both rotl and rotr.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Do not require both rotr and rotl from the backend
Richard Henderson [Wed, 8 Jan 2025 17:53:38 +0000 (09:53 -0800)] 
tcg: Do not require both rotr and rotl from the backend

Many host architectures do not implement both rotate right
and rotate left and require the compiler to negate the
shift count to rotate the opposite direction.  We have been
requiring the backend to perform this transformation.
Do this during opcode expansion so that the next patch
can drop support where possible in the backend.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_sar_{i32,i64}
Richard Henderson [Wed, 8 Jan 2025 16:05:18 +0000 (08:05 -0800)] 
tcg: Merge INDEX_op_sar_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert sar to TCGOutOpBinary
Richard Henderson [Wed, 8 Jan 2025 07:36:22 +0000 (23:36 -0800)] 
tcg: Convert sar to TCGOutOpBinary

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_shr_{i32,i64}
Richard Henderson [Wed, 8 Jan 2025 06:52:10 +0000 (22:52 -0800)] 
tcg: Merge INDEX_op_shr_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert shr to TCGOutOpBinary
Richard Henderson [Wed, 8 Jan 2025 06:22:36 +0000 (22:22 -0800)] 
tcg: Convert shr to TCGOutOpBinary

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_shl_{i32,i64}
Richard Henderson [Wed, 8 Jan 2025 05:50:04 +0000 (21:50 -0800)] 
tcg: Merge INDEX_op_shl_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert shl to TCGOutOpBinary
Richard Henderson [Wed, 8 Jan 2025 05:33:33 +0000 (21:33 -0800)] 
tcg: Convert shl to TCGOutOpBinary

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_remu_{i32,i64}
Richard Henderson [Wed, 8 Jan 2025 04:25:14 +0000 (20:25 -0800)] 
tcg: Merge INDEX_op_remu_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert remu to TCGOutOpBinary
Richard Henderson [Wed, 8 Jan 2025 04:12:08 +0000 (20:12 -0800)] 
tcg: Convert remu to TCGOutOpBinary

For TCI, we're losing type information in the interpreter.
Introduce a tci-specific opcode to handle the difference.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_rem_{i32,i64}
Richard Henderson [Wed, 8 Jan 2025 03:00:51 +0000 (19:00 -0800)] 
tcg: Merge INDEX_op_rem_{i32,i64}

Rename to INDEX_op_rems to emphasize signed inputs,
and mirroring INDEX_op_remu_*.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert rem to TCGOutOpBinary
Richard Henderson [Wed, 8 Jan 2025 02:52:30 +0000 (18:52 -0800)] 
tcg: Convert rem to TCGOutOpBinary

For TCI, we're losing type information in the interpreter.
Introduce a tci-specific opcode to handle the difference.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_divu2_{i32,i64}
Richard Henderson [Wed, 8 Jan 2025 02:23:17 +0000 (18:23 -0800)] 
tcg: Merge INDEX_op_divu2_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert divu2 to TCGOutOpDivRem
Richard Henderson [Wed, 8 Jan 2025 02:10:14 +0000 (18:10 -0800)] 
tcg: Convert divu2 to TCGOutOpDivRem

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_div2_{i32,i64}
Richard Henderson [Wed, 8 Jan 2025 00:44:23 +0000 (16:44 -0800)] 
tcg: Merge INDEX_op_div2_{i32,i64}

Rename to INDEX_op_divs2 to emphasize signed inputs,
and mirroring INDEX_op_divu2_*.  Document the opcode.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert div2 to TCGOutOpDivRem
Richard Henderson [Wed, 8 Jan 2025 00:32:29 +0000 (16:32 -0800)] 
tcg: Convert div2 to TCGOutOpDivRem

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_divu_{i32,i64}
Richard Henderson [Tue, 7 Jan 2025 22:27:19 +0000 (14:27 -0800)] 
tcg: Merge INDEX_op_divu_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert divu to TCGOutOpBinary
Richard Henderson [Tue, 7 Jan 2025 22:10:27 +0000 (14:10 -0800)] 
tcg: Convert divu to TCGOutOpBinary

For TCI, we're losing type information in the interpreter.
Introduce a tci-specific opcode to handle the difference.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_div_{i32,i64}
Richard Henderson [Tue, 7 Jan 2025 21:22:56 +0000 (13:22 -0800)] 
tcg: Merge INDEX_op_div_{i32,i64}

Rename to INDEX_op_divs to emphasize signed inputs,
and mirroring INDEX_op_divu_*.

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert div to TCGOutOpBinary
Richard Henderson [Tue, 7 Jan 2025 21:04:24 +0000 (13:04 -0800)] 
tcg: Convert div to TCGOutOpBinary

For TCI, we're losing type information in the interpreter.
Introduce a tci-specific opcode to handle the difference.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_mulsh_{i32,i64}
Richard Henderson [Tue, 7 Jan 2025 19:19:29 +0000 (11:19 -0800)] 
tcg: Merge INDEX_op_mulsh_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert mulsh to TCGOutOpBinary
Richard Henderson [Tue, 7 Jan 2025 19:13:05 +0000 (11:13 -0800)] 
tcg: Convert mulsh to TCGOutOpBinary

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_muluh_{i32,i64}
Richard Henderson [Tue, 7 Jan 2025 18:36:24 +0000 (10:36 -0800)] 
tcg: Merge INDEX_op_muluh_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert muluh to TCGOutOpBinary
Richard Henderson [Tue, 7 Jan 2025 18:16:03 +0000 (10:16 -0800)] 
tcg: Convert muluh to TCGOutOpBinary

Remove unreachable mul[su]h_i32 leftovers from commit aeb6326ec5e
("tcg/riscv: Require TCG_TARGET_REG_BITS == 64").

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_mul_{i32,i64}
Richard Henderson [Tue, 7 Jan 2025 17:32:18 +0000 (09:32 -0800)] 
tcg: Merge INDEX_op_mul_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert mul to TCGOutOpBinary
Richard Henderson [Tue, 7 Jan 2025 17:15:09 +0000 (09:15 -0800)] 
tcg: Convert mul to TCGOutOpBinary

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_not_{i32,i64}
Richard Henderson [Tue, 7 Jan 2025 07:46:47 +0000 (23:46 -0800)] 
tcg: Merge INDEX_op_not_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert not to TCGOutOpUnary
Richard Henderson [Tue, 7 Jan 2025 07:37:54 +0000 (23:37 -0800)] 
tcg: Convert not to TCGOutOpUnary

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_neg_{i32,i64}
Richard Henderson [Tue, 7 Jan 2025 06:48:57 +0000 (22:48 -0800)] 
tcg: Merge INDEX_op_neg_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert neg to TCGOutOpUnary
Richard Henderson [Tue, 7 Jan 2025 06:37:07 +0000 (22:37 -0800)] 
tcg: Convert neg to TCGOutOpUnary

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_sub_{i32,i64}
Richard Henderson [Tue, 7 Jan 2025 06:06:32 +0000 (22:06 -0800)] 
tcg: Merge INDEX_op_sub_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert sub to TCGOutOpSubtract
Richard Henderson [Tue, 7 Jan 2025 05:57:43 +0000 (21:57 -0800)] 
tcg: Convert sub to TCGOutOpSubtract

Create a special subclass for sub, because two backends can
support "subtract from immediate".  Drop all backend support
for an immediate as the second operand, as we transform sub
to add during optimize.

Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg/arm: Fix constraints for sub
Richard Henderson [Thu, 2 Jan 2025 21:25:15 +0000 (13:25 -0800)] 
tcg/arm: Fix constraints for sub

In 7536b82d288 we lost the rI constraint that allowed the use of
RSB to perform reg = imm - reg.  At the same time, drop support
for reg = reg - imm, which is now transformed generically to
addition, and need not be handled by the backend.

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_nor_{i32,i64}
Richard Henderson [Tue, 7 Jan 2025 05:02:17 +0000 (21:02 -0800)] 
tcg: Merge INDEX_op_nor_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert nor to TCGOutOpBinary
Richard Henderson [Tue, 7 Jan 2025 04:57:21 +0000 (20:57 -0800)] 
tcg: Convert nor to TCGOutOpBinary

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg/loongarch64: Do not accept constant argument to nor
Richard Henderson [Tue, 7 Jan 2025 04:37:25 +0000 (20:37 -0800)] 
tcg/loongarch64: Do not accept constant argument to nor

The instruction set does not implement nor with immediate.
There is no reason to pretend that we do.

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_nand_{i32,i64}
Richard Henderson [Tue, 7 Jan 2025 04:32:54 +0000 (20:32 -0800)] 
tcg: Merge INDEX_op_nand_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Convert nand to TCGOutOpBinary
Richard Henderson [Tue, 7 Jan 2025 00:18:19 +0000 (16:18 -0800)] 
tcg: Convert nand to TCGOutOpBinary

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
6 weeks agotcg: Merge INDEX_op_eqv_{i32,i64}
Richard Henderson [Mon, 6 Jan 2025 23:47:53 +0000 (15:47 -0800)] 
tcg: Merge INDEX_op_eqv_{i32,i64}

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>