| 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..3f4c401a19d5c43ff9f64c6a9e3bd14d60ff9fb6 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,14 @@ 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();
 | 
| +  RTC_DCHECK_GE(last_packet->headers_size(), rtp_header->headers_size());
 | 
| +  size_t last_packet_reduction_len =
 | 
| +      last_packet->headers_size() - rtp_header->headers_size();
 | 
|  
 | 
|    std::unique_ptr<RtpPacketizer> packetizer(RtpPacketizer::Create(
 | 
| -      video_type, max_data_payload_length,
 | 
| +      video_type, max_data_payload_length, last_packet_reduction_len,
 | 
|        video_header ? &(video_header->codecHeader) : nullptr, frame_type));
 | 
|    // Media packet storage.
 | 
|    StorageType storage = packetizer->GetStorageType(retransmission_settings);
 | 
| @@ -363,18 +369,22 @@ 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 (num_packets == 0)
 | 
| +    return false;
 | 
|  
 | 
| -    if (!packetizer->NextPacket(packet.get(), &last))
 | 
| +  bool first_frame = first_frame_sent_();
 | 
| +  for (size_t i = 0; i < num_packets; ++i) {
 | 
| +    bool last = (i + 1) == num_packets;
 | 
| +    auto packet = last ? std::move(last_packet)
 | 
| +                       : rtc::MakeUnique<RtpPacketToSend>(*rtp_header);
 | 
| +    if (!packetizer->NextPacket(packet.get()))
 | 
|        return false;
 | 
| -    RTC_DCHECK_LE(packet->payload_size(), max_data_payload_length);
 | 
| -
 | 
| +    RTC_DCHECK_LE(packet->payload_size(),
 | 
| +                  last ? max_data_payload_length - last_packet_reduction_len
 | 
| +                       : max_data_payload_length);
 | 
|      if (!rtp_sender_->AssignSequenceNumber(packet.get()))
 | 
|        return false;
 | 
|  
 | 
| @@ -392,7 +402,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 +411,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",
 | 
| 
 |