aboutsummaryrefslogtreecommitdiffstats
path: root/src/pq_alsa.c
diff options
context:
space:
mode:
authorHarald Welte <laforge@gnumonks.org>2017-05-28 10:20:54 +0200
committerHarald Welte <laforge@gnumonks.org>2017-05-28 10:44:06 +0200
commit5912848d2edbf61158ac7edc72c2302649a0d9ed (patch)
treede76a2a48b98730f5cb92af44410e47761d0e61d /src/pq_alsa.c
parent62688b60c29225d557da8844d7259ce3eee962c5 (diff)
prepare gapk for dealing with variable-length frames
The existing architecture was modelled around fixed-length codec frame sizes, which of course fails with multi-rate codecs such as AMR.
Diffstat (limited to 'src/pq_alsa.c')
-rw-r--r--src/pq_alsa.c10
1 files changed, 6 insertions, 4 deletions
diff --git a/src/pq_alsa.c b/src/pq_alsa.c
index b17faa8..563452e 100644
--- a/src/pq_alsa.c
+++ b/src/pq_alsa.c
@@ -40,20 +40,22 @@ struct pq_state_alsa {
};
static int
-pq_cb_alsa_input(void *_state, uint8_t *out, const uint8_t *in)
+pq_cb_alsa_input(void *_state, uint8_t *out, const uint8_t *in, unsigned int in_len)
{
struct pq_state_alsa *state = _state;
unsigned int num_samples = state->blk_len/2;
int rv;
rv = snd_pcm_readi(state->pcm_handle, out, num_samples);
- return rv == num_samples ? 0 : -1;
+ if (rv < 0)
+ return rv;
+ return rv * sizeof(uint16_t);
}
static int
-pq_cb_alsa_output(void *_state, uint8_t *out, const uint8_t *in)
+pq_cb_alsa_output(void *_state, uint8_t *out, const uint8_t *in, unsigned int in_len)
{
struct pq_state_alsa *state = _state;
- unsigned int num_samples = state->blk_len/2;
+ unsigned int num_samples = in_len/2;
int rv;
rv = snd_pcm_writei(state->pcm_handle, in, num_samples);
return rv == num_samples ? 0 : -1;