blob: 5ddd2c3d8fde848e7587d481c98a0f22dca20f21 [file] [log] [blame]
/*
* Copyright (c) 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 mos_os_mock_adaptor_specific.cpp
//! \brief Common interface and structure used in mock adaptor.
//!
#include "mos_os.h"
#include "mos_os_specific.h"
#include "media_skuwa_specific.h"
#include "skuwa_factory.h"
#include "hwinfo_linux.h"
#include "mos_os_mock_adaptor_specific.h"
typedef DeviceInfoFactory<struct GfxDeviceInfo> DeviceInfoFact;
typedef DeviceInfoFactory<struct LinuxDeviceInit> DeviceInitFact;
MosMockAdaptorSpecific::MosMockAdaptorSpecific()
{
}
MosMockAdaptorSpecific::~MosMockAdaptorSpecific()
{
}
GfxDeviceInfo *MosMockAdaptorSpecific::GetDeviceInfo(uint32_t devId)
{
GfxDeviceInfo *devInfo = DeviceInfoFact::LookupDevice(devId);
return devInfo;
}
LinuxDeviceInit *MosMockAdaptorSpecific::GetDeviceInit(uint32_t platKey)
{
LinuxDeviceInit *devInfo = DeviceInitFact::LookupDevice(platKey);
return devInfo;
}
MOS_STATUS MosMockAdaptorSpecific::InitializeSkuWaTable(PMOS_CONTEXT context)
{
MOS_OS_CHK_NULL_RETURN(context);
MOS_OS_CHK_NULL_RETURN(m_pPlatform);
LinuxDriverInfo drvInfo = {18, 3, 0, 23172, 3, 1, 0, 1, 0, 0, 1, 0};
if (HWInfoGetLinuxDrvInfo(context->fd, &drvInfo) != MOS_STATUS_SUCCESS)
{
return MOS_STATUS_INVALID_HANDLE;
}
drvInfo.devId = m_pPlatform->usDeviceID;
drvInfo.devRev = m_pPlatform->usRevId;
GfxDeviceInfo *devInfo = GetDeviceInfo(drvInfo.devId);
if (devInfo == nullptr)
{
MOS_OS_ASSERTMESSAGE("Failed to get the device info for Device id: %x\n", drvInfo.devId);
return MOS_STATUS_PLATFORM_NOT_SUPPORTED;
}
/* Initialize Platform Info */
m_pGtSystemInfo->SliceCount = devInfo->SliceCount;
m_pGtSystemInfo->SubSliceCount = devInfo->SubSliceCount;
m_pGtSystemInfo->EUCount = devInfo->EUCount;
if (devInfo->InitMediaSysInfo &&
devInfo->InitMediaSysInfo(devInfo, m_pGtSystemInfo))
{
MOS_OS_NORMALMESSAGE("Init Media SystemInfo\n");
}
else
{
MOS_OS_ASSERTMESSAGE("Failed to Init Gt System Info\n");
return MOS_STATUS_PLATFORM_NOT_SUPPORTED;
}
unsigned int maxNengine = 0;
if((m_pGtSystemInfo->VDBoxInfo.NumberOfVDBoxEnabled == 0)
|| (m_pGtSystemInfo->VEBoxInfo.NumberOfVEBoxEnabled == 0))
{
if (mos_query_engines_count(context->bufmgr, &maxNengine))
{
MOS_OS_ASSERTMESSAGE("Failed to query engines count.\n");
return MOS_STATUS_PLATFORM_NOT_SUPPORTED;
}
}
if (m_pGtSystemInfo->VDBoxInfo.NumberOfVDBoxEnabled == 0)
{
unsigned int nengine = maxNengine;
struct i915_engine_class_instance *uengines = nullptr;
uengines = (struct i915_engine_class_instance *)MOS_AllocAndZeroMemory(nengine * sizeof(struct i915_engine_class_instance));
MOS_OS_CHK_NULL_RETURN(uengines);
if (mos_query_engines(context->bufmgr, I915_ENGINE_CLASS_VIDEO, 0, &nengine,uengines) == 0)
{
m_pGtSystemInfo->VDBoxInfo.NumberOfVDBoxEnabled = nengine;
}
else
{
MOS_OS_ASSERTMESSAGE("Failed to query vdbox engine\n");
MOS_SafeFreeMemory(uengines);
return MOS_STATUS_PLATFORM_NOT_SUPPORTED;
}
for (int i=0; i<nengine; i++)
{
m_pGtSystemInfo->VDBoxInfo.Instances.VDBoxEnableMask |= 1 << uengines[i].engine_instance;
}
MOS_SafeFreeMemory(uengines);
}
if (m_pGtSystemInfo->VEBoxInfo.NumberOfVEBoxEnabled == 0)
{
unsigned int nengine = maxNengine;
struct i915_engine_class_instance *uengines = nullptr;
uengines = (struct i915_engine_class_instance *)MOS_AllocAndZeroMemory(nengine * sizeof(struct i915_engine_class_instance));
MOS_OS_CHK_NULL_RETURN(uengines);
if (mos_query_engines(context->bufmgr,I915_ENGINE_CLASS_VIDEO_ENHANCE,0,&nengine,uengines) == 0)
{
MOS_OS_ASSERT(nengine <= maxNengine);
m_pGtSystemInfo->VEBoxInfo.NumberOfVEBoxEnabled = nengine;
}
else
{
MOS_OS_ASSERTMESSAGE("Failed to query vebox engine\n");
MOS_SafeFreeMemory(uengines);
return MOS_STATUS_PLATFORM_NOT_SUPPORTED;
}
MOS_SafeFreeMemory(uengines);
}
uint32_t platformKey = devInfo->productFamily;
LinuxDeviceInit *devInit = GetDeviceInit(platformKey);
if (devInit && devInit->InitMediaFeature &&
devInit->InitMediaWa &&
devInit->InitMediaFeature(devInfo, m_pSkuTable, &drvInfo) &&
devInit->InitMediaWa(devInfo, m_pWaTable, &drvInfo))
{
MOS_OS_NORMALMESSAGE("Init Media SKU/WA info successfully\n");
}
else
{
MOS_OS_ASSERTMESSAGE("Failed to Init SKU/WA Info\n");
return MOS_STATUS_PLATFORM_NOT_SUPPORTED;
}
uint32_t devExtKey = platformKey + MEDIA_EXT_FLAG;
LinuxDeviceInit *devExtInit = GetDeviceInit(devExtKey);
/* The initializationof Ext SKU/WA is optional. So skip the check of return value */
if (devExtInit && devExtInit->InitMediaFeature &&
devExtInit->InitMediaWa &&
devExtInit->InitMediaFeature(devInfo, m_pSkuTable, &drvInfo) &&
devExtInit->InitMediaWa(devInfo, m_pWaTable, &drvInfo))
{
MOS_OS_NORMALMESSAGE("Init Media SystemInfo successfully\n");
}
/* disable it on Linux */
MEDIA_WR_SKU(m_pSkuTable, FtrPerCtxtPreemptionGranularityControl, 0);
MEDIA_WR_SKU(m_pSkuTable, FtrMediaThreadGroupLevelPreempt, 0);
MEDIA_WR_SKU(m_pSkuTable, FtrMediaMidBatchPreempt, 0);
MEDIA_WR_SKU(m_pSkuTable, FtrMediaMidThreadLevelPreempt, 0);
MEDIA_WR_SKU(m_pSkuTable, FtrGpGpuThreadGroupLevelPreempt, 0);
MEDIA_WR_SKU(m_pSkuTable, FtrGpGpuMidBatchPreempt, 0);
MEDIA_WR_SKU(m_pSkuTable, FtrGpGpuMidThreadLevelPreempt, 0);
return MOS_STATUS_SUCCESS;
}
MOS_STATUS MosMockAdaptorSpecific::UpdateUserFeatureKey(PMOS_CONTEXT osContext)
{
PLATFORM platForm = osContext->platform;
int iDeviceId = osContext->iDeviceId;
uint32_t platFormId = __MEDIA_USER_FEATURE_VALUE_MOCKADAPTOR_PLATFORM_ID;
uint32_t deviceId = __MEDIA_USER_FEATURE_VALUE_MOCKADAPTOR_DEVICE_ID;
MOS_USER_FEATURE_VALUE_WRITE_DATA userFeatureWriteData;
userFeatureWriteData = __NULL_USER_FEATURE_VALUE_WRITE_DATA__;
userFeatureWriteData.Value.i32Data = (int32_t)platForm.eProductFamily;
userFeatureWriteData.ValueID = (MOS_USER_FEATURE_VALUE_ID)platFormId;
MOS_UserFeature_WriteValues_ID(nullptr, &userFeatureWriteData, 1, osContext);
userFeatureWriteData = __NULL_USER_FEATURE_VALUE_WRITE_DATA__;
userFeatureWriteData.Value.i32Data = (int32_t)iDeviceId;
userFeatureWriteData.ValueID = (MOS_USER_FEATURE_VALUE_ID)deviceId;
MOS_UserFeature_WriteValues_ID(nullptr, &userFeatureWriteData, 1, osContext);
return MOS_STATUS_SUCCESS;
}