target/arm: Fix alignment for VLD4.32
authorClément Chigot <chigot@adacore.com>
Wed, 14 Sep 2022 10:50:59 +0000 (12:50 +0200)
committerPeter Maydell <peter.maydell@linaro.org>
Thu, 22 Sep 2022 15:38:27 +0000 (16:38 +0100)
When requested, the alignment for VLD4.32 is 8 and not 16.

See ARM documentation about VLD4 encoding:
    ebytes = 1 << UInt(size);
    if size == '10' then
        alignment = if a == '0' then 1 else 8;
    else
        alignment = if a == '0' then 1 else 4*ebytes;

Signed-off-by: Clément Chigot <chigot@adacore.com>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-id: 20220914105058.2787404-1-chigot@adacore.com
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
target/arm/translate-neon.c

index 321c17e2c7e9563555de2a12329369a2aa3a66a3..4016339d46f8e209ba8317d2eb9893188b46bd52 100644 (file)
@@ -584,7 +584,11 @@ static bool trans_VLD_all_lanes(DisasContext *s, arg_VLD_all_lanes *a)
         case 3:
             return false;
         case 4:
-            align = pow2_align(size + 2);
+            if (size == 2) {
+                align = pow2_align(3);
+            } else {
+                align = pow2_align(size + 2);
+            }
             break;
         default:
             g_assert_not_reached();