Add replacement interface for webrtc::GainConrol
The pointer-to-submodule interfaces are being removed. This CL: 1) introduces AudioProcessing::Config::GainController1 with most config, 2) adds functions to APM for setting and getting analog gain, 3) creates a temporary GainControlConfigProxy to support the transition to the new config. 4) Moves the lock references in GainControlForExperimentalAgc and GainControlImpl into the GainControlConfigProxy, as it becomes the sole AGC object with functionality exposed to the client. Bug: webrtc:9947, webrtc:9878 Change-Id: Ic31e15e9bb26d6497a92b77874e0b6cab21ff2b2 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/126485 Commit-Queue: Sam Zackrisson <saza@webrtc.org> Reviewed-by: Fredrik Solenberg <solenberg@webrtc.org> Reviewed-by: Alessio Bazzica <alessiob@webrtc.org> Cr-Commit-Position: refs/heads/master@{#27316}
This commit is contained in:
committed by
Commit Bot
parent
4bd3177ae5
commit
f0d1c03c31
@ -182,17 +182,21 @@ void EnableAllAPComponents(AudioProcessing* ap) {
|
||||
apm_config.echo_canceller.enabled = true;
|
||||
#if defined(WEBRTC_AUDIOPROC_FIXED_PROFILE)
|
||||
apm_config.echo_canceller.mobile_mode = true;
|
||||
EXPECT_NOERR(ap->gain_control()->set_mode(GainControl::kAdaptiveDigital));
|
||||
EXPECT_NOERR(ap->gain_control()->Enable(true));
|
||||
|
||||
apm_config.gain_controller1.enabled = true;
|
||||
apm_config.gain_controller1.mode =
|
||||
AudioProcessing::Config::GainController1::kAdaptiveDigital;
|
||||
#elif defined(WEBRTC_AUDIOPROC_FLOAT_PROFILE)
|
||||
// TODO(peah): Update tests to instead use AEC3.
|
||||
apm_config.echo_canceller.use_legacy_aec = true;
|
||||
apm_config.echo_canceller.mobile_mode = false;
|
||||
apm_config.echo_canceller.legacy_moderate_suppression_level = true;
|
||||
|
||||
EXPECT_NOERR(ap->gain_control()->set_mode(GainControl::kAdaptiveAnalog));
|
||||
EXPECT_NOERR(ap->gain_control()->set_analog_level_limits(0, 255));
|
||||
EXPECT_NOERR(ap->gain_control()->Enable(true));
|
||||
apm_config.gain_controller1.enabled = true;
|
||||
apm_config.gain_controller1.mode =
|
||||
AudioProcessing::Config::GainController1::kAdaptiveAnalog;
|
||||
apm_config.gain_controller1.analog_level_minimum = 0;
|
||||
apm_config.gain_controller1.analog_level_maximum = 255;
|
||||
#endif
|
||||
|
||||
apm_config.high_pass_filter.enabled = true;
|
||||
@ -958,12 +962,7 @@ TEST_F(ApmTest, GainControl) {
|
||||
apm_->gain_control()->set_mode(mode[i]));
|
||||
EXPECT_EQ(mode[i], apm_->gain_control()->mode());
|
||||
}
|
||||
// Testing invalid target levels
|
||||
EXPECT_EQ(apm_->kBadParameterError,
|
||||
apm_->gain_control()->set_target_level_dbfs(-3));
|
||||
EXPECT_EQ(apm_->kBadParameterError,
|
||||
apm_->gain_control()->set_target_level_dbfs(-40));
|
||||
// Testing valid target levels
|
||||
// Testing target levels
|
||||
EXPECT_EQ(apm_->kNoError,
|
||||
apm_->gain_control()->set_target_level_dbfs(
|
||||
apm_->gain_control()->target_level_dbfs()));
|
||||
@ -975,13 +974,7 @@ TEST_F(ApmTest, GainControl) {
|
||||
EXPECT_EQ(level_dbfs[i], apm_->gain_control()->target_level_dbfs());
|
||||
}
|
||||
|
||||
// Testing invalid compression gains
|
||||
EXPECT_EQ(apm_->kBadParameterError,
|
||||
apm_->gain_control()->set_compression_gain_db(-1));
|
||||
EXPECT_EQ(apm_->kBadParameterError,
|
||||
apm_->gain_control()->set_compression_gain_db(100));
|
||||
|
||||
// Testing valid compression gains
|
||||
// Testing compression gains
|
||||
EXPECT_EQ(apm_->kNoError,
|
||||
apm_->gain_control()->set_compression_gain_db(
|
||||
apm_->gain_control()->compression_gain_db()));
|
||||
@ -990,6 +983,7 @@ TEST_F(ApmTest, GainControl) {
|
||||
for (size_t i = 0; i < arraysize(gain_db); i++) {
|
||||
EXPECT_EQ(apm_->kNoError,
|
||||
apm_->gain_control()->set_compression_gain_db(gain_db[i]));
|
||||
ProcessStreamChooser(kFloatFormat);
|
||||
EXPECT_EQ(gain_db[i], apm_->gain_control()->compression_gain_db());
|
||||
}
|
||||
|
||||
@ -999,19 +993,7 @@ TEST_F(ApmTest, GainControl) {
|
||||
EXPECT_EQ(apm_->kNoError, apm_->gain_control()->enable_limiter(true));
|
||||
EXPECT_TRUE(apm_->gain_control()->is_limiter_enabled());
|
||||
|
||||
// Testing invalid level limits
|
||||
EXPECT_EQ(apm_->kBadParameterError,
|
||||
apm_->gain_control()->set_analog_level_limits(-1, 512));
|
||||
EXPECT_EQ(apm_->kBadParameterError,
|
||||
apm_->gain_control()->set_analog_level_limits(100000, 512));
|
||||
EXPECT_EQ(apm_->kBadParameterError,
|
||||
apm_->gain_control()->set_analog_level_limits(512, -1));
|
||||
EXPECT_EQ(apm_->kBadParameterError,
|
||||
apm_->gain_control()->set_analog_level_limits(512, 100000));
|
||||
EXPECT_EQ(apm_->kBadParameterError,
|
||||
apm_->gain_control()->set_analog_level_limits(512, 255));
|
||||
|
||||
// Testing valid level limits
|
||||
// Testing level limits
|
||||
EXPECT_EQ(apm_->kNoError,
|
||||
apm_->gain_control()->set_analog_level_limits(
|
||||
apm_->gain_control()->analog_level_minimum(),
|
||||
@ -1038,6 +1020,46 @@ TEST_F(ApmTest, GainControl) {
|
||||
EXPECT_FALSE(apm_->gain_control()->is_enabled());
|
||||
}
|
||||
|
||||
#if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
|
||||
TEST_F(ApmTest, GainControlDiesOnTooLowTargetLevelDbfs) {
|
||||
EXPECT_DEATH(apm_->gain_control()->set_target_level_dbfs(-1), "");
|
||||
}
|
||||
|
||||
TEST_F(ApmTest, GainControlDiesOnTooHighTargetLevelDbfs) {
|
||||
EXPECT_DEATH(apm_->gain_control()->set_target_level_dbfs(32), "");
|
||||
}
|
||||
|
||||
TEST_F(ApmTest, GainControlDiesOnTooLowCompressionGainDb) {
|
||||
EXPECT_DEATH(apm_->gain_control()->set_compression_gain_db(-1), "");
|
||||
}
|
||||
|
||||
TEST_F(ApmTest, GainControlDiesOnTooHighCompressionGainDb) {
|
||||
EXPECT_DEATH(apm_->gain_control()->set_compression_gain_db(91), "");
|
||||
}
|
||||
|
||||
TEST_F(ApmTest, GainControlDiesOnTooLowAnalogLevelLowerLimit) {
|
||||
EXPECT_DEATH(apm_->gain_control()->set_analog_level_limits(-1, 512), "");
|
||||
}
|
||||
|
||||
TEST_F(ApmTest, GainControlDiesOnTooHighAnalogLevelUpperLimit) {
|
||||
EXPECT_DEATH(apm_->gain_control()->set_analog_level_limits(512, 65536), "");
|
||||
}
|
||||
|
||||
TEST_F(ApmTest, GainControlDiesOnInvertedAnalogLevelLimits) {
|
||||
EXPECT_DEATH(apm_->gain_control()->set_analog_level_limits(512, 255), "");
|
||||
}
|
||||
|
||||
TEST_F(ApmTest, ApmDiesOnTooLowAnalogLevel) {
|
||||
apm_->gain_control()->set_analog_level_limits(255, 512);
|
||||
EXPECT_DEATH(apm_->set_stream_analog_level(254), "");
|
||||
}
|
||||
|
||||
TEST_F(ApmTest, ApmDiesOnTooHighAnalogLevel) {
|
||||
apm_->gain_control()->set_analog_level_limits(255, 512);
|
||||
EXPECT_DEATH(apm_->set_stream_analog_level(513), "");
|
||||
}
|
||||
#endif
|
||||
|
||||
void ApmTest::RunQuantizedVolumeDoesNotGetStuckTest(int sample_rate) {
|
||||
Init(sample_rate, sample_rate, sample_rate, 2, 2, 2, false);
|
||||
EXPECT_EQ(apm_->kNoError,
|
||||
|
||||
Reference in New Issue
Block a user