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     mhw_vdbox_vvcp_impl_xe2_lpm_base.h
24 //! \brief    MHW VDBOX VVCP interface common base for Xe2_LPM+ platforms
25 //! \details
26 //!
27 
28 #ifndef __MHW_VDBOX_VVCP_IMPL_XE2_LPM_BASE_H__
29 #define __MHW_VDBOX_VVCP_IMPL_XE2_LPM_BASE_H__
30 
31 #include "mhw_vdbox_vvcp_impl.h"
32 
33 namespace mhw
34 {
35 namespace vdbox
36 {
37 namespace vvcp
38 {
39 namespace xe2_lpm_base
40 {
41 
42 template <typename cmd_t>
43 class BaseImpl : public vvcp::Impl<cmd_t>
44 {
45 protected:
46     using base_t = vvcp::Impl<cmd_t>;
BaseImpl(PMOS_INTERFACE osItf,MhwCpInterface * cpItf)47     BaseImpl(PMOS_INTERFACE osItf, MhwCpInterface *cpItf) : base_t(osItf, cpItf){};
48 
49 public:
GetMocsValue(MOS_HW_RESOURCE_DEF hwResType)50     uint32_t GetMocsValue(MOS_HW_RESOURCE_DEF hwResType) override
51     {
52         return this->m_cacheabilitySettings[hwResType].Gen12_7.Index;
53     }
54 MEDIA_CLASS_DEFINE_END(mhw__vdbox__vvcp__xe2_lpm_base__BaseImpl)
55 };
56 
57 }  // namespace xe2_lpm_base
58 }  // namespace vvcp
59 }  // namespace vdbox
60 }  // namespace mhw
61 
62 #endif  // __MHW_VDBOX_VVCP_IMPL_XE2_LPM_BASE_H__
63