2017-12-21 07:45:38 +08:00
|
|
|
/*
|
2023-01-04 02:39:11 +08:00
|
|
|
* Copyright (C) 2018-2023 Intel Corporation
|
2018-09-18 15:11:08 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2021-10-05 20:54:33 +08:00
|
|
|
#include "shared/test/common/mocks/mock_memory_manager.h"
|
2019-02-27 18:39:32 +08:00
|
|
|
|
2020-02-24 05:44:01 +08:00
|
|
|
#include "shared/source/command_stream/command_stream_receiver.h"
|
|
|
|
#include "shared/source/gmm_helper/gmm.h"
|
2023-01-13 23:18:40 +08:00
|
|
|
#include "shared/source/helpers/aligned_memory.h"
|
2021-10-07 01:46:49 +08:00
|
|
|
#include "shared/source/helpers/surface_format_info.h"
|
2020-02-24 05:44:01 +08:00
|
|
|
#include "shared/source/memory_manager/deferred_deleter.h"
|
2023-01-13 23:18:40 +08:00
|
|
|
#include "shared/source/memory_manager/gfx_partition.h"
|
|
|
|
#include "shared/test/common/helpers/default_hw_info.h"
|
2021-10-15 00:53:11 +08:00
|
|
|
#include "shared/test/common/mocks/mock_allocation_properties.h"
|
2023-01-13 23:18:40 +08:00
|
|
|
#include "shared/test/common/mocks/mock_host_ptr_manager.h"
|
|
|
|
#include "shared/test/common/mocks/mock_os_context.h"
|
2020-02-22 16:28:27 +08:00
|
|
|
|
2017-12-21 07:45:38 +08:00
|
|
|
#include <cstring>
|
|
|
|
|
2019-03-26 18:59:46 +08:00
|
|
|
namespace NEO {
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2023-01-13 23:18:40 +08:00
|
|
|
MockMemoryManager::MockMemoryManager(bool enableLocalMemory, ExecutionEnvironment &executionEnvironment) : MemoryManagerCreate(false, enableLocalMemory, executionEnvironment) {
|
|
|
|
hostPtrManager.reset(new MockHostPtrManager);
|
|
|
|
}
|
|
|
|
|
|
|
|
MockMemoryManager::MockMemoryManager() : MockMemoryManager(*(new MockExecutionEnvironment(defaultHwInfo.get()))) {
|
|
|
|
mockExecutionEnvironment.reset(static_cast<MockExecutionEnvironment *>(&executionEnvironment));
|
|
|
|
mockExecutionEnvironment->initGmm();
|
|
|
|
}
|
|
|
|
|
|
|
|
MockMemoryManager::MockMemoryManager(bool enable64pages, bool enableLocalMemory) : MemoryManagerCreate(enable64pages, enableLocalMemory, *(new MockExecutionEnvironment(defaultHwInfo.get()))) {
|
|
|
|
mockExecutionEnvironment.reset(static_cast<MockExecutionEnvironment *>(&executionEnvironment));
|
|
|
|
}
|
|
|
|
|
2017-12-21 07:45:38 +08:00
|
|
|
void MockMemoryManager::setDeferredDeleter(DeferredDeleter *deleter) {
|
|
|
|
deferredDeleter.reset(deleter);
|
|
|
|
}
|
|
|
|
|
|
|
|
void MockMemoryManager::overrideAsyncDeleterFlag(bool newValue) {
|
|
|
|
asyncDeleterEnabled = newValue;
|
|
|
|
if (asyncDeleterEnabled && deferredDeleter == nullptr) {
|
|
|
|
deferredDeleter = createDeferredDeleter();
|
|
|
|
}
|
|
|
|
}
|
2018-12-14 18:24:45 +08:00
|
|
|
|
|
|
|
void *MockMemoryManager::allocateSystemMemory(size_t size, size_t alignment) {
|
2019-03-06 23:35:21 +08:00
|
|
|
if (failAllocateSystemMemory) {
|
|
|
|
return nullptr;
|
|
|
|
}
|
2021-08-11 18:36:04 +08:00
|
|
|
|
|
|
|
if (fakeBigAllocations && size > bigAllocation) {
|
|
|
|
size = MemoryConstants::pageSize64k;
|
|
|
|
}
|
|
|
|
|
2018-12-14 18:24:45 +08:00
|
|
|
return OsAgnosticMemoryManager::allocateSystemMemory(redundancyRatio * size, alignment);
|
|
|
|
}
|
|
|
|
|
2023-01-13 23:18:40 +08:00
|
|
|
void MockMemoryManager::waitForEnginesCompletion(GraphicsAllocation &graphicsAllocation) {
|
|
|
|
waitForEnginesCompletionCalled++;
|
|
|
|
if (waitAllocations.get()) {
|
|
|
|
waitAllocations->addAllocation(&graphicsAllocation);
|
|
|
|
}
|
|
|
|
MemoryManager::waitForEnginesCompletion(graphicsAllocation);
|
|
|
|
}
|
|
|
|
|
2018-12-14 18:24:45 +08:00
|
|
|
GraphicsAllocation *MockMemoryManager::allocateGraphicsMemoryWithProperties(const AllocationProperties &properties) {
|
2023-03-06 23:12:14 +08:00
|
|
|
validateAllocateProperties(properties);
|
2021-02-25 16:38:48 +08:00
|
|
|
if (isMockHostMemoryManager) {
|
|
|
|
allocateGraphicsMemoryWithPropertiesCount++;
|
|
|
|
if (forceFailureInPrimaryAllocation) {
|
2023-01-04 02:39:11 +08:00
|
|
|
if (singleFailureInPrimaryAllocation) {
|
|
|
|
forceFailureInPrimaryAllocation = false;
|
|
|
|
}
|
2021-02-25 16:38:48 +08:00
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
return NEO::MemoryManager::allocateGraphicsMemoryWithProperties(properties);
|
|
|
|
}
|
|
|
|
|
2020-04-16 23:24:38 +08:00
|
|
|
recentlyPassedDeviceBitfield = properties.subDevicesBitfield;
|
2018-12-20 15:43:57 +08:00
|
|
|
AllocationProperties adjustedProperties(properties);
|
|
|
|
adjustedProperties.size = redundancyRatio * properties.size;
|
2022-12-12 18:57:02 +08:00
|
|
|
adjustedProperties.rootDeviceIndex = properties.rootDeviceIndex;
|
2018-12-20 15:43:57 +08:00
|
|
|
return OsAgnosticMemoryManager::allocateGraphicsMemoryWithProperties(adjustedProperties);
|
2018-12-14 18:24:45 +08:00
|
|
|
}
|
|
|
|
|
2021-02-25 16:38:48 +08:00
|
|
|
GraphicsAllocation *MockMemoryManager::allocateGraphicsMemoryWithProperties(const AllocationProperties &properties, const void *ptr) {
|
2023-03-06 23:12:14 +08:00
|
|
|
validateAllocateProperties(properties);
|
2022-11-21 19:03:05 +08:00
|
|
|
lastAllocationProperties.reset(new AllocationProperties(properties));
|
2021-06-16 22:41:26 +08:00
|
|
|
if (returnFakeAllocation) {
|
2023-09-27 08:10:51 +08:00
|
|
|
return new GraphicsAllocation(properties.rootDeviceIndex, properties.allocationType, const_cast<void *>(ptr), dummyAddress, properties.size, 0, MemoryPool::System4KBPages, maxOsContextCount);
|
2021-06-16 22:41:26 +08:00
|
|
|
}
|
2021-02-25 16:38:48 +08:00
|
|
|
if (isMockHostMemoryManager) {
|
|
|
|
allocateGraphicsMemoryWithPropertiesCount++;
|
|
|
|
if (forceFailureInAllocationWithHostPointer) {
|
2023-02-16 19:19:02 +08:00
|
|
|
if (singleFailureInAllocationWithHostPointer) {
|
|
|
|
forceFailureInAllocationWithHostPointer = false;
|
|
|
|
}
|
|
|
|
|
2021-02-25 16:38:48 +08:00
|
|
|
return nullptr;
|
|
|
|
}
|
2023-02-16 19:19:02 +08:00
|
|
|
|
2021-02-25 16:38:48 +08:00
|
|
|
return NEO::MemoryManager::allocateGraphicsMemoryWithProperties(properties, ptr);
|
|
|
|
}
|
2023-02-16 19:19:02 +08:00
|
|
|
|
|
|
|
recentlyPassedDeviceBitfield = properties.subDevicesBitfield;
|
2021-02-25 16:38:48 +08:00
|
|
|
return OsAgnosticMemoryManager::allocateGraphicsMemoryWithProperties(properties, ptr);
|
|
|
|
}
|
|
|
|
|
2019-01-22 19:40:17 +08:00
|
|
|
GraphicsAllocation *MockMemoryManager::allocateGraphicsMemoryForImage(const AllocationData &allocationData) {
|
|
|
|
allocateForImageCalled = true;
|
|
|
|
auto *allocation = MemoryManager::allocateGraphicsMemoryForImage(allocationData);
|
2017-12-21 07:45:38 +08:00
|
|
|
if (redundancyRatio != 1) {
|
2019-01-22 19:40:17 +08:00
|
|
|
memset((unsigned char *)allocation->getUnderlyingBuffer(), 0, allocationData.imgInfo->size * redundancyRatio);
|
2017-12-21 07:45:38 +08:00
|
|
|
}
|
|
|
|
return allocation;
|
|
|
|
}
|
|
|
|
|
2021-08-11 18:36:04 +08:00
|
|
|
GraphicsAllocation *MockMemoryManager::allocateMemoryByKMD(const AllocationData &allocationData) {
|
2019-11-14 17:08:59 +08:00
|
|
|
allocateForShareableCalled = true;
|
2021-08-11 18:36:04 +08:00
|
|
|
return OsAgnosticMemoryManager::allocateMemoryByKMD(allocationData);
|
2019-11-14 17:08:59 +08:00
|
|
|
}
|
|
|
|
|
2022-12-07 06:36:12 +08:00
|
|
|
GraphicsAllocation *MockMemoryManager::allocatePhysicalDeviceMemory(const AllocationData &allocationData, AllocationStatus &status) {
|
|
|
|
return OsAgnosticMemoryManager::allocatePhysicalDeviceMemory(allocationData, status);
|
|
|
|
}
|
|
|
|
|
|
|
|
GraphicsAllocation *MockMemoryManager::allocatePhysicalLocalDeviceMemory(const AllocationData &allocationData, AllocationStatus &status) {
|
|
|
|
return OsAgnosticMemoryManager::allocatePhysicalLocalDeviceMemory(allocationData, status);
|
|
|
|
}
|
|
|
|
|
2019-02-28 21:12:13 +08:00
|
|
|
GraphicsAllocation *MockMemoryManager::allocateGraphicsMemory64kb(const AllocationData &allocationData) {
|
2018-07-24 22:42:35 +08:00
|
|
|
allocation64kbPageCreated = true;
|
2021-12-03 21:52:16 +08:00
|
|
|
preferCompressedFlagPassed = forceCompressed ? true : allocationData.flags.preferCompressed;
|
2018-07-24 22:42:35 +08:00
|
|
|
|
2018-12-06 22:03:06 +08:00
|
|
|
auto allocation = OsAgnosticMemoryManager::allocateGraphicsMemory64kb(allocationData);
|
2018-07-24 15:06:33 +08:00
|
|
|
if (allocation) {
|
2021-12-03 21:52:16 +08:00
|
|
|
allocation->getDefaultGmm()->isCompressionEnabled = preferCompressedFlagPassed;
|
2018-07-24 15:06:33 +08:00
|
|
|
}
|
|
|
|
return allocation;
|
|
|
|
}
|
|
|
|
|
2018-07-24 22:42:35 +08:00
|
|
|
GraphicsAllocation *MockMemoryManager::allocateGraphicsMemoryInDevicePool(const AllocationData &allocationData, AllocationStatus &status) {
|
|
|
|
if (failInDevicePool) {
|
|
|
|
status = AllocationStatus::RetryInNonDevicePool;
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
if (failInDevicePoolWithError) {
|
|
|
|
status = AllocationStatus::Error;
|
|
|
|
return nullptr;
|
|
|
|
}
|
2021-02-25 16:38:48 +08:00
|
|
|
if (successAllocatedGraphicsMemoryIndex >= maxSuccessAllocatedGraphicsMemoryIndex) {
|
|
|
|
return nullptr;
|
2018-07-24 22:42:35 +08:00
|
|
|
|
2021-02-25 16:38:48 +08:00
|
|
|
} else {
|
|
|
|
auto allocation = OsAgnosticMemoryManager::allocateGraphicsMemoryInDevicePool(allocationData, status);
|
|
|
|
if (allocation) {
|
|
|
|
allocationInDevicePoolCreated = true;
|
|
|
|
if (localMemorySupported[allocation->getRootDeviceIndex()]) {
|
|
|
|
static_cast<MemoryAllocation *>(allocation)->overrideMemoryPool(MemoryPool::LocalMemory);
|
|
|
|
}
|
2019-04-16 21:42:23 +08:00
|
|
|
}
|
2021-02-25 16:38:48 +08:00
|
|
|
successAllocatedGraphicsMemoryIndex++;
|
|
|
|
return allocation;
|
2018-07-24 22:42:35 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-30 18:01:33 +08:00
|
|
|
GraphicsAllocation *MockMemoryManager::allocateGraphicsMemoryWithAlignment(const AllocationData &allocationData) {
|
2018-07-25 15:38:00 +08:00
|
|
|
if (failInAllocateWithSizeAndAlignment) {
|
|
|
|
return nullptr;
|
|
|
|
}
|
2018-07-24 22:42:35 +08:00
|
|
|
allocationCreated = true;
|
2021-02-19 19:45:53 +08:00
|
|
|
alignAllocationData = allocationData;
|
2018-11-30 18:01:33 +08:00
|
|
|
return OsAgnosticMemoryManager::allocateGraphicsMemoryWithAlignment(allocationData);
|
2018-07-24 22:42:35 +08:00
|
|
|
}
|
2019-02-21 23:29:05 +08:00
|
|
|
|
2022-02-04 21:59:01 +08:00
|
|
|
GraphicsAllocation *MockMemoryManager::allocate32BitGraphicsMemory(uint32_t rootDeviceIndex, size_t size, const void *ptr, AllocationType allocationType) {
|
2018-12-21 17:16:27 +08:00
|
|
|
bool allocateMemory = ptr == nullptr;
|
2020-03-25 22:15:03 +08:00
|
|
|
AllocationData allocationData{};
|
|
|
|
MockAllocationProperties properties(rootDeviceIndex, allocateMemory, size, allocationType);
|
2019-05-10 17:30:07 +08:00
|
|
|
getAllocationData(allocationData, properties, ptr, createStorageInfoFromProperties(properties));
|
2023-09-16 01:20:28 +08:00
|
|
|
return allocate32BitGraphicsMemoryImpl(allocationData);
|
2018-12-21 17:16:27 +08:00
|
|
|
}
|
2018-07-24 22:42:35 +08:00
|
|
|
|
2023-09-16 01:20:28 +08:00
|
|
|
GraphicsAllocation *MockMemoryManager::allocate32BitGraphicsMemoryImpl(const AllocationData &allocationData) {
|
2021-05-06 22:15:19 +08:00
|
|
|
allocate32BitGraphicsMemoryImplCalled = true;
|
2019-07-26 21:28:06 +08:00
|
|
|
if (failAllocate32Bit) {
|
|
|
|
return nullptr;
|
|
|
|
}
|
2023-09-16 01:20:28 +08:00
|
|
|
return OsAgnosticMemoryManager::allocate32BitGraphicsMemoryImpl(allocationData);
|
2019-07-26 21:28:06 +08:00
|
|
|
}
|
|
|
|
|
2023-01-13 23:18:40 +08:00
|
|
|
void MockMemoryManager::forceLimitedRangeAllocator(uint32_t rootDeviceIndex, uint64_t range) {
|
2023-04-28 21:24:48 +08:00
|
|
|
getGfxPartition(rootDeviceIndex)->init(range, 0, 0, gfxPartitions.size(), false, 0u);
|
2023-01-13 23:18:40 +08:00
|
|
|
}
|
|
|
|
|
2023-02-28 08:20:17 +08:00
|
|
|
bool MockMemoryManager::hasPageFaultsEnabled(const Device &neoDevice) {
|
2023-11-30 16:32:25 +08:00
|
|
|
if (debugManager.flags.EnableRecoverablePageFaults.get() != -1) {
|
|
|
|
return !!debugManager.flags.EnableRecoverablePageFaults.get();
|
2023-02-28 08:20:17 +08:00
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2023-01-13 23:18:40 +08:00
|
|
|
bool MockMemoryManager::isKmdMigrationAvailable(uint32_t rootDeviceIndex) {
|
2023-11-30 16:32:25 +08:00
|
|
|
if (debugManager.flags.UseKmdMigration.get() != -1) {
|
|
|
|
return !!debugManager.flags.UseKmdMigration.get();
|
2023-01-13 23:18:40 +08:00
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2021-04-23 01:01:19 +08:00
|
|
|
GraphicsAllocation *MockMemoryManager::createGraphicsAllocationFromExistingStorage(AllocationProperties &properties, void *ptr, MultiGraphicsAllocation &multiGraphicsAllocation) {
|
|
|
|
auto allocation = OsAgnosticMemoryManager::createGraphicsAllocationFromExistingStorage(properties, ptr, multiGraphicsAllocation);
|
|
|
|
createGraphicsAllocationFromExistingStorageCalled++;
|
|
|
|
allocationsFromExistingStorage.push_back(allocation);
|
|
|
|
return allocation;
|
|
|
|
}
|
|
|
|
|
2023-05-04 09:40:52 +08:00
|
|
|
GraphicsAllocation *MockMemoryManager::createGraphicsAllocationFromSharedHandle(osHandle handle, const AllocationProperties &properties, bool requireSpecificBitness, bool isHostIpcAllocation, bool reuseSharedAllocation, void *mapPointer) {
|
2022-05-31 17:36:11 +08:00
|
|
|
if (handle != invalidSharedHandle) {
|
2023-05-04 09:40:52 +08:00
|
|
|
auto allocation = OsAgnosticMemoryManager::createGraphicsAllocationFromSharedHandle(handle, properties, requireSpecificBitness, isHostIpcAllocation, reuseSharedAllocation, mapPointer);
|
2022-05-31 17:36:11 +08:00
|
|
|
this->capturedSharedHandle = handle;
|
|
|
|
return allocation;
|
|
|
|
} else {
|
|
|
|
this->capturedSharedHandle = handle;
|
|
|
|
return nullptr;
|
|
|
|
}
|
2022-06-15 19:07:49 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
GraphicsAllocation *MockMemoryManager::createGraphicsAllocationFromNTHandle(void *handle, uint32_t rootDeviceIndex, AllocationType allocType) {
|
|
|
|
if (toOsHandle(handle) != invalidSharedHandle) {
|
2023-12-11 22:24:36 +08:00
|
|
|
auto graphicsAllocation = createMemoryAllocation(NEO::AllocationType::sharedBuffer, nullptr, reinterpret_cast<void *>(1), 1,
|
2022-06-15 19:07:49 +08:00
|
|
|
4096u, toOsHandle(handle), MemoryPool::SystemCpuInaccessible, rootDeviceIndex,
|
|
|
|
false, false, false);
|
|
|
|
graphicsAllocation->setSharedHandle(toOsHandle(handle));
|
|
|
|
this->capturedSharedHandle = toOsHandle(handle);
|
|
|
|
return graphicsAllocation;
|
|
|
|
} else {
|
|
|
|
this->capturedSharedHandle = toOsHandle(handle);
|
|
|
|
return nullptr;
|
|
|
|
}
|
2022-05-31 17:36:11 +08:00
|
|
|
}
|
|
|
|
|
2021-10-21 19:16:19 +08:00
|
|
|
bool MockMemoryManager::copyMemoryToAllocationBanks(GraphicsAllocation *graphicsAllocation, size_t destinationOffset, const void *memoryToCopy, size_t sizeToCopy, DeviceBitfield handleMask) {
|
|
|
|
copyMemoryToAllocationBanksCalled++;
|
|
|
|
copyMemoryToAllocationBanksParamsPassed.push_back({graphicsAllocation, destinationOffset, memoryToCopy, sizeToCopy, handleMask});
|
|
|
|
return OsAgnosticMemoryManager::copyMemoryToAllocationBanks(graphicsAllocation, destinationOffset, memoryToCopy, sizeToCopy, handleMask);
|
|
|
|
};
|
|
|
|
|
2023-01-13 23:18:40 +08:00
|
|
|
void *MockAllocSysMemAgnosticMemoryManager::allocateSystemMemory(size_t size, size_t alignment) {
|
|
|
|
constexpr size_t minAlignment = 16;
|
|
|
|
alignment = std::max(alignment, minAlignment);
|
|
|
|
return alignedMalloc(size, alignment);
|
|
|
|
}
|
|
|
|
|
2019-03-28 22:42:23 +08:00
|
|
|
FailMemoryManager::FailMemoryManager(int32_t failedAllocationsCount, ExecutionEnvironment &executionEnvironment) : MockMemoryManager(executionEnvironment) {
|
2018-12-06 22:03:06 +08:00
|
|
|
this->failedAllocationsCount = failedAllocationsCount;
|
2018-10-19 19:41:42 +08:00
|
|
|
}
|
|
|
|
|
2019-03-06 23:35:21 +08:00
|
|
|
FailMemoryManager::FailMemoryManager(int32_t failedAllocationsCount, ExecutionEnvironment &executionEnvironment, bool enableLocalMemory)
|
|
|
|
: MockMemoryManager(enableLocalMemory, executionEnvironment) {
|
|
|
|
this->failedAllocationsCount = failedAllocationsCount;
|
|
|
|
}
|
|
|
|
|
2023-01-13 23:18:40 +08:00
|
|
|
GraphicsAllocation *MockMemoryManagerFailFirstAllocation::allocateNonSystemGraphicsMemoryInDevicePool(const AllocationData &allocationData, AllocationStatus &status) {
|
|
|
|
auto allocation = baseAllocateGraphicsMemoryInDevicePool(allocationData, status);
|
|
|
|
if (!allocation) {
|
|
|
|
allocation = allocateGraphicsMemory(allocationData);
|
|
|
|
}
|
2023-10-17 17:26:50 +08:00
|
|
|
static_cast<MemoryAllocation *>(allocation)->overrideMemoryPool(MemoryPool::SystemCpuInaccessible);
|
2023-01-13 23:18:40 +08:00
|
|
|
return allocation;
|
|
|
|
}
|
|
|
|
|
|
|
|
OsContext *MockMemoryManagerOsAgnosticContext::createAndRegisterOsContext(CommandStreamReceiver *commandStreamReceiver,
|
|
|
|
const EngineDescriptor &engineDescriptor) {
|
|
|
|
auto osContext = new OsContext(commandStreamReceiver->getRootDeviceIndex(), 0, engineDescriptor);
|
|
|
|
osContext->incRefInternal();
|
2023-04-26 18:36:25 +08:00
|
|
|
allRegisteredEngines[commandStreamReceiver->getRootDeviceIndex()].emplace_back(commandStreamReceiver, osContext);
|
2023-01-13 23:18:40 +08:00
|
|
|
return osContext;
|
|
|
|
}
|
|
|
|
|
|
|
|
OsContext *MockMemoryManagerWithDebuggableOsContext::createAndRegisterOsContext(CommandStreamReceiver *commandStreamReceiver,
|
|
|
|
const EngineDescriptor &engineDescriptor) {
|
|
|
|
auto osContext = new MockOsContext(0, engineDescriptor);
|
|
|
|
osContext->debuggableContext = true;
|
|
|
|
osContext->incRefInternal();
|
2023-04-26 18:36:25 +08:00
|
|
|
allRegisteredEngines[commandStreamReceiver->getRootDeviceIndex()].emplace_back(commandStreamReceiver, osContext);
|
2023-01-13 23:18:40 +08:00
|
|
|
return osContext;
|
|
|
|
}
|
|
|
|
|
2019-03-26 18:59:46 +08:00
|
|
|
} // namespace NEO
|