aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-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 004d19abd3f2..1c8b9c92d5fb 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)