2020-01-17 15:56:05 +08:00
|
|
|
/*
|
2022-01-13 01:53:00 +08:00
|
|
|
* Copyright (C) 2020-2022 Intel Corporation
|
2020-01-17 15:56:05 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
2020-02-24 05:44:01 +08:00
|
|
|
#include "shared/source/command_container/command_encoder.h"
|
2020-12-21 08:56:30 +08:00
|
|
|
#include "shared/source/kernel/kernel_descriptor.h"
|
2021-01-21 20:10:13 +08:00
|
|
|
#include "shared/test/common/fixtures/device_fixture.h"
|
2022-06-30 03:17:47 +08:00
|
|
|
#include "shared/test/common/test_macros/hw_test.h"
|
2020-02-23 16:03:33 +08:00
|
|
|
|
2020-03-19 21:26:08 +08:00
|
|
|
namespace NEO {
|
|
|
|
|
2020-06-02 16:14:02 +08:00
|
|
|
class CommandEncodeStatesFixture : public DeviceFixture {
|
2020-01-17 15:56:05 +08:00
|
|
|
public:
|
2022-03-10 15:32:37 +08:00
|
|
|
class MyMockCommandContainer : public CommandContainer {
|
|
|
|
public:
|
|
|
|
using CommandContainer::dirtyHeaps;
|
|
|
|
};
|
|
|
|
|
2022-08-11 22:01:11 +08:00
|
|
|
void setUp() {
|
|
|
|
DeviceFixture::setUp();
|
2022-03-10 15:32:37 +08:00
|
|
|
cmdContainer = std::make_unique<MyMockCommandContainer>();
|
2022-03-25 01:19:42 +08:00
|
|
|
cmdContainer->initialize(pDevice, nullptr, true);
|
2020-12-04 19:28:18 +08:00
|
|
|
cmdContainer->setDirtyStateForAllHeaps(false);
|
2020-01-17 15:56:05 +08:00
|
|
|
}
|
2022-08-11 22:01:11 +08:00
|
|
|
void tearDown() {
|
2020-01-17 15:56:05 +08:00
|
|
|
cmdContainer.reset();
|
2022-08-11 22:01:11 +08:00
|
|
|
DeviceFixture::tearDown();
|
2020-01-17 15:56:05 +08:00
|
|
|
}
|
2022-03-10 15:32:37 +08:00
|
|
|
std::unique_ptr<MyMockCommandContainer> cmdContainer;
|
2020-12-21 08:56:30 +08:00
|
|
|
KernelDescriptor descriptor;
|
2022-01-13 01:53:00 +08:00
|
|
|
|
|
|
|
EncodeDispatchKernelArgs createDefaultDispatchKernelArgs(Device *device,
|
|
|
|
DispatchKernelEncoderI *dispatchInterface,
|
2022-06-14 21:22:59 +08:00
|
|
|
const void *threadGroupDimensions,
|
2022-01-13 01:53:00 +08:00
|
|
|
bool requiresUncachedMocs) {
|
|
|
|
EncodeDispatchKernelArgs args{
|
2022-04-05 03:07:08 +08:00
|
|
|
0, // eventAddress
|
|
|
|
device, // device
|
|
|
|
dispatchInterface, // dispatchInterface
|
2022-06-14 21:22:59 +08:00
|
|
|
threadGroupDimensions, // threadGroupDimensions
|
2022-04-05 03:07:08 +08:00
|
|
|
PreemptionMode::Disabled, // preemptionMode
|
|
|
|
1, // partitionCount
|
|
|
|
false, // isIndirect
|
|
|
|
false, // isPredicate
|
|
|
|
false, // isTimestampEvent
|
|
|
|
requiresUncachedMocs, // requiresUncachedMocs
|
|
|
|
false, // useGlobalAtomics
|
|
|
|
false, // isInternal
|
2022-05-28 00:47:43 +08:00
|
|
|
false, // isCooperative
|
|
|
|
false, // isHostScopeSignalEvent
|
2022-06-27 18:30:29 +08:00
|
|
|
false, // isKernelUsingSystemAllocation
|
|
|
|
false // isKernelDispatchedFromImmediateCmdList
|
2022-01-13 01:53:00 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
return args;
|
|
|
|
}
|
2020-03-19 21:26:08 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace NEO
|
2020-06-26 22:03:30 +08:00
|
|
|
|
|
|
|
struct WalkerThreadFixture {
|
2022-08-16 20:19:30 +08:00
|
|
|
void setUp() {
|
2020-06-26 22:03:30 +08:00
|
|
|
startWorkGroup[0] = startWorkGroup[1] = startWorkGroup[2] = 0u;
|
|
|
|
numWorkGroups[0] = numWorkGroups[1] = numWorkGroups[2] = 1u;
|
|
|
|
workGroupSizes[0] = 32u;
|
|
|
|
workGroupSizes[1] = workGroupSizes[2] = 1u;
|
|
|
|
simd = 32u;
|
|
|
|
localIdDimensions = 3u;
|
|
|
|
requiredWorkGroupOrder = 0u;
|
|
|
|
}
|
2022-08-16 20:19:30 +08:00
|
|
|
void tearDown() {}
|
2020-06-26 22:03:30 +08:00
|
|
|
|
2020-07-07 04:55:37 +08:00
|
|
|
uint32_t startWorkGroup[3];
|
|
|
|
uint32_t numWorkGroups[3];
|
|
|
|
uint32_t workGroupSizes[3];
|
2020-06-26 22:03:30 +08:00
|
|
|
uint32_t simd;
|
|
|
|
uint32_t localIdDimensions;
|
|
|
|
uint32_t requiredWorkGroupOrder;
|
|
|
|
};
|
|
|
|
|
2022-08-16 20:19:30 +08:00
|
|
|
using WalkerThreadTest = Test<WalkerThreadFixture>;
|