phoglund@webrtc.org | 07bf43c | 2012-12-18 15:40:53 +0000 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. |
| 3 | * |
| 4 | * Use of this source code is governed by a BSD-style license |
| 5 | * that can be found in the LICENSE file in the root of the source |
| 6 | * tree. An additional intellectual property rights grant can be found |
| 7 | * in the file PATENTS. All contributing project authors may |
| 8 | * be found in the AUTHORS file in the root of the source tree. |
| 9 | */ |
| 10 | |
Mirko Bonadei | 92ea95e | 2017-09-15 06:47:31 +0200 | [diff] [blame] | 11 | #ifndef MODULES_RTP_RTCP_SOURCE_RTP_RECEIVER_STRATEGY_H_ |
| 12 | #define MODULES_RTP_RTCP_SOURCE_RTP_RECEIVER_STRATEGY_H_ |
phoglund@webrtc.org | 07bf43c | 2012-12-18 15:40:53 +0000 | [diff] [blame] | 13 | |
Mirko Bonadei | 92ea95e | 2017-09-15 06:47:31 +0200 | [diff] [blame] | 14 | #include "modules/rtp_rtcp/include/rtp_rtcp.h" |
| 15 | #include "modules/rtp_rtcp/include/rtp_rtcp_defines.h" |
| 16 | #include "modules/rtp_rtcp/source/rtp_utility.h" |
| 17 | #include "rtc_base/criticalsection.h" |
Mirko Bonadei | 7120742 | 2017-09-15 13:58:09 +0200 | [diff] [blame^] | 18 | #include "typedefs.h" // NOLINT(build/include) |
phoglund@webrtc.org | 07bf43c | 2012-12-18 15:40:53 +0000 | [diff] [blame] | 19 | |
| 20 | namespace webrtc { |
| 21 | |
magjed | 56124bd | 2016-11-24 09:34:46 -0800 | [diff] [blame] | 22 | struct CodecInst; |
| 23 | |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 24 | class TelephoneEventHandler; |
| 25 | |
phoglund@webrtc.org | 07bf43c | 2012-12-18 15:40:53 +0000 | [diff] [blame] | 26 | // This strategy deals with media-specific RTP packet processing. |
| 27 | // This class is not thread-safe and must be protected by its caller. |
| 28 | class RTPReceiverStrategy { |
| 29 | public: |
andresp@webrtc.org | dc80bae | 2014-04-08 11:06:12 +0000 | [diff] [blame] | 30 | static RTPReceiverStrategy* CreateVideoStrategy(RtpData* data_callback); |
solenberg | 1d03139 | 2016-03-30 02:42:32 -0700 | [diff] [blame] | 31 | static RTPReceiverStrategy* CreateAudioStrategy(RtpData* data_callback); |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 32 | |
tnakamura@webrtc.org | aa4d96a | 2013-07-16 19:25:04 +0000 | [diff] [blame] | 33 | virtual ~RTPReceiverStrategy() {} |
stefan@webrtc.org | 66b2e5c | 2013-07-05 14:30:48 +0000 | [diff] [blame] | 34 | |
tnakamura@webrtc.org | aa4d96a | 2013-07-16 19:25:04 +0000 | [diff] [blame] | 35 | // Parses the RTP packet and calls the data callback with the payload data. |
| 36 | // Implementations are encouraged to use the provided packet buffer and RTP |
| 37 | // header as arguments to the callback; implementations are also allowed to |
| 38 | // make changes in the data as necessary. The specific_payload argument |
| 39 | // provides audio or video-specific data. The is_first_packet argument is true |
| 40 | // if this packet is either the first packet ever or the first in its frame. |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 41 | virtual int32_t ParseRtpPacket(WebRtcRTPHeader* rtp_header, |
| 42 | const PayloadUnion& specific_payload, |
| 43 | bool is_red, |
stefan@webrtc.org | 7bb8f02 | 2013-09-06 13:40:11 +0000 | [diff] [blame] | 44 | const uint8_t* payload, |
pkasting@chromium.org | 4591fbd | 2014-11-20 22:28:14 +0000 | [diff] [blame] | 45 | size_t payload_length, |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 46 | int64_t timestamp_ms, |
| 47 | bool is_first_packet) = 0; |
| 48 | |
danilchap | 799a9d0 | 2016-09-22 03:36:27 -0700 | [diff] [blame] | 49 | virtual TelephoneEventHandler* GetTelephoneEventHandler() = 0; |
| 50 | |
tnakamura@webrtc.org | aa4d96a | 2013-07-16 19:25:04 +0000 | [diff] [blame] | 51 | // Computes the current dead-or-alive state. |
| 52 | virtual RTPAliveType ProcessDeadOrAlive( |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 53 | uint16_t last_payload_length) const = 0; |
tnakamura@webrtc.org | aa4d96a | 2013-07-16 19:25:04 +0000 | [diff] [blame] | 54 | |
| 55 | // Returns true if we should report CSRC changes for this payload type. |
| 56 | // TODO(phoglund): should move out of here along with other payload stuff. |
| 57 | virtual bool ShouldReportCsrcChanges(uint8_t payload_type) const = 0; |
| 58 | |
magjed | 56124bd | 2016-11-24 09:34:46 -0800 | [diff] [blame] | 59 | // Notifies the strategy that we have created a new non-RED audio payload type |
| 60 | // in the payload registry. |
| 61 | virtual int32_t OnNewPayloadTypeCreated(const CodecInst& audio_codec) = 0; |
tnakamura@webrtc.org | aa4d96a | 2013-07-16 19:25:04 +0000 | [diff] [blame] | 62 | |
| 63 | // Invokes the OnInitializeDecoder callback in a media-specific way. |
| 64 | virtual int32_t InvokeOnInitializeDecoder( |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 65 | RtpFeedback* callback, |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 66 | int8_t payload_type, |
| 67 | const char payload_name[RTP_PAYLOAD_NAME_SIZE], |
| 68 | const PayloadUnion& specific_payload) const = 0; |
tnakamura@webrtc.org | aa4d96a | 2013-07-16 19:25:04 +0000 | [diff] [blame] | 69 | |
| 70 | // Checks if the payload type has changed, and returns whether we should |
| 71 | // reset statistics and/or discard this packet. |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 72 | virtual void CheckPayloadChanged(int8_t payload_type, |
| 73 | PayloadUnion* specific_payload, |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 74 | bool* should_discard_changes); |
| 75 | |
| 76 | virtual int Energy(uint8_t array_of_energy[kRtpCsrcSize]) const; |
tnakamura@webrtc.org | aa4d96a | 2013-07-16 19:25:04 +0000 | [diff] [blame] | 77 | |
| 78 | // Stores / retrieves the last media specific payload for later reference. |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 79 | void GetLastMediaSpecificPayload(PayloadUnion* payload) const; |
| 80 | void SetLastMediaSpecificPayload(const PayloadUnion& payload); |
tnakamura@webrtc.org | aa4d96a | 2013-07-16 19:25:04 +0000 | [diff] [blame] | 81 | |
| 82 | protected: |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 83 | // The data callback is where we should send received payload data. |
| 84 | // See ParseRtpPacket. This class does not claim ownership of the callback. |
| 85 | // Implementations must NOT hold any critical sections while calling the |
| 86 | // callback. |
| 87 | // |
| 88 | // Note: Implementations may call the callback for other reasons than calls |
| 89 | // to ParseRtpPacket, for instance if the implementation somehow recovers a |
| 90 | // packet. |
danilchap | 6db6cdc | 2015-12-15 02:54:47 -0800 | [diff] [blame] | 91 | explicit RTPReceiverStrategy(RtpData* data_callback); |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 92 | |
danilchap | 7c9426c | 2016-04-14 03:05:31 -0700 | [diff] [blame] | 93 | rtc::CriticalSection crit_sect_; |
wu@webrtc.org | 822fbd8 | 2013-08-15 23:38:54 +0000 | [diff] [blame] | 94 | PayloadUnion last_payload_; |
phoglund@webrtc.org | a22a9bd | 2013-01-14 10:01:55 +0000 | [diff] [blame] | 95 | RtpData* data_callback_; |
phoglund@webrtc.org | 07bf43c | 2012-12-18 15:40:53 +0000 | [diff] [blame] | 96 | }; |
phoglund@webrtc.org | 07bf43c | 2012-12-18 15:40:53 +0000 | [diff] [blame] | 97 | } // namespace webrtc |
| 98 | |
Mirko Bonadei | 92ea95e | 2017-09-15 06:47:31 +0200 | [diff] [blame] | 99 | #endif // MODULES_RTP_RTCP_SOURCE_RTP_RECEIVER_STRATEGY_H_ |