mirror of
https://github.com/Motorhead1991/qemu.git
synced 2026-01-05 14:07:41 -07:00
In function do_extractm() the mask is calculated as
dup_const(1 << (element_width - 1)). '1' being signed int
works fine for MO_8,16,32. For MO_64, on PPC64 host
this ends up becoming 0 on compilation. The vextractdm
uses MO_64, and it ends up having mask as 0.
Explicitly use 1ULL instead of signed int 1 like its
used everywhere else.
Resolves: https://gitlab.com/qemu-project/qemu/-/issues/1536
Signed-off-by: Shivaprasad G Bhat <sbhat@linux.ibm.com>
Reviewed-by: Alex Bennée <alex.bennee@linaro.org>
Reviewed-by: Lucas Mateus Castro <lucas.araujo@eldorado.org.br>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Reviewed-by: Cédric Le Goater <clg@redhat.com>
Message-Id: <168319292809.1159309.5817546227121323288.stgit@ltc-boston1.aus.stglabs.ibm.com>
Signed-off-by: Daniel Henrique Barboza <danielhb413@gmail.com>
(cherry picked from commit
|
||
|---|---|---|
| .. | ||
| branch-impl.c.inc | ||
| dfp-impl.c.inc | ||
| fixedpoint-impl.c.inc | ||
| fp-impl.c.inc | ||
| fp-ops.c.inc | ||
| processor-ctrl-impl.c.inc | ||
| spe-impl.c.inc | ||
| spe-ops.c.inc | ||
| storage-ctrl-impl.c.inc | ||
| vmx-impl.c.inc | ||
| vmx-ops.c.inc | ||
| vsx-impl.c.inc | ||
| vsx-ops.c.inc | ||