Index: webrtc/pc/channel.cc |
diff --git a/webrtc/pc/channel.cc b/webrtc/pc/channel.cc |
index e978d7d4b0e2bdcf8f7c084fc16572dd5fd5b1fb..1e3c4225799d0f6c991f8841d0a4ea0c7117a266 100644 |
--- a/webrtc/pc/channel.cc |
+++ b/webrtc/pc/channel.cc |
@@ -14,9 +14,9 @@ |
#include "webrtc/audio_sink.h" |
#include "webrtc/base/bind.h" |
-#include "webrtc/base/buffer.h" |
#include "webrtc/base/byteorder.h" |
#include "webrtc/base/common.h" |
+#include "webrtc/base/copyonwritebuffer.h" |
#include "webrtc/base/dscp.h" |
#include "webrtc/base/logging.h" |
#include "webrtc/base/trace_event.h" |
@@ -61,7 +61,7 @@ static void SafeSetError(const std::string& message, std::string* error_desc) { |
} |
struct PacketMessageData : public rtc::MessageData { |
- rtc::Buffer packet; |
+ rtc::CopyOnWriteBuffer packet; |
rtc::PacketOptions options; |
}; |
@@ -93,7 +93,7 @@ static const char* PacketType(bool rtcp) { |
return (!rtcp) ? "RTP" : "RTCP"; |
} |
-static bool ValidPacket(bool rtcp, const rtc::Buffer* packet) { |
+static bool ValidPacket(bool rtcp, const rtc::CopyOnWriteBuffer* packet) { |
// Check the packet size. We could check the header too if needed. |
return (packet && |
packet->size() >= (!rtcp ? kMinRtpPacketLen : kMinRtcpPacketLen) && |
@@ -435,12 +435,12 @@ bool BaseChannel::IsReadyToSend() const { |
(srtp_filter_.IsActive() || !ShouldSetupDtlsSrtp()); |
} |
-bool BaseChannel::SendPacket(rtc::Buffer* packet, |
+bool BaseChannel::SendPacket(rtc::CopyOnWriteBuffer* packet, |
const rtc::PacketOptions& options) { |
return SendPacket(false, packet, options); |
} |
-bool BaseChannel::SendRtcp(rtc::Buffer* packet, |
+bool BaseChannel::SendRtcp(rtc::CopyOnWriteBuffer* packet, |
const rtc::PacketOptions& options) { |
return SendPacket(true, packet, options); |
} |
@@ -479,7 +479,7 @@ void BaseChannel::OnChannelRead(TransportChannel* channel, |
// When using RTCP multiplexing we might get RTCP packets on the RTP |
// transport. We feed RTP traffic into the demuxer to determine if it is RTCP. |
bool rtcp = PacketIsRtcp(channel, data, len); |
- rtc::Buffer packet(data, len); |
+ rtc::CopyOnWriteBuffer packet(data, len); |
HandlePacket(rtcp, &packet, packet_time); |
} |
@@ -529,7 +529,7 @@ bool BaseChannel::PacketIsRtcp(const TransportChannel* channel, |
} |
bool BaseChannel::SendPacket(bool rtcp, |
- rtc::Buffer* packet, |
+ rtc::CopyOnWriteBuffer* packet, |
const rtc::PacketOptions& options) { |
// SendPacket gets called from MediaEngine, typically on an encoder thread. |
// If the thread is not our worker thread, we will post to our worker |
@@ -650,7 +650,7 @@ bool BaseChannel::SendPacket(bool rtcp, |
return true; |
} |
-bool BaseChannel::WantsPacket(bool rtcp, rtc::Buffer* packet) { |
+bool BaseChannel::WantsPacket(bool rtcp, const rtc::CopyOnWriteBuffer* packet) { |
// Protect ourselves against crazy data. |
if (!ValidPacket(rtcp, packet)) { |
LOG(LS_ERROR) << "Dropping incoming " << content_name_ << " " |
@@ -663,10 +663,10 @@ bool BaseChannel::WantsPacket(bool rtcp, rtc::Buffer* packet) { |
return true; |
} |
// Check whether we handle this payload. |
- return bundle_filter_.DemuxPacket(packet->data<uint8_t>(), packet->size()); |
+ return bundle_filter_.DemuxPacket(packet->data(), packet->size()); |
} |
-void BaseChannel::HandlePacket(bool rtcp, rtc::Buffer* packet, |
+void BaseChannel::HandlePacket(bool rtcp, rtc::CopyOnWriteBuffer* packet, |
const rtc::PacketTime& packet_time) { |
if (!WantsPacket(rtcp, packet)) { |
return; |
@@ -1860,7 +1860,7 @@ bool DataChannel::Init() { |
} |
bool DataChannel::SendData(const SendDataParams& params, |
- const rtc::Buffer& payload, |
+ const rtc::CopyOnWriteBuffer& payload, |
SendDataResult* result) { |
return InvokeOnWorker(Bind(&DataMediaChannel::SendData, |
media_channel(), params, payload, result)); |
@@ -1871,7 +1871,7 @@ const ContentInfo* DataChannel::GetFirstContent( |
return GetFirstDataContent(sdesc); |
} |
-bool DataChannel::WantsPacket(bool rtcp, rtc::Buffer* packet) { |
+bool DataChannel::WantsPacket(bool rtcp, const rtc::CopyOnWriteBuffer* packet) { |
if (data_channel_type_ == DCT_SCTP) { |
// TODO(pthatcher): Do this in a more robust way by checking for |
// SCTP or DTLS. |