2019-10-09 10:47:26 +00:00
|
|
|
// DESCRIPTION: Verilator: --protect-lib example module
|
|
|
|
//
|
2020-03-21 15:24:24 +00:00
|
|
|
// This file ONLY is placed under the Creative Commons Public Domain, for
|
|
|
|
// any use, without warranty, 2019 by Todd Strader.
|
|
|
|
// SPDX-License-Identifier: CC0-1.0
|
2019-10-09 10:47:26 +00:00
|
|
|
//======================================================================
|
|
|
|
|
|
|
|
// See examples/tracing_c for notes on tracing
|
|
|
|
|
|
|
|
// Include common routines
|
|
|
|
#include <verilated.h>
|
|
|
|
|
|
|
|
#include "Vtop.h"
|
|
|
|
|
|
|
|
#if VM_TRACE
|
2021-01-03 16:57:29 +00:00
|
|
|
#include <verilated_vcd_c.h>
|
2019-10-09 10:47:26 +00:00
|
|
|
#endif
|
|
|
|
|
2022-11-23 23:50:31 +00:00
|
|
|
int main(int argc, char** argv) {
|
2024-03-27 22:07:14 +00:00
|
|
|
(void)argc;
|
|
|
|
(void)argv;
|
2019-10-09 10:47:26 +00:00
|
|
|
|
2021-03-07 16:01:54 +00:00
|
|
|
// Construct context to hold simulation time, etc
|
2024-01-28 19:47:14 +00:00
|
|
|
const std::unique_ptr<VerilatedContext> contextp{new VerilatedContext};
|
2021-03-07 16:01:54 +00:00
|
|
|
contextp->debug(0);
|
|
|
|
contextp->randReset(2);
|
|
|
|
contextp->commandArgs(argc, argv);
|
2019-10-09 10:47:26 +00:00
|
|
|
|
|
|
|
// Construct the Verilated model, including the secret module
|
2024-01-28 19:47:14 +00:00
|
|
|
const std::unique_ptr<Vtop> top{new Vtop{contextp.get(), "TOP"}};
|
2019-10-09 10:47:26 +00:00
|
|
|
|
|
|
|
#if VM_TRACE
|
|
|
|
// When tracing, the contents of the secret module will not be seen
|
2020-08-15 14:12:55 +00:00
|
|
|
VerilatedVcdC* tfp = nullptr;
|
2021-03-07 16:01:54 +00:00
|
|
|
const char* flag = contextp->commandArgsPlusMatch("trace");
|
2022-09-15 01:10:19 +00:00
|
|
|
if (flag && 0 == std::strcmp(flag, "+trace")) {
|
2021-03-07 16:01:54 +00:00
|
|
|
contextp->traceEverOn(true);
|
2019-10-09 10:47:26 +00:00
|
|
|
VL_PRINTF("Enabling waves into logs/vlt_dump.vcd...\n");
|
|
|
|
tfp = new VerilatedVcdC;
|
|
|
|
top->trace(tfp, 99);
|
|
|
|
Verilated::mkdir("logs");
|
|
|
|
tfp->open("logs/vlt_dump.vcd");
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
top->clk = 0;
|
|
|
|
|
|
|
|
// Simulate until $finish
|
2021-03-07 16:01:54 +00:00
|
|
|
while (!contextp->gotFinish()) {
|
2019-10-09 10:47:26 +00:00
|
|
|
top->clk = ~top->clk & 0x1;
|
|
|
|
top->eval();
|
|
|
|
#if VM_TRACE
|
2021-03-07 16:01:54 +00:00
|
|
|
if (tfp) tfp->dump(contextp->time());
|
2019-10-09 10:47:26 +00:00
|
|
|
#endif
|
2024-06-12 00:55:01 +00:00
|
|
|
contextp->timeInc(1);
|
2019-10-09 10:47:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Final model cleanup
|
|
|
|
top->final();
|
|
|
|
|
|
|
|
// Close trace if opened
|
|
|
|
#if VM_TRACE
|
2020-04-14 02:51:35 +00:00
|
|
|
if (tfp) {
|
|
|
|
tfp->close();
|
2020-08-15 14:12:55 +00:00
|
|
|
tfp = nullptr;
|
2020-04-14 02:51:35 +00:00
|
|
|
}
|
2019-10-09 10:47:26 +00:00
|
|
|
#endif
|
|
|
|
|
2021-01-03 16:57:29 +00:00
|
|
|
// Return good completion status
|
2021-02-13 22:06:53 +00:00
|
|
|
// Don't use exit() or destructor won't get called
|
|
|
|
return 0;
|
2019-10-09 10:47:26 +00:00
|
|
|
}
|