[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH v2 01/13] target-arm: A64: add support for condi
From: |
Richard Henderson |
Subject: |
Re: [Qemu-devel] [PATCH v2 01/13] target-arm: A64: add support for conditional select |
Date: |
Sat, 07 Dec 2013 05:59:02 +1300 |
User-agent: |
Mozilla/5.0 (X11; Linux x86_64; rv:24.0) Gecko/20100101 Thunderbird/24.1.0 |
On 12/07/2013 02:19 AM, Peter Maydell wrote:
> + tcg_rd = cpu_reg(s, rd);
> +
> + if (cond >= 0x0e) { /* condition "always" */
> + tcg_src = read_cpu_reg(s, rn, sf);
> + tcg_gen_mov_i64(tcg_rd, tcg_src);
> + } else {
> + /* OPTME: we could use movcond here, at the cost of duplicating
> + * a lot of the arm_gen_test_cc() logic.
> + */
> + int label_match = gen_new_label();
> + int label_continue = gen_new_label();
> +
> + arm_gen_test_cc(cond, label_match);
> + /* nomatch: */
> + tcg_src = cpu_reg(s, rm);
Sorry for missing this in the first round: For the silly corner case of Rd ==
XZR, tcg_rd is dead after the branch.
We could either move the tcg_rd assignment down into each basic block with the
assignment to tcg_src, or simply add
if (rd == 31) {
/* silly no-op write; until we use movcond we must special-case
this to avoid a dead temporary across basic blocks. */
return;
}
Either solution is ok by me.
r~
- [Qemu-devel] [PATCH v2 00/13] target-arm: A64 decoder set 2: misc logic and bit ops, Peter Maydell, 2013/12/06
- [Qemu-devel] [PATCH v2 02/13] target-arm: A64: add support for logical (shifted register), Peter Maydell, 2013/12/06
- [Qemu-devel] [PATCH v2 06/13] target-arm: A64: add support for 2-src shift reg insns, Peter Maydell, 2013/12/06
- [Qemu-devel] [PATCH v2 08/13] target-arm: A64: add support for 1-src RBIT insn, Peter Maydell, 2013/12/06
- [Qemu-devel] [PATCH v2 01/13] target-arm: A64: add support for conditional select, Peter Maydell, 2013/12/06
- Re: [Qemu-devel] [PATCH v2 01/13] target-arm: A64: add support for conditional select,
Richard Henderson <=
- [Qemu-devel] [PATCH v2 04/13] target-arm: A64: add support for EXTR, Peter Maydell, 2013/12/06
- [Qemu-devel] [PATCH v2 05/13] target-arm: A64: add support for 2-src data processing and DIV, Peter Maydell, 2013/12/06
- [Qemu-devel] [PATCH v2 09/13] target-arm: A64: add support for 1-src REV insns, Peter Maydell, 2013/12/06
- [Qemu-devel] [PATCH v2 13/13] target-arm: A64: add support for logical (immediate) insns, Peter Maydell, 2013/12/06
- [Qemu-devel] [PATCH v2 11/13] host-utils: add clrsb32/64 - count leading redundant sign bits, Peter Maydell, 2013/12/06
- [Qemu-devel] [PATCH v2 12/13] target-arm: A64: add support for 1-src CLS insn, Peter Maydell, 2013/12/06
- [Qemu-devel] [PATCH v2 03/13] target-arm: A64: add support for ADR and ADRP, Peter Maydell, 2013/12/06
- [Qemu-devel] [PATCH v2 10/13] target-arm: A64: add support for bitfield insns, Peter Maydell, 2013/12/06
- [Qemu-devel] [PATCH v2 07/13] target-arm: A64: add support for 1-src data processing and CLZ, Peter Maydell, 2013/12/06