2017-12-21 07:45:38 +08:00
|
|
|
/*
|
2018-09-18 15:11:08 +08:00
|
|
|
* Copyright (C) 2017-2018 Intel Corporation
|
2017-12-21 07:45:38 +08:00
|
|
|
*
|
2018-09-18 15:11:08 +08:00
|
|
|
* SPDX-License-Identifier: MIT
|
2017-12-21 07:45:38 +08:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
#include "runtime/helpers/preamble.h"
|
|
|
|
#include "runtime/helpers/options.h"
|
|
|
|
#include "unit_tests/command_stream/linear_stream_fixture.h"
|
|
|
|
#include "unit_tests/fixtures/device_fixture.h"
|
|
|
|
#include "unit_tests/fixtures/platform_fixture.h"
|
|
|
|
#include "unit_tests/helpers/hw_parse.h"
|
|
|
|
|
|
|
|
using namespace OCLRT;
|
|
|
|
|
|
|
|
struct PreambleFixture : public DeviceFixture,
|
|
|
|
public LinearStreamFixture,
|
|
|
|
public HardwareParse,
|
|
|
|
public ::testing::Test {
|
|
|
|
void SetUp() override {
|
|
|
|
DeviceFixture::SetUp();
|
|
|
|
HardwareParse::SetUp();
|
|
|
|
}
|
|
|
|
|
|
|
|
void TearDown() override {
|
|
|
|
HardwareParse::TearDown();
|
|
|
|
DeviceFixture::TearDown();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
class PreambleVfeState : public PlatformFixture,
|
|
|
|
public ::testing::Test,
|
|
|
|
public LinearStreamFixture,
|
|
|
|
public HardwareParse {
|
|
|
|
public:
|
|
|
|
void SetUp() override {
|
|
|
|
::testing::Test::SetUp();
|
|
|
|
LinearStreamFixture::SetUp();
|
|
|
|
HardwareParse::SetUp();
|
2018-06-26 16:51:01 +08:00
|
|
|
PlatformFixture::SetUp();
|
2017-12-21 07:45:38 +08:00
|
|
|
const HardwareInfo &hwInfo = pPlatform->getDevice(0)->getHardwareInfo();
|
|
|
|
HardwareInfo *pHwInfo = const_cast<HardwareInfo *>(&hwInfo);
|
|
|
|
pOldWaTable = pHwInfo->pWaTable;
|
|
|
|
memcpy(&testWaTable, pOldWaTable, sizeof(testWaTable));
|
|
|
|
pHwInfo->pWaTable = &testWaTable;
|
|
|
|
}
|
|
|
|
void TearDown() override {
|
|
|
|
const HardwareInfo &hwInfo = pPlatform->getDevice(0)->getHardwareInfo();
|
|
|
|
HardwareInfo *pHwInfo = const_cast<HardwareInfo *>(&hwInfo);
|
|
|
|
pHwInfo->pWaTable = pOldWaTable;
|
|
|
|
PlatformFixture::TearDown();
|
|
|
|
HardwareParse::TearDown();
|
|
|
|
LinearStreamFixture::TearDown();
|
|
|
|
::testing::Test::TearDown();
|
|
|
|
}
|
|
|
|
|
|
|
|
WorkaroundTable testWaTable;
|
|
|
|
const WorkaroundTable *pOldWaTable;
|
|
|
|
};
|