compute-runtime/unit_tests/program/process_debug_data_tests.cpp

98 lines
4.1 KiB
C++

/*
* Copyright (C) 2018-2019 Intel Corporation
*
* SPDX-License-Identifier: MIT
*
*/
#include "test.h"
#include "unit_tests/mocks/mock_program.h"
#include "unit_tests/program/program_tests.h"
#include "program_debug_data.h"
#include <memory>
using namespace iOpenCL;
using namespace NEO;
TEST_F(ProgramTests, GivenProgramWithDebugDataForTwoKernelsWhenPorcessedThenDebugDataIsSetInKernelInfos) {
const char kernelName1[] = "kernel1";
const char kernelName2[] = "kernel2";
uint32_t kernelNameSize = static_cast<uint32_t>(sizeof(kernelName1));
uint32_t genIsaSize = 8;
uint32_t visaSize = 8;
size_t debugDataSize = sizeof(SProgramDebugDataHeaderIGC) + 2 * (sizeof(SKernelDebugDataHeaderIGC) + kernelNameSize + genIsaSize + visaSize);
std::unique_ptr<char[]> debugData(new char[debugDataSize]);
auto kernelInfo1 = new KernelInfo();
kernelInfo1->name = kernelName1;
auto kernelInfo2 = new KernelInfo();
kernelInfo2->name = kernelName2;
auto program = std::make_unique<MockProgram>(*pDevice->getExecutionEnvironment());
SProgramDebugDataHeaderIGC *programDebugHeader = reinterpret_cast<SProgramDebugDataHeaderIGC *>(debugData.get());
programDebugHeader->NumberOfKernels = 2;
SKernelDebugDataHeaderIGC *kernelDebugHeader = reinterpret_cast<SKernelDebugDataHeaderIGC *>(ptrOffset(programDebugHeader, sizeof(SProgramDebugDataHeaderIGC)));
kernelDebugHeader->KernelNameSize = kernelNameSize;
kernelDebugHeader->SizeGenIsaDbgInBytes = genIsaSize;
kernelDebugHeader->SizeVisaDbgInBytes = visaSize;
char *kernelName = reinterpret_cast<char *>(ptrOffset(kernelDebugHeader, sizeof(SKernelDebugDataHeaderIGC)));
memcpy_s(kernelName, kernelNameSize, kernelName1, kernelNameSize);
char *vIsa1 = (ptrOffset(kernelName, kernelNameSize));
memset(vIsa1, 10, visaSize);
char *genIsa1 = (ptrOffset(vIsa1, visaSize));
memset(genIsa1, 20, genIsaSize);
kernelDebugHeader = reinterpret_cast<SKernelDebugDataHeaderIGC *>(ptrOffset(vIsa1, genIsaSize + visaSize));
kernelDebugHeader->KernelNameSize = kernelNameSize;
kernelDebugHeader->SizeGenIsaDbgInBytes = genIsaSize;
kernelDebugHeader->SizeVisaDbgInBytes = visaSize;
kernelName = reinterpret_cast<char *>(ptrOffset(kernelDebugHeader, sizeof(SKernelDebugDataHeaderIGC)));
memcpy_s(kernelName, kernelNameSize, kernelName2, kernelNameSize);
char *vIsa2 = (ptrOffset(kernelName, kernelNameSize));
memset(vIsa2, 10, visaSize);
char *genIsa2 = (ptrOffset(vIsa2, visaSize));
memset(genIsa2, 20, genIsaSize);
program->storeDebugData(debugData.get(), debugDataSize);
program->addKernelInfo(kernelInfo1);
program->addKernelInfo(kernelInfo2);
program->processDebugData();
size_t programDebugDataSize = 0;
EXPECT_EQ(genIsaSize, kernelInfo1->debugData.genIsaSize);
EXPECT_EQ(visaSize, kernelInfo1->debugData.vIsaSize);
EXPECT_EQ(ptrDiff(vIsa1, debugData.get()), ptrDiff(kernelInfo1->debugData.vIsa, program->getDebugDataBinary(programDebugDataSize)));
EXPECT_EQ(ptrDiff(genIsa1, debugData.get()), ptrDiff(kernelInfo1->debugData.genIsa, program->getDebugDataBinary(programDebugDataSize)));
EXPECT_EQ(genIsaSize, kernelInfo2->debugData.genIsaSize);
EXPECT_EQ(visaSize, kernelInfo2->debugData.vIsaSize);
EXPECT_EQ(ptrDiff(vIsa2, debugData.get()), ptrDiff(kernelInfo2->debugData.vIsa, program->getDebugDataBinary(programDebugDataSize)));
EXPECT_EQ(ptrDiff(genIsa2, debugData.get()), ptrDiff(kernelInfo2->debugData.genIsa, program->getDebugDataBinary(programDebugDataSize)));
}
TEST_F(ProgramTests, GivenProgramWithoutDebugDataWhenPorcessedThenDebugDataIsNotSetInKernelInfo) {
const char kernelName1[] = "kernel1";
auto kernelInfo1 = new KernelInfo();
kernelInfo1->name = kernelName1;
auto program = std::make_unique<MockProgram>(*pDevice->getExecutionEnvironment());
program->addKernelInfo(kernelInfo1);
program->processDebugData();
size_t programDebugDataSize = 0;
EXPECT_EQ(0u, kernelInfo1->debugData.genIsaSize);
EXPECT_EQ(0u, kernelInfo1->debugData.vIsaSize);
EXPECT_EQ(nullptr, program->getDebugDataBinary(programDebugDataSize));
}