From ec1eadafd5baed15bf18c516f35146e69786c53e Mon Sep 17 00:00:00 2001
From: Miller Puckette <msp@ucsd.edu>
Date: Thu, 20 Dec 2007 12:36:19 -0800
Subject: [PATCH] monkey with callback scheduler

---
 src/m_sched.c |  5 ++++-
 src/s_audio.c | 10 +++++-----
 2 files changed, 9 insertions(+), 6 deletions(-)

diff --git a/src/m_sched.c b/src/m_sched.c
index 8801e285d..a71957420 100644
--- a/src/m_sched.c
+++ b/src/m_sched.c
@@ -28,7 +28,10 @@ int sys_schedblocksize = DEFDACBLKSIZE;
 int sys_usecsincelastsleep(void);
 int sys_sleepgrain;
 
-int sched_reopenmeplease = 0;   /* request from s_audio for deferred reopen */
+void sched_reopenmeplease(void)   /* request from s_audio for deferred reopen */
+{
+	sys_quit = SYS_QUIT_RESTART;
+}
 
 typedef void (*t_clockmethod)(void *client);
 
diff --git a/src/s_audio.c b/src/s_audio.c
index ca8713c8b..626c9f58d 100644
--- a/src/s_audio.c
+++ b/src/s_audio.c
@@ -68,7 +68,7 @@ static int audio_advance;
 static int audio_callback;
 
 void sched_audio_callbackfn(void);
-extern int sched_reopenmeplease;
+void sched_reopenmeplease(void);
 
 static int audio_isopen(void)
 {
@@ -364,10 +364,11 @@ void sys_close_audio(void)
         mmio_close_audio();
     else
 #endif
-        post("sys_close_audio: unknown API %d", sys_audioapi);
+        post("sys_close_audio: unknown API %d", sys_audioapiopened);
     sys_inchannels = sys_outchannels = 0;
     sys_audioapiopened = -1;
     sched_set_using_audio(SCHED_AUDIO_NONE);
+    audio_state = 0;
 }
 
     /* open audio using whatever parameters were last used */
@@ -432,6 +433,7 @@ void sys_reopen_audio( void)
     }
     else
     {
+		/* fprintf(stderr, "started w/callback %d\n", callback); */
         audio_state = 1;
         sched_set_using_audio(
             (callback ? SCHED_AUDIO_CALLBACK : SCHED_AUDIO_POLL));
@@ -743,7 +745,7 @@ void glob_audio_dialog(t_pd *dummy, t_symbol *s, int argc, t_atom *argv)
         newrate, newadvance, (newcallback >= 0 ? newcallback : 0));
     if (!audio_callback && !newcallback)
         sys_reopen_audio();
-    else sched_reopenmeplease = 1;
+    else sched_reopenmeplease();
 }
 
 void sys_listdevs(void )
@@ -820,7 +822,6 @@ void glob_audio_setapi(void *dummy, t_floatarg f)
     else if (audio_isopen())
     {
         sys_close_audio();
-        audio_state = 0;
     }
 }
 
@@ -837,7 +838,6 @@ void sys_set_audio_state(int onoff)
         if (audio_isopen())
             sys_close_audio();
     }
-    audio_state = onoff;
 }
 
 void sys_get_audio_apis(char *buf)
-- 
GitLab