jack: removed sample_rate callback

Currently, the JACK plugin manipulates the audio_format struct which
was passed to the open() method.  This is very likely to break,
because the plugin must not permanently store this pointer.  After
this patch, MPD ignores sample rate changes.  It looks like other
software is doing the same, and I guess this is a non-issue.

This patch converts the audio_format pointer within jack_data into a
static audio_format struct.
This commit is contained in:
Max Kellermann 2009-01-30 19:43:31 +01:00
parent 5900827675
commit a93e73bea8

View File

@ -47,8 +47,8 @@ struct jack_data {
char *output_ports[2]; char *output_ports[2];
int ringbuffer_size; int ringbuffer_size;
/* for srate() only */ /* the current audio format */
struct audio_format *audio_format; struct audio_format audio_format;
/* jack library stuff */ /* jack library stuff */
jack_port_t *ports[2]; jack_port_t *ports[2];
@ -101,17 +101,6 @@ mpd_jack_finish(void *data)
mpd_jack_free(jd); mpd_jack_free(jd);
} }
static int
mpd_jack_srate(G_GNUC_UNUSED jack_nframes_t rate, void *data)
{
struct jack_data *jd = (struct jack_data *)data;
struct audio_format *audioFormat = jd->audio_format;
audioFormat->sample_rate = (int)jack_get_sample_rate(jd->client);
return 0;
}
static int static int
mpd_jack_process(jack_nframes_t nframes, void *arg) mpd_jack_process(jack_nframes_t nframes, void *arg)
{ {
@ -222,10 +211,8 @@ mpd_jack_test_default_device(void)
} }
static bool static bool
mpd_jack_connect(struct jack_data *jd, struct audio_format *audio_format) mpd_jack_connect(struct jack_data *jd)
{ {
jd->audio_format = audio_format;
for (unsigned i = 0; i < G_N_ELEMENTS(jd->ringbuffer); ++i) for (unsigned i = 0; i < G_N_ELEMENTS(jd->ringbuffer); ++i)
jd->ringbuffer[i] = jd->ringbuffer[i] =
jack_ringbuffer_create(jd->ringbuffer_size); jack_ringbuffer_create(jd->ringbuffer_size);
@ -238,7 +225,6 @@ mpd_jack_connect(struct jack_data *jd, struct audio_format *audio_format)
} }
jack_set_process_callback(jd->client, mpd_jack_process, jd); jack_set_process_callback(jd->client, mpd_jack_process, jd);
jack_set_sample_rate_callback(jd->client, mpd_jack_srate, jd);
jack_on_shutdown(jd->client, mpd_jack_shutdown, jd); jack_on_shutdown(jd->client, mpd_jack_shutdown, jd);
for (unsigned i = 0; i < G_N_ELEMENTS(jd->ports); ++i) { for (unsigned i = 0; i < G_N_ELEMENTS(jd->ports); ++i) {
@ -299,12 +285,13 @@ mpd_jack_open(void *data, struct audio_format *audio_format)
assert(jd != NULL); assert(jd != NULL);
if (!mpd_jack_connect(jd, audio_format)) { if (!mpd_jack_connect(jd)) {
mpd_jack_client_free(jd); mpd_jack_client_free(jd);
return false; return false;
} }
set_audioformat(jd, audio_format); set_audioformat(jd, audio_format);
jd->audio_format = *audio_format;
return true; return true;
} }
@ -372,7 +359,7 @@ static void
mpd_jack_write_samples(struct jack_data *jd, const void *src, mpd_jack_write_samples(struct jack_data *jd, const void *src,
unsigned num_samples) unsigned num_samples)
{ {
switch (jd->audio_format->bits) { switch (jd->audio_format.bits) {
case 16: case 16:
mpd_jack_write_samples_16(jd, (const int16_t*)src, mpd_jack_write_samples_16(jd, (const int16_t*)src,
num_samples); num_samples);
@ -392,7 +379,7 @@ static bool
mpd_jack_play(void *data, const char *buff, size_t size) mpd_jack_play(void *data, const char *buff, size_t size)
{ {
struct jack_data *jd = data; struct jack_data *jd = data;
const size_t frame_size = audio_format_frame_size(jd->audio_format); const size_t frame_size = audio_format_frame_size(&jd->audio_format);
size_t space, space1; size_t space, space1;
if (jd->shutdown) { if (jd->shutdown) {