[rtcp] in Tmmbn/tmmbr packets bitrate updated to 64bit
to match packet format. Review-Url: https://codereview.webrtc.org/1991223002 Cr-Commit-Position: refs/heads/master@{#12837}
This commit is contained in:
parent
1abfc2a7f3
commit
6a1a8ce668
@ -11,11 +11,12 @@
|
||||
#include "webrtc/modules/rtp_rtcp/source/rtcp_packet/tmmb_item.h"
|
||||
|
||||
#include "webrtc/base/checks.h"
|
||||
#include "webrtc/base/logging.h"
|
||||
#include "webrtc/modules/rtp_rtcp/source/byte_io.h"
|
||||
|
||||
namespace webrtc {
|
||||
namespace rtcp {
|
||||
TmmbItem::TmmbItem(uint32_t ssrc, uint32_t bitrate_bps, uint16_t overhead)
|
||||
TmmbItem::TmmbItem(uint32_t ssrc, uint64_t bitrate_bps, uint16_t overhead)
|
||||
: ssrc_(ssrc), bitrate_bps_(bitrate_bps), packet_overhead_(overhead) {
|
||||
RTC_DCHECK_LE(overhead, 0x1ffu);
|
||||
}
|
||||
@ -27,22 +28,30 @@ TmmbItem::TmmbItem(uint32_t ssrc, uint32_t bitrate_bps, uint16_t overhead)
|
||||
// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
||||
// 4 | MxTBR Exp | MxTBR Mantissa |Measured Overhead|
|
||||
// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
||||
void TmmbItem::Parse(const uint8_t* buffer) {
|
||||
bool TmmbItem::Parse(const uint8_t* buffer) {
|
||||
ssrc_ = ByteReader<uint32_t>::ReadBigEndian(&buffer[0]);
|
||||
// Read 4 bytes into 1 block.
|
||||
uint32_t compact = ByteReader<uint32_t>::ReadBigEndian(&buffer[4]);
|
||||
// Split 1 block into 3 components.
|
||||
uint8_t exponent = compact >> 26; // 6 bits.
|
||||
uint32_t mantissa = (compact >> 9) & 0x1ffff; // 17 bits.
|
||||
uint64_t mantissa = (compact >> 9) & 0x1ffff; // 17 bits.
|
||||
uint16_t overhead = compact & 0x1ff; // 9 bits.
|
||||
// Combine 3 components into 2 values.
|
||||
bitrate_bps_ = (mantissa << exponent);
|
||||
|
||||
bool shift_overflow = (bitrate_bps_ >> exponent) != mantissa;
|
||||
if (shift_overflow) {
|
||||
LOG(LS_ERROR) << "Invalid tmmb bitrate value : " << mantissa
|
||||
<< "*2^" << static_cast<int>(exponent);
|
||||
return false;
|
||||
}
|
||||
packet_overhead_ = overhead;
|
||||
return true;
|
||||
}
|
||||
|
||||
void TmmbItem::Create(uint8_t* buffer) const {
|
||||
const uint32_t kMaxMantissa = 0x1ffff; // 17 bits.
|
||||
uint32_t mantissa = bitrate_bps_;
|
||||
constexpr uint64_t kMaxMantissa = 0x1ffff; // 17 bits.
|
||||
uint64_t mantissa = bitrate_bps_;
|
||||
uint32_t exponent = 0;
|
||||
while (mantissa > kMaxMantissa) {
|
||||
mantissa >>= 1;
|
||||
|
||||
@ -23,17 +23,17 @@ class TmmbItem {
|
||||
static const size_t kLength = 8;
|
||||
|
||||
TmmbItem() : ssrc_(0), bitrate_bps_(0), packet_overhead_(0) {}
|
||||
TmmbItem(uint32_t ssrc, uint32_t bitrate_bps, uint16_t overhead);
|
||||
TmmbItem(uint32_t ssrc, uint64_t bitrate_bps, uint16_t overhead);
|
||||
|
||||
void Parse(const uint8_t* buffer);
|
||||
bool Parse(const uint8_t* buffer);
|
||||
void Create(uint8_t* buffer) const;
|
||||
|
||||
void set_ssrc(uint32_t ssrc) { ssrc_ = ssrc; }
|
||||
void set_bitrate_bps(uint32_t bitrate_bps) { bitrate_bps_ = bitrate_bps; }
|
||||
void set_bitrate_bps(uint64_t bitrate_bps) { bitrate_bps_ = bitrate_bps; }
|
||||
void set_packet_overhead(uint16_t overhead);
|
||||
|
||||
uint32_t ssrc() const { return ssrc_; }
|
||||
uint32_t bitrate_bps() const { return bitrate_bps_; }
|
||||
uint64_t bitrate_bps() const { return bitrate_bps_; }
|
||||
uint16_t packet_overhead() const { return packet_overhead_; }
|
||||
|
||||
private:
|
||||
@ -41,7 +41,7 @@ class TmmbItem {
|
||||
uint32_t ssrc_;
|
||||
// Maximum total media bit rate that the media receiver is
|
||||
// currently prepared to accept for this media stream.
|
||||
uint32_t bitrate_bps_;
|
||||
uint64_t bitrate_bps_;
|
||||
// Per-packet overhead that the media receiver has observed
|
||||
// for this media stream at its chosen reference protocol layer.
|
||||
uint16_t packet_overhead_;
|
||||
|
||||
@ -63,7 +63,8 @@ bool Tmmbn::Parse(const RtcpCommonHeader& header, const uint8_t* payload) {
|
||||
size_t number_of_items = items_size_bytes / TmmbItem::kLength;
|
||||
items_.resize(number_of_items);
|
||||
for (TmmbItem& item : items_) {
|
||||
item.Parse(next_item);
|
||||
if (!item.Parse(next_item))
|
||||
return false;
|
||||
next_item += TmmbItem::kLength;
|
||||
}
|
||||
return true;
|
||||
|
||||
@ -64,7 +64,8 @@ bool Tmmbr::Parse(const RtcpCommonHeader& header, const uint8_t* payload) {
|
||||
size_t number_of_items = items_size_bytes / TmmbItem::kLength;
|
||||
items_.resize(number_of_items);
|
||||
for (TmmbItem& item : items_) {
|
||||
item.Parse(next_item);
|
||||
if (!item.Parse(next_item))
|
||||
return false;
|
||||
next_item += TmmbItem::kLength;
|
||||
}
|
||||
return true;
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user