summaryrefslogtreecommitdiffstats
path: root/audio
diff options
context:
space:
mode:
authorache <ache@FreeBSD.org>1998-06-16 18:28:32 +0000
committerache <ache@FreeBSD.org>1998-06-16 18:28:32 +0000
commitc21b678054365d2d5d505a161740731ac174c136 (patch)
tree54a786f54bb7333ab852f659b30a69620e9ffabe /audio
parent6c66a3e1269e1f9cf50ecaa0db1b0de35741fb3f (diff)
downloadFreeBSD-ports-c21b678054365d2d5d505a161740731ac174c136.zip
FreeBSD-ports-c21b678054365d2d5d505a161740731ac174c136.tar.gz
Minimize differences, handle EINTR
Diffstat (limited to 'audio')
-rw-r--r--audio/timidity/files/patch-ae34
1 files changed, 20 insertions, 14 deletions
diff --git a/audio/timidity/files/patch-ae b/audio/timidity/files/patch-ae
index 004d19a..1c8b9c9 100644
--- a/audio/timidity/files/patch-ae
+++ b/audio/timidity/files/patch-ae
@@ -1,5 +1,5 @@
*** linux_a.c.orig Mon May 20 17:09:46 1996
---- linux_a.c Tue Jun 16 19:59:01 1998
+--- linux_a.c Tue Jun 16 21:40:17 1998
***************
*** 71,82 ****
then 8-bit unsigned if it fails. If you have a sound device that
@@ -110,13 +110,13 @@
if (dpm.encoding & PE_16BIT) tmp++;
tmp |= (dpm.extra_param[0]<<16);
***************
-*** 189,215 ****
+*** 189,216 ****
return warnings;
}
static void output_data(int32 *buf, int32 count)
{
-! if (!(dpm.encoding & PE_MONO)) count*=2; /* Stereo samples */
+ if (!(dpm.encoding & PE_MONO)) count*=2; /* Stereo samples */
! if (dpm.encoding & PE_16BIT)
! {
@@ -138,7 +138,8 @@
}
}
---- 235,264 ----
+ static void close_output(void)
+--- 235,269 ----
return warnings;
}
@@ -147,25 +148,30 @@
+ doesn't. */
static void output_data(int32 *buf, int32 count)
{
-! char *p;
-! int res, l;
++ char *p;
++ int res, l;
++
+ if (!(dpm.encoding & PE_MONO)) count*=2; /* Stereo samples */
-! if (!(dpm.encoding & PE_MONO))
-! count *= 2; /* Stereo samples */
-!
! if (dpm.encoding & PE_16BIT) {
/* Convert data to signed 16-bit PCM */
s32tos16(buf, count);
-! res = count*2;
+! res = count*2;
! } else {
/* Convert to 8-bit unsigned and write out. */
s32tou8(buf, count);
-! res = count ;
+! res = count;
! }
-! for (p = (char *) buf ; res > 0 ; res -= l ) {
+! for (p = (char *) buf; res > 0; res -= l) {
+! again:
! l = write(dpm.fd, p, res);
-! if (l < 0) return ;
-! p += l ;
+! if (l < 0) {
+! if (errno == EINTR)
+! goto again;
+! return;
}
++ p += l;
++ }
}
+ static void close_output(void)
OpenPOWER on IntegriCloud