APM: make recommended_stream_analog_level() a trivial getter
The current design of the modified getter is error-prone since the returned value changes meaning based on when (which point in the code) the getter is called - namely, before `ProcessStream()` is called the getter returns the stream analog level, after it returns the recommended level. Plus, the new implementation, which essentially returns a local member, removes the risks that the non-trivial implementation is computationally expensive. Bug: webrtc:7494, b/241923537 Change-Id: I6714444df27bcc055ae693974ecd1f77f79e6ec0 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/271580 Reviewed-by: Hanna Silen <silen@webrtc.org> Reviewed-by: Per Åhgren <peah@webrtc.org> Commit-Queue: Alessio Bazzica <alessiob@webrtc.org> Cr-Commit-Position: refs/heads/main@{#38055}
This commit is contained in:
committed by
WebRTC LUCI CQ
parent
fcf1af3049
commit
533e461228
@ -163,7 +163,7 @@ class AudioProcessingImpl : public AudioProcessing {
|
||||
|
||||
void set_stream_analog_level_locked(int level)
|
||||
RTC_EXCLUSIVE_LOCKS_REQUIRED(mutex_capture_);
|
||||
int recommended_stream_analog_level_locked() const
|
||||
void UpdateRecommendedInputVolumeLocked()
|
||||
RTC_EXCLUSIVE_LOCKS_REQUIRED(mutex_capture_);
|
||||
|
||||
void OverrideSubmoduleCreationForTesting(
|
||||
@ -475,6 +475,10 @@ class AudioProcessingImpl : public AudioProcessing {
|
||||
// acquired. Unspecified when unknown.
|
||||
absl::optional<int> applied_input_volume;
|
||||
bool applied_input_volume_changed;
|
||||
// Recommended input volume to apply on the audio input device the next time
|
||||
// that audio is acquired. Unspecified when no input volume can be
|
||||
// recommended.
|
||||
absl::optional<int> recommended_input_volume;
|
||||
} capture_ RTC_GUARDED_BY(mutex_capture_);
|
||||
|
||||
struct ApmCaptureNonLockedState {
|
||||
|
||||
Reference in New Issue
Block a user