/* * Copyright (C) 2018-2019 Intel Corporation * * SPDX-License-Identifier: MIT * */ #include "common/helpers/bit_helpers.h" #include "runtime/mem_obj/mem_obj_helper.h" namespace OCLRT { bool MemObjHelper::parseMemoryProperties(const cl_mem_properties_intel *properties, MemoryProperties &propertiesStruct) { if (properties == nullptr) { return true; } for (int i = 0; properties[i] != 0; i += 2) { switch (properties[i]) { case CL_MEM_FLAGS: propertiesStruct.flags |= static_cast(properties[i + 1]); break; case CL_MEM_FLAGS_INTEL: propertiesStruct.flags_intel |= static_cast(properties[i + 1]); break; default: return false; } } return true; } AllocationProperties MemObjHelper::getAllocationProperties(cl_mem_flags_intel flags, bool allocateMemory, size_t size, GraphicsAllocation::AllocationType type) { AllocationProperties allocationProperties(allocateMemory, size, type); allocationProperties.flags.uncacheable = isValueSet(flags, CL_MEM_LOCALLY_UNCACHED_RESOURCE); return allocationProperties; } AllocationProperties MemObjHelper::getAllocationProperties(ImageInfo *imgInfo, bool allocateMemory) { return AllocationProperties(imgInfo, allocateMemory); } DevicesBitfield MemObjHelper::getDevicesBitfield(const MemoryProperties &properties) { return {}; } bool MemObjHelper::isSuitableForRenderCompression(bool renderCompressedBuffers, const MemoryProperties &properties, ContextType contextType) { return renderCompressedBuffers; } bool MemObjHelper::validateExtraMemoryProperties(const MemoryProperties &properties) { return true; } void MemObjHelper::addExtraMemoryProperties(MemoryProperties &properties) { } } // namespace OCLRT