diff options
author | Denys Vlasenko <vda.linux@googlemail.com> | 2019-10-24 16:26:55 +0200 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2019-10-24 16:26:55 +0200 |
commit | be5a505d771a77c640acc35ceaa470c80e62f954 (patch) | |
tree | c15e916dcf9ea7809794e36440c066f5b2f79598 | |
parent | 7427406580e78666fad3634b4bfaf1922d4bb457 (diff) | |
download | busybox-w32-be5a505d771a77c640acc35ceaa470c80e62f954.tar.gz busybox-w32-be5a505d771a77c640acc35ceaa470c80e62f954.tar.bz2 busybox-w32-be5a505d771a77c640acc35ceaa470c80e62f954.zip |
Remove syscall wrappers around clock_gettime, closes 12091
12091 "Direct use of __NR_clock_gettime is not time64-safe".
function old new delta
runsv_main 1698 1712 +14
startservice 378 383 +5
get_mono 31 25 -6
date_main 932 926 -6
gettimeofday_ns 17 - -17
------------------------------------------------------------------------------
(add/remove: 0/1 grow/shrink: 2/2 up/down: 19/-29) Total: -10 bytes
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
-rw-r--r-- | Makefile.flags | 6 | ||||
-rw-r--r-- | coreutils/date.c | 16 | ||||
-rw-r--r-- | libbb/time.c | 11 | ||||
-rw-r--r-- | runit/runsv.c | 11 |
4 files changed, 9 insertions, 35 deletions
diff --git a/Makefile.flags b/Makefile.flags index 6f6142cc5..bea464753 100644 --- a/Makefile.flags +++ b/Makefile.flags | |||
@@ -129,10 +129,12 @@ endif | |||
129 | # fall back to using a temp file: | 129 | # fall back to using a temp file: |
130 | CRYPT_AVAILABLE := $(shell echo 'int main(void){return 0;}' >crypttest.c; $(CC) $(CFLAGS) -lcrypt -o /dev/null crypttest.c >/dev/null 2>&1 && echo "y"; rm crypttest.c) | 130 | CRYPT_AVAILABLE := $(shell echo 'int main(void){return 0;}' >crypttest.c; $(CC) $(CFLAGS) -lcrypt -o /dev/null crypttest.c >/dev/null 2>&1 && echo "y"; rm crypttest.c) |
131 | ifeq ($(CRYPT_AVAILABLE),y) | 131 | ifeq ($(CRYPT_AVAILABLE),y) |
132 | LDLIBS += m crypt | 132 | LDLIBS += m rt crypt |
133 | else | 133 | else |
134 | LDLIBS += m | 134 | LDLIBS += m rt |
135 | endif | 135 | endif |
136 | # libm may be needed for dc, awk, ntpd | ||
137 | # librt may be needed for clock_gettime() | ||
136 | 138 | ||
137 | # libpam may use libpthread, libdl and/or libaudit. | 139 | # libpam may use libpthread, libdl and/or libaudit. |
138 | # On some platforms that requires an explicit -lpthread, -ldl, -laudit. | 140 | # On some platforms that requires an explicit -lpthread, -ldl, -laudit. |
diff --git a/coreutils/date.c b/coreutils/date.c index 731241536..f7e9a8d0e 100644 --- a/coreutils/date.c +++ b/coreutils/date.c | |||
@@ -33,10 +33,9 @@ | |||
33 | //config: Enable option (-I) to output an ISO-8601 compliant | 33 | //config: Enable option (-I) to output an ISO-8601 compliant |
34 | //config: date/time string. | 34 | //config: date/time string. |
35 | //config: | 35 | //config: |
36 | //config:# defaults to "no": stat's nanosecond field is a bit non-portable | ||
37 | //config:config FEATURE_DATE_NANO | 36 | //config:config FEATURE_DATE_NANO |
38 | //config: bool "Support %[num]N nanosecond format specifier" | 37 | //config: bool "Support %[num]N nanosecond format specifier" |
39 | //config: default n # syscall(__NR_clock_gettime) or syscall(__NR_clock_gettime64) | 38 | //config: default n # stat's nanosecond field is a bit non-portable |
40 | //config: depends on DATE | 39 | //config: depends on DATE |
41 | //config: select PLATFORM_LINUX | 40 | //config: select PLATFORM_LINUX |
42 | //config: help | 41 | //config: help |
@@ -271,17 +270,8 @@ int date_main(int argc UNUSED_PARAM, char **argv) | |||
271 | */ | 270 | */ |
272 | #endif | 271 | #endif |
273 | } else { | 272 | } else { |
274 | #if ENABLE_FEATURE_DATE_NANO && defined(__NR_clock_gettime) | 273 | #if ENABLE_FEATURE_DATE_NANO |
275 | /* libc has incredibly messy way of doing this, | 274 | clock_gettime(CLOCK_REALTIME, &ts); |
276 | * typically requiring -lrt. We just skip all this mess */ | ||
277 | syscall(__NR_clock_gettime, CLOCK_REALTIME, &ts); | ||
278 | #elif ENABLE_FEATURE_DATE_NANO && __TIMESIZE == 64 | ||
279 | /* Let's only support the 64 suffix syscalls for 64-bit time_t. | ||
280 | * This simplifies the code for us as we don't need to convert | ||
281 | * between 64-bit and 32-bit. We also don't have a way to | ||
282 | * report overflow errors here. | ||
283 | */ | ||
284 | syscall(__NR_clock_gettime64, CLOCK_REALTIME, &ts); | ||
285 | #else | 275 | #else |
286 | time(&ts.tv_sec); | 276 | time(&ts.tv_sec); |
287 | #endif | 277 | #endif |
diff --git a/libbb/time.c b/libbb/time.c index b6fcae28b..e66a9cba8 100644 --- a/libbb/time.c +++ b/libbb/time.c | |||
@@ -253,18 +253,9 @@ char* FAST_FUNC strftime_YYYYMMDDHHMMSS(char *buf, unsigned len, time_t *tp) | |||
253 | #define CLOCK_MONOTONIC 1 | 253 | #define CLOCK_MONOTONIC 1 |
254 | #endif | 254 | #endif |
255 | 255 | ||
256 | /* libc has incredibly messy way of doing this, | ||
257 | * typically requiring -lrt. We just skip all this mess */ | ||
258 | static void get_mono(struct timespec *ts) | 256 | static void get_mono(struct timespec *ts) |
259 | { | 257 | { |
260 | #if defined(__NR_clock_gettime) | 258 | if (clock_gettime(CLOCK_MONOTONIC, ts)) |
261 | if (syscall(__NR_clock_gettime, CLOCK_MONOTONIC, ts)) | ||
262 | #elif __TIMESIZE == 64 | ||
263 | if (syscall(__NR_clock_gettime64, CLOCK_MONOTONIC, ts)) | ||
264 | #else | ||
265 | # error "We currently don't support architectures without " \ | ||
266 | "the __NR_clock_gettime syscall and 32-bit time_t" | ||
267 | #endif | ||
268 | bb_simple_error_msg_and_die("clock_gettime(MONOTONIC) failed"); | 259 | bb_simple_error_msg_and_die("clock_gettime(MONOTONIC) failed"); |
269 | } | 260 | } |
270 | unsigned long long FAST_FUNC monotonic_ns(void) | 261 | unsigned long long FAST_FUNC monotonic_ns(void) |
diff --git a/runit/runsv.c b/runit/runsv.c index 737909b0e..36d85101e 100644 --- a/runit/runsv.c +++ b/runit/runsv.c | |||
@@ -51,18 +51,9 @@ ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |||
51 | #if ENABLE_MONOTONIC_SYSCALL | 51 | #if ENABLE_MONOTONIC_SYSCALL |
52 | #include <sys/syscall.h> | 52 | #include <sys/syscall.h> |
53 | 53 | ||
54 | /* libc has incredibly messy way of doing this, | ||
55 | * typically requiring -lrt. We just skip all this mess */ | ||
56 | static void gettimeofday_ns(struct timespec *ts) | 54 | static void gettimeofday_ns(struct timespec *ts) |
57 | { | 55 | { |
58 | #if defined(__NR_clock_gettime) | 56 | clock_gettime(CLOCK_REALTIME, ts); |
59 | syscall(__NR_clock_gettime, CLOCK_REALTIME, ts); | ||
60 | #elif __TIMESIZE == 64 | ||
61 | syscall(__NR_clock_gettime64, CLOCK_REALTIME, ts); | ||
62 | #else | ||
63 | # error "We currently don't support architectures without " \ | ||
64 | "the __NR_clock_gettime syscall and 32-bit time_t" | ||
65 | #endif | ||
66 | } | 57 | } |
67 | #else | 58 | #else |
68 | static void gettimeofday_ns(struct timespec *ts) | 59 | static void gettimeofday_ns(struct timespec *ts) |