target/ppc: Fix vslv and vsrv
vslv and vsrv are broken on little endian, we append 00 to the high byte not the low byte. Fix it by using the VsrB() accessor. Signed-off-by: Anton Blanchard <anton@ozlabs.org> Message-Id: <20190507004811.29968-6-anton@ozlabs.org> Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
This commit is contained in:
parent
d47a751ada
commit
63be02fc69
@ -1815,10 +1815,10 @@ void helper_vslv(ppc_avr_t *r, ppc_avr_t *a, ppc_avr_t *b)
|
|||||||
|
|
||||||
size = ARRAY_SIZE(r->u8);
|
size = ARRAY_SIZE(r->u8);
|
||||||
for (i = 0; i < size; i++) {
|
for (i = 0; i < size; i++) {
|
||||||
shift = b->u8[i] & 0x7; /* extract shift value */
|
shift = b->VsrB(i) & 0x7; /* extract shift value */
|
||||||
bytes = (a->u8[i] << 8) + /* extract adjacent bytes */
|
bytes = (a->VsrB(i) << 8) + /* extract adjacent bytes */
|
||||||
(((i + 1) < size) ? a->u8[i + 1] : 0);
|
(((i + 1) < size) ? a->VsrB(i + 1) : 0);
|
||||||
r->u8[i] = (bytes << shift) >> 8; /* shift and store result */
|
r->VsrB(i) = (bytes << shift) >> 8; /* shift and store result */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1833,10 +1833,10 @@ void helper_vsrv(ppc_avr_t *r, ppc_avr_t *a, ppc_avr_t *b)
|
|||||||
* order will guarantee that computed result is not fed back.
|
* order will guarantee that computed result is not fed back.
|
||||||
*/
|
*/
|
||||||
for (i = ARRAY_SIZE(r->u8) - 1; i >= 0; i--) {
|
for (i = ARRAY_SIZE(r->u8) - 1; i >= 0; i--) {
|
||||||
shift = b->u8[i] & 0x7; /* extract shift value */
|
shift = b->VsrB(i) & 0x7; /* extract shift value */
|
||||||
bytes = ((i ? a->u8[i - 1] : 0) << 8) + a->u8[i];
|
bytes = ((i ? a->VsrB(i - 1) : 0) << 8) + a->VsrB(i);
|
||||||
/* extract adjacent bytes */
|
/* extract adjacent bytes */
|
||||||
r->u8[i] = (bytes >> shift) & 0xFF; /* shift and store result */
|
r->VsrB(i) = (bytes >> shift) & 0xFF; /* shift and store result */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user