verilator/test_regress/t/t_mem_multi_io2.cpp

90 lines
2.0 KiB
C++
Raw Normal View History

// -*- mode: C++; c-file-style: "cc-mode" -*-
//
2012-02-02 01:20:43 +00:00
// This file ONLY is placed into the Public Domain, for any use,
// without warranty, 2008 by Lane Brooks.
// SPDX-License-Identifier: CC0-1.0
2012-02-02 01:20:43 +00:00
#include VM_PREFIX_INCLUDE
2012-02-02 01:20:43 +00:00
VM_PREFIX* tb = NULL;
bool pass = true;
double sc_time_stamp() { return 0; }
2012-02-02 01:20:43 +00:00
void check(const char* bus, int got, int exp) {
if (got != exp) {
VL_PRINTF("%%Error: Data mismatch on '%s', got=%x, exp=%x\n", bus, got, exp);
pass = false;
2012-02-02 01:20:43 +00:00
}
}
#ifdef SYSTEMC_VERSION
int sc_main(int, char**)
#else
int main()
#endif
{
2012-02-02 01:20:43 +00:00
Verilated::debug(0);
tb = new VM_PREFIX("tb");
2012-02-02 01:20:43 +00:00
#ifdef SYSTEMC_VERSION
sc_signal<vluint32_t> i3;
sc_signal<vluint32_t> o3;
sc_signal<vluint32_t> i34[4];
sc_signal<vluint32_t> o34[4];
sc_signal<vluint32_t> i345[4][5];
sc_signal<vluint32_t> o345[4][5];
2012-02-02 01:20:43 +00:00
tb->i3(i3);
tb->o3(o3);
for (int i = 0; i < 4; i++) {
tb->i34[i](i34[i]);
tb->o34[i](o34[i]);
for (int j = 0; j < 5; j++) {
tb->i345[i][j](i345[i][j]);
tb->o345[i][j](o345[i][j]);
}
2012-02-02 01:20:43 +00:00
}
#endif
// loop through every possibility and check the result
#ifdef SYSTEMC_VERSION
2020-02-29 14:44:51 +00:00
sc_start(1, SC_NS);
2012-02-02 01:20:43 +00:00
# define ASSIGN(s,v) s.write(v)
# define READ(s) s.read()
#else
tb->eval();
# define ASSIGN(s,v) tb->s = (v)
# define READ(s) tb->s
#endif
ASSIGN(i3, 13);
for (int i = 0; i < 4; i++) {
ASSIGN(i34[i], i);
for (int j = 0; j < 5; j++) {
ASSIGN(i345[i][j], i * 8 + j);
}
2012-02-02 01:20:43 +00:00
}
#ifdef SYSTEMC_VERSION
sc_start(1, SC_NS);
2012-02-02 01:20:43 +00:00
#else
tb->eval();
#endif
check("o3", READ(o3), 13);
for (int i = 0; i < 4; i++) {
check("o34", READ(o34[i]), i);
for (int j = 0; j < 5; j++) {
check("o345", READ(o345[i][j]), i * 8 + j);
}
2012-02-02 01:20:43 +00:00
}
if (pass) {
VL_PRINTF("*-* All Finished *-*\n");
2012-02-02 01:20:43 +00:00
} else {
vl_fatal(__FILE__, __LINE__, "top", "Unexpected results from test\n");
2012-02-02 01:20:43 +00:00
}
return 0;
}