summaryrefslogtreecommitdiff
path: root/src/common
diff options
context:
space:
mode:
authorteor (Tim Wilson-Brown) <teor2345@gmail.com>2016-06-30 09:19:33 +1000
committerteor (Tim Wilson-Brown) <teor2345@gmail.com>2016-06-30 09:29:14 +1000
commitaae14f83466364187dd04334e2f8b02e06002a88 (patch)
treec89c30842d35f44695b85fedaf34acae03669fcb /src/common
parent11ba7f00371ef3ed7b9fd353aad4e3e672239a40 (diff)
downloadtor-aae14f83466364187dd04334e2f8b02e06002a88.tar.gz
tor-aae14f83466364187dd04334e2f8b02e06002a88.zip
Fix bug19483: avoid range checks when they are always true
Some compilers are smart enough to work out that comparisons to LONG_MAX are a no-op on L64.
Diffstat (limited to 'src/common')
-rw-r--r--src/common/util.c14
1 files changed, 10 insertions, 4 deletions
diff --git a/src/common/util.c b/src/common/util.c
index 613e0001ea..fce99ee3f4 100644
--- a/src/common/util.c
+++ b/src/common/util.c
@@ -1451,11 +1451,14 @@ tv_udiff(const struct timeval *start, const struct timeval *end)
* between 0 and TV_USEC_PER_SEC. */
udiff = secdiff*1000000 + ((int64_t)end->tv_usec - (int64_t)start->tv_usec);
+ /* Some compilers are smart enough to work out this is a no-op on L64 */
+#if SIZEOF_LONG < 8
if (udiff > (int64_t)LONG_MAX || udiff < (int64_t)LONG_MIN) {
return LONG_MAX;
- } else {
- return (long)udiff;
}
+#endif
+
+ return (long)udiff;
}
/** Return the number of milliseconds elapsed between *start and *end.
@@ -1507,11 +1510,14 @@ tv_mdiff(const struct timeval *start, const struct timeval *end)
((int64_t)end->tv_usec - (int64_t)start->tv_usec + 500 + 1000000) / 1000
- 1000;
+ /* Some compilers are smart enough to work out this is a no-op on L64 */
+#if SIZEOF_LONG < 8
if (mdiff > (int64_t)LONG_MAX || mdiff < (int64_t)LONG_MIN) {
return LONG_MAX;
- } else {
- return (long)mdiff;
}
+#endif
+
+ return (long)mdiff;
}
/**