|  | /* | 
|  | *  Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. | 
|  | * | 
|  | *  Use of this source code is governed by a BSD-style license | 
|  | *  that can be found in the LICENSE file in the root of the source | 
|  | *  tree. An additional intellectual property rights grant can be found | 
|  | *  in the file PATENTS.  All contributing project authors may | 
|  | *  be found in the AUTHORS file in the root of the source tree. | 
|  | */ | 
|  |  | 
|  | #ifndef MODULES_RTP_RTCP_INCLUDE_FLEXFEC_SENDER_H_ | 
|  | #define MODULES_RTP_RTCP_INCLUDE_FLEXFEC_SENDER_H_ | 
|  |  | 
|  | #include <memory> | 
|  | #include <string> | 
|  | #include <vector> | 
|  |  | 
|  | #include "api/array_view.h" | 
|  | #include "api/rtp_parameters.h" | 
|  | #include "modules/include/module_common_types.h" | 
|  | #include "modules/rtp_rtcp/include/rtp_header_extension_map.h" | 
|  | #include "modules/rtp_rtcp/include/rtp_rtcp_defines.h" | 
|  | #include "modules/rtp_rtcp/source/rtp_header_extension_size.h" | 
|  | #include "modules/rtp_rtcp/source/ulpfec_generator.h" | 
|  | #include "rtc_base/random.h" | 
|  |  | 
|  | namespace webrtc { | 
|  |  | 
|  | class Clock; | 
|  | class RtpPacketToSend; | 
|  |  | 
|  | // Note that this class is not thread safe, and thus requires external | 
|  | // synchronization. Currently, this is done using the lock in PayloadRouter. | 
|  |  | 
|  | class FlexfecSender { | 
|  | public: | 
|  | FlexfecSender(int payload_type, | 
|  | uint32_t ssrc, | 
|  | uint32_t protected_media_ssrc, | 
|  | const std::string& mid, | 
|  | const std::vector<RtpExtension>& rtp_header_extensions, | 
|  | rtc::ArrayView<const RtpExtensionSize> extension_sizes, | 
|  | const RtpState* rtp_state, | 
|  | Clock* clock); | 
|  | ~FlexfecSender(); | 
|  |  | 
|  | uint32_t ssrc() const { return ssrc_; } | 
|  |  | 
|  | // Sets the FEC rate, max frames sent before FEC packets are sent, | 
|  | // and what type of generator matrices are used. | 
|  | void SetFecParameters(const FecProtectionParams& params); | 
|  |  | 
|  | // Adds a media packet to the internal buffer. When enough media packets | 
|  | // have been added, the FEC packets are generated and stored internally. | 
|  | // These FEC packets are then obtained by calling GetFecPackets(). | 
|  | // Returns true if the media packet was successfully added. | 
|  | bool AddRtpPacketAndGenerateFec(const RtpPacketToSend& packet); | 
|  |  | 
|  | // Returns true if there are generated FEC packets available. | 
|  | bool FecAvailable() const; | 
|  |  | 
|  | // Returns generated FlexFEC packets. | 
|  | std::vector<std::unique_ptr<RtpPacketToSend>> GetFecPackets(); | 
|  |  | 
|  | // Returns the overhead, per packet, for FlexFEC. | 
|  | size_t MaxPacketOverhead() const; | 
|  |  | 
|  | // Only called on the VideoSendStream queue, after operation has shut down. | 
|  | RtpState GetRtpState(); | 
|  |  | 
|  | private: | 
|  | // Utility. | 
|  | Clock* const clock_; | 
|  | Random random_; | 
|  | int64_t last_generated_packet_ms_; | 
|  |  | 
|  | // Config. | 
|  | const int payload_type_; | 
|  | const uint32_t timestamp_offset_; | 
|  | const uint32_t ssrc_; | 
|  | const uint32_t protected_media_ssrc_; | 
|  | // MID value to send in the MID header extension. | 
|  | const std::string mid_; | 
|  | // Sequence number of next packet to generate. | 
|  | uint16_t seq_num_; | 
|  |  | 
|  | // Implementation. | 
|  | UlpfecGenerator ulpfec_generator_; | 
|  | const RtpHeaderExtensionMap rtp_header_extension_map_; | 
|  | const size_t header_extensions_size_; | 
|  | }; | 
|  |  | 
|  | }  // namespace webrtc | 
|  |  | 
|  | #endif  // MODULES_RTP_RTCP_INCLUDE_FLEXFEC_SENDER_H_ |