1 /* Pausing execution of the current thread.
2 Copyright (C) 2009-2020 Free Software Foundation, Inc.
3 Written by Eric Blake <ebb9@byu.net>, 2009.
5 This program is free software: you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 3 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program. If not, see <https://www.gnu.org/licenses/>. */
18 /* This file is _intentionally_ light-weight. Rather than using
19 select or nanosleep, both of which drag in external libraries on
20 some platforms, this merely rounds up to the nearest second if
21 usleep() does not exist. If sub-second resolution is important,
22 then use a more powerful interface to begin with. */
31 #if defined _WIN32 && ! defined __CYGWIN__
32 # define WIN32_LEAN_AND_MEAN /* avoid including junk */
37 # define HAVE_USLEEP 0
40 /* Sleep for MICRO microseconds, which can be greater than 1 second.
41 Return -1 and set errno to EINVAL on range error (about 4295
42 seconds), or 0 on success. Interaction with SIGALARM is
46 usleep (useconds_t micro
)
49 #if defined _WIN32 && ! defined __CYGWIN__
50 unsigned int milliseconds
= micro
/ 1000;
51 if (sizeof milliseconds
< sizeof micro
&& micro
/ 1000 != milliseconds
)
61 unsigned int seconds
= micro
/ 1000000;
62 if (sizeof seconds
< sizeof micro
&& micro
/ 1000000 != seconds
)
67 if (!HAVE_USLEEP
&& micro
% 1000000)
69 while ((seconds
= sleep (seconds
)) != 0);
74 return usleep (micro
% 1000000);