xref: /aosp_15_r20/external/intel-media-driver/media_driver/agnostic/gen11/hw/mhw_sfc_g11_X.h (revision ba62d9d3abf0e404f2022b4cd7a85e107f48596f)
1 /*
2 * Copyright (c) 2015-2018, 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_sfc_g11_X.h
24 //! \brief    Defines functions for constructing sfc commands on Gen911-based platforms
25 //!
26 #ifndef __MHW_SFC_G11_X_H__
27 #define __MHW_SFC_G11_X_H__
28 
29 #include "mhw_sfc_generic.h"
30 #include "mhw_sfc_hwcmd_g11_X.h"
31 #include "mhw_utilities.h"
32 #include "mos_os.h"
33 
34 class MhwSfcInterfaceG11 : public MhwSfcInterfaceGeneric<mhw_sfc_g11_X>
35 {
36 public:
37     MhwSfcInterfaceG11(PMOS_INTERFACE pOsInterface);
38 
~MhwSfcInterfaceG11()39     virtual ~MhwSfcInterfaceG11()
40     {
41 
42     }
43 
44     virtual MOS_STATUS AddSfcState(
45         PMOS_COMMAND_BUFFER            pCmdBuffer,
46         PMHW_SFC_STATE_PARAMS          pSfcStateParams,
47         PMHW_SFC_OUT_SURFACE_PARAMS    pOutSurface);
48 
49     MOS_STATUS AddSfcAvsState(
50         PMOS_COMMAND_BUFFER            pCmdBuffer,
51         PMHW_SFC_AVS_STATE             pSfcAvsState);
52 
53 
54     virtual MOS_STATUS SetSfcSamplerTable(
55         PMHW_SFC_AVS_LUMA_TABLE         pLumaTable,
56         PMHW_SFC_AVS_CHROMA_TABLE       pChromaTable,
57         PMHW_AVS_PARAMS                 pAvsParams,
58         MOS_FORMAT                      SrcFormat,
59         float                           fScaleX,
60         float                           fScaleY,
61         uint32_t                        dwChromaSiting,
62         bool                            bUse8x8Filter,
63         float                           fHPStrength,
64         float                           fLanczosT);
65 
66 };
67 #endif // __MHW_SFC_G11_X_H__
68