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