X-Git-Url: https://git.distorted.org.uk/~mdw/disorder/blobdiff_plain/e8c185c3c5870f21f8352c9684e6feb9c1ef37a5..983c335710951dd573e653b4da2a7a5d71b0aa9b:/lib/uaudio-command.c diff --git a/lib/uaudio-command.c b/lib/uaudio-command.c index 12a47dc..5e4531e 100644 --- a/lib/uaudio-command.c +++ b/lib/uaudio-command.c @@ -17,7 +17,13 @@ * along with this program. If not, see . */ /** @file lib/uaudio-command.c - * @brief Support for commmand backend */ + * @brief Support for commmand backend + * + * We use the code in @ref lib/uaudio-schedule.c to ensure that we write at + * approximately the 'real' rate. For disorder-playrtp this isn't very useful + * (thought it might reduce the size of various buffers downstream of us) but + * when run from the speaker it means that pausing stands a chance of working. + */ #include "common.h" #include @@ -28,6 +34,7 @@ #include "mem.h" #include "wstat.h" #include "uaudio.h" +#include "configuration.h" /** @brief Pipe to subprocess */ static int command_fd; @@ -63,7 +70,7 @@ static void command_open(void) { int pfd[2]; const char *command; - if(!(command = uaudio_get("command"))) + if(!(command = uaudio_get("command", NULL))) fatal(0, "'command' not set"); xpipe(pfd); command_pid = xfork(); @@ -80,11 +87,12 @@ static void command_open(void) { fatal(errno, "error executing /bin/sh"); } close(pfd[0]); - command_pid = pfd[1]; + command_fd = pfd[1]; } /** @brief Send audio data to subprocess */ static size_t command_play(void *buffer, size_t nsamples) { + uaudio_schedule_synchronize(); const size_t bytes = nsamples * uaudio_sample_size; int written = write(command_fd, buffer, bytes); if(written < 0) { @@ -100,12 +108,15 @@ static size_t command_play(void *buffer, size_t nsamples) { fatal(errno, "error writing to audio command subprocess"); } } - return written / uaudio_sample_size; + const size_t written_samples = written / uaudio_sample_size; + uaudio_schedule_update(written_samples); + return written_samples; } static void command_start(uaudio_callback *callback, void *userdata) { command_open(); + uaudio_schedule_init(); uaudio_thread_start(callback, userdata, command_play, @@ -119,6 +130,7 @@ static void command_stop(void) { } static void command_activate(void) { + uaudio_schedule_reactivated = 1; uaudio_thread_activate(); } @@ -126,13 +138,18 @@ static void command_deactivate(void) { uaudio_thread_deactivate(); } +static void command_configure(void) { + uaudio_set("command", config->speaker_command); +} + const struct uaudio uaudio_command = { .name = "command", .options = command_options, .start = command_start, .stop = command_stop, .activate = command_activate, - .deactivate = command_deactivate + .deactivate = command_deactivate, + .configure = command_configure, }; /*