| /* |
| * Copyright (c) 2018, 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 media_scalability_singlepipe.cpp |
| //! \brief Defines the common interface for media scalability singlepipe mode. |
| //! \details The media scalability singlepipe interface is further sub-divided by component, |
| //! this file is for the base interface which is shared by all components. |
| //! |
| #include <typeinfo> |
| #include <iostream> |
| #include "mos_os_virtualengine_scalability.h" |
| #include "media_scalability_defs.h" |
| #include "media_scalability_singlepipe.h" |
| #include "mhw_mi.h" |
| |
| MediaScalabilitySinglePipe::MediaScalabilitySinglePipe(void *hwInterface, MediaContext *mediaContext, uint8_t componentType) : |
| MediaScalability(mediaContext) |
| { |
| m_componentType = componentType; |
| } |
| |
| MOS_STATUS MediaScalabilitySinglePipe::Initialize(const MediaScalabilityOption &option) |
| { |
| SCALABILITY_CHK_NULL_RETURN(m_osInterface); |
| |
| if (MOS_VE_SUPPORTED(m_osInterface)) |
| { |
| MOS_VIRTUALENGINE_INIT_PARAMS VEInitParams; |
| MOS_ZeroMemory(&VEInitParams, sizeof(VEInitParams)); |
| VEInitParams.bScalabilitySupported = false; |
| |
| if (m_osInterface->apoMosEnabled) |
| { |
| SCALABILITY_CHK_NULL_RETURN(m_osInterface->osStreamState); |
| SCALABILITY_CHK_STATUS_RETURN(MosInterface::CreateVirtualEngineState( |
| m_osInterface->osStreamState, &VEInitParams, m_veState)); |
| SCALABILITY_CHK_NULL_RETURN(m_veState); |
| |
| SCALABILITY_CHK_STATUS_RETURN(MosInterface::GetVeHintParams(m_osInterface->osStreamState, false, &m_veHitParams)); |
| SCALABILITY_CHK_NULL_RETURN(m_veHitParams); |
| } |
| else |
| { |
| SCALABILITY_CHK_STATUS_RETURN(Mos_VirtualEngineInterface_Initialize(m_osInterface, &VEInitParams)); |
| m_veInterface = m_osInterface->pVEInterf; |
| SCALABILITY_CHK_NULL_RETURN(m_veInterface); |
| if (m_veInterface->pfnVEGetHintParams) |
| { |
| SCALABILITY_CHK_STATUS_RETURN(m_veInterface->pfnVEGetHintParams(m_veInterface, false, &m_veHitParams)); |
| SCALABILITY_CHK_NULL_RETURN(m_veHitParams); |
| } |
| } |
| } |
| |
| PMOS_GPUCTX_CREATOPTIONS_ENHANCED gpuCtxCreateOption = MOS_New(MOS_GPUCTX_CREATOPTIONS_ENHANCED); |
| SCALABILITY_CHK_NULL_RETURN(gpuCtxCreateOption); |
| |
| gpuCtxCreateOption->RAMode = option.GetRAMode(); |
| gpuCtxCreateOption->LRCACount = 1; |
| // This setting is only for encode, please override it in decode/vpp |
| gpuCtxCreateOption->UsingSFC = false; |
| #if (_DEBUG || _RELEASE_INTERNAL) |
| if (m_osInterface->bEnableDbgOvrdInVE) |
| { |
| gpuCtxCreateOption->DebugOverride = true; |
| if (m_osInterface->apoMosEnabled) |
| { |
| SCALABILITY_ASSERT(MosInterface::GetVeEngineCount(m_osInterface->osStreamState) == 1); |
| gpuCtxCreateOption->EngineInstance[0] = MosInterface::GetEngineLogicId(m_osInterface->osStreamState, 0); |
| } |
| else |
| { |
| SCALABILITY_ASSERT(m_veInterface->ucEngineCount == 1); |
| gpuCtxCreateOption->EngineInstance[0] = m_veInterface->EngineLogicId[0]; |
| } |
| } |
| #endif |
| m_gpuCtxCreateOption = (PMOS_GPUCTX_CREATOPTIONS)gpuCtxCreateOption; |
| |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| MOS_STATUS MediaScalabilitySinglePipe::Destroy() |
| { |
| SCALABILITY_FUNCTION_ENTER; |
| |
| SCALABILITY_CHK_STATUS_RETURN(MediaScalability::Destroy()); |
| |
| if (m_gpuCtxCreateOption != nullptr) |
| { |
| MOS_Delete(m_gpuCtxCreateOption); |
| } |
| |
| if (m_scalabilityOption != nullptr) |
| { |
| MOS_Delete(m_scalabilityOption); |
| } |
| |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| MOS_STATUS MediaScalabilitySinglePipe::GetGpuCtxCreationOption(MOS_GPUCTX_CREATOPTIONS *gpuCtxCreateOption) |
| { |
| SCALABILITY_FUNCTION_ENTER; |
| SCALABILITY_CHK_NULL_RETURN(gpuCtxCreateOption); |
| SCALABILITY_CHK_NULL_RETURN(m_gpuCtxCreateOption); |
| |
| size_t size = sizeof(MOS_GPUCTX_CREATOPTIONS); |
| |
| if (typeid(*gpuCtxCreateOption) == typeid(MOS_GPUCTX_CREATOPTIONS_ENHANCED)) |
| { |
| size = sizeof(MOS_GPUCTX_CREATOPTIONS_ENHANCED); |
| } |
| |
| SCALABILITY_CHK_STATUS_MESSAGE_RETURN(MOS_SecureMemcpy( |
| (void *)gpuCtxCreateOption, |
| size, |
| (void *)m_gpuCtxCreateOption, |
| size), |
| "Failed to copy gpu ctx create option"); |
| |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| MOS_STATUS MediaScalabilitySinglePipe::VerifyCmdBuffer(uint32_t requestedSize, uint32_t requestedPatchListSize, bool &singleTaskPhaseSupportedInPak) |
| { |
| // legacy mode & resize CommandBuffer Size for every BRC pass |
| return VerifySpaceAvailable(requestedSize, requestedPatchListSize, singleTaskPhaseSupportedInPak); |
| } |
| |
| MOS_STATUS MediaScalabilitySinglePipe::GetCmdBuffer(PMOS_COMMAND_BUFFER cmdBuffer, bool frameTrackingRequested) |
| { |
| SCALABILITY_CHK_NULL_RETURN(m_osInterface); |
| SCALABILITY_CHK_NULL_RETURN(cmdBuffer); |
| SCALABILITY_CHK_STATUS_RETURN(m_osInterface->pfnGetCommandBuffer(m_osInterface, cmdBuffer, 0)); |
| |
| if (!m_attrReady) |
| { |
| SCALABILITY_CHK_STATUS_RETURN(SendAttrWithFrameTracking(*cmdBuffer, frameTrackingRequested)); |
| m_attrReady = true; |
| } |
| |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| MOS_STATUS MediaScalabilitySinglePipe::ReturnCmdBuffer(PMOS_COMMAND_BUFFER cmdBuffer) |
| { |
| SCALABILITY_CHK_NULL_RETURN(m_osInterface); |
| SCALABILITY_CHK_NULL_RETURN(cmdBuffer); |
| |
| m_osInterface->pfnReturnCommandBuffer(m_osInterface, cmdBuffer, 0); |
| |
| return MOS_STATUS_SUCCESS; |
| } |
| |
| MOS_STATUS MediaScalabilitySinglePipe::SetHintParams() |
| { |
| SCALABILITY_FUNCTION_ENTER; |
| |
| SCALABILITY_CHK_NULL_RETURN(m_osInterface); |
| if (m_osInterface->apoMosEnabled) |
| { |
| SCALABILITY_CHK_NULL_RETURN(m_osInterface->osStreamState); |
| } |
| else |
| { |
| SCALABILITY_CHK_NULL_RETURN(m_veInterface); |
| } |
| |
| MOS_STATUS eStatus = MOS_STATUS_SUCCESS; |
| MOS_VIRTUALENGINE_SET_PARAMS veParams; |
| MOS_ZeroMemory(&veParams, sizeof(veParams)); |
| |
| veParams.ucScalablePipeNum = 1; |
| veParams.bScalableMode = false; |
| |
| if (!MOS_VE_CTXBASEDSCHEDULING_SUPPORTED(m_osInterface)) |
| { |
| //not used by VE2.0 |
| veParams.bNeedSyncWithPrevious = true; |
| veParams.bSameEngineAsLastSubmission = false; |
| veParams.bSFCInUse = false; |
| } |
| |
| if (m_osInterface->apoMosEnabled) |
| { |
| SCALABILITY_CHK_STATUS_RETURN(MosInterface::SetVeHintParams(m_osInterface->osStreamState, &veParams)); |
| } |
| else |
| { |
| if (m_veInterface && m_veInterface->pfnVESetHintParams) |
| { |
| SCALABILITY_CHK_STATUS_RETURN(m_veInterface->pfnVESetHintParams(m_veInterface, &veParams)); |
| } |
| } |
| return eStatus; |
| } |
| |
| MOS_STATUS MediaScalabilitySinglePipe::PopulateHintParams(PMOS_COMMAND_BUFFER cmdBuffer) |
| { |
| SCALABILITY_FUNCTION_ENTER; |
| SCALABILITY_CHK_NULL_RETURN(cmdBuffer); |
| SCALABILITY_CHK_NULL_RETURN(m_veHitParams); |
| |
| MOS_STATUS eStatus = MOS_STATUS_SUCCESS; |
| PMOS_CMD_BUF_ATTRI_VE attriVe = MosInterface::GetAttributeVeBuffer(cmdBuffer); |
| if (attriVe) |
| { |
| attriVe->VEngineHintParams = *(m_veHitParams); |
| attriVe->bUseVirtualEngineHint = true; |
| } |
| return eStatus; |
| } |
| |
| MOS_STATUS MediaScalabilitySinglePipe::SubmitCmdBuffer(PMOS_COMMAND_BUFFER cmdBuffer) |
| { |
| SCALABILITY_FUNCTION_ENTER; |
| SCALABILITY_CHK_NULL_RETURN(m_osInterface); |
| SCALABILITY_CHK_NULL_RETURN(cmdBuffer); |
| |
| SCALABILITY_CHK_STATUS_RETURN(GetCmdBuffer(cmdBuffer)); |
| SCALABILITY_CHK_STATUS_RETURN(m_miInterface->AddMiBatchBufferEnd(cmdBuffer, nullptr)); |
| SCALABILITY_CHK_STATUS_RETURN(ReturnCmdBuffer(cmdBuffer)); |
| |
| if (MOS_VE_SUPPORTED(m_osInterface)) |
| { |
| SCALABILITY_CHK_STATUS_RETURN(SetHintParams()); |
| if(cmdBuffer && m_veHitParams) |
| { |
| SCALABILITY_CHK_STATUS_RETURN(PopulateHintParams(cmdBuffer)); |
| } |
| } |
| |
| m_attrReady = false; |
| return m_osInterface->pfnSubmitCommandBuffer(m_osInterface, cmdBuffer, false); |
| } |
| |