|
From: | Richard Henderson |
Subject: | Re: [PATCH v6 1/8] tcg/sparc: Use tcg_out_movi_imm13 in tcg_out_addsub2_i64 |
Date: | Tue, 8 Feb 2022 22:09:45 +1100 |
User-agent: | Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.5.0 |
On 2/8/22 21:40, Peter Maydell wrote:
On Tue, 8 Feb 2022 at 07:17, Richard Henderson <richard.henderson@linaro.org> wrote:When BH is constant, it is constrained to 10 bits for use in MOVCC.Where does this happen? I assumed it was going to be done by the constraint encodings, but tcg_out_addsub2_i64() is called for the add2_i64 and sub2_i64 ops, which get return C_O2_I4(r, r, rZ, rZ, rJ, rJ); and constraint J is CONST('J', TCG_CT_CONST_S13). (and indeed there is no "constrain to 10 bits" letter).
Typo/thinko with 10 bit vs 11 bit: CONST('I', TCG_CT_CONST_S11) But there are different constraints for add2_i32 and add2_i64: case INDEX_op_add2_i32: case INDEX_op_sub2_i32: return C_O2_I4(r, r, rZ, rZ, rJ, rJ); ... case INDEX_op_add2_i64: case INDEX_op_sub2_i64: return C_O2_I4(R, R, RZ, RZ, RJ, RI); r~
[Prev in Thread] | Current Thread | [Next in Thread] |