Commit 198f7058 authored by Maciej W. Rozycki's avatar Maciej W. Rozycki Committed by Ralf Baechle

MIPS: math-emu: Add IEEE Std 754-2008 ABS.fmt and NEG.fmt emulation

Implement IEEE Std 754-2008 non-arithmetic ABS.fmt and NEG.fmt emulation
wired to the state of the FCSR.ABS2008 bit.  In the non-arithmetic mode
the sign bit is altered according to the operation requested regardless
of the datum encoded in the input operand, no other bits are changed,
the resulting bit pattern is written to the output operand and no
exception is ever signalled.
Signed-off-by: default avatarMaciej W. Rozycki <macro@imgtec.com>
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Matthew Fortune <Matthew.Fortune@imgtec.com>
Cc: linux-mips@linux-mips.org
Cc: linux-kernel@vger.kernel.org
Patchwork: https://patchwork.linux-mips.org/patch/11476/Signed-off-by: default avatarRalf Baechle <ralf@linux-mips.org>
parent 9519ef37
...@@ -23,27 +23,39 @@ ...@@ -23,27 +23,39 @@
union ieee754dp ieee754dp_neg(union ieee754dp x) union ieee754dp ieee754dp_neg(union ieee754dp x)
{ {
unsigned int oldrm;
union ieee754dp y; union ieee754dp y;
oldrm = ieee754_csr.rm; if (ieee754_csr.abs2008) {
ieee754_csr.rm = FPU_CSR_RD; y = x;
y = ieee754dp_sub(ieee754dp_zero(0), x); DPSIGN(y) = !DPSIGN(x);
ieee754_csr.rm = oldrm; } else {
unsigned int oldrm;
oldrm = ieee754_csr.rm;
ieee754_csr.rm = FPU_CSR_RD;
y = ieee754dp_sub(ieee754dp_zero(0), x);
ieee754_csr.rm = oldrm;
}
return y; return y;
} }
union ieee754dp ieee754dp_abs(union ieee754dp x) union ieee754dp ieee754dp_abs(union ieee754dp x)
{ {
unsigned int oldrm;
union ieee754dp y; union ieee754dp y;
oldrm = ieee754_csr.rm; if (ieee754_csr.abs2008) {
ieee754_csr.rm = FPU_CSR_RD; y = x;
if (DPSIGN(x)) DPSIGN(y) = 0;
y = ieee754dp_sub(ieee754dp_zero(0), x); } else {
else unsigned int oldrm;
y = ieee754dp_add(ieee754dp_zero(0), x);
ieee754_csr.rm = oldrm; oldrm = ieee754_csr.rm;
ieee754_csr.rm = FPU_CSR_RD;
if (DPSIGN(x))
y = ieee754dp_sub(ieee754dp_zero(0), x);
else
y = ieee754dp_add(ieee754dp_zero(0), x);
ieee754_csr.rm = oldrm;
}
return y; return y;
} }
...@@ -23,27 +23,39 @@ ...@@ -23,27 +23,39 @@
union ieee754sp ieee754sp_neg(union ieee754sp x) union ieee754sp ieee754sp_neg(union ieee754sp x)
{ {
unsigned int oldrm;
union ieee754sp y; union ieee754sp y;
oldrm = ieee754_csr.rm; if (ieee754_csr.abs2008) {
ieee754_csr.rm = FPU_CSR_RD; y = x;
y = ieee754sp_sub(ieee754sp_zero(0), x); SPSIGN(y) = !SPSIGN(x);
ieee754_csr.rm = oldrm; } else {
unsigned int oldrm;
oldrm = ieee754_csr.rm;
ieee754_csr.rm = FPU_CSR_RD;
y = ieee754sp_sub(ieee754sp_zero(0), x);
ieee754_csr.rm = oldrm;
}
return y; return y;
} }
union ieee754sp ieee754sp_abs(union ieee754sp x) union ieee754sp ieee754sp_abs(union ieee754sp x)
{ {
unsigned int oldrm;
union ieee754sp y; union ieee754sp y;
oldrm = ieee754_csr.rm; if (ieee754_csr.abs2008) {
ieee754_csr.rm = FPU_CSR_RD; y = x;
if (SPSIGN(x)) SPSIGN(y) = 0;
y = ieee754sp_sub(ieee754sp_zero(0), x); } else {
else unsigned int oldrm;
y = ieee754sp_add(ieee754sp_zero(0), x);
ieee754_csr.rm = oldrm; oldrm = ieee754_csr.rm;
ieee754_csr.rm = FPU_CSR_RD;
if (SPSIGN(x))
y = ieee754sp_sub(ieee754sp_zero(0), x);
else
y = ieee754sp_add(ieee754sp_zero(0), x);
ieee754_csr.rm = oldrm;
}
return y; return y;
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment