[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH 08/43] tcg: Fix generation of dupi_vec for 32-bit host
From: |
Richard Henderson |
Subject: |
[PATCH 08/43] tcg: Fix generation of dupi_vec for 32-bit host |
Date: |
Tue, 8 Sep 2020 17:16:12 -0700 |
The definition of INDEX_op_dupi_vec is that it operates on
units of tcg_target_ulong -- in this case 32 bits. It does
not work to use this for a uint64_t value that happens to be
small enough to fit in tcg_target_ulong.
Fixes: d2fd745fe8b
Fixes: db432672dc5
Cc: qemu-stable@nongnu.org
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
---
tcg/tcg-op-vec.c | 12 ++++++++----
1 file changed, 8 insertions(+), 4 deletions(-)
diff --git a/tcg/tcg-op-vec.c b/tcg/tcg-op-vec.c
index ed6fb55fe1..cdbf11c573 100644
--- a/tcg/tcg-op-vec.c
+++ b/tcg/tcg-op-vec.c
@@ -252,10 +252,10 @@ TCGv_vec tcg_const_ones_vec_matching(TCGv_vec m)
void tcg_gen_dup64i_vec(TCGv_vec r, uint64_t a)
{
- if (TCG_TARGET_REG_BITS == 32 && a == deposit64(a, 32, 32, a)) {
- do_dupi_vec(r, MO_32, a);
- } else if (TCG_TARGET_REG_BITS == 64 || a == (uint64_t)(int32_t)a) {
+ if (TCG_TARGET_REG_BITS == 64) {
do_dupi_vec(r, MO_64, a);
+ } else if (a == dup_const(MO_32, a)) {
+ do_dupi_vec(r, MO_32, a);
} else {
TCGv_i64 c = tcg_const_i64(a);
tcg_gen_dup_i64_vec(MO_64, r, c);
@@ -280,7 +280,11 @@ void tcg_gen_dup8i_vec(TCGv_vec r, uint32_t a)
void tcg_gen_dupi_vec(unsigned vece, TCGv_vec r, uint64_t a)
{
- do_dupi_vec(r, MO_REG, dup_const(vece, a));
+ if (vece == MO_64) {
+ tcg_gen_dup64i_vec(r, a);
+ } else {
+ do_dupi_vec(r, MO_REG, dup_const(vece, a));
+ }
}
void tcg_gen_dup_i64_vec(unsigned vece, TCGv_vec r, TCGv_i64 a)
--
2.25.1
- [PATCH 00/43] tcg patch queue, Richard Henderson, 2020/09/08
- [PATCH 03/43] tcg: Move sorted_args into TCGArgConstraint.sort_index, Richard Henderson, 2020/09/08
- [PATCH 02/43] tcg: Drop union from TCGArgConstraint, Richard Henderson, 2020/09/08
- [PATCH 01/43] tcg: Adjust simd_desc size encoding, Richard Henderson, 2020/09/08
- [PATCH 05/43] tcg: Move some TCG_CT_* bits to TCGArgConstraint bitfields, Richard Henderson, 2020/09/08
- [PATCH 04/43] tcg: Remove TCG_CT_REG, Richard Henderson, 2020/09/08
- [PATCH 06/43] tcg: Remove TCGOpDef.used, Richard Henderson, 2020/09/08
- [PATCH 07/43] tcg/i386: Fix dupi for avx2 32-bit hosts, Richard Henderson, 2020/09/08
- [PATCH 08/43] tcg: Fix generation of dupi_vec for 32-bit host,
Richard Henderson <=
- [PATCH 09/43] tcg/optimize: Fold dup2_vec, Richard Henderson, 2020/09/08
- [PATCH 10/43] tcg: Remove TCG_TARGET_HAS_cmp_vec, Richard Henderson, 2020/09/08
- [PATCH 11/43] tcg: Use tcg_out_dupi_vec from temp_load, Richard Henderson, 2020/09/08
- [PATCH 12/43] tcg: Increase tcg_out_dupi_vec immediate to int64_t, Richard Henderson, 2020/09/08
- [PATCH 13/43] tcg: Consolidate 3 bits into enum TCGTempKind, Richard Henderson, 2020/09/08
- [PATCH 14/43] tcg: Add temp_readonly, Richard Henderson, 2020/09/08
- [PATCH 15/43] tcg: Expand TCGTemp.val to 64-bits, Richard Henderson, 2020/09/08
- [PATCH 16/43] tcg: Rename struct tcg_temp_info to TempOptInfo, Richard Henderson, 2020/09/08