2011-05-30 11:22:19 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2011 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This file contains the declaration of the VP8 packetizer class.
|
2011-06-07 12:23:14 +00:00
|
|
|
* A packetizer object is created for each encoded video frame. The
|
|
|
|
* constructor is called with the payload data and size,
|
|
|
|
* together with the fragmentation information and a packetizer mode
|
|
|
|
* of choice. Alternatively, if no fragmentation info is available, the
|
|
|
|
* second constructor can be used with only payload data and size; in that
|
|
|
|
* case the mode kSloppy is used.
|
2011-05-30 11:22:19 +00:00
|
|
|
*
|
2011-06-07 12:23:14 +00:00
|
|
|
* After creating the packetizer, the method NextPacket is called
|
|
|
|
* repeatedly to get all packets for the frame. The method returns
|
|
|
|
* false as long as there are more packets left to fetch.
|
2011-05-30 11:22:19 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef WEBRTC_MODULES_RTP_RTCP_RTP_FORMAT_VP8_H_
|
|
|
|
#define WEBRTC_MODULES_RTP_RTCP_RTP_FORMAT_VP8_H_
|
|
|
|
|
|
|
|
#include "module_common_types.h"
|
|
|
|
#include "typedefs.h"
|
|
|
|
|
|
|
|
namespace webrtc
|
|
|
|
{
|
|
|
|
|
|
|
|
enum VP8PacketizerMode
|
|
|
|
{
|
2011-06-15 09:38:28 +00:00
|
|
|
kStrict = 0, // split partitions if too large; never aggregate, balance size
|
|
|
|
kAggregate, // split partitions if too large; aggregate whole partitions
|
|
|
|
kSloppy, // split entire payload without considering partition limits
|
|
|
|
kNumModes,
|
2011-05-30 11:22:19 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// Packetizer for VP8.
|
2011-06-07 12:23:14 +00:00
|
|
|
class RtpFormatVp8
|
2011-05-30 11:22:19 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
// Initialize with payload from encoder and fragmentation info.
|
2011-06-07 12:23:14 +00:00
|
|
|
// The payload_data must be exactly one encoded VP8 frame.
|
|
|
|
RtpFormatVp8(const WebRtc_UWord8* payload_data,
|
|
|
|
WebRtc_UWord32 payload_size,
|
2011-06-15 09:38:28 +00:00
|
|
|
const RTPFragmentationHeader& fragmentation,
|
2011-06-07 12:23:14 +00:00
|
|
|
VP8PacketizerMode mode);
|
|
|
|
|
|
|
|
// Initialize without fragmentation info. Mode kSloppy will be used.
|
|
|
|
// The payload_data must be exactly one encoded VP8 frame.
|
|
|
|
RtpFormatVp8(const WebRtc_UWord8* payload_data,
|
|
|
|
WebRtc_UWord32 payload_size);
|
2011-05-30 11:22:19 +00:00
|
|
|
|
|
|
|
// Get the next payload with VP8 payload header.
|
|
|
|
// max_payload_len limits the sum length of payload and VP8 payload header.
|
|
|
|
// buffer is a pointer to where the output will be written.
|
|
|
|
// bytes_to_send is an output variable that will contain number of bytes
|
|
|
|
// written to buffer.
|
2011-06-07 12:23:14 +00:00
|
|
|
// Returns true for the last packet of the frame, false otherwise (i.e.,
|
|
|
|
// call the function again to get the next packet).
|
|
|
|
int NextPacket(int max_payload_len, WebRtc_UWord8* buffer,
|
|
|
|
int* bytes_to_send, bool* last_packet);
|
2011-05-30 11:22:19 +00:00
|
|
|
|
|
|
|
private:
|
2011-06-15 09:38:28 +00:00
|
|
|
enum AggregationMode
|
|
|
|
{
|
|
|
|
kAggrNone = 0, // no aggregation
|
|
|
|
kAggrPartitions, // aggregate intact partitions
|
|
|
|
kAggrFragments // aggregate intact and fragmented partitions
|
|
|
|
};
|
|
|
|
|
|
|
|
static const AggregationMode aggr_modes_[kNumModes];
|
|
|
|
static const bool bal_modes_[kNumModes];
|
|
|
|
static const bool sep_first_modes_[kNumModes];
|
|
|
|
|
|
|
|
// Calculate size of next chunk to send. Returns 0 if none can be sent.
|
|
|
|
int CalcNextSize(int max_payload_len, int remaining_bytes,
|
|
|
|
bool split_payload) const;
|
2011-06-07 12:23:14 +00:00
|
|
|
|
2011-05-30 11:22:19 +00:00
|
|
|
// Write the payload header and copy the payload to the buffer.
|
|
|
|
// Will copy send_bytes bytes from the current position on the payload data.
|
|
|
|
// last_fragment indicates that this packet ends with the last byte of a
|
|
|
|
// partition.
|
2011-06-07 12:23:14 +00:00
|
|
|
int WriteHeaderAndPayload(int send_bytes, bool end_of_fragment,
|
2011-05-30 11:22:19 +00:00
|
|
|
WebRtc_UWord8* buffer);
|
|
|
|
|
|
|
|
const WebRtc_UWord8* payload_data_;
|
2011-06-15 11:35:59 +00:00
|
|
|
const int payload_size_;
|
2011-06-15 09:38:28 +00:00
|
|
|
RTPFragmentationHeader part_info_;
|
2011-06-07 12:23:14 +00:00
|
|
|
int payload_bytes_sent_;
|
2011-06-15 09:38:28 +00:00
|
|
|
int part_ix_;
|
2011-05-30 11:22:19 +00:00
|
|
|
bool beginning_; // first partition in this frame
|
|
|
|
bool first_fragment_; // first fragment of a partition
|
|
|
|
const int vp8_header_bytes_; // length of VP8 payload header
|
2011-06-15 09:38:28 +00:00
|
|
|
AggregationMode aggr_mode_;
|
|
|
|
bool balance_;
|
|
|
|
bool separate_first_;
|
2011-05-30 11:22:19 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* WEBRTC_MODULES_RTP_RTCP_RTP_FORMAT_VP8_H_ */
|