Ensure adjusted "known delay" doesn't drop below zero.
The untrusted delay mode provides an option to reduce the "known delay" parameter passed down to the core AEC. This is necessary to handle the very low latencies observed with the Chromium audio backend on Mac. Prior to this change, it was possible to pass a negative value. The AEC produced good output in practice, but it turned out this tripped a heretofore unnoticed assert in ProcessBlock(). This change avoids the assert, and maintains the good output across a set of Mac recordings. Bit-exact in some cases, and in the remaining, quickly converging to identical output. The assert was hit on the last webrtc roll in Chromium in content_browsertests on Mac. Corresponds to: https://chromereviews.googleplex.com/9960013 TBR=bjornv TESTED=Verified locally that "content_browsertests --gtest_filter=WebrtcBrowserTest.*"" passes. Review URL: https://webrtc-codereview.appspot.com/2328005 git-svn-id: http://webrtc.googlecode.com/svn/trunk@4886 4adac7df-926f-26a2-2b94-8c16560cd09d
This commit is contained in:
parent
fd11bbfb56
commit
8e2f9bce71
@ -814,15 +814,20 @@ static void ProcessExtended(aecpc_t* self, const int16_t* near,
|
|||||||
|
|
||||||
EstBufDelayExtended(self);
|
EstBufDelayExtended(self);
|
||||||
|
|
||||||
for (i = 0; i < num_frames; ++i) {
|
{
|
||||||
// |delay_diff_offset| gives us the option to manually rewind the delay on
|
// |delay_diff_offset| gives us the option to manually rewind the delay on
|
||||||
// very low delay platforms which can't be expressed purely through
|
// very low delay platforms which can't be expressed purely through
|
||||||
// |reported_delay_ms|.
|
// |reported_delay_ms|.
|
||||||
|
const int adjusted_known_delay =
|
||||||
|
WEBRTC_SPL_MAX(0, self->knownDelay + delay_diff_offset);
|
||||||
|
|
||||||
|
for (i = 0; i < num_frames; ++i) {
|
||||||
WebRtcAec_ProcessFrame(self->aec, &near[FRAME_LEN * i],
|
WebRtcAec_ProcessFrame(self->aec, &near[FRAME_LEN * i],
|
||||||
&near_high[FRAME_LEN * i], self->knownDelay + delay_diff_offset,
|
&near_high[FRAME_LEN * i], adjusted_known_delay,
|
||||||
&out[FRAME_LEN * i], &out_high[FRAME_LEN * i]);
|
&out[FRAME_LEN * i], &out_high[FRAME_LEN * i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void EstBufDelayNormal(aecpc_t* aecpc) {
|
static void EstBufDelayNormal(aecpc_t* aecpc) {
|
||||||
int nSampSndCard = aecpc->msInSndCardBuf * sampMsNb * aecpc->rate_factor;
|
int nSampSndCard = aecpc->msInSndCardBuf * sampMsNb * aecpc->rate_factor;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user