1 /*
2 * Copyright (c) 2024, 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     VpKernelConfigXe2_Hpg.cpp
24 //! \brief    vp kernel config
25 //! \details  vp kernel config
26 //!
27 
28 #include "vp_kernel_config_xe2_hpg.h"
29 #include "vp_utils.h"
30 
31 using namespace vp;
32 
VpKernelConfigXe2_Hpg()33 VpKernelConfigXe2_Hpg::VpKernelConfigXe2_Hpg()
34 {
35     InitKernelParams();
36 }
37 
~VpKernelConfigXe2_Hpg()38 VpKernelConfigXe2_Hpg::~VpKernelConfigXe2_Hpg()
39 {
40 }
41 
InitKernelParams()42 void VpKernelConfigXe2_Hpg::InitKernelParams()
43 {
44     ///*                                             GRF_Count
45     //                                               |  BT_Count
46     //                                               |  |    Sampler_Count
47     //                                               |  |    |  Thread_Count
48     //                                               |  |    |  |                          GRF_Start_Register
49     //                                               |  |    |  |                          |   CURBE_Length
50     //                                               |  |    |  |                          |   |    block_width
51     //                                               |  |    |  |                          |   |    |                       block_height
52     //                                               |  |    |  |                          |   |    |                       |                       blocks_x
53     //                                               |  |    |  |                          |   |    |                       |                       |   blocks_y
54     //                                               |  |    |  |                          |   |    |                       |                       |   |*/
55     ADD_VP_KERNEL_PARAMS(kernelCombinedFc,           7, 40,  3, VP_USE_MEDIA_THREADS_MAX,  0,  6,   VP_COMP_BLOCK_WIDTH,    VP_COMP_BLOCK_HEIGHT,   1,  1);
56     ADD_VP_KERNEL_PARAMS(kernelVeboxUpdateDnState,   4, 34,  0, VP_USE_MEDIA_THREADS_MAX,  0,  2,   64,                     8,                      1,  1);
57     ADD_VP_KERNEL_PARAMS(kernelHdrMandatory,         8, 40,  4, VP_USE_MEDIA_THREADS_MAX,  0,  8,   16,                     8,                      1,  1);
58     ADD_VP_KERNEL_PARAMS(kernelHdr3DLutCalc,         4, 34,  0, VP_USE_MEDIA_THREADS_MAX,  0,  44,  64,                     8,                      1,  1);
59 }
60