| /* |
| * Copyright (c) 2019-2020, Intel Corporation |
| * |
| * 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. |
| */ |
| //! |
| //! \file decode_av1_pipeline_g12.cpp |
| //! \brief Defines the interface for av1 decode pipeline |
| //! |
| #include "decode_av1_pipeline_g12.h" |
| #include "decode_av1_packet_g12.h" |
| #include "decode_av1_picture_packet_g12.h" |
| #include "decode_av1_tile_packet_g12.h" |
| #include "decode_utils.h" |
| #include "codechal_debug.h" |
| #include "decode_av1_tile_coding.h" |
| #include "decode_av1_feature_manager_g12.h" |
| #include "decode_mem_compression_g12.h" |
| #include "decode_av1_feature_defs_g12.h" |
| |
| namespace decode |
| { |
| Av1PipelineG12::Av1PipelineG12( |
| CodechalHwInterface * hwInterface, |
| CodechalDebugInterface *debugInterface) |
| : Av1Pipeline(hwInterface, debugInterface) |
| { |
| |
| } |
| |
| MOS_STATUS Av1PipelineG12::Init(void *settings) |
| { |
| DECODE_FUNC_CALL(); |
| |
| DECODE_CHK_NULL(settings); |
| DECODE_CHK_STATUS(Initialize(settings)); |
| |
| if (MEDIA_IS_SKU(m_skuTable, FtrWithSlimVdbox)) |
| { |
| m_numVdbox = 1; |
| } |
| |
| m_av1DecodePkt = MOS_New(Av1DecodePktG12, this, m_task, m_hwInterface); |
| DECODE_CHK_STATUS(RegisterPacket(DecodePacketId(this, av1DecodePacketId), m_av1DecodePkt)); |
| DECODE_CHK_STATUS(m_av1DecodePkt->Init()); |
| |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| MOS_STATUS Av1PipelineG12::InitContext() |
| { |
| DECODE_FUNC_CALL(); |
| |
| auto basicFeature = dynamic_cast<Av1BasicFeature*>(m_featureManager->GetFeature(FeatureIDs::basicFeature)); |
| DECODE_CHK_NULL(basicFeature); |
| |
| DecodeScalabilityPars scalPars; |
| MOS_ZeroMemory(&scalPars, sizeof(ScalabilityPars)); |
| scalPars.disableScalability = true; |
| scalPars.enableVE = MOS_VE_SUPPORTED(m_osInterface); |
| if (MEDIA_IS_SKU(m_skuTable, FtrWithSlimVdbox)) |
| { |
| scalPars.usingSlimVdbox = true; |
| } |
| else |
| { |
| scalPars.usingSlimVdbox = false; |
| } |
| scalPars.numVdbox = m_numVdbox; |
| |
| m_mediaContext->SwitchContext(VdboxDecodeFunc, &scalPars, &m_scalability); |
| DECODE_CHK_NULL(m_scalability); |
| |
| m_decodeContext = m_osInterface->pfnGetGpuContext(m_osInterface); |
| |
| m_passNum = basicFeature->m_tileCoding.CalcNumPass(*basicFeature->m_av1PicParams, basicFeature->m_av1TileParams); |
| m_scalability->SetPassNumber(m_passNum); |
| |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| MOS_STATUS Av1PipelineG12::Prepare(void *params) |
| { |
| DECODE_FUNC_CALL(); |
| |
| DECODE_CHK_NULL(params); |
| DecodePipelineParams *pipelineParams = (DecodePipelineParams *)params; |
| m_pipeMode = pipelineParams->m_pipeMode; |
| |
| PERF_UTILITY_AUTO((__FUNCTION__ + std::to_string((int)m_pipeMode)).c_str(), PERF_DECODE, PERF_LEVEL_HAL); |
| |
| auto basicFeature = dynamic_cast<Av1BasicFeature*>(m_featureManager->GetFeature(FeatureIDs::basicFeature)); |
| DECODE_CHK_NULL(basicFeature); |
| |
| if (IsFirstProcessPipe(*pipelineParams)) |
| { |
| DECODE_CHK_STATUS(Av1Pipeline::Prepare(params)); |
| } |
| |
| DECODE_CHK_STATUS(m_preSubPipeline->Prepare(*pipelineParams)); |
| DECODE_CHK_STATUS(m_postSubPipeline->Prepare(*pipelineParams)); |
| |
| if (m_pipeMode == decodePipeModeProcess) |
| { |
| if (IsCompleteBitstream()) |
| { |
| CODECHAL_DEBUG_TOOL(DECODE_CHK_STATUS(DumpParams(*basicFeature))); |
| |
| DecodeStatusParameters inputParameters = {}; |
| MOS_ZeroMemory(&inputParameters, sizeof(DecodeStatusParameters)); |
| inputParameters.statusReportFeedbackNumber = basicFeature->m_av1PicParams->m_statusReportFeedbackNumber; |
| inputParameters.codecFunction = basicFeature->m_codecFunction; |
| inputParameters.picWidthInMb = basicFeature->m_picWidthInMb; |
| inputParameters.pictureCodingType = basicFeature->m_pictureCodingType; |
| inputParameters.currOriginalPic = basicFeature->m_curRenderPic; |
| inputParameters.currDecodedPicRes = basicFeature->m_destSurface.OsResource; |
| inputParameters.numUsedVdbox = m_numVdbox; |
| m_allocator->UpdateResoreceUsageType(&inputParameters.currDecodedPicRes, resourceOutputPicture); |
| m_statusReport->Init(&inputParameters); |
| } |
| } |
| |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| MOS_STATUS Av1PipelineG12::Execute() |
| { |
| DECODE_FUNC_CALL(); |
| |
| PERF_UTILITY_AUTO((__FUNCTION__ + std::to_string((int)m_pipeMode)).c_str(), PERF_DECODE, PERF_LEVEL_HAL); |
| |
| if (m_pipeMode == decodePipeModeBegin) |
| { |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| auto basicFeature = dynamic_cast<Av1BasicFeature *>(m_featureManager->GetFeature(FeatureIDs::basicFeature)); |
| DECODE_CHK_NULL(basicFeature); |
| if (basicFeature->m_av1PicParams->m_anchorFrameInsertion) |
| { |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| if (m_pipeMode == decodePipeModeProcess) |
| { |
| DECODE_CHK_STATUS(m_preSubPipeline->Execute()); |
| |
| if (IsCompleteBitstream()) |
| { |
| DECODE_CHK_STATUS(InitContext()); |
| DECODE_CHK_STATUS(ActivateDecodePackets()); |
| DECODE_CHK_STATUS(ExecuteActivePackets()); |
| } |
| |
| DECODE_CHK_STATUS(m_postSubPipeline->Execute()); |
| } |
| else if (m_pipeMode == decodePipeModeEnd) |
| { |
| auto feature = dynamic_cast<DecodeBasicFeature*>(m_featureManager->GetFeature(FeatureIDs::basicFeature)); |
| DECODE_CHK_NULL(feature); |
| CODECHAL_DEBUG_TOOL( |
| m_debugInterface->m_bufferDumpFrameNum = feature->m_frameNum; |
| DECODE_CHK_STATUS(m_debugInterface->DumpYUVSurface( |
| &feature->m_destSurface, |
| CodechalDbgAttr::attrDecodeOutputSurface, |
| "DstSurf"));) |
| |
| auto filmGrainFeature = dynamic_cast<Av1DecodeFilmGrainG12*>(m_featureManager->GetFeature( |
| Av1FeatureIDs::av1SwFilmGrain)); |
| if (filmGrainFeature != nullptr && filmGrainFeature->m_filmGrainEnabled) |
| { |
| auto av1Feature = dynamic_cast<Av1BasicFeature*>(feature); |
| CODECHAL_DEBUG_TOOL( |
| m_debugInterface->m_bufferDumpFrameNum = feature->m_frameNum; |
| DECODE_CHK_STATUS(m_debugInterface->DumpYUVSurface( |
| &av1Feature->m_fgOutputSurf, |
| CodechalDbgAttr::attrFilmGrain, |
| "FilmGrain"));) |
| } |
| |
| // Only update user features for the first frame. |
| if (feature->m_frameNum == 0) |
| { |
| DECODE_CHK_STATUS(UserFeatureReport()); |
| } |
| feature->m_frameNum++; |
| |
| DECODE_CHK_STATUS(m_statusReport->Reset()); |
| } |
| |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| MOS_STATUS Av1PipelineG12::GetStatusReport(void *status, uint16_t numStatus) |
| { |
| DECODE_FUNC_CALL(); |
| |
| m_statusReport->GetReport(numStatus, status); |
| |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| uint32_t Av1PipelineG12::GetCompletedReport() |
| { |
| DECODE_FUNC_CALL(); |
| |
| uint32_t completedCount = m_statusReport->GetCompletedCount(); |
| uint32_t reportedCount = m_statusReport->GetReportedCount(); |
| |
| if (reportedCount > completedCount) |
| { |
| DECODE_ASSERTMESSAGE("No report available at all"); |
| return 0; |
| } |
| else |
| { |
| uint32_t availableCount = completedCount - reportedCount; |
| return availableCount; |
| } |
| } |
| |
| MOS_STATUS Av1PipelineG12::Destroy() |
| { |
| DECODE_FUNC_CALL(); |
| |
| Uninitialize(); |
| |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| MOS_STATUS Av1PipelineG12::Initialize(void *settings) |
| { |
| DECODE_FUNC_CALL(); |
| |
| DECODE_CHK_STATUS(Av1Pipeline::Initialize(settings)); |
| DECODE_CHK_STATUS(InitMmcState()); |
| |
| //pre subpipeline for generate noise |
| auto *codecSettings = (CodechalSetting *)settings; |
| m_fgGenNoiseSubPipeline = MOS_New(FilmGrainPreSubPipeline, this, m_task, m_numVdbox); |
| DECODE_CHK_NULL(m_fgGenNoiseSubPipeline); |
| DECODE_CHK_STATUS(m_preSubPipeline->Register(*m_fgGenNoiseSubPipeline)); |
| DECODE_CHK_STATUS(m_fgGenNoiseSubPipeline->Init(*codecSettings)); |
| |
| //post subpipeline for apply noise |
| m_fgAppNoiseSubPipeline = MOS_New(FilmGrainPostSubPipeline, this, m_task, m_numVdbox); |
| DECODE_CHK_NULL(m_fgAppNoiseSubPipeline); |
| DECODE_CHK_STATUS(m_postSubPipeline->Register(*m_fgAppNoiseSubPipeline)); |
| DECODE_CHK_STATUS(m_fgAppNoiseSubPipeline->Init(*codecSettings)); |
| |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| MOS_STATUS Av1PipelineG12::Uninitialize() |
| { |
| DECODE_FUNC_CALL(); |
| |
| for (auto pair : m_packetList) |
| { |
| pair.second->Destroy(); |
| } |
| |
| if (m_mmcState != nullptr) |
| { |
| MOS_Delete(m_mmcState); |
| } |
| |
| return Av1Pipeline::Uninitialize(); |
| } |
| |
| MOS_STATUS Av1PipelineG12::UserFeatureReport() |
| { |
| DECODE_FUNC_CALL(); |
| |
| return Av1Pipeline::UserFeatureReport(); |
| } |
| |
| MOS_STATUS Av1PipelineG12::CreateSubPackets(DecodeSubPacketManager &subPacketManager, CodechalSetting &codecSettings) |
| { |
| DECODE_CHK_STATUS(DecodePipeline::CreateSubPackets(subPacketManager, codecSettings)); |
| |
| Av1DecodePicPktG12 *pictureDecodePkt = MOS_New(Av1DecodePicPktG12, this, m_hwInterface); |
| DECODE_CHK_NULL(pictureDecodePkt); |
| DECODE_CHK_STATUS(subPacketManager.Register( |
| DecodePacketId(this, av1PictureSubPacketId), *pictureDecodePkt)); |
| |
| Av1DecodeTilePktG12 *tileDecodePkt = MOS_New(Av1DecodeTilePktG12, this, m_hwInterface); |
| DECODE_CHK_NULL(tileDecodePkt); |
| DECODE_CHK_STATUS(subPacketManager.Register( |
| DecodePacketId(this, av1TileSubPacketId), *tileDecodePkt)); |
| |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| MOS_STATUS Av1PipelineG12::InitMmcState() |
| { |
| #ifdef _MMC_SUPPORTED |
| DECODE_CHK_NULL(m_hwInterface); |
| m_mmcState = MOS_New(DecodeMemCompG12, m_hwInterface); |
| DECODE_CHK_NULL(m_mmcState); |
| |
| Av1BasicFeature *basicFeature = dynamic_cast<Av1BasicFeature*>(m_featureManager->GetFeature(FeatureIDs::basicFeature)); |
| DECODE_CHK_NULL(basicFeature); |
| DECODE_CHK_STATUS(basicFeature->SetMmcState(m_mmcState->IsMmcEnabled())); |
| #endif |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| #if USE_CODECHAL_DEBUG_TOOL |
| MOS_STATUS Av1PipelineG12::DumpParams(Av1BasicFeature &basicFeature) |
| { |
| m_debugInterface->m_frameType = basicFeature.m_av1PicParams->m_picInfoFlags.m_fields.m_frameType ? P_TYPE : I_TYPE; |
| m_debugInterface->m_bufferDumpFrameNum = basicFeature.m_frameNum; |
| |
| DECODE_CHK_STATUS(DumpPicParams( |
| basicFeature.m_av1PicParams)); |
| |
| DECODE_CHK_STATUS(DumpBitstreamControlParams( |
| basicFeature.m_av1TileParams)); |
| |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| MOS_STATUS Av1PipelineG12::DumpBitstreamControlParams(CodecAv1TileParams *tileParams) |
| { |
| CODECHAL_DEBUG_FUNCTION_ENTER; |
| |
| if (!m_debugInterface->DumpIsEnabled(CodechalDbgAttr::attrSlcParams)) |
| { |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| CODECHAL_DEBUG_CHK_NULL(tileParams); |
| |
| std::ostringstream oss; |
| oss.setf(std::ios::showbase | std::ios::uppercase); |
| |
| oss << "BSTileDataLocation: " << +tileParams->m_bsTileDataLocation << std::endl; |
| oss << "BSTileBytesInBuffer: " << +tileParams->m_bsTileBytesInBuffer << std::endl; |
| oss << "wBadBSBufferChopping: " << +tileParams->m_badBSBufferChopping << std::endl; |
| oss << "tile_row: " << +tileParams->m_tileRow << std::endl; |
| oss << "tile_column: " << +tileParams->m_tileColumn << std::endl; |
| oss << "tile_index: " << +tileParams->m_tileIndex << std::endl; |
| oss << "StartTileIdx: " << +tileParams->m_startTileIdx << std::endl; |
| oss << "EndTileIdx: " << +tileParams->m_endTileIdx << std::endl; |
| oss << "anchor_frame_idx: " << +tileParams->m_anchorFrameIdx.FrameIdx << std::endl; |
| oss << "BSTilePayloadSizeInBytes: " << +tileParams->m_bsTilePayloadSizeInBytes << std::endl; |
| |
| const char *fileName = m_debugInterface->CreateFileName( |
| "DEC", |
| "BitstreamControlParams", |
| CodechalDbgExtType::txt); |
| |
| std::ofstream ofs; |
| ofs.open(fileName, std::ios::out); |
| ofs << oss.str(); |
| ofs.close(); |
| |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| MOS_STATUS Av1PipelineG12::DumpPicParams(CodecAv1PicParams *picParams) |
| { |
| CODECHAL_DEBUG_FUNCTION_ENTER; |
| |
| if (!m_debugInterface->DumpIsEnabled(CodechalDbgAttr::attrPicParams)) |
| { |
| return MOS_STATUS_SUCCESS; |
| } |
| CODECHAL_DEBUG_CHK_NULL(picParams); |
| |
| std::ostringstream oss; |
| oss.setf(std::ios::showbase | std::ios::uppercase); |
| |
| oss << "CurrPic FrameIdx: " << std::hex << +picParams->m_currPic.FrameIdx << std::endl; |
| oss << "CurrDisplayPic FrameIdx: " << std::hex << +picParams->m_currDisplayPic.FrameIdx << std::endl; |
| oss << "Profile: " << std::hex << +picParams->m_profile << std::endl; |
| oss << "AnchorFrameInsertion: " << std::hex << +picParams->m_anchorFrameInsertion << std::endl; |
| oss << "order_hint_bits_minus_1: " << std::hex << +picParams->m_orderHintBitsMinus1 << std::endl; |
| oss << "BitDepthIdx: " << std::hex << +picParams->m_bitDepthIdx << std::endl; |
| |
| //Sequence Info Flags |
| oss << "dwSeqInfoFlags: " << std::hex << +picParams->m_seqInfoFlags.m_value << std::endl; |
| oss << "still_picture: " << std::hex << +picParams->m_seqInfoFlags.m_fields.m_stillPicture << std::endl; |
| oss << "use_128x128_superblock: " << std::hex << +picParams->m_seqInfoFlags.m_fields.m_use128x128Superblock << std::endl; |
| oss << "enable_filter_intra: " << std::hex << +picParams->m_seqInfoFlags.m_fields.m_enableFilterIntra << std::endl; |
| oss << "enable_intra_edge_filter: " << std::hex << +picParams->m_seqInfoFlags.m_fields.m_enableIntraEdgeFilter << std::endl; |
| oss << "enable_interintra_compound: " << std::hex << +picParams->m_seqInfoFlags.m_fields.m_enableInterintraCompound << std::endl; |
| oss << "enable_masked_compound: " << std::hex << +picParams->m_seqInfoFlags.m_fields.m_enableMaskedCompound << std::endl; |
| oss << "enable_dual_filter: " << std::hex << +picParams->m_seqInfoFlags.m_fields.m_enableDualFilter << std::endl; |
| oss << "enable_order_hint: " << std::hex << +picParams->m_seqInfoFlags.m_fields.m_enableOrderHint << std::endl; |
| oss << "enable_jnt_comp: " << std::hex << +picParams->m_seqInfoFlags.m_fields.m_enableJntComp << std::endl; |
| oss << "enable_cdef: " << std::hex << +picParams->m_seqInfoFlags.m_fields.m_enableCdef << std::endl; |
| oss << "mono_chrome: " << std::hex << +picParams->m_seqInfoFlags.m_fields.m_monoChrome << std::endl; |
| oss << "color_range: " << std::hex << +picParams->m_seqInfoFlags.m_fields.m_colorRange << std::endl; |
| oss << "subsampling_x: " << std::hex << +picParams->m_seqInfoFlags.m_fields.m_subsamplingX << std::endl; |
| oss << "subsampling_y: " << std::hex << +picParams->m_seqInfoFlags.m_fields.m_subsamplingY << std::endl; |
| oss << "chroma_sample_position: " << std::hex << +picParams->m_seqInfoFlags.m_fields.m_chromaSamplePosition << std::endl; |
| oss << "film_grain_params_present: " << std::hex << +picParams->m_seqInfoFlags.m_fields.m_filmGrainParamsPresent << std::endl; |
| |
| //frame info |
| oss << "dwPicInfoFlags: " << std::hex << +picParams->m_picInfoFlags.m_value << std::endl; |
| oss << "frame_type: " << std::hex << +picParams->m_picInfoFlags.m_fields.m_frameType << std::endl; |
| oss << "show_frame: " << std::hex << +picParams->m_picInfoFlags.m_fields.m_showFrame << std::endl; |
| oss << "showable_frame: " << std::hex << +picParams->m_picInfoFlags.m_fields.m_showableFrame << std::endl; |
| oss << "error_resilient_mode: " << std::hex << +picParams->m_picInfoFlags.m_fields.m_errorResilientMode << std::endl; |
| oss << "disable_cdf_update: " << std::hex << +picParams->m_picInfoFlags.m_fields.m_disableCdfUpdate << std::endl; |
| oss << "allow_screen_content_tools: " << std::hex << +picParams->m_picInfoFlags.m_fields.m_allowScreenContentTools << std::endl; |
| oss << "force_integer_mv: " << std::hex << +picParams->m_picInfoFlags.m_fields.m_forceIntegerMv << std::endl; |
| oss << "allow_intrabc: " << std::hex << +picParams->m_picInfoFlags.m_fields.m_allowIntrabc << std::endl; |
| oss << "use_superres: " << std::hex << +picParams->m_picInfoFlags.m_fields.m_useSuperres << std::endl; |
| oss << "allow_high_precision_mv: " << std::hex << +picParams->m_picInfoFlags.m_fields.m_allowHighPrecisionMv << std::endl; |
| oss << "is_motion_mode_switchable: " << std::hex << +picParams->m_picInfoFlags.m_fields.m_isMotionModeSwitchable << std::endl; |
| oss << "use_ref_frame_mvs: " << std::hex << +picParams->m_picInfoFlags.m_fields.m_useRefFrameMvs << std::endl; |
| oss << "disable_frame_end_update_cdf: " << std::hex << +picParams->m_picInfoFlags.m_fields.m_disableFrameEndUpdateCdf << std::endl; |
| oss << "uniform_tile_spacing_flag: " << std::hex << +picParams->m_picInfoFlags.m_fields.m_uniformTileSpacingFlag << std::endl; |
| oss << "allow_warped_motion: " << std::hex << +picParams->m_picInfoFlags.m_fields.m_allowWarpedMotion << std::endl; |
| oss << "large_scale_tile: " << std::hex << +picParams->m_picInfoFlags.m_fields.m_largeScaleTile << std::endl; |
| |
| oss << "frame_width_minus1: " << std::hex << +picParams->m_frameWidthMinus1 << std::endl; |
| oss << "frame_height_minus1: " << std::hex << +picParams->m_frameHeightMinus1 << std::endl; |
| |
| for (auto i = 0; i < 8; ++i) |
| { |
| oss << "ref_frame_map[" << +i << "] FrameIdx:" << std::hex << +picParams->m_refFrameMap[i].FrameIdx << std::endl; |
| oss << "ref_frame_map[" << +i << "] PicFlags:" << std::hex << +picParams->m_refFrameMap[i].PicFlags << std::endl; |
| } |
| |
| for (auto i = 0; i < 7; i++) |
| { |
| oss << "ref_frame_idx[" << +i << "]: " << std::hex << +picParams->m_refFrameIdx[i] << std::endl; |
| } |
| |
| oss << "primary_ref_frame: " << std::hex << +picParams->m_primaryRefFrame << std::endl; |
| oss << "output_frame_width_in_tiles_minus_1: " << std::hex << +picParams->m_outputFrameWidthInTilesMinus1 << std::endl; |
| oss << "output_frame_height_in_tiles_minus_1: " << std::hex << +picParams->m_outputFrameHeightInTilesMinus1 << std::endl; |
| |
| for (auto i = 0; i < 2; i++) |
| { |
| oss << "filter_level[" << +i << "]: " << std::hex << +picParams->m_filterLevel[i] << std::endl; |
| } |
| oss << "filter_level_u: " << std::hex << +picParams->m_filterLevelU << std::endl; |
| oss << "filter_level_v: " << std::hex << +picParams->m_filterLevelV << std::endl; |
| |
| //Loop Filter Info Flags |
| oss << "cLoopFilterInfoFlags value: " << std::hex << +picParams->m_loopFilterInfoFlags.m_value << std::endl; |
| oss << "sharpness_level: " << std::hex << +picParams->m_loopFilterInfoFlags.m_fields.m_sharpnessLevel << std::endl; |
| oss << "mode_ref_delta_enabled: " << std::hex << +picParams->m_loopFilterInfoFlags.m_fields.m_modeRefDeltaEnabled << std::endl; |
| oss << "mode_ref_delta_update: " << std::hex << +picParams->m_loopFilterInfoFlags.m_fields.m_modeRefDeltaUpdate << std::endl; |
| |
| oss << "order_hint: " << std::hex << +picParams->m_orderHint << std::endl; |
| oss << "superres_scale_denominator: " << std::hex << +picParams->m_superresScaleDenominator << std::endl; |
| oss << "interp_filter: " << std::hex << +picParams->m_interpFilter << std::endl; |
| |
| for (auto i = 0; i < 8; i++) |
| { |
| oss << "ref_deltas[" << +i << "]: " << std::hex << +picParams->m_refDeltas[i] << std::endl; |
| } |
| |
| for (auto i = 0; i < 2; i++) |
| { |
| oss << "mode_deltas[" << +i << "]: " << std::hex << +picParams->m_modeDeltas[i] << std::endl; |
| } |
| |
| oss << "base_qindex: " << std::hex << +picParams->m_baseQindex << std::endl; |
| oss << "y_dc_delta_q: " << std::hex << +picParams->m_yDcDeltaQ << std::endl; |
| oss << "u_dc_delta_q: " << std::hex << +picParams->m_uDcDeltaQ << std::endl; |
| oss << "u_ac_delta_q: " << std::hex << +picParams->m_uAcDeltaQ << std::endl; |
| oss << "v_dc_delta_q: " << std::hex << +picParams->m_vDcDeltaQ << std::endl; |
| oss << "v_ac_delta_q: " << std::hex << +picParams->m_vAcDeltaQ << std::endl; |
| |
| // quantization_matrix |
| oss << "wQMatrixFlags value: " << std::hex << +picParams->m_qMatrixFlags.m_value << std::endl; |
| oss << "using_qmatrix: " << std::hex << +picParams->m_qMatrixFlags.m_fields.m_usingQmatrix<< std::endl; |
| oss << "qm_y: " << std::hex << +picParams->m_qMatrixFlags.m_fields.m_qmY << std::endl; |
| oss << "qm_u: " << std::hex << +picParams->m_qMatrixFlags.m_fields.m_qmU << std::endl; |
| oss << "qm_v: " << std::hex << +picParams->m_qMatrixFlags.m_fields.m_qmV << std::endl; |
| |
| // Mode control flags |
| oss << "dwModeControlFlags value: " << std::hex << +picParams->m_modeControlFlags.m_value << std::endl; |
| oss << "delta_q_present_flag: " << std::hex << +picParams->m_modeControlFlags.m_fields.m_deltaQPresentFlag << std::endl; |
| oss << "log2_delta_q_res: " << std::hex << +picParams->m_modeControlFlags.m_fields.m_log2DeltaQRes << std::endl; |
| oss << "delta_lf_present_flag: " << std::hex << +picParams->m_modeControlFlags.m_fields.m_deltaLfPresentFlag << std::endl; |
| oss << "log2_delta_lf_res: " << std::hex << +picParams->m_modeControlFlags.m_fields.m_log2DeltaLfRes << std::endl; |
| oss << "delta_lf_multi: " << std::hex << +picParams->m_modeControlFlags.m_fields.m_deltaLfMulti << std::endl; |
| oss << "tx_mode: " << std::hex << +picParams->m_modeControlFlags.m_fields.m_txMode << std::endl; |
| oss << "reference_mode: " << std::hex << +picParams->m_modeControlFlags.m_fields.m_referenceMode << std::endl; |
| oss << "reduced_tx_set_used: " << std::hex << +picParams->m_modeControlFlags.m_fields.m_reducedTxSetUsed << std::endl; |
| oss << "skip_mode_present: " << std::hex << +picParams->m_modeControlFlags.m_fields.m_skipModePresent << std::endl; |
| |
| // Segmentation |
| oss << "enabled: " << std::hex << +picParams->m_av1SegData.m_enabled << std::endl; |
| oss << "update_map: " << std::hex << +picParams->m_av1SegData.m_updateMap << std::endl; |
| oss << "temporal_update: " << std::hex << +picParams->m_av1SegData.m_temporalUpdate << std::endl; |
| oss << "update_data: " << std::hex << +picParams->m_av1SegData.m_updateData << std::endl; |
| |
| for (auto i = 0; i < 8; i++) |
| { |
| for (auto j = 0; j < 8; j++) |
| { |
| oss << "feature_data[" << +i << "][" << +j << "]: " << std::hex << +picParams->m_av1SegData.m_featureData[i][j] << std::endl; |
| } |
| } |
| for (auto i = 0; i < 8; i++) |
| { |
| oss << "feature_mask[" << +i << "]: " << std::hex << +picParams->m_av1SegData.m_featureMask [i] << std::endl; |
| } |
| |
| oss << "tile_cols: " << std::hex << +picParams->m_tileCols << std::endl; |
| for (auto i = 0; i < 63; i++) |
| { |
| oss << "width_in_sbs_minus_1[" << +i << "]: " << std::hex << +picParams->m_widthInSbsMinus1[i] << std::endl; |
| } |
| oss << "tile_rows: " << std::hex << +picParams->m_tileRows << std::endl; |
| for (auto i = 0; i < 63; i++) |
| { |
| oss << "height_in_sbs_minus_1[" << +i << "]: " << std::hex << +picParams->m_heightInSbsMinus1[i] << std::endl; |
| } |
| |
| |
| oss << "tile_count_minus_1: " << std::hex << +picParams->m_tileCountMinus1 << std::endl; |
| oss << "context_update_tile_id: " << std::hex << +picParams->m_contextUpdateTileId << std::endl; |
| |
| oss << "cdef_damping_minus_3: " << std::hex << +picParams->m_cdefDampingMinus3 << std::endl; |
| oss << "cdef_bits: " << std::hex << +picParams->m_cdefBits << std::endl; |
| for (auto i = 0; i < 8; i++) |
| { |
| oss << "cdef_y_strengths[" << +i << "]: " << std::hex << +picParams->m_cdefYStrengths[i] << std::endl; |
| } |
| for (auto i = 0; i < 8; i++) |
| { |
| oss << "cdef_uv_strengths[" << +i << "]: " << std::hex << +picParams->m_cdefUvStrengths[i] << std::endl; |
| } |
| |
| // Loop Restoration Flags |
| oss << "LoopRestorationFlags value: " << std::hex << +picParams->m_loopRestorationFlags.m_value << std::endl; |
| oss << "yframe_restoration_type: " << std::hex << +picParams->m_loopRestorationFlags.m_fields.m_yframeRestorationType << std::endl; |
| oss << "cbframe_restoration_type: " << std::hex << +picParams->m_loopRestorationFlags.m_fields.m_cbframeRestorationType << std::endl; |
| oss << "crframe_restoration_type: " << std::hex << +picParams->m_loopRestorationFlags.m_fields.m_crframeRestorationType << std::endl; |
| oss << "lr_unit_shift: " << std::hex << +picParams->m_loopRestorationFlags.m_fields.m_lrUnitShift << std::endl; |
| oss << "lr_uv_shift: " << std::hex << +picParams->m_loopRestorationFlags.m_fields.m_lrUvShift << std::endl; |
| |
| for (auto i = 0; i < 7; i++) |
| { |
| oss << "wm[" << +i << "].wmtype: " << std::hex << +picParams->m_wm[i].m_wmtype << std::endl; |
| for (auto j = 0; j < 8; j++) |
| { |
| oss << "wm[" << +i << "].wmmat[" << +j << "]: " << std::hex << +picParams->m_wm[i].m_wmmat[j] << std::endl; |
| } |
| } |
| |
| //Film Grain params |
| oss << "apply_grain: " << std::hex << +picParams->m_filmGrainParams.m_filmGrainInfoFlags.m_fields.m_applyGrain << std::endl; |
| oss << "chroma_scaling_from_luma: " << std::hex << +picParams->m_filmGrainParams.m_filmGrainInfoFlags.m_fields.m_chromaScalingFromLuma << std::endl; |
| oss << "grain_scaling_minus_8: " << std::hex << +picParams->m_filmGrainParams.m_filmGrainInfoFlags.m_fields.m_grainScalingMinus8 << std::endl; |
| oss << "ar_coeff_lag: " << std::hex << +picParams->m_filmGrainParams.m_filmGrainInfoFlags.m_fields.m_arCoeffLag << std::endl; |
| oss << "ar_coeff_shift_minus_6: " << std::hex << +picParams->m_filmGrainParams.m_filmGrainInfoFlags.m_fields.m_arCoeffShiftMinus6 << std::endl; |
| oss << "grain_scale_shift: " << std::hex << +picParams->m_filmGrainParams.m_filmGrainInfoFlags.m_fields.m_grainScaleShift << std::endl; |
| oss << "overlap_flag: " << std::hex << +picParams->m_filmGrainParams.m_filmGrainInfoFlags.m_fields.m_overlapFlag << std::endl; |
| oss << "clip_to_restricted_range: " << std::hex << +picParams->m_filmGrainParams.m_filmGrainInfoFlags.m_fields.m_clipToRestrictedRange << std::endl; |
| |
| oss << "random_seed: " << std::hex << +picParams->m_filmGrainParams.m_randomSeed << std::endl; |
| oss << "num_y_points: " << std::hex << +picParams->m_filmGrainParams.m_numYPoints << std::endl; |
| for (auto i = 0; i < 14; i++) |
| { |
| oss << "point_y_value[" << +i << "]: " << std::hex << +picParams->m_filmGrainParams.m_pointYValue[i] << std::endl; |
| } |
| for (auto i = 0; i < 14; i++) |
| { |
| oss << "point_y_scaling[" << +i << "]: " << std::hex << +picParams->m_filmGrainParams.m_pointYScaling[i] << std::endl; |
| } |
| |
| oss << "num_cb_points: " << std::hex << +picParams->m_filmGrainParams.m_numCbPoints << std::endl; |
| for (auto i = 0; i < 10; i++) |
| { |
| oss << "point_cb_value[" << +i << "]: " << std::hex << +picParams->m_filmGrainParams.m_pointCbValue[i] << std::endl; |
| } |
| for (auto i = 0; i < 10; i++) |
| { |
| oss << "point_cb_scaling[" << +i << "]: " << std::hex << +picParams->m_filmGrainParams.m_pointCbScaling[i] << std::endl; |
| } |
| |
| oss << "num_cr_points: " << std::hex << +picParams->m_filmGrainParams.m_numCrPoints << std::endl; |
| for (auto i = 0; i < 10; i++) |
| { |
| oss << "point_cr_value[" << +i << "]: " << std::hex << +picParams->m_filmGrainParams.m_pointCrValue[i] << std::endl; |
| } |
| for (auto i = 0; i < 10; i++) |
| { |
| oss << "point_cr_scaling[" << +i << "]: " << std::hex << +picParams->m_filmGrainParams.m_pointCrScaling[i] << std::endl; |
| } |
| |
| for (auto i = 0; i < 24; i++) |
| { |
| oss << "ar_coeffs_y[" << +i << "]: " << std::hex << +picParams->m_filmGrainParams.m_arCoeffsY[i] << std::endl; |
| } |
| for (auto i = 0; i < 25; i++) |
| { |
| oss << "ar_coeffs_cb[" << +i << "]: " << std::hex << +picParams->m_filmGrainParams.m_arCoeffsCb[i] << std::endl; |
| } |
| for (auto i = 0; i < 25; i++) |
| { |
| oss << "ar_coeffs_cr[" << +i << "]: " << std::hex << +picParams->m_filmGrainParams.m_arCoeffsCr[i] << std::endl; |
| } |
| |
| oss << "cb_mult: " << std::hex << +picParams->m_filmGrainParams.m_cbMult << std::endl; |
| oss << "cb_luma_mult: " << std::hex << +picParams->m_filmGrainParams.m_cbLumaMult << std::endl; |
| oss << "cb_offset: " << std::hex << +picParams->m_filmGrainParams.m_cbOffset << std::endl; |
| oss << "cr_mult: " << std::hex << +picParams->m_filmGrainParams.m_crMult << std::endl; |
| oss << "cr_luma_mult: " << std::hex << +picParams->m_filmGrainParams.m_crLumaMult << std::endl; |
| oss << "cr_offset: " << std::hex << +picParams->m_filmGrainParams.m_crOffset << std::endl; |
| oss << "StatusReportFeedbackNumber: " << std::hex << +picParams->m_statusReportFeedbackNumber << std::endl; |
| |
| //Driver internal |
| oss << "losslessMode: " << std::hex << +picParams->m_losslessMode << std::endl; |
| oss << "superResUpscaledWidthMinus1: " << std::hex << +picParams->m_superResUpscaledWidthMinus1 << std::endl; |
| oss << "superResUpscaledHeightMinus1: " << std::hex << +picParams->m_superResUpscaledHeightMinus1 << std::endl; |
| for (auto i = 0; i < 8; i++) |
| { |
| oss << "activeRefBitMaskMfmv[" << +i << "]: " << std::hex << +picParams->m_activeRefBitMaskMfmv[i] << std::endl; |
| } |
| |
| const char* fileName = m_debugInterface->CreateFileName( |
| "DEC", |
| CodechalDbgBufferType::bufPicParams, |
| CodechalDbgExtType::txt); |
| |
| std::ofstream ofs(fileName, std::ios::out); |
| ofs << oss.str(); |
| ofs.close(); |
| |
| return MOS_STATUS_SUCCESS; |
| } |
| #endif |
| |
| MOS_STATUS Av1PipelineG12::CreateFeatureManager() |
| { |
| DECODE_FUNC_CALL(); |
| m_featureManager = MOS_New(DecodeAv1FeatureManagerG12, m_allocator, m_hwInterface); |
| DECODE_CHK_NULL(m_featureManager); |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| } |