1 /* 2 * Copyright (c) 2020-2023, 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_vdbox_vdenc_impl_xe2_hpm.h 24 //! \brief MHW VDBOX VDENC interface common base for Xe2_HPM 25 //! \details 26 //! 27 28 #ifndef __MHW_VDBOX_VDENC_IMPL_XE2_HPM_H__ 29 #define __MHW_VDBOX_VDENC_IMPL_XE2_HPM_H__ 30 31 #include "mhw_vdbox_vdenc_impl_xe_lpm_plus_base.h" 32 #include "mhw_vdbox_vdenc_hwcmd_xe2_hpm.h" 33 34 namespace mhw 35 { 36 namespace vdbox 37 { 38 namespace vdenc 39 { 40 namespace xe_lpm_plus_base 41 { 42 namespace v1 43 { 44 class Impl : public BaseImplGeneric<Cmd> 45 { 46 protected: 47 using cmd_t = Cmd; 48 using base_t = BaseImplGeneric<cmd_t>; 49 50 public: Impl(PMOS_INTERFACE osItf)51 Impl(PMOS_INTERFACE osItf) : base_t(osItf){}; 52 53 protected: _MHW_SETCMD_OVERRIDE_DECL(VDENC_CMD1)54 _MHW_SETCMD_OVERRIDE_DECL(VDENC_CMD1) 55 { 56 _MHW_SETCMD_CALLBASE(VDENC_CMD1); 57 58 #define DO_FIELDS() \ 59 DO_FIELD(DW9, VDENC_CMD1_DW9_BIT24, params.vdencCmd1Par95); \ 60 DO_FIELD(DW32, VDENC_CMD1_DW32_BIT24, params.vdencCmd1Par93); \ 61 DO_FIELD(DW31, VDENC_CMD1_DW31_BIT24, params.vdencCmd1Par94); \ 62 DO_FIELD(DW33, VDENC_CMD1_DW33_BIT0, params.vdencCmd1Par11[1]); \ 63 DO_FIELD(DW33, VDENC_CMD1_DW33_BIT8, params.vdencCmd1Par15[3]); \ 64 DO_FIELD(DW33, VDENC_CMD1_DW33_BIT16, params.vdencCmd1Par15[2]); \ 65 DO_FIELD(DW33, VDENC_CMD1_DW33_BIT24, params.vdencCmd1Par15[1]); \ 66 DO_FIELD(DW34, VDENC_CMD1_DW34_BIT0, params.vdencCmd1Par14[2]); \ 67 DO_FIELD(DW34, VDENC_CMD1_DW34_BIT8, params.vdencCmd1Par14[1]); \ 68 DO_FIELD(DW34, VDENC_CMD1_DW34_BIT16, params.vdencCmd1Par11[3]); \ 69 DO_FIELD(DW34, VDENC_CMD1_DW34_BIT24, params.vdencCmd1Par11[2]); \ 70 DO_FIELD(DW35, VDENC_CMD1_DW35_BIT0, params.vdencCmd1Par10[3]); \ 71 DO_FIELD(DW35, VDENC_CMD1_DW35_BIT8, params.vdencCmd1Par10[2]); \ 72 DO_FIELD(DW35, VDENC_CMD1_DW35_BIT16, params.vdencCmd1Par10[1]); \ 73 DO_FIELD(DW35, VDENC_CMD1_DW35_BIT24, params.vdencCmd1Par14[3]); \ 74 DO_FIELD(DW36, VDENC_CMD1_DW36_BIT0, params.vdencCmd1Par9[1]); \ 75 DO_FIELD(DW36, VDENC_CMD1_DW36_BIT8, params.vdencCmd1Par13[3]); \ 76 DO_FIELD(DW36, VDENC_CMD1_DW36_BIT16, params.vdencCmd1Par13[2]); \ 77 DO_FIELD(DW36, VDENC_CMD1_DW36_BIT24, params.vdencCmd1Par13[1]); \ 78 DO_FIELD(DW37, VDENC_CMD1_DW37_BIT0, params.vdencCmd1Par12[2]); \ 79 DO_FIELD(DW37, VDENC_CMD1_DW37_BIT8, params.vdencCmd1Par12[1]); \ 80 DO_FIELD(DW37, VDENC_CMD1_DW37_BIT16, params.vdencCmd1Par9[3]); \ 81 DO_FIELD(DW37, VDENC_CMD1_DW37_BIT24, params.vdencCmd1Par9[2]); \ 82 DO_FIELD(DW38, VDENC_CMD1_DW38_BIT0, params.vdencCmd1Par8[3]); \ 83 DO_FIELD(DW38, VDENC_CMD1_DW38_BIT8, params.vdencCmd1Par8[2]); \ 84 DO_FIELD(DW38, VDENC_CMD1_DW38_BIT16, params.vdencCmd1Par8[1]); \ 85 DO_FIELD(DW38, VDENC_CMD1_DW38_BIT24, params.vdencCmd1Par12[3]) 86 87 #include "mhw_hwcmd_process_cmdfields.h" 88 } 89 _MHW_SETCMD_OVERRIDE_DECL(VDENC_CMD2)90 _MHW_SETCMD_OVERRIDE_DECL(VDENC_CMD2) 91 { 92 _MHW_SETCMD_CALLBASE(VDENC_CMD2); 93 94 #define DO_FIELDS_EXT() \ 95 __MHW_VDBOX_VDENC_WRAPPER_EXT(VDENC_CMD2_IMPL_XE2_EXT) 96 97 #include "mhw_hwcmd_process_cmdfields.h" 98 } 99 _MHW_SETCMD_OVERRIDE_DECL(VDENC_HEVC_VP9_TILE_SLICE_STATE)100 _MHW_SETCMD_OVERRIDE_DECL(VDENC_HEVC_VP9_TILE_SLICE_STATE) 101 { 102 _MHW_SETCMD_CALLBASE(VDENC_HEVC_VP9_TILE_SLICE_STATE); 103 104 #define DO_FIELDS() \ 105 DO_FIELD(DW11, VDENC_HEVC_VP9_TILE_SLICE_STATE_DW11_BIT24, params.VdencHEVCVP9TileSlicePar22); \ 106 DO_FIELD(DW12, VDENC_HEVC_VP9_TILE_SLICE_STATE_DW12_BIT0, params.VdencHEVCVP9TileSlicePar5); \ 107 DO_FIELD(DW12, VDENC_HEVC_VP9_TILE_SLICE_STATE_DW12_BIT3, params.VdencHEVCVP9TileSlicePar24); \ 108 DO_FIELD(DW12, PaletteModeEnable, params.paletteModeEnable); \ 109 DO_FIELD(DW14, VDENC_HEVC_VP9_TILE_SLICE_STATE_DW14_BIT8, params.VdencHEVCVP9TileSlicePar8); \ 110 DO_FIELD(DW14, VDENC_HEVC_VP9_TILE_SLICE_STATE_DW14_BIT0, params.VdencHEVCVP9TileSlicePar9); \ 111 DO_FIELD(DW14, VDENC_HEVC_VP9_TILE_SLICE_STATE_DW14_BIT16, params.VdencHEVCVP9TileSlicePar10) 112 113 #include "mhw_hwcmd_process_cmdfields.h" 114 } 115 _MHW_SETCMD_OVERRIDE_DECL(VDENC_AVC_IMG_STATE)116 _MHW_SETCMD_OVERRIDE_DECL(VDENC_AVC_IMG_STATE) 117 { 118 _MHW_SETCMD_CALLBASE(VDENC_AVC_IMG_STATE); 119 120 #define DO_FIELDS_EXT() \ 121 __MHW_VDBOX_VDENC_WRAPPER_EXT(VDENC_AVC_IMG_STATE_IMPL_XE2_HPM_EXT) 122 123 #include "mhw_hwcmd_process_cmdfields.h" 124 } 125 _MHW_SETCMD_OVERRIDE_DECL(VD_PIPELINE_FLUSH)126 _MHW_SETCMD_OVERRIDE_DECL(VD_PIPELINE_FLUSH) 127 { 128 _MHW_SETCMD_CALLBASE(VD_PIPELINE_FLUSH); 129 130 #define DO_FIELDS() \ 131 DO_FIELD(DW1, VdaqmPipelineDone, params.waitDoneVDAQM); \ 132 DO_FIELD(DW1, VdaqmPipelineCommandFlush, params.flushVDAQM) 133 134 #include "mhw_hwcmd_process_cmdfields.h" 135 } 136 _MHW_SETCMD_OVERRIDE_DECL(VDENC_PIPE_MODE_SELECT)137 _MHW_SETCMD_OVERRIDE_DECL(VDENC_PIPE_MODE_SELECT) 138 { 139 _MHW_SETCMD_CALLBASE(VDENC_PIPE_MODE_SELECT); 140 #define DO_FIELDS() \ 141 DO_FIELD(DW6, FastPassEn, params.fastPassEn); \ 142 DO_FIELD(DW6, FastPassScale, params.fastPassScale); \ 143 DO_FIELD(DW6, DownScaleType, params.DownScaleType) 144 145 #include "mhw_hwcmd_process_cmdfields.h" 146 } 147 148 MEDIA_CLASS_DEFINE_END(mhw__vdbox__vdenc__xe_lpm_plus_base__v1__Impl) 149 }; 150 } // namespace v1 151 } // namespace xe_lpm_plus_base 152 } // namespace vdenc 153 } // namespace vdbox 154 } // namespace mhw 155 156 #endif // __MHW_VDBOX_VDENC_IMPL_XE2_HPM_H__ 157