Chromium Code Reviews| Index: webrtc/modules/rtp_rtcp/source/forward_error_correction.cc | 
| diff --git a/webrtc/modules/rtp_rtcp/source/forward_error_correction.cc b/webrtc/modules/rtp_rtcp/source/forward_error_correction.cc | 
| index 3106d6d38ec4dc0214bcf0ddec6ca8cda8e015e3..4ca9cbcf96c28b65ffdb4a788398a307bc0590e3 100644 | 
| --- a/webrtc/modules/rtp_rtcp/source/forward_error_correction.cc | 
| +++ b/webrtc/modules/rtp_rtcp/source/forward_error_correction.cc | 
| @@ -20,6 +20,8 @@ | 
| #include "webrtc/base/logging.h" | 
| #include "webrtc/modules/rtp_rtcp/include/rtp_rtcp_defines.h" | 
| #include "webrtc/modules/rtp_rtcp/source/byte_io.h" | 
| +#include "webrtc/modules/rtp_rtcp/source/flexfec_header_reader_writer.h" | 
| +#include "webrtc/modules/rtp_rtcp/source/forward_error_correction_internal.h" | 
| #include "webrtc/modules/rtp_rtcp/source/ulpfec_header_reader_writer.h" | 
| namespace webrtc { | 
| @@ -84,6 +86,14 @@ std::unique_ptr<ForwardErrorCorrection> ForwardErrorCorrection::CreateUlpfec() { | 
| std::move(fec_header_reader), std::move(fec_header_writer))); | 
| } | 
| +std::unique_ptr<ForwardErrorCorrection> | 
| +ForwardErrorCorrection::CreateFlexfec() { | 
| + std::unique_ptr<FecHeaderReader> fec_header_reader(new FlexfecHeaderReader()); | 
| + std::unique_ptr<FecHeaderWriter> fec_header_writer(new FlexfecHeaderWriter()); | 
| + return std::unique_ptr<ForwardErrorCorrection>(new ForwardErrorCorrection( | 
| + std::move(fec_header_reader), std::move(fec_header_writer))); | 
| +} | 
| + | 
| int ForwardErrorCorrection::EncodeFec(const PacketList& media_packets, | 
| uint8_t protection_factor, | 
| int num_important_packets, | 
| @@ -152,9 +162,10 @@ int ForwardErrorCorrection::EncodeFec(const PacketList& media_packets, | 
| GenerateFecPayloads(media_packets, num_fec_packets); | 
| // TODO(brandtr): Generalize this when multistream protection support is | 
| // added. | 
| + const uint32_t media_ssrc = ParseSsrc(media_packets.front()->data); | 
| const uint16_t seq_num_base = | 
| ParseSequenceNumber(media_packets.front().get()->data); | 
| 
 
danilchap
2016/09/21 11:17:56
can remove .get() here too
 
brandtr
2016/09/21 11:43:28
Done.
 
 | 
| - FinalizeFecHeaders(num_fec_packets, seq_num_base); | 
| + FinalizeFecHeaders(num_fec_packets, media_ssrc, seq_num_base); | 
| return 0; | 
| } | 
| @@ -305,11 +316,12 @@ int ForwardErrorCorrection::InsertZerosInPacketMasks( | 
| } | 
| void ForwardErrorCorrection::FinalizeFecHeaders(size_t num_fec_packets, | 
| + uint32_t media_ssrc, | 
| uint16_t seq_num_base) { | 
| for (size_t i = 0; i < num_fec_packets; ++i) { | 
| fec_header_writer_->FinalizeFecHeader( | 
| - seq_num_base, &packet_masks_[i * packet_mask_size_], packet_mask_size_, | 
| - &generated_fec_packets_[i]); | 
| + media_ssrc, seq_num_base, &packet_masks_[i * packet_mask_size_], | 
| + packet_mask_size_, &generated_fec_packets_[i]); | 
| } | 
| } |