diff options
| author | Bernhard Reutner-Fischer <rep.dot.nop@gmail.com> | 2014-04-13 16:37:57 +0200 |
|---|---|---|
| committer | Denys Vlasenko <vda.linux@googlemail.com> | 2014-04-13 16:37:57 +0200 |
| commit | ad16741ccd8a8587644d88fb8fdfc41ada1928a6 (patch) | |
| tree | aa6461272aa3b71bb2f2f8da4b91a31d8b35eb59 | |
| parent | 69b114fb8a2566e14ce125f7736add9dacf6e18d (diff) | |
| download | busybox-w32-ad16741ccd8a8587644d88fb8fdfc41ada1928a6.tar.gz busybox-w32-ad16741ccd8a8587644d88fb8fdfc41ada1928a6.tar.bz2 busybox-w32-ad16741ccd8a8587644d88fb8fdfc41ada1928a6.zip | |
libbb: provide usleep() fallback implementation
POSIX.1-2008 removed the usleep function, provide a fallback
implementaion using the recommended nanosleep().
Signed-off-by: Bernhard Reutner-Fischer <rep.dot.nop@gmail.com>
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
| -rw-r--r-- | include/platform.h | 16 | ||||
| -rw-r--r-- | libbb/platform.c | 18 |
2 files changed, 32 insertions, 2 deletions
diff --git a/include/platform.h b/include/platform.h index bd11ad69a..92f775551 100644 --- a/include/platform.h +++ b/include/platform.h | |||
| @@ -373,6 +373,7 @@ typedef unsigned smalluint; | |||
| 373 | #define HAVE_STRSIGNAL 1 | 373 | #define HAVE_STRSIGNAL 1 |
| 374 | #define HAVE_STRVERSCMP 1 | 374 | #define HAVE_STRVERSCMP 1 |
| 375 | #define HAVE_VASPRINTF 1 | 375 | #define HAVE_VASPRINTF 1 |
| 376 | #define HAVE_USLEEP 1 | ||
| 376 | #define HAVE_UNLOCKED_STDIO 1 | 377 | #define HAVE_UNLOCKED_STDIO 1 |
| 377 | #define HAVE_UNLOCKED_LINE_OPS 1 | 378 | #define HAVE_UNLOCKED_LINE_OPS 1 |
| 378 | #define HAVE_GETLINE 1 | 379 | #define HAVE_GETLINE 1 |
| @@ -381,8 +382,15 @@ typedef unsigned smalluint; | |||
| 381 | #define HAVE_NET_ETHERNET_H 1 | 382 | #define HAVE_NET_ETHERNET_H 1 |
| 382 | #define HAVE_SYS_STATFS_H 1 | 383 | #define HAVE_SYS_STATFS_H 1 |
| 383 | 384 | ||
| 384 | #if defined(__UCLIBC__) && UCLIBC_VERSION < KERNEL_VERSION(0, 9, 32) | 385 | #if defined(__UCLIBC__) |
| 385 | # undef HAVE_STRVERSCMP | 386 | # if UCLIBC_VERSION < KERNEL_VERSION(0, 9, 32) |
| 387 | # undef HAVE_STRVERSCMP | ||
| 388 | # endif | ||
| 389 | # if UCLIBC_VERSION >= KERNEL_VERSION(0, 9, 30) | ||
| 390 | # ifndef __UCLIBC_SUSV3_LEGACY__ | ||
| 391 | # undef HAVE_USLEEP | ||
| 392 | # endif | ||
| 393 | # endif | ||
| 386 | #endif | 394 | #endif |
| 387 | 395 | ||
| 388 | #if defined(__WATCOMC__) | 396 | #if defined(__WATCOMC__) |
| @@ -519,6 +527,10 @@ extern char *strsep(char **stringp, const char *delim) FAST_FUNC; | |||
| 519 | # define strsignal(sig) get_signame(sig) | 527 | # define strsignal(sig) get_signame(sig) |
| 520 | #endif | 528 | #endif |
| 521 | 529 | ||
| 530 | #ifndef HAVE_USLEEP | ||
| 531 | extern int usleep(unsigned) FAST_FUNC; | ||
| 532 | #endif | ||
| 533 | |||
| 522 | #ifndef HAVE_VASPRINTF | 534 | #ifndef HAVE_VASPRINTF |
| 523 | extern int vasprintf(char **string_ptr, const char *format, va_list p) FAST_FUNC; | 535 | extern int vasprintf(char **string_ptr, const char *format, va_list p) FAST_FUNC; |
| 524 | #endif | 536 | #endif |
diff --git a/libbb/platform.c b/libbb/platform.c index 19734517b..8d90ca4e9 100644 --- a/libbb/platform.c +++ b/libbb/platform.c | |||
| @@ -17,6 +17,24 @@ char* FAST_FUNC strchrnul(const char *s, int c) | |||
| 17 | } | 17 | } |
| 18 | #endif | 18 | #endif |
| 19 | 19 | ||
| 20 | #ifndef HAVE_USLEEP | ||
| 21 | int FAST_FUNC usleep(unsigned usec) | ||
| 22 | { | ||
| 23 | struct timespec ts; | ||
| 24 | ts.tv_sec = usec / 1000000u; | ||
| 25 | ts.tv_nsec = (usec % 1000000u) * 1000u; | ||
| 26 | /* | ||
| 27 | * If a signal has non-default handler, nanosleep returns early. | ||
| 28 | * Our version of usleep doesn't return early | ||
| 29 | * if interrupted by such signals: | ||
| 30 | * | ||
| 31 | */ | ||
| 32 | while (nanosleep(&ts, &ts) != 0) | ||
| 33 | continue; | ||
| 34 | return 0; | ||
| 35 | } | ||
| 36 | #endif | ||
| 37 | |||
| 20 | #ifndef HAVE_VASPRINTF | 38 | #ifndef HAVE_VASPRINTF |
| 21 | int FAST_FUNC vasprintf(char **string_ptr, const char *format, va_list p) | 39 | int FAST_FUNC vasprintf(char **string_ptr, const char *format, va_list p) |
| 22 | { | 40 | { |
