summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorBastien Nocera <hadess@users.sourceforge.net>2005-03-31 22:46:15 +0000
committerBastien Nocera <hadess@users.sourceforge.net>2005-03-31 22:46:15 +0000
commit67e530e95ee93fce168465234ac2d1f7540ff0b4 (patch)
treef32af033344a31678867855ea8ddcb6b17f7f458 /src
parent59dbbde187ebc62564d8c0c62eec4b466ca05cf6 (diff)
downloadxine-lib-67e530e95ee93fce168465234ac2d1f7540ff0b4.tar.gz
xine-lib-67e530e95ee93fce168465234ac2d1f7540ff0b4.tar.bz2
- handle EINTR when calling nanosleep, spotted by Mathieu Routhier
CVS patchset: 7444 CVS date: 2005/03/31 22:46:15
Diffstat (limited to 'src')
-rw-r--r--src/xine-utils/utils.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/src/xine-utils/utils.c b/src/xine-utils/utils.c
index 16499b713..59cb4da32 100644
--- a/src/xine-utils/utils.c
+++ b/src/xine-utils/utils.c
@@ -17,7 +17,7 @@
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
*
- * $Id: utils.c,v 1.37 2004/10/30 15:04:47 miguelfreitas Exp $
+ * $Id: utils.c,v 1.38 2005/03/31 22:46:15 hadess Exp $
*
*/
#define _POSIX_PTHREAD_SEMANTICS 1 /* for 5-arg getpwuid_r on solaris */
@@ -420,11 +420,12 @@ char *xine_chomp(char *str) {
void xine_usec_sleep(unsigned usec) {
#if HAVE_NANOSLEEP
/* nanosleep is prefered on solaris, because it's mt-safe */
- struct timespec ts;
+ struct timespec ts, remaining;
ts.tv_sec = usec / 1000000;
ts.tv_nsec = (usec % 1000000) * 1000;
- nanosleep(&ts, NULL);
+ while (nanosleep (&ts, &remaining) == -1 && errno == EINTR)
+ ts = remaining;
#else
# if WIN32
Sleep(usec / 1000);