1*35ffd701SAndroid Build Coastguard Worker /*============================================================================== 2*35ffd701SAndroid Build Coastguard Worker Copyright(c) 2020 Intel Corporation 3*35ffd701SAndroid Build Coastguard Worker 4*35ffd701SAndroid Build Coastguard Worker Permission is hereby granted, free of charge, to any person obtaining a 5*35ffd701SAndroid Build Coastguard Worker copy of this software and associated documentation files(the "Software"), 6*35ffd701SAndroid Build Coastguard Worker to deal in the Software without restriction, including without limitation 7*35ffd701SAndroid Build Coastguard Worker the rights to use, copy, modify, merge, publish, distribute, sublicense, 8*35ffd701SAndroid Build Coastguard Worker and / or sell copies of the Software, and to permit persons to whom the 9*35ffd701SAndroid Build Coastguard Worker Software is furnished to do so, subject to the following conditions: 10*35ffd701SAndroid Build Coastguard Worker 11*35ffd701SAndroid Build Coastguard Worker The above copyright notice and this permission notice shall be included 12*35ffd701SAndroid Build Coastguard Worker in all copies or substantial portions of the Software. 13*35ffd701SAndroid Build Coastguard Worker 14*35ffd701SAndroid Build Coastguard Worker THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 15*35ffd701SAndroid Build Coastguard Worker OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 16*35ffd701SAndroid Build Coastguard Worker FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 17*35ffd701SAndroid Build Coastguard Worker THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR 18*35ffd701SAndroid Build Coastguard Worker OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 19*35ffd701SAndroid Build Coastguard Worker ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 20*35ffd701SAndroid Build Coastguard Worker OTHER DEALINGS IN THE SOFTWARE. 21*35ffd701SAndroid Build Coastguard Worker ============================================================================*/ 22*35ffd701SAndroid Build Coastguard Worker 23*35ffd701SAndroid Build Coastguard Worker #pragma once 24*35ffd701SAndroid Build Coastguard Worker 25*35ffd701SAndroid Build Coastguard Worker #include "GmmCachePolicyULT.h" 26*35ffd701SAndroid Build Coastguard Worker 27*35ffd701SAndroid Build Coastguard Worker class CTestGen12dGPUCachePolicy : public CTestCachePolicy 28*35ffd701SAndroid Build Coastguard Worker { 29*35ffd701SAndroid Build Coastguard Worker protected: 30*35ffd701SAndroid Build Coastguard Worker virtual void SetUpGen12dGPUVariant(PRODUCT_FAMILY); 31*35ffd701SAndroid Build Coastguard Worker virtual void TearDownGen12dGPUVariant(); 32*35ffd701SAndroid Build Coastguard Worker virtual void CheckL3Gen12dGPUCachePolicy(); 33*35ffd701SAndroid Build Coastguard Worker virtual void CheckSpecialMocs(uint32_t Usage, 34*35ffd701SAndroid Build Coastguard Worker uint32_t AssignedMocsIdx, 35*35ffd701SAndroid Build Coastguard Worker GMM_CACHE_POLICY_ELEMENT ClientRequest); 36*35ffd701SAndroid Build Coastguard Worker 37*35ffd701SAndroid Build Coastguard Worker virtual void CheckMocsIdxHDCL1(uint32_t Usage, 38*35ffd701SAndroid Build Coastguard Worker uint32_t AssignedMocsIdx, 39*35ffd701SAndroid Build Coastguard Worker GMM_CACHE_POLICY_ELEMENT ClientRequest); 40*35ffd701SAndroid Build Coastguard Worker 41*35ffd701SAndroid Build Coastguard Worker public: 42*35ffd701SAndroid Build Coastguard Worker static void SetUpTestCase(); 43*35ffd701SAndroid Build Coastguard Worker static void TearDownTestCase(); 44*35ffd701SAndroid Build Coastguard Worker }; 45*35ffd701SAndroid Build Coastguard Worker 46*35ffd701SAndroid Build Coastguard Worker class CTestXe_HP_CachePolicy : public CTestGen12dGPUCachePolicy 47*35ffd701SAndroid Build Coastguard Worker { 48*35ffd701SAndroid Build Coastguard Worker protected: 49*35ffd701SAndroid Build Coastguard Worker virtual void SetUpPlatformVariant(PRODUCT_FAMILY); 50*35ffd701SAndroid Build Coastguard Worker virtual void TearDownPlatformVariant(); 51*35ffd701SAndroid Build Coastguard Worker virtual void CheckL3CachePolicy(); 52*35ffd701SAndroid Build Coastguard Worker virtual void CheckPAT(); 53*35ffd701SAndroid Build Coastguard Worker 54*35ffd701SAndroid Build Coastguard Worker public: 55*35ffd701SAndroid Build Coastguard Worker static void SetUpTestCase(); 56*35ffd701SAndroid Build Coastguard Worker static void TearDownTestCase(); 57*35ffd701SAndroid Build Coastguard Worker }; 58*35ffd701SAndroid Build Coastguard Worker #pragma once 59