Fix VPI module tree (#2704)

This commit is contained in:
Todd Strader 2020-12-16 11:46:57 -05:00 committed by GitHub
parent f98782c061
commit b75901b3eb
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 45 additions and 12 deletions

View File

@ -691,7 +691,6 @@ void EmitCSyms::emitSymImp() {
++it) { ++it) {
string name = it->second.m_prettyName; string name = it->second.m_prettyName;
if (it->first == "TOP") continue; if (it->first == "TOP") continue;
name = name.replace(0, 4, ""); // Remove the "TOP."
if ((name.find('.') == string::npos) && (it->second.m_type == "SCOPE_MODULE")) { if ((name.find('.') == string::npos) && (it->second.m_type == "SCOPE_MODULE")) {
puts("__Vhier.add(0, &" + protect("__Vscope_" + it->second.m_symName) + ");\n"); puts("__Vhier.add(0, &" + protect("__Vscope_" + it->second.m_symName) + ");\n");
} }

View File

@ -1161,7 +1161,7 @@ sub compile {
if ($param{make_pli}) { if ($param{make_pli}) {
$self->oprint("Compile vpi\n") if $self->{verbose}; $self->oprint("Compile vpi\n") if $self->{verbose};
my @cmd = ($ENV{CXX}, @{$param{pli_flags}}, "-DIS_VPI", my @cmd = ($ENV{CXX}, @{$param{pli_flags}}, "-DIS_VPI", $ENV{CFLAGS},
"$self->{t_dir}/$self->{pli_filename}"); "$self->{t_dir}/$self->{pli_filename}");
$self->_run(logfile=>"$self->{obj_dir}/pli_compile.log", $self->_run(logfile=>"$self->{obj_dir}/pli_compile.log",
@ -2731,7 +2731,7 @@ Run simulator-agnostic distribution tests.
Run GHDL simulator tests. Run GHDL simulator tests.
=item --iverilog =item --iv
Run Icarus Verilog simulator tests. Run Icarus Verilog simulator tests.

View File

@ -48,6 +48,12 @@ unsigned int main_time = 0;
return __LINE__; \ return __LINE__; \
} }
#define CHECK_RESULT_Z(got) \
if (got) { \
printf("%%Error: %s:%d: GOT = !NULL EXP = NULL\n", FILENM, __LINE__); \
return __LINE__; \
}
#define CHECK_RESULT_CSTR(got, exp) \ #define CHECK_RESULT_CSTR(got, exp) \
if (strcmp((got), (exp))) { \ if (strcmp((got), (exp))) { \
printf("%%Error: %s:%d: GOT = '%s' EXP = '%s'\n", FILENM, __LINE__, \ printf("%%Error: %s:%d: GOT = '%s' EXP = '%s'\n", FILENM, __LINE__, \
@ -55,17 +61,45 @@ unsigned int main_time = 0;
return __LINE__; \ return __LINE__; \
} }
void modDump(const TestVpiHandle& it, int n) {
while (TestVpiHandle hndl = vpi_scan(it)) {
const char* nm = vpi_get_str(vpiName, hndl);
for (int i = 0; i < n; i++) printf(" ");
printf("%s\n", nm);
TestVpiHandle subIt = vpi_iterate(vpiModule, hndl);
if (subIt) modDump(subIt, n + 1);
}
}
extern "C" { extern "C" {
int mon_check() { int mon_check() {
TestVpiHandle it = vpi_iterate(vpiModule, NULL); TestVpiHandle it = vpi_iterate(vpiModule, NULL);
#ifdef IS_ICARUS
// Icarus segfaults when some VPI handles are freed
it.nofree();
#endif
CHECK_RESULT_NZ(it); CHECK_RESULT_NZ(it);
// Uncomment to see what other simulators return
// modDump(it, 0);
// return 1;
TestVpiHandle topmod = vpi_scan(it); TestVpiHandle topmod = vpi_scan(it);
CHECK_RESULT_NZ(topmod); CHECK_RESULT_NZ(topmod);
char* name = vpi_get_str(vpiName, topmod); const char* t_name = vpi_get_str(vpiName, topmod);
CHECK_RESULT_NZ(name); CHECK_RESULT_NZ(t_name);
CHECK_RESULT_CSTR(name, "t");
// Icarus reports the top most module as "top"
if (strcmp(t_name, "top") == 0) {
it = vpi_iterate(vpiModule, topmod);
CHECK_RESULT_NZ(it);
topmod = vpi_scan(it);
t_name = vpi_get_str(vpiName, topmod);
CHECK_RESULT_NZ(t_name);
}
CHECK_RESULT_CSTR(t_name, "t");
TestVpiHandle topmod_done = (vpi_scan(it));
CHECK_RESULT_Z(topmod_done);
TestVpiHandle it2 = vpi_iterate(vpiModule, topmod); TestVpiHandle it2 = vpi_iterate(vpiModule, topmod);
CHECK_RESULT_NZ(it2); CHECK_RESULT_NZ(it2);
@ -73,8 +107,8 @@ int mon_check() {
TestVpiHandle mod2 = vpi_scan(it2); TestVpiHandle mod2 = vpi_scan(it2);
CHECK_RESULT_NZ(mod2); CHECK_RESULT_NZ(mod2);
name = vpi_get_str(vpiName, mod2); const char* mod_a_name = vpi_get_str(vpiName, mod2);
CHECK_RESULT_CSTR(name, "mod_a"); CHECK_RESULT_CSTR(mod_a_name, "mod_a");
TestVpiHandle it3 = vpi_iterate(vpiModule, mod2); TestVpiHandle it3 = vpi_iterate(vpiModule, mod2);
CHECK_RESULT_NZ(it3); CHECK_RESULT_NZ(it3);
@ -82,14 +116,14 @@ int mon_check() {
TestVpiHandle mod3 = vpi_scan(it3); TestVpiHandle mod3 = vpi_scan(it3);
CHECK_RESULT_NZ(mod3); CHECK_RESULT_NZ(mod3);
name = vpi_get_str(vpiName, mod3); const char* mod_c_name = vpi_get_str(vpiName, mod3);
if (strcmp(name, "mod_b") == 0) { if (strcmp(mod_c_name, "mod_b") == 0) {
// Full visibility in other simulators, skip mod_b // Full visibility in other simulators, skip mod_b
TestVpiHandle mod4 = vpi_scan(it3); TestVpiHandle mod4 = vpi_scan(it3);
CHECK_RESULT_NZ(mod4); CHECK_RESULT_NZ(mod4);
name = vpi_get_str(vpiName, mod4); mod_c_name = vpi_get_str(vpiName, mod4);
} }
CHECK_RESULT_CSTR(name, "mod_c."); CHECK_RESULT_CSTR(mod_c_name, "mod_c.");
return 0; // Ok return 0; // Ok
} }