aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDenys Vlasenko <vda.linux@googlemail.com>2020-12-16 21:36:36 +0100
committerDenys Vlasenko <vda.linux@googlemail.com>2020-12-16 21:36:36 +0100
commiteb0c2e218ca1b0d733157bc2a11f8621d4ed2409 (patch)
tree0507607659fb458a001d894cb4503c401bae48a9
parentd3c36882dc5bc5fcede9a45a6bc7a39570fba7d0 (diff)
downloadbusybox-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.h2
-rw-r--r--libbb/xfuncs.c12
-rw-r--r--libbb/xfuncs_printf.c18
-rw-r--r--networking/ntpd.c3
-rw-r--r--util-linux/hwclock.c6
-rw-r--r--util-linux/rdate.c7
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;
657time_t validate_tm_time(const char *date_str, struct tm *ptm) FAST_FUNC; 657time_t validate_tm_time(const char *date_str, struct tm *ptm) FAST_FUNC;
658char *strftime_HHMMSS(char *buf, unsigned len, time_t *tp) FAST_FUNC; 658char *strftime_HHMMSS(char *buf, unsigned len, time_t *tp) FAST_FUNC;
659char *strftime_YYYYMMDDHHMMSS(char *buf, unsigned len, time_t *tp) FAST_FUNC; 659char *strftime_YYYYMMDDHHMMSS(char *buf, unsigned len, time_t *tp) FAST_FUNC;
660void xsettimeofday(const struct timeval *tv) FAST_FUNC;
661
660 662
661int xsocket(int domain, int type, int protocol) FAST_FUNC; 663int xsocket(int domain, int type, int protocol) FAST_FUNC;
662void xbind(int sockfd, struct sockaddr *my_addr, socklen_t addrlen) FAST_FUNC; 664void 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.
423int 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.
708int 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
718void 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
193static void to_sys_clock(const char **pp_rtcname, int utc) 191static 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