/* * Copyright (C) 2018 Intel Corporation * * SPDX-License-Identifier: MIT * */ #include "mock/mock_encoder.h" #include "offline_compiler/decoder/binary_decoder.h" #include "unit_tests/helpers/test_files.h" #include "runtime/helpers/array_count.h" #include "gmock/gmock.h" #include namespace OCLRT { TEST(EncoderTests, WhenParsingValidListOfParametersThenReturnValueIsZero) { const char *argv[] = { "cloc", "asm", "-dump", "test_files/dump", "-out", "test_files/binary_gen.bin"}; MockEncoder encoder; EXPECT_EQ(0, encoder.validateInput(static_cast(arrayCount(argv)), argv)); } TEST(EncoderTests, WhenMissingParametersThenErrorCodeIsReturned) { const char *argv[] = { "cloc", "asm", "-dump", "test_files/dump", "-out"}; MockEncoder encoder; EXPECT_NE(0, encoder.validateInput(static_cast(arrayCount(argv)), argv)); } TEST(EncoderTests, GivenWrongParametersWhenParsingParametersThenErrorCodeIsReturne) { const char *argv[] = { "cloc", "asm", "-dump", "", "-out", "rasputin"}; MockEncoder encoder; EXPECT_NE(0, encoder.validateInput(static_cast(arrayCount(argv)), argv)); } TEST(EncoderTests, WhenTryingToCopyNonExistingFileThenErrorCodeIsReturned) { MockEncoder encoder; std::stringstream ss; int retVal = encoder.copyBinaryToBinary("test_files/non_existing.bin", ss); EXPECT_NE(0, retVal); } TEST(EncoderTests, WhenWritingValuesToBinaryThenValuesAreWrittenCorrectly) { MockEncoder encoder; std::stringstream in; std::stringstream out; in.str("255 255 255 255"); std::string s = in.str(); encoder.write(in, out); uint8_t val1; out.read(reinterpret_cast(&val1), sizeof(uint8_t)); ASSERT_EQ(static_cast(255), val1); encoder.write(in, out); uint16_t val2; out.read(reinterpret_cast(&val2), sizeof(uint16_t)); ASSERT_EQ(static_cast(255), val2); encoder.write(in, out); uint32_t val3; out.read(reinterpret_cast(&val3), sizeof(uint32_t)); ASSERT_EQ(static_cast(255), val3); encoder.write(in, out); uint64_t val4; out.read(reinterpret_cast(&val4), sizeof(uint64_t)); ASSERT_EQ(static_cast(255), val4); } TEST(EncoderTests, GivenProperPTMFileFormatWhenWritingToBinaryThenValuesAreWrittenCorrectly) { MockEncoder encoder; std::stringstream out; out.str(""); std::string s = "ProgramBinaryHeader:"; int retVal = encoder.writeDeviceBinary(s, out); ASSERT_EQ(0, retVal); ASSERT_EQ("", out.str()); s = "Hex 48 65 6c 6c 6f 20 77 6f 72 6c 64"; retVal = encoder.writeDeviceBinary(s, out); ASSERT_EQ(0, retVal); ASSERT_EQ("Hello world", out.str()); s = "1 CheckOne 220"; out.str(""); retVal = encoder.writeDeviceBinary(s, out); ASSERT_EQ(0, retVal); uint8_t val1; out.read(reinterpret_cast(&val1), sizeof(uint8_t)); ASSERT_EQ(static_cast(220), val1); s = "2 CheckTwo 2428"; out.str(""); retVal = encoder.writeDeviceBinary(s, out); ASSERT_EQ(0, retVal); uint16_t val2; out.read(reinterpret_cast(&val2), sizeof(uint16_t)); ASSERT_EQ(static_cast(2428), val2); s = "4 CheckThree 242806820"; out.str(""); retVal = encoder.writeDeviceBinary(s, out); ASSERT_EQ(retVal, 0); uint32_t val3; out.read(reinterpret_cast(&val3), sizeof(uint32_t)); ASSERT_EQ(static_cast(242806820), val3); s = "8 CheckFour 242806820"; out.str(""); retVal = encoder.writeDeviceBinary(s, out); ASSERT_EQ(retVal, 0); uint64_t val4; out.read(reinterpret_cast(&val4), sizeof(uint64_t)); ASSERT_EQ(static_cast(242806820), val4); } TEST(EncoderTests, GivenImproperPTMFIleFormatWhenWritingToBinaryThenErrorCodeIsReturned) { std::string s = "3 UnknownSize 41243"; std::stringstream out(""); MockEncoder encoder; int retVal = encoder.writeDeviceBinary(s, out); ASSERT_EQ(-1, retVal); } TEST(EncoderTests, GivenIncorrectPatchListSizeWhileCalculatingPatchListSizeThenPatchListSizeIsSetToCorrectValue) { std::vector ptmFile; ptmFile.push_back("ProgramBinaryHeader:"); ptmFile.push_back("\t4 Magic 1229870147"); ptmFile.push_back("\t4 PatchListSize 14"); ptmFile.push_back("PATCH_TOKEN_ALLOCATE_CONSTANT_MEMORY_SURFACE_PROGRAM_BINARY_INFO:"); ptmFile.push_back("\t8 Token 42"); ptmFile.push_back("\t4 Size 16"); ptmFile.push_back("\t1 ConstantBufferIndex 0"); ptmFile.push_back("\t2 InlineDataSize 14"); ptmFile.push_back("\tHex 48 65 6c 6c 6f 20 77 6f 72 6c 64 21 a 0"); ptmFile.push_back("Kernel #0"); MockEncoder encoder; encoder.calculatePatchListSizes(ptmFile); EXPECT_EQ("\t4 PatchListSize 29", ptmFile[2]); } TEST(EncoderTests, GivenCorrectPTMFileWhileProcessingThenCorrectBinaryIsExpected) { std::stringstream expectedBinary; uint8_t byte; uint32_t byte4; uint64_t byte8; byte4 = 1229870147; expectedBinary.write(reinterpret_cast(&byte4), sizeof(uint32_t)); byte4 = 1042; expectedBinary.write(reinterpret_cast(&byte4), sizeof(uint32_t)); byte4 = 12; expectedBinary.write(reinterpret_cast(&byte4), sizeof(uint32_t)); byte4 = 4; expectedBinary.write(reinterpret_cast(&byte4), sizeof(uint32_t)); byte4 = 1; expectedBinary.write(reinterpret_cast(&byte4), sizeof(uint32_t)); byte4 = 2; expectedBinary.write(reinterpret_cast(&byte4), sizeof(uint32_t)); byte4 = 18; expectedBinary.write(reinterpret_cast(&byte4), sizeof(uint32_t)); byte4 = 42; expectedBinary.write(reinterpret_cast(&byte4), sizeof(uint32_t)); byte4 = 16; expectedBinary.write(reinterpret_cast(&byte4), sizeof(uint32_t)); byte4 = 0; expectedBinary.write(reinterpret_cast(&byte4), sizeof(uint32_t)); byte4 = 2; expectedBinary.write(reinterpret_cast(&byte4), sizeof(uint32_t)); byte = 0x48; expectedBinary.write(reinterpret_cast(&byte), sizeof(uint8_t)); byte = 0x65; expectedBinary.write(reinterpret_cast(&byte), sizeof(uint8_t)); byte4 = 2316678223; expectedBinary.write(reinterpret_cast(&byte4), sizeof(uint32_t)); byte8 = 4988534869940066475; expectedBinary.write(reinterpret_cast(&byte8), sizeof(uint64_t)); byte4 = 12; expectedBinary.write(reinterpret_cast(&byte4), sizeof(uint32_t)); byte4 = 0; expectedBinary.write(reinterpret_cast(&byte4), sizeof(uint32_t)); byte4 = 0; expectedBinary.write(reinterpret_cast(&byte4), sizeof(uint32_t)); byte4 = 0; expectedBinary.write(reinterpret_cast(&byte4), sizeof(uint32_t)); byte4 = 0; expectedBinary.write(reinterpret_cast(&byte4), sizeof(uint32_t)); byte4 = 520; expectedBinary.write(reinterpret_cast(&byte4), sizeof(uint32_t)); std::string kernelName = "kernel"; expectedBinary.write(kernelName.c_str(), kernelName.length()); byte = 0; for (size_t i = kernelName.length(); i < 12; ++i) { expectedBinary.write(reinterpret_cast(&byte), sizeof(uint8_t)); } std::vector ptmFile; ptmFile.push_back("ProgramBinaryHeader:"); ptmFile.push_back("\t4 Magic 1229870147"); ptmFile.push_back("\t4 Version 1042"); ptmFile.push_back("\t4 Device 12"); ptmFile.push_back("\t4 GPUPointerSizeInBytes 4"); ptmFile.push_back("\t4 NumberOfKernels 1"); ptmFile.push_back("\t4 SteppingId 2"); ptmFile.push_back("\t4 PatchListSize 18"); ptmFile.push_back("PATCH_TOKEN_ALLOCATE_CONSTANT_MEMORY_SURFACE_PROGRAM_BINARY_INFO:"); ptmFile.push_back("\t4 Token 42"); ptmFile.push_back("\t4 Size 16"); ptmFile.push_back("\t4 ConstantBufferIndex 0"); ptmFile.push_back("\t4 InlineDataSize 2"); ptmFile.push_back("\tHex 48 65"); ptmFile.push_back("Kernel #0"); ptmFile.push_back("KernelBinaryHeader:"); ptmFile.push_back("\t4 CheckSum 2316678223"); ptmFile.push_back("\t8 ShaderHashCode 4988534869940066475"); ptmFile.push_back("\t4 KernelNameSize 12"); ptmFile.push_back("\t4 PatchListSize 0"); ptmFile.push_back("\t4 KernelHeapSize 0"); ptmFile.push_back("\t4 GeneralStateHeapSize 0"); ptmFile.push_back("\t4 DynamicStateHeapSize 0"); ptmFile.push_back("\t4 KernelUnpaddedSize 520"); ptmFile.push_back("\tKernelName kernel"); std::stringstream binary; MockEncoder encoder; int retVal = encoder.processBinary(ptmFile, binary); EXPECT_EQ(-1, retVal); EXPECT_EQ(expectedBinary.str(), binary.str()); } } // namespace OCLRT