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 55 56 57 58 59 60 61 62 63 64 65
|
/*
* Copyright (C) 2020 Intel Corporation
*
* SPDX-License-Identifier: MIT
*
*/
#include "shared/source/program/program_info.h"
#include "opencl/source/program/kernel_info.h"
#include "gmock/gmock.h"
#include "gtest/gtest.h"
TEST(ProgramInfoTests, WhenPrepareLinkerInputStorageGetsCalledTwiceThenLinkerInputStorageIsReused) {
NEO::ProgramInfo programInfo;
EXPECT_EQ(nullptr, programInfo.linkerInput);
programInfo.prepareLinkerInputStorage();
EXPECT_NE(nullptr, programInfo.linkerInput);
auto prevLinkerInput = programInfo.linkerInput.get();
programInfo.prepareLinkerInputStorage();
EXPECT_EQ(prevLinkerInput, programInfo.linkerInput.get());
}
TEST(GetMaxInlineSlmNeeded, GivenProgramWithoutKernelsThenReturn0) {
NEO::ProgramInfo programInfo;
EXPECT_EQ(0U, NEO::getMaxInlineSlmNeeded(programInfo));
}
TEST(GetMaxInlineSlmNeeded, GivenProgramWithKernelsNotRequirignSlmThenReturn0) {
NEO::ProgramInfo programInfo;
programInfo.kernelInfos = {new NEO::KernelInfo(), new NEO::KernelInfo(), new NEO::KernelInfo()};
EXPECT_EQ(0U, NEO::getMaxInlineSlmNeeded(programInfo));
}
TEST(GetMaxInlineSlmNeeded, GivenProgramWithKernelsThenReturnMaxOfInlineSlmNeededByKernels) {
iOpenCL::SPatchAllocateLocalSurface slmTokens[3] = {};
slmTokens[0].TotalInlineLocalMemorySize = 16;
slmTokens[1].TotalInlineLocalMemorySize = 64;
slmTokens[2].TotalInlineLocalMemorySize = 32;
NEO::ProgramInfo programInfo;
programInfo.kernelInfos = {new NEO::KernelInfo(), new NEO::KernelInfo(), new NEO::KernelInfo()};
programInfo.kernelInfos[0]->patchInfo.localsurface = &slmTokens[0];
programInfo.kernelInfos[1]->patchInfo.localsurface = &slmTokens[1];
programInfo.kernelInfos[2]->patchInfo.localsurface = &slmTokens[2];
EXPECT_EQ(64U, NEO::getMaxInlineSlmNeeded(programInfo));
}
TEST(RequiresLocalMemoryWindowVA, GivenProgramWithoutKernelsThenReturnFalse) {
NEO::ProgramInfo programInfo;
EXPECT_FALSE(NEO::requiresLocalMemoryWindowVA(programInfo));
}
TEST(RequiresLocalMemoryWindowVA, GivenProgramWithKernelsNotLocalMemoryWindowVAThenReturnFalse) {
NEO::ProgramInfo programInfo;
programInfo.kernelInfos = {new NEO::KernelInfo(), new NEO::KernelInfo(), new NEO::KernelInfo()};
EXPECT_FALSE(NEO::requiresLocalMemoryWindowVA(programInfo));
}
TEST(RequiresLocalMemoryWindowVA, GivenProgramWithKernelsWhenSomeOfKernelRequireLocalMemoryWidnowVAThenReturnTrue) {
NEO::ProgramInfo programInfo;
programInfo.kernelInfos = {new NEO::KernelInfo(), new NEO::KernelInfo(), new NEO::KernelInfo()};
programInfo.kernelInfos[1]->workloadInfo.localMemoryStatelessWindowStartAddressOffset = 0U;
EXPECT_TRUE(NEO::requiresLocalMemoryWindowVA(programInfo));
}
|