commit | e8d854eca1cadc89af8f776158a4278049a59f63 | [log] [tgz] |
---|---|---|
author | Tommi <tommi@webrtc.org> | Fri Jan 28 07:53:00 2022 |
committer | WebRTC LUCI CQ <webrtc-scoped@luci-project-accounts.iam.gserviceaccount.com> | Fri Jan 28 09:34:25 2022 |
tree | ffdc5624e058728dbba23c7ea397ec57100950b5 | |
parent | 5d9ae8635c5be4759adb2e92dbe4827e7351f057 [diff] |
Destroy channel objects synchronously. This reverts the async operation introduced here: https://webrtc-review.googlesource.com/c/src/+/248170 The race that happened was that the "flush" operation in the dtor of ChannelManager, could run _after_ PeerConnection::Close() which is where the Call object gets deleted. Inside the dtor of Call, there are DCHECKs that could hit when the pending deletions hadn't run. In most cases the Invoke() that is used to delete the Call object would run after the pending tasks, but there's still one code path that I'm looking for that could trigger the deletion of a channel after Call is destructed. Bug: webrtc:11992, webrtc:13540, chromium:1291383 Change-Id: I160742907cc0c097a4b2bb1b7c3da03b4e8cd8d8 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/249780 Reviewed-by: Mirko Bonadei <mbonadei@webrtc.org> Commit-Queue: Tomas Gunnarsson <tommi@webrtc.org> Reviewed-by: Harald Alvestrand <hta@webrtc.org> Cr-Commit-Position: refs/heads/main@{#35822}
WebRTC is a free, open software project that provides browsers and mobile applications with Real-Time Communications (RTC) capabilities via simple APIs. The WebRTC components have been optimized to best serve this purpose.
Our mission: To enable rich, high-quality RTC applications to be developed for the browser, mobile platforms, and IoT devices, and allow them all to communicate via a common set of protocols.
The WebRTC initiative is a project supported by Google, Mozilla and Opera, amongst others.
See here for instructions on how to get started developing with the native code.
Authoritative list of directories that contain the native API header files.