summaryrefslogtreecommitdiffstats
path: root/sys
diff options
context:
space:
mode:
authorWim Taymans <wim.taymans@gmail.com>2003-05-31 14:14:21 +0000
committerWim Taymans <wim.taymans@gmail.com>2003-05-31 14:14:21 +0000
commitf11e5be82f27094d51bc8244d0f08957fe8d5a2f (patch)
tree56dedc2d3f43e2bb66eb4e8da69c275706182afb /sys
parent04b611b88ce9aec269a0f79f216fae2e39eb4b7b (diff)
- use common code to write samples to the device
Original commit message from CVS: - use common code to write samples to the device - add some error handling
Diffstat (limited to 'sys')
-rw-r--r--sys/oss/gstosssink.c32
1 files changed, 20 insertions, 12 deletions
diff --git a/sys/oss/gstosssink.c b/sys/oss/gstosssink.c
index 1ce75397..f8edd5a1 100644
--- a/sys/oss/gstosssink.c
+++ b/sys/oss/gstosssink.c
@@ -22,6 +22,7 @@
#include <sys/ioctl.h>
#include <sys/soundcard.h>
+#include <errno.h>
#include <gstosssink.h>
@@ -383,6 +384,7 @@ gst_osssink_chain (GstPad *pad, GstBuffer *buf)
if (!osssink->mute) {
guchar *data = GST_BUFFER_DATA (buf);
gint size = GST_BUFFER_SIZE (buf);
+ gint to_write = 0;
if (osssink->clock) {
gint delay = 0;
@@ -400,22 +402,13 @@ gst_osssink_chain (GstPad *pad, GstBuffer *buf)
if (jitter >= 0) {
gst_clock_handle_discont (osssink->clock, buftime - queued + jitter);
- write (osssink->common.fd, data, size);
+ to_write = size;
gst_oss_clock_set_active (osssink->provided_clock, TRUE);
osssink->resync = FALSE;
- osssink->handled += size;
}
}
else {
- gint to_write;
- while (size > 0) {
- to_write = MIN (size, osssink->chunk_size);
-
- write (osssink->common.fd, data, to_write);
- size -= to_write;
- data += to_write;
- osssink->handled += to_write;
- }
+ to_write = size;
}
}
/* no clock, try to be as fast as possible */
@@ -425,7 +418,22 @@ gst_osssink_chain (GstPad *pad, GstBuffer *buf)
ioctl (osssink->common.fd, SNDCTL_DSP_GETOSPACE, &ospace);
if (ospace.bytes >= size) {
- write (osssink->common.fd, data, size);
+ to_write = size;
+ }
+ }
+
+ while (to_write > 0) {
+ gint done = write (osssink->common.fd, data,
+ MIN (to_write, osssink->chunk_size));
+
+ if (done == -1) {
+ if (errno != EINTR)
+ break;
+ }
+ else {
+ to_write -= done;
+ data += done;
+ osssink->handled += done;
}
}
}