webrtc/sdk
Guy Hershenbaum 94dfe1cc59 Fix NetworkMonitor race condition when dispatching native observers
There is a race condition in NetworkMonitor where native observers may be removed concurrently with a notification being dispatched, leading to a dangling pointer dereference (trying to dispatch an observer that was already removed and destroyed), and from there a crash with access violation.

By ensuring dispatching to native observers is done within the synchronization lock that guards additions/removals of native observers protects against this race condition.
Since native observers callbacks are posted to the networking thread in the C++ side anyway, there should be no risk of deadlock/starvation due to long-running observers.

Bug: webrtc:15837
Change-Id: Id2b788f102dbd25de76ceed434c4cd68aa9a569e
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/338643
Reviewed-by: Taylor Brandstetter <deadbeef@webrtc.org>
Commit-Queue: Harald Alvestrand <hta@webrtc.org>
Reviewed-by: Harald Alvestrand <hta@webrtc.org>
Cr-Commit-Position: refs/heads/main@{#42256}
2024-05-08 08:27:19 +00:00
..
android Fix NetworkMonitor race condition when dispatching native observers 2024-05-08 08:27:19 +00:00
objc Move webrtc::AudioDeviceModule include to api/ folder 2024-04-22 08:56:31 +00:00
BUILD.gn Move webrtc::AudioDeviceModule include to api/ folder 2024-04-22 08:56:31 +00:00
media_constraints.cc Remove unused combined_audio_video_bwe. 2023-05-26 15:56:00 +00:00
media_constraints.h Remove unused combined_audio_video_bwe. 2023-05-26 15:56:00 +00:00
media_constraints_unittest.cc Remove unused combined_audio_video_bwe. 2023-05-26 15:56:00 +00:00
OWNERS Remove wildcard ownership for build files. 2020-02-19 14:05:46 +00:00