127 lines
5.4 KiB
C++
127 lines
5.4 KiB
C++
/*
|
|
* Copyright (C) 2018-2022 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: MIT
|
|
*
|
|
*/
|
|
|
|
#pragma once
|
|
#include "shared/source/memory_manager/graphics_allocation.h"
|
|
#include "shared/source/memory_manager/memadvise_flags.h"
|
|
#include "shared/source/memory_manager/memory_manager.h"
|
|
|
|
namespace NEO {
|
|
class BufferObject;
|
|
class OsContext;
|
|
class Drm;
|
|
enum class CachePolicy : uint32_t;
|
|
enum class CacheRegion : uint16_t;
|
|
|
|
struct OsHandleLinux : OsHandle {
|
|
~OsHandleLinux() override = default;
|
|
BufferObject *bo = nullptr;
|
|
};
|
|
|
|
using BufferObjects = StackVec<BufferObject *, EngineLimits::maxHandleCount>;
|
|
|
|
class DrmAllocation : public GraphicsAllocation {
|
|
public:
|
|
using MemoryUnmapFunction = int (*)(void *, size_t);
|
|
|
|
struct MemoryToUnmap {
|
|
void *pointer;
|
|
size_t size;
|
|
MemoryUnmapFunction unmapFunction;
|
|
};
|
|
|
|
DrmAllocation(uint32_t rootDeviceIndex, AllocationType allocationType, BufferObject *bo, void *ptrIn, size_t sizeIn, osHandle sharedHandle, MemoryPool pool, uint64_t canonizedGpuAddress)
|
|
: DrmAllocation(rootDeviceIndex, 1, allocationType, bo, ptrIn, sizeIn, sharedHandle, pool, canonizedGpuAddress) {}
|
|
|
|
DrmAllocation(uint32_t rootDeviceIndex, size_t numGmms, AllocationType allocationType, BufferObject *bo, void *ptrIn, size_t sizeIn, osHandle sharedHandle, MemoryPool pool, uint64_t canonizedGpuAddress)
|
|
: GraphicsAllocation(rootDeviceIndex, numGmms, allocationType, ptrIn, sizeIn, sharedHandle, pool, MemoryManager::maxOsContextCount, canonizedGpuAddress), bufferObjects(EngineLimits::maxHandleCount) {
|
|
bufferObjects[0] = bo;
|
|
}
|
|
|
|
DrmAllocation(uint32_t rootDeviceIndex, AllocationType allocationType, BufferObject *bo, void *ptrIn, uint64_t canonizedGpuAddress, size_t sizeIn, MemoryPool pool)
|
|
: DrmAllocation(rootDeviceIndex, 1, allocationType, bo, ptrIn, canonizedGpuAddress, sizeIn, pool) {}
|
|
|
|
DrmAllocation(uint32_t rootDeviceIndex, size_t numGmms, AllocationType allocationType, BufferObject *bo, void *ptrIn, uint64_t canonizedGpuAddress, size_t sizeIn, MemoryPool pool)
|
|
: GraphicsAllocation(rootDeviceIndex, numGmms, allocationType, ptrIn, canonizedGpuAddress, 0, sizeIn, pool, MemoryManager::maxOsContextCount), bufferObjects(EngineLimits::maxHandleCount) {
|
|
bufferObjects[0] = bo;
|
|
}
|
|
|
|
DrmAllocation(uint32_t rootDeviceIndex, AllocationType allocationType, BufferObjects &bos, void *ptrIn, uint64_t canonizedGpuAddress, size_t sizeIn, MemoryPool pool)
|
|
: DrmAllocation(rootDeviceIndex, 1, allocationType, bos, ptrIn, canonizedGpuAddress, sizeIn, pool) {}
|
|
|
|
DrmAllocation(uint32_t rootDeviceIndex, size_t numGmms, AllocationType allocationType, BufferObjects &bos, void *ptrIn, uint64_t canonizedGpuAddress, size_t sizeIn, MemoryPool pool)
|
|
: GraphicsAllocation(rootDeviceIndex, numGmms, allocationType, ptrIn, canonizedGpuAddress, 0, sizeIn, pool, MemoryManager::maxOsContextCount),
|
|
bufferObjects(bos) {
|
|
}
|
|
|
|
~DrmAllocation() override;
|
|
|
|
std::string getAllocationInfoString() const override;
|
|
|
|
BufferObject *getBO() const {
|
|
if (fragmentsStorage.fragmentCount) {
|
|
return static_cast<OsHandleLinux *>(fragmentsStorage.fragmentStorageData[0].osHandleStorage)->bo;
|
|
}
|
|
return this->bufferObjects[0];
|
|
}
|
|
const BufferObjects &getBOs() const {
|
|
return this->bufferObjects;
|
|
}
|
|
BufferObject *&getBufferObjectToModify(uint32_t handleIndex) {
|
|
return bufferObjects[handleIndex];
|
|
}
|
|
|
|
void resizeBufferObjects(uint32_t size) {
|
|
this->bufferObjects.resize(size);
|
|
}
|
|
|
|
uint32_t getNumHandles() override {
|
|
return this->numHandles;
|
|
}
|
|
|
|
void setNumHandles(uint32_t numHandles) override {
|
|
this->numHandles = numHandles;
|
|
}
|
|
|
|
uint64_t peekInternalHandle(MemoryManager *memoryManager) override;
|
|
|
|
uint64_t peekInternalHandle(MemoryManager *memoryManager, uint32_t handleId) override;
|
|
|
|
bool setCacheRegion(Drm *drm, CacheRegion regionIndex);
|
|
bool setCacheAdvice(Drm *drm, size_t regionSize, CacheRegion regionIndex);
|
|
void setCachePolicy(CachePolicy memType);
|
|
|
|
bool setMemAdvise(Drm *drm, MemAdviseFlags flags);
|
|
bool setMemPrefetch(Drm *drm, uint32_t subDeviceId);
|
|
|
|
void *getMmapPtr() { return this->mmapPtr; }
|
|
void setMmapPtr(void *ptr) { this->mmapPtr = ptr; }
|
|
size_t getMmapSize() { return this->mmapSize; }
|
|
void setMmapSize(size_t size) { this->mmapSize = size; }
|
|
|
|
MOCKABLE_VIRTUAL int makeBOsResident(OsContext *osContext, uint32_t vmHandleId, std::vector<BufferObject *> *bufferObjects, bool bind);
|
|
MOCKABLE_VIRTUAL int bindBO(BufferObject *bo, OsContext *osContext, uint32_t vmHandleId, std::vector<BufferObject *> *bufferObjects, bool bind);
|
|
MOCKABLE_VIRTUAL int bindBOs(OsContext *osContext, uint32_t vmHandleId, std::vector<BufferObject *> *bufferObjects, bool bind);
|
|
MOCKABLE_VIRTUAL void registerBOBindExtHandle(Drm *drm);
|
|
void freeRegisteredBOBindExtHandles(Drm *drm);
|
|
void linkWithRegisteredHandle(uint32_t handle);
|
|
MOCKABLE_VIRTUAL void markForCapture();
|
|
MOCKABLE_VIRTUAL bool shouldAllocationPageFault(const Drm *drm);
|
|
void registerMemoryToUnmap(void *pointer, size_t size, MemoryUnmapFunction unmapFunction);
|
|
|
|
protected:
|
|
BufferObjects bufferObjects{};
|
|
StackVec<uint32_t, 1> registeredBoBindHandles;
|
|
MemAdviseFlags enabledMemAdviseFlags{};
|
|
StackVec<MemoryToUnmap, 1> memoryToUnmap;
|
|
uint32_t numHandles = 0u;
|
|
|
|
void *mmapPtr = nullptr;
|
|
size_t mmapSize = 0u;
|
|
};
|
|
} // namespace NEO
|