2019-11-10 02:02:25 +08:00
|
|
|
/*
|
2020-01-14 21:32:11 +08:00
|
|
|
* Copyright (C) 2019-2020 Intel Corporation
|
2019-11-10 02:02:25 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2020-02-25 16:55:13 +08:00
|
|
|
#include "shared/source/helpers/vec.h"
|
2020-03-31 13:43:07 +08:00
|
|
|
#include "shared/test/unit_test/cmd_parse/hw_parse.h"
|
2020-02-24 08:01:38 +08:00
|
|
|
#include "shared/test/unit_test/helpers/debug_manager_state_restore.h"
|
2020-06-19 22:33:53 +08:00
|
|
|
#include "shared/test/unit_test/helpers/variable_backup.h"
|
2020-04-02 15:35:50 +08:00
|
|
|
#include "shared/test/unit_test/mocks/mock_device.h"
|
2020-02-24 08:01:38 +08:00
|
|
|
#include "shared/test/unit_test/utilities/base_object_utils.h"
|
2020-02-24 17:22:30 +08:00
|
|
|
|
2020-02-23 05:50:57 +08:00
|
|
|
#include "opencl/source/event/user_event.h"
|
2020-03-12 17:49:20 +08:00
|
|
|
#include "opencl/test/unit_test/helpers/unit_test_helper.h"
|
2020-03-18 20:08:45 +08:00
|
|
|
#include "opencl/test/unit_test/mocks/mock_cl_device.h"
|
2020-02-23 22:20:22 +08:00
|
|
|
#include "opencl/test/unit_test/mocks/mock_command_queue.h"
|
|
|
|
#include "opencl/test/unit_test/mocks/mock_context.h"
|
|
|
|
#include "opencl/test/unit_test/mocks/mock_kernel.h"
|
|
|
|
#include "opencl/test/unit_test/mocks/mock_timestamp_container.h"
|
2019-11-10 02:02:25 +08:00
|
|
|
#include "test.h"
|
|
|
|
|
2020-06-19 22:33:53 +08:00
|
|
|
namespace NEO {
|
|
|
|
|
|
|
|
extern CommandStreamReceiverCreateFunc commandStreamReceiverFactory[2 * IGFX_MAX_CORE];
|
2019-11-10 02:02:25 +08:00
|
|
|
|
2020-05-21 22:35:20 +08:00
|
|
|
template <int timestampPacketEnabled>
|
|
|
|
struct BlitEnqueueTests : public ::testing::Test {
|
2019-11-10 02:02:25 +08:00
|
|
|
class BcsMockContext : public MockContext {
|
|
|
|
public:
|
2020-01-14 21:32:11 +08:00
|
|
|
BcsMockContext(ClDevice *device) : MockContext(device) {
|
2020-03-04 06:33:31 +08:00
|
|
|
bcsOsContext.reset(OsContext::create(nullptr, 0, 0, aub_stream::ENGINE_BCS, PreemptionMode::Disabled,
|
|
|
|
false, false, false));
|
2019-11-10 02:02:25 +08:00
|
|
|
bcsCsr.reset(createCommandStream(*device->getExecutionEnvironment(), device->getRootDeviceIndex()));
|
|
|
|
bcsCsr->setupContext(*bcsOsContext);
|
|
|
|
bcsCsr->initializeTagAllocation();
|
|
|
|
}
|
2020-01-21 16:51:13 +08:00
|
|
|
|
2020-02-25 16:55:13 +08:00
|
|
|
BlitOperationResult blitMemoryToAllocation(MemObj &memObj, GraphicsAllocation *memory, void *hostPtr, Vec3<size_t> size) const override {
|
2019-11-10 02:02:25 +08:00
|
|
|
auto blitProperties = BlitProperties::constructPropertiesForReadWriteBuffer(BlitterConstants::BlitDirection::HostPtrToBuffer,
|
2019-12-12 17:47:28 +08:00
|
|
|
*bcsCsr, memory, nullptr,
|
|
|
|
hostPtr,
|
|
|
|
memory->getGpuAddress(), 0,
|
2020-02-25 16:55:13 +08:00
|
|
|
0, 0, size, 0, 0, 0, 0);
|
2019-11-10 02:02:25 +08:00
|
|
|
|
|
|
|
BlitPropertiesContainer container;
|
|
|
|
container.push_back(blitProperties);
|
2020-04-29 20:06:01 +08:00
|
|
|
bcsCsr->blitBuffer(container, true, false);
|
2019-11-10 02:02:25 +08:00
|
|
|
|
|
|
|
return BlitOperationResult::Success;
|
|
|
|
}
|
|
|
|
std::unique_ptr<OsContext> bcsOsContext;
|
|
|
|
std::unique_ptr<CommandStreamReceiver> bcsCsr;
|
|
|
|
};
|
|
|
|
|
|
|
|
template <typename FamilyType>
|
|
|
|
void SetUpT() {
|
2020-03-24 23:03:47 +08:00
|
|
|
auto &hwHelper = HwHelper::get(defaultHwInfo->platform.eRenderCoreFamily);
|
2019-11-10 02:02:25 +08:00
|
|
|
if (is32bit || !hwHelper.requiresAuxResolves()) {
|
|
|
|
GTEST_SKIP();
|
|
|
|
}
|
2020-05-21 22:35:20 +08:00
|
|
|
DebugManager.flags.EnableTimestampPacket.set(timestampPacketEnabled);
|
2019-11-10 02:02:25 +08:00
|
|
|
DebugManager.flags.EnableBlitterOperationsForReadWriteBuffers.set(1);
|
|
|
|
DebugManager.flags.ForceAuxTranslationMode.set(1);
|
|
|
|
DebugManager.flags.CsrDispatchMode.set(static_cast<int32_t>(DispatchMode::ImmediateDispatch));
|
2020-01-14 21:32:11 +08:00
|
|
|
device = std::make_unique<MockClDevice>(MockDevice::createWithNewExecutionEnvironment<MockDevice>(nullptr));
|
2020-03-04 15:51:02 +08:00
|
|
|
auto &capabilityTable = device->getRootDeviceEnvironment().getMutableHardwareInfo()->capabilityTable;
|
2019-11-10 02:02:25 +08:00
|
|
|
bool createBcsEngine = !capabilityTable.blitterOperationsSupported;
|
|
|
|
capabilityTable.blitterOperationsSupported = true;
|
|
|
|
|
|
|
|
if (createBcsEngine) {
|
|
|
|
auto &engine = device->getEngine(HwHelperHw<FamilyType>::lowPriorityEngineType, true);
|
2020-06-02 16:04:25 +08:00
|
|
|
bcsOsContext.reset(OsContext::create(nullptr, 1, device->getDeviceBitfield(), aub_stream::ENGINE_BCS, PreemptionMode::Disabled,
|
2020-03-04 06:33:31 +08:00
|
|
|
false, false, false));
|
2019-11-10 02:02:25 +08:00
|
|
|
engine.osContext = bcsOsContext.get();
|
|
|
|
engine.commandStreamReceiver->setupContext(*bcsOsContext);
|
|
|
|
}
|
|
|
|
bcsMockContext = std::make_unique<BcsMockContext>(device.get());
|
|
|
|
auto mockCmdQueue = new MockCommandQueueHw<FamilyType>(bcsMockContext.get(), device.get(), nullptr);
|
|
|
|
commandQueue.reset(mockCmdQueue);
|
|
|
|
mockKernel = std::make_unique<MockKernelWithInternals>(*device, bcsMockContext.get());
|
|
|
|
mockKernel->mockKernel->auxTranslationRequired = true;
|
|
|
|
auto mockProgram = mockKernel->mockProgram;
|
|
|
|
mockProgram->setAllowNonUniform(true);
|
|
|
|
|
|
|
|
gpgpuCsr = mockCmdQueue->gpgpuEngine->commandStreamReceiver;
|
|
|
|
bcsCsr = mockCmdQueue->bcsEngine->commandStreamReceiver;
|
|
|
|
}
|
|
|
|
|
|
|
|
template <typename FamilyType>
|
|
|
|
void TearDownT() {}
|
|
|
|
|
|
|
|
template <size_t N>
|
|
|
|
void setMockKernelArgs(std::array<Buffer *, N> buffers) {
|
|
|
|
if (mockKernel->kernelInfo.kernelArgInfo.size() < buffers.size()) {
|
|
|
|
mockKernel->kernelInfo.kernelArgInfo.resize(buffers.size());
|
|
|
|
}
|
|
|
|
mockKernel->mockKernel->initialize();
|
|
|
|
|
|
|
|
for (uint32_t i = 0; i < buffers.size(); i++) {
|
|
|
|
cl_mem clMem = buffers[i];
|
|
|
|
|
|
|
|
mockKernel->kernelInfo.kernelArgInfo.at(i).kernelArgPatchInfoVector.resize(1);
|
|
|
|
mockKernel->kernelInfo.kernelArgInfo.at(i).pureStatefulBufferAccess = false;
|
|
|
|
mockKernel->mockKernel->setArgBuffer(i, sizeof(cl_mem *), &clMem);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
ReleaseableObjectPtr<Buffer> createBuffer(size_t size, bool compressed) {
|
|
|
|
auto buffer = clUniquePtr<Buffer>(Buffer::create(bcsMockContext.get(), CL_MEM_READ_WRITE, size, nullptr, retVal));
|
|
|
|
if (compressed) {
|
2020-06-02 19:38:13 +08:00
|
|
|
buffer->getGraphicsAllocation(device->getRootDeviceIndex())->setAllocationType(GraphicsAllocation::AllocationType::BUFFER_COMPRESSED);
|
2019-11-10 02:02:25 +08:00
|
|
|
} else {
|
2020-06-02 19:38:13 +08:00
|
|
|
buffer->getGraphicsAllocation(device->getRootDeviceIndex())->setAllocationType(GraphicsAllocation::AllocationType::BUFFER);
|
2019-11-10 02:02:25 +08:00
|
|
|
}
|
|
|
|
return buffer;
|
|
|
|
}
|
|
|
|
|
|
|
|
template <typename Family>
|
|
|
|
GenCmdList getCmdList(LinearStream &linearStream) {
|
|
|
|
HardwareParse hwParser;
|
|
|
|
hwParser.parseCommands<Family>(linearStream);
|
|
|
|
|
|
|
|
return hwParser.cmdList;
|
|
|
|
}
|
|
|
|
|
|
|
|
template <typename Family>
|
|
|
|
GenCmdList::iterator expectPipeControl(GenCmdList::iterator itorStart, GenCmdList::iterator itorEnd) {
|
|
|
|
using PIPE_CONTROL = typename Family::PIPE_CONTROL;
|
|
|
|
PIPE_CONTROL *pipeControlCmd = nullptr;
|
|
|
|
GenCmdList::iterator commandItor = itorStart;
|
|
|
|
bool stallingWrite = false;
|
|
|
|
|
|
|
|
do {
|
|
|
|
commandItor = find<PIPE_CONTROL *>(commandItor, itorEnd);
|
|
|
|
if (itorEnd == commandItor) {
|
|
|
|
EXPECT_TRUE(false);
|
|
|
|
return itorEnd;
|
|
|
|
}
|
|
|
|
pipeControlCmd = genCmdCast<PIPE_CONTROL *>(*commandItor);
|
|
|
|
stallingWrite = pipeControlCmd->getPostSyncOperation() == PIPE_CONTROL::POST_SYNC_OPERATION::POST_SYNC_OPERATION_WRITE_IMMEDIATE_DATA &&
|
|
|
|
pipeControlCmd->getCommandStreamerStallEnable();
|
|
|
|
|
|
|
|
++commandItor;
|
|
|
|
} while (!stallingWrite);
|
|
|
|
|
|
|
|
return --commandItor;
|
|
|
|
}
|
|
|
|
|
2020-03-12 17:49:20 +08:00
|
|
|
template <typename Family>
|
|
|
|
GenCmdList::iterator expectMiFlush(GenCmdList::iterator itorStart, GenCmdList::iterator itorEnd) {
|
|
|
|
Family *miFlushCmd = nullptr;
|
|
|
|
GenCmdList::iterator commandItor = itorStart;
|
|
|
|
bool miFlushWithMemoryWrite = false;
|
|
|
|
|
|
|
|
do {
|
|
|
|
commandItor = find<Family *>(commandItor, itorEnd);
|
|
|
|
if (itorEnd == commandItor) {
|
|
|
|
EXPECT_TRUE(false);
|
|
|
|
return itorEnd;
|
|
|
|
}
|
|
|
|
miFlushCmd = genCmdCast<Family *>(*commandItor);
|
|
|
|
miFlushWithMemoryWrite = miFlushCmd->getDestinationAddress() != 0;
|
|
|
|
|
|
|
|
++commandItor;
|
|
|
|
} while (!miFlushWithMemoryWrite);
|
|
|
|
|
|
|
|
return --commandItor;
|
|
|
|
}
|
|
|
|
|
2019-11-10 02:02:25 +08:00
|
|
|
template <typename Command>
|
|
|
|
GenCmdList::iterator expectCommand(GenCmdList::iterator itorStart, GenCmdList::iterator itorEnd) {
|
|
|
|
auto commandItor = find<Command *>(itorStart, itorEnd);
|
|
|
|
EXPECT_TRUE(commandItor != itorEnd);
|
|
|
|
|
|
|
|
return commandItor;
|
|
|
|
}
|
|
|
|
|
|
|
|
template <typename Family>
|
|
|
|
void verifySemaphore(GenCmdList::iterator &semaphoreItor, uint64_t expectedAddress) {
|
|
|
|
using MI_SEMAPHORE_WAIT = typename Family::MI_SEMAPHORE_WAIT;
|
|
|
|
|
|
|
|
auto semaphoreCmd = genCmdCast<MI_SEMAPHORE_WAIT *>(*semaphoreItor);
|
|
|
|
EXPECT_EQ(expectedAddress, semaphoreCmd->getSemaphoreGraphicsAddress());
|
|
|
|
}
|
|
|
|
|
|
|
|
DebugManagerStateRestore restore;
|
|
|
|
|
|
|
|
std::unique_ptr<OsContext> bcsOsContext;
|
2020-01-14 21:32:11 +08:00
|
|
|
std::unique_ptr<MockClDevice> device;
|
2019-11-10 02:02:25 +08:00
|
|
|
std::unique_ptr<BcsMockContext> bcsMockContext;
|
|
|
|
std::unique_ptr<CommandQueue> commandQueue;
|
|
|
|
std::unique_ptr<MockKernelWithInternals> mockKernel;
|
|
|
|
|
|
|
|
CommandStreamReceiver *bcsCsr = nullptr;
|
|
|
|
CommandStreamReceiver *gpgpuCsr = nullptr;
|
|
|
|
|
|
|
|
size_t gws[3] = {63, 0, 0};
|
|
|
|
size_t lws[3] = {16, 0, 0};
|
|
|
|
uint32_t hostPtr = 0;
|
|
|
|
cl_int retVal = CL_SUCCESS;
|
|
|
|
};
|
|
|
|
|
2020-05-21 22:35:20 +08:00
|
|
|
using BlitAuxTranslationTests = BlitEnqueueTests<1>;
|
|
|
|
|
2019-11-10 02:02:25 +08:00
|
|
|
HWTEST_TEMPLATED_F(BlitAuxTranslationTests, givenBlitAuxTranslationWhenConstructingCommandBufferThenEnsureCorrectOrder) {
|
|
|
|
using PIPE_CONTROL = typename FamilyType::PIPE_CONTROL;
|
|
|
|
using MI_SEMAPHORE_WAIT = typename FamilyType::MI_SEMAPHORE_WAIT;
|
|
|
|
using WALKER_TYPE = typename FamilyType::WALKER_TYPE;
|
|
|
|
using XY_COPY_BLT = typename FamilyType::XY_COPY_BLT;
|
|
|
|
using MI_FLUSH_DW = typename FamilyType::MI_FLUSH_DW;
|
|
|
|
|
|
|
|
auto buffer0 = createBuffer(1, true);
|
|
|
|
auto buffer1 = createBuffer(1, false);
|
|
|
|
auto buffer2 = createBuffer(1, true);
|
|
|
|
setMockKernelArgs(std::array<Buffer *, 3>{{buffer0.get(), buffer1.get(), buffer2.get()}});
|
|
|
|
|
|
|
|
auto mockCmdQ = static_cast<MockCommandQueueHw<FamilyType> *>(commandQueue.get());
|
|
|
|
auto initialBcsTaskCount = mockCmdQ->bcsTaskCount;
|
|
|
|
|
|
|
|
mockCmdQ->enqueueKernel(mockKernel->mockKernel, 1, nullptr, gws, lws, 0, nullptr, nullptr);
|
|
|
|
|
|
|
|
EXPECT_EQ(mockCmdQ->bcsTaskCount, initialBcsTaskCount + 1);
|
|
|
|
|
|
|
|
// Gpgpu command buffer
|
|
|
|
{
|
|
|
|
auto cmdListCsr = getCmdList<FamilyType>(gpgpuCsr->getCS(0));
|
|
|
|
auto cmdListQueue = getCmdList<FamilyType>(commandQueue->getCS(0));
|
|
|
|
|
|
|
|
// Barrier
|
|
|
|
expectPipeControl<FamilyType>(cmdListCsr.begin(), cmdListCsr.end());
|
|
|
|
|
|
|
|
// Aux to NonAux
|
|
|
|
auto cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(cmdListQueue.begin(), cmdListQueue.end());
|
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdListQueue.end());
|
|
|
|
// Walker
|
|
|
|
cmdFound = expectCommand<WALKER_TYPE>(++cmdFound, cmdListQueue.end());
|
|
|
|
cmdFound = expectCommand<WALKER_TYPE>(++cmdFound, cmdListQueue.end());
|
|
|
|
// NonAux to Aux
|
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdListQueue.end());
|
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdListQueue.end());
|
|
|
|
|
|
|
|
// task count
|
|
|
|
expectPipeControl<FamilyType>(++cmdFound, cmdListQueue.end());
|
|
|
|
}
|
|
|
|
|
|
|
|
// BCS command buffer
|
|
|
|
{
|
|
|
|
auto cmdList = getCmdList<FamilyType>(bcsCsr->getCS(0));
|
|
|
|
|
|
|
|
// Barrier
|
|
|
|
auto cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(cmdList.begin(), cmdList.end());
|
|
|
|
|
|
|
|
// Aux to NonAux
|
|
|
|
cmdFound = expectCommand<XY_COPY_BLT>(++cmdFound, cmdList.end());
|
|
|
|
cmdFound = expectCommand<MI_FLUSH_DW>(++cmdFound, cmdList.end());
|
|
|
|
cmdFound = expectCommand<XY_COPY_BLT>(++cmdFound, cmdList.end());
|
|
|
|
cmdFound = expectCommand<MI_FLUSH_DW>(++cmdFound, cmdList.end());
|
|
|
|
|
2020-05-15 15:20:45 +08:00
|
|
|
// wait for NDR (walker split)
|
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdList.end());
|
2019-11-10 02:02:25 +08:00
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdList.end());
|
|
|
|
|
|
|
|
// NonAux to Aux
|
|
|
|
cmdFound = expectCommand<XY_COPY_BLT>(++cmdFound, cmdList.end());
|
|
|
|
cmdFound = expectCommand<MI_FLUSH_DW>(++cmdFound, cmdList.end());
|
|
|
|
cmdFound = expectCommand<XY_COPY_BLT>(++cmdFound, cmdList.end());
|
|
|
|
cmdFound = expectCommand<MI_FLUSH_DW>(++cmdFound, cmdList.end());
|
|
|
|
|
|
|
|
// taskCount
|
|
|
|
expectCommand<MI_FLUSH_DW>(++cmdFound, cmdList.end());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-11-18 20:35:44 +08:00
|
|
|
HWTEST_TEMPLATED_F(BlitAuxTranslationTests, givenBlitAuxTranslationWhenConstructingBlockedCommandBufferThenEnsureCorrectOrder) {
|
|
|
|
using PIPE_CONTROL = typename FamilyType::PIPE_CONTROL;
|
|
|
|
using MI_SEMAPHORE_WAIT = typename FamilyType::MI_SEMAPHORE_WAIT;
|
|
|
|
using WALKER_TYPE = typename FamilyType::WALKER_TYPE;
|
|
|
|
using XY_COPY_BLT = typename FamilyType::XY_COPY_BLT;
|
|
|
|
using MI_FLUSH_DW = typename FamilyType::MI_FLUSH_DW;
|
|
|
|
|
|
|
|
auto buffer0 = createBuffer(1, true);
|
|
|
|
auto buffer1 = createBuffer(1, false);
|
|
|
|
auto buffer2 = createBuffer(1, true);
|
|
|
|
setMockKernelArgs(std::array<Buffer *, 3>{{buffer0.get(), buffer1.get(), buffer2.get()}});
|
|
|
|
|
|
|
|
auto mockCmdQ = static_cast<MockCommandQueueHw<FamilyType> *>(commandQueue.get());
|
|
|
|
auto initialBcsTaskCount = mockCmdQ->bcsTaskCount;
|
|
|
|
|
|
|
|
UserEvent userEvent;
|
|
|
|
cl_event waitlist[] = {&userEvent};
|
|
|
|
|
|
|
|
mockCmdQ->enqueueKernel(mockKernel->mockKernel, 1, nullptr, gws, lws, 1, waitlist, nullptr);
|
|
|
|
userEvent.setStatus(CL_COMPLETE);
|
|
|
|
|
|
|
|
EXPECT_EQ(mockCmdQ->bcsTaskCount, initialBcsTaskCount + 1);
|
|
|
|
|
|
|
|
// Gpgpu command buffer
|
|
|
|
{
|
|
|
|
auto cmdListCsr = getCmdList<FamilyType>(gpgpuCsr->getCS(0));
|
|
|
|
auto ultCsr = static_cast<UltCommandStreamReceiver<FamilyType> *>(gpgpuCsr);
|
|
|
|
auto cmdListQueue = getCmdList<FamilyType>(*ultCsr->lastFlushedCommandStream);
|
|
|
|
|
|
|
|
// Barrier
|
|
|
|
expectPipeControl<FamilyType>(cmdListCsr.begin(), cmdListCsr.end());
|
|
|
|
|
|
|
|
// Aux to NonAux
|
|
|
|
auto cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(cmdListQueue.begin(), cmdListQueue.end());
|
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdListQueue.end());
|
|
|
|
// Walker
|
|
|
|
cmdFound = expectCommand<WALKER_TYPE>(++cmdFound, cmdListQueue.end());
|
|
|
|
cmdFound = expectCommand<WALKER_TYPE>(++cmdFound, cmdListQueue.end());
|
|
|
|
// NonAux to Aux
|
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdListQueue.end());
|
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdListQueue.end());
|
|
|
|
|
|
|
|
// task count
|
|
|
|
expectPipeControl<FamilyType>(++cmdFound, cmdListQueue.end());
|
|
|
|
}
|
|
|
|
|
|
|
|
// BCS command buffer
|
|
|
|
{
|
|
|
|
auto cmdList = getCmdList<FamilyType>(bcsCsr->getCS(0));
|
|
|
|
|
|
|
|
// Barrier
|
|
|
|
auto cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(cmdList.begin(), cmdList.end());
|
|
|
|
|
|
|
|
// Aux to NonAux
|
|
|
|
cmdFound = expectCommand<XY_COPY_BLT>(++cmdFound, cmdList.end());
|
|
|
|
cmdFound = expectCommand<MI_FLUSH_DW>(++cmdFound, cmdList.end());
|
|
|
|
cmdFound = expectCommand<XY_COPY_BLT>(++cmdFound, cmdList.end());
|
|
|
|
cmdFound = expectCommand<MI_FLUSH_DW>(++cmdFound, cmdList.end());
|
|
|
|
|
2020-05-15 15:20:45 +08:00
|
|
|
// wait for NDR (walker split)
|
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdList.end());
|
2019-11-18 20:35:44 +08:00
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdList.end());
|
|
|
|
|
|
|
|
// NonAux to Aux
|
|
|
|
cmdFound = expectCommand<XY_COPY_BLT>(++cmdFound, cmdList.end());
|
|
|
|
cmdFound = expectCommand<MI_FLUSH_DW>(++cmdFound, cmdList.end());
|
|
|
|
cmdFound = expectCommand<XY_COPY_BLT>(++cmdFound, cmdList.end());
|
|
|
|
cmdFound = expectCommand<MI_FLUSH_DW>(++cmdFound, cmdList.end());
|
|
|
|
|
|
|
|
// taskCount
|
|
|
|
expectCommand<MI_FLUSH_DW>(++cmdFound, cmdList.end());
|
|
|
|
}
|
|
|
|
EXPECT_FALSE(mockCmdQ->isQueueBlocked());
|
|
|
|
}
|
|
|
|
|
2019-11-10 02:02:25 +08:00
|
|
|
HWTEST_TEMPLATED_F(BlitAuxTranslationTests, givenBlitTranslationWhenConstructingCommandBufferThenSynchronizeBarrier) {
|
|
|
|
using PIPE_CONTROL = typename FamilyType::PIPE_CONTROL;
|
|
|
|
using MI_SEMAPHORE_WAIT = typename FamilyType::MI_SEMAPHORE_WAIT;
|
|
|
|
|
|
|
|
auto buffer = createBuffer(1, true);
|
|
|
|
setMockKernelArgs(std::array<Buffer *, 1>{{buffer.get()}});
|
|
|
|
|
|
|
|
commandQueue->enqueueKernel(mockKernel->mockKernel, 1, nullptr, gws, nullptr, 0, nullptr, nullptr);
|
|
|
|
|
|
|
|
auto cmdListCsr = getCmdList<FamilyType>(gpgpuCsr->getCS(0));
|
|
|
|
auto pipeControl = expectPipeControl<FamilyType>(cmdListCsr.begin(), cmdListCsr.end());
|
|
|
|
auto pipeControlCmd = genCmdCast<PIPE_CONTROL *>(*pipeControl);
|
|
|
|
|
|
|
|
uint64_t low = pipeControlCmd->getAddress();
|
|
|
|
uint64_t high = pipeControlCmd->getAddressHigh();
|
|
|
|
uint64_t barrierGpuAddress = (high << 32) | low;
|
|
|
|
|
|
|
|
auto cmdList = getCmdList<FamilyType>(bcsCsr->getCS(0));
|
|
|
|
auto semaphore = expectCommand<MI_SEMAPHORE_WAIT>(cmdList.begin(), cmdList.end());
|
|
|
|
verifySemaphore<FamilyType>(semaphore, barrierGpuAddress);
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST_TEMPLATED_F(BlitAuxTranslationTests, givenBlitTranslationWhenConstructingCommandBufferThenSynchronizeBcsOutput) {
|
|
|
|
using XY_COPY_BLT = typename FamilyType::XY_COPY_BLT;
|
|
|
|
using MI_FLUSH_DW = typename FamilyType::MI_FLUSH_DW;
|
|
|
|
using MI_SEMAPHORE_WAIT = typename FamilyType::MI_SEMAPHORE_WAIT;
|
|
|
|
using WALKER_TYPE = typename FamilyType::WALKER_TYPE;
|
|
|
|
|
|
|
|
auto buffer0 = createBuffer(1, true);
|
|
|
|
auto buffer1 = createBuffer(1, true);
|
|
|
|
setMockKernelArgs(std::array<Buffer *, 2>{{buffer0.get(), buffer1.get()}});
|
|
|
|
|
|
|
|
commandQueue->enqueueKernel(mockKernel->mockKernel, 1, nullptr, gws, nullptr, 0, nullptr, nullptr);
|
|
|
|
|
|
|
|
uint64_t auxToNonAuxOutputAddress[2] = {};
|
|
|
|
uint64_t nonAuxToAuxOutputAddress[2] = {};
|
|
|
|
{
|
|
|
|
auto cmdListBcs = getCmdList<FamilyType>(bcsCsr->getCS(0));
|
|
|
|
|
|
|
|
auto cmdFound = expectCommand<XY_COPY_BLT>(cmdListBcs.begin(), cmdListBcs.end());
|
|
|
|
|
2020-03-12 17:49:20 +08:00
|
|
|
cmdFound = expectMiFlush<MI_FLUSH_DW>(++cmdFound, cmdListBcs.end());
|
2019-11-10 02:02:25 +08:00
|
|
|
auto miflushDwCmd = genCmdCast<MI_FLUSH_DW *>(*cmdFound);
|
|
|
|
auxToNonAuxOutputAddress[0] = miflushDwCmd->getDestinationAddress();
|
|
|
|
|
2020-03-12 17:49:20 +08:00
|
|
|
cmdFound = expectMiFlush<MI_FLUSH_DW>(++cmdFound, cmdListBcs.end());
|
2019-11-10 02:02:25 +08:00
|
|
|
miflushDwCmd = genCmdCast<MI_FLUSH_DW *>(*cmdFound);
|
|
|
|
auxToNonAuxOutputAddress[1] = miflushDwCmd->getDestinationAddress();
|
|
|
|
|
|
|
|
cmdFound = expectCommand<XY_COPY_BLT>(++cmdFound, cmdListBcs.end());
|
|
|
|
|
2020-03-12 17:49:20 +08:00
|
|
|
cmdFound = expectMiFlush<MI_FLUSH_DW>(++cmdFound, cmdListBcs.end());
|
2019-11-10 02:02:25 +08:00
|
|
|
miflushDwCmd = genCmdCast<MI_FLUSH_DW *>(*cmdFound);
|
|
|
|
nonAuxToAuxOutputAddress[0] = miflushDwCmd->getDestinationAddress();
|
|
|
|
|
2020-03-12 17:49:20 +08:00
|
|
|
cmdFound = expectMiFlush<MI_FLUSH_DW>(++cmdFound, cmdListBcs.end());
|
2019-11-10 02:02:25 +08:00
|
|
|
miflushDwCmd = genCmdCast<MI_FLUSH_DW *>(*cmdFound);
|
|
|
|
nonAuxToAuxOutputAddress[1] = miflushDwCmd->getDestinationAddress();
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
auto cmdListQueue = getCmdList<FamilyType>(commandQueue->getCS(0));
|
|
|
|
|
|
|
|
// Aux to NonAux
|
|
|
|
auto cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(cmdListQueue.begin(), cmdListQueue.end());
|
|
|
|
verifySemaphore<FamilyType>(cmdFound, auxToNonAuxOutputAddress[0]);
|
|
|
|
|
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdListQueue.end());
|
|
|
|
verifySemaphore<FamilyType>(cmdFound, auxToNonAuxOutputAddress[1]);
|
|
|
|
|
|
|
|
// Walker
|
|
|
|
cmdFound = expectCommand<WALKER_TYPE>(++cmdFound, cmdListQueue.end());
|
|
|
|
|
|
|
|
// NonAux to Aux
|
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdListQueue.end());
|
|
|
|
verifySemaphore<FamilyType>(cmdFound, nonAuxToAuxOutputAddress[0]);
|
|
|
|
|
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdListQueue.end());
|
|
|
|
verifySemaphore<FamilyType>(cmdFound, nonAuxToAuxOutputAddress[1]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST_TEMPLATED_F(BlitAuxTranslationTests, givenBlitTranslationWhenConstructingCommandBufferThenSynchronizeKernel) {
|
|
|
|
using XY_COPY_BLT = typename FamilyType::XY_COPY_BLT;
|
|
|
|
using MI_SEMAPHORE_WAIT = typename FamilyType::MI_SEMAPHORE_WAIT;
|
|
|
|
|
|
|
|
auto buffer = createBuffer(1, true);
|
|
|
|
setMockKernelArgs(std::array<Buffer *, 1>{{buffer.get()}});
|
|
|
|
|
|
|
|
auto mockCmdQ = static_cast<MockCommandQueueHw<FamilyType> *>(commandQueue.get());
|
2020-03-09 20:48:30 +08:00
|
|
|
mockCmdQ->overrideIsCacheFlushForBcsRequired.enabled = true;
|
|
|
|
mockCmdQ->overrideIsCacheFlushForBcsRequired.returnValue = false;
|
|
|
|
|
2019-11-10 02:02:25 +08:00
|
|
|
mockCmdQ->enqueueKernel(mockKernel->mockKernel, 1, nullptr, gws, nullptr, 0, nullptr, nullptr);
|
|
|
|
|
|
|
|
auto kernelNode = mockCmdQ->timestampPacketContainer->peekNodes()[0];
|
2020-05-19 22:20:41 +08:00
|
|
|
auto kernelNodeAddress = TimestampPacketHelper::getContextEndGpuAddress(*kernelNode);
|
2019-11-10 02:02:25 +08:00
|
|
|
|
|
|
|
auto cmdList = getCmdList<FamilyType>(bcsCsr->getCS(0));
|
|
|
|
|
|
|
|
// Aux to nonAux
|
|
|
|
auto cmdFound = expectCommand<XY_COPY_BLT>(cmdList.begin(), cmdList.end());
|
|
|
|
|
|
|
|
// semaphore before NonAux to Aux
|
|
|
|
auto semaphore = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdList.end());
|
|
|
|
verifySemaphore<FamilyType>(semaphore, kernelNodeAddress);
|
|
|
|
}
|
|
|
|
|
2020-03-09 20:48:30 +08:00
|
|
|
HWTEST_TEMPLATED_F(BlitAuxTranslationTests, givenBlitTranslationWhenConstructingCommandBufferThenSynchronizeCacheFlush) {
|
|
|
|
using XY_COPY_BLT = typename FamilyType::XY_COPY_BLT;
|
|
|
|
using MI_SEMAPHORE_WAIT = typename FamilyType::MI_SEMAPHORE_WAIT;
|
|
|
|
using PIPE_CONTROL = typename FamilyType::PIPE_CONTROL;
|
|
|
|
using WALKER_TYPE = typename FamilyType::WALKER_TYPE;
|
|
|
|
|
|
|
|
auto buffer = createBuffer(1, true);
|
|
|
|
setMockKernelArgs(std::array<Buffer *, 1>{{buffer.get()}});
|
|
|
|
|
|
|
|
auto mockCmdQ = static_cast<MockCommandQueueHw<FamilyType> *>(commandQueue.get());
|
|
|
|
mockCmdQ->overrideIsCacheFlushForBcsRequired.enabled = true;
|
|
|
|
mockCmdQ->overrideIsCacheFlushForBcsRequired.returnValue = true;
|
|
|
|
mockCmdQ->enqueueKernel(mockKernel->mockKernel, 1, nullptr, gws, nullptr, 0, nullptr, nullptr);
|
|
|
|
|
|
|
|
auto cmdListBcs = getCmdList<FamilyType>(bcsCsr->getCS(0));
|
|
|
|
auto cmdListQueue = getCmdList<FamilyType>(mockCmdQ->getCS(0));
|
|
|
|
|
|
|
|
uint64_t cacheFlushWriteAddress = 0;
|
|
|
|
|
|
|
|
{
|
|
|
|
auto cmdFound = expectCommand<WALKER_TYPE>(cmdListQueue.begin(), cmdListQueue.end());
|
|
|
|
cmdFound = expectPipeControl<FamilyType>(++cmdFound, cmdListQueue.end());
|
|
|
|
|
|
|
|
auto pipeControlCmd = genCmdCast<PIPE_CONTROL *>(*cmdFound);
|
|
|
|
if (!pipeControlCmd->getDcFlushEnable()) {
|
|
|
|
// skip pipe control with TimestampPacket write
|
|
|
|
cmdFound = expectPipeControl<FamilyType>(++cmdFound, cmdListQueue.end());
|
|
|
|
pipeControlCmd = genCmdCast<PIPE_CONTROL *>(*cmdFound);
|
|
|
|
}
|
|
|
|
|
|
|
|
EXPECT_TRUE(pipeControlCmd->getDcFlushEnable());
|
|
|
|
EXPECT_TRUE(pipeControlCmd->getCommandStreamerStallEnable());
|
|
|
|
uint64_t low = pipeControlCmd->getAddress();
|
|
|
|
uint64_t high = pipeControlCmd->getAddressHigh();
|
|
|
|
cacheFlushWriteAddress = (high << 32) | low;
|
|
|
|
EXPECT_NE(0u, cacheFlushWriteAddress);
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
// Aux to nonAux
|
|
|
|
auto cmdFound = expectCommand<XY_COPY_BLT>(cmdListBcs.begin(), cmdListBcs.end());
|
|
|
|
|
|
|
|
// semaphore before NonAux to Aux
|
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdListBcs.end());
|
|
|
|
verifySemaphore<FamilyType>(cmdFound, cacheFlushWriteAddress);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-11-10 02:02:25 +08:00
|
|
|
HWTEST_TEMPLATED_F(BlitAuxTranslationTests, givenBlitTranslationWhenConstructingCommandBufferThenSynchronizeEvents) {
|
|
|
|
using XY_COPY_BLT = typename FamilyType::XY_COPY_BLT;
|
|
|
|
using MI_SEMAPHORE_WAIT = typename FamilyType::MI_SEMAPHORE_WAIT;
|
|
|
|
|
|
|
|
auto buffer = createBuffer(1, true);
|
|
|
|
setMockKernelArgs(std::array<Buffer *, 1>{{buffer.get()}});
|
|
|
|
|
|
|
|
auto event = make_releaseable<Event>(commandQueue.get(), CL_COMMAND_READ_BUFFER, 0, 0);
|
|
|
|
MockTimestampPacketContainer eventDependencyContainer(*bcsCsr->getTimestampPacketAllocator(), 1);
|
|
|
|
auto eventDependency = eventDependencyContainer.getNode(0);
|
|
|
|
event->addTimestampPacketNodes(eventDependencyContainer);
|
|
|
|
cl_event clEvent[] = {event.get()};
|
|
|
|
|
|
|
|
commandQueue->enqueueKernel(mockKernel->mockKernel, 1, nullptr, gws, nullptr, 1, clEvent, nullptr);
|
|
|
|
|
2020-05-19 22:20:41 +08:00
|
|
|
auto eventDependencyAddress = TimestampPacketHelper::getContextEndGpuAddress(*eventDependency);
|
2019-11-10 02:02:25 +08:00
|
|
|
|
|
|
|
auto cmdList = getCmdList<FamilyType>(bcsCsr->getCS(0));
|
|
|
|
|
|
|
|
// Barrier
|
|
|
|
auto cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(cmdList.begin(), cmdList.end());
|
|
|
|
|
|
|
|
// Event
|
|
|
|
auto semaphore = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdList.end());
|
|
|
|
verifySemaphore<FamilyType>(semaphore, eventDependencyAddress);
|
|
|
|
|
|
|
|
cmdFound = expectCommand<XY_COPY_BLT>(++semaphore, cmdList.end());
|
|
|
|
expectCommand<XY_COPY_BLT>(++cmdFound, cmdList.end());
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST_TEMPLATED_F(BlitAuxTranslationTests, givenOutEventWhenDispatchingThenAssignNonAuxNodes) {
|
|
|
|
using WALKER_TYPE = typename FamilyType::WALKER_TYPE;
|
|
|
|
using MI_SEMAPHORE_WAIT = typename FamilyType::MI_SEMAPHORE_WAIT;
|
|
|
|
|
|
|
|
auto buffer0 = createBuffer(1, true);
|
|
|
|
auto buffer1 = createBuffer(1, false);
|
|
|
|
auto buffer2 = createBuffer(1, true);
|
|
|
|
|
|
|
|
setMockKernelArgs(std::array<Buffer *, 3>{{buffer0.get(), buffer1.get(), buffer2.get()}});
|
|
|
|
|
|
|
|
cl_event clEvent;
|
|
|
|
commandQueue->enqueueKernel(mockKernel->mockKernel, 1, nullptr, gws, nullptr, 0, nullptr, &clEvent);
|
|
|
|
auto event = castToObject<Event>(clEvent);
|
|
|
|
auto &eventNodes = event->getTimestampPacketNodes()->peekNodes();
|
|
|
|
EXPECT_EQ(3u, eventNodes.size());
|
|
|
|
|
|
|
|
auto cmdListQueue = getCmdList<FamilyType>(commandQueue->getCS(0));
|
|
|
|
|
|
|
|
auto cmdFound = expectCommand<WALKER_TYPE>(cmdListQueue.begin(), cmdListQueue.end());
|
|
|
|
|
|
|
|
// NonAux to Aux
|
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdListQueue.end());
|
2020-05-19 22:20:41 +08:00
|
|
|
auto eventNodeAddress = TimestampPacketHelper::getContextEndGpuAddress(*eventNodes[1]);
|
2019-11-10 02:02:25 +08:00
|
|
|
verifySemaphore<FamilyType>(cmdFound, eventNodeAddress);
|
|
|
|
|
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdListQueue.end());
|
2020-05-19 22:20:41 +08:00
|
|
|
eventNodeAddress = TimestampPacketHelper::getContextEndGpuAddress(*eventNodes[2]);
|
2019-11-10 02:02:25 +08:00
|
|
|
verifySemaphore<FamilyType>(cmdFound, eventNodeAddress);
|
|
|
|
|
|
|
|
clReleaseEvent(clEvent);
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST_TEMPLATED_F(BlitAuxTranslationTests, givenBlitAuxTranslationWhenDispatchingThenEstimateCmdBufferSize) {
|
|
|
|
using WALKER_TYPE = typename FamilyType::WALKER_TYPE;
|
|
|
|
using MI_SEMAPHORE_WAIT = typename FamilyType::MI_SEMAPHORE_WAIT;
|
|
|
|
|
2020-03-09 20:48:30 +08:00
|
|
|
auto &hwInfo = device->getHardwareInfo();
|
|
|
|
auto mockCmdQ = static_cast<MockCommandQueueHw<FamilyType> *>(commandQueue.get());
|
|
|
|
mockCmdQ->overrideIsCacheFlushForBcsRequired.enabled = true;
|
|
|
|
mockCmdQ->overrideIsCacheFlushForBcsRequired.returnValue = false;
|
|
|
|
|
2019-11-10 02:02:25 +08:00
|
|
|
auto buffer0 = createBuffer(1, true);
|
|
|
|
auto buffer1 = createBuffer(1, false);
|
|
|
|
auto buffer2 = createBuffer(1, true);
|
|
|
|
|
|
|
|
MemObjsForAuxTranslation memObjects;
|
|
|
|
memObjects.insert(buffer0.get());
|
|
|
|
memObjects.insert(buffer2.get());
|
|
|
|
|
|
|
|
size_t numBuffersToEstimate = 2;
|
2019-11-07 00:18:47 +08:00
|
|
|
size_t dependencySize = numBuffersToEstimate * TimestampPacketHelper::getRequiredCmdStreamSizeForNodeDependencyWithBlitEnqueue<FamilyType>();
|
2019-11-10 02:02:25 +08:00
|
|
|
|
|
|
|
setMockKernelArgs(std::array<Buffer *, 3>{{buffer0.get(), buffer1.get(), buffer2.get()}});
|
|
|
|
|
2020-03-09 20:48:30 +08:00
|
|
|
mockCmdQ->storeMultiDispatchInfo = true;
|
|
|
|
mockCmdQ->enqueueKernel(mockKernel->mockKernel, 1, nullptr, gws, lws, 0, nullptr, nullptr);
|
|
|
|
|
|
|
|
MultiDispatchInfo &multiDispatchInfo = mockCmdQ->storedMultiDispatchInfo;
|
|
|
|
DispatchInfo *firstDispatchInfo = multiDispatchInfo.begin();
|
|
|
|
DispatchInfo *lastDispatchInfo = &(*multiDispatchInfo.rbegin());
|
|
|
|
|
|
|
|
EXPECT_NE(firstDispatchInfo, lastDispatchInfo); // walker split
|
|
|
|
|
|
|
|
EXPECT_EQ(dependencySize, firstDispatchInfo->dispatchInitCommands.estimateCommandsSize(memObjects.size(), hwInfo, mockCmdQ->isCacheFlushForBcsRequired()));
|
|
|
|
EXPECT_EQ(0u, firstDispatchInfo->dispatchEpilogueCommands.estimateCommandsSize(memObjects.size(), hwInfo, mockCmdQ->isCacheFlushForBcsRequired()));
|
|
|
|
|
|
|
|
EXPECT_EQ(0u, lastDispatchInfo->dispatchInitCommands.estimateCommandsSize(memObjects.size(), hwInfo, mockCmdQ->isCacheFlushForBcsRequired()));
|
|
|
|
EXPECT_EQ(dependencySize, lastDispatchInfo->dispatchEpilogueCommands.estimateCommandsSize(memObjects.size(), hwInfo, mockCmdQ->isCacheFlushForBcsRequired()));
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST_TEMPLATED_F(BlitAuxTranslationTests, givenBlitAuxTranslationWithRequiredCacheFlushWhenDispatchingThenEstimateCmdBufferSize) {
|
|
|
|
using WALKER_TYPE = typename FamilyType::WALKER_TYPE;
|
|
|
|
using MI_SEMAPHORE_WAIT = typename FamilyType::MI_SEMAPHORE_WAIT;
|
|
|
|
|
|
|
|
auto &hwInfo = device->getHardwareInfo();
|
2019-11-10 02:02:25 +08:00
|
|
|
auto mockCmdQ = static_cast<MockCommandQueueHw<FamilyType> *>(commandQueue.get());
|
2020-03-09 20:48:30 +08:00
|
|
|
mockCmdQ->overrideIsCacheFlushForBcsRequired.enabled = true;
|
|
|
|
mockCmdQ->overrideIsCacheFlushForBcsRequired.returnValue = true;
|
|
|
|
|
|
|
|
auto buffer0 = createBuffer(1, true);
|
|
|
|
auto buffer1 = createBuffer(1, false);
|
|
|
|
auto buffer2 = createBuffer(1, true);
|
|
|
|
|
|
|
|
MemObjsForAuxTranslation memObjects;
|
|
|
|
memObjects.insert(buffer0.get());
|
|
|
|
memObjects.insert(buffer2.get());
|
|
|
|
|
|
|
|
size_t numBuffersToEstimate = 2;
|
|
|
|
size_t dependencySize = numBuffersToEstimate * TimestampPacketHelper::getRequiredCmdStreamSizeForNodeDependencyWithBlitEnqueue<FamilyType>();
|
|
|
|
|
|
|
|
size_t cacheFlushSize = MemorySynchronizationCommands<FamilyType>::getSizeForPipeControlWithPostSyncOperation(hwInfo);
|
|
|
|
|
|
|
|
setMockKernelArgs(std::array<Buffer *, 3>{{buffer0.get(), buffer1.get(), buffer2.get()}});
|
|
|
|
|
2019-11-10 02:02:25 +08:00
|
|
|
mockCmdQ->storeMultiDispatchInfo = true;
|
|
|
|
mockCmdQ->enqueueKernel(mockKernel->mockKernel, 1, nullptr, gws, lws, 0, nullptr, nullptr);
|
|
|
|
|
|
|
|
MultiDispatchInfo &multiDispatchInfo = mockCmdQ->storedMultiDispatchInfo;
|
|
|
|
DispatchInfo *firstDispatchInfo = multiDispatchInfo.begin();
|
|
|
|
DispatchInfo *lastDispatchInfo = &(*multiDispatchInfo.rbegin());
|
|
|
|
|
|
|
|
EXPECT_NE(firstDispatchInfo, lastDispatchInfo); // walker split
|
|
|
|
|
2020-03-09 20:48:30 +08:00
|
|
|
EXPECT_EQ(dependencySize, firstDispatchInfo->dispatchInitCommands.estimateCommandsSize(memObjects.size(), hwInfo, mockCmdQ->isCacheFlushForBcsRequired()));
|
|
|
|
EXPECT_EQ(0u, firstDispatchInfo->dispatchEpilogueCommands.estimateCommandsSize(memObjects.size(), hwInfo, mockCmdQ->isCacheFlushForBcsRequired()));
|
2019-11-10 02:02:25 +08:00
|
|
|
|
2020-03-09 20:48:30 +08:00
|
|
|
EXPECT_EQ(0u, lastDispatchInfo->dispatchInitCommands.estimateCommandsSize(memObjects.size(), hwInfo, mockCmdQ->isCacheFlushForBcsRequired()));
|
|
|
|
EXPECT_EQ(dependencySize + cacheFlushSize, lastDispatchInfo->dispatchEpilogueCommands.estimateCommandsSize(memObjects.size(), hwInfo, mockCmdQ->isCacheFlushForBcsRequired()));
|
2019-11-10 02:02:25 +08:00
|
|
|
}
|
2019-11-18 20:35:44 +08:00
|
|
|
|
|
|
|
HWTEST_TEMPLATED_F(BlitAuxTranslationTests, givenBlitTranslationWhenConstructingBlockedCommandBufferThenSynchronizeBarrier) {
|
|
|
|
using PIPE_CONTROL = typename FamilyType::PIPE_CONTROL;
|
|
|
|
using MI_SEMAPHORE_WAIT = typename FamilyType::MI_SEMAPHORE_WAIT;
|
|
|
|
|
|
|
|
auto buffer = createBuffer(1, true);
|
|
|
|
setMockKernelArgs(std::array<Buffer *, 1>{{buffer.get()}});
|
|
|
|
|
|
|
|
UserEvent userEvent;
|
|
|
|
cl_event waitlist[] = {&userEvent};
|
|
|
|
|
|
|
|
commandQueue->enqueueKernel(mockKernel->mockKernel, 1, nullptr, gws, nullptr, 1, waitlist, nullptr);
|
|
|
|
userEvent.setStatus(CL_COMPLETE);
|
|
|
|
|
|
|
|
auto cmdListCsr = getCmdList<FamilyType>(gpgpuCsr->getCS(0));
|
|
|
|
auto pipeControl = expectPipeControl<FamilyType>(cmdListCsr.begin(), cmdListCsr.end());
|
|
|
|
auto pipeControlCmd = genCmdCast<PIPE_CONTROL *>(*pipeControl);
|
|
|
|
|
|
|
|
uint64_t low = pipeControlCmd->getAddress();
|
|
|
|
uint64_t high = pipeControlCmd->getAddressHigh();
|
|
|
|
uint64_t barrierGpuAddress = (high << 32) | low;
|
|
|
|
|
|
|
|
auto cmdList = getCmdList<FamilyType>(bcsCsr->getCS(0));
|
|
|
|
auto semaphore = expectCommand<MI_SEMAPHORE_WAIT>(cmdList.begin(), cmdList.end());
|
|
|
|
verifySemaphore<FamilyType>(semaphore, barrierGpuAddress);
|
|
|
|
|
|
|
|
EXPECT_FALSE(commandQueue->isQueueBlocked());
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST_TEMPLATED_F(BlitAuxTranslationTests, givenBlitTranslationWhenConstructingBlockedCommandBufferThenSynchronizeEvents) {
|
|
|
|
using XY_COPY_BLT = typename FamilyType::XY_COPY_BLT;
|
|
|
|
using MI_SEMAPHORE_WAIT = typename FamilyType::MI_SEMAPHORE_WAIT;
|
|
|
|
|
|
|
|
auto buffer = createBuffer(1, true);
|
|
|
|
setMockKernelArgs(std::array<Buffer *, 1>{{buffer.get()}});
|
|
|
|
|
|
|
|
auto event = make_releaseable<Event>(commandQueue.get(), CL_COMMAND_READ_BUFFER, 0, 0);
|
|
|
|
MockTimestampPacketContainer eventDependencyContainer(*bcsCsr->getTimestampPacketAllocator(), 1);
|
|
|
|
auto eventDependency = eventDependencyContainer.getNode(0);
|
|
|
|
event->addTimestampPacketNodes(eventDependencyContainer);
|
|
|
|
|
|
|
|
UserEvent userEvent;
|
|
|
|
cl_event waitlist[] = {&userEvent, event.get()};
|
|
|
|
commandQueue->enqueueKernel(mockKernel->mockKernel, 1, nullptr, gws, nullptr, 2, waitlist, nullptr);
|
|
|
|
userEvent.setStatus(CL_COMPLETE);
|
|
|
|
|
2020-05-19 22:20:41 +08:00
|
|
|
auto eventDependencyAddress = TimestampPacketHelper::getContextEndGpuAddress(*eventDependency);
|
2019-11-18 20:35:44 +08:00
|
|
|
|
|
|
|
auto cmdList = getCmdList<FamilyType>(bcsCsr->getCS(0));
|
|
|
|
|
|
|
|
// Barrier
|
|
|
|
auto cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(cmdList.begin(), cmdList.end());
|
|
|
|
|
|
|
|
// Event
|
|
|
|
auto semaphore = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdList.end());
|
|
|
|
verifySemaphore<FamilyType>(semaphore, eventDependencyAddress);
|
|
|
|
|
|
|
|
cmdFound = expectCommand<XY_COPY_BLT>(++semaphore, cmdList.end());
|
|
|
|
expectCommand<XY_COPY_BLT>(++cmdFound, cmdList.end());
|
|
|
|
|
|
|
|
EXPECT_FALSE(commandQueue->isQueueBlocked());
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST_TEMPLATED_F(BlitAuxTranslationTests, givenBlitTranslationWhenConstructingBlockedCommandBufferThenSynchronizeKernel) {
|
|
|
|
using XY_COPY_BLT = typename FamilyType::XY_COPY_BLT;
|
|
|
|
using MI_SEMAPHORE_WAIT = typename FamilyType::MI_SEMAPHORE_WAIT;
|
|
|
|
|
|
|
|
auto buffer = createBuffer(1, true);
|
|
|
|
setMockKernelArgs(std::array<Buffer *, 1>{{buffer.get()}});
|
|
|
|
|
|
|
|
auto mockCmdQ = static_cast<MockCommandQueueHw<FamilyType> *>(commandQueue.get());
|
|
|
|
UserEvent userEvent;
|
|
|
|
cl_event waitlist[] = {&userEvent};
|
|
|
|
|
|
|
|
mockCmdQ->enqueueKernel(mockKernel->mockKernel, 1, nullptr, gws, nullptr, 1, waitlist, nullptr);
|
|
|
|
userEvent.setStatus(CL_COMPLETE);
|
|
|
|
|
|
|
|
auto kernelNode = mockCmdQ->timestampPacketContainer->peekNodes()[0];
|
2020-05-19 22:20:41 +08:00
|
|
|
auto kernelNodeAddress = TimestampPacketHelper::getContextEndGpuAddress(*kernelNode);
|
2019-11-18 20:35:44 +08:00
|
|
|
|
|
|
|
auto cmdList = getCmdList<FamilyType>(bcsCsr->getCS(0));
|
|
|
|
|
|
|
|
// Aux to nonAux
|
|
|
|
auto cmdFound = expectCommand<XY_COPY_BLT>(cmdList.begin(), cmdList.end());
|
|
|
|
|
|
|
|
// semaphore before NonAux to Aux
|
|
|
|
auto semaphore = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdList.end());
|
2020-03-09 20:48:30 +08:00
|
|
|
if (mockCmdQ->isCacheFlushForBcsRequired()) {
|
|
|
|
semaphore = expectCommand<MI_SEMAPHORE_WAIT>(++semaphore, cmdList.end());
|
|
|
|
}
|
2019-11-18 20:35:44 +08:00
|
|
|
verifySemaphore<FamilyType>(semaphore, kernelNodeAddress);
|
|
|
|
|
|
|
|
EXPECT_FALSE(commandQueue->isQueueBlocked());
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST_TEMPLATED_F(BlitAuxTranslationTests, givenBlitTranslationWhenConstructingBlockedCommandBufferThenSynchronizeBcsOutput) {
|
|
|
|
using XY_COPY_BLT = typename FamilyType::XY_COPY_BLT;
|
|
|
|
using MI_FLUSH_DW = typename FamilyType::MI_FLUSH_DW;
|
|
|
|
using MI_SEMAPHORE_WAIT = typename FamilyType::MI_SEMAPHORE_WAIT;
|
|
|
|
using WALKER_TYPE = typename FamilyType::WALKER_TYPE;
|
|
|
|
|
|
|
|
auto buffer0 = createBuffer(1, true);
|
|
|
|
auto buffer1 = createBuffer(1, true);
|
|
|
|
setMockKernelArgs(std::array<Buffer *, 2>{{buffer0.get(), buffer1.get()}});
|
|
|
|
|
|
|
|
UserEvent userEvent;
|
|
|
|
cl_event waitlist[] = {&userEvent};
|
|
|
|
commandQueue->enqueueKernel(mockKernel->mockKernel, 1, nullptr, gws, nullptr, 1, waitlist, nullptr);
|
|
|
|
userEvent.setStatus(CL_COMPLETE);
|
|
|
|
|
|
|
|
uint64_t auxToNonAuxOutputAddress[2] = {};
|
|
|
|
uint64_t nonAuxToAuxOutputAddress[2] = {};
|
|
|
|
{
|
|
|
|
auto cmdListBcs = getCmdList<FamilyType>(bcsCsr->getCS(0));
|
|
|
|
|
|
|
|
auto cmdFound = expectCommand<XY_COPY_BLT>(cmdListBcs.begin(), cmdListBcs.end());
|
|
|
|
|
2020-03-12 17:49:20 +08:00
|
|
|
cmdFound = expectMiFlush<MI_FLUSH_DW>(++cmdFound, cmdListBcs.end());
|
2019-11-18 20:35:44 +08:00
|
|
|
auto miflushDwCmd = genCmdCast<MI_FLUSH_DW *>(*cmdFound);
|
|
|
|
auxToNonAuxOutputAddress[0] = miflushDwCmd->getDestinationAddress();
|
|
|
|
|
2020-03-12 17:49:20 +08:00
|
|
|
cmdFound = expectMiFlush<MI_FLUSH_DW>(++cmdFound, cmdListBcs.end());
|
2019-11-18 20:35:44 +08:00
|
|
|
miflushDwCmd = genCmdCast<MI_FLUSH_DW *>(*cmdFound);
|
|
|
|
auxToNonAuxOutputAddress[1] = miflushDwCmd->getDestinationAddress();
|
|
|
|
|
|
|
|
cmdFound = expectCommand<XY_COPY_BLT>(++cmdFound, cmdListBcs.end());
|
|
|
|
|
2020-03-12 17:49:20 +08:00
|
|
|
cmdFound = expectMiFlush<MI_FLUSH_DW>(++cmdFound, cmdListBcs.end());
|
2019-11-18 20:35:44 +08:00
|
|
|
miflushDwCmd = genCmdCast<MI_FLUSH_DW *>(*cmdFound);
|
|
|
|
nonAuxToAuxOutputAddress[0] = miflushDwCmd->getDestinationAddress();
|
|
|
|
|
2020-03-12 17:49:20 +08:00
|
|
|
cmdFound = expectMiFlush<MI_FLUSH_DW>(++cmdFound, cmdListBcs.end());
|
2019-11-18 20:35:44 +08:00
|
|
|
miflushDwCmd = genCmdCast<MI_FLUSH_DW *>(*cmdFound);
|
|
|
|
nonAuxToAuxOutputAddress[1] = miflushDwCmd->getDestinationAddress();
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
auto ultCsr = static_cast<UltCommandStreamReceiver<FamilyType> *>(gpgpuCsr);
|
|
|
|
auto cmdListQueue = getCmdList<FamilyType>(*ultCsr->lastFlushedCommandStream);
|
|
|
|
|
|
|
|
// Aux to NonAux
|
|
|
|
auto cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(cmdListQueue.begin(), cmdListQueue.end());
|
|
|
|
verifySemaphore<FamilyType>(cmdFound, auxToNonAuxOutputAddress[0]);
|
|
|
|
|
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdListQueue.end());
|
|
|
|
verifySemaphore<FamilyType>(cmdFound, auxToNonAuxOutputAddress[1]);
|
|
|
|
|
|
|
|
// Walker
|
|
|
|
cmdFound = expectCommand<WALKER_TYPE>(++cmdFound, cmdListQueue.end());
|
|
|
|
|
|
|
|
// NonAux to Aux
|
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdListQueue.end());
|
|
|
|
verifySemaphore<FamilyType>(cmdFound, nonAuxToAuxOutputAddress[0]);
|
|
|
|
|
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(++cmdFound, cmdListQueue.end());
|
|
|
|
verifySemaphore<FamilyType>(cmdFound, nonAuxToAuxOutputAddress[1]);
|
|
|
|
}
|
|
|
|
|
|
|
|
EXPECT_FALSE(commandQueue->isQueueBlocked());
|
|
|
|
}
|
2020-05-04 16:25:08 +08:00
|
|
|
|
|
|
|
HWTEST_TEMPLATED_F(BlitAuxTranslationTests, givenBlitTranslationWhenEnqueueIsCalledThenDoImplicitFlushOnGpgpuCsr) {
|
|
|
|
auto buffer = createBuffer(1, true);
|
|
|
|
setMockKernelArgs(std::array<Buffer *, 1>{{buffer.get()}});
|
|
|
|
|
|
|
|
auto ultCsr = static_cast<UltCommandStreamReceiver<FamilyType> *>(gpgpuCsr);
|
|
|
|
|
|
|
|
EXPECT_EQ(0u, ultCsr->taskCount);
|
|
|
|
|
|
|
|
commandQueue->enqueueKernel(mockKernel->mockKernel, 1, nullptr, gws, nullptr, 0, nullptr, nullptr);
|
|
|
|
|
|
|
|
EXPECT_EQ(1u, ultCsr->taskCount);
|
|
|
|
EXPECT_TRUE(ultCsr->recordedDispatchFlags.implicitFlush);
|
|
|
|
}
|
2020-05-21 22:35:20 +08:00
|
|
|
|
|
|
|
using BlitEnqueueWithNoTimestampPacketTests = BlitEnqueueTests<0>;
|
|
|
|
|
|
|
|
HWTEST_TEMPLATED_F(BlitEnqueueWithNoTimestampPacketTests, givenNoTimestampPacketsWritewhenEnqueueingBlitOperationThenEnginesAreSynchronized) {
|
|
|
|
using MI_SEMAPHORE_WAIT = typename FamilyType::MI_SEMAPHORE_WAIT;
|
|
|
|
using MI_FLUSH_DW = typename FamilyType::MI_FLUSH_DW;
|
|
|
|
using WALKER_TYPE = typename FamilyType::WALKER_TYPE;
|
|
|
|
|
|
|
|
const size_t bufferSize = 1u;
|
|
|
|
auto buffer = createBuffer(bufferSize, false);
|
|
|
|
auto ultCsr = static_cast<UltCommandStreamReceiver<FamilyType> *>(gpgpuCsr);
|
|
|
|
ASSERT_EQ(0u, ultCsr->taskCount);
|
|
|
|
|
|
|
|
setMockKernelArgs(std::array<Buffer *, 1>{{buffer.get()}});
|
|
|
|
commandQueue->enqueueKernel(mockKernel->mockKernel, 1, nullptr, gws, nullptr, 0, nullptr, nullptr);
|
|
|
|
|
|
|
|
char cpuBuffer[bufferSize]{};
|
|
|
|
commandQueue->enqueueReadBuffer(buffer.get(), CL_FALSE, 0, bufferSize, cpuBuffer, nullptr, 0, nullptr, nullptr);
|
|
|
|
commandQueue->finish();
|
|
|
|
|
|
|
|
auto bcsCommands = getCmdList<FamilyType>(bcsCsr->getCS(0));
|
|
|
|
auto ccsCommands = getCmdList<FamilyType>(commandQueue->getCS(0));
|
|
|
|
|
|
|
|
auto cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(bcsCommands.begin(), bcsCommands.end());
|
|
|
|
|
|
|
|
cmdFound = expectMiFlush<MI_FLUSH_DW>(cmdFound++, bcsCommands.end());
|
|
|
|
auto miflushDwCmd = genCmdCast<MI_FLUSH_DW *>(*cmdFound);
|
|
|
|
const auto bcsSignalAddress = miflushDwCmd->getDestinationAddress();
|
|
|
|
|
|
|
|
cmdFound = expectCommand<WALKER_TYPE>(ccsCommands.begin(), ccsCommands.end());
|
|
|
|
|
|
|
|
cmdFound = expectCommand<MI_SEMAPHORE_WAIT>(cmdFound++, ccsCommands.end());
|
|
|
|
verifySemaphore<FamilyType>(cmdFound, bcsSignalAddress);
|
|
|
|
}
|
2020-06-09 01:29:18 +08:00
|
|
|
|
|
|
|
using BlitEnqueueWithDebugCapabilityTests = BlitEnqueueTests<0>;
|
|
|
|
|
2020-06-15 15:40:02 +08:00
|
|
|
HWTEST_TEMPLATED_F(BlitEnqueueWithDebugCapabilityTests, givenDebugFlagSetWhenDispatchingBlitEnqueueThenAddPausingCommands) {
|
2020-06-09 01:29:18 +08:00
|
|
|
using MI_SEMAPHORE_WAIT = typename FamilyType::MI_SEMAPHORE_WAIT;
|
2020-06-17 20:58:28 +08:00
|
|
|
using MI_FLUSH_DW = typename FamilyType::MI_FLUSH_DW;
|
|
|
|
|
|
|
|
DebugManager.flags.PauseOnBlitCopy.set(1);
|
2020-06-09 01:29:18 +08:00
|
|
|
|
2020-06-17 20:58:28 +08:00
|
|
|
auto ultBcsCsr = static_cast<UltCommandStreamReceiver<FamilyType> *>(bcsCsr);
|
2020-06-09 01:29:18 +08:00
|
|
|
|
2020-06-17 20:58:28 +08:00
|
|
|
auto debugPauseStateAddress = ultBcsCsr->getDebugPauseStateGPUAddress();
|
2020-06-09 01:29:18 +08:00
|
|
|
|
|
|
|
auto buffer = createBuffer(1, false);
|
|
|
|
buffer->forceDisallowCPUCopy = true;
|
|
|
|
int hostPtr = 0;
|
|
|
|
|
|
|
|
commandQueue->enqueueWriteBuffer(buffer.get(), true, 0, 1, &hostPtr, nullptr, 0, nullptr, nullptr);
|
|
|
|
commandQueue->enqueueWriteBuffer(buffer.get(), true, 0, 1, &hostPtr, nullptr, 0, nullptr, nullptr);
|
|
|
|
|
|
|
|
HardwareParse hwParser;
|
2020-06-17 20:58:28 +08:00
|
|
|
hwParser.parseCommands<FamilyType>(ultBcsCsr->commandStream);
|
2020-06-09 01:29:18 +08:00
|
|
|
auto &cmdList = hwParser.cmdList;
|
|
|
|
|
|
|
|
auto semaphore = find<MI_SEMAPHORE_WAIT *>(cmdList.begin(), cmdList.end());
|
2020-06-17 20:58:28 +08:00
|
|
|
bool semaphoreBeforeCopyFound = false;
|
|
|
|
bool semaphoreAfterCopyFound = false;
|
2020-06-09 01:29:18 +08:00
|
|
|
while (semaphore != cmdList.end()) {
|
|
|
|
auto semaphoreCmd = genCmdCast<MI_SEMAPHORE_WAIT *>(*semaphore);
|
|
|
|
if (static_cast<uint32_t>(DebugPauseState::hasUserStartConfirmation) == semaphoreCmd->getSemaphoreDataDword()) {
|
|
|
|
EXPECT_EQ(debugPauseStateAddress, semaphoreCmd->getSemaphoreGraphicsAddress());
|
|
|
|
EXPECT_EQ(MI_SEMAPHORE_WAIT::COMPARE_OPERATION::COMPARE_OPERATION_SAD_EQUAL_SDD, semaphoreCmd->getCompareOperation());
|
|
|
|
EXPECT_EQ(MI_SEMAPHORE_WAIT::WAIT_MODE::WAIT_MODE_POLLING_MODE, semaphoreCmd->getWaitMode());
|
|
|
|
|
2020-06-17 20:58:28 +08:00
|
|
|
semaphoreBeforeCopyFound = true;
|
2020-06-09 01:29:18 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (static_cast<uint32_t>(DebugPauseState::hasUserEndConfirmation) == semaphoreCmd->getSemaphoreDataDword()) {
|
2020-06-17 20:58:28 +08:00
|
|
|
EXPECT_TRUE(semaphoreBeforeCopyFound);
|
2020-06-09 01:29:18 +08:00
|
|
|
EXPECT_EQ(debugPauseStateAddress, semaphoreCmd->getSemaphoreGraphicsAddress());
|
|
|
|
EXPECT_EQ(MI_SEMAPHORE_WAIT::COMPARE_OPERATION::COMPARE_OPERATION_SAD_EQUAL_SDD, semaphoreCmd->getCompareOperation());
|
|
|
|
EXPECT_EQ(MI_SEMAPHORE_WAIT::WAIT_MODE::WAIT_MODE_POLLING_MODE, semaphoreCmd->getWaitMode());
|
|
|
|
|
2020-06-17 20:58:28 +08:00
|
|
|
semaphoreAfterCopyFound = true;
|
2020-06-09 01:29:18 +08:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
semaphore = find<MI_SEMAPHORE_WAIT *>(++semaphore, cmdList.end());
|
|
|
|
}
|
|
|
|
|
2020-06-17 20:58:28 +08:00
|
|
|
EXPECT_TRUE(semaphoreAfterCopyFound);
|
|
|
|
|
|
|
|
auto miFlush = find<MI_FLUSH_DW *>(cmdList.begin(), cmdList.end());
|
|
|
|
bool miFlushBeforeCopyFound = false;
|
|
|
|
bool miFlushAfterCopyFound = false;
|
|
|
|
while (miFlush != cmdList.end()) {
|
|
|
|
auto miFlushCmd = genCmdCast<MI_FLUSH_DW *>(*miFlush);
|
|
|
|
if (static_cast<uint32_t>(DebugPauseState::waitingForUserStartConfirmation) == miFlushCmd->getImmediateData() &&
|
|
|
|
debugPauseStateAddress == miFlushCmd->getDestinationAddress()) {
|
|
|
|
|
|
|
|
EXPECT_EQ(MI_FLUSH_DW::POST_SYNC_OPERATION_WRITE_IMMEDIATE_DATA_QWORD, miFlushCmd->getPostSyncOperation());
|
|
|
|
|
|
|
|
miFlushBeforeCopyFound = true;
|
2020-06-09 01:29:18 +08:00
|
|
|
}
|
|
|
|
|
2020-06-17 20:58:28 +08:00
|
|
|
if (static_cast<uint32_t>(DebugPauseState::waitingForUserEndConfirmation) == miFlushCmd->getImmediateData() &&
|
|
|
|
debugPauseStateAddress == miFlushCmd->getDestinationAddress()) {
|
|
|
|
EXPECT_TRUE(miFlushBeforeCopyFound);
|
2020-06-09 01:29:18 +08:00
|
|
|
|
2020-06-17 20:58:28 +08:00
|
|
|
EXPECT_EQ(MI_FLUSH_DW::POST_SYNC_OPERATION_WRITE_IMMEDIATE_DATA_QWORD, miFlushCmd->getPostSyncOperation());
|
|
|
|
|
|
|
|
miFlushAfterCopyFound = true;
|
2020-06-09 01:29:18 +08:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2020-06-17 20:58:28 +08:00
|
|
|
miFlush = find<MI_FLUSH_DW *>(++miFlush, cmdList.end());
|
2020-06-09 01:29:18 +08:00
|
|
|
}
|
|
|
|
|
2020-06-17 20:58:28 +08:00
|
|
|
EXPECT_TRUE(miFlushAfterCopyFound);
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST_TEMPLATED_F(BlitEnqueueWithDebugCapabilityTests, givenDebugFlagSetWhenCreatingCsrThenCreateDebugThread) {
|
|
|
|
DebugManager.flags.PauseOnBlitCopy.set(1);
|
|
|
|
|
|
|
|
auto localDevice = std::make_unique<MockClDevice>(MockDevice::createWithNewExecutionEnvironment<MockDevice>(nullptr));
|
|
|
|
|
|
|
|
auto ultCsr = static_cast<UltCommandStreamReceiver<FamilyType> *>(localDevice->getDefaultEngine().commandStreamReceiver);
|
|
|
|
|
|
|
|
EXPECT_NE(nullptr, ultCsr->userPauseConfirmation.get());
|
2020-06-09 01:29:18 +08:00
|
|
|
}
|
2020-06-19 22:33:53 +08:00
|
|
|
|
|
|
|
struct BlitEnqueueFlushTests : public BlitEnqueueTests<1> {
|
|
|
|
template <typename FamilyType>
|
|
|
|
class MyUltCsr : public UltCommandStreamReceiver<FamilyType> {
|
|
|
|
public:
|
|
|
|
using UltCommandStreamReceiver<FamilyType>::UltCommandStreamReceiver;
|
|
|
|
|
|
|
|
bool flush(BatchBuffer &batchBuffer, ResidencyContainer &allocationsForResidency) override {
|
|
|
|
latestFlushedCounter = ++(*flushCounter);
|
|
|
|
return UltCommandStreamReceiver<FamilyType>::flush(batchBuffer, allocationsForResidency);
|
|
|
|
}
|
|
|
|
|
|
|
|
static CommandStreamReceiver *create(bool withAubDump, ExecutionEnvironment &executionEnvironment, uint32_t rootDeviceIndex) {
|
|
|
|
return new MyUltCsr<FamilyType>(executionEnvironment, rootDeviceIndex);
|
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t *flushCounter = nullptr;
|
|
|
|
uint32_t latestFlushedCounter = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
template <typename T>
|
|
|
|
void SetUpT() {
|
|
|
|
auto csrCreateFcn = &commandStreamReceiverFactory[IGFX_MAX_CORE + defaultHwInfo->platform.eRenderCoreFamily];
|
|
|
|
variableBackup = std::make_unique<VariableBackup<CommandStreamReceiverCreateFunc>>(csrCreateFcn);
|
|
|
|
*csrCreateFcn = MyUltCsr<T>::create;
|
|
|
|
|
|
|
|
BlitEnqueueTests<1>::SetUpT<T>();
|
|
|
|
}
|
|
|
|
|
|
|
|
std::unique_ptr<VariableBackup<CommandStreamReceiverCreateFunc>> variableBackup;
|
|
|
|
};
|
|
|
|
|
|
|
|
HWTEST_TEMPLATED_F(BlitEnqueueFlushTests, givenNonBlockedQueueWhenBlitEnqueuedThenFlushGpgpuCsrFirst) {
|
|
|
|
auto buffer = createBuffer(1, false);
|
|
|
|
buffer->forceDisallowCPUCopy = true;
|
|
|
|
int hostPtr = 0;
|
|
|
|
|
|
|
|
uint32_t flushCounter = 0;
|
|
|
|
|
|
|
|
auto myUltGpgpuCsr = static_cast<MyUltCsr<FamilyType> *>(gpgpuCsr);
|
|
|
|
myUltGpgpuCsr->flushCounter = &flushCounter;
|
|
|
|
auto myUltBcsCsr = static_cast<MyUltCsr<FamilyType> *>(bcsCsr);
|
|
|
|
myUltBcsCsr->flushCounter = &flushCounter;
|
|
|
|
|
|
|
|
commandQueue->enqueueWriteBuffer(buffer.get(), true, 0, 1, &hostPtr, nullptr, 0, nullptr, nullptr);
|
|
|
|
|
|
|
|
EXPECT_EQ(1u, myUltGpgpuCsr->latestFlushedCounter);
|
|
|
|
EXPECT_EQ(2u, myUltBcsCsr->latestFlushedCounter);
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST_TEMPLATED_F(BlitEnqueueFlushTests, givenBlockedQueueWhenBlitEnqueuedThenFlushGpgpuCsrFirst) {
|
|
|
|
auto buffer = createBuffer(1, false);
|
|
|
|
buffer->forceDisallowCPUCopy = true;
|
|
|
|
int hostPtr = 0;
|
|
|
|
|
|
|
|
uint32_t flushCounter = 0;
|
|
|
|
|
|
|
|
auto myUltGpgpuCsr = static_cast<MyUltCsr<FamilyType> *>(gpgpuCsr);
|
|
|
|
myUltGpgpuCsr->flushCounter = &flushCounter;
|
|
|
|
auto myUltBcsCsr = static_cast<MyUltCsr<FamilyType> *>(bcsCsr);
|
|
|
|
myUltBcsCsr->flushCounter = &flushCounter;
|
|
|
|
|
|
|
|
UserEvent userEvent;
|
|
|
|
cl_event waitlist[] = {&userEvent};
|
|
|
|
|
|
|
|
commandQueue->enqueueWriteBuffer(buffer.get(), false, 0, 1, &hostPtr, nullptr, 1, waitlist, nullptr);
|
|
|
|
userEvent.setStatus(CL_COMPLETE);
|
|
|
|
|
|
|
|
EXPECT_EQ(1u, myUltGpgpuCsr->latestFlushedCounter);
|
|
|
|
EXPECT_EQ(2u, myUltBcsCsr->latestFlushedCounter);
|
|
|
|
|
|
|
|
EXPECT_FALSE(commandQueue->isQueueBlocked());
|
|
|
|
}
|
|
|
|
} // namespace NEO
|