compute-runtime/shared/test/common/mocks/mock_cif.h

223 lines
6.8 KiB
C++

/*
* Copyright (C) 2018-2021 Intel Corporation
*
* SPDX-License-Identifier: MIT
*
*/
#pragma once
#include "cif/builtins/memory/buffer/buffer.h"
#include "cif/common/cif.h"
#include "cif/common/cif_main.h"
#include "cif/common/id.h"
#include <map>
namespace NEO {
extern bool failCreateCifMain;
using CreatorFuncT = CIF::ICIF *(*)(CIF::InterfaceId_t intId, CIF::Version_t version);
template <typename BaseType = CIF::ICIF>
struct MockCIF : BaseType {
void Release() override { // NOLINT(readability-identifier-naming)
auto prev = refCount--;
assert(prev >= 1);
if (prev == 1) {
delete this;
}
}
void Retain() override { // NOLINT(readability-identifier-naming)
++refCount;
}
uint32_t GetRefCount() const override { // NOLINT(readability-identifier-naming)
return refCount;
}
CIF::Version_t GetEnabledVersion() const override { // NOLINT(readability-identifier-naming)
return 1;
}
bool GetSupportedVersions(CIF::InterfaceId_t intId, CIF::Version_t &verMin, // NOLINT(readability-identifier-naming)
CIF::Version_t &verMax) const override {
verMin = 1;
verMax = CIF::MaxVersion;
return true; // by default : no sub-interface are supported
}
uint32_t refCount = 1u;
};
struct MockCIFMain : MockCIF<CIF::CIFMain> {
template <typename InterfaceT>
static void setGlobalCreatorFunc(CreatorFuncT func) {
globalCreators[InterfaceT::GetInterfaceId()] = func;
}
template <typename InterfaceT>
void setDefaultCreatorFunc(CreatorFuncT func) {
defaultCreators[InterfaceT::GetInterfaceId()] = func;
}
template <typename InterfaceT>
static CreatorFuncT getGlobalCreatorFunc() {
auto it = globalCreators.find(InterfaceT::GetInterfaceId());
if (it == globalCreators.end()) {
return nullptr;
}
return it->second;
}
template <typename InterfaceT>
static void removeGlobalCreatorFunc() {
auto it = globalCreators.find(InterfaceT::GetInterfaceId());
if (it == globalCreators.end()) {
return;
}
globalCreators.erase(it);
}
static void clearGlobalCreatorFuncs() {
decltype(globalCreators) emptyCreators;
globalCreators.swap(emptyCreators);
}
static std::map<CIF::InterfaceId_t, CreatorFuncT> globalCreators;
MockCIFMain();
CIF::Version_t GetBinaryVersion() const override { // NOLINT(readability-identifier-naming)
return 1;
}
CIF::ICIF *CreateInterfaceImpl(CIF::InterfaceId_t intId, CIF::Version_t version) override; // NOLINT(readability-identifier-naming)
CIF::InterfaceId_t FindIncompatibleImpl(CIF::InterfaceId_t entryPointInterface, CIF::CompatibilityDataHandle handle) const override { // NOLINT(readability-identifier-naming)
if (globalCreators.find(entryPointInterface) != globalCreators.end()) {
return CIF::InvalidInterface;
}
if (defaultCreators.find(entryPointInterface) != defaultCreators.end()) {
return CIF::InvalidInterface;
}
return entryPointInterface;
}
bool FindSupportedVersionsImpl(CIF::InterfaceId_t entryPointInterface, CIF::InterfaceId_t interfaceToFind, CIF::Version_t &verMin, CIF::Version_t &verMax) const override { // NOLINT(readability-identifier-naming)
if (globalCreators.find(entryPointInterface) != globalCreators.end()) {
verMin = verMax = 1;
return true;
}
if (defaultCreators.find(entryPointInterface) != defaultCreators.end()) {
verMin = verMax = 1;
return true;
}
return false;
}
std::map<CIF::InterfaceId_t, CreatorFuncT> defaultCreators;
};
struct MockCIFBuffer : MockCIF<CIF::Builtins::BufferSimple> {
MockCIFBuffer();
static CIF::ICIF *Create(CIF::InterfaceId_t intId, CIF::Version_t version); // NOLINT(readability-identifier-naming)
static bool failAllocations;
void SetAllocator(CIF::Builtins::AllocatorT allocator, CIF::Builtins::DeallocatorT deallocator, // NOLINT(readability-identifier-naming)
CIF::Builtins::ReallocatorT reallocator) override {
// unsupported in mock
}
void SetUnderlyingStorage(void *memory, size_t size, CIF::Builtins::DeallocatorT deallocator) override { // NOLINT(readability-identifier-naming)
if ((memory == nullptr) || (size == 0)) {
data.clear();
return;
}
data.assign((char *)memory, ((char *)memory) + size);
}
void SetUnderlyingStorage(const void *memory, size_t size) override { // NOLINT(readability-identifier-naming)
if ((memory == nullptr) || (size == 0)) {
data.clear();
return;
}
data.assign((char *)memory, ((char *)memory) + size);
}
void *DetachAllocation() override { // NOLINT(readability-identifier-naming)
// unsupported in mock
return nullptr;
}
const void *GetMemoryRaw() const override { // NOLINT(readability-identifier-naming)
if (data.size() > 0) {
return data.data();
} else {
return nullptr;
}
}
void *GetMemoryRawWriteable() override { // NOLINT(readability-identifier-naming)
if (data.size() > 0) {
return data.data();
} else {
return nullptr;
}
}
size_t GetSizeRaw() const override { // NOLINT(readability-identifier-naming)
return data.size();
}
size_t GetCapacityRaw() const override { // NOLINT(readability-identifier-naming)
return data.capacity();
}
bool Resize(size_t newSize) override { // NOLINT(readability-identifier-naming)
data.resize(newSize);
return true;
}
bool Reserve(size_t newCapacity) override { // NOLINT(readability-identifier-naming)
data.reserve(newCapacity);
return true;
}
void Clear() override { // NOLINT(readability-identifier-naming)
data.clear();
}
void Deallocate() override { // NOLINT(readability-identifier-naming)
std::vector<char> rhs;
rhs.swap(data);
}
bool AlignUp(uint32_t alignment) override { // NOLINT(readability-identifier-naming)
auto rest = data.size() & alignment;
if (rest != 0) {
data.resize(data.size() + alignment - rest);
}
return true;
}
bool PushBackRawBytes(const void *newData, size_t size) override { // NOLINT(readability-identifier-naming)
if ((newData == nullptr) || (size == 0)) {
return true;
}
data.insert(data.end(), (char *)newData, ((char *)newData) + size);
return true;
}
bool IsConst() const override { // NOLINT(readability-identifier-naming)
return false;
}
std::vector<char> data;
};
} // namespace NEO