aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
Diffstat (limited to 'arch')
-rw-r--r--arch/mips/math-emu/cp1emu.c66
-rw-r--r--arch/mips/math-emu/dp_add.c2
-rw-r--r--arch/mips/math-emu/dp_cmp.c2
-rw-r--r--arch/mips/math-emu/dp_div.c2
-rw-r--r--arch/mips/math-emu/dp_fint.c4
-rw-r--r--arch/mips/math-emu/dp_flong.c4
-rw-r--r--arch/mips/math-emu/dp_frexp.c2
-rw-r--r--arch/mips/math-emu/dp_fsp.c2
-rw-r--r--arch/mips/math-emu/dp_logb.c2
-rw-r--r--arch/mips/math-emu/dp_modf.c2
-rw-r--r--arch/mips/math-emu/dp_mul.c2
-rw-r--r--arch/mips/math-emu/dp_scalb.c4
-rw-r--r--arch/mips/math-emu/dp_simple.c10
-rw-r--r--arch/mips/math-emu/dp_sqrt.c4
-rw-r--r--arch/mips/math-emu/dp_sub.c2
-rw-r--r--arch/mips/math-emu/dp_tint.c6
-rw-r--r--arch/mips/math-emu/dp_tlong.c6
-rw-r--r--arch/mips/math-emu/ieee754.h166
-rw-r--r--arch/mips/math-emu/ieee754d.c4
-rw-r--r--arch/mips/math-emu/ieee754dp.c14
-rw-r--r--arch/mips/math-emu/ieee754dp.h18
-rw-r--r--arch/mips/math-emu/ieee754m.c12
-rw-r--r--arch/mips/math-emu/ieee754sp.c14
-rw-r--r--arch/mips/math-emu/ieee754sp.h18
-rw-r--r--arch/mips/math-emu/sp_add.c2
-rw-r--r--arch/mips/math-emu/sp_cmp.c2
-rw-r--r--arch/mips/math-emu/sp_div.c2
-rw-r--r--arch/mips/math-emu/sp_fdp.c4
-rw-r--r--arch/mips/math-emu/sp_fint.c4
-rw-r--r--arch/mips/math-emu/sp_flong.c4
-rw-r--r--arch/mips/math-emu/sp_frexp.c2
-rw-r--r--arch/mips/math-emu/sp_logb.c2
-rw-r--r--arch/mips/math-emu/sp_modf.c2
-rw-r--r--arch/mips/math-emu/sp_mul.c2
-rw-r--r--arch/mips/math-emu/sp_scalb.c4
-rw-r--r--arch/mips/math-emu/sp_simple.c10
-rw-r--r--arch/mips/math-emu/sp_sqrt.c2
-rw-r--r--arch/mips/math-emu/sp_sub.c2
-rw-r--r--arch/mips/math-emu/sp_tint.c6
-rw-r--r--arch/mips/math-emu/sp_tlong.c6
40 files changed, 212 insertions, 212 deletions
diff --git a/arch/mips/math-emu/cp1emu.c b/arch/mips/math-emu/cp1emu.c
index 7b3c9acae689..d670e3973bf1 100644
--- a/arch/mips/math-emu/cp1emu.c
+++ b/arch/mips/math-emu/cp1emu.c
@@ -1349,8 +1349,8 @@ static const unsigned char cmptab[8] = {
1349 */ 1349 */
1350 1350
1351#define DEF3OP(name, p, f1, f2, f3) \ 1351#define DEF3OP(name, p, f1, f2, f3) \
1352static ieee754##p fpemu_##p##_##name(ieee754##p r, ieee754##p s, \ 1352static union ieee754##p fpemu_##p##_##name(union ieee754##p r, union ieee754##p s, \
1353 ieee754##p t) \ 1353 union ieee754##p t) \
1354{ \ 1354{ \
1355 struct _ieee754_csr ieee754_csr_save; \ 1355 struct _ieee754_csr ieee754_csr_save; \
1356 s = f1(s, t); \ 1356 s = f1(s, t); \
@@ -1364,22 +1364,22 @@ static ieee754##p fpemu_##p##_##name(ieee754##p r, ieee754##p s, \
1364 return s; \ 1364 return s; \
1365} 1365}
1366 1366
1367static ieee754dp fpemu_dp_recip(ieee754dp d) 1367static union ieee754dp fpemu_dp_recip(union ieee754dp d)
1368{ 1368{
1369 return ieee754dp_div(ieee754dp_one(0), d); 1369 return ieee754dp_div(ieee754dp_one(0), d);
1370} 1370}
1371 1371
1372static ieee754dp fpemu_dp_rsqrt(ieee754dp d) 1372static union ieee754dp fpemu_dp_rsqrt(union ieee754dp d)
1373{ 1373{
1374 return ieee754dp_div(ieee754dp_one(0), ieee754dp_sqrt(d)); 1374 return ieee754dp_div(ieee754dp_one(0), ieee754dp_sqrt(d));
1375} 1375}
1376 1376
1377static ieee754sp fpemu_sp_recip(ieee754sp s) 1377static union ieee754sp fpemu_sp_recip(union ieee754sp s)
1378{ 1378{
1379 return ieee754sp_div(ieee754sp_one(0), s); 1379 return ieee754sp_div(ieee754sp_one(0), s);
1380} 1380}
1381 1381
1382static ieee754sp fpemu_sp_rsqrt(ieee754sp s) 1382static union ieee754sp fpemu_sp_rsqrt(union ieee754sp s)
1383{ 1383{
1384 return ieee754sp_div(ieee754sp_one(0), ieee754sp_sqrt(s)); 1384 return ieee754sp_div(ieee754sp_one(0), ieee754sp_sqrt(s));
1385} 1385}
@@ -1403,8 +1403,8 @@ static int fpux_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1403 switch (MIPSInst_FMA_FFMT(ir)) { 1403 switch (MIPSInst_FMA_FFMT(ir)) {
1404 case s_fmt:{ /* 0 */ 1404 case s_fmt:{ /* 0 */
1405 1405
1406 ieee754sp(*handler) (ieee754sp, ieee754sp, ieee754sp); 1406 union ieee754sp(*handler) (union ieee754sp, union ieee754sp, union ieee754sp);
1407 ieee754sp fd, fr, fs, ft; 1407 union ieee754sp fd, fr, fs, ft;
1408 u32 __user *va; 1408 u32 __user *va;
1409 u32 val; 1409 u32 val;
1410 1410
@@ -1492,8 +1492,8 @@ static int fpux_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1492 } 1492 }
1493 1493
1494 case d_fmt:{ /* 1 */ 1494 case d_fmt:{ /* 1 */
1495 ieee754dp(*handler) (ieee754dp, ieee754dp, ieee754dp); 1495 union ieee754dp(*handler) (union ieee754dp, union ieee754dp, union ieee754dp);
1496 ieee754dp fd, fr, fs, ft; 1496 union ieee754dp fd, fr, fs, ft;
1497 u64 __user *va; 1497 u64 __user *va;
1498 u64 val; 1498 u64 val;
1499 1499
@@ -1588,8 +1588,8 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1588 unsigned rcsr = 0; /* resulting csr */ 1588 unsigned rcsr = 0; /* resulting csr */
1589 unsigned cond; 1589 unsigned cond;
1590 union { 1590 union {
1591 ieee754dp d; 1591 union ieee754dp d;
1592 ieee754sp s; 1592 union ieee754sp s;
1593 int w; 1593 int w;
1594#ifdef __mips64 1594#ifdef __mips64
1595 s64 l; 1595 s64 l;
@@ -1600,8 +1600,8 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1600 switch (rfmt = (MIPSInst_FFMT(ir) & 0xf)) { 1600 switch (rfmt = (MIPSInst_FFMT(ir) & 0xf)) {
1601 case s_fmt:{ /* 0 */ 1601 case s_fmt:{ /* 0 */
1602 union { 1602 union {
1603 ieee754sp(*b) (ieee754sp, ieee754sp); 1603 union ieee754sp(*b) (union ieee754sp, union ieee754sp);
1604 ieee754sp(*u) (ieee754sp); 1604 union ieee754sp(*u) (union ieee754sp);
1605 } handler; 1605 } handler;
1606 1606
1607 switch (MIPSInst_FUNC(ir)) { 1607 switch (MIPSInst_FUNC(ir)) {
@@ -1666,7 +1666,7 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1666 /* binary op on handler */ 1666 /* binary op on handler */
1667 scopbop: 1667 scopbop:
1668 { 1668 {
1669 ieee754sp fs, ft; 1669 union ieee754sp fs, ft;
1670 1670
1671 SPFROMREG(fs, MIPSInst_FS(ir)); 1671 SPFROMREG(fs, MIPSInst_FS(ir));
1672 SPFROMREG(ft, MIPSInst_FT(ir)); 1672 SPFROMREG(ft, MIPSInst_FT(ir));
@@ -1676,7 +1676,7 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1676 } 1676 }
1677 scopuop: 1677 scopuop:
1678 { 1678 {
1679 ieee754sp fs; 1679 union ieee754sp fs;
1680 1680
1681 SPFROMREG(fs, MIPSInst_FS(ir)); 1681 SPFROMREG(fs, MIPSInst_FS(ir));
1682 rv.s = (*handler.u) (fs); 1682 rv.s = (*handler.u) (fs);
@@ -1699,7 +1699,7 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1699 case fcvts_op: 1699 case fcvts_op:
1700 return SIGILL; /* not defined */ 1700 return SIGILL; /* not defined */
1701 case fcvtd_op:{ 1701 case fcvtd_op:{
1702 ieee754sp fs; 1702 union ieee754sp fs;
1703 1703
1704 SPFROMREG(fs, MIPSInst_FS(ir)); 1704 SPFROMREG(fs, MIPSInst_FS(ir));
1705 rv.d = ieee754dp_fsp(fs); 1705 rv.d = ieee754dp_fsp(fs);
@@ -1707,7 +1707,7 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1707 goto copcsr; 1707 goto copcsr;
1708 } 1708 }
1709 case fcvtw_op:{ 1709 case fcvtw_op:{
1710 ieee754sp fs; 1710 union ieee754sp fs;
1711 1711
1712 SPFROMREG(fs, MIPSInst_FS(ir)); 1712 SPFROMREG(fs, MIPSInst_FS(ir));
1713 rv.w = ieee754sp_tint(fs); 1713 rv.w = ieee754sp_tint(fs);
@@ -1721,7 +1721,7 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1721 case fceil_op: 1721 case fceil_op:
1722 case ffloor_op:{ 1722 case ffloor_op:{
1723 unsigned int oldrm = ieee754_csr.rm; 1723 unsigned int oldrm = ieee754_csr.rm;
1724 ieee754sp fs; 1724 union ieee754sp fs;
1725 1725
1726 SPFROMREG(fs, MIPSInst_FS(ir)); 1726 SPFROMREG(fs, MIPSInst_FS(ir));
1727 ieee754_csr.rm = ieee_rm[modeindex(MIPSInst_FUNC(ir))]; 1727 ieee754_csr.rm = ieee_rm[modeindex(MIPSInst_FUNC(ir))];
@@ -1734,7 +1734,7 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1734 1734
1735#if defined(__mips64) 1735#if defined(__mips64)
1736 case fcvtl_op:{ 1736 case fcvtl_op:{
1737 ieee754sp fs; 1737 union ieee754sp fs;
1738 1738
1739 SPFROMREG(fs, MIPSInst_FS(ir)); 1739 SPFROMREG(fs, MIPSInst_FS(ir));
1740 rv.l = ieee754sp_tlong(fs); 1740 rv.l = ieee754sp_tlong(fs);
@@ -1747,7 +1747,7 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1747 case fceill_op: 1747 case fceill_op:
1748 case ffloorl_op:{ 1748 case ffloorl_op:{
1749 unsigned int oldrm = ieee754_csr.rm; 1749 unsigned int oldrm = ieee754_csr.rm;
1750 ieee754sp fs; 1750 union ieee754sp fs;
1751 1751
1752 SPFROMREG(fs, MIPSInst_FS(ir)); 1752 SPFROMREG(fs, MIPSInst_FS(ir));
1753 ieee754_csr.rm = ieee_rm[modeindex(MIPSInst_FUNC(ir))]; 1753 ieee754_csr.rm = ieee_rm[modeindex(MIPSInst_FUNC(ir))];
@@ -1761,7 +1761,7 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1761 default: 1761 default:
1762 if (MIPSInst_FUNC(ir) >= fcmp_op) { 1762 if (MIPSInst_FUNC(ir) >= fcmp_op) {
1763 unsigned cmpop = MIPSInst_FUNC(ir) - fcmp_op; 1763 unsigned cmpop = MIPSInst_FUNC(ir) - fcmp_op;
1764 ieee754sp fs, ft; 1764 union ieee754sp fs, ft;
1765 1765
1766 SPFROMREG(fs, MIPSInst_FS(ir)); 1766 SPFROMREG(fs, MIPSInst_FS(ir));
1767 SPFROMREG(ft, MIPSInst_FT(ir)); 1767 SPFROMREG(ft, MIPSInst_FT(ir));
@@ -1785,8 +1785,8 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1785 1785
1786 case d_fmt:{ 1786 case d_fmt:{
1787 union { 1787 union {
1788 ieee754dp(*b) (ieee754dp, ieee754dp); 1788 union ieee754dp(*b) (union ieee754dp, union ieee754dp);
1789 ieee754dp(*u) (ieee754dp); 1789 union ieee754dp(*u) (union ieee754dp);
1790 } handler; 1790 } handler;
1791 1791
1792 switch (MIPSInst_FUNC(ir)) { 1792 switch (MIPSInst_FUNC(ir)) {
@@ -1852,7 +1852,7 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1852 1852
1853 /* binary op on handler */ 1853 /* binary op on handler */
1854 dcopbop:{ 1854 dcopbop:{
1855 ieee754dp fs, ft; 1855 union ieee754dp fs, ft;
1856 1856
1857 DPFROMREG(fs, MIPSInst_FS(ir)); 1857 DPFROMREG(fs, MIPSInst_FS(ir));
1858 DPFROMREG(ft, MIPSInst_FT(ir)); 1858 DPFROMREG(ft, MIPSInst_FT(ir));
@@ -1861,7 +1861,7 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1861 goto copcsr; 1861 goto copcsr;
1862 } 1862 }
1863 dcopuop:{ 1863 dcopuop:{
1864 ieee754dp fs; 1864 union ieee754dp fs;
1865 1865
1866 DPFROMREG(fs, MIPSInst_FS(ir)); 1866 DPFROMREG(fs, MIPSInst_FS(ir));
1867 rv.d = (*handler.u) (fs); 1867 rv.d = (*handler.u) (fs);
@@ -1870,7 +1870,7 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1870 1870
1871 /* unary conv ops */ 1871 /* unary conv ops */
1872 case fcvts_op:{ 1872 case fcvts_op:{
1873 ieee754dp fs; 1873 union ieee754dp fs;
1874 1874
1875 DPFROMREG(fs, MIPSInst_FS(ir)); 1875 DPFROMREG(fs, MIPSInst_FS(ir));
1876 rv.s = ieee754sp_fdp(fs); 1876 rv.s = ieee754sp_fdp(fs);
@@ -1881,7 +1881,7 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1881 return SIGILL; /* not defined */ 1881 return SIGILL; /* not defined */
1882 1882
1883 case fcvtw_op:{ 1883 case fcvtw_op:{
1884 ieee754dp fs; 1884 union ieee754dp fs;
1885 1885
1886 DPFROMREG(fs, MIPSInst_FS(ir)); 1886 DPFROMREG(fs, MIPSInst_FS(ir));
1887 rv.w = ieee754dp_tint(fs); /* wrong */ 1887 rv.w = ieee754dp_tint(fs); /* wrong */
@@ -1895,7 +1895,7 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1895 case fceil_op: 1895 case fceil_op:
1896 case ffloor_op:{ 1896 case ffloor_op:{
1897 unsigned int oldrm = ieee754_csr.rm; 1897 unsigned int oldrm = ieee754_csr.rm;
1898 ieee754dp fs; 1898 union ieee754dp fs;
1899 1899
1900 DPFROMREG(fs, MIPSInst_FS(ir)); 1900 DPFROMREG(fs, MIPSInst_FS(ir));
1901 ieee754_csr.rm = ieee_rm[modeindex(MIPSInst_FUNC(ir))]; 1901 ieee754_csr.rm = ieee_rm[modeindex(MIPSInst_FUNC(ir))];
@@ -1908,7 +1908,7 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1908 1908
1909#if defined(__mips64) 1909#if defined(__mips64)
1910 case fcvtl_op:{ 1910 case fcvtl_op:{
1911 ieee754dp fs; 1911 union ieee754dp fs;
1912 1912
1913 DPFROMREG(fs, MIPSInst_FS(ir)); 1913 DPFROMREG(fs, MIPSInst_FS(ir));
1914 rv.l = ieee754dp_tlong(fs); 1914 rv.l = ieee754dp_tlong(fs);
@@ -1921,7 +1921,7 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1921 case fceill_op: 1921 case fceill_op:
1922 case ffloorl_op:{ 1922 case ffloorl_op:{
1923 unsigned int oldrm = ieee754_csr.rm; 1923 unsigned int oldrm = ieee754_csr.rm;
1924 ieee754dp fs; 1924 union ieee754dp fs;
1925 1925
1926 DPFROMREG(fs, MIPSInst_FS(ir)); 1926 DPFROMREG(fs, MIPSInst_FS(ir));
1927 ieee754_csr.rm = ieee_rm[modeindex(MIPSInst_FUNC(ir))]; 1927 ieee754_csr.rm = ieee_rm[modeindex(MIPSInst_FUNC(ir))];
@@ -1935,7 +1935,7 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1935 default: 1935 default:
1936 if (MIPSInst_FUNC(ir) >= fcmp_op) { 1936 if (MIPSInst_FUNC(ir) >= fcmp_op) {
1937 unsigned cmpop = MIPSInst_FUNC(ir) - fcmp_op; 1937 unsigned cmpop = MIPSInst_FUNC(ir) - fcmp_op;
1938 ieee754dp fs, ft; 1938 union ieee754dp fs, ft;
1939 1939
1940 DPFROMREG(fs, MIPSInst_FS(ir)); 1940 DPFROMREG(fs, MIPSInst_FS(ir));
1941 DPFROMREG(ft, MIPSInst_FT(ir)); 1941 DPFROMREG(ft, MIPSInst_FT(ir));
@@ -1960,7 +1960,7 @@ static int fpu_emu(struct pt_regs *xcp, struct mips_fpu_struct *ctx,
1960 } 1960 }
1961 1961
1962 case w_fmt:{ 1962 case w_fmt:{
1963 ieee754sp fs; 1963 union ieee754sp fs;
1964 1964
1965 switch (MIPSInst_FUNC(ir)) { 1965 switch (MIPSInst_FUNC(ir)) {
1966 case fcvts_op: 1966 case fcvts_op:
diff --git a/arch/mips/math-emu/dp_add.c b/arch/mips/math-emu/dp_add.c
index c57c8adc42c4..b5aac129e9f1 100644
--- a/arch/mips/math-emu/dp_add.c
+++ b/arch/mips/math-emu/dp_add.c
@@ -27,7 +27,7 @@
27 27
28#include "ieee754dp.h" 28#include "ieee754dp.h"
29 29
30ieee754dp ieee754dp_add(ieee754dp x, ieee754dp y) 30union ieee754dp ieee754dp_add(union ieee754dp x, union ieee754dp y)
31{ 31{
32 COMPXDP; 32 COMPXDP;
33 COMPYDP; 33 COMPYDP;
diff --git a/arch/mips/math-emu/dp_cmp.c b/arch/mips/math-emu/dp_cmp.c
index 0f32486b0ed9..a3b4984d2e83 100644
--- a/arch/mips/math-emu/dp_cmp.c
+++ b/arch/mips/math-emu/dp_cmp.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754dp.h" 27#include "ieee754dp.h"
28 28
29int ieee754dp_cmp(ieee754dp x, ieee754dp y, int cmp, int sig) 29int ieee754dp_cmp(union ieee754dp x, union ieee754dp y, int cmp, int sig)
30{ 30{
31 COMPXDP; 31 COMPXDP;
32 COMPYDP; 32 COMPYDP;
diff --git a/arch/mips/math-emu/dp_div.c b/arch/mips/math-emu/dp_div.c
index a1bce1b7c09c..30cc7fa3ce37 100644
--- a/arch/mips/math-emu/dp_div.c
+++ b/arch/mips/math-emu/dp_div.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754dp.h" 27#include "ieee754dp.h"
28 28
29ieee754dp ieee754dp_div(ieee754dp x, ieee754dp y) 29union ieee754dp ieee754dp_div(union ieee754dp x, union ieee754dp y)
30{ 30{
31 COMPXDP; 31 COMPXDP;
32 COMPYDP; 32 COMPYDP;
diff --git a/arch/mips/math-emu/dp_fint.c b/arch/mips/math-emu/dp_fint.c
index 88571288c9e0..60ed6ec7ddc7 100644
--- a/arch/mips/math-emu/dp_fint.c
+++ b/arch/mips/math-emu/dp_fint.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754dp.h" 27#include "ieee754dp.h"
28 28
29ieee754dp ieee754dp_fint(int x) 29union ieee754dp ieee754dp_fint(int x)
30{ 30{
31 u64 xm; 31 u64 xm;
32 int xe; 32 int xe;
@@ -70,7 +70,7 @@ ieee754dp ieee754dp_fint(int x)
70#endif 70#endif
71} 71}
72 72
73ieee754dp ieee754dp_funs(unsigned int u) 73union ieee754dp ieee754dp_funs(unsigned int u)
74{ 74{
75 if ((int) u < 0) 75 if ((int) u < 0)
76 return ieee754dp_add(ieee754dp_1e31(), 76 return ieee754dp_add(ieee754dp_1e31(),
diff --git a/arch/mips/math-emu/dp_flong.c b/arch/mips/math-emu/dp_flong.c
index 14fc01ec742d..2418f9d03055 100644
--- a/arch/mips/math-emu/dp_flong.c
+++ b/arch/mips/math-emu/dp_flong.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754dp.h" 27#include "ieee754dp.h"
28 28
29ieee754dp ieee754dp_flong(s64 x) 29union ieee754dp ieee754dp_flong(s64 x)
30{ 30{
31 u64 xm; 31 u64 xm;
32 int xe; 32 int xe;
@@ -68,7 +68,7 @@ ieee754dp ieee754dp_flong(s64 x)
68 DPNORMRET1(xs, xe, xm, "dp_flong", x); 68 DPNORMRET1(xs, xe, xm, "dp_flong", x);
69} 69}
70 70
71ieee754dp ieee754dp_fulong(u64 u) 71union ieee754dp ieee754dp_fulong(u64 u)
72{ 72{
73 if ((s64) u < 0) 73 if ((s64) u < 0)
74 return ieee754dp_add(ieee754dp_1e63(), 74 return ieee754dp_add(ieee754dp_1e63(),
diff --git a/arch/mips/math-emu/dp_frexp.c b/arch/mips/math-emu/dp_frexp.c
index cb15a5eaecbb..6ab7df958362 100644
--- a/arch/mips/math-emu/dp_frexp.c
+++ b/arch/mips/math-emu/dp_frexp.c
@@ -28,7 +28,7 @@
28 28
29/* close to ieeep754dp_logb 29/* close to ieeep754dp_logb
30*/ 30*/
31ieee754dp ieee754dp_frexp(ieee754dp x, int *eptr) 31union ieee754dp ieee754dp_frexp(union ieee754dp x, int *eptr)
32{ 32{
33 COMPXDP; 33 COMPXDP;
34 CLEARCX; 34 CLEARCX;
diff --git a/arch/mips/math-emu/dp_fsp.c b/arch/mips/math-emu/dp_fsp.c
index daed6834dc15..d69cb1ad3f60 100644
--- a/arch/mips/math-emu/dp_fsp.c
+++ b/arch/mips/math-emu/dp_fsp.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754dp.h" 27#include "ieee754dp.h"
28 28
29ieee754dp ieee754dp_fsp(ieee754sp x) 29union ieee754dp ieee754dp_fsp(union ieee754sp x)
30{ 30{
31 COMPXSP; 31 COMPXSP;
32 32
diff --git a/arch/mips/math-emu/dp_logb.c b/arch/mips/math-emu/dp_logb.c
index 151127e59f5c..80116e2f331f 100644
--- a/arch/mips/math-emu/dp_logb.c
+++ b/arch/mips/math-emu/dp_logb.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754dp.h" 27#include "ieee754dp.h"
28 28
29ieee754dp ieee754dp_logb(ieee754dp x) 29union ieee754dp ieee754dp_logb(union ieee754dp x)
30{ 30{
31 COMPXDP; 31 COMPXDP;
32 32
diff --git a/arch/mips/math-emu/dp_modf.c b/arch/mips/math-emu/dp_modf.c
index b01f9cf6d402..cbc1386cdfca 100644
--- a/arch/mips/math-emu/dp_modf.c
+++ b/arch/mips/math-emu/dp_modf.c
@@ -28,7 +28,7 @@
28 28
29/* modf function is always exact for a finite number 29/* modf function is always exact for a finite number
30*/ 30*/
31ieee754dp ieee754dp_modf(ieee754dp x, ieee754dp *ip) 31union ieee754dp ieee754dp_modf(union ieee754dp x, union ieee754dp *ip)
32{ 32{
33 COMPXDP; 33 COMPXDP;
34 34
diff --git a/arch/mips/math-emu/dp_mul.c b/arch/mips/math-emu/dp_mul.c
index 09175f461920..c4cad69c377e 100644
--- a/arch/mips/math-emu/dp_mul.c
+++ b/arch/mips/math-emu/dp_mul.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754dp.h" 27#include "ieee754dp.h"
28 28
29ieee754dp ieee754dp_mul(ieee754dp x, ieee754dp y) 29union ieee754dp ieee754dp_mul(union ieee754dp x, union ieee754dp y)
30{ 30{
31 COMPXDP; 31 COMPXDP;
32 COMPYDP; 32 COMPYDP;
diff --git a/arch/mips/math-emu/dp_scalb.c b/arch/mips/math-emu/dp_scalb.c
index 6f5df438dda8..4f8b65622942 100644
--- a/arch/mips/math-emu/dp_scalb.c
+++ b/arch/mips/math-emu/dp_scalb.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754dp.h" 27#include "ieee754dp.h"
28 28
29ieee754dp ieee754dp_scalb(ieee754dp x, int n) 29union ieee754dp ieee754dp_scalb(union ieee754dp x, int n)
30{ 30{
31 COMPXDP; 31 COMPXDP;
32 32
@@ -51,7 +51,7 @@ ieee754dp ieee754dp_scalb(ieee754dp x, int n)
51} 51}
52 52
53 53
54ieee754dp ieee754dp_ldexp(ieee754dp x, int n) 54union ieee754dp ieee754dp_ldexp(union ieee754dp x, int n)
55{ 55{
56 return ieee754dp_scalb(x, n); 56 return ieee754dp_scalb(x, n);
57} 57}
diff --git a/arch/mips/math-emu/dp_simple.c b/arch/mips/math-emu/dp_simple.c
index 79ce2673a714..b341cc83eeb0 100644
--- a/arch/mips/math-emu/dp_simple.c
+++ b/arch/mips/math-emu/dp_simple.c
@@ -26,12 +26,12 @@
26 26
27#include "ieee754dp.h" 27#include "ieee754dp.h"
28 28
29int ieee754dp_finite(ieee754dp x) 29int ieee754dp_finite(union ieee754dp x)
30{ 30{
31 return DPBEXP(x) != DP_EMAX + 1 + DP_EBIAS; 31 return DPBEXP(x) != DP_EMAX + 1 + DP_EBIAS;
32} 32}
33 33
34ieee754dp ieee754dp_copysign(ieee754dp x, ieee754dp y) 34union ieee754dp ieee754dp_copysign(union ieee754dp x, union ieee754dp y)
35{ 35{
36 CLEARCX; 36 CLEARCX;
37 DPSIGN(x) = DPSIGN(y); 37 DPSIGN(x) = DPSIGN(y);
@@ -39,7 +39,7 @@ ieee754dp ieee754dp_copysign(ieee754dp x, ieee754dp y)
39} 39}
40 40
41 41
42ieee754dp ieee754dp_neg(ieee754dp x) 42union ieee754dp ieee754dp_neg(union ieee754dp x)
43{ 43{
44 COMPXDP; 44 COMPXDP;
45 45
@@ -55,7 +55,7 @@ ieee754dp ieee754dp_neg(ieee754dp x)
55 DPSIGN(x) ^= 1; 55 DPSIGN(x) ^= 1;
56 56
57 if (xc == IEEE754_CLASS_SNAN) { 57 if (xc == IEEE754_CLASS_SNAN) {
58 ieee754dp y = ieee754dp_indef(); 58 union ieee754dp y = ieee754dp_indef();
59 SETCX(IEEE754_INVALID_OPERATION); 59 SETCX(IEEE754_INVALID_OPERATION);
60 DPSIGN(y) = DPSIGN(x); 60 DPSIGN(y) = DPSIGN(x);
61 return ieee754dp_nanxcpt(y, "neg"); 61 return ieee754dp_nanxcpt(y, "neg");
@@ -65,7 +65,7 @@ ieee754dp ieee754dp_neg(ieee754dp x)
65} 65}
66 66
67 67
68ieee754dp ieee754dp_abs(ieee754dp x) 68union ieee754dp ieee754dp_abs(union ieee754dp x)
69{ 69{
70 COMPXDP; 70 COMPXDP;
71 71
diff --git a/arch/mips/math-emu/dp_sqrt.c b/arch/mips/math-emu/dp_sqrt.c
index b874d60a942b..cee9f3c2700d 100644
--- a/arch/mips/math-emu/dp_sqrt.c
+++ b/arch/mips/math-emu/dp_sqrt.c
@@ -34,10 +34,10 @@ static const unsigned table[] = {
34 1742, 661, 130 34 1742, 661, 130
35}; 35};
36 36
37ieee754dp ieee754dp_sqrt(ieee754dp x) 37union ieee754dp ieee754dp_sqrt(union ieee754dp x)
38{ 38{
39 struct _ieee754_csr oldcsr; 39 struct _ieee754_csr oldcsr;
40 ieee754dp y, z, t; 40 union ieee754dp y, z, t;
41 unsigned scalx, yh; 41 unsigned scalx, yh;
42 COMPXDP; 42 COMPXDP;
43 43
diff --git a/arch/mips/math-emu/dp_sub.c b/arch/mips/math-emu/dp_sub.c
index 91e0a4b5cbc7..1e8f19ae6cd5 100644
--- a/arch/mips/math-emu/dp_sub.c
+++ b/arch/mips/math-emu/dp_sub.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754dp.h" 27#include "ieee754dp.h"
28 28
29ieee754dp ieee754dp_sub(ieee754dp x, ieee754dp y) 29union ieee754dp ieee754dp_sub(union ieee754dp x, union ieee754dp y)
30{ 30{
31 COMPXDP; 31 COMPXDP;
32 COMPYDP; 32 COMPYDP;
diff --git a/arch/mips/math-emu/dp_tint.c b/arch/mips/math-emu/dp_tint.c
index 0ebe8598b94a..2a00805fdbeb 100644
--- a/arch/mips/math-emu/dp_tint.c
+++ b/arch/mips/math-emu/dp_tint.c
@@ -27,7 +27,7 @@
27#include <linux/kernel.h> 27#include <linux/kernel.h>
28#include "ieee754dp.h" 28#include "ieee754dp.h"
29 29
30int ieee754dp_tint(ieee754dp x) 30int ieee754dp_tint(union ieee754dp x)
31{ 31{
32 COMPXDP; 32 COMPXDP;
33 33
@@ -109,9 +109,9 @@ int ieee754dp_tint(ieee754dp x)
109} 109}
110 110
111 111
112unsigned int ieee754dp_tuns(ieee754dp x) 112unsigned int ieee754dp_tuns(union ieee754dp x)
113{ 113{
114 ieee754dp hb = ieee754dp_1e31(); 114 union ieee754dp hb = ieee754dp_1e31();
115 115
116 /* what if x < 0 ?? */ 116 /* what if x < 0 ?? */
117 if (ieee754dp_lt(x, hb)) 117 if (ieee754dp_lt(x, hb))
diff --git a/arch/mips/math-emu/dp_tlong.c b/arch/mips/math-emu/dp_tlong.c
index 133ce2ba0012..3366399eebe8 100644
--- a/arch/mips/math-emu/dp_tlong.c
+++ b/arch/mips/math-emu/dp_tlong.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754dp.h" 27#include "ieee754dp.h"
28 28
29s64 ieee754dp_tlong(ieee754dp x) 29s64 ieee754dp_tlong(union ieee754dp x)
30{ 30{
31 COMPXDP; 31 COMPXDP;
32 32
@@ -112,9 +112,9 @@ s64 ieee754dp_tlong(ieee754dp x)
112} 112}
113 113
114 114
115u64 ieee754dp_tulong(ieee754dp x) 115u64 ieee754dp_tulong(union ieee754dp x)
116{ 116{
117 ieee754dp hb = ieee754dp_1e63(); 117 union ieee754dp hb = ieee754dp_1e63();
118 118
119 /* what if x < 0 ?? */ 119 /* what if x < 0 ?? */
120 if (ieee754dp_lt(x, hb)) 120 if (ieee754dp_lt(x, hb))
diff --git a/arch/mips/math-emu/ieee754.h b/arch/mips/math-emu/ieee754.h
index 9e8c26e850fe..05705fa785c3 100644
--- a/arch/mips/math-emu/ieee754.h
+++ b/arch/mips/math-emu/ieee754.h
@@ -46,7 +46,7 @@ struct ieee754dp_const {
46 ;)))) 46 ;))))
47}; 47};
48 48
49typedef union _ieee754dp { 49union ieee754dp {
50 struct ieee754dp_const oparts; 50 struct ieee754dp_const oparts;
51 struct { 51 struct {
52 __BITFIELD_FIELD(unsigned int sign:1, 52 __BITFIELD_FIELD(unsigned int sign:1,
@@ -56,7 +56,7 @@ typedef union _ieee754dp {
56 } parts; 56 } parts;
57 double d; 57 double d;
58 u64 bits; 58 u64 bits;
59} ieee754dp; 59};
60 60
61struct ieee754sp_const { 61struct ieee754sp_const {
62 __BITFIELD_FIELD(unsigned sign:1, 62 __BITFIELD_FIELD(unsigned sign:1,
@@ -65,106 +65,106 @@ struct ieee754sp_const {
65 ;))) 65 ;)))
66}; 66};
67 67
68typedef union _ieee754sp { 68union ieee754sp {
69 struct ieee754sp_const parts; 69 struct ieee754sp_const parts;
70 float f; 70 float f;
71 u32 bits; 71 u32 bits;
72} ieee754sp; 72};
73 73
74/* 74/*
75 * single precision (often aka float) 75 * single precision (often aka float)
76*/ 76*/
77int ieee754sp_finite(ieee754sp x); 77int ieee754sp_finite(union ieee754sp x);
78int ieee754sp_class(ieee754sp x); 78int ieee754sp_class(union ieee754sp x);
79 79
80ieee754sp ieee754sp_abs(ieee754sp x); 80union ieee754sp ieee754sp_abs(union ieee754sp x);
81ieee754sp ieee754sp_neg(ieee754sp x); 81union ieee754sp ieee754sp_neg(union ieee754sp x);
82ieee754sp ieee754sp_scalb(ieee754sp x, int); 82union ieee754sp ieee754sp_scalb(union ieee754sp x, int);
83ieee754sp ieee754sp_logb(ieee754sp x); 83union ieee754sp ieee754sp_logb(union ieee754sp x);
84 84
85/* x with sign of y */ 85/* x with sign of y */
86ieee754sp ieee754sp_copysign(ieee754sp x, ieee754sp y); 86union ieee754sp ieee754sp_copysign(union ieee754sp x, union ieee754sp y);
87 87
88ieee754sp ieee754sp_add(ieee754sp x, ieee754sp y); 88union ieee754sp ieee754sp_add(union ieee754sp x, union ieee754sp y);
89ieee754sp ieee754sp_sub(ieee754sp x, ieee754sp y); 89union ieee754sp ieee754sp_sub(union ieee754sp x, union ieee754sp y);
90ieee754sp ieee754sp_mul(ieee754sp x, ieee754sp y); 90union ieee754sp ieee754sp_mul(union ieee754sp x, union ieee754sp y);
91ieee754sp ieee754sp_div(ieee754sp x, ieee754sp y); 91union ieee754sp ieee754sp_div(union ieee754sp x, union ieee754sp y);
92 92
93ieee754sp ieee754sp_fint(int x); 93union ieee754sp ieee754sp_fint(int x);
94ieee754sp ieee754sp_funs(unsigned x); 94union ieee754sp ieee754sp_funs(unsigned x);
95ieee754sp ieee754sp_flong(s64 x); 95union ieee754sp ieee754sp_flong(s64 x);
96ieee754sp ieee754sp_fulong(u64 x); 96union ieee754sp ieee754sp_fulong(u64 x);
97ieee754sp ieee754sp_fdp(ieee754dp x); 97union ieee754sp ieee754sp_fdp(union ieee754dp x);
98 98
99int ieee754sp_tint(ieee754sp x); 99int ieee754sp_tint(union ieee754sp x);
100unsigned int ieee754sp_tuns(ieee754sp x); 100unsigned int ieee754sp_tuns(union ieee754sp x);
101s64 ieee754sp_tlong(ieee754sp x); 101s64 ieee754sp_tlong(union ieee754sp x);
102u64 ieee754sp_tulong(ieee754sp x); 102u64 ieee754sp_tulong(union ieee754sp x);
103 103
104int ieee754sp_cmp(ieee754sp x, ieee754sp y, int cop, int sig); 104int ieee754sp_cmp(union ieee754sp x, union ieee754sp y, int cop, int sig);
105/* 105/*
106 * basic sp math 106 * basic sp math
107 */ 107 */
108ieee754sp ieee754sp_modf(ieee754sp x, ieee754sp * ip); 108union ieee754sp ieee754sp_modf(union ieee754sp x, union ieee754sp * ip);
109ieee754sp ieee754sp_frexp(ieee754sp x, int *exp); 109union ieee754sp ieee754sp_frexp(union ieee754sp x, int *exp);
110ieee754sp ieee754sp_ldexp(ieee754sp x, int exp); 110union ieee754sp ieee754sp_ldexp(union ieee754sp x, int exp);
111 111
112ieee754sp ieee754sp_ceil(ieee754sp x); 112union ieee754sp ieee754sp_ceil(union ieee754sp x);
113ieee754sp ieee754sp_floor(ieee754sp x); 113union ieee754sp ieee754sp_floor(union ieee754sp x);
114ieee754sp ieee754sp_trunc(ieee754sp x); 114union ieee754sp ieee754sp_trunc(union ieee754sp x);
115 115
116ieee754sp ieee754sp_sqrt(ieee754sp x); 116union ieee754sp ieee754sp_sqrt(union ieee754sp x);
117 117
118/* 118/*
119 * double precision (often aka double) 119 * double precision (often aka double)
120*/ 120*/
121int ieee754dp_finite(ieee754dp x); 121int ieee754dp_finite(union ieee754dp x);
122int ieee754dp_class(ieee754dp x); 122int ieee754dp_class(union ieee754dp x);
123 123
124/* x with sign of y */ 124/* x with sign of y */
125ieee754dp ieee754dp_copysign(ieee754dp x, ieee754dp y); 125union ieee754dp ieee754dp_copysign(union ieee754dp x, union ieee754dp y);
126 126
127ieee754dp ieee754dp_add(ieee754dp x, ieee754dp y); 127union ieee754dp ieee754dp_add(union ieee754dp x, union ieee754dp y);
128ieee754dp ieee754dp_sub(ieee754dp x, ieee754dp y); 128union ieee754dp ieee754dp_sub(union ieee754dp x, union ieee754dp y);
129ieee754dp ieee754dp_mul(ieee754dp x, ieee754dp y); 129union ieee754dp ieee754dp_mul(union ieee754dp x, union ieee754dp y);
130ieee754dp ieee754dp_div(ieee754dp x, ieee754dp y); 130union ieee754dp ieee754dp_div(union ieee754dp x, union ieee754dp y);
131 131
132ieee754dp ieee754dp_abs(ieee754dp x); 132union ieee754dp ieee754dp_abs(union ieee754dp x);
133ieee754dp ieee754dp_neg(ieee754dp x); 133union ieee754dp ieee754dp_neg(union ieee754dp x);
134ieee754dp ieee754dp_scalb(ieee754dp x, int); 134union ieee754dp ieee754dp_scalb(union ieee754dp x, int);
135 135
136/* return exponent as integer in floating point format 136/* return exponent as integer in floating point format
137 */ 137 */
138ieee754dp ieee754dp_logb(ieee754dp x); 138union ieee754dp ieee754dp_logb(union ieee754dp x);
139 139
140ieee754dp ieee754dp_fint(int x); 140union ieee754dp ieee754dp_fint(int x);
141ieee754dp ieee754dp_funs(unsigned x); 141union ieee754dp ieee754dp_funs(unsigned x);
142ieee754dp ieee754dp_flong(s64 x); 142union ieee754dp ieee754dp_flong(s64 x);
143ieee754dp ieee754dp_fulong(u64 x); 143union ieee754dp ieee754dp_fulong(u64 x);
144ieee754dp ieee754dp_fsp(ieee754sp x); 144union ieee754dp ieee754dp_fsp(union ieee754sp x);
145 145
146ieee754dp ieee754dp_ceil(ieee754dp x); 146union ieee754dp ieee754dp_ceil(union ieee754dp x);
147ieee754dp ieee754dp_floor(ieee754dp x); 147union ieee754dp ieee754dp_floor(union ieee754dp x);
148ieee754dp ieee754dp_trunc(ieee754dp x); 148union ieee754dp ieee754dp_trunc(union ieee754dp x);
149 149
150int ieee754dp_tint(ieee754dp x); 150int ieee754dp_tint(union ieee754dp x);
151unsigned int ieee754dp_tuns(ieee754dp x); 151unsigned int ieee754dp_tuns(union ieee754dp x);
152s64 ieee754dp_tlong(ieee754dp x); 152s64 ieee754dp_tlong(union ieee754dp x);
153u64 ieee754dp_tulong(ieee754dp x); 153u64 ieee754dp_tulong(union ieee754dp x);
154 154
155int ieee754dp_cmp(ieee754dp x, ieee754dp y, int cop, int sig); 155int ieee754dp_cmp(union ieee754dp x, union ieee754dp y, int cop, int sig);
156/* 156/*
157 * basic sp math 157 * basic sp math
158 */ 158 */
159ieee754dp ieee754dp_modf(ieee754dp x, ieee754dp * ip); 159union ieee754dp ieee754dp_modf(union ieee754dp x, union ieee754dp * ip);
160ieee754dp ieee754dp_frexp(ieee754dp x, int *exp); 160union ieee754dp ieee754dp_frexp(union ieee754dp x, int *exp);
161ieee754dp ieee754dp_ldexp(ieee754dp x, int exp); 161union ieee754dp ieee754dp_ldexp(union ieee754dp x, int exp);
162 162
163ieee754dp ieee754dp_ceil(ieee754dp x); 163union ieee754dp ieee754dp_ceil(union ieee754dp x);
164ieee754dp ieee754dp_floor(ieee754dp x); 164union ieee754dp ieee754dp_floor(union ieee754dp x);
165ieee754dp ieee754dp_trunc(ieee754dp x); 165union ieee754dp ieee754dp_trunc(union ieee754dp x);
166 166
167ieee754dp ieee754dp_sqrt(ieee754dp x); 167union ieee754dp ieee754dp_sqrt(union ieee754dp x);
168 168
169 169
170 170
@@ -204,65 +204,65 @@ ieee754dp ieee754dp_sqrt(ieee754dp x);
204 204
205/* "normal" comparisons 205/* "normal" comparisons
206*/ 206*/
207static inline int ieee754sp_eq(ieee754sp x, ieee754sp y) 207static inline int ieee754sp_eq(union ieee754sp x, union ieee754sp y)
208{ 208{
209 return ieee754sp_cmp(x, y, IEEE754_CEQ, 0); 209 return ieee754sp_cmp(x, y, IEEE754_CEQ, 0);
210} 210}
211 211
212static inline int ieee754sp_ne(ieee754sp x, ieee754sp y) 212static inline int ieee754sp_ne(union ieee754sp x, union ieee754sp y)
213{ 213{
214 return ieee754sp_cmp(x, y, 214 return ieee754sp_cmp(x, y,
215 IEEE754_CLT | IEEE754_CGT | IEEE754_CUN, 0); 215 IEEE754_CLT | IEEE754_CGT | IEEE754_CUN, 0);
216} 216}
217 217
218static inline int ieee754sp_lt(ieee754sp x, ieee754sp y) 218static inline int ieee754sp_lt(union ieee754sp x, union ieee754sp y)
219{ 219{
220 return ieee754sp_cmp(x, y, IEEE754_CLT, 0); 220 return ieee754sp_cmp(x, y, IEEE754_CLT, 0);
221} 221}
222 222
223static inline int ieee754sp_le(ieee754sp x, ieee754sp y) 223static inline int ieee754sp_le(union ieee754sp x, union ieee754sp y)
224{ 224{
225 return ieee754sp_cmp(x, y, IEEE754_CLT | IEEE754_CEQ, 0); 225 return ieee754sp_cmp(x, y, IEEE754_CLT | IEEE754_CEQ, 0);
226} 226}
227 227
228static inline int ieee754sp_gt(ieee754sp x, ieee754sp y) 228static inline int ieee754sp_gt(union ieee754sp x, union ieee754sp y)
229{ 229{
230 return ieee754sp_cmp(x, y, IEEE754_CGT, 0); 230 return ieee754sp_cmp(x, y, IEEE754_CGT, 0);
231} 231}
232 232
233 233
234static inline int ieee754sp_ge(ieee754sp x, ieee754sp y) 234static inline int ieee754sp_ge(union ieee754sp x, union ieee754sp y)
235{ 235{
236 return ieee754sp_cmp(x, y, IEEE754_CGT | IEEE754_CEQ, 0); 236 return ieee754sp_cmp(x, y, IEEE754_CGT | IEEE754_CEQ, 0);
237} 237}
238 238
239static inline int ieee754dp_eq(ieee754dp x, ieee754dp y) 239static inline int ieee754dp_eq(union ieee754dp x, union ieee754dp y)
240{ 240{
241 return ieee754dp_cmp(x, y, IEEE754_CEQ, 0); 241 return ieee754dp_cmp(x, y, IEEE754_CEQ, 0);
242} 242}
243 243
244static inline int ieee754dp_ne(ieee754dp x, ieee754dp y) 244static inline int ieee754dp_ne(union ieee754dp x, union ieee754dp y)
245{ 245{
246 return ieee754dp_cmp(x, y, 246 return ieee754dp_cmp(x, y,
247 IEEE754_CLT | IEEE754_CGT | IEEE754_CUN, 0); 247 IEEE754_CLT | IEEE754_CGT | IEEE754_CUN, 0);
248} 248}
249 249
250static inline int ieee754dp_lt(ieee754dp x, ieee754dp y) 250static inline int ieee754dp_lt(union ieee754dp x, union ieee754dp y)
251{ 251{
252 return ieee754dp_cmp(x, y, IEEE754_CLT, 0); 252 return ieee754dp_cmp(x, y, IEEE754_CLT, 0);
253} 253}
254 254
255static inline int ieee754dp_le(ieee754dp x, ieee754dp y) 255static inline int ieee754dp_le(union ieee754dp x, union ieee754dp y)
256{ 256{
257 return ieee754dp_cmp(x, y, IEEE754_CLT | IEEE754_CEQ, 0); 257 return ieee754dp_cmp(x, y, IEEE754_CLT | IEEE754_CEQ, 0);
258} 258}
259 259
260static inline int ieee754dp_gt(ieee754dp x, ieee754dp y) 260static inline int ieee754dp_gt(union ieee754dp x, union ieee754dp y)
261{ 261{
262 return ieee754dp_cmp(x, y, IEEE754_CGT, 0); 262 return ieee754dp_cmp(x, y, IEEE754_CGT, 0);
263} 263}
264 264
265static inline int ieee754dp_ge(ieee754dp x, ieee754dp y) 265static inline int ieee754dp_ge(union ieee754dp x, union ieee754dp y)
266{ 266{
267 return ieee754dp_cmp(x, y, IEEE754_CGT | IEEE754_CEQ, 0); 267 return ieee754dp_cmp(x, y, IEEE754_CGT | IEEE754_CEQ, 0);
268} 268}
@@ -271,8 +271,8 @@ static inline int ieee754dp_ge(ieee754dp x, ieee754dp y)
271/* 271/*
272 * Like strtod 272 * Like strtod
273 */ 273 */
274ieee754dp ieee754dp_fstr(const char *s, char **endp); 274union ieee754dp ieee754dp_fstr(const char *s, char **endp);
275char *ieee754dp_tstr(ieee754dp x, int prec, int fmt, int af); 275char *ieee754dp_tstr(union ieee754dp x, int prec, int fmt, int af);
276 276
277 277
278/* 278/*
@@ -338,8 +338,8 @@ static inline int ieee754_sxtest(unsigned n)
338} 338}
339 339
340/* debugging */ 340/* debugging */
341ieee754sp ieee754sp_dump(char *s, ieee754sp x); 341union ieee754sp ieee754sp_dump(char *s, union ieee754sp x);
342ieee754dp ieee754dp_dump(char *s, ieee754dp x); 342union ieee754dp ieee754dp_dump(char *s, union ieee754dp x);
343 343
344#define IEEE754_SPCVAL_PZERO 0 344#define IEEE754_SPCVAL_PZERO 0
345#define IEEE754_SPCVAL_NZERO 1 345#define IEEE754_SPCVAL_NZERO 1
@@ -361,8 +361,8 @@ ieee754dp ieee754dp_dump(char *s, ieee754dp x);
361 361
362extern const struct ieee754dp_const __ieee754dp_spcvals[]; 362extern const struct ieee754dp_const __ieee754dp_spcvals[];
363extern const struct ieee754sp_const __ieee754sp_spcvals[]; 363extern const struct ieee754sp_const __ieee754sp_spcvals[];
364#define ieee754dp_spcvals ((const ieee754dp *)__ieee754dp_spcvals) 364#define ieee754dp_spcvals ((const union ieee754dp *)__ieee754dp_spcvals)
365#define ieee754sp_spcvals ((const ieee754sp *)__ieee754sp_spcvals) 365#define ieee754sp_spcvals ((const union ieee754sp *)__ieee754sp_spcvals)
366 366
367/* 367/*
368 * Return infinity with given sign 368 * Return infinity with given sign
@@ -404,8 +404,8 @@ struct ieee754xctx {
404 const char *op; /* operation name */ 404 const char *op; /* operation name */
405 int rt; /* result type */ 405 int rt; /* result type */
406 union { 406 union {
407 ieee754sp sp; /* single precision */ 407 union ieee754sp sp; /* single precision */
408 ieee754dp dp; /* double precision */ 408 union ieee754dp dp; /* double precision */
409#ifdef IEEE854_XP 409#ifdef IEEE854_XP
410 ieee754xp xp; /* extended precision */ 410 ieee754xp xp; /* extended precision */
411#endif 411#endif
diff --git a/arch/mips/math-emu/ieee754d.c b/arch/mips/math-emu/ieee754d.c
index 9599bdd32585..627932839d57 100644
--- a/arch/mips/math-emu/ieee754d.c
+++ b/arch/mips/math-emu/ieee754d.c
@@ -56,7 +56,7 @@
56#define DPBEXP(dp) (dp.parts.bexp) 56#define DPBEXP(dp) (dp.parts.bexp)
57#define DPMANT(dp) (dp.parts.mant) 57#define DPMANT(dp) (dp.parts.mant)
58 58
59ieee754dp ieee754dp_dump(char *m, ieee754dp x) 59union ieee754dp ieee754dp_dump(char *m, union ieee754dp x)
60{ 60{
61 int i; 61 int i;
62 62
@@ -96,7 +96,7 @@ ieee754dp ieee754dp_dump(char *m, ieee754dp x)
96 return x; 96 return x;
97} 97}
98 98
99ieee754sp ieee754sp_dump(char *m, ieee754sp x) 99union ieee754sp ieee754sp_dump(char *m, union ieee754sp x)
100{ 100{
101 int i; 101 int i;
102 102
diff --git a/arch/mips/math-emu/ieee754dp.c b/arch/mips/math-emu/ieee754dp.c
index df59d16bd4fd..3692362b8072 100644
--- a/arch/mips/math-emu/ieee754dp.c
+++ b/arch/mips/math-emu/ieee754dp.c
@@ -27,26 +27,26 @@
27 27
28#include "ieee754dp.h" 28#include "ieee754dp.h"
29 29
30int ieee754dp_class(ieee754dp x) 30int ieee754dp_class(union ieee754dp x)
31{ 31{
32 COMPXDP; 32 COMPXDP;
33 EXPLODEXDP; 33 EXPLODEXDP;
34 return xc; 34 return xc;
35} 35}
36 36
37int ieee754dp_isnan(ieee754dp x) 37int ieee754dp_isnan(union ieee754dp x)
38{ 38{
39 return ieee754dp_class(x) >= IEEE754_CLASS_SNAN; 39 return ieee754dp_class(x) >= IEEE754_CLASS_SNAN;
40} 40}
41 41
42int ieee754dp_issnan(ieee754dp x) 42int ieee754dp_issnan(union ieee754dp x)
43{ 43{
44 assert(ieee754dp_isnan(x)); 44 assert(ieee754dp_isnan(x));
45 return ((DPMANT(x) & DP_MBIT(DP_MBITS-1)) == DP_MBIT(DP_MBITS-1)); 45 return ((DPMANT(x) & DP_MBIT(DP_MBITS-1)) == DP_MBIT(DP_MBITS-1));
46} 46}
47 47
48 48
49ieee754dp __cold ieee754dp_xcpt(ieee754dp r, const char *op, ...) 49union ieee754dp __cold ieee754dp_xcpt(union ieee754dp r, const char *op, ...)
50{ 50{
51 struct ieee754xctx ax; 51 struct ieee754xctx ax;
52 if (!TSTX()) 52 if (!TSTX())
@@ -61,7 +61,7 @@ ieee754dp __cold ieee754dp_xcpt(ieee754dp r, const char *op, ...)
61 return ax.rv.dp; 61 return ax.rv.dp;
62} 62}
63 63
64ieee754dp __cold ieee754dp_nanxcpt(ieee754dp r, const char *op, ...) 64union ieee754dp __cold ieee754dp_nanxcpt(union ieee754dp r, const char *op, ...)
65{ 65{
66 struct ieee754xctx ax; 66 struct ieee754xctx ax;
67 67
@@ -88,7 +88,7 @@ ieee754dp __cold ieee754dp_nanxcpt(ieee754dp r, const char *op, ...)
88 return ax.rv.dp; 88 return ax.rv.dp;
89} 89}
90 90
91ieee754dp ieee754dp_bestnan(ieee754dp x, ieee754dp y) 91union ieee754dp ieee754dp_bestnan(union ieee754dp x, union ieee754dp y)
92{ 92{
93 assert(ieee754dp_isnan(x)); 93 assert(ieee754dp_isnan(x));
94 assert(ieee754dp_isnan(y)); 94 assert(ieee754dp_isnan(y));
@@ -131,7 +131,7 @@ static u64 get_rounding(int sn, u64 xm)
131 * xe is an unbiased exponent 131 * xe is an unbiased exponent
132 * xm is 3bit extended precision value. 132 * xm is 3bit extended precision value.
133 */ 133 */
134ieee754dp ieee754dp_format(int sn, int xe, u64 xm) 134union ieee754dp ieee754dp_format(int sn, int xe, u64 xm)
135{ 135{
136 assert(xm); /* we don't gen exact zeros (probably should) */ 136 assert(xm); /* we don't gen exact zeros (probably should) */
137 137
diff --git a/arch/mips/math-emu/ieee754dp.h b/arch/mips/math-emu/ieee754dp.h
index ce2af5b04b48..ad2568fa0b05 100644
--- a/arch/mips/math-emu/ieee754dp.h
+++ b/arch/mips/math-emu/ieee754dp.h
@@ -46,9 +46,9 @@
46#define DPDNORMX DPDNORMx(xm, xe) 46#define DPDNORMX DPDNORMx(xm, xe)
47#define DPDNORMY DPDNORMx(ym, ye) 47#define DPDNORMY DPDNORMx(ym, ye)
48 48
49static inline ieee754dp builddp(int s, int bx, u64 m) 49static inline union ieee754dp builddp(int s, int bx, u64 m)
50{ 50{
51 ieee754dp r; 51 union ieee754dp r;
52 52
53 assert((s) == 0 || (s) == 1); 53 assert((s) == 0 || (s) == 1);
54 assert((bx) >= DP_EMIN - 1 + DP_EBIAS 54 assert((bx) >= DP_EMIN - 1 + DP_EBIAS
@@ -61,19 +61,19 @@ static inline ieee754dp builddp(int s, int bx, u64 m)
61 return r; 61 return r;
62} 62}
63 63
64extern int ieee754dp_isnan(ieee754dp); 64extern int ieee754dp_isnan(union ieee754dp);
65extern int ieee754dp_issnan(ieee754dp); 65extern int ieee754dp_issnan(union ieee754dp);
66extern int __cold ieee754si_xcpt(int, const char *, ...); 66extern int __cold ieee754si_xcpt(int, const char *, ...);
67extern s64 __cold ieee754di_xcpt(s64, const char *, ...); 67extern s64 __cold ieee754di_xcpt(s64, const char *, ...);
68extern ieee754dp __cold ieee754dp_xcpt(ieee754dp, const char *, ...); 68extern union ieee754dp __cold ieee754dp_xcpt(union ieee754dp, const char *, ...);
69extern ieee754dp __cold ieee754dp_nanxcpt(ieee754dp, const char *, ...); 69extern union ieee754dp __cold ieee754dp_nanxcpt(union ieee754dp, const char *, ...);
70extern ieee754dp ieee754dp_bestnan(ieee754dp, ieee754dp); 70extern union ieee754dp ieee754dp_bestnan(union ieee754dp, union ieee754dp);
71extern ieee754dp ieee754dp_format(int, int, u64); 71extern union ieee754dp ieee754dp_format(int, int, u64);
72 72
73 73
74#define DPNORMRET2(s, e, m, name, a0, a1) \ 74#define DPNORMRET2(s, e, m, name, a0, a1) \
75{ \ 75{ \
76 ieee754dp V = ieee754dp_format(s, e, m); \ 76 union ieee754dp V = ieee754dp_format(s, e, m); \
77 if(TSTX()) \ 77 if(TSTX()) \
78 return ieee754dp_xcpt(V, name, a0, a1); \ 78 return ieee754dp_xcpt(V, name, a0, a1); \
79 else \ 79 else \
diff --git a/arch/mips/math-emu/ieee754m.c b/arch/mips/math-emu/ieee754m.c
index 24190f3c9dd6..06224064333b 100644
--- a/arch/mips/math-emu/ieee754m.c
+++ b/arch/mips/math-emu/ieee754m.c
@@ -26,9 +26,9 @@
26 26
27#include "ieee754.h" 27#include "ieee754.h"
28 28
29ieee754dp ieee754dp_floor(ieee754dp x) 29union ieee754dp ieee754dp_floor(union ieee754dp x)
30{ 30{
31 ieee754dp i; 31 union ieee754dp i;
32 32
33 if (ieee754dp_lt(ieee754dp_modf(x, &i), ieee754dp_zero(0))) 33 if (ieee754dp_lt(ieee754dp_modf(x, &i), ieee754dp_zero(0)))
34 return ieee754dp_sub(i, ieee754dp_one(0)); 34 return ieee754dp_sub(i, ieee754dp_one(0));
@@ -36,9 +36,9 @@ ieee754dp ieee754dp_floor(ieee754dp x)
36 return i; 36 return i;
37} 37}
38 38
39ieee754dp ieee754dp_ceil(ieee754dp x) 39union ieee754dp ieee754dp_ceil(union ieee754dp x)
40{ 40{
41 ieee754dp i; 41 union ieee754dp i;
42 42
43 if (ieee754dp_gt(ieee754dp_modf(x, &i), ieee754dp_zero(0))) 43 if (ieee754dp_gt(ieee754dp_modf(x, &i), ieee754dp_zero(0)))
44 return ieee754dp_add(i, ieee754dp_one(0)); 44 return ieee754dp_add(i, ieee754dp_one(0));
@@ -46,9 +46,9 @@ ieee754dp ieee754dp_ceil(ieee754dp x)
46 return i; 46 return i;
47} 47}
48 48
49ieee754dp ieee754dp_trunc(ieee754dp x) 49union ieee754dp ieee754dp_trunc(union ieee754dp x)
50{ 50{
51 ieee754dp i; 51 union ieee754dp i;
52 52
53 (void) ieee754dp_modf(x, &i); 53 (void) ieee754dp_modf(x, &i);
54 return i; 54 return i;
diff --git a/arch/mips/math-emu/ieee754sp.c b/arch/mips/math-emu/ieee754sp.c
index dd3ecd62e469..ac84d19e7c87 100644
--- a/arch/mips/math-emu/ieee754sp.c
+++ b/arch/mips/math-emu/ieee754sp.c
@@ -27,26 +27,26 @@
27 27
28#include "ieee754sp.h" 28#include "ieee754sp.h"
29 29
30int ieee754sp_class(ieee754sp x) 30int ieee754sp_class(union ieee754sp x)
31{ 31{
32 COMPXSP; 32 COMPXSP;
33 EXPLODEXSP; 33 EXPLODEXSP;
34 return xc; 34 return xc;
35} 35}
36 36
37int ieee754sp_isnan(ieee754sp x) 37int ieee754sp_isnan(union ieee754sp x)
38{ 38{
39 return ieee754sp_class(x) >= IEEE754_CLASS_SNAN; 39 return ieee754sp_class(x) >= IEEE754_CLASS_SNAN;
40} 40}
41 41
42int ieee754sp_issnan(ieee754sp x) 42int ieee754sp_issnan(union ieee754sp x)
43{ 43{
44 assert(ieee754sp_isnan(x)); 44 assert(ieee754sp_isnan(x));
45 return (SPMANT(x) & SP_MBIT(SP_MBITS-1)); 45 return (SPMANT(x) & SP_MBIT(SP_MBITS-1));
46} 46}
47 47
48 48
49ieee754sp __cold ieee754sp_xcpt(ieee754sp r, const char *op, ...) 49union ieee754sp __cold ieee754sp_xcpt(union ieee754sp r, const char *op, ...)
50{ 50{
51 struct ieee754xctx ax; 51 struct ieee754xctx ax;
52 52
@@ -62,7 +62,7 @@ ieee754sp __cold ieee754sp_xcpt(ieee754sp r, const char *op, ...)
62 return ax.rv.sp; 62 return ax.rv.sp;
63} 63}
64 64
65ieee754sp __cold ieee754sp_nanxcpt(ieee754sp r, const char *op, ...) 65union ieee754sp __cold ieee754sp_nanxcpt(union ieee754sp r, const char *op, ...)
66{ 66{
67 struct ieee754xctx ax; 67 struct ieee754xctx ax;
68 68
@@ -89,7 +89,7 @@ ieee754sp __cold ieee754sp_nanxcpt(ieee754sp r, const char *op, ...)
89 return ax.rv.sp; 89 return ax.rv.sp;
90} 90}
91 91
92ieee754sp ieee754sp_bestnan(ieee754sp x, ieee754sp y) 92union ieee754sp ieee754sp_bestnan(union ieee754sp x, union ieee754sp y)
93{ 93{
94 assert(ieee754sp_isnan(x)); 94 assert(ieee754sp_isnan(x));
95 assert(ieee754sp_isnan(y)); 95 assert(ieee754sp_isnan(y));
@@ -132,7 +132,7 @@ static unsigned get_rounding(int sn, unsigned xm)
132 * xe is an unbiased exponent 132 * xe is an unbiased exponent
133 * xm is 3bit extended precision value. 133 * xm is 3bit extended precision value.
134 */ 134 */
135ieee754sp ieee754sp_format(int sn, int xe, unsigned xm) 135union ieee754sp ieee754sp_format(int sn, int xe, unsigned xm)
136{ 136{
137 assert(xm); /* we don't gen exact zeros (probably should) */ 137 assert(xm); /* we don't gen exact zeros (probably should) */
138 138
diff --git a/arch/mips/math-emu/ieee754sp.h b/arch/mips/math-emu/ieee754sp.h
index e3933bed0be4..5836fa1e69d8 100644
--- a/arch/mips/math-emu/ieee754sp.h
+++ b/arch/mips/math-emu/ieee754sp.h
@@ -51,9 +51,9 @@
51#define SPDNORMX SPDNORMx(xm, xe) 51#define SPDNORMX SPDNORMx(xm, xe)
52#define SPDNORMY SPDNORMx(ym, ye) 52#define SPDNORMY SPDNORMx(ym, ye)
53 53
54static inline ieee754sp buildsp(int s, int bx, unsigned m) 54static inline union ieee754sp buildsp(int s, int bx, unsigned m)
55{ 55{
56 ieee754sp r; 56 union ieee754sp r;
57 57
58 assert((s) == 0 || (s) == 1); 58 assert((s) == 0 || (s) == 1);
59 assert((bx) >= SP_EMIN - 1 + SP_EBIAS 59 assert((bx) >= SP_EMIN - 1 + SP_EBIAS
@@ -67,19 +67,19 @@ static inline ieee754sp buildsp(int s, int bx, unsigned m)
67 return r; 67 return r;
68} 68}
69 69
70extern int ieee754sp_isnan(ieee754sp); 70extern int ieee754sp_isnan(union ieee754sp);
71extern int ieee754sp_issnan(ieee754sp); 71extern int ieee754sp_issnan(union ieee754sp);
72extern int __cold ieee754si_xcpt(int, const char *, ...); 72extern int __cold ieee754si_xcpt(int, const char *, ...);
73extern s64 __cold ieee754di_xcpt(s64, const char *, ...); 73extern s64 __cold ieee754di_xcpt(s64, const char *, ...);
74extern ieee754sp __cold ieee754sp_xcpt(ieee754sp, const char *, ...); 74extern union ieee754sp __cold ieee754sp_xcpt(union ieee754sp, const char *, ...);
75extern ieee754sp __cold ieee754sp_nanxcpt(ieee754sp, const char *, ...); 75extern union ieee754sp __cold ieee754sp_nanxcpt(union ieee754sp, const char *, ...);
76extern ieee754sp ieee754sp_bestnan(ieee754sp, ieee754sp); 76extern union ieee754sp ieee754sp_bestnan(union ieee754sp, union ieee754sp);
77extern ieee754sp ieee754sp_format(int, int, unsigned); 77extern union ieee754sp ieee754sp_format(int, int, unsigned);
78 78
79 79
80#define SPNORMRET2(s, e, m, name, a0, a1) \ 80#define SPNORMRET2(s, e, m, name, a0, a1) \
81{ \ 81{ \
82 ieee754sp V = ieee754sp_format(s, e, m); \ 82 union ieee754sp V = ieee754sp_format(s, e, m); \
83 if(TSTX()) \ 83 if(TSTX()) \
84 return ieee754sp_xcpt(V, name, a0, a1); \ 84 return ieee754sp_xcpt(V, name, a0, a1); \
85 else \ 85 else \
diff --git a/arch/mips/math-emu/sp_add.c b/arch/mips/math-emu/sp_add.c
index c446e64637e2..4938d8f1d4bc 100644
--- a/arch/mips/math-emu/sp_add.c
+++ b/arch/mips/math-emu/sp_add.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754sp.h" 27#include "ieee754sp.h"
28 28
29ieee754sp ieee754sp_add(ieee754sp x, ieee754sp y) 29union ieee754sp ieee754sp_add(union ieee754sp x, union ieee754sp y)
30{ 30{
31 COMPXSP; 31 COMPXSP;
32 COMPYSP; 32 COMPYSP;
diff --git a/arch/mips/math-emu/sp_cmp.c b/arch/mips/math-emu/sp_cmp.c
index 716cf37e2465..b98d68617cfe 100644
--- a/arch/mips/math-emu/sp_cmp.c
+++ b/arch/mips/math-emu/sp_cmp.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754sp.h" 27#include "ieee754sp.h"
28 28
29int ieee754sp_cmp(ieee754sp x, ieee754sp y, int cmp, int sig) 29int ieee754sp_cmp(union ieee754sp x, union ieee754sp y, int cmp, int sig)
30{ 30{
31 COMPXSP; 31 COMPXSP;
32 COMPYSP; 32 COMPYSP;
diff --git a/arch/mips/math-emu/sp_div.c b/arch/mips/math-emu/sp_div.c
index d7747928c954..1f62865ffcbd 100644
--- a/arch/mips/math-emu/sp_div.c
+++ b/arch/mips/math-emu/sp_div.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754sp.h" 27#include "ieee754sp.h"
28 28
29ieee754sp ieee754sp_div(ieee754sp x, ieee754sp y) 29union ieee754sp ieee754sp_div(union ieee754sp x, union ieee754sp y)
30{ 30{
31 COMPXSP; 31 COMPXSP;
32 COMPYSP; 32 COMPYSP;
diff --git a/arch/mips/math-emu/sp_fdp.c b/arch/mips/math-emu/sp_fdp.c
index e1515aae0166..cbefb88a14ef 100644
--- a/arch/mips/math-emu/sp_fdp.c
+++ b/arch/mips/math-emu/sp_fdp.c
@@ -26,10 +26,10 @@
26 26
27#include "ieee754sp.h" 27#include "ieee754sp.h"
28 28
29ieee754sp ieee754sp_fdp(ieee754dp x) 29union ieee754sp ieee754sp_fdp(union ieee754dp x)
30{ 30{
31 COMPXDP; 31 COMPXDP;
32 ieee754sp nan; 32 union ieee754sp nan;
33 33
34 EXPLODEXDP; 34 EXPLODEXDP;
35 35
diff --git a/arch/mips/math-emu/sp_fint.c b/arch/mips/math-emu/sp_fint.c
index 9694d6c016cb..7ba2b40348c4 100644
--- a/arch/mips/math-emu/sp_fint.c
+++ b/arch/mips/math-emu/sp_fint.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754sp.h" 27#include "ieee754sp.h"
28 28
29ieee754sp ieee754sp_fint(int x) 29union ieee754sp ieee754sp_fint(int x)
30{ 30{
31 unsigned xm; 31 unsigned xm;
32 int xe; 32 int xe;
@@ -70,7 +70,7 @@ ieee754sp ieee754sp_fint(int x)
70} 70}
71 71
72 72
73ieee754sp ieee754sp_funs(unsigned int u) 73union ieee754sp ieee754sp_funs(unsigned int u)
74{ 74{
75 if ((int) u < 0) 75 if ((int) u < 0)
76 return ieee754sp_add(ieee754sp_1e31(), 76 return ieee754sp_add(ieee754sp_1e31(),
diff --git a/arch/mips/math-emu/sp_flong.c b/arch/mips/math-emu/sp_flong.c
index 16a651f29865..c457a9f8a148 100644
--- a/arch/mips/math-emu/sp_flong.c
+++ b/arch/mips/math-emu/sp_flong.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754sp.h" 27#include "ieee754sp.h"
28 28
29ieee754sp ieee754sp_flong(s64 x) 29union ieee754sp ieee754sp_flong(s64 x)
30{ 30{
31 u64 xm; /* <--- need 64-bit mantissa temp */ 31 u64 xm; /* <--- need 64-bit mantissa temp */
32 int xe; 32 int xe;
@@ -69,7 +69,7 @@ ieee754sp ieee754sp_flong(s64 x)
69} 69}
70 70
71 71
72ieee754sp ieee754sp_fulong(u64 u) 72union ieee754sp ieee754sp_fulong(u64 u)
73{ 73{
74 if ((s64) u < 0) 74 if ((s64) u < 0)
75 return ieee754sp_add(ieee754sp_1e63(), 75 return ieee754sp_add(ieee754sp_1e63(),
diff --git a/arch/mips/math-emu/sp_frexp.c b/arch/mips/math-emu/sp_frexp.c
index 5bc993c30044..668252bca513 100644
--- a/arch/mips/math-emu/sp_frexp.c
+++ b/arch/mips/math-emu/sp_frexp.c
@@ -28,7 +28,7 @@
28 28
29/* close to ieeep754sp_logb 29/* close to ieeep754sp_logb
30*/ 30*/
31ieee754sp ieee754sp_frexp(ieee754sp x, int *eptr) 31union ieee754sp ieee754sp_frexp(union ieee754sp x, int *eptr)
32{ 32{
33 COMPXSP; 33 COMPXSP;
34 CLEARCX; 34 CLEARCX;
diff --git a/arch/mips/math-emu/sp_logb.c b/arch/mips/math-emu/sp_logb.c
index 9c14e0c75bd2..4dfe5386e89d 100644
--- a/arch/mips/math-emu/sp_logb.c
+++ b/arch/mips/math-emu/sp_logb.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754sp.h" 27#include "ieee754sp.h"
28 28
29ieee754sp ieee754sp_logb(ieee754sp x) 29union ieee754sp ieee754sp_logb(union ieee754sp x)
30{ 30{
31 COMPXSP; 31 COMPXSP;
32 32
diff --git a/arch/mips/math-emu/sp_modf.c b/arch/mips/math-emu/sp_modf.c
index 25a0fbaa0556..30d53ec1f7eb 100644
--- a/arch/mips/math-emu/sp_modf.c
+++ b/arch/mips/math-emu/sp_modf.c
@@ -28,7 +28,7 @@
28 28
29/* modf function is always exact for a finite number 29/* modf function is always exact for a finite number
30*/ 30*/
31ieee754sp ieee754sp_modf(ieee754sp x, ieee754sp *ip) 31union ieee754sp ieee754sp_modf(union ieee754sp x, union ieee754sp *ip)
32{ 32{
33 COMPXSP; 33 COMPXSP;
34 34
diff --git a/arch/mips/math-emu/sp_mul.c b/arch/mips/math-emu/sp_mul.c
index fa4675cf2aad..c628f3c495dc 100644
--- a/arch/mips/math-emu/sp_mul.c
+++ b/arch/mips/math-emu/sp_mul.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754sp.h" 27#include "ieee754sp.h"
28 28
29ieee754sp ieee754sp_mul(ieee754sp x, ieee754sp y) 29union ieee754sp ieee754sp_mul(union ieee754sp x, union ieee754sp y)
30{ 30{
31 COMPXSP; 31 COMPXSP;
32 COMPYSP; 32 COMPYSP;
diff --git a/arch/mips/math-emu/sp_scalb.c b/arch/mips/math-emu/sp_scalb.c
index dd76196984c8..9831d428af6f 100644
--- a/arch/mips/math-emu/sp_scalb.c
+++ b/arch/mips/math-emu/sp_scalb.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754sp.h" 27#include "ieee754sp.h"
28 28
29ieee754sp ieee754sp_scalb(ieee754sp x, int n) 29union ieee754sp ieee754sp_scalb(union ieee754sp x, int n)
30{ 30{
31 COMPXSP; 31 COMPXSP;
32 32
@@ -51,7 +51,7 @@ ieee754sp ieee754sp_scalb(ieee754sp x, int n)
51} 51}
52 52
53 53
54ieee754sp ieee754sp_ldexp(ieee754sp x, int n) 54union ieee754sp ieee754sp_ldexp(union ieee754sp x, int n)
55{ 55{
56 return ieee754sp_scalb(x, n); 56 return ieee754sp_scalb(x, n);
57} 57}
diff --git a/arch/mips/math-emu/sp_simple.c b/arch/mips/math-emu/sp_simple.c
index ae4fcfafd853..633c7a54cf1e 100644
--- a/arch/mips/math-emu/sp_simple.c
+++ b/arch/mips/math-emu/sp_simple.c
@@ -26,12 +26,12 @@
26 26
27#include "ieee754sp.h" 27#include "ieee754sp.h"
28 28
29int ieee754sp_finite(ieee754sp x) 29int ieee754sp_finite(union ieee754sp x)
30{ 30{
31 return SPBEXP(x) != SP_EMAX + 1 + SP_EBIAS; 31 return SPBEXP(x) != SP_EMAX + 1 + SP_EBIAS;
32} 32}
33 33
34ieee754sp ieee754sp_copysign(ieee754sp x, ieee754sp y) 34union ieee754sp ieee754sp_copysign(union ieee754sp x, union ieee754sp y)
35{ 35{
36 CLEARCX; 36 CLEARCX;
37 SPSIGN(x) = SPSIGN(y); 37 SPSIGN(x) = SPSIGN(y);
@@ -39,7 +39,7 @@ ieee754sp ieee754sp_copysign(ieee754sp x, ieee754sp y)
39} 39}
40 40
41 41
42ieee754sp ieee754sp_neg(ieee754sp x) 42union ieee754sp ieee754sp_neg(union ieee754sp x)
43{ 43{
44 COMPXSP; 44 COMPXSP;
45 45
@@ -55,7 +55,7 @@ ieee754sp ieee754sp_neg(ieee754sp x)
55 SPSIGN(x) ^= 1; 55 SPSIGN(x) ^= 1;
56 56
57 if (xc == IEEE754_CLASS_SNAN) { 57 if (xc == IEEE754_CLASS_SNAN) {
58 ieee754sp y = ieee754sp_indef(); 58 union ieee754sp y = ieee754sp_indef();
59 SETCX(IEEE754_INVALID_OPERATION); 59 SETCX(IEEE754_INVALID_OPERATION);
60 SPSIGN(y) = SPSIGN(x); 60 SPSIGN(y) = SPSIGN(x);
61 return ieee754sp_nanxcpt(y, "neg"); 61 return ieee754sp_nanxcpt(y, "neg");
@@ -65,7 +65,7 @@ ieee754sp ieee754sp_neg(ieee754sp x)
65} 65}
66 66
67 67
68ieee754sp ieee754sp_abs(ieee754sp x) 68union ieee754sp ieee754sp_abs(union ieee754sp x)
69{ 69{
70 COMPXSP; 70 COMPXSP;
71 71
diff --git a/arch/mips/math-emu/sp_sqrt.c b/arch/mips/math-emu/sp_sqrt.c
index fed20175f5fb..4c60d91961f4 100644
--- a/arch/mips/math-emu/sp_sqrt.c
+++ b/arch/mips/math-emu/sp_sqrt.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754sp.h" 27#include "ieee754sp.h"
28 28
29ieee754sp ieee754sp_sqrt(ieee754sp x) 29union ieee754sp ieee754sp_sqrt(union ieee754sp x)
30{ 30{
31 int ix, s, q, m, t, i; 31 int ix, s, q, m, t, i;
32 unsigned int r; 32 unsigned int r;
diff --git a/arch/mips/math-emu/sp_sub.c b/arch/mips/math-emu/sp_sub.c
index e595c6f3d0bb..ed67acfb114f 100644
--- a/arch/mips/math-emu/sp_sub.c
+++ b/arch/mips/math-emu/sp_sub.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754sp.h" 27#include "ieee754sp.h"
28 28
29ieee754sp ieee754sp_sub(ieee754sp x, ieee754sp y) 29union ieee754sp ieee754sp_sub(union ieee754sp x, union ieee754sp y)
30{ 30{
31 COMPXSP; 31 COMPXSP;
32 COMPYSP; 32 COMPYSP;
diff --git a/arch/mips/math-emu/sp_tint.c b/arch/mips/math-emu/sp_tint.c
index 0fe9acc7716e..37cb096ee931 100644
--- a/arch/mips/math-emu/sp_tint.c
+++ b/arch/mips/math-emu/sp_tint.c
@@ -27,7 +27,7 @@
27#include <linux/kernel.h> 27#include <linux/kernel.h>
28#include "ieee754sp.h" 28#include "ieee754sp.h"
29 29
30int ieee754sp_tint(ieee754sp x) 30int ieee754sp_tint(union ieee754sp x)
31{ 31{
32 COMPXSP; 32 COMPXSP;
33 33
@@ -113,9 +113,9 @@ int ieee754sp_tint(ieee754sp x)
113} 113}
114 114
115 115
116unsigned int ieee754sp_tuns(ieee754sp x) 116unsigned int ieee754sp_tuns(union ieee754sp x)
117{ 117{
118 ieee754sp hb = ieee754sp_1e31(); 118 union ieee754sp hb = ieee754sp_1e31();
119 119
120 /* what if x < 0 ?? */ 120 /* what if x < 0 ?? */
121 if (ieee754sp_lt(x, hb)) 121 if (ieee754sp_lt(x, hb))
diff --git a/arch/mips/math-emu/sp_tlong.c b/arch/mips/math-emu/sp_tlong.c
index d0ca6e22be29..da412d38d5ef 100644
--- a/arch/mips/math-emu/sp_tlong.c
+++ b/arch/mips/math-emu/sp_tlong.c
@@ -26,7 +26,7 @@
26 26
27#include "ieee754sp.h" 27#include "ieee754sp.h"
28 28
29s64 ieee754sp_tlong(ieee754sp x) 29s64 ieee754sp_tlong(union ieee754sp x)
30{ 30{
31 COMPXDP; /* <-- need 64-bit mantissa tmp */ 31 COMPXDP; /* <-- need 64-bit mantissa tmp */
32 32
@@ -108,9 +108,9 @@ s64 ieee754sp_tlong(ieee754sp x)
108} 108}
109 109
110 110
111u64 ieee754sp_tulong(ieee754sp x) 111u64 ieee754sp_tulong(union ieee754sp x)
112{ 112{
113 ieee754sp hb = ieee754sp_1e63(); 113 union ieee754sp hb = ieee754sp_1e63();
114 114
115 /* what if x < 0 ?? */ 115 /* what if x < 0 ?? */
116 if (ieee754sp_lt(x, hb)) 116 if (ieee754sp_lt(x, hb))