/* * Copyright (c) 2015 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 COMMON_VIDEO_H264_H264_BITSTREAM_PARSER_H_ #define COMMON_VIDEO_H264_H264_BITSTREAM_PARSER_H_ #include #include #include "absl/types/optional.h" #include "api/video_codecs/bitstream_parser.h" #include "common_video/h264/pps_parser.h" #include "common_video/h264/sps_parser.h" namespace webrtc { // Stateful H264 bitstream parser (due to SPS/PPS). Used to parse out QP values // from the bitstream. // TODO(pbos): Unify with RTP SPS parsing and only use one H264 parser. // TODO(pbos): If/when this gets used on the receiver side CHECKs must be // removed and gracefully abort as we have no control over receive-side // bitstreams. class H264BitstreamParser : public BitstreamParser { public: H264BitstreamParser(); ~H264BitstreamParser() override; // These are here for backwards-compatability for the time being. void ParseBitstream(const uint8_t* bitstream, size_t length); bool GetLastSliceQp(int* qp) const; // New interface. void ParseBitstream(rtc::ArrayView bitstream) override; absl::optional GetLastSliceQp() const override; protected: enum Result { kOk, kInvalidStream, kUnsupportedStream, }; void ParseSlice(const uint8_t* slice, size_t length); Result ParseNonParameterSetNalu(const uint8_t* source, size_t source_length, uint8_t nalu_type); // SPS/PPS state, updated when parsing new SPS/PPS, used to parse slices. absl::optional sps_; absl::optional pps_; // Last parsed slice QP. absl::optional last_slice_qp_delta_; }; } // namespace webrtc #endif // COMMON_VIDEO_H264_H264_BITSTREAM_PARSER_H_