mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-13 22:00:47 +01:00

This CL makes NetEq handle nested RED packets without crashing. Nested RED packets mean that the block PT (see https://tools.ietf.org/html/rfc2198.html#section-3) in the RED packet is also set to the RED PT. This implies a nested RED packet, which is not supported. Instead, all payloads in a RED packet that have the RED PT will be discarded. Bug: chromium:851662 Change-Id: I86ec257e60fb8076e3574ac5a4a1ca50196f6b34 Reviewed-on: https://webrtc-review.googlesource.com/86824 Commit-Queue: Henrik Lundin <henrik.lundin@webrtc.org> Reviewed-by: Ivo Creusen <ivoc@webrtc.org> Cr-Commit-Position: refs/heads/master@{#23825}
50 lines
1.9 KiB
C++
50 lines
1.9 KiB
C++
/*
|
|
* Copyright (c) 2012 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_AUDIO_CODING_NETEQ_RED_PAYLOAD_SPLITTER_H_
|
|
#define MODULES_AUDIO_CODING_NETEQ_RED_PAYLOAD_SPLITTER_H_
|
|
|
|
#include "modules/audio_coding/neteq/packet.h"
|
|
#include "rtc_base/constructormagic.h"
|
|
|
|
namespace webrtc {
|
|
|
|
// Forward declarations.
|
|
class DecoderDatabase;
|
|
|
|
// This class handles splitting of RED payloads into smaller parts.
|
|
// Codec-specific packet splitting can be performed by
|
|
// AudioDecoder::ParsePayload.
|
|
class RedPayloadSplitter {
|
|
public:
|
|
RedPayloadSplitter() {}
|
|
|
|
virtual ~RedPayloadSplitter() {}
|
|
|
|
// Splits each packet in |packet_list| into its separate RED payloads. Each
|
|
// RED payload is packetized into a Packet. The original elements in
|
|
// |packet_list| are properly deleted, and replaced by the new packets.
|
|
// Note that all packets in |packet_list| must be RED payloads, i.e., have
|
|
// RED headers according to RFC 2198 at the very beginning of the payload.
|
|
// Returns kOK or an error.
|
|
virtual bool SplitRed(PacketList* packet_list);
|
|
|
|
// Checks all packets in |packet_list|. Packets that are DTMF events or
|
|
// comfort noise payloads are kept. Except that, only one single payload type
|
|
// is accepted. Any packet with another payload type is discarded.
|
|
virtual void CheckRedPayloads(PacketList* packet_list,
|
|
const DecoderDatabase& decoder_database);
|
|
|
|
private:
|
|
RTC_DISALLOW_COPY_AND_ASSIGN(RedPayloadSplitter);
|
|
};
|
|
|
|
} // namespace webrtc
|
|
#endif // MODULES_AUDIO_CODING_NETEQ_RED_PAYLOAD_SPLITTER_H_
|