Reason for revert: Broke a lot of tests in chromium.webrtc browser_tests. See e.g. https://build.chromium.org/p/chromium.webrtc/builders/Mac%20Tester/builds/62228 and https://build.chromium.org/p/chromium.webrtc/builders/Win8%20Tester/builds/30102. [ RUN ] WebRtcVideoQualityBrowserTests/WebRtcVideoQualityBrowserTest.MANUAL_TestVideoQualityH264/1 ... # # Fatal error in e:\b\c\b\win_builder\src\third_party\webrtc\modules\rtp_rtcp\source\rtp_format_h264.cc, line 170 # last system error: 0 # Check failed: packetization_mode_ == kH264PacketizationMode1 (0 vs. 2) # Original issue's description: > Implement H.264 packetization mode 0. > > This approach extends the H.264 specific information with > a packetization mode enum. > > Status: Parameter is in code. No way to set it yet. > > Rebase of CL 2009213002 > > BUG=600254 > > Committed: https://crrev.com/3bba101f36483b8030a693dfbc93af736d1dba68 > Cr-Commit-Position: refs/heads/master@{#15032} TBR=hbos@webrtc.org,sprang@webrtc.org,mflodman@webrtc.org,hta@webrtc.org # Not skipping CQ checks because original CL landed more than 1 days ago. BUG=600254 NOPRESUBMIT=true Review-Url: https://codereview.webrtc.org/2500743002 Cr-Commit-Position: refs/heads/master@{#15050}
56 lines
1.9 KiB
C++
56 lines
1.9 KiB
C++
/*
|
|
* Copyright (c) 2014 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.
|
|
*/
|
|
|
|
#include "webrtc/modules/rtp_rtcp/source/rtp_format.h"
|
|
|
|
#include "webrtc/modules/rtp_rtcp/source/rtp_format_h264.h"
|
|
#include "webrtc/modules/rtp_rtcp/source/rtp_format_video_generic.h"
|
|
#include "webrtc/modules/rtp_rtcp/source/rtp_format_vp8.h"
|
|
#include "webrtc/modules/rtp_rtcp/source/rtp_format_vp9.h"
|
|
|
|
namespace webrtc {
|
|
RtpPacketizer* RtpPacketizer::Create(RtpVideoCodecTypes type,
|
|
size_t max_payload_len,
|
|
const RTPVideoTypeHeader* rtp_type_header,
|
|
FrameType frame_type) {
|
|
switch (type) {
|
|
case kRtpVideoH264:
|
|
return new RtpPacketizerH264(frame_type, max_payload_len);
|
|
case kRtpVideoVp8:
|
|
assert(rtp_type_header != NULL);
|
|
return new RtpPacketizerVp8(rtp_type_header->VP8, max_payload_len);
|
|
case kRtpVideoVp9:
|
|
assert(rtp_type_header != NULL);
|
|
return new RtpPacketizerVp9(rtp_type_header->VP9, max_payload_len);
|
|
case kRtpVideoGeneric:
|
|
return new RtpPacketizerGeneric(frame_type, max_payload_len);
|
|
case kRtpVideoNone:
|
|
assert(false);
|
|
}
|
|
return NULL;
|
|
}
|
|
|
|
RtpDepacketizer* RtpDepacketizer::Create(RtpVideoCodecTypes type) {
|
|
switch (type) {
|
|
case kRtpVideoH264:
|
|
return new RtpDepacketizerH264();
|
|
case kRtpVideoVp8:
|
|
return new RtpDepacketizerVp8();
|
|
case kRtpVideoVp9:
|
|
return new RtpDepacketizerVp9();
|
|
case kRtpVideoGeneric:
|
|
return new RtpDepacketizerGeneric();
|
|
case kRtpVideoNone:
|
|
assert(false);
|
|
}
|
|
return NULL;
|
|
}
|
|
} // namespace webrtc
|