mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-05 08:43:55 -06:00
target/arm: Implement MVE VMAXNMA and VMINNMA
Implement the MVE VMAXNMA and VMINNMA insns; these are 2-operand, but the destination register must be the same as one of the source registers. We defer the decode of the size in bit 28 to the individual insn patterns rather than doing it in the format, because otherwise we would have a single insn pattern that overlapped with two groups (eg VMAXNMA with the VMULH_S and VMULH_U groups). Having two insn patterns per insn seems clearer than a complex multilevel nesting of overlapping and non-overlapping groups. Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
parent
d3cd965c84
commit
90257a4f35
4 changed files with 42 additions and 0 deletions
|
@ -2855,6 +2855,29 @@ DO_2OP_FP_ALL(vfabd, abd)
|
|||
DO_2OP_FP_ALL(vmaxnm, maxnum)
|
||||
DO_2OP_FP_ALL(vminnm, minnum)
|
||||
|
||||
static inline float16 float16_maxnuma(float16 a, float16 b, float_status *s)
|
||||
{
|
||||
return float16_maxnum(float16_abs(a), float16_abs(b), s);
|
||||
}
|
||||
|
||||
static inline float32 float32_maxnuma(float32 a, float32 b, float_status *s)
|
||||
{
|
||||
return float32_maxnum(float32_abs(a), float32_abs(b), s);
|
||||
}
|
||||
|
||||
static inline float16 float16_minnuma(float16 a, float16 b, float_status *s)
|
||||
{
|
||||
return float16_minnum(float16_abs(a), float16_abs(b), s);
|
||||
}
|
||||
|
||||
static inline float32 float32_minnuma(float32 a, float32 b, float_status *s)
|
||||
{
|
||||
return float32_minnum(float32_abs(a), float32_abs(b), s);
|
||||
}
|
||||
|
||||
DO_2OP_FP_ALL(vmaxnma, maxnuma)
|
||||
DO_2OP_FP_ALL(vminnma, minnuma)
|
||||
|
||||
#define DO_VCADD_FP(OP, ESIZE, TYPE, FN0, FN1) \
|
||||
void HELPER(glue(mve_, OP))(CPUARMState *env, \
|
||||
void *vd, void *vn, void *vm) \
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue