blob: d4c925eeff77a4b78574b20ab2cace87166ee484 [file] [log] [blame]
Niels Möller3a742392018-10-08 11:13:58 +02001/*
2 * Copyright 2018 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11// This is EXPERIMENTAL interface for media transport.
12//
13// The goal is to refactor WebRTC code so that audio and video frames
14// are sent / received through the media transport interface. This will
15// enable different media transport implementations, including QUIC-based
16// media transport.
17
18#include "api/media_transport_interface.h"
19
Yves Gerey988cc082018-10-23 12:03:01 +020020#include <cstdint>
21#include <utility>
22
Niels Möller3a742392018-10-08 11:13:58 +020023namespace webrtc {
24
Piotr (Peter) Slatalaa0677d12018-10-29 07:31:42 -070025MediaTransportSettings::MediaTransportSettings() = default;
Piotr (Peter) Slatalaed7b8b12018-10-29 10:43:16 -070026MediaTransportSettings::MediaTransportSettings(const MediaTransportSettings&) =
27 default;
28MediaTransportSettings& MediaTransportSettings::operator=(
29 const MediaTransportSettings&) = default;
Piotr (Peter) Slatalaa0677d12018-10-29 07:31:42 -070030MediaTransportSettings::~MediaTransportSettings() = default;
31
Piotr (Peter) Slatalae0c2e972018-10-08 09:43:21 -070032MediaTransportEncodedAudioFrame::~MediaTransportEncodedAudioFrame() {}
33
Niels Möller3a742392018-10-08 11:13:58 +020034MediaTransportEncodedAudioFrame::MediaTransportEncodedAudioFrame(
35 int sampling_rate_hz,
36 int starting_sample_index,
37 int samples_per_channel,
38 int sequence_number,
39 FrameType frame_type,
40 uint8_t payload_type,
41 std::vector<uint8_t> encoded_data)
42 : sampling_rate_hz_(sampling_rate_hz),
43 starting_sample_index_(starting_sample_index),
44 samples_per_channel_(samples_per_channel),
45 sequence_number_(sequence_number),
46 frame_type_(frame_type),
47 payload_type_(payload_type),
48 encoded_data_(std::move(encoded_data)) {}
49
Piotr (Peter) Slatalae0c2e972018-10-08 09:43:21 -070050MediaTransportEncodedAudioFrame& MediaTransportEncodedAudioFrame::operator=(
51 const MediaTransportEncodedAudioFrame&) = default;
52
53MediaTransportEncodedAudioFrame& MediaTransportEncodedAudioFrame::operator=(
54 MediaTransportEncodedAudioFrame&&) = default;
55
56MediaTransportEncodedAudioFrame::MediaTransportEncodedAudioFrame(
57 const MediaTransportEncodedAudioFrame&) = default;
58
59MediaTransportEncodedAudioFrame::MediaTransportEncodedAudioFrame(
60 MediaTransportEncodedAudioFrame&&) = default;
61
Niels Möllerd5696fb2018-11-28 15:34:37 +010062MediaTransportEncodedVideoFrame::MediaTransportEncodedVideoFrame() = default;
63
64MediaTransportEncodedVideoFrame::~MediaTransportEncodedVideoFrame() = default;
Niels Möller3a742392018-10-08 11:13:58 +020065
66MediaTransportEncodedVideoFrame::MediaTransportEncodedVideoFrame(
67 int64_t frame_id,
68 std::vector<int64_t> referenced_frame_ids,
69 VideoCodecType codec_type,
70 const webrtc::EncodedImage& encoded_image)
71 : codec_type_(codec_type),
72 encoded_image_(encoded_image),
73 frame_id_(frame_id),
74 referenced_frame_ids_(std::move(referenced_frame_ids)) {}
75
Piotr (Peter) Slatalae0c2e972018-10-08 09:43:21 -070076MediaTransportEncodedVideoFrame& MediaTransportEncodedVideoFrame::operator=(
Niels Möllerd5696fb2018-11-28 15:34:37 +010077 const MediaTransportEncodedVideoFrame& o) {
78 codec_type_ = o.codec_type_;
79 encoded_image_ = o.encoded_image_;
80 encoded_data_ = o.encoded_data_;
81 frame_id_ = o.frame_id_;
82 referenced_frame_ids_ = o.referenced_frame_ids_;
83 if (!encoded_data_.empty()) {
84 // We own the underlying data.
85 encoded_image_._buffer = encoded_data_.data();
86 }
87 return *this;
88}
Piotr (Peter) Slatalae0c2e972018-10-08 09:43:21 -070089
90MediaTransportEncodedVideoFrame& MediaTransportEncodedVideoFrame::operator=(
Niels Möllerd5696fb2018-11-28 15:34:37 +010091 MediaTransportEncodedVideoFrame&& o) {
92 codec_type_ = o.codec_type_;
93 encoded_image_ = o.encoded_image_;
94 encoded_data_ = std::move(o.encoded_data_);
95 frame_id_ = o.frame_id_;
96 referenced_frame_ids_ = std::move(o.referenced_frame_ids_);
97 if (!encoded_data_.empty()) {
98 // We take over ownership of the underlying data.
99 encoded_image_._buffer = encoded_data_.data();
100 o.encoded_image_._buffer = nullptr;
101 }
102 return *this;
103}
Piotr (Peter) Slatalae0c2e972018-10-08 09:43:21 -0700104
105MediaTransportEncodedVideoFrame::MediaTransportEncodedVideoFrame(
Niels Möllerd5696fb2018-11-28 15:34:37 +0100106 const MediaTransportEncodedVideoFrame& o)
107 : MediaTransportEncodedVideoFrame() {
108 *this = o;
109}
Piotr (Peter) Slatalae0c2e972018-10-08 09:43:21 -0700110
111MediaTransportEncodedVideoFrame::MediaTransportEncodedVideoFrame(
Niels Möllerd5696fb2018-11-28 15:34:37 +0100112 MediaTransportEncodedVideoFrame&& o)
113 : MediaTransportEncodedVideoFrame() {
114 *this = std::move(o);
115}
116
117void MediaTransportEncodedVideoFrame::Retain() {
118 if (encoded_image_._buffer && encoded_data_.empty()) {
119 encoded_data_ =
120 std::vector<uint8_t>(encoded_image_._buffer,
121 encoded_image_._buffer + encoded_image_._length);
122 encoded_image_._buffer = encoded_data_.data();
123 }
124}
Niels Möller3a742392018-10-08 11:13:58 +0200125
Bjorn Mellem1f6aa9f2018-10-30 15:15:00 -0700126SendDataParams::SendDataParams() = default;
Niels Möllere0446cb2018-11-30 09:35:52 +0100127SendDataParams::SendDataParams(const SendDataParams&) = default;
Bjorn Mellem1f6aa9f2018-10-30 15:15:00 -0700128
Piotr (Peter) Slatalaa0677d12018-10-29 07:31:42 -0700129RTCErrorOr<std::unique_ptr<MediaTransportInterface>>
130MediaTransportFactory::CreateMediaTransport(
131 rtc::PacketTransportInternal* packet_transport,
132 rtc::Thread* network_thread,
133 bool is_caller) {
Piotr (Peter) Slatalaed7b8b12018-10-29 10:43:16 -0700134 MediaTransportSettings settings;
135 settings.is_caller = is_caller;
136 return CreateMediaTransport(packet_transport, network_thread, settings);
Piotr (Peter) Slatalaa0677d12018-10-29 07:31:42 -0700137}
138
139RTCErrorOr<std::unique_ptr<MediaTransportInterface>>
140MediaTransportFactory::CreateMediaTransport(
141 rtc::PacketTransportInternal* packet_transport,
142 rtc::Thread* network_thread,
Piotr (Peter) Slatalaed7b8b12018-10-29 10:43:16 -0700143 const MediaTransportSettings& settings) {
Piotr (Peter) Slatalaa0677d12018-10-29 07:31:42 -0700144 return std::unique_ptr<MediaTransportInterface>(nullptr);
145}
146
Piotr (Peter) Slatalaada077f2018-11-08 07:43:31 -0800147absl::optional<TargetTransferRate>
148MediaTransportInterface::GetLatestTargetTransferRate() {
149 return absl::nullopt;
150}
151
152void MediaTransportInterface::SetNetworkChangeCallback(
153 MediaTransportNetworkChangeCallback* callback) {}
154
155void MediaTransportInterface::RemoveTargetTransferRateObserver(
156 webrtc::TargetTransferRateObserver* observer) {}
157
Piotr (Peter) Slatalaada077f2018-11-08 07:43:31 -0800158void MediaTransportInterface::AddTargetTransferRateObserver(
159 webrtc::TargetTransferRateObserver* observer) {}
160
161size_t MediaTransportInterface::GetAudioPacketOverhead() const {
162 return 0;
163}
164
Niels Möller3a742392018-10-08 11:13:58 +0200165} // namespace webrtc