2017-12-21 00:45:38 +01:00
|
|
|
/*
|
2024-01-05 15:51:04 +00:00
|
|
|
* Copyright (C) 2018-2024 Intel Corporation
|
2018-09-18 09:11:08 +02:00
|
|
|
*
|
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
|
*
|
|
|
|
|
*/
|
2017-12-21 00:45:38 +01:00
|
|
|
|
2018-07-06 09:07:42 +02:00
|
|
|
#include "mock_gmm_client_context.h"
|
2017-12-21 00:45:38 +01:00
|
|
|
|
2019-03-26 11:59:46 +01:00
|
|
|
namespace NEO {
|
2020-08-05 11:09:25 +02:00
|
|
|
|
|
|
|
|
MEMORY_OBJECT_CONTROL_STATE MockGmmClientContextBase::cachePolicyGetMemoryObject(GMM_RESOURCE_INFO *pResInfo, GMM_RESOURCE_USAGE_TYPE usage) {
|
|
|
|
|
MEMORY_OBJECT_CONTROL_STATE retVal = {};
|
|
|
|
|
memset(&retVal, 0, sizeof(MEMORY_OBJECT_CONTROL_STATE));
|
|
|
|
|
switch (usage) {
|
|
|
|
|
case GMM_RESOURCE_USAGE_OCL_INLINE_CONST_HDC:
|
|
|
|
|
retVal.DwordValue = 32u;
|
|
|
|
|
break;
|
|
|
|
|
case GMM_RESOURCE_USAGE_OCL_BUFFER:
|
|
|
|
|
retVal.DwordValue = 16u;
|
|
|
|
|
break;
|
|
|
|
|
case GMM_RESOURCE_USAGE_OCL_BUFFER_CONST:
|
|
|
|
|
retVal.DwordValue = 8u;
|
|
|
|
|
break;
|
|
|
|
|
case GMM_RESOURCE_USAGE_OCL_BUFFER_CACHELINE_MISALIGNED:
|
2023-05-08 17:06:24 +00:00
|
|
|
retVal.DwordValue = 6u;
|
2020-08-05 11:09:25 +02:00
|
|
|
break;
|
|
|
|
|
case GMM_RESOURCE_USAGE_OCL_STATE_HEAP_BUFFER:
|
|
|
|
|
retVal.DwordValue = 2u;
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
retVal.DwordValue = 4u;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
return retVal;
|
|
|
|
|
}
|
|
|
|
|
|
2022-09-21 12:49:45 +00:00
|
|
|
uint32_t MockGmmClientContextBase::cachePolicyGetPATIndex(GMM_RESOURCE_INFO *gmmResourceInfo, GMM_RESOURCE_USAGE_TYPE usage, bool compressed, bool cachable) {
|
|
|
|
|
passedCompressedSettingForGetPatIndexQuery = compressed;
|
|
|
|
|
passedCachableSettingForGetPatIndexQuery = cachable;
|
|
|
|
|
|
2022-04-11 17:13:44 +00:00
|
|
|
if (returnErrorOnPatIndexQuery) {
|
|
|
|
|
return MockPatIndex::error;
|
|
|
|
|
}
|
|
|
|
|
|
2024-01-05 15:51:04 +00:00
|
|
|
if (usage == GMM_RESOURCE_USAGE_OCL_BUFFER_CACHELINE_MISALIGNED ||
|
|
|
|
|
usage == GMM_RESOURCE_USAGE_SURFACE_UNCACHED) {
|
2022-04-11 17:13:44 +00:00
|
|
|
return MockPatIndex::uncached;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return MockPatIndex::cached;
|
2022-02-15 15:07:01 +00:00
|
|
|
}
|
|
|
|
|
|
2019-03-26 11:59:46 +01:00
|
|
|
} // namespace NEO
|