Index: webrtc/modules/rtp_rtcp/source/rtp_sender_video.cc |
diff --git a/webrtc/modules/rtp_rtcp/source/rtp_sender_video.cc b/webrtc/modules/rtp_rtcp/source/rtp_sender_video.cc |
index b89aefef53e44977f2bda96438bd16cb3b4572af..6420a89b9df3037458219a5048eda47e14d24f9b 100644 |
--- a/webrtc/modules/rtp_rtcp/source/rtp_sender_video.cc |
+++ b/webrtc/modules/rtp_rtcp/source/rtp_sender_video.cc |
@@ -19,6 +19,7 @@ |
#include "webrtc/base/checks.h" |
#include "webrtc/base/logging.h" |
+#include "webrtc/base/ptr_util.h" |
#include "webrtc/base/trace_event.h" |
#include "webrtc/modules/rtp_rtcp/include/rtp_rtcp_defines.h" |
#include "webrtc/modules/rtp_rtcp/source/byte_io.h" |
@@ -300,6 +301,7 @@ bool RTPSenderVideo::SendVideo(RtpVideoCodecTypes video_type, |
rtp_header->SetPayloadType(payload_type); |
rtp_header->SetTimestamp(rtp_timestamp); |
rtp_header->set_capture_time_ms(capture_time_ms); |
+ auto last_packet = rtc::MakeUnique<RtpPacketToSend>(*rtp_header); |
size_t fec_packet_overhead; |
bool red_enabled; |
@@ -322,12 +324,12 @@ bool RTPSenderVideo::SendVideo(RtpVideoCodecTypes video_type, |
VideoRotation current_rotation = video_header->rotation; |
if (frame_type == kVideoFrameKey || current_rotation != last_rotation_ || |
current_rotation != kVideoRotation_0) |
- rtp_header->SetExtension<VideoOrientation>(current_rotation); |
+ last_packet->SetExtension<VideoOrientation>(current_rotation); |
last_rotation_ = current_rotation; |
// Report content type only for key frames. |
if (frame_type == kVideoFrameKey && |
video_header->content_type != VideoContentType::UNSPECIFIED) { |
- rtp_header->SetExtension<VideoContentTypeExtension>( |
+ last_packet->SetExtension<VideoContentTypeExtension>( |
video_header->content_type); |
} |
} |
@@ -350,10 +352,13 @@ bool RTPSenderVideo::SendVideo(RtpVideoCodecTypes video_type, |
(rtp_sender_->RtxStatus() ? kRtxHeaderSize : 0); |
RTC_DCHECK_LE(packet_capacity, rtp_header->capacity()); |
RTC_DCHECK_GT(packet_capacity, rtp_header->headers_size()); |
+ RTC_DCHECK_GT(packet_capacity, last_packet->headers_size()); |
size_t max_data_payload_length = packet_capacity - rtp_header->headers_size(); |
+ size_t last_packet_extensions_len = |
+ last_packet->headers_size() - rtp_header->headers_size(); |
danilchap
2017/05/12 13:56:10
be explicit about your assumption
last_packet->hea
ilnik
2017/05/12 14:46:08
Done.
|
std::unique_ptr<RtpPacketizer> packetizer(RtpPacketizer::Create( |
- video_type, max_data_payload_length, |
+ video_type, max_data_payload_length, last_packet_extensions_len, |
video_header ? &(video_header->codecHeader) : nullptr, frame_type)); |
// Media packet storage. |
StorageType storage = packetizer->GetStorageType(retransmission_settings); |
@@ -363,18 +368,20 @@ bool RTPSenderVideo::SendVideo(RtpVideoCodecTypes video_type, |
// issue is fixed. |
const RTPFragmentationHeader* frag = |
(video_type == kRtpVideoVp8) ? nullptr : fragmentation; |
- packetizer->SetPayloadData(payload_data, payload_size, frag); |
+ size_t num_packets = |
+ packetizer->SetPayloadData(payload_data, payload_size, frag); |
bool first_frame = first_frame_sent_(); |
- bool first = true; |
- bool last = false; |
- while (!last) { |
- std::unique_ptr<RtpPacketToSend> packet(new RtpPacketToSend(*rtp_header)); |
- |
- if (!packetizer->NextPacket(packet.get(), &last)) |
+ for (size_t i = 0; i < num_packets; ++i) { |
+ RtpPacketToSend* rtp_header_to_use = rtp_header.get(); |
+ bool last = (i + 1) == num_packets; |
+ if (last) |
+ rtp_header_to_use = last_packet.get(); |
+ std::unique_ptr<RtpPacketToSend> packet( |
danilchap
2017/05/12 13:56:10
may be
auto packet = last ? std::move(last_packet)
ilnik
2017/05/12 14:46:08
Done.
|
+ new RtpPacketToSend(*rtp_header_to_use)); |
+ if (!packetizer->NextPacket(packet.get())) |
return false; |
- RTC_DCHECK_LE(packet->payload_size(), max_data_payload_length); |
- |
+ RTC_DCHECK_LE(packet->payload_size(), packet->capacity()); |
danilchap
2017/05/12 13:56:10
sorry for confusion, but
packet->capacity() != pac
ilnik
2017/05/12 14:46:08
Done here something better now. It may be redundan
|
if (!rtp_sender_->AssignSequenceNumber(packet.get())) |
return false; |
@@ -392,7 +399,7 @@ bool RTPSenderVideo::SendVideo(RtpVideoCodecTypes video_type, |
} |
if (first_frame) { |
- if (first) { |
+ if (i == 0) { |
LOG(LS_INFO) |
<< "Sent first RTP packet of the first video frame (pre-pacer)"; |
} |
@@ -401,7 +408,6 @@ bool RTPSenderVideo::SendVideo(RtpVideoCodecTypes video_type, |
<< "Sent last RTP packet of the first video frame (pre-pacer)"; |
} |
} |
- first = false; |
} |
TRACE_EVENT_ASYNC_END1("webrtc", "Video", capture_time_ms, "timestamp", |