* [PATCH] Remove __isinf_ns
@ 2015-06-15 11:30 Wilco Dijkstra
2015-06-15 15:07 ` Joseph Myers
2015-07-09 15:22 ` Ondřej Bílka
0 siblings, 2 replies; 6+ messages in thread
From: Wilco Dijkstra @ 2015-06-15 11:30 UTC (permalink / raw)
To: GNU C Library
[-- Attachment #1: Type: text/plain, Size: 1171 bytes --]
Remove all uses and definition of the internal function __isinf_ns(l/f) as there is no benefit in
having it when isinf gets inlined in math.h (I'll post that as a separate patch).
GLIBC builds and passes math tests on AArch64. OK for commit?
ChangeLog:
2015-06-15 Wilco Dijkstra <wdijkstr@arm.com>
* include/math.h: Remove __isinf_ns, __isinf_nsf, __isinf_nsl.
* math/Makefile: Remove isinf_ns.c.
* math/divtc3.c (__divtc3): Replace __isinf_nsl with isinf.
* math/multc3.c (__multc3): Likewise.
* math/s_casin.c (__casin): Likewise.
* math/s_casinf.c (__casinf): Likewise.
* math/s_casinl.c (__casinl): Likewise.
* math/s_cproj.c (__cproj): Likewise.
* math/s_cprojf.c (__cprojf): Likewise.
* math/s_cprojl.c (__cprofl): Likewise.
* math/s_ctan.c (__ctan): Likewise.
* math/s_ctanf.c (__ctanf): Likewise.
* math/s_ctanh.c (__ctanh): Likewise.
* math/s_ctanhf.c (__ctanhf): Likewise.
* math/s_ctanhl.c (__ctanhl): Likewise.
* math/s_ctanl.c (__ctanl): Likewise.
* math/w_fmod.c (__fmod): Likewise.
* math/w_fmodf.c (__fmodf): Likewise.
* math/w_fmodl.c (_fmodl): Likewise.
* math/w_remainder.c (__remainder): Likewise.
[-- Attachment #2: Remove-__isinf_ns.txt --]
[-- Type: text/plain, Size: 25642 bytes --]
---
include/math.h | 4 ----
math/Makefile | 2 +-
math/divtc3.c | 12 ++++++------
math/multc3.c | 16 ++++++++--------
math/s_casin.c | 2 +-
math/s_casinf.c | 2 +-
math/s_casinl.c | 2 +-
math/s_cproj.c | 2 +-
math/s_cprojf.c | 2 +-
math/s_cprojl.c | 2 +-
math/s_ctan.c | 4 ++--
math/s_ctanf.c | 4 ++--
math/s_ctanh.c | 4 ++--
math/s_ctanhf.c | 4 ++--
math/s_ctanhl.c | 4 ++--
math/s_ctanl.c | 4 ++--
math/w_fmod.c | 2 +-
math/w_fmodf.c | 2 +-
math/w_fmodl.c | 2 +-
math/w_remainder.c | 2 +-
math/w_remainderf.c | 2 +-
math/w_remainderl.c | 2 +-
math/w_scalb.c | 6 +++---
math/w_scalbf.c | 6 +++---
math/w_scalbl.c | 6 +++---
sysdeps/ieee754/dbl-64/s_isinf_ns.c | 20 --------------------
sysdeps/ieee754/dbl-64/s_sincos.c | 2 +-
sysdeps/ieee754/dbl-64/wordsize-64/math_private.h | 10 ----------
sysdeps/ieee754/dbl-64/wordsize-64/s_isinf_ns.c | 20 --------------------
sysdeps/ieee754/flt-32/e_exp2f.c | 2 +-
sysdeps/ieee754/flt-32/math_private.h | 10 ----------
sysdeps/ieee754/flt-32/s_isinf_nsf.c | 20 --------------------
sysdeps/ieee754/ldbl-128/s_isinf_nsl.c | 19 -------------------
sysdeps/ieee754/ldbl-128/s_sincosl.c | 2 +-
sysdeps/ieee754/ldbl-128ibm/s_cprojl.c | 2 +-
sysdeps/ieee754/ldbl-128ibm/s_ctanl.c | 2 +-
sysdeps/ieee754/ldbl-128ibm/s_isinf_nsl.c | 23 -----------------------
sysdeps/ieee754/ldbl-128ibm/s_sincosl.c | 2 +-
sysdeps/ieee754/ldbl-96/s_isinf_nsl.c | 18 ------------------
sysdeps/ieee754/ldbl-96/s_sincosl.c | 2 +-
40 files changed, 55 insertions(+), 199 deletions(-)
delete mode 100644 sysdeps/ieee754/dbl-64/s_isinf_ns.c
delete mode 100644 sysdeps/ieee754/dbl-64/wordsize-64/s_isinf_ns.c
delete mode 100644 sysdeps/ieee754/flt-32/s_isinf_nsf.c
delete mode 100644 sysdeps/ieee754/ldbl-128/s_isinf_nsl.c
delete mode 100644 sysdeps/ieee754/ldbl-128ibm/s_isinf_nsl.c
delete mode 100644 sysdeps/ieee754/ldbl-96/s_isinf_nsl.c
diff --git a/include/math.h b/include/math.h
index 42bb55e..b28c441 100644
--- a/include/math.h
+++ b/include/math.h
@@ -35,9 +35,5 @@ libm_hidden_proto (__expl)
libm_hidden_proto (__expm1l)
# endif
-extern int __isinf_ns (double);
-extern int __isinf_nsf (float);
-extern int __isinf_nsl (long double);
-
#endif
#endif
diff --git a/math/Makefile b/math/Makefile
index f78d75b..8a1740b 100644
--- a/math/Makefile
+++ b/math/Makefile
@@ -61,7 +61,7 @@ libm-calls = e_acos e_acosh e_asin e_atan2 e_atanh e_cosh e_exp e_fmod \
s_catan s_casin s_ccos s_csin s_ctan s_ctanh s_cacos \
s_casinh s_cacosh s_catanh s_csqrt s_cpow s_cproj s_clog10 \
s_fma s_lrint s_llrint s_lround s_llround e_exp10 w_log2 \
- s_isinf_ns s_issignaling $(calls:s_%=m_%) x2y2m1 k_casinh \
+ s_issignaling $(calls:s_%=m_%) x2y2m1 k_casinh \
gamma_product k_standard
dbl-only-routines := branred doasin dosincos halfulp mpa mpatan2 \
diff --git a/math/divtc3.c b/math/divtc3.c
index bfd9b3f..c0dee8e 100644
--- a/math/divtc3.c
+++ b/math/divtc3.c
@@ -54,19 +54,19 @@ __divtc3 (long double a, long double b, long double c, long double d)
x = __copysignl (INFINITY, c) * a;
y = __copysignl (INFINITY, c) * b;
}
- else if ((__isinf_nsl (a) || __isinf_nsl (b))
+ else if ((isinf (a) || isinf (b))
&& isfinite (c) && isfinite (d))
{
- a = __copysignl (__isinf_nsl (a) ? 1 : 0, a);
- b = __copysignl (__isinf_nsl (b) ? 1 : 0, b);
+ a = __copysignl (isinf (a) ? 1 : 0, a);
+ b = __copysignl (isinf (b) ? 1 : 0, b);
x = INFINITY * (a * c + b * d);
y = INFINITY * (b * c - a * d);
}
- else if ((__isinf_nsl (c) || __isinf_nsl (d))
+ else if ((isinf (c) || isinf (d))
&& isfinite (a) && isfinite (b))
{
- c = __copysignl (__isinf_nsl (c) ? 1 : 0, c);
- d = __copysignl (__isinf_nsl (d) ? 1 : 0, d);
+ c = __copysignl (isinf (c) ? 1 : 0, c);
+ d = __copysignl (isinf (d) ? 1 : 0, d);
x = 0.0 * (a * c + b * d);
y = 0.0 * (b * c - a * d);
}
diff --git a/math/multc3.c b/math/multc3.c
index 1dbb59a..2fd165d 100644
--- a/math/multc3.c
+++ b/math/multc3.c
@@ -38,29 +38,29 @@ __multc3 (long double a, long double b, long double c, long double d)
{
/* Recover infinities that computed as NaN + iNaN. */
bool recalc = 0;
- if (__isinf_nsl (a) || __isinf_nsl (b))
+ if (isinf (a) || isinf (b))
{
/* z is infinite. "Box" the infinity and change NaNs in
the other factor to 0. */
- a = __copysignl (__isinf_nsl (a) ? 1 : 0, a);
- b = __copysignl (__isinf_nsl (b) ? 1 : 0, b);
+ a = __copysignl (isinf (a) ? 1 : 0, a);
+ b = __copysignl (isinf (b) ? 1 : 0, b);
if (isnan (c)) c = __copysignl (0, c);
if (isnan (d)) d = __copysignl (0, d);
recalc = 1;
}
- if (__isinf_nsl (c) || __isinf_nsl (d))
+ if (isinf (c) || isinf (d))
{
/* w is infinite. "Box" the infinity and change NaNs in
the other factor to 0. */
- c = __copysignl (__isinf_nsl (c) ? 1 : 0, c);
- d = __copysignl (__isinf_nsl (d) ? 1 : 0, d);
+ c = __copysignl (isinf (c) ? 1 : 0, c);
+ d = __copysignl (isinf (d) ? 1 : 0, d);
if (isnan (a)) a = __copysignl (0, a);
if (isnan (b)) b = __copysignl (0, b);
recalc = 1;
}
if (!recalc
- && (__isinf_nsl (ac) || __isinf_nsl (bd)
- || __isinf_nsl (ad) || __isinf_nsl (bc)))
+ && (isinf (ac) || isinf (bd)
+ || isinf (ad) || isinf (bc)))
{
/* Recover infinities from overflow by changing NaNs to 0. */
if (isnan (a)) a = __copysignl (0, a);
diff --git a/math/s_casin.c b/math/s_casin.c
index 206f1d2..826fd38 100644
--- a/math/s_casin.c
+++ b/math/s_casin.c
@@ -33,7 +33,7 @@ __casin (__complex__ double x)
{
res = x;
}
- else if (__isinf_ns (__real__ x) || __isinf_ns (__imag__ x))
+ else if (isinf (__real__ x) || isinf (__imag__ x))
{
__real__ res = __nan ("");
__imag__ res = __copysign (HUGE_VAL, __imag__ x);
diff --git a/math/s_casinf.c b/math/s_casinf.c
index 65cba20..9b3d2f1 100644
--- a/math/s_casinf.c
+++ b/math/s_casinf.c
@@ -33,7 +33,7 @@ __casinf (__complex__ float x)
{
res = x;
}
- else if (__isinf_nsf (__real__ x) || __isinf_nsf (__imag__ x))
+ else if (isinf (__real__ x) || isinf (__imag__ x))
{
__real__ res = __nanf ("");
__imag__ res = __copysignf (HUGE_VALF, __imag__ x);
diff --git a/math/s_casinl.c b/math/s_casinl.c
index 2263a26..f7d85fc 100644
--- a/math/s_casinl.c
+++ b/math/s_casinl.c
@@ -33,7 +33,7 @@ __casinl (__complex__ long double x)
{
res = x;
}
- else if (__isinf_nsl (__real__ x) || __isinf_nsl (__imag__ x))
+ else if (isinf (__real__ x) || isinf (__imag__ x))
{
__real__ res = __nanl ("");
__imag__ res = __copysignl (HUGE_VALL, __imag__ x);
diff --git a/math/s_cproj.c b/math/s_cproj.c
index bf2cfc4..42bf076 100644
--- a/math/s_cproj.c
+++ b/math/s_cproj.c
@@ -25,7 +25,7 @@
__complex__ double
__cproj (__complex__ double x)
{
- if (__isinf_ns (__real__ x) || __isinf_ns (__imag__ x))
+ if (isinf (__real__ x) || isinf (__imag__ x))
{
__complex__ double res;
diff --git a/math/s_cprojf.c b/math/s_cprojf.c
index 531d10e..9340372 100644
--- a/math/s_cprojf.c
+++ b/math/s_cprojf.c
@@ -25,7 +25,7 @@
__complex__ float
__cprojf (__complex__ float x)
{
- if (__isinf_nsf (__real__ x) || __isinf_nsf (__imag__ x))
+ if (isinf (__real__ x) || isinf (__imag__ x))
{
__complex__ float res;
diff --git a/math/s_cprojl.c b/math/s_cprojl.c
index 32292a4..de88318 100644
--- a/math/s_cprojl.c
+++ b/math/s_cprojl.c
@@ -25,7 +25,7 @@
__complex__ long double
__cprojl (__complex__ long double x)
{
- if (__isinf_nsl (__real__ x) || __isinf_nsl (__imag__ x))
+ if (isinf (__real__ x) || isinf (__imag__ x))
{
__complex__ long double res;
diff --git a/math/s_ctan.c b/math/s_ctan.c
index 97a7a03..1471ec2 100644
--- a/math/s_ctan.c
+++ b/math/s_ctan.c
@@ -30,7 +30,7 @@ __ctan (__complex__ double x)
if (__glibc_unlikely (!isfinite (__real__ x) || !isfinite (__imag__ x)))
{
- if (__isinf_ns (__imag__ x))
+ if (isinf (__imag__ x))
{
__real__ res = __copysign (0.0, __real__ x);
__imag__ res = __copysign (1.0, __imag__ x);
@@ -44,7 +44,7 @@ __ctan (__complex__ double x)
__real__ res = __nan ("");
__imag__ res = __nan ("");
- if (__isinf_ns (__real__ x))
+ if (isinf (__real__ x))
feraiseexcept (FE_INVALID);
}
}
diff --git a/math/s_ctanf.c b/math/s_ctanf.c
index 5f1adc8..afe38b2 100644
--- a/math/s_ctanf.c
+++ b/math/s_ctanf.c
@@ -30,7 +30,7 @@ __ctanf (__complex__ float x)
if (__glibc_unlikely (!isfinite (__real__ x) || !isfinite (__imag__ x)))
{
- if (__isinf_nsf (__imag__ x))
+ if (isinf (__imag__ x))
{
__real__ res = __copysignf (0.0, __real__ x);
__imag__ res = __copysignf (1.0, __imag__ x);
@@ -44,7 +44,7 @@ __ctanf (__complex__ float x)
__real__ res = __nanf ("");
__imag__ res = __nanf ("");
- if (__isinf_nsf (__real__ x))
+ if (isinf (__real__ x))
feraiseexcept (FE_INVALID);
}
}
diff --git a/math/s_ctanh.c b/math/s_ctanh.c
index ca4c0e2..1930fb7 100644
--- a/math/s_ctanh.c
+++ b/math/s_ctanh.c
@@ -30,7 +30,7 @@ __ctanh (__complex__ double x)
if (__glibc_unlikely (!isfinite (__real__ x) || !isfinite (__imag__ x)))
{
- if (__isinf_ns (__real__ x))
+ if (isinf (__real__ x))
{
__real__ res = __copysign (1.0, __real__ x);
__imag__ res = __copysign (0.0, __imag__ x);
@@ -44,7 +44,7 @@ __ctanh (__complex__ double x)
__real__ res = __nan ("");
__imag__ res = __nan ("");
- if (__isinf_ns (__imag__ x))
+ if (isinf (__imag__ x))
feraiseexcept (FE_INVALID);
}
}
diff --git a/math/s_ctanhf.c b/math/s_ctanhf.c
index 1405f3f..dc53335 100644
--- a/math/s_ctanhf.c
+++ b/math/s_ctanhf.c
@@ -30,7 +30,7 @@ __ctanhf (__complex__ float x)
if (__glibc_unlikely (!isfinite (__real__ x) || !isfinite (__imag__ x)))
{
- if (__isinf_nsf (__real__ x))
+ if (isinf (__real__ x))
{
__real__ res = __copysignf (1.0, __real__ x);
__imag__ res = __copysignf (0.0, __imag__ x);
@@ -44,7 +44,7 @@ __ctanhf (__complex__ float x)
__real__ res = __nanf ("");
__imag__ res = __nanf ("");
- if (__isinf_nsf (__imag__ x))
+ if (isinf (__imag__ x))
feraiseexcept (FE_INVALID);
}
}
diff --git a/math/s_ctanhl.c b/math/s_ctanhl.c
index 016ebc5..ab63c93 100644
--- a/math/s_ctanhl.c
+++ b/math/s_ctanhl.c
@@ -30,7 +30,7 @@ __ctanhl (__complex__ long double x)
if (__glibc_unlikely (!isfinite (__real__ x) || !isfinite (__imag__ x)))
{
- if (__isinf_nsl (__real__ x))
+ if (isinf (__real__ x))
{
__real__ res = __copysignl (1.0, __real__ x);
__imag__ res = __copysignl (0.0, __imag__ x);
@@ -44,7 +44,7 @@ __ctanhl (__complex__ long double x)
__real__ res = __nanl ("");
__imag__ res = __nanl ("");
- if (__isinf_nsl (__imag__ x))
+ if (isinf (__imag__ x))
feraiseexcept (FE_INVALID);
}
}
diff --git a/math/s_ctanl.c b/math/s_ctanl.c
index 6ad1b75..a6e3907 100644
--- a/math/s_ctanl.c
+++ b/math/s_ctanl.c
@@ -30,7 +30,7 @@ __ctanl (__complex__ long double x)
if (__glibc_unlikely (!isfinite (__real__ x) || !isfinite (__imag__ x)))
{
- if (__isinf_nsl (__imag__ x))
+ if (isinf (__imag__ x))
{
__real__ res = __copysignl (0.0, __real__ x);
__imag__ res = __copysignl (1.0, __imag__ x);
@@ -44,7 +44,7 @@ __ctanl (__complex__ long double x)
__real__ res = __nanl ("");
__imag__ res = __nanl ("");
- if (__isinf_nsl (__real__ x))
+ if (isinf (__real__ x))
feraiseexcept (FE_INVALID);
}
}
diff --git a/math/w_fmod.c b/math/w_fmod.c
index 0ee5ee4..90f2465 100644
--- a/math/w_fmod.c
+++ b/math/w_fmod.c
@@ -23,7 +23,7 @@
double
__fmod (double x, double y)
{
- if (__builtin_expect (__isinf_ns (x) || y == 0.0, 0)
+ if (__builtin_expect (isinf (x) || y == 0.0, 0)
&& _LIB_VERSION != _IEEE_ && !isnan (y) && !isnan (x))
/* fmod(+-Inf,y) or fmod(x,0) */
return __kernel_standard (x, y, 27);
diff --git a/math/w_fmodf.c b/math/w_fmodf.c
index ba9b847..7dcb2fe 100644
--- a/math/w_fmodf.c
+++ b/math/w_fmodf.c
@@ -23,7 +23,7 @@
float
__fmodf (float x, float y)
{
- if (__builtin_expect (__isinf_nsf (x) || y == 0.0f, 0)
+ if (__builtin_expect (isinf (x) || y == 0.0f, 0)
&& _LIB_VERSION != _IEEE_ && !isnan (y) && !isnan (x))
/* fmod(+-Inf,y) or fmod(x,0) */
return __kernel_standard_f (x, y, 127);
diff --git a/math/w_fmodl.c b/math/w_fmodl.c
index a64af8e..f6a25d2 100644
--- a/math/w_fmodl.c
+++ b/math/w_fmodl.c
@@ -23,7 +23,7 @@
long double
__fmodl (long double x, long double y)
{
- if (__builtin_expect (__isinf_nsl (x) || y == 0.0L, 0)
+ if (__builtin_expect (isinf (x) || y == 0.0L, 0)
&& _LIB_VERSION != _IEEE_ && !isnan (y) && !isnan (x))
/* fmod(+-Inf,y) or fmod(x,0) */
return __kernel_standard_l (x, y, 227);
diff --git a/math/w_remainder.c b/math/w_remainder.c
index 9be4dfd..a6da192 100644
--- a/math/w_remainder.c
+++ b/math/w_remainder.c
@@ -25,7 +25,7 @@ double
__remainder (double x, double y)
{
if (((__builtin_expect (y == 0.0, 0) && ! isnan (x))
- || (__builtin_expect (__isinf_ns (x), 0) && ! isnan (y)))
+ || (__builtin_expect (isinf (x), 0) && ! isnan (y)))
&& _LIB_VERSION != _IEEE_)
return __kernel_standard (x, y, 28); /* remainder domain */
diff --git a/math/w_remainderf.c b/math/w_remainderf.c
index b207d84..c003002 100644
--- a/math/w_remainderf.c
+++ b/math/w_remainderf.c
@@ -25,7 +25,7 @@ float
__remainderf (float x, float y)
{
if (((__builtin_expect (y == 0.0f, 0) && ! isnan (x))
- || (__builtin_expect (__isinf_nsf (x), 0) && ! isnan (y)))
+ || (__builtin_expect (isinf (x), 0) && ! isnan (y)))
&& _LIB_VERSION != _IEEE_)
return __kernel_standard_f (x, y, 128); /* remainder domain */
diff --git a/math/w_remainderl.c b/math/w_remainderl.c
index 78842af..b25929d 100644
--- a/math/w_remainderl.c
+++ b/math/w_remainderl.c
@@ -25,7 +25,7 @@ long double
__remainderl (long double x, long double y)
{
if (((__builtin_expect (y == 0.0L, 0) && ! isnan (x))
- || (__builtin_expect (__isinf_nsl (x), 0) && ! isnan (y)))
+ || (__builtin_expect (isinf (x), 0) && ! isnan (y)))
&& _LIB_VERSION != _IEEE_)
return __kernel_standard_l (x, y, 228); /* remainder domain */
diff --git a/math/w_scalb.c b/math/w_scalb.c
index 09627f4..ea258b1 100644
--- a/math/w_scalb.c
+++ b/math/w_scalb.c
@@ -58,15 +58,15 @@ __scalb (double x, double fn)
if (!isnan (x) && !isnan (fn))
__set_errno (EDOM);
}
- else if (__isinf_ns (z))
+ else if (isinf (z))
{
- if (!__isinf_ns (x) && !__isinf_ns (fn))
+ if (!isinf (x) && !isinf (fn))
__set_errno (ERANGE);
}
else
{
/* z == 0. */
- if (x != 0.0 && !__isinf_ns (fn))
+ if (x != 0.0 && !isinf (fn))
__set_errno (ERANGE);
}
}
diff --git a/math/w_scalbf.c b/math/w_scalbf.c
index e7b855b..30eb3a2 100644
--- a/math/w_scalbf.c
+++ b/math/w_scalbf.c
@@ -58,15 +58,15 @@ __scalbf (float x, float fn)
if (!isnan (x) && !isnan (fn))
__set_errno (EDOM);
}
- else if (__isinf_nsf (z))
+ else if (isinf (z))
{
- if (!__isinf_nsf (x) && !__isinf_nsf (fn))
+ if (!isinf (x) && !isinf (fn))
__set_errno (ERANGE);
}
else
{
/* z == 0. */
- if (x != 0.0f && !__isinf_nsf (fn))
+ if (x != 0.0f && !isinf (fn))
__set_errno (ERANGE);
}
}
diff --git a/math/w_scalbl.c b/math/w_scalbl.c
index 5e1e017..0fcf807 100644
--- a/math/w_scalbl.c
+++ b/math/w_scalbl.c
@@ -58,15 +58,15 @@ __scalbl (long double x, long double fn)
if (!isnan (x) && !isnan (fn))
__set_errno (EDOM);
}
- else if (__isinf_nsl (z))
+ else if (isinf (z))
{
- if (!__isinf_nsl (x) && !__isinf_nsl (fn))
+ if (!isinf (x) && !isinf (fn))
__set_errno (ERANGE);
}
else
{
/* z == 0. */
- if (x != 0.0L && !__isinf_nsl (fn))
+ if (x != 0.0L && !isinf (fn))
__set_errno (ERANGE);
}
}
diff --git a/sysdeps/ieee754/dbl-64/s_isinf_ns.c b/sysdeps/ieee754/dbl-64/s_isinf_ns.c
deleted file mode 100644
index d8142bc..0000000
--- a/sysdeps/ieee754/dbl-64/s_isinf_ns.c
+++ /dev/null
@@ -1,20 +0,0 @@
-/*
- * Written by Ulrich Drepper <drepper@gmail.com>.
- */
-
-/*
- * __isinf_ns(x) returns != 0 if x is ±inf, else 0;
- * no branching!
- */
-
-#include <math.h>
-#include <math_private.h>
-
-#undef __isinf_ns
-int
-__isinf_ns (double x)
-{
- int32_t hx, lx;
- EXTRACT_WORDS (hx, lx, x);
- return !(lx | ((hx & 0x7fffffff) ^ 0x7ff00000));
-}
diff --git a/sysdeps/ieee754/dbl-64/s_sincos.c b/sysdeps/ieee754/dbl-64/s_sincos.c
index c8a9999..d7431b7 100644
--- a/sysdeps/ieee754/dbl-64/s_sincos.c
+++ b/sysdeps/ieee754/dbl-64/s_sincos.c
@@ -37,7 +37,7 @@ __sincos (double x, double *sinx, double *cosx)
{
/* sin(Inf or NaN) is NaN */
*sinx = *cosx = x - x;
- if (__isinf_ns (x))
+ if (isinf (x))
__set_errno (EDOM);
}
else
diff --git a/sysdeps/ieee754/dbl-64/wordsize-64/math_private.h b/sysdeps/ieee754/dbl-64/wordsize-64/math_private.h
index 4f92199..957baba 100644
--- a/sysdeps/ieee754/dbl-64/wordsize-64/math_private.h
+++ b/sysdeps/ieee754/dbl-64/wordsize-64/math_private.h
@@ -13,16 +13,6 @@ __isnan (double d)
}
#endif
-#ifndef __isinf_ns
-extern __always_inline int
-__isinf_ns (double d)
-{
- uint64_t di;
- EXTRACT_WORDS64 (di, d);
- return (di & 0x7fffffffffffffffull) == 0x7ff0000000000000ull;
-}
-#endif
-
#ifndef __finite
extern __always_inline int
__finite (double d)
diff --git a/sysdeps/ieee754/dbl-64/wordsize-64/s_isinf_ns.c b/sysdeps/ieee754/dbl-64/wordsize-64/s_isinf_ns.c
deleted file mode 100644
index 9d78ed1..0000000
--- a/sysdeps/ieee754/dbl-64/wordsize-64/s_isinf_ns.c
+++ /dev/null
@@ -1,20 +0,0 @@
-/*
- * Written by Ulrich Drepper <drepper@gmail.com>.
- */
-
-/*
- * __isinf_ns(x) returns != 0 if x is ±inf, else 0;
- * no branching!
- */
-
-#include <math.h>
-#include <math_private.h>
-
-#undef __isinf_ns
-int
-__isinf_ns (double x)
-{
- int64_t ix;
- EXTRACT_WORDS64(ix,x);
- return (ix & UINT64_C(0x7fffffffffffffff)) == UINT64_C(0x7ff0000000000000);
-}
diff --git a/sysdeps/ieee754/flt-32/e_exp2f.c b/sysdeps/ieee754/flt-32/e_exp2f.c
index f3e3a8e..fe2863a 100644
--- a/sysdeps/ieee754/flt-32/e_exp2f.c
+++ b/sysdeps/ieee754/flt-32/e_exp2f.c
@@ -112,7 +112,7 @@ __ieee754_exp2f (float x)
/* Exceptional cases: */
else if (isless (x, himark))
{
- if (__isinf_nsf (x))
+ if (isinf (x))
/* e^-inf == 0, with no error. */
return 0;
else
diff --git a/sysdeps/ieee754/flt-32/math_private.h b/sysdeps/ieee754/flt-32/math_private.h
index e33db02..48db37e 100644
--- a/sysdeps/ieee754/flt-32/math_private.h
+++ b/sysdeps/ieee754/flt-32/math_private.h
@@ -12,16 +12,6 @@ __isnanf (float d)
}
#endif
-#ifndef __isinf_nsf
-extern __always_inline int
-__isinf_nsf (float d)
-{
- u_int32_t di;
- GET_FLOAT_WORD (di, d);
- return (di & 0x7fffffff) == 0x7f800000;
-}
-#endif
-
#ifndef __finitef
extern __always_inline int
__finitef (float d)
diff --git a/sysdeps/ieee754/flt-32/s_isinf_nsf.c b/sysdeps/ieee754/flt-32/s_isinf_nsf.c
deleted file mode 100644
index 284d619..0000000
--- a/sysdeps/ieee754/flt-32/s_isinf_nsf.c
+++ /dev/null
@@ -1,20 +0,0 @@
-/*
- * Written by Ulrich Drepper <drepper@gmail.com>.
- */
-
-/*
- * __isinf_nsf(x) returns != 0 if x is ±inf, else 0;
- * no branching!
- */
-
-#include <math.h>
-#include <math_private.h>
-
-#undef __isinf_nsf
-int
-__isinf_nsf (float x)
-{
- int32_t ix;
- GET_FLOAT_WORD(ix,x);
- return (ix & 0x7fffffff) == 0x7f800000;
-}
diff --git a/sysdeps/ieee754/ldbl-128/s_isinf_nsl.c b/sysdeps/ieee754/ldbl-128/s_isinf_nsl.c
deleted file mode 100644
index 7d6cfb9..0000000
--- a/sysdeps/ieee754/ldbl-128/s_isinf_nsl.c
+++ /dev/null
@@ -1,19 +0,0 @@
-/*
- * Written by Ulrich Drepper <drepper@gmail.com>
- */
-
-/*
- * __isinf_nsl(x) returns != 0 if x is ±inf, else 0;
- * no branching!
- */
-
-#include <math.h>
-#include <math_private.h>
-
-int
-__isinf_nsl (long double x)
-{
- int64_t hx,lx;
- GET_LDOUBLE_WORDS64(hx,lx,x);
- return !(lx | ((hx & 0x7fffffffffffffffLL) ^ 0x7fff000000000000LL));
-}
diff --git a/sysdeps/ieee754/ldbl-128/s_sincosl.c b/sysdeps/ieee754/ldbl-128/s_sincosl.c
index 6c4cbd7..d4d432a 100644
--- a/sysdeps/ieee754/ldbl-128/s_sincosl.c
+++ b/sysdeps/ieee754/ldbl-128/s_sincosl.c
@@ -39,7 +39,7 @@ __sincosl (long double x, long double *sinx, long double *cosx)
{
/* sin(Inf or NaN) is NaN */
*sinx = *cosx = x - x;
- if (__isinf_nsl (x))
+ if (isinf (x))
__set_errno (EDOM);
}
else
diff --git a/sysdeps/ieee754/ldbl-128ibm/s_cprojl.c b/sysdeps/ieee754/ldbl-128ibm/s_cprojl.c
index 4243a4b..41fd162 100644
--- a/sysdeps/ieee754/ldbl-128ibm/s_cprojl.c
+++ b/sysdeps/ieee754/ldbl-128ibm/s_cprojl.c
@@ -24,7 +24,7 @@
__complex__ long double
__cprojl (__complex__ long double x)
{
- if (__isinf_nsl (__real__ x) || __isinf_nsl (__imag__ x))
+ if (isinf (__real__ x) || isinf (__imag__ x))
{
__complex__ long double res;
diff --git a/sysdeps/ieee754/ldbl-128ibm/s_ctanl.c b/sysdeps/ieee754/ldbl-128ibm/s_ctanl.c
index fc44378..1768d30 100644
--- a/sysdeps/ieee754/ldbl-128ibm/s_ctanl.c
+++ b/sysdeps/ieee754/ldbl-128ibm/s_ctanl.c
@@ -49,7 +49,7 @@ __ctanl (__complex__ long double x)
__real__ res = __nanl ("");
__imag__ res = __nanl ("");
- if (__isinf_nsl (__real__ x))
+ if (isinf (__real__ x))
feraiseexcept (FE_INVALID);
}
}
diff --git a/sysdeps/ieee754/ldbl-128ibm/s_isinf_nsl.c b/sysdeps/ieee754/ldbl-128ibm/s_isinf_nsl.c
deleted file mode 100644
index 54e72c9..0000000
--- a/sysdeps/ieee754/ldbl-128ibm/s_isinf_nsl.c
+++ /dev/null
@@ -1,23 +0,0 @@
-/*
- * __isinf_nsl(x) returns != 0 if x is ±inf, else 0;
- * no branching!
- * slightly dodgy in relying on signed shift right copying sign bit
- */
-
-#include <math.h>
-#include <math_private.h>
-
-int
-__isinf_nsl (long double x)
-{
- double xhi;
- int64_t hx, mask;
-
- xhi = ldbl_high (x);
- EXTRACT_WORDS64 (hx, xhi);
-
- mask = (hx & 0x7fffffffffffffffLL) ^ 0x7ff0000000000000LL;
- mask |= -mask;
- mask >>= 63;
- return ~mask;
-}
diff --git a/sysdeps/ieee754/ldbl-128ibm/s_sincosl.c b/sysdeps/ieee754/ldbl-128ibm/s_sincosl.c
index 8a49c54..b7efd1a 100644
--- a/sysdeps/ieee754/ldbl-128ibm/s_sincosl.c
+++ b/sysdeps/ieee754/ldbl-128ibm/s_sincosl.c
@@ -42,7 +42,7 @@ __sincosl (long double x, long double *sinx, long double *cosx)
{
/* sin(Inf or NaN) is NaN */
*sinx = *cosx = x - x;
- if (__isinf_nsl (x))
+ if (isinf (x))
__set_errno (EDOM);
}
else
diff --git a/sysdeps/ieee754/ldbl-96/s_isinf_nsl.c b/sysdeps/ieee754/ldbl-96/s_isinf_nsl.c
deleted file mode 100644
index 9c7868b..0000000
--- a/sysdeps/ieee754/ldbl-96/s_isinf_nsl.c
+++ /dev/null
@@ -1,18 +0,0 @@
-/*
- * Written by Ulrich Drepper <drepper@gmail.com>.
- */
-
-/*
- * __isinf_nsl(x) returns != 0 if x is ±inf, else 0;
- */
-
-#include <math.h>
-#include <math_private.h>
-
-int
-__isinf_nsl (long double x)
-{
- int32_t se,hx,lx;
- GET_LDOUBLE_WORDS(se,hx,lx,x);
- return !(((se & 0x7fff) ^ 0x7fff) | lx | (hx & 0x7fffffff));
-}
diff --git a/sysdeps/ieee754/ldbl-96/s_sincosl.c b/sysdeps/ieee754/ldbl-96/s_sincosl.c
index 37067bd..86f1d96 100644
--- a/sysdeps/ieee754/ldbl-96/s_sincosl.c
+++ b/sysdeps/ieee754/ldbl-96/s_sincosl.c
@@ -42,7 +42,7 @@ __sincosl (long double x, long double *sinx, long double *cosx)
{
/* sin(Inf or NaN) is NaN */
*sinx = *cosx = x - x;
- if (__isinf_nsl (x))
+ if (isinf (x))
__set_errno (EDOM);
}
else
--
1.9.1
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] Remove __isinf_ns
2015-06-15 11:30 [PATCH] Remove __isinf_ns Wilco Dijkstra
@ 2015-06-15 15:07 ` Joseph Myers
2015-06-15 16:32 ` Wilco Dijkstra
2015-07-09 15:22 ` Ondřej Bílka
1 sibling, 1 reply; 6+ messages in thread
From: Joseph Myers @ 2015-06-15 15:07 UTC (permalink / raw)
To: Wilco Dijkstra; +Cc: GNU C Library
On Mon, 15 Jun 2015, Wilco Dijkstra wrote:
> 2015-06-15 Wilco Dijkstra <wdijkstr@arm.com>
>
> * include/math.h: Remove __isinf_ns, __isinf_nsf, __isinf_nsl.
> * math/Makefile: Remove isinf_ns.c.
> * math/divtc3.c (__divtc3): Replace __isinf_nsl with isinf.
> * math/multc3.c (__multc3): Likewise.
> * math/s_casin.c (__casin): Likewise.
> * math/s_casinf.c (__casinf): Likewise.
> * math/s_casinl.c (__casinl): Likewise.
> * math/s_cproj.c (__cproj): Likewise.
> * math/s_cprojf.c (__cprojf): Likewise.
> * math/s_cprojl.c (__cprofl): Likewise.
> * math/s_ctan.c (__ctan): Likewise.
> * math/s_ctanf.c (__ctanf): Likewise.
> * math/s_ctanh.c (__ctanh): Likewise.
> * math/s_ctanhf.c (__ctanhf): Likewise.
> * math/s_ctanhl.c (__ctanhl): Likewise.
> * math/s_ctanl.c (__ctanl): Likewise.
> * math/w_fmod.c (__fmod): Likewise.
> * math/w_fmodf.c (__fmodf): Likewise.
> * math/w_fmodl.c (_fmodl): Likewise.
> * math/w_remainder.c (__remainder): Likewise.
This ChangeLog entry seems very incomplete. Please repost the patch with
a complete ChangeLog entry (that covers all files modified or removed).
--
Joseph S. Myers
joseph@codesourcery.com
^ permalink raw reply [flat|nested] 6+ messages in thread
* RE: [PATCH] Remove __isinf_ns
2015-06-15 15:07 ` Joseph Myers
@ 2015-06-15 16:32 ` Wilco Dijkstra
0 siblings, 0 replies; 6+ messages in thread
From: Wilco Dijkstra @ 2015-06-15 16:32 UTC (permalink / raw)
To: 'Joseph Myers'; +Cc: GNU C Library
> Joseph Myers wrote:
>
> This ChangeLog entry seems very incomplete. Please repost the patch with
> a complete ChangeLog entry (that covers all files modified or removed).
Yes it seems to miss the last part - here is the full version:
2015-06-15 Wilco Dijkstra <wdijkstr@arm.com>
* include/math.h: Remove __isinf_ns, __isinf_nsf, __isinf_nsl.
* math/Makefile: Remove isinf_ns.c.
* math/divtc3.c (__divtc3): Replace __isinf_nsl with isinf.
* math/multc3.c (__multc3): Likewise.
* math/s_casin.c (__casin): Likewise.
* math/s_casinf.c (__casinf): Likewise.
* math/s_casinl.c (__casinl): Likewise.
* math/s_cproj.c (__cproj): Likewise.
* math/s_cprojf.c (__cprojf): Likewise.
* math/s_cprojl.c (__cprofl): Likewise.
* math/s_ctan.c (__ctan): Likewise.
* math/s_ctanf.c (__ctanf): Likewise.
* math/s_ctanh.c (__ctanh): Likewise.
* math/s_ctanhf.c (__ctanhf): Likewise.
* math/s_ctanhl.c (__ctanhl): Likewise.
* math/s_ctanl.c (__ctanl): Likewise.
* math/w_fmod.c (__fmod): Likewise.
* math/w_fmodf.c (__fmodf): Likewise.
* math/w_fmodl.c (_fmodl): Likewise.
* math/w_remainder.c (__remainder): Likewise.
* math/w_remainderf.c (__remainderf): Likewise.
* math/w_remainderl.c (__remainderl): Likewise.
* math/w_scalb.c (__scalb): Likewise.
* math/w_scalbf.c (__scalbf): Likewise.
* math/w_scalbl.c (__scalbl): Likewise.
* sysdeps/ieee754/dbl-64/s_isinf_ns.c: Deleted file.
* sysdeps/ieee754/dbl-64/s_sincos.c (__sincos): Replace __isinf_ns
with isinf.
* sysdeps/ieee754/dbl-64/wordsize-64/math_private.h (__isinf_ns):
Remove function.
* sysdeps/ieee754/dbl-64/wordsize-64/s_isinf_ns.c: Deleted file.
* sysdeps/ieee754/flt-32/e_exp2f.c (__ieee754_exp2f): Replace
__isinf_nsf with isinf.
* sysdeps/ieee754/flt-32/math_private.h (__isinf_nsf): Remove function.
* sysdeps/ieee754/flt-32/s_isinf_nsf.c: Deleted file.
* sysdeps/ieee754/ldbl-128/s_isinf_nsl.c: Deleted file.
* sysdeps/ieee754/ldbl-128/s_sincosl.c (__sincosl): Replace __isinf_nsl
with isinf.
* sysdeps/ieee754/ldbl-128ibm/s_cprojl.c(__cprojll): Replace
__isinf_nsl with isinf.
* sysdeps/ieee754/ldbl-128ibm/s_ctanl.c(__ctanl): Replace __isinf_nsl
with isinf.
* sysdeps/ieee754/ldbl-128ibm/s_isinf_nsl.c: Deleted file.
* sysdeps/ieee754/ldbl-128ibm/s_sincosl.c (__sincosl): Replace
__isinf_nsl with isinf.
* sysdeps/ieee754/ldbl-96/s_isinf_nsl.c: Deleted file.
* sysdeps/ieee754/ldbl-96/s_sincosl.c (__sincosl): Replace __isinf_nsl
with isinf.
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] Remove __isinf_ns
2015-06-15 11:30 [PATCH] Remove __isinf_ns Wilco Dijkstra
2015-06-15 15:07 ` Joseph Myers
@ 2015-07-09 15:22 ` Ondřej Bílka
2015-07-09 16:40 ` Wilco Dijkstra
1 sibling, 1 reply; 6+ messages in thread
From: Ondřej Bílka @ 2015-07-09 15:22 UTC (permalink / raw)
To: Wilco Dijkstra; +Cc: GNU C Library
On Mon, Jun 15, 2015 at 11:44:48AM +0100, Wilco Dijkstra wrote:
> Remove all uses and definition of the internal function __isinf_ns(l/f) as there is no benefit in
> having it when isinf gets inlined in math.h (I'll post that as a separate patch).
>
> GLIBC builds and passes math tests on AArch64. OK for commit?
>
Almost ok.
> diff --git a/math/divtc3.c b/math/divtc3.c
> index bfd9b3f..c0dee8e 100644
> --- a/math/divtc3.c
> +++ b/math/divtc3.c
> @@ -54,19 +54,19 @@ __divtc3 (long double a, long double b, long double c, long double d)
> x = __copysignl (INFINITY, c) * a;
> y = __copysignl (INFINITY, c) * b;
> }
> - else if ((__isinf_nsl (a) || __isinf_nsl (b))
> + else if ((isinf (a) || isinf (b))
> && isfinite (c) && isfinite (d))
> {
> - a = __copysignl (__isinf_nsl (a) ? 1 : 0, a);
> - b = __copysignl (__isinf_nsl (b) ? 1 : 0, b);
> + a = __copysignl (isinf (a) ? 1 : 0, a);
> + b = __copysignl (isinf (b) ? 1 : 0, b);
> x = INFINITY * (a * c + b * d);
> y = INFINITY * (b * c - a * d);
> }
> - else if ((__isinf_nsl (c) || __isinf_nsl (d))
> + else if ((isinf (c) || isinf (d))
> && isfinite (a) && isfinite (b))
> {
> - c = __copysignl (__isinf_nsl (c) ? 1 : 0, c);
> - d = __copysignl (__isinf_nsl (d) ? 1 : 0, d);
> + c = __copysignl (isinf (c) ? 1 : 0, c);
> + d = __copysignl (isinf (d) ? 1 : 0, d);
> x = 0.0 * (a * c + b * d);
> y = 0.0 * (b * c - a * d);
> }
These patterns are unnecessary as with libc they could be written as
c = isinf (c);
with libc isinf.
^ permalink raw reply [flat|nested] 6+ messages in thread
* RE: [PATCH] Remove __isinf_ns
2015-07-09 15:22 ` Ondřej Bílka
@ 2015-07-09 16:40 ` Wilco Dijkstra
2015-07-09 17:25 ` Ondřej Bílka
0 siblings, 1 reply; 6+ messages in thread
From: Wilco Dijkstra @ 2015-07-09 16:40 UTC (permalink / raw)
To: 'Ondřej Bílka'; +Cc: GNU C Library
> Ondřej Bílka wrote:
> On Mon, Jun 15, 2015 at 11:44:48AM +0100, Wilco Dijkstra wrote:
> > Remove all uses and definition of the internal function __isinf_ns(l/f) as there is no
> benefit in
> > having it when isinf gets inlined in math.h (I'll post that as a separate patch).
> >
> > GLIBC builds and passes math tests on AArch64. OK for commit?
> >
> Almost ok.
>
> > diff --git a/math/divtc3.c b/math/divtc3.c
> > index bfd9b3f..c0dee8e 100644
> > --- a/math/divtc3.c
> > +++ b/math/divtc3.c
> > @@ -54,19 +54,19 @@ __divtc3 (long double a, long double b, long double c, long double d)
> > x = __copysignl (INFINITY, c) * a;
> > y = __copysignl (INFINITY, c) * b;
> > }
> > - else if ((__isinf_nsl (a) || __isinf_nsl (b))
> > + else if ((isinf (a) || isinf (b))
> > && isfinite (c) && isfinite (d))
> > {
> > - a = __copysignl (__isinf_nsl (a) ? 1 : 0, a);
> > - b = __copysignl (__isinf_nsl (b) ? 1 : 0, b);
> > + a = __copysignl (isinf (a) ? 1 : 0, a);
> > + b = __copysignl (isinf (b) ? 1 : 0, b);
> > x = INFINITY * (a * c + b * d);
> > y = INFINITY * (b * c - a * d);
> > }
> > - else if ((__isinf_nsl (c) || __isinf_nsl (d))
> > + else if ((isinf (c) || isinf (d))
> > && isfinite (a) && isfinite (b))
> > {
> > - c = __copysignl (__isinf_nsl (c) ? 1 : 0, c);
> > - d = __copysignl (__isinf_nsl (d) ? 1 : 0, d);
> > + c = __copysignl (isinf (c) ? 1 : 0, c);
> > + d = __copysignl (isinf (d) ? 1 : 0, d);
> > x = 0.0 * (a * c + b * d);
> > y = 0.0 * (b * c - a * d);
> > }
>
> These patterns are unnecessary as with libc they could be written as
>
> c = isinf (c);
>
> with libc isinf.
That's not exactly equivalent due to signed zeroes.
Wilco
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] Remove __isinf_ns
2015-07-09 16:40 ` Wilco Dijkstra
@ 2015-07-09 17:25 ` Ondřej Bílka
0 siblings, 0 replies; 6+ messages in thread
From: Ondřej Bílka @ 2015-07-09 17:25 UTC (permalink / raw)
To: Wilco Dijkstra; +Cc: GNU C Library
On Thu, Jul 09, 2015 at 05:40:21PM +0100, Wilco Dijkstra wrote:
>
>
> > OndÅej BÃlka wrote:
> > On Mon, Jun 15, 2015 at 11:44:48AM +0100, Wilco Dijkstra wrote:
> > > Remove all uses and definition of the internal function __isinf_ns(l/f) as there is no
> > benefit in
> > > having it when isinf gets inlined in math.h (I'll post that as a separate patch).
> > >
> > > GLIBC builds and passes math tests on AArch64. OK for commit?
> > >
> > Almost ok.
> >
> > > diff --git a/math/divtc3.c b/math/divtc3.c
> > > index bfd9b3f..c0dee8e 100644
> > > --- a/math/divtc3.c
> > > +++ b/math/divtc3.c
> > > @@ -54,19 +54,19 @@ __divtc3 (long double a, long double b, long double c, long double d)
> > > x = __copysignl (INFINITY, c) * a;
> > > y = __copysignl (INFINITY, c) * b;
> > > }
> > > - else if ((__isinf_nsl (a) || __isinf_nsl (b))
> > > + else if ((isinf (a) || isinf (b))
> > > && isfinite (c) && isfinite (d))
> > > {
> > > - a = __copysignl (__isinf_nsl (a) ? 1 : 0, a);
> > > - b = __copysignl (__isinf_nsl (b) ? 1 : 0, b);
> > > + a = __copysignl (isinf (a) ? 1 : 0, a);
> > > + b = __copysignl (isinf (b) ? 1 : 0, b);
> > > x = INFINITY * (a * c + b * d);
> > > y = INFINITY * (b * c - a * d);
> > > }
> > > - else if ((__isinf_nsl (c) || __isinf_nsl (d))
> > > + else if ((isinf (c) || isinf (d))
> > > && isfinite (a) && isfinite (b))
> > > {
> > > - c = __copysignl (__isinf_nsl (c) ? 1 : 0, c);
> > > - d = __copysignl (__isinf_nsl (d) ? 1 : 0, d);
> > > + c = __copysignl (isinf (c) ? 1 : 0, c);
> > > + d = __copysignl (isinf (d) ? 1 : 0, d);
> > > x = 0.0 * (a * c + b * d);
> > > y = 0.0 * (b * c - a * d);
> > > }
> >
> > These patterns are unnecessary as with libc they could be written as
> >
> > c = isinf (c);
> >
> > with libc isinf.
>
> That's not exactly equivalent due to signed zeroes.
>
Thanks for clarification.
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2015-07-09 17:25 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2015-06-15 11:30 [PATCH] Remove __isinf_ns Wilco Dijkstra
2015-06-15 15:07 ` Joseph Myers
2015-06-15 16:32 ` Wilco Dijkstra
2015-07-09 15:22 ` Ondřej Bílka
2015-07-09 16:40 ` Wilco Dijkstra
2015-07-09 17:25 ` Ondřej Bílka
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).