Chromium Code Reviews| Index: webrtc/call/rtp_transport_controller.h |
| diff --git a/webrtc/call/rtp_transport_controller.h b/webrtc/call/rtp_transport_controller.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..0cc71e675e5c062624137d467c57da3d308e55f7 |
| --- /dev/null |
| +++ b/webrtc/call/rtp_transport_controller.h |
| @@ -0,0 +1,60 @@ |
| +/* |
| + * Copyright (c) 2017 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. |
| + */ |
| + |
| +#ifndef WEBRTC_CALL_RTP_TRANSPORT_CONTROLLER_H_ |
| +#define WEBRTC_CALL_RTP_TRANSPORT_CONTROLLER_H_ |
| + |
| +namespace webrtc { |
| + |
| +class CongestionController; |
| +class Module; |
| +class PacketRouter; |
| +class RtpPacketSender; |
| +class TransportFeedbackObserver; |
| +class VieRemb; |
| + |
| +// An RtpTransportController should own everything related to the RTP |
| +// transport to/from a remote endpoint. We should have separate |
| +// interfaces for send and receive side, even if they are implemented |
| +// by the same class. This is an ongoing refactoring project. At some |
| +// point, this class should be promoted to a public api under |
| +// webrtc/api/rtp/. |
| +// |
| +// For a start, this object is just a collection of the objects needed |
| +// by the VideoSendStream constructor. The plan is to move ownership |
| +// of all RTP-related objects here, and add methods to create per-ssrc |
| +// objects which would then be passed to VideoSendStream. |
|
danilchap
2017/03/14 17:59:14
May be add a comment that direct accessors (remb()
nisse-webrtc
2017/03/15 08:06:23
Done.
|
| +// |
| +// This should also have a reference to the underlying |
| +// webrtc::Transport. Currently, webrtc::Transport is implemented by |
|
Taylor Brandstetter
2017/03/14 23:08:35
"webrtc::Transport(s)", since there may be multipl
nisse-webrtc
2017/03/15 08:06:23
Updated the comment. On the underlying question, I
Taylor Brandstetter
2017/03/15 21:39:07
I think we may be using the same name (RtpTranspor
|
| +// WebRtcVideoChannel2 and WebRtcVoiceMediaChannel, and owned by |
| +// WebrtcSession. Video and audio always uses different transport |
| +// objects, even in the common case where they are bundeled over the |
|
Taylor Brandstetter
2017/03/14 23:08:35
"bundled"
nisse-webrtc
2017/03/15 08:06:23
Done.
|
| +// same underlying transport. |
| +// |
| +// Extracting the logic of the webrtc::Transport from BaseChannel and |
| +// subclasses into a separate class seems to be a prerequesite for |
| +// moving the transport here. |
| +class RtpTransportControllerSendInterface { |
| + public: |
| + virtual ~RtpTransportControllerSendInterface() {} |
| + virtual VieRemb* remb() = 0; |
| + virtual PacketRouter* packet_router() = 0; |
| + |
| + // Currently returning the same pointer, but with different types. |
| + virtual CongestionController* congestion_controller() = 0; |
| + virtual TransportFeedbackObserver* transport_feedback_observer() = 0; |
| + |
| + virtual RtpPacketSender* packet_sender() = 0; |
| +}; |
| + |
| +} // namespace webrtc |
| + |
| +#endif // WEBRTC_CALL_RTP_TRANSPORT_CONTROLLER_H_ |