Browse Source

Cope with signals interrupting the nanosleep of nmsleep.

nfactor-troky
Con Kolivas 13 years ago
parent
commit
bc0b14063f
  1. 15
      util.c

15
util.c

@ -692,9 +692,14 @@ void thr_info_cancel(struct thr_info *thr)
* on SMP machines */ * on SMP machines */
void nmsleep(unsigned int msecs) void nmsleep(unsigned int msecs)
{ {
struct timespec twait; struct timespec twait, tleft;
int ret;
twait.tv_sec = msecs / 1000;
twait.tv_nsec = (uint64_t)(msecs * 1000000) - (uint64_t)(twait.tv_sec / 1000000000); tleft.tv_sec = msecs / 1000;
nanosleep(&twait, NULL); tleft.tv_nsec = (uint64_t)(msecs * 1000000) - (uint64_t)(twait.tv_sec / 1000000000);
do {
twait.tv_sec = tleft.tv_sec;
twait.tv_nsec = tleft.tv_nsec;
ret = nanosleep(&twait, &tleft);
} while (ret == -1 && errno == EINTR);
} }

Loading…
Cancel
Save