1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
|
/*
* Copyright (C) 2020-2022 Intel Corporation
*
* SPDX-License-Identifier: MIT
*
*/
#include "shared/source/program/program_info.h"
#include "shared/source/device/device.h"
#include "shared/source/program/kernel_info.h"
namespace NEO {
ProgramInfo::~ProgramInfo() {
for (auto &kernelInfo : kernelInfos) {
delete kernelInfo;
}
kernelInfos.clear();
}
size_t getMaxInlineSlmNeeded(const ProgramInfo &programInfo) {
uint32_t ret = 0U;
for (const auto &kernelInfo : programInfo.kernelInfos) {
ret = std::max(ret, kernelInfo->kernelDescriptor.kernelAttributes.slmInlineSize);
}
return ret;
}
bool requiresLocalMemoryWindowVA(const ProgramInfo &programInfo) {
for (const auto &kernelInfo : programInfo.kernelInfos) {
if (isValidOffset(kernelInfo->kernelDescriptor.payloadMappings.implicitArgs.localMemoryStatelessWindowStartAddres)) {
return true;
}
}
return false;
}
bool isRebuiltToPatchtokensRequired(Device *neoDevice, ArrayRef<const uint8_t> archive, std::string &optionsString, bool isBuiltin) {
if (isBuiltin) {
return false;
}
auto isSourceLevelDebuggerActive = (nullptr != neoDevice->getSourceLevelDebugger());
auto isZebinFormat = NEO::isDeviceBinaryFormat<NEO::DeviceBinaryFormat::Zebin>(archive);
if (isSourceLevelDebuggerActive && isZebinFormat) {
auto pos = optionsString.find(NEO::CompilerOptions::allowZebin.str());
optionsString.erase(pos, pos + NEO::CompilerOptions::allowZebin.length());
optionsString += " " + NEO::CompilerOptions::disableZebin.str();
return true;
}
return false;
}
} // namespace NEO
|