Fix PacedSender class to use plain mutex, rather than RecursiveCriticalSection

Bug: webrtc:11567
Change-Id: I51f17ddebdda2fafeb9b721d038b16e784e7bd8f
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/206464
Commit-Queue: Niels Moller <nisse@webrtc.org>
Reviewed-by: Sebastian Jansson <srte@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#33202}
diff --git a/modules/pacing/paced_sender.cc b/modules/pacing/paced_sender.cc
index a0e7676..57dbc4f 100644
--- a/modules/pacing/paced_sender.cc
+++ b/modules/pacing/paced_sender.cc
@@ -58,13 +58,13 @@
 }
 
 void PacedSender::CreateProbeCluster(DataRate bitrate, int cluster_id) {
-  rtc::CritScope cs(&critsect_);
+  MutexLock lock(&mutex_);
   return pacing_controller_.CreateProbeCluster(bitrate, cluster_id);
 }
 
 void PacedSender::Pause() {
   {
-    rtc::CritScope cs(&critsect_);
+    MutexLock lock(&mutex_);
     pacing_controller_.Pause();
   }
 
@@ -77,7 +77,7 @@
 
 void PacedSender::Resume() {
   {
-    rtc::CritScope cs(&critsect_);
+    MutexLock lock(&mutex_);
     pacing_controller_.Resume();
   }
 
@@ -90,7 +90,7 @@
 
 void PacedSender::SetCongestionWindow(DataSize congestion_window_size) {
   {
-    rtc::CritScope cs(&critsect_);
+    MutexLock lock(&mutex_);
     pacing_controller_.SetCongestionWindow(congestion_window_size);
   }
   MaybeWakupProcessThread();
@@ -98,7 +98,7 @@
 
 void PacedSender::UpdateOutstandingData(DataSize outstanding_data) {
   {
-    rtc::CritScope cs(&critsect_);
+    MutexLock lock(&mutex_);
     pacing_controller_.UpdateOutstandingData(outstanding_data);
   }
   MaybeWakupProcessThread();
@@ -106,7 +106,7 @@
 
 void PacedSender::SetPacingRates(DataRate pacing_rate, DataRate padding_rate) {
   {
-    rtc::CritScope cs(&critsect_);
+    MutexLock lock(&mutex_);
     pacing_controller_.SetPacingRates(pacing_rate, padding_rate);
   }
   MaybeWakupProcessThread();
@@ -117,7 +117,7 @@
   {
     TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("webrtc"),
                  "PacedSender::EnqueuePackets");
-    rtc::CritScope cs(&critsect_);
+    MutexLock lock(&mutex_);
     for (auto& packet : packets) {
       TRACE_EVENT2(TRACE_DISABLED_BY_DEFAULT("webrtc"),
                    "PacedSender::EnqueuePackets::Loop", "sequence_number",
@@ -131,42 +131,42 @@
 }
 
 void PacedSender::SetAccountForAudioPackets(bool account_for_audio) {
-  rtc::CritScope cs(&critsect_);
+  MutexLock lock(&mutex_);
   pacing_controller_.SetAccountForAudioPackets(account_for_audio);
 }
 
 void PacedSender::SetIncludeOverhead() {
-  rtc::CritScope cs(&critsect_);
+  MutexLock lock(&mutex_);
   pacing_controller_.SetIncludeOverhead();
 }
 
 void PacedSender::SetTransportOverhead(DataSize overhead_per_packet) {
-  rtc::CritScope cs(&critsect_);
+  MutexLock lock(&mutex_);
   pacing_controller_.SetTransportOverhead(overhead_per_packet);
 }
 
 TimeDelta PacedSender::ExpectedQueueTime() const {
-  rtc::CritScope cs(&critsect_);
+  MutexLock lock(&mutex_);
   return pacing_controller_.ExpectedQueueTime();
 }
 
 DataSize PacedSender::QueueSizeData() const {
-  rtc::CritScope cs(&critsect_);
+  MutexLock lock(&mutex_);
   return pacing_controller_.QueueSizeData();
 }
 
 absl::optional<Timestamp> PacedSender::FirstSentPacketTime() const {
-  rtc::CritScope cs(&critsect_);
+  MutexLock lock(&mutex_);
   return pacing_controller_.FirstSentPacketTime();
 }
 
 TimeDelta PacedSender::OldestPacketWaitTime() const {
-  rtc::CritScope cs(&critsect_);
+  MutexLock lock(&mutex_);
   return pacing_controller_.OldestPacketWaitTime();
 }
 
 int64_t PacedSender::TimeUntilNextProcess() {
-  rtc::CritScope cs(&critsect_);
+  MutexLock lock(&mutex_);
 
   Timestamp next_send_time = pacing_controller_.NextSendTime();
   TimeDelta sleep_time =
@@ -178,7 +178,7 @@
 }
 
 void PacedSender::Process() {
-  rtc::CritScope cs(&critsect_);
+  MutexLock lock(&mutex_);
   pacing_controller_.ProcessPackets();
 }
 
@@ -198,7 +198,7 @@
 
 void PacedSender::SetQueueTimeLimit(TimeDelta limit) {
   {
-    rtc::CritScope cs(&critsect_);
+    MutexLock lock(&mutex_);
     pacing_controller_.SetQueueTimeLimit(limit);
   }
   MaybeWakupProcessThread();
diff --git a/modules/pacing/paced_sender.h b/modules/pacing/paced_sender.h
index d255efd..c819f3f 100644
--- a/modules/pacing/paced_sender.h
+++ b/modules/pacing/paced_sender.h
@@ -32,7 +32,7 @@
 #include "modules/rtp_rtcp/include/rtp_packet_sender.h"
 #include "modules/rtp_rtcp/source/rtp_packet_to_send.h"
 #include "modules/utility/include/process_thread.h"
-#include "rtc_base/deprecated/recursive_critical_section.h"
+#include "rtc_base/synchronization/mutex.h"
 #include "rtc_base/thread_annotations.h"
 
 namespace webrtc {
@@ -157,9 +157,9 @@
     PacedSender* const delegate_;
   } module_proxy_{this};
 
-  rtc::RecursiveCriticalSection critsect_;
+  mutable Mutex mutex_;
   const PacingController::ProcessMode process_mode_;
-  PacingController pacing_controller_ RTC_GUARDED_BY(critsect_);
+  PacingController pacing_controller_ RTC_GUARDED_BY(mutex_);
 
   Clock* const clock_;
   ProcessThread* const process_thread_;