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