[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PULL 5/9] s390x/tcg: Fix VECTOR SHIFT RIGHT ARITHMETIC BY BYTE
From: |
Cornelia Huck |
Subject: |
[PULL 5/9] s390x/tcg: Fix VECTOR SHIFT RIGHT ARITHMETIC BY BYTE |
Date: |
Tue, 22 Oct 2019 11:54:24 +0200 |
From: David Hildenbrand <address@hidden>
We forgot to propagate the highest bit accross the high doubleword in
two cases (shift >=64).
Fixes: 5f724887e3dd ("s390x/tcg: Implement VECTOR SHIFT RIGHT ARITHMETIC")
Reviewed-by: Richard Henderson <address@hidden>
Signed-off-by: David Hildenbrand <address@hidden>
Message-Id: <address@hidden>
Signed-off-by: Cornelia Huck <address@hidden>
---
target/s390x/vec_int_helper.c | 6 ++++--
1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/target/s390x/vec_int_helper.c b/target/s390x/vec_int_helper.c
index 1b3aaecbdb3d..d38405848fed 100644
--- a/target/s390x/vec_int_helper.c
+++ b/target/s390x/vec_int_helper.c
@@ -70,15 +70,17 @@ static void s390_vec_sar(S390Vector *d, const S390Vector
*a, uint64_t count)
d->doubleword[0] = a->doubleword[0];
d->doubleword[1] = a->doubleword[1];
} else if (count == 64) {
+ tmp = (int64_t)a->doubleword[0] >> 63;
d->doubleword[1] = a->doubleword[0];
- d->doubleword[0] = 0;
+ d->doubleword[0] = tmp;
} else if (count < 64) {
tmp = a->doubleword[1] >> count;
d->doubleword[1] = deposit64(tmp, 64 - count, count, a->doubleword[0]);
d->doubleword[0] = (int64_t)a->doubleword[0] >> count;
} else {
+ tmp = (int64_t)a->doubleword[0] >> 63;
d->doubleword[1] = (int64_t)a->doubleword[0] >> (count - 64);
- d->doubleword[0] = 0;
+ d->doubleword[0] = tmp;
}
}
--
2.21.0
- [PULL 0/9] more s390x fixes, Cornelia Huck, 2019/10/22
- [PULL 1/9] s390x/cpumodel: Add missing visit_free, Cornelia Huck, 2019/10/22
- [PULL 2/9] s390x/mmu: Remove duplicate check for MMU_DATA_STORE, Cornelia Huck, 2019/10/22
- [PULL 3/9] s390x/tcg: Fix VECTOR MULTIPLY LOGICAL ODD, Cornelia Huck, 2019/10/22
- [PULL 4/9] s390x/tcg: Fix VECTOR MULTIPLY AND ADD *, Cornelia Huck, 2019/10/22
- [PULL 5/9] s390x/tcg: Fix VECTOR SHIFT RIGHT ARITHMETIC BY BYTE,
Cornelia Huck <=
- [PULL 6/9] s390x/tcg: Fix VECTOR SUBTRACT COMPUTE BORROW INDICATION, Cornelia Huck, 2019/10/22
- [PULL 7/9] s390x/tcg: Fix VECTOR SUBTRACT WITH BORROW INDICATION, Cornelia Huck, 2019/10/22
- [PULL 8/9] s390x/tcg: Fix VECTOR SUBTRACT WITH BORROW COMPUTE BORROW INDICATION, Cornelia Huck, 2019/10/22
- [PULL 9/9] s390x/kvm: Set default cpu model for all machine classes, Cornelia Huck, 2019/10/22
- Re: [PULL 0/9] more s390x fixes, Peter Maydell, 2019/10/22