mirror of
https://github.com/intel/compute-runtime.git
synced 2025-09-15 13:01:45 +08:00
Reorganization directory structure [2/n]
Change-Id: I47962d17d755e80dcd9476e1ed75560f433f6115
This commit is contained in:

committed by
Jaroslaw Chodor

parent
d015d3633f
commit
e8852a68c4
95
opencl/test/unit_test/program/process_debug_data_tests.cpp
Normal file
95
opencl/test/unit_test/program/process_debug_data_tests.cpp
Normal file
@ -0,0 +1,95 @@
|
||||
/*
|
||||
* Copyright (C) 2018-2020 Intel Corporation
|
||||
*
|
||||
* SPDX-License-Identifier: MIT
|
||||
*
|
||||
*/
|
||||
|
||||
#include "test.h"
|
||||
|
||||
#include "mocks/mock_program.h"
|
||||
#include "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->debugData = makeCopy(debugData.get(), debugDataSize);
|
||||
program->debugDataSize = debugDataSize;
|
||||
|
||||
program->addKernelInfo(kernelInfo1);
|
||||
program->addKernelInfo(kernelInfo2);
|
||||
|
||||
program->processDebugData();
|
||||
EXPECT_EQ(genIsaSize, kernelInfo1->debugData.genIsaSize);
|
||||
EXPECT_EQ(visaSize, kernelInfo1->debugData.vIsaSize);
|
||||
EXPECT_EQ(ptrDiff(vIsa1, debugData.get()), ptrDiff(kernelInfo1->debugData.vIsa, program->getDebugData()));
|
||||
EXPECT_EQ(ptrDiff(genIsa1, debugData.get()), ptrDiff(kernelInfo1->debugData.genIsa, program->getDebugData()));
|
||||
|
||||
EXPECT_EQ(genIsaSize, kernelInfo2->debugData.genIsaSize);
|
||||
EXPECT_EQ(visaSize, kernelInfo2->debugData.vIsaSize);
|
||||
EXPECT_EQ(ptrDiff(vIsa2, debugData.get()), ptrDiff(kernelInfo2->debugData.vIsa, program->getDebugData()));
|
||||
EXPECT_EQ(ptrDiff(genIsa2, debugData.get()), ptrDiff(kernelInfo2->debugData.genIsa, program->getDebugData()));
|
||||
}
|
||||
|
||||
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();
|
||||
|
||||
EXPECT_EQ(0u, kernelInfo1->debugData.genIsaSize);
|
||||
EXPECT_EQ(0u, kernelInfo1->debugData.vIsaSize);
|
||||
EXPECT_EQ(nullptr, program->getDebugData());
|
||||
}
|
Reference in New Issue
Block a user