1 /* 2 * Copyright (c) 2014-2020, Intel Corporation 3 * 4 * Permission is hereby granted, free of charge, to any person obtaining a 5 * copy of this software and associated documentation files (the "Software"), 6 * to deal in the Software without restriction, including without limitation 7 * the rights to use, copy, modify, merge, publish, distribute, sublicense, 8 * and/or sell copies of the Software, and to permit persons to whom the 9 * Software is furnished to do so, subject to the following conditions: 10 * 11 * The above copyright notice and this permission notice shall be included 12 * in all copies or substantial portions of the Software. 13 * 14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 15 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 17 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR 18 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 19 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 20 * OTHER DEALINGS IN THE SOFTWARE. 21 */ 22 //! 23 //! \file mhw_state_heap_g11.h 24 //! \brief This modules implements HW interface layer to be used on all platforms on all operating systems/DDIs, across MHW components. 25 //! 26 27 #ifndef __MHW_STATE_HEAP_G11_H__ 28 #define __MHW_STATE_HEAP_G11_H__ 29 30 #include "mhw_state_heap_generic.h" 31 #include "mhw_state_heap_hwcmd_g11_X.h" 32 33 // Each increment in sampler index represents this increment in offset 34 #define MHW_SAMPLER_STATE_AVS_INC_G11 2048 35 #define MHW_SAMPLER_STATE_CONV_INC_G11 2048 36 #define MHW_SAMPLER_WIDTH_ALIGN_UNIT_G11 2 37 #define MHW_SAMPLER_HEIGHT_ALIGN_UNIT_G11 4 38 39 struct MHW_STATE_HEAP_INTERFACE_G11_X : public MHW_STATE_HEAP_INTERFACE_GENERIC<mhw_state_heap_g11_X> 40 { 41 42 private: 43 uint16_t m_wSizeOfInterfaceDescriptor; 44 uint32_t m_dwSizeSurfaceState; 45 uint32_t m_dwSizeSurfaceStateAdv; 46 47 public: 48 MHW_STATE_HEAP_INTERFACE_G11_X(PMOS_INTERFACE pInputOSInterface, int8_t bDynamicMode); 49 50 ~MHW_STATE_HEAP_INTERFACE_G11_X(); 51 52 MOS_STATUS SetInterfaceDescriptorEntry( 53 PMHW_ID_ENTRY_PARAMS pParams); 54 55 MOS_STATUS AddInterfaceDescriptorData( 56 PMHW_ID_ENTRY_PARAMS pParams); 57 58 MOS_STATUS SetSurfaceStateEntry( 59 PMHW_SURFACE_STATE_PARAMS pParams); 60 61 MOS_STATUS SetSurfaceState( 62 PMHW_KERNEL_STATE pKernelState, 63 PMOS_COMMAND_BUFFER pCmdBuffer, 64 uint32_t dwNumSurfaceStatesToSet, 65 PMHW_RCS_SURFACE_PARAMS pParams); 66 67 MOS_STATUS SetSamplerState( 68 void *pSampler, 69 PMHW_SAMPLER_STATE_PARAM pParam); 70 71 MOS_STATUS AddSamplerStateData( 72 uint32_t samplerOffset, 73 MemoryBlock *memoryBlock, 74 PMHW_SAMPLER_STATE_PARAM pParam); 75 76 MOS_STATUS InitSamplerStates( 77 void *pSamplerStates, 78 int32_t iSamplers); 79 80 MOS_STATUS LoadSamplerAvsTable( 81 void *pTable, 82 PMHW_SAMPLER_AVS_TABLE_PARAM pMhwSamplerAvsTableParam); 83 84 MOS_STATUS InitHwSizes(); 85 86 MOS_STATUS SetInterfaceDescriptor( 87 uint32_t dwNumIdsToSet, 88 PMHW_INTERFACE_DESCRIPTOR_PARAMS pParams); 89 90 }; 91 #endif 92