blob: 4975bed8bca2e6d9fc41a0ebeb8124b83cf9cac9 [file] [log] [blame]
/*
* Copyright (c) 2017, 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_libva_caps_g10_cnl.cpp
//! \brief This file implements the C++ class/interface for CNL media capbilities.
//!
#include "media_libva_util.h"
#include "media_libva.h"
#include "media_libva_caps_g10_cnl.h"
#include "media_libva_caps_factory.h"
MediaLibvaCapsG10Cnl::MediaLibvaCapsG10Cnl(DDI_MEDIA_CONTEXT *mediaCtx) : MediaLibvaCapsG10(mediaCtx)
{
// CNL supported Encode format
static struct EncodeFormatTable encodeFormatTableCNL[] =
{
{AVC, DualPipe, VA_RT_FORMAT_YUV420},
{AVC, Vdenc, VA_RT_FORMAT_YUV420 | VA_RT_FORMAT_YUV422 | VA_RT_FORMAT_YUV444},
{HEVC, DualPipe, VA_RT_FORMAT_YUV420 | VA_RT_FORMAT_YUV420_10BPP},
{HEVC, Vdenc, VA_RT_FORMAT_YUV420 | VA_RT_FORMAT_YUV420_10BPP | VA_RT_FORMAT_YUV422 | VA_RT_FORMAT_YUV444 | VA_RT_FORMAT_RGB32 | VA_RT_FORMAT_RGB32_10BPP},
{VP9, DualPipe, VA_RT_FORMAT_YUV420 | VA_RT_FORMAT_YUV420_10BPP},
{VP9, Vdenc, VA_RT_FORMAT_YUV420 | VA_RT_FORMAT_YUV420_10BPP | VA_RT_FORMAT_YUV422 | VA_RT_FORMAT_YUV444 |VA_RT_FORMAT_RGB32 | VA_RT_FORMAT_RGB32_10BPP},
};
m_encodeFormatTable = (struct EncodeFormatTable*)(&encodeFormatTableCNL[0]);
m_encodeFormatCount = sizeof(encodeFormatTableCNL)/sizeof(struct EncodeFormatTable);
return;
}
VAStatus MediaLibvaCapsG10Cnl::GetMbProcessingRateEnc(
MEDIA_FEATURE_TABLE *skuTable,
uint32_t tuIdx,
uint32_t codecMode,
bool vdencActive,
uint32_t *mbProcessingRatePerSec)
{
DDI_CHK_NULL(skuTable, "Null pointer", VA_STATUS_ERROR_INVALID_PARAMETER);
DDI_CHK_NULL(mbProcessingRatePerSec, "Null pointer", VA_STATUS_ERROR_INVALID_PARAMETER);
uint32_t gtIdx = 0;
if (vdencActive)
{
// For AVC Vdenc
if (codecMode == CODECHAL_ENCODE_MODE_AVC)
{
if (MEDIA_IS_SKU(skuTable, FtrULX))
{
const uint32_t mbRate[7] =
{
// TU7 | TU6 | TU5 | TU4 | TU3 | TU2 | TU1
1200000, 1200000, 800000, 800000, 800000, 600000, 600000
};
*mbProcessingRatePerSec = mbRate[tuIdx];
}
else // same numbers for ULT/ classic
{
const uint32_t mbRate[7] =
{
// TU7 | TU6 | TU5 | TU4 | TU3 | TU2 | TU1
2200000, 2200000, 1650000, 1650000, 1650000, 1100000, 1100000
};
*mbProcessingRatePerSec = mbRate[tuIdx];
}
}
else if (codecMode == CODECHAL_ENCODE_MODE_HEVC)
{
if (MEDIA_IS_SKU(skuTable, FtrULX))
{
const uint32_t mbRate[7] =
{
// TU7 | TU6 | TU5 | TU4 | TU3 | TU2 | TU1
1200000, 1200000, 600000, 600000, 600000, 300000, 300000
};
*mbProcessingRatePerSec = mbRate[tuIdx];
}
else // same numbers for ULT/ classic
{
const uint32_t mbRate[7] =
{
// TU7 | TU6 | TU5 | TU4 | TU3 | TU2 | TU1
2200000, 2200000, 1200000, 1200000, 1200000, 550000, 550000
};
*mbProcessingRatePerSec = mbRate[tuIdx];
}
}
}
else
{
DDI_CHK_NULL(m_mediaCtx->pGtSystemInfo, "Null pointer", VA_STATUS_ERROR_INVALID_PARAMETER);
//Dual pipe mode
if (m_mediaCtx->pGtSystemInfo->EUCount == 16) //FtrGT0_5
{
gtIdx = 5;
}
else if (m_mediaCtx->pGtSystemInfo->EUCount == 24) //FtrGT1
{
gtIdx = 4;
}
else if (m_mediaCtx->pGtSystemInfo->EUCount == 32) //FtrGT1_5
{
gtIdx = 3;
}
else if (m_mediaCtx->pGtSystemInfo->EUCount == 40) //FtrGT2
{
gtIdx = 2;
}
else if (m_mediaCtx->pGtSystemInfo->EUCount == 56) //FtrGT3
{
gtIdx = 1;
}
else if (m_mediaCtx->pGtSystemInfo->EUCount == 72) //FtrGT4
{
gtIdx = 0;
}
else
{
return VA_STATUS_ERROR_INVALID_PARAMETER;
}
// AVC Dual pipe mode. Data obtained from regular KBL
if (codecMode == CODECHAL_ENCODE_MODE_AVC)
{
if (MEDIA_IS_SKU(skuTable, FtrULX))
{
const uint32_t mbRate[7][6] =
{
// GT4 | GT3 | GT2 | GT1.5 | GT1 | GT0.5
{ 0, 0, 1029393, 1029393, 676280, 676280 },
{ 0, 0, 975027, 975027, 661800, 661800 },
{ 0, 0, 776921, 776921, 640000, 640000 },
{ 0, 0, 776921, 776921, 640000, 640000 },
{ 0, 0, 776921, 776921, 640000, 640000 },
{ 0, 0, 416051, 416051, 317980, 317980 },
{ 0, 0, 214438, 214438, 180655, 180655 }
};
if (gtIdx == 0 || gtIdx == 1)
{
return VA_STATUS_ERROR_INVALID_PARAMETER;
}
*mbProcessingRatePerSec = mbRate[tuIdx][gtIdx];
}
else // same numbers for ULT/ classic
{
const uint32_t mbRate[7][6] =
{
// GT4 | GT3 | GT2 | GT1.5 | GT1 | GT0.5
{ 1544090, 1544090, 1544090, 1029393, 676280, 676280 },
{ 1462540, 1462540, 1462540, 975027, 661800, 661800 },
{ 1165381, 1165381, 1165381, 776921, 640000, 640000 },
{ 1165381, 1165381, 1165381, 776921, 640000, 640000 },
{ 1165381, 1165381, 1165381, 776921, 640000, 640000 },
{ 624076, 624076, 624076, 416051, 317980, 317980 },
{ 321657, 321657, 321657, 214438, 180655, 180655 }
};
*mbProcessingRatePerSec = mbRate[tuIdx][gtIdx];
}
}
else if (codecMode == CODECHAL_ENCODE_MODE_HEVC)
{
// HEVC dual pipe values temporarily set to 50000 for ULT/ULX all TUs and GT
const uint32_t mbRate[7][6] =
{
// GT4 | GT3 | GT2 | GT1.5 | GT1 | GT0.5
{ 500000, 500000, 500000, 500000, 500000, 500000 },
{ 500000, 500000, 500000, 500000, 500000, 500000 },
{ 250000, 250000, 250000, 250000, 250000, 250000 },
{ 250000, 250000, 250000, 250000, 250000, 250000 },
{ 250000, 250000, 250000, 250000, 250000, 250000 },
{ 125000, 125000, 125000, 125000, 125000, 250000 },
{ 125000, 125000, 125000, 125000, 125000, 250000 }
};
*mbProcessingRatePerSec = mbRate[tuIdx][gtIdx];
}
else
{
return VA_STATUS_ERROR_INVALID_PARAMETER;
}
}
return VA_STATUS_SUCCESS;
}
extern template class MediaLibvaCapsFactory<MediaLibvaCaps, DDI_MEDIA_CONTEXT>;
static bool cnlRegistered = MediaLibvaCapsFactory<MediaLibvaCaps, DDI_MEDIA_CONTEXT>::
RegisterCaps<MediaLibvaCapsG10Cnl>((uint32_t)IGFX_CANNONLAKE);