diff options
author | Denys Vlasenko <vda.linux@googlemail.com> | 2020-12-16 21:36:36 +0100 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2020-12-16 21:36:36 +0100 |
commit | eb0c2e218ca1b0d733157bc2a11f8621d4ed2409 (patch) | |
tree | 0507607659fb458a001d894cb4503c401bae48a9 | |
parent | d3c36882dc5bc5fcede9a45a6bc7a39570fba7d0 (diff) | |
download | busybox-w32-eb0c2e218ca1b0d733157bc2a11f8621d4ed2409.tar.gz busybox-w32-eb0c2e218ca1b0d733157bc2a11f8621d4ed2409.tar.bz2 busybox-w32-eb0c2e218ca1b0d733157bc2a11f8621d4ed2409.zip |
libbb: introduce and use xsettimeofday()
function old new delta
xsettimeofday - 25 +25
rdate_main 274 260 -14
step_time 348 331 -17
set_kernel_timezone_and_clock 119 102 -17
------------------------------------------------------------------------------
(add/remove: 1/0 grow/shrink: 0/3 up/down: 25/-48) Total: -23 bytes
text data bss dec hex filename
1020753 559 5052 1026364 fa93c busybox_old
1020708 559 5052 1026319 fa90f busybox_unstripped
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
-rw-r--r-- | include/libbb.h | 2 | ||||
-rw-r--r-- | libbb/xfuncs.c | 12 | ||||
-rw-r--r-- | libbb/xfuncs_printf.c | 18 | ||||
-rw-r--r-- | networking/ntpd.c | 3 | ||||
-rw-r--r-- | util-linux/hwclock.c | 6 | ||||
-rw-r--r-- | util-linux/rdate.c | 7 |
6 files changed, 26 insertions, 22 deletions
diff --git a/include/libbb.h b/include/libbb.h index 6b7141456..1c3d905b6 100644 --- a/include/libbb.h +++ b/include/libbb.h | |||
@@ -657,6 +657,8 @@ void parse_datestr(const char *date_str, struct tm *ptm) FAST_FUNC; | |||
657 | time_t validate_tm_time(const char *date_str, struct tm *ptm) FAST_FUNC; | 657 | time_t validate_tm_time(const char *date_str, struct tm *ptm) FAST_FUNC; |
658 | char *strftime_HHMMSS(char *buf, unsigned len, time_t *tp) FAST_FUNC; | 658 | char *strftime_HHMMSS(char *buf, unsigned len, time_t *tp) FAST_FUNC; |
659 | char *strftime_YYYYMMDDHHMMSS(char *buf, unsigned len, time_t *tp) FAST_FUNC; | 659 | char *strftime_YYYYMMDDHHMMSS(char *buf, unsigned len, time_t *tp) FAST_FUNC; |
660 | void xsettimeofday(const struct timeval *tv) FAST_FUNC; | ||
661 | |||
660 | 662 | ||
661 | int xsocket(int domain, int type, int protocol) FAST_FUNC; | 663 | int xsocket(int domain, int type, int protocol) FAST_FUNC; |
662 | void xbind(int sockfd, struct sockaddr *my_addr, socklen_t addrlen) FAST_FUNC; | 664 | void xbind(int sockfd, struct sockaddr *my_addr, socklen_t addrlen) FAST_FUNC; |
diff --git a/libbb/xfuncs.c b/libbb/xfuncs.c index ee2dbdef1..d93d8aaf5 100644 --- a/libbb/xfuncs.c +++ b/libbb/xfuncs.c | |||
@@ -417,15 +417,3 @@ int FAST_FUNC wait4pid(pid_t pid) | |||
417 | return WTERMSIG(status) + 0x180; | 417 | return WTERMSIG(status) + 0x180; |
418 | return 0; | 418 | return 0; |
419 | } | 419 | } |
420 | |||
421 | // Useful when we do know that pid is valid, and we just want to wait | ||
422 | // for it to exit. Not existing pid is fatal. waitpid() status is not returned. | ||
423 | int FAST_FUNC wait_for_exitstatus(pid_t pid) | ||
424 | { | ||
425 | int exit_status, n; | ||
426 | |||
427 | n = safe_waitpid(pid, &exit_status, 0); | ||
428 | if (n < 0) | ||
429 | bb_simple_perror_msg_and_die("waitpid"); | ||
430 | return exit_status; | ||
431 | } | ||
diff --git a/libbb/xfuncs_printf.c b/libbb/xfuncs_printf.c index db40e996b..6c220434d 100644 --- a/libbb/xfuncs_printf.c +++ b/libbb/xfuncs_printf.c | |||
@@ -702,3 +702,21 @@ void FAST_FUNC xvfork_parent_waits_and_exits(void) | |||
702 | } | 702 | } |
703 | /* Child continues */ | 703 | /* Child continues */ |
704 | } | 704 | } |
705 | |||
706 | // Useful when we do know that pid is valid, and we just want to wait | ||
707 | // for it to exit. Not existing pid is fatal. waitpid() status is not returned. | ||
708 | int FAST_FUNC wait_for_exitstatus(pid_t pid) | ||
709 | { | ||
710 | int exit_status, n; | ||
711 | |||
712 | n = safe_waitpid(pid, &exit_status, 0); | ||
713 | if (n < 0) | ||
714 | bb_simple_perror_msg_and_die("waitpid"); | ||
715 | return exit_status; | ||
716 | } | ||
717 | |||
718 | void FAST_FUNC xsettimeofday(const struct timeval *tv) | ||
719 | { | ||
720 | if (settimeofday(tv, NULL)) | ||
721 | bb_simple_perror_msg_and_die("settimeofday"); | ||
722 | } | ||
diff --git a/networking/ntpd.c b/networking/ntpd.c index 032dc51ac..06f6017d0 100644 --- a/networking/ntpd.c +++ b/networking/ntpd.c | |||
@@ -1147,8 +1147,7 @@ step_time(double offset) | |||
1147 | gettimeofday(&tvc, NULL); /* never fails */ | 1147 | gettimeofday(&tvc, NULL); /* never fails */ |
1148 | dtime = tvc.tv_sec + (1.0e-6 * tvc.tv_usec) + offset; | 1148 | dtime = tvc.tv_sec + (1.0e-6 * tvc.tv_usec) + offset; |
1149 | d_to_tv(dtime, &tvn); | 1149 | d_to_tv(dtime, &tvn); |
1150 | if (settimeofday(&tvn, NULL) == -1) | 1150 | xsettimeofday(&tvn); |
1151 | bb_simple_perror_msg_and_die("settimeofday"); | ||
1152 | 1151 | ||
1153 | VERB2 { | 1152 | VERB2 { |
1154 | tval = tvc.tv_sec; | 1153 | tval = tvc.tv_sec; |
diff --git a/util-linux/hwclock.c b/util-linux/hwclock.c index 77aa2d7c3..dd66ec199 100644 --- a/util-linux/hwclock.c +++ b/util-linux/hwclock.c | |||
@@ -184,10 +184,8 @@ static void set_kernel_timezone_and_clock(int utc, const struct timeval *hctosys | |||
184 | /*tz.tz_dsttime = 0; already is */ | 184 | /*tz.tz_dsttime = 0; already is */ |
185 | set_kernel_tz(&tz); /* MIGHT warp_clock() if 1st call since boot */ | 185 | set_kernel_tz(&tz); /* MIGHT warp_clock() if 1st call since boot */ |
186 | 186 | ||
187 | if (hctosys) { /* it's --hctosys: set time too */ | 187 | if (hctosys) /* it's --hctosys: set time too */ |
188 | if (settimeofday(hctosys, NULL)) | 188 | xsettimeofday(hctosys); |
189 | bb_simple_perror_msg_and_die("settimeofday"); | ||
190 | } | ||
191 | } | 189 | } |
192 | 190 | ||
193 | static void to_sys_clock(const char **pp_rtcname, int utc) | 191 | static void to_sys_clock(const char **pp_rtcname, int utc) |
diff --git a/util-linux/rdate.c b/util-linux/rdate.c index bb1dc519a..9b80141c9 100644 --- a/util-linux/rdate.c +++ b/util-linux/rdate.c | |||
@@ -96,11 +96,10 @@ int rdate_main(int argc UNUSED_PARAM, char **argv) | |||
96 | if (time(NULL) == remote_time) | 96 | if (time(NULL) == remote_time) |
97 | bb_simple_error_msg("current time matches remote time"); | 97 | bb_simple_error_msg("current time matches remote time"); |
98 | else { | 98 | else { |
99 | struct timespec ts; | 99 | struct timeval ts; |
100 | ts.tv_sec = remote_time; | 100 | ts.tv_sec = remote_time; |
101 | ts.tv_nsec = 0; | 101 | ts.tv_usec = 0; |
102 | if (clock_settime(CLOCK_REALTIME, &ts) < 0) | 102 | xsettimeofday(&ts); |
103 | bb_simple_perror_msg_and_die("can't set time of day"); | ||
104 | } | 103 | } |
105 | } | 104 | } |
106 | 105 | ||