Reason for revert: About to fix problem and reland. Original issue's description: > Revert of Create RtcpDemuxer (patchset #13 id:240001 of https://codereview.webrtc.org/2943693003/ ) > > Reason for revert: > Breaks Chromium FYI bots. > > The problem is in the BUILD.gn file. > > Sample failure: > https://build.chromium.org/p/chromium.webrtc.fyi/builders/Linux%20Builder/builds/17829 > > Sample logs: > use_goma = true > """ to /b/c/b/Linux_Builder/src/out/Release/args.gn. > > /b/c/b/Linux_Builder/src/buildtools/linux64/gn gen //out/Release --check > -> returned 1 > ERROR at //third_party/webrtc/call/BUILD.gn:46:5: Can't load input file. > "//webrtc/base:rtc_base_approved", > ^-------------------------------- > > Original issue's description: > > Create RtcpDemuxer. Capabilities: > > 1. Demux RTCP messages according to the sender-SSRC. > > 2. Demux RTCP messages according to the RSID (resolved to an SSRC, then compared to the sender-RTCP). > > 3. Allow listening in on all RTCP messages passing through the demuxer ("broadcast sinks"). > > > > BUG=webrtc:7135 > > > > Review-Url: https://codereview.webrtc.org/2943693003 > > Cr-Commit-Position: refs/heads/master@{#18763} > > Committed:cb83bdf01f> > BUG=webrtc:7135 > > Review-Url: https://codereview.webrtc.org/2957763002 > Cr-Commit-Position: refs/heads/master@{#18764} > Committed:0e7e7869e7BUG=webrtc:7135 Review-Url: https://codereview.webrtc.org/2960623002 Cr-Commit-Position: refs/heads/master@{#18768}
217 lines
5.9 KiB
Plaintext
217 lines
5.9 KiB
Plaintext
# Copyright (c) 2015 The WebRTC project authors. All Rights Reserved.
|
|
#
|
|
# Use of this source code is governed by a BSD-style license
|
|
# that can be found in the LICENSE file in the root of the source
|
|
# tree. An additional intellectual property rights grant can be found
|
|
# in the file PATENTS. All contributing project authors may
|
|
# be found in the AUTHORS file in the root of the source tree.
|
|
|
|
import("../webrtc.gni")
|
|
|
|
rtc_source_set("call_interfaces") {
|
|
sources = [
|
|
"audio_receive_stream.h",
|
|
"audio_send_stream.cc",
|
|
"audio_send_stream.h",
|
|
"audio_state.h",
|
|
"call.h",
|
|
"callfactoryinterface.h",
|
|
"flexfec_receive_stream.h",
|
|
"syncable.cc",
|
|
"syncable.h",
|
|
]
|
|
deps = [
|
|
":rtp_interfaces",
|
|
"..:video_stream_api",
|
|
"..:webrtc_common",
|
|
"../api:audio_mixer_api",
|
|
"../api:libjingle_peerconnection_api",
|
|
"../api:transport_api",
|
|
"../api/audio_codecs:audio_codecs_api",
|
|
"../base:rtc_base",
|
|
"../base:rtc_base_approved",
|
|
]
|
|
}
|
|
|
|
# TODO(nisse): These RTP targets should be moved elsewhere
|
|
# when interfaces have stabilized.
|
|
rtc_source_set("rtp_interfaces") {
|
|
sources = [
|
|
"rtcp_packet_sink_interface.h",
|
|
"rtp_packet_sink_interface.h",
|
|
"rtp_stream_receiver_controller_interface.h",
|
|
"rtp_transport_controller_send_interface.h",
|
|
]
|
|
deps = [
|
|
"../base:rtc_base_approved",
|
|
]
|
|
}
|
|
|
|
rtc_source_set("rtp_receiver") {
|
|
sources = [
|
|
"rsid_resolution_observer.h",
|
|
"rtcp_demuxer.cc",
|
|
"rtcp_demuxer.h",
|
|
"rtp_demuxer.cc",
|
|
"rtp_demuxer.h",
|
|
"rtp_rtcp_demuxer_helper.cc",
|
|
"rtp_rtcp_demuxer_helper.h",
|
|
"rtp_stream_receiver_controller.cc",
|
|
"rtp_stream_receiver_controller.h",
|
|
"rtx_receive_stream.cc",
|
|
"rtx_receive_stream.h",
|
|
]
|
|
deps = [
|
|
":rtp_interfaces",
|
|
"..:webrtc_common",
|
|
"../base:rtc_base_approved",
|
|
"../modules/rtp_rtcp",
|
|
]
|
|
}
|
|
|
|
rtc_source_set("rtp_sender") {
|
|
sources = [
|
|
"rtp_transport_controller_send.cc",
|
|
"rtp_transport_controller_send.h",
|
|
]
|
|
deps = [
|
|
":rtp_interfaces",
|
|
"../base:rtc_base_approved",
|
|
"../modules/congestion_controller",
|
|
]
|
|
}
|
|
|
|
rtc_static_library("call") {
|
|
sources = [
|
|
"bitrate_allocator.cc",
|
|
"call.cc",
|
|
"callfactory.cc",
|
|
"callfactory.h",
|
|
"flexfec_receive_stream_impl.cc",
|
|
"flexfec_receive_stream_impl.h",
|
|
]
|
|
|
|
if (!build_with_chromium && is_clang) {
|
|
# Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
|
|
suppressed_configs += [ "//build/config/clang:find_bad_constructs" ]
|
|
}
|
|
|
|
public_deps = [
|
|
":call_interfaces",
|
|
"../api:call_api",
|
|
]
|
|
|
|
deps = [
|
|
":call_interfaces",
|
|
":rtp_interfaces",
|
|
":rtp_receiver",
|
|
":rtp_sender",
|
|
"..:webrtc_common",
|
|
"../api:transport_api",
|
|
"../audio",
|
|
"../base:rtc_task_queue",
|
|
"../logging:rtc_event_log_api",
|
|
"../logging:rtc_event_log_impl",
|
|
"../modules/bitrate_controller",
|
|
"../modules/congestion_controller",
|
|
"../modules/pacing",
|
|
"../modules/rtp_rtcp",
|
|
"../modules/utility",
|
|
"../system_wrappers",
|
|
"../video",
|
|
]
|
|
}
|
|
|
|
if (rtc_include_tests) {
|
|
rtc_source_set("call_tests") {
|
|
testonly = true
|
|
|
|
# Skip restricting visibility on mobile platforms since the tests on those
|
|
# gets additional generated targets which would require many lines here to
|
|
# cover (which would be confusing to read and hard to maintain).
|
|
if (!is_android && !is_ios) {
|
|
visibility = [ "//webrtc:video_engine_tests" ]
|
|
}
|
|
sources = [
|
|
"bitrate_allocator_unittest.cc",
|
|
"bitrate_estimator_tests.cc",
|
|
"call_unittest.cc",
|
|
"flexfec_receive_stream_unittest.cc",
|
|
"rtcp_demuxer_unittest.cc",
|
|
"rtp_demuxer_unittest.cc",
|
|
"rtp_rtcp_demuxer_helper_unittest.cc",
|
|
"rtx_receive_stream_unittest.cc",
|
|
]
|
|
deps = [
|
|
":call",
|
|
":rtp_interfaces",
|
|
":rtp_receiver",
|
|
":rtp_sender",
|
|
"..:webrtc_common",
|
|
"../api:mock_audio_mixer",
|
|
"../base:rtc_base_approved",
|
|
"../logging:rtc_event_log_api",
|
|
"../modules/audio_device:mock_audio_device",
|
|
"../modules/audio_mixer",
|
|
"../modules/bitrate_controller",
|
|
"../modules/congestion_controller:mock_congestion_controller",
|
|
"../modules/pacing",
|
|
"../modules/rtp_rtcp",
|
|
"../modules/rtp_rtcp:mock_rtp_rtcp",
|
|
"../system_wrappers",
|
|
"../test:audio_codec_mocks",
|
|
"../test:direct_transport",
|
|
"../test:test_common",
|
|
"../test:test_support",
|
|
"../test:video_test_common",
|
|
"//testing/gmock",
|
|
"//testing/gtest",
|
|
]
|
|
if (!build_with_chromium && is_clang) {
|
|
# Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
|
|
suppressed_configs += [ "//build/config/clang:find_bad_constructs" ]
|
|
}
|
|
}
|
|
|
|
rtc_source_set("call_perf_tests") {
|
|
testonly = true
|
|
|
|
# Skip restricting visibility on mobile platforms since the tests on those
|
|
# gets additional generated targets which would require many lines here to
|
|
# cover (which would be confusing to read and hard to maintain).
|
|
if (!is_android && !is_ios) {
|
|
visibility = [ "//webrtc:webrtc_perf_tests" ]
|
|
}
|
|
sources = [
|
|
"call_perf_tests.cc",
|
|
"rampup_tests.cc",
|
|
"rampup_tests.h",
|
|
]
|
|
deps = [
|
|
":call_interfaces",
|
|
"..:webrtc_common",
|
|
"../api/audio_codecs:builtin_audio_encoder_factory",
|
|
"../base:rtc_base_approved",
|
|
"../logging:rtc_event_log_api",
|
|
"../modules/audio_coding",
|
|
"../modules/audio_mixer:audio_mixer_impl",
|
|
"../modules/rtp_rtcp",
|
|
"../system_wrappers",
|
|
"../system_wrappers:metrics_default",
|
|
"../test:direct_transport",
|
|
"../test:fake_audio_device",
|
|
"../test:test_support",
|
|
"../test:video_test_common",
|
|
"../video",
|
|
"../voice_engine",
|
|
"//testing/gtest",
|
|
"//webrtc/test:field_trial",
|
|
"//webrtc/test:test_common",
|
|
]
|
|
if (!build_with_chromium && is_clang) {
|
|
# Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163).
|
|
suppressed_configs += [ "//build/config/clang:find_bad_constructs" ]
|
|
}
|
|
}
|
|
}
|