2022-09-15 00:28:41 +00:00
|
|
|
/*
|
2023-01-16 15:30:27 +00:00
|
|
|
* Copyright (C) 2022-2023 Intel Corporation
|
2022-09-15 00:28:41 +00:00
|
|
|
*
|
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include "shared/test/unit_test/fixtures/command_container_fixture.h"
|
|
|
|
|
|
2023-03-16 00:12:49 +00:00
|
|
|
#include "shared/source/indirect_heap/heap_size.h"
|
2023-03-10 12:28:11 +00:00
|
|
|
#include "shared/source/os_interface/product_helper.h"
|
2023-01-16 15:30:27 +00:00
|
|
|
#include "shared/test/common/mocks/mock_device.h"
|
2022-09-15 00:28:41 +00:00
|
|
|
|
|
|
|
|
namespace NEO {
|
|
|
|
|
|
|
|
|
|
void CommandEncodeStatesFixture::setUp() {
|
|
|
|
|
DeviceFixture::setUp();
|
|
|
|
|
cmdContainer = std::make_unique<MyMockCommandContainer>();
|
2023-03-16 00:12:49 +00:00
|
|
|
cmdContainer->initialize(pDevice, nullptr, HeapSize::defaultHeapSize, true, false);
|
2022-09-15 00:28:41 +00:00
|
|
|
cmdContainer->setDirtyStateForAllHeaps(false);
|
|
|
|
|
const auto &hwInfo = pDevice->getHardwareInfo();
|
2023-01-23 13:20:47 +00:00
|
|
|
auto &productHelper = pDevice->getProductHelper();
|
|
|
|
|
cmdContainer->systolicModeSupport = productHelper.isSystolicModeConfigurable(hwInfo);
|
2023-02-22 21:30:40 +00:00
|
|
|
cmdContainer->doubleSbaWa = productHelper.isAdditionalStateBaseAddressWARequired(hwInfo);
|
2023-02-24 16:55:21 +00:00
|
|
|
this->l1CachePolicyData.init(productHelper);
|
|
|
|
|
cmdContainer->l1CachePolicyData = &this->l1CachePolicyData;
|
2022-09-15 00:28:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void CommandEncodeStatesFixture::tearDown() {
|
|
|
|
|
cmdContainer.reset();
|
|
|
|
|
DeviceFixture::tearDown();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
EncodeDispatchKernelArgs CommandEncodeStatesFixture::createDefaultDispatchKernelArgs(Device *device,
|
|
|
|
|
DispatchKernelEncoderI *dispatchInterface,
|
|
|
|
|
const void *threadGroupDimensions,
|
|
|
|
|
bool requiresUncachedMocs) {
|
2023-01-26 14:33:36 +00:00
|
|
|
|
2022-09-15 00:28:41 +00:00
|
|
|
EncodeDispatchKernelArgs args{
|
|
|
|
|
0, // eventAddress
|
|
|
|
|
device, // device
|
|
|
|
|
dispatchInterface, // dispatchInterface
|
2023-01-26 14:33:36 +00:00
|
|
|
nullptr, // surfaceStateHeap
|
|
|
|
|
nullptr, // dynamicStateHeap
|
2022-09-15 00:28:41 +00:00
|
|
|
threadGroupDimensions, // threadGroupDimensions
|
|
|
|
|
nullptr, // additionalCommands
|
|
|
|
|
PreemptionMode::Disabled, // preemptionMode
|
|
|
|
|
1, // partitionCount
|
|
|
|
|
false, // isIndirect
|
|
|
|
|
false, // isPredicate
|
|
|
|
|
false, // isTimestampEvent
|
|
|
|
|
requiresUncachedMocs, // requiresUncachedMocs
|
|
|
|
|
false, // useGlobalAtomics
|
|
|
|
|
false, // isInternal
|
|
|
|
|
false, // isCooperative
|
|
|
|
|
false, // isHostScopeSignalEvent
|
|
|
|
|
false, // isKernelUsingSystemAllocation
|
|
|
|
|
false, // isKernelDispatchedFromImmediateCmdList
|
2022-10-11 18:47:13 +00:00
|
|
|
false, // isRcs
|
|
|
|
|
false // dcFlushEnable
|
2022-09-15 00:28:41 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
return args;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
} // namespace NEO
|
|
|
|
|
|
|
|
|
|
void WalkerThreadFixture::setUp() {
|
|
|
|
|
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;
|
|
|
|
|
}
|