# HG changeset patch # User philipjsg # Date 1044410392 0 # Node ID 01d48dc59daba4444ce8da83f676e4a4cba2300c # Parent bde449e6b74325518163d0192c75629ae0c7660f Fix the 'hard cpu loop' problem when capturing audio from /dev/dsp. This code now waits for up to 30ms before reporting that no packet is available. diff -r bde449e6b743 -r 01d48dc59dab audio.c --- a/audio.c Tue Feb 04 23:44:26 2003 +0000 +++ b/audio.c Wed Feb 05 01:59:52 2003 +0000 @@ -244,6 +244,18 @@ if (av_new_packet(pkt, s->frame_size) < 0) return -EIO; for(;;) { + struct timeval tv; + fd_set fds; + + tv.tv_sec = 0; + tv.tv_usec = 30 * 1000; /* 30 msecs -- a bit shorter than 1 frame at 30fps */ + + FD_ZERO(&fds); + FD_SET(s->fd, &fds); + + /* This will block until data is available or we get a timeout */ + (void) select(s->fd + 1, &fds, 0, 0, &tv); + ret = read(s->fd, pkt->data, pkt->size); if (ret > 0) break;