[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v4 22/30] target/arm: Enforce alignment for VLDn/VSTn (multiple)
From: |
Richard Henderson |
Subject: |
[PATCH v4 22/30] target/arm: Enforce alignment for VLDn/VSTn (multiple) |
Date: |
Fri, 16 Apr 2021 11:59:51 -0700 |
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
---
target/arm/translate-neon.c.inc | 27 ++++++++++++++++++++++-----
1 file changed, 22 insertions(+), 5 deletions(-)
diff --git a/target/arm/translate-neon.c.inc b/target/arm/translate-neon.c.inc
index 9c2b076027..e706c37c80 100644
--- a/target/arm/translate-neon.c.inc
+++ b/target/arm/translate-neon.c.inc
@@ -429,7 +429,7 @@ static bool trans_VLDST_multiple(DisasContext *s,
arg_VLDST_multiple *a)
{
/* Neon load/store multiple structures */
int nregs, interleave, spacing, reg, n;
- MemOp endian = s->be_data;
+ MemOp mop, align, endian;
int mmu_idx = get_mem_index(s);
int size = a->size;
TCGv_i64 tmp64;
@@ -473,20 +473,36 @@ static bool trans_VLDST_multiple(DisasContext *s,
arg_VLDST_multiple *a)
}
/* For our purposes, bytes are always little-endian. */
+ endian = s->be_data;
if (size == 0) {
endian = MO_LE;
}
+
+ /* Enforce alignment requested by the instruction */
+ if (a->align) {
+ align = pow2_align(a->align + 2); /* 4 ** a->align */
+ } else {
+ align = s->align_mem ? MO_ALIGN : 0;
+ }
+
/*
* Consecutive little-endian elements from a single register
* can be promoted to a larger little-endian operation.
*/
if (interleave == 1 && endian == MO_LE) {
+ /* Retain any natural alignment. */
+ if (align == MO_ALIGN) {
+ align = pow2_align(size);
+ }
size = 3;
}
+
tmp64 = tcg_temp_new_i64();
addr = tcg_temp_new_i32();
tmp = tcg_const_i32(1 << size);
load_reg_var(s, addr, a->rn);
+
+ mop = endian | size | align;
for (reg = 0; reg < nregs; reg++) {
for (n = 0; n < 8 >> size; n++) {
int xs;
@@ -494,15 +510,16 @@ static bool trans_VLDST_multiple(DisasContext *s,
arg_VLDST_multiple *a)
int tt = a->vd + reg + spacing * xs;
if (a->l) {
- gen_aa32_ld_internal_i64(s, tmp64, addr, mmu_idx,
- endian | size);
+ gen_aa32_ld_internal_i64(s, tmp64, addr, mmu_idx, mop);
neon_store_element64(tt, n, size, tmp64);
} else {
neon_load_element64(tmp64, tt, n, size);
- gen_aa32_st_internal_i64(s, tmp64, addr, mmu_idx,
- endian | size);
+ gen_aa32_st_internal_i64(s, tmp64, addr, mmu_idx, mop);
}
tcg_gen_add_i32(addr, addr, tmp);
+
+ /* Subsequent memory operations inherit alignment */
+ mop &= ~MO_AMASK;
}
}
}
--
2.25.1
- [PATCH v4 12/30] target/arm: Fix SCTLR_B test for TCGv_i64 load/store, (continued)
- [PATCH v4 12/30] target/arm: Fix SCTLR_B test for TCGv_i64 load/store, Richard Henderson, 2021/04/16
- [PATCH v4 14/30] target/arm: Enforce word alignment for LDRD/STRD, Richard Henderson, 2021/04/16
- [PATCH v4 11/30] target/arm: Merge gen_aa32_frob64 into gen_aa32_ld_i64, Richard Henderson, 2021/04/16
- [PATCH v4 15/30] target/arm: Enforce alignment for LDA/LDAH/STL/STLH, Richard Henderson, 2021/04/16
- [PATCH v4 17/30] target/arm: Enforce alignment for RFE, Richard Henderson, 2021/04/16
- [PATCH v4 19/30] target/arm: Enforce alignment for VLDM/VSTM, Richard Henderson, 2021/04/16
- [PATCH v4 16/30] target/arm: Enforce alignment for LDM/STM, Richard Henderson, 2021/04/16
- [PATCH v4 20/30] target/arm: Enforce alignment for VLDR/VSTR, Richard Henderson, 2021/04/16
- [PATCH v4 18/30] target/arm: Enforce alignment for SRS, Richard Henderson, 2021/04/16
- [PATCH v4 23/30] target/arm: Enforce alignment for VLDn/VSTn (single), Richard Henderson, 2021/04/16
- [PATCH v4 22/30] target/arm: Enforce alignment for VLDn/VSTn (multiple),
Richard Henderson <=
- [PATCH v4 25/30] target/arm: Use finalize_memop for aa64 fpr load/store, Richard Henderson, 2021/04/16
- [PATCH v4 26/30] target/arm: Enforce alignment for aa64 load-acq/store-rel, Richard Henderson, 2021/04/16
- [PATCH v4 29/30] target/arm: Enforce alignment for aa64 vector LDn/STn (single), Richard Henderson, 2021/04/16
- [PATCH v4 24/30] target/arm: Use finalize_memop for aa64 gpr load/store, Richard Henderson, 2021/04/16
- [PATCH v4 21/30] target/arm: Enforce alignment for VLDn (all lanes), Richard Henderson, 2021/04/16
- [PATCH v4 27/30] target/arm: Use MemOp for size + endian in aa64 vector ld/st, Richard Henderson, 2021/04/16
- [PATCH v4 30/30] target/arm: Enforce alignment for sve LD1R, Richard Henderson, 2021/04/16
- [PATCH v4 28/30] target/arm: Enforce alignment for aa64 vector LDn/STn (multiple), Richard Henderson, 2021/04/16
- Re: [PATCH v4 for-6.1 00/39] target/arm: enforce alignment, Peter Maydell, 2021/04/16