e62aa3e09b
* * rocDecode/ES parser: Added elementary stream file parser for HEVC and AVC. * * rocDecode/ES parser: Added elementary stream file parser for AV1. Also cleaned up the bitstream ring buffer code. * * rocDecode/ES parser: Added the IVF container file parser for AV1. Also fixed a bug in fill ring buffer function. * * rocDecode/ES file parder: Added supported stream type detection. - The stream type detection checks the unique syntax patterns of the stream type and calculate the likeliheed score. Based on the score, the most likely type is determined. - The current supported stream types are: AVC/HEVC/AV1 elementary streams, IVF AV1 streams. * * rocDecode/ES file parser: Fixed an AVC decode regression due to a copy and paste error. * * rocDecode/ES file parser: Added bit depth parsing for codec support check; Added stronger AV1 detection for IVF AV1 stream type. * * rocDecode/ES file parser: Removed debugging logs. * * rocDecode/ES file parser: Added exmaple code to use the built-in file parser. * * rocDecode/Bitstream reader: Renamed the elementary parser feature to bitstream reader and re-organized the code. - Moved the bitstream reader code to rocDecode core lib from utility. - Added bitstream reader interface in parallel with rocDecode parser and decoder interfaces. * * rocDecode/Bitstream reader: Added sample to use bitstream reader, instead of FFMPEG demuxer, to get picture data. Also reverted the original sample app back to using FFMPEG demuxer only. * * rocDecode/Bitstream reader: Renamed the new sample app. * * rocDecode/Bitstream reader: FFMPEG dependency reduction. - Moved MD5 functions out of RocVideoDecoder utility class. This removed RocVideoDecoder's dependency on FFMPEG. - Added the new MD5 utility, which depends on FFMPEG lib. MD5 message digest generation is now performed in the MD5 utility. - Modified decode sampples that uses MD5 generation function. - Removed FFMPEG dependency from video decoder basic sample. * * rocDecode/Bitstream reader: Added option to use bitstream reader to video decode sample and conformance test script. Added the missing destroy bitstream reader call in video decode basic sample. * * rocDecode/Bitstream reader: Minor format change. No functional changes. * * rocDecode/Bitstream reader: Added handling of unsupported stream file type by the bitstream reader to decode sample apps. * * rocDecode/Bitstream reader: Fixed build errors of several samples. * * rocDecode/Bitstream reader: Added changes based on review comments. * * rocDecode/Bitstream reader: File name changes based on review comments. * * rocDecode/Bitstream reader: Moved MD5 code into single header file. Added changes based on review comments. * * rocDecode/Bitstream reader: Removed redundant path. * * rocDecode/Bitstream reader: Changed rocDecode version to 0.10.0. Added minor changes based on review comments. --------- Co-authored-by: Kiriti Gowda <kiritigowda@gmail.com>
101 строка
3.9 KiB
C++
101 строка
3.9 KiB
C++
/*
|
|
Copyright (c) 2023 - 2024 Advanced Micro Devices, Inc. All rights reserved.
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
in the Software without restriction, including without limitation the rights
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
all copies or substantial portions of the Software.
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
THE SOFTWARE.
|
|
*/
|
|
|
|
#include "../commons.h"
|
|
#include "bs_reader_handle.h"
|
|
|
|
rocDecStatus ROCDECAPI rocDecCreateBitstreamReader(RocdecBitstreamReader *bs_reader_handle, const char *input_file_path) {
|
|
if (bs_reader_handle == nullptr || input_file_path == nullptr) {
|
|
return ROCDEC_INVALID_PARAMETER;
|
|
}
|
|
RocdecBitstreamReader handle = nullptr;
|
|
try {
|
|
handle = new RocBitstreamReaderHandle(input_file_path);
|
|
}
|
|
catch (const std::exception& e) {
|
|
ERR( STR("Failed to create RocBitstreamReader handle, ") + STR(e.what()))
|
|
return ROCDEC_RUNTIME_ERROR;
|
|
}
|
|
*bs_reader_handle = handle;
|
|
return ROCDEC_SUCCESS;
|
|
}
|
|
|
|
rocDecStatus ROCDECAPI rocDecGetBitstreamCodecType(RocdecBitstreamReader bs_reader_handle, rocDecVideoCodec *codec_type) {
|
|
if (bs_reader_handle == nullptr || codec_type == nullptr) {
|
|
return ROCDEC_INVALID_PARAMETER;
|
|
}
|
|
auto roc_bs_reader_handle = static_cast<RocBitstreamReaderHandle*>(bs_reader_handle);
|
|
rocDecStatus ret;
|
|
try {
|
|
ret = roc_bs_reader_handle->GetBitstreamCodecType(codec_type);
|
|
}
|
|
catch (const std::exception& e) {
|
|
roc_bs_reader_handle->CaptureError(e.what());
|
|
ERR(e.what())
|
|
return ROCDEC_RUNTIME_ERROR;
|
|
}
|
|
return ret;
|
|
}
|
|
|
|
rocDecStatus ROCDECAPI rocDecGetBitstreamBitDepth(RocdecBitstreamReader bs_reader_handle, int *bit_depth) {
|
|
if (bs_reader_handle == nullptr || bit_depth == nullptr) {
|
|
return ROCDEC_INVALID_PARAMETER;
|
|
}
|
|
auto roc_bs_reader_handle = static_cast<RocBitstreamReaderHandle*>(bs_reader_handle);
|
|
rocDecStatus ret;
|
|
try {
|
|
ret = roc_bs_reader_handle->GetBitstreamBitDepth(bit_depth);
|
|
}
|
|
catch (const std::exception& e) {
|
|
roc_bs_reader_handle->CaptureError(e.what());
|
|
ERR(e.what())
|
|
return ROCDEC_RUNTIME_ERROR;
|
|
}
|
|
return ret;
|
|
}
|
|
|
|
rocDecStatus ROCDECAPI rocDecGetBitstreamPicData(RocdecBitstreamReader bs_reader_handle, uint8_t **pic_data, int *pic_size, int64_t *pts) {
|
|
if (bs_reader_handle == nullptr || pic_data == nullptr || pic_size == nullptr || pts == nullptr) {
|
|
return ROCDEC_INVALID_PARAMETER;
|
|
}
|
|
auto roc_bs_reader_handle = static_cast<RocBitstreamReaderHandle*>(bs_reader_handle);
|
|
rocDecStatus ret;
|
|
try {
|
|
ret = roc_bs_reader_handle->GetBitstreamPicData(pic_data, pic_size, pts);
|
|
}
|
|
catch (const std::exception& e) {
|
|
roc_bs_reader_handle->CaptureError(e.what());
|
|
ERR(e.what())
|
|
return ROCDEC_RUNTIME_ERROR;
|
|
}
|
|
return ret;
|
|
}
|
|
|
|
rocDecStatus ROCDECAPI rocDecDestroyBitstreamReader(RocdecBitstreamReader bs_reader_handle) {
|
|
if (bs_reader_handle == nullptr) {
|
|
return ROCDEC_INVALID_PARAMETER;
|
|
}
|
|
auto roc_bs_reader_handle = static_cast<RocBitstreamReaderHandle*>(bs_reader_handle);
|
|
delete roc_bs_reader_handle;
|
|
return ROCDEC_SUCCESS;
|
|
}
|