blob: dd57d517d2d82c6a059ac9be0cfb25fb8b78d37d [file] [log] [blame]
#include <stdio.h>
#include <analyzer/plugins/plugin.hpp>
#include <hei_util.hpp>
#include <test/sim-hw-access.hpp>
#include <util/pdbg.hpp>
#include <util/trace.hpp>
#include "gtest/gtest.h"
using namespace analyzer;
static const auto nodeId =
static_cast<libhei::NodeId_t>(libhei::hash<libhei::NodeId_t>("TOD_ERROR"));
TEST(TodStepCheckFault, MdmtFault)
{
pdbg_targets_init(nullptr);
auto proc0 = util::pdbg::getTrgt("/proc0");
auto proc1 = util::pdbg::getTrgt("/proc1");
libhei::Chip chip0{proc0, P10_20};
libhei::Chip chip1{proc1, P10_20};
sim::ScomAccess& scom = sim::ScomAccess::getSingleton();
scom.flush();
// TOD_ERROR[14] = 0b1 step check on primary config master select 0
scom.add(proc0, 0x00040030, 0x0002000000000000); // TOD_ERROR
// TOD_PSS_MSS_STATUS[0:2] = 0b000 primary config is active
// TOD_PSS_MSS_STATUS[12] = 0b0 primary config master select 0
// TOD_PSS_MSS_STATUS[13] = 0b1 primary config master TOD
// TOD_PSS_MSS_STATUS[14] = 0b1 primary config master drawer
scom.add(proc0, 0x00040008, 0x0006000000000000);
// TOD_ERROR[17] = 0b1 internal step check
// TOD_ERROR[21] = 0b1 step check on primary config slave select 1
scom.add(proc1, 0x00040030, 0x0000440000000000); // TOD_ERROR
// TOD_PSS_MSS_STATUS[0:2] = 0b000 primary config is active
// TOD_PSS_MSS_STATUS[15] = 0b1 primary config slave path select 1
scom.add(proc1, 0x00040008, 0x0001000000000000);
// TOD_PRI_PORT_1_CTRL[0:2] = 0b001 IOHS 1
scom.add(proc1, 0x00040002, 0x2000000000000000);
// TOD_ERROR(0)[14] step check error on master select 0
libhei::Signature sig0{chip0, nodeId, 0, 14, libhei::ATTN_TYPE_CHECKSTOP};
// TOD_ERROR(0)[17] internal step check error
libhei::Signature sig1{chip1, nodeId, 0, 17, libhei::ATTN_TYPE_CHECKSTOP};
// TOD_ERROR(0)[21] step check error on slave select 1
libhei::Signature sig2{chip1, nodeId, 0, 21, libhei::ATTN_TYPE_CHECKSTOP};
libhei::IsolationData isoData{};
isoData.addSignature(sig0);
isoData.addSignature(sig1);
isoData.addSignature(sig2);
ServiceData sd{sig1, AnalysisType::SYSTEM_CHECKSTOP, isoData};
// Call the plugin.
auto plugin =
PluginMap::getSingleton().get(chip1.getType(), "tod_step_check_fault");
plugin(0, chip1, sd);
nlohmann::json j{};
std::string s{};
// Callout list
j = sd.getCalloutList();
s = R"([
{
"Deconfigured": false,
"Guarded": false,
"LocationCode": "P0",
"Priority": "M"
},
{
"Deconfigured": false,
"Guarded": false,
"LocationCode": "/proc0",
"Priority": "M"
}
])";
EXPECT_EQ(s, j.dump(4));
// Callout FFDC
j = sd.getCalloutFFDC();
s = R"([
{
"Callout Type": "Clock Callout",
"Clock Type": "TOD_CLOCK",
"Priority": "medium"
},
{
"Callout Type": "Hardware Callout",
"Guard": false,
"Priority": "medium",
"Target": "/proc0"
}
])";
EXPECT_EQ(s, j.dump(4));
}