mirror of
https://github.com/intel/compute-runtime.git
synced 2025-12-30 01:35:20 +08:00
Store program binary type per device
Related-To: NEO-5001 Signed-off-by: Mateusz Jablonski <mateusz.jablonski@intel.com>
This commit is contained in:
committed by
Compute-Runtime-Automation
parent
62ea57ff61
commit
0aec0bdde4
@@ -1566,7 +1566,7 @@ TEST_F(ProgramWithDebugSymbolsTests, GivenProgramCreatedWithDashGOptionWhenGetti
|
||||
pProgram->buildInfos[rootDeviceIndex].packedDeviceBinary.reset();
|
||||
pProgram->buildInfos[rootDeviceIndex].packedDeviceBinarySize = 0U;
|
||||
|
||||
retVal = pProgram->packDeviceBinary(rootDeviceIndex);
|
||||
retVal = pProgram->packDeviceBinary(*pClDevice);
|
||||
|
||||
retVal = pProgram->getInfo(
|
||||
CL_PROGRAM_BINARY_SIZES,
|
||||
@@ -1847,7 +1847,7 @@ TEST_F(ProgramTests, WhenCreatingProgramFromGenBinaryThenSuccessIsReturned) {
|
||||
EXPECT_NE(nullptr, pProgram);
|
||||
EXPECT_EQ(CL_SUCCESS, retVal);
|
||||
|
||||
EXPECT_EQ((uint32_t)CL_PROGRAM_BINARY_TYPE_EXECUTABLE, (uint32_t)pProgram->getProgramBinaryType());
|
||||
EXPECT_EQ((uint32_t)CL_PROGRAM_BINARY_TYPE_EXECUTABLE, (uint32_t)pProgram->getProgramBinaryType(pClDevice));
|
||||
EXPECT_TRUE(pProgram->getIsBuiltIn());
|
||||
|
||||
cl_device_id deviceId = pContext->getDevice(0);
|
||||
@@ -1865,7 +1865,7 @@ TEST_F(ProgramTests, GivenRetValNullPointerWhenCreatingProgramFromGenBinaryThenS
|
||||
|
||||
Program *pProgram = Program::createBuiltInFromGenBinary(pContext, pContext->getDevices(), binary, size, nullptr);
|
||||
EXPECT_NE(nullptr, pProgram);
|
||||
EXPECT_EQ((uint32_t)CL_PROGRAM_BINARY_TYPE_EXECUTABLE, (uint32_t)pProgram->getProgramBinaryType());
|
||||
EXPECT_EQ((uint32_t)CL_PROGRAM_BINARY_TYPE_EXECUTABLE, (uint32_t)pProgram->getProgramBinaryType(pClDevice));
|
||||
|
||||
cl_device_id deviceId = pContext->getDevice(0);
|
||||
cl_build_status status = 0;
|
||||
@@ -1884,7 +1884,7 @@ TEST_F(ProgramTests, GivenNullContextWhenCreatingProgramFromGenBinaryThenSuccess
|
||||
Program *pProgram = Program::createBuiltInFromGenBinary(nullptr, toClDeviceVector(*pClDevice), binary, size, &retVal);
|
||||
EXPECT_NE(nullptr, pProgram);
|
||||
EXPECT_EQ(CL_SUCCESS, retVal);
|
||||
EXPECT_EQ((uint32_t)CL_PROGRAM_BINARY_TYPE_EXECUTABLE, (uint32_t)pProgram->getProgramBinaryType());
|
||||
EXPECT_EQ((uint32_t)CL_PROGRAM_BINARY_TYPE_EXECUTABLE, (uint32_t)pProgram->getProgramBinaryType(pClDevice));
|
||||
|
||||
cl_build_status status = 0;
|
||||
pProgram->getBuildInfo(pClDevice, CL_PROGRAM_BUILD_STATUS,
|
||||
@@ -1923,7 +1923,7 @@ TEST_F(ProgramTests, GivenNoCompilerInterfaceRootDeviceEnvironmentWhenRebuilding
|
||||
EXPECT_NE(0u, binarySize);
|
||||
|
||||
// Create program from loaded binary
|
||||
cl_int retVal = program->createProgramFromBinary(pBinary.get(), binarySize, rootDeviceIndex);
|
||||
cl_int retVal = program->createProgramFromBinary(pBinary.get(), binarySize, *pClDevice);
|
||||
EXPECT_EQ(CL_SUCCESS, retVal);
|
||||
|
||||
// Ask to rebuild program from its IR binary - it should fail (no Compiler Interface)
|
||||
@@ -1975,7 +1975,7 @@ TEST_F(ProgramTests, GivenFailingGenBinaryProgramWhenRebuildingBinaryThenInvalid
|
||||
EXPECT_NE(0u, binarySize);
|
||||
|
||||
// Create program from loaded binary
|
||||
retVal = program->createProgramFromBinary(pBinary.get(), binarySize, rootDeviceIndex);
|
||||
retVal = program->createProgramFromBinary(pBinary.get(), binarySize, *pClDevice);
|
||||
EXPECT_EQ(CL_SUCCESS, retVal);
|
||||
|
||||
// Ask to rebuild program from its IR binary - it should fail (simulated invalid binary)
|
||||
@@ -2146,7 +2146,7 @@ struct CreateProgramFromBinaryMock : public MockProgram {
|
||||
using MockProgram::MockProgram;
|
||||
|
||||
cl_int createProgramFromBinary(const void *pBinary,
|
||||
size_t binarySize, uint32_t rootDeviceIndex) override {
|
||||
size_t binarySize, ClDevice &clDevice) override {
|
||||
this->irBinary.reset(new char[binarySize]);
|
||||
this->irBinarySize = binarySize;
|
||||
this->isSpirV = spirv;
|
||||
@@ -2595,7 +2595,7 @@ TEST(CreateProgramFromBinaryTests, givenBinaryProgramBuiltInWhenKernelRebulildIs
|
||||
EXPECT_EQ(CL_SUCCESS, retVal);
|
||||
|
||||
auto rootDeviceIndex = clDevice->getRootDeviceIndex();
|
||||
retVal = pProgram->createProgramFromBinary(programTokens.storage.data(), programTokens.storage.size(), rootDeviceIndex);
|
||||
retVal = pProgram->createProgramFromBinary(programTokens.storage.data(), programTokens.storage.size(), *clDevice);
|
||||
EXPECT_EQ(CL_SUCCESS, retVal);
|
||||
EXPECT_EQ(nullptr, pProgram->buildInfos[rootDeviceIndex].unpackedDeviceBinary.get());
|
||||
EXPECT_EQ(0U, pProgram->buildInfos[rootDeviceIndex].unpackedDeviceBinarySize);
|
||||
@@ -2640,7 +2640,7 @@ TEST(CreateProgramFromBinaryTests, givenBinaryProgramWhenKernelRebulildIsNotForc
|
||||
EXPECT_EQ(CL_SUCCESS, retVal);
|
||||
|
||||
auto rootDeviceIndex = clDevice->getRootDeviceIndex();
|
||||
retVal = pProgram->createProgramFromBinary(programTokens.storage.data(), programTokens.storage.size(), rootDeviceIndex);
|
||||
retVal = pProgram->createProgramFromBinary(programTokens.storage.data(), programTokens.storage.size(), *clDevice);
|
||||
EXPECT_EQ(CL_SUCCESS, retVal);
|
||||
EXPECT_NE(nullptr, reinterpret_cast<uint8_t *>(pProgram->buildInfos[rootDeviceIndex].unpackedDeviceBinary.get()));
|
||||
EXPECT_EQ(programTokens.storage.size(), pProgram->buildInfos[rootDeviceIndex].unpackedDeviceBinarySize);
|
||||
|
||||
Reference in New Issue
Block a user