2020-01-12 01:25:26 +08:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2020 Intel Corporation
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2020-02-24 05:44:01 +08:00
|
|
|
#include "shared/source/program/program_info.h"
|
2020-01-12 01:25:26 +08:00
|
|
|
|
2020-02-23 05:50:57 +08:00
|
|
|
#include "opencl/source/program/kernel_info.h"
|
2020-01-12 01:25:26 +08:00
|
|
|
|
|
|
|
namespace NEO {
|
|
|
|
|
|
|
|
ProgramInfo::~ProgramInfo() {
|
|
|
|
for (auto &kernelInfo : kernelInfos) {
|
|
|
|
delete kernelInfo;
|
|
|
|
}
|
|
|
|
kernelInfos.clear();
|
|
|
|
}
|
|
|
|
|
2020-01-26 02:18:48 +08:00
|
|
|
size_t getMaxInlineSlmNeeded(const ProgramInfo &programInfo) {
|
|
|
|
uint32_t ret = 0U;
|
|
|
|
for (const auto &kernelInfo : programInfo.kernelInfos) {
|
|
|
|
if (nullptr == kernelInfo->patchInfo.localsurface) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
ret = std::max(ret, kernelInfo->patchInfo.localsurface->TotalInlineLocalMemorySize);
|
|
|
|
}
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool requiresLocalMemoryWindowVA(const ProgramInfo &programInfo) {
|
|
|
|
for (const auto &kernelInfo : programInfo.kernelInfos) {
|
|
|
|
if (WorkloadInfo::undefinedOffset != kernelInfo->workloadInfo.localMemoryStatelessWindowStartAddressOffset) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2020-01-12 01:25:26 +08:00
|
|
|
} // namespace NEO
|