forked from github/verilator
5b3717b369
This patch normalizes what the tests do before exiting. After this change each test should call final on the top module and explicitly free the top module object before exiting.
55 lines
1.4 KiB
C++
55 lines
1.4 KiB
C++
// -*- mode: C++; c-file-style: "cc-mode" -*-
|
|
//*************************************************************************
|
|
//
|
|
// Copyright 2020 by Geza Lore. This program is free software; you can
|
|
// redistribute it and/or modify it under the terms of either the GNU
|
|
// Lesser General Public License Version 3 or the Perl Artistic License
|
|
// Version 2.0.
|
|
// SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0
|
|
//
|
|
//*************************************************************************
|
|
|
|
#include <iostream>
|
|
|
|
#include "verilated.h"
|
|
#include VM_PREFIX_INCLUDE
|
|
|
|
// clang-format off
|
|
#if defined(T_X_ASSIGN_0)
|
|
# define EXPECTED 0
|
|
#elif defined(T_X_ASSIGN_1)
|
|
# define EXPECTED 1
|
|
#elif defined(T_X_ASSIGN_UNIQUE_0)
|
|
# define EXPECTED 0
|
|
#elif defined(T_X_ASSIGN_UNIQUE_1)
|
|
# define EXPECTED 1
|
|
#else
|
|
# error "Don't know expectd output for test" #TEST
|
|
#endif
|
|
// clang-format on
|
|
|
|
int main(int argc, const char** argv) {
|
|
VM_PREFIX* top = new VM_PREFIX();
|
|
|
|
#if defined(T_X_ASSIGN_UNIQUE_0)
|
|
Verilated::randReset(0);
|
|
#elif defined(T_X_ASSIGN_UNIQUE_1)
|
|
Verilated::randReset(1);
|
|
#endif
|
|
|
|
// Evaluate one clock posedge
|
|
top->clk = 0;
|
|
top->eval();
|
|
top->clk = 1;
|
|
top->eval();
|
|
|
|
if (top->o != EXPECTED) {
|
|
vl_fatal(__FILE__, __LINE__, "TOP.t", "incorrect module output");
|
|
exit(1);
|
|
}
|
|
|
|
VL_DO_DANGLING(delete top, top);
|
|
std::cout << "*-* All Finished *-*" << std::endl;
|
|
return 0;
|
|
}
|