blob: 3c4b0bd7edb57aa65d0dda651d03bb43482ef36d [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.
*/
#ifndef __VP_RENDER_CMD_PACKET_EXT_H__
#define __VP_RENDER_CMD_PACKET_EXT_H__
#include "media_render_cmd_packet.h"
#include "vp_allocator.h"
#include "vp_cmd_packet.h"
#include "vp_kernelset.h"
#include "vp_render_common.h"
namespace vp
{
//!
//! \brief Secure Block Copy kernel inline data size
//!
#define SECURE_BLOCK_COPY_KERNEL_INLINE_SIZE (1 * sizeof(uint32_t))
//!
//! \brief Secure Block Copy kernel width
//!
#define SECURE_BLOCK_COPY_KERNEL_SURF_WIDTH 64
//!
//! \brief Secure Block Copy kernel block height
//!
#define SECURE_BLOCK_COPY_KERNEL_BLOCK_HEIGHT 24
class VpRenderCmdPacket : virtual public RenderCmdPacket, virtual public VpCmdPacket
{
public:
VpRenderCmdPacket(MediaTask* task, PVP_MHWINTERFACE hwInterface, PVpAllocator& allocator, VPMediaMemComp* mmc, VpKernelSet* kernelSet);
virtual ~VpRenderCmdPacket();
MOS_STATUS Prepare() override;
MOS_STATUS Init() override
{
return RenderCmdPacket::Init();
}
MOS_STATUS Destroy() override
{
return RenderCmdPacket::Destroy();
}
virtual MOS_STATUS Submit(MOS_COMMAND_BUFFER* commandBuffer, uint8_t packetPhase = otherPacket) override;
virtual MOS_STATUS SubmitWithMultiKernel(MOS_COMMAND_BUFFER* commandBuffer, uint8_t packetPhase = otherPacket);
MOS_STATUS SetVeboxUpdateParams(PVEBOX_UPDATE_PARAMS params);
MOS_STATUS SetSecureCopyParams(bool copyNeeded);
MOS_STATUS PacketInit(
VP_SURFACE* inputSurface,
VP_SURFACE* outputSurface,
VP_SURFACE* previousSurface,
VP_SURFACE_SETTING& surfSetting,
VP_EXECUTE_CAPS packetCaps) override;
MOS_STATUS SetSRParams(PRENDER_SR_PARAMS params);
MOS_STATUS SetSRChromaParams(PRENDER_SR_PARAMS params);
MOS_STATUS ReadSRWeights(uint16_t *pBuf, const uint8_t*pWeight, const uint32_t uWeightSize, uint32_t outChannels, uint32_t inChannels, uint32_t nWeightsPerChannel, uint32_t layer);
protected:
MOS_STATUS KernelStateSetup();
virtual MOS_STATUS SetupSamplerStates();
virtual MOS_STATUS SetupSurfaceState();
virtual MOS_STATUS SetupCurbeState();
virtual VP_SURFACE* GetSurface(SurfaceType type);
virtual MOS_STATUS SetupWalkerParams();
virtual MOS_STATUS SetupMediaWalker() override;
MOS_STATUS SendMediaStates(PRENDERHAL_INTERFACE pRenderHal, PMOS_COMMAND_BUFFER pCmdBuffer);
MOS_STATUS InitRenderHalSurface(
VP_SURFACE &surface,
RENDERHAL_SURFACE &renderSurface);
MOS_STATUS InitStateHeapSurface(
SurfaceType type,
RENDERHAL_SURFACE& renderSurface);
// comments here: Hight overwite params if needed
MOS_STATUS UpdateRenderSurface(RENDERHAL_SURFACE_NEXT &renderSurface, KERNEL_SURFACE_STATE_PARAM& kernelParams);
MOS_STATUS SetSamplerAvsParams(MHW_SAMPLER_STATE_PARAM& samplerStateParam, PRENDER_SR_PARAMS params);
MOS_STATUS SamplerAvsCalcScalingTable(
MHW_AVS_PARAMS& avsParameters,
MOS_FORMAT SrcFormat,
bool bVertical,
float fLumaScale,
float fChromaScale,
uint32_t dwChromaSiting,
bool b8TapAdaptiveEnable);
MOS_STATUS SetNearestModeTable(
int32_t * iCoefs,
uint32_t dwPlane,
bool bBalancedFilter);
MOS_STATUS CalcPolyphaseTablesUV(
int32_t * piCoefs,
float fLanczosT,
float fInverseScaleFactor);
MOS_STATUS CalcPolyphaseTablesY(
int32_t *iCoefs,
float fScaleFactor,
uint32_t dwPlane,
MOS_FORMAT srcFmt,
float fHPStrength,
bool bUse8x8Filter,
uint32_t dwHwPhase);
MOS_STATUS CalcPolyphaseTablesUVOffset(
int32_t* piCoefs,
float fLanczosT,
float fInverseScaleFactor,
int32_t iUvPhaseOffset);
protected:
KERNEL_OBJECTS m_kernelObjs;
KERNEL_CONFIGS m_kernelConfigs;
KERNEL_RENDER_DATA m_kernelRenderData;
Kdll_FilterEntry *m_filter = nullptr; // Kernel Filter (points to base of filter array)
bool m_firstFrame = true;
VpKernelSet *m_kernelSet = nullptr;
VpRenderKernelObj *m_kernel = nullptr; // processing kernel pointer
RENDER_KERNEL_PARAMS m_renderKernelParams;
KERNEL_SAMPLER_STATE_GROUP m_kernelSamplerStateGroup;
KERNEL_SUBMISSION_MODE m_submissionMode = MULTI_KERNELS_WITH_MULTI_MEDIA_STATES;
uint32_t m_slmSize = 0;
uint32_t m_totalCurbeSize = 0;
uint32_t m_totoalInlineSize = 0;
};
}
#endif