1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
|
/*
* Copyright (c) 2016-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 mos_os_virtualengine_singlepipe.cpp
//! \brief Implements the MOS interface extension for Cross OS, supporting virtual engine single pipe mode.
//! \details Implements the MOS interface extension for Cross OS, supporting virtual engine single pipe mode. Only necessary when KMD supports virtual engine.
//!
#include "mos_util_debug.h"
#include "mos_os_virtualengine.h"
//==<Functions>=======================================================
void Mos_VirtualEngine_SinglePipe_Destroy(
PMOS_VIRTUALENGINE_INTERFACE pVEInterface)
{
MOS_OS_FUNCTION_ENTER;
return;
}
#if (_DEBUG || _RELEASE_INTERNAL)
MOS_STATUS Mos_VirtualEngine_SinglePipe_PopulateDbgOvrdParams(
PMOS_VIRTUALENGINE_INTERFACE pVEInterface)
{
PMOS_INTERFACE pOsInterface = nullptr;
int32_t iForceEngine = 0;
MOS_STATUS eStatus = MOS_STATUS_UNKNOWN;
MOS_OS_FUNCTION_ENTER;
MOS_OS_CHK_NULL(pVEInterface);
MOS_OS_CHK_NULL(pVEInterface->pOsInterface);
pOsInterface = pVEInterface->pOsInterface;
iForceEngine = MOS_INVALID_FORCEENGINE_VALUE;
switch (pOsInterface->Component)
{
case COMPONENT_Decode:
iForceEngine = pOsInterface->eForceVdbox;
break;
case COMPONENT_VPCommon:
iForceEngine = pOsInterface->eForceVebox;
break;
case COMPONENT_Encode:
default:
eStatus = MOS_STATUS_INVALID_PARAMETER;
MOS_OS_ASSERTMESSAGE("Not supported MOS Component.")
goto finish;
}
MOS_ZeroMemory(pVEInterface->EngineLogicId, sizeof(pVEInterface->EngineLogicId));
pVEInterface->ucEngineCount = 0;
if (iForceEngine == 0)
{
pVEInterface->EngineLogicId[0] = 0;
}
else
{
uint8_t ui8EngineId = 0;
switch (iForceEngine & MOS_FORCEENGINE_MASK)
{
case 1:
ui8EngineId = 0;
break;
case 2:
ui8EngineId = 1;
break;
case 3:
ui8EngineId = 2;
break;
case 4:
ui8EngineId = 3;
break;
default:
eStatus = MOS_STATUS_INVALID_PARAMETER;
MOS_OS_ASSERTMESSAGE("Invalid force engine value.");
goto finish;
}
pVEInterface->EngineLogicId[0] = ui8EngineId;
}
pVEInterface->ucEngineCount = 1;
eStatus = MOS_STATUS_SUCCESS;
finish:
return eStatus;
}
#endif //(_DEBUG || _RELEASE_INTERNAL)
|