summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorArun Raghavan <git@arunraghavan.net>2016-02-17 19:47:10 +0530
committerArun Raghavan <git@arunraghavan.net>2016-02-25 09:09:13 +0530
commit3133ff8e1110ae694070951fdfe37e63a58995cb (patch)
tree1c0cff10710670a209b495acb0327e50525c44de
parent222a98846c8c0b0c2b1b6adccf248b6a181f634e (diff)
downloadpulseaudio-3133ff8e1110ae694070951fdfe37e63a58995cb.tar.gz
echo-cancel: webrtc canceller supports different in/out channel counts
Needed for upcoming beamforming code.
-rw-r--r--src/modules/echo-cancel/echo-cancel.h2
-rw-r--r--src/modules/echo-cancel/webrtc.cc14
2 files changed, 9 insertions, 7 deletions
diff --git a/src/modules/echo-cancel/echo-cancel.h b/src/modules/echo-cancel/echo-cancel.h
index 4c1571796..ab0c5e91e 100644
--- a/src/modules/echo-cancel/echo-cancel.h
+++ b/src/modules/echo-cancel/echo-cancel.h
@@ -65,7 +65,7 @@ struct pa_echo_canceller_params {
* to C++ linkage. apm is a pointer to an AudioProcessing object */
void *apm;
unsigned int blocksize; /* in frames */
- pa_sample_spec rec_ss, play_ss;
+ pa_sample_spec rec_ss, play_ss, out_ss;
void *trace_callback;
bool agc;
bool first;
diff --git a/src/modules/echo-cancel/webrtc.cc b/src/modules/echo-cancel/webrtc.cc
index 1df9b6173..6c2dd99f1 100644
--- a/src/modules/echo-cancel/webrtc.cc
+++ b/src/modules/echo-cancel/webrtc.cc
@@ -335,6 +335,7 @@ bool pa_webrtc_ec_init(pa_core *c, pa_echo_canceller *ec,
ec->params.webrtc.apm = apm;
ec->params.webrtc.rec_ss = *rec_ss;
ec->params.webrtc.play_ss = *play_ss;
+ ec->params.webrtc.out_ss = *out_ss;
ec->params.webrtc.blocksize = (uint64_t) out_ss->rate * BLOCK_SIZE_US / PA_USEC_PER_SEC;
*nframes = ec->params.webrtc.blocksize;
ec->params.webrtc.first = true;
@@ -379,17 +380,18 @@ void pa_webrtc_ec_play(pa_echo_canceller *ec, const uint8_t *play) {
void pa_webrtc_ec_record(pa_echo_canceller *ec, const uint8_t *rec, uint8_t *out) {
webrtc::AudioProcessing *apm = (webrtc::AudioProcessing*)ec->params.webrtc.apm;
webrtc::AudioFrame out_frame;
- const pa_sample_spec *ss = &ec->params.webrtc.rec_ss;
+ const pa_sample_spec *rec_ss = &ec->params.webrtc.rec_ss;
+ const pa_sample_spec *out_ss = &ec->params.webrtc.out_ss;
pa_cvolume v;
int old_volume, new_volume;
- out_frame.num_channels_ = ss->channels;
- out_frame.sample_rate_hz_ = ss->rate;
+ out_frame.num_channels_ = rec_ss->channels;
+ out_frame.sample_rate_hz_ = rec_ss->rate;
out_frame.interleaved_ = true;
out_frame.samples_per_channel_ = ec->params.webrtc.blocksize;
pa_assert(out_frame.samples_per_channel_ <= webrtc::AudioFrame::kMaxDataSizeSamples);
- memcpy(out_frame.data_, rec, ec->params.webrtc.blocksize * pa_frame_size(ss));
+ memcpy(out_frame.data_, rec, ec->params.webrtc.blocksize * pa_frame_size(rec_ss));
if (ec->params.webrtc.agc) {
pa_cvolume_init(&v);
@@ -414,12 +416,12 @@ void pa_webrtc_ec_record(pa_echo_canceller *ec, const uint8_t *rec, uint8_t *out
}
if (old_volume != new_volume) {
- pa_cvolume_set(&v, ss->channels, webrtc_volume_to_pa(new_volume));
+ pa_cvolume_set(&v, rec_ss->channels, webrtc_volume_to_pa(new_volume));
pa_echo_canceller_set_capture_volume(ec, &v);
}
}
- memcpy(out, out_frame.data_, ec->params.webrtc.blocksize * pa_frame_size(ss));
+ memcpy(out, out_frame.data_, ec->params.webrtc.blocksize * pa_frame_size(out_ss));
}
void pa_webrtc_ec_set_drift(pa_echo_canceller *ec, float drift) {