1 // SPDX-License-Identifier: GPL-2.0-only
2 /* IEEE754 floating point arithmetic
3 * double precision: common utilities
6 * MIPS floating point support
7 * Copyright (C) 1994-2000 Algorithmics Ltd.
10 #include "ieee754dp.h"
12 union ieee754dp
ieee754dp_neg(union ieee754dp x
)
16 if (ieee754_csr
.abs2008
) {
18 DPSIGN(y
) = !DPSIGN(x
);
22 oldrm
= ieee754_csr
.rm
;
23 ieee754_csr
.rm
= FPU_CSR_RD
;
24 y
= ieee754dp_sub(ieee754dp_zero(0), x
);
25 ieee754_csr
.rm
= oldrm
;
30 union ieee754dp
ieee754dp_abs(union ieee754dp x
)
34 if (ieee754_csr
.abs2008
) {
40 oldrm
= ieee754_csr
.rm
;
41 ieee754_csr
.rm
= FPU_CSR_RD
;
43 y
= ieee754dp_sub(ieee754dp_zero(0), x
);
45 y
= ieee754dp_add(ieee754dp_zero(0), x
);
46 ieee754_csr
.rm
= oldrm
;