summaryrefslogtreecommitdiff
path: root/src/sort.c
diff options
context:
space:
mode:
authorEric Blake <ebb9@byu.net>2009-11-23 14:59:18 -0700
committerEric Blake <ebb9@byu.net>2009-11-24 06:36:07 -0700
commitf9d0bb8481bed4cea5994ed8aae49fcf52c0e604 (patch)
tree89b6696d0c7a8c7673b14de0fff4214b87633a78 /src/sort.c
parentab6b27eba720c04da91f5300121a6fe06d1fa9b4 (diff)
downloadcoreutils-f9d0bb8481bed4cea5994ed8aae49fcf52c0e604.tar.xz
build: fix link failure on cygwin
Cygwin 1.5 has a broken sleep, and the gnulib tests dragged in rpl_sleep which then caused a link failure because it wasn't in libcoreutils.a. We could solve it by using the gnulib sleep module. However, sleep and usleep may interact poorly with SIGALRM, and they have less granularity; so it is better to adopt a policy that if we must sleep, prefer xnanosleep. * src/sort.c (pipe_fork): Use xnanosleep, to avoid the need for rpl_sleep on cygwin, and to reduce granularity. (MAX_FORK_TRIES_COMPRESS, MAX_FORK_TRIES_DECOMPRESS): Increase, to account for reduction in granularity. * src/tail.c (tail_file): Use xnanosleep in debug code. * cfg.mk (sc_prohibit_sleep): New rule.
Diffstat (limited to 'src/sort.c')
-rw-r--r--src/sort.c13
1 files changed, 7 insertions, 6 deletions
diff --git a/src/sort.c b/src/sort.c
index 0213fee1f..8709e5370 100644
--- a/src/sort.c
+++ b/src/sort.c
@@ -44,6 +44,7 @@
#include "strnumcmp.h"
#include "xmemcoll.h"
#include "xmemxfrm.h"
+#include "xnanosleep.h"
#include "xstrtol.h"
#if HAVE_SYS_RESOURCE_H
@@ -107,13 +108,13 @@ enum
/* The number of times we should try to fork a compression process
(we retry if the fork call fails). We don't _need_ to compress
temp files, this is just to reduce disk access, so this number
- can be small. */
- MAX_FORK_TRIES_COMPRESS = 2,
+ can be small. Each retry doubles in duration. */
+ MAX_FORK_TRIES_COMPRESS = 4,
/* The number of times we should try to fork a decompression process.
If we can't fork a decompression process, we can't sort, so this
- number should be big. */
- MAX_FORK_TRIES_DECOMPRESS = 8
+ number should be big. Each retry doubles in duration. */
+ MAX_FORK_TRIES_DECOMPRESS = 9
};
/* The representation of the decimal point in the current locale. */
@@ -868,7 +869,7 @@ pipe_fork (int pipefds[2], size_t tries)
#if HAVE_WORKING_FORK
struct tempnode *saved_temphead;
int saved_errno;
- unsigned int wait_retry = 1;
+ double wait_retry = 0.25;
pid_t pid IF_LINT (= -1);
struct cs_status cs;
@@ -895,7 +896,7 @@ pipe_fork (int pipefds[2], size_t tries)
break;
else
{
- sleep (wait_retry);
+ xnanosleep (wait_retry);
wait_retry *= 2;
reap_some ();
}