mirror of
https://github.com/intel/compute-runtime.git
synced 2025-12-21 01:04:57 +08:00
Cleaned up files: level_zero/core/source/driver/driver.h level_zero/tools/source/sysman/fabric_port/windows/os_fabric_port_imp.h level_zero/tools/source/sysman/pci/os_pci.h shared/source/debug_settings/debug_settings_manager.h shared/source/gmm_helper/page_table_mngr.h shared/source/gmm_helper/windows/gmm_memory_base.h shared/source/kernel/kernel_arg_metadata.h shared/test/common/libult/linux/drm_mock.h shared/test/unit_test/fixtures/command_container_fixture.h shared/test/unit_test/fixtures/product_config_fixture.h shared/test/unit_test/helpers/simd_helper_tests_pvc_and_later.inl shared/test/unit_test/os_interface/hw_info_config_tests.h Related-To: NEO-5548 Signed-off-by: Warchulski, Jaroslaw <jaroslaw.warchulski@intel.com>
203 lines
5.9 KiB
C++
203 lines
5.9 KiB
C++
/*
|
|
* Copyright (C) 2020-2023 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: MIT
|
|
*
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include "shared/source/compiler_interface/tokenized_string.h"
|
|
#include "shared/source/utilities/const_stringref.h"
|
|
|
|
#include <cstdint>
|
|
#include <cstring>
|
|
#include <string>
|
|
#include <type_traits>
|
|
|
|
namespace NEO {
|
|
|
|
namespace KernelArgMetadata {
|
|
|
|
enum AccessQualifier : uint8_t {
|
|
AccessUnknown,
|
|
AccessNone,
|
|
AccessReadOnly,
|
|
AccessWriteOnly,
|
|
AccessReadWrite,
|
|
};
|
|
|
|
namespace AccessQualifierStrings {
|
|
inline constexpr ConstStringRef none = "NONE";
|
|
inline constexpr ConstStringRef readOnly = "read_only";
|
|
inline constexpr ConstStringRef writeOnly = "write_only";
|
|
inline constexpr ConstStringRef readWrite = "read_write";
|
|
inline constexpr ConstStringRef underscoreReadOnly = "__read_only";
|
|
inline constexpr ConstStringRef underscoreWriteOnly = "__write_only";
|
|
inline constexpr ConstStringRef underscoreReadWrite = "__read_write";
|
|
} // namespace AccessQualifierStrings
|
|
|
|
enum AddressSpaceQualifier : uint8_t {
|
|
AddrUnknown,
|
|
AddrGlobal,
|
|
AddrLocal,
|
|
AddrPrivate,
|
|
AddrConstant
|
|
};
|
|
|
|
namespace AddressSpaceQualifierStrings {
|
|
inline constexpr ConstStringRef addrGlobal = "__global";
|
|
inline constexpr ConstStringRef addrLocal = "__local";
|
|
inline constexpr ConstStringRef addrPrivate = "__private";
|
|
inline constexpr ConstStringRef addrConstant = "__constant";
|
|
inline constexpr ConstStringRef addrNotSpecified = "not_specified";
|
|
} // namespace AddressSpaceQualifierStrings
|
|
|
|
constexpr AccessQualifier parseAccessQualifier(ConstStringRef str) {
|
|
using namespace AccessQualifierStrings;
|
|
if (str.empty() || (none == str)) {
|
|
return AccessNone;
|
|
}
|
|
|
|
if (str.length() < 3) {
|
|
return AccessUnknown;
|
|
}
|
|
|
|
ConstStringRef strNoUnderscore = ('_' == str[0]) ? ConstStringRef(str.data() + 2, str.length() - 2) : str;
|
|
static_assert(writeOnly[0] != readOnly[0], "");
|
|
static_assert(writeOnly[0] != readWrite[0], "");
|
|
if (strNoUnderscore[0] == writeOnly[0]) {
|
|
return (writeOnly == strNoUnderscore) ? AccessWriteOnly : AccessUnknown;
|
|
}
|
|
|
|
if (readOnly == strNoUnderscore) {
|
|
return AccessReadOnly;
|
|
}
|
|
|
|
return (readWrite == strNoUnderscore) ? AccessReadWrite : AccessUnknown;
|
|
}
|
|
|
|
constexpr AddressSpaceQualifier parseAddressSpace(ConstStringRef str) {
|
|
using namespace AddressSpaceQualifierStrings;
|
|
if (str.empty()) {
|
|
return AddrGlobal;
|
|
}
|
|
|
|
if (str.length() < 3) {
|
|
return AddrUnknown;
|
|
}
|
|
|
|
switch (str[2]) {
|
|
default:
|
|
return AddrUnknown;
|
|
case addrNotSpecified[2]:
|
|
return (str == addrNotSpecified) ? AddrPrivate : AddrUnknown;
|
|
case addrGlobal[2]:
|
|
return (str == addrGlobal) ? AddrGlobal : AddrUnknown;
|
|
case addrLocal[2]:
|
|
return (str == addrLocal) ? AddrLocal : AddrUnknown;
|
|
case addrPrivate[2]:
|
|
return (str == addrPrivate) ? AddrPrivate : AddrUnknown;
|
|
case addrConstant[2]:
|
|
return (str == addrConstant) ? AddrConstant : AddrUnknown;
|
|
}
|
|
}
|
|
|
|
union TypeQualifiers {
|
|
uint8_t packed = 0U;
|
|
struct {
|
|
bool constQual : 1;
|
|
bool volatileQual : 1;
|
|
bool restrictQual : 1;
|
|
bool pipeQual : 1;
|
|
bool unknownQual : 1;
|
|
};
|
|
bool empty() const {
|
|
return 0U == packed;
|
|
}
|
|
};
|
|
|
|
namespace TypeQualifierStrings {
|
|
inline constexpr ConstStringRef qualConst = "const";
|
|
inline constexpr ConstStringRef qualVolatile = "volatile";
|
|
inline constexpr ConstStringRef qualRestrict = "restrict";
|
|
inline constexpr ConstStringRef qualPipe = "pipe";
|
|
} // namespace TypeQualifierStrings
|
|
|
|
inline TypeQualifiers parseTypeQualifiers(ConstStringRef str) {
|
|
using namespace TypeQualifierStrings;
|
|
TypeQualifiers ret = {};
|
|
auto tokenized = CompilerOptions::tokenize(str);
|
|
for (const auto &tok : tokenized) {
|
|
bool knownQualifier = true;
|
|
switch (tok[0]) {
|
|
default:
|
|
knownQualifier = false;
|
|
break;
|
|
case qualConst[0]:
|
|
knownQualifier = (qualConst == tok);
|
|
ret.constQual |= knownQualifier;
|
|
break;
|
|
case qualVolatile[0]:
|
|
knownQualifier = (qualVolatile == tok);
|
|
ret.volatileQual |= knownQualifier;
|
|
break;
|
|
case qualRestrict[0]:
|
|
knownQualifier = (qualRestrict == tok);
|
|
ret.restrictQual |= knownQualifier;
|
|
break;
|
|
case qualPipe[0]:
|
|
knownQualifier = (qualPipe == tok);
|
|
ret.pipeQual |= knownQualifier;
|
|
break;
|
|
}
|
|
ret.unknownQual |= !knownQualifier;
|
|
}
|
|
return ret;
|
|
}
|
|
|
|
} // namespace KernelArgMetadata
|
|
|
|
inline std::string parseLimitedString(const char *str, size_t maxSize) {
|
|
std::string ret{str, str + maxSize};
|
|
size_t minSize = strlen(ret.c_str());
|
|
ret.assign(str, minSize);
|
|
return ret;
|
|
}
|
|
|
|
struct ArgTypeTraits {
|
|
ArgTypeTraits() {
|
|
accessQualifier = KernelArgMetadata::AccessUnknown;
|
|
addressQualifier = KernelArgMetadata::AddrGlobal;
|
|
}
|
|
uint16_t argByValSize = 0U;
|
|
struct {
|
|
std::underlying_type_t<KernelArgMetadata::AccessQualifier> accessQualifier : 4;
|
|
std::underlying_type_t<KernelArgMetadata::AddressSpaceQualifier> addressQualifier : 4;
|
|
};
|
|
KernelArgMetadata::TypeQualifiers typeQualifiers;
|
|
|
|
KernelArgMetadata::AccessQualifier getAccessQualifier() const {
|
|
return static_cast<KernelArgMetadata::AccessQualifier>(accessQualifier);
|
|
}
|
|
|
|
KernelArgMetadata::AddressSpaceQualifier getAddressQualifier() const {
|
|
return static_cast<KernelArgMetadata::AddressSpaceQualifier>(addressQualifier);
|
|
}
|
|
};
|
|
|
|
namespace {
|
|
inline constexpr auto ArgTypeMetadataSize = sizeof(ArgTypeTraits);
|
|
static_assert(ArgTypeMetadataSize <= 4, "Keep it small");
|
|
} // namespace
|
|
|
|
struct ArgTypeMetadataExtended {
|
|
std::string argName;
|
|
std::string type;
|
|
std::string accessQualifier;
|
|
std::string addressQualifier;
|
|
std::string typeQualifiers;
|
|
};
|
|
|
|
} // namespace NEO
|