Chromium Code Reviews| Index: webrtc/modules/rtp_rtcp/source/flexfec_header_reader_writer.h |
| diff --git a/webrtc/modules/rtp_rtcp/source/flexfec_header_reader_writer.h b/webrtc/modules/rtp_rtcp/source/flexfec_header_reader_writer.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..66a1b33002c31f9895941633d417a80f1bf04efc |
| --- /dev/null |
| +++ b/webrtc/modules/rtp_rtcp/source/flexfec_header_reader_writer.h |
| @@ -0,0 +1,86 @@ |
| +/* |
| + * 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 WEBRTC_MODULES_RTP_RTCP_SOURCE_FLEXFEC_HEADER_READER_WRITER_H_ |
| +#define WEBRTC_MODULES_RTP_RTCP_SOURCE_FLEXFEC_HEADER_READER_WRITER_H_ |
| + |
| +#include "webrtc/base/basictypes.h" |
| +#include "webrtc/modules/rtp_rtcp/source/forward_error_correction.h" |
| + |
| +namespace webrtc { |
| + |
| +// FlexFEC header, minimum 20 bytes. |
| +// 0 1 2 3 |
| +// 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 |
| +// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
| +// 0 |F|R|P|X| CC |M| PT recovery | length recovery | |
| +// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
| +// 4 | TS recovery | |
| +// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
| +// 8 | SSRCCount | reserved | |
| +// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
|
danilchap
2016/09/07 12:41:17
May be annotate this line differently:
+=+=+=+=+
t
brandtr
2016/09/12 11:31:21
Done.
|
| +// 12 | SSRC_i | |
| +// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
| +// 16 | SN base_i |k| Mask [0-14] | |
| +// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
| +// 20 |k| Mask [15-45] (optional) | |
| +// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
| +// 24 |k| | |
| +// +-+ Mask [46-108] (optional) | |
| +// 28 | | |
| +// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
|
danilchap
2016/09/07 12:41:17
And make this line same
brandtr
2016/09/12 11:31:21
Done.
|
| +// 32 | ... next in SSRC_i ... | |
|
danilchap
2016/09/07 12:41:17
Because of variable length of previous header, it
brandtr
2016/09/12 11:31:21
Done.
|
| +// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
|
danilchap
2016/09/07 12:41:17
May be remove this line to note 'next in SSRC_i' t
brandtr
2016/09/12 11:31:21
Good idea, done.
|
| +// |
| +// FlexFEC header in 'inflexible' mode (F = 1), 20 bytes. |
| +// 0 1 2 3 |
| +// 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 |
| +// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
| +// 0 |1|0|P|X| CC |M| PT recovery | length recovery | |
| +// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
| +// 4 | TS recovery | |
| +// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
| +// 8 | SSRCCount | reserved | |
| +// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
| +// 12 | SSRC_i | |
| +// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
| +// 16 | SN base_i | M (columns) | N (rows) | |
| +// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
| + |
| +class FlexfecHeaderReader : public FecHeaderReader { |
| + public: |
| + FlexfecHeaderReader(); |
| + ~FlexfecHeaderReader() override; |
| + |
| + bool ReadFecHeader( |
| + ForwardErrorCorrection::ReceivedFecPacket* fec_packet) const override; |
| +}; |
| + |
| +class FlexfecHeaderWriter : public FecHeaderWriter { |
| + public: |
| + FlexfecHeaderWriter(); |
| + ~FlexfecHeaderWriter() override; |
| + |
| + size_t MinPacketMaskSize(const uint8_t* packet_mask, |
| + size_t packet_mask_size) const override; |
| + |
| + size_t FecHeaderSize(size_t packet_mask_row_size) const override; |
| + |
| + void FinalizeFecHeader( |
| + uint32_t ssrc, |
| + uint16_t seq_num_base, |
| + const uint8_t* packet_mask, |
| + size_t packet_mask_size, |
| + ForwardErrorCorrection::Packet* fec_packet) const override; |
| +}; |
| + |
| +} // namespace webrtc |
| + |
| +#endif // WEBRTC_MODULES_RTP_RTCP_SOURCE_FLEXFEC_HEADER_READER_WRITER_H_ |