commit | 6e2458d8888a0fb88242e912b325d5cf422c0410 | [log] [tgz] |
---|---|---|
author | Erik Språng <sprang@webrtc.org> | Wed Aug 11 13:34:59 2021 +0200 |
committer | WebRTC LUCI CQ <webrtc-scoped@luci-project-accounts.iam.gserviceaccount.com> | Wed Aug 11 13:28:11 2021 +0000 |
tree | 04813639667cbd021ab2203f8db4fe069cfdf979 | |
parent | 8729d785dfb7439c64eb90610db7478a917c1d59 [diff] |
Add lock to guard rtp packet sequencer. With deferred packet sequencing, the PacketSequencer instance is called directly from the RtpRtcp module while before it was called from within the RTPSender while holding a lock. Since sequence number assignment happens on the same thread as actual packet sending, though thought was that locking was no longer needed. Unfortunately, SetRtpState()/GetRtpState() also exists - and while they should only be called on creating/destruction there is a possible race where a delayed packet from the pacer accesses the sequencer while GetRtpState() is being called. For now, this CL just adds a lock to guard sequencer. Follow-ups will make sure get/set state is never called while module is attached to the packet router. After that, the lock can be removed again. Bug: webrtc:11340, webrtc:12470 Change-Id: I123c762fb4afd20b3a6bd03b86234eb9ec34a209 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/228430 Reviewed-by: Danil Chapovalov <danilchap@webrtc.org> Commit-Queue: Erik Språng <sprang@webrtc.org> Cr-Commit-Position: refs/heads/master@{#34723}
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.