diff --git a/frontends/verific/verific.cc b/frontends/verific/verific.cc index afa3a92c9c1..08b8c505dce 100644 --- a/frontends/verific/verific.cc +++ b/frontends/verific/verific.cc @@ -2688,11 +2688,51 @@ struct VerificExtNets } }; +#ifdef VERIFIC_SYSTEMVERILOG_SUPPORT +static msg_type_t prev_1063; +#endif +#ifdef VERIFIC_VHDL_SUPPORT +static msg_type_t prev_1240 ; +static msg_type_t prev_1241 ; +#endif +void save_blackbox_msg_state() +{ +#ifdef VERIFIC_SYSTEMVERILOG_SUPPORT + prev_1063 = Message::GetMessageType("VERI-1063") ; + Message::SetMessageType("VERI-1063", VERIFIC_INFO); +#endif +#ifdef VERIFIC_VHDL_SUPPORT + prev_1240 = Message::GetMessageType("VHDL-1240") ; + prev_1241 = Message::GetMessageType("VHDL-1241") ; + Message::SetMessageType("VHDL-1240", VERIFIC_INFO); + Message::SetMessageType("VHDL-1241", VERIFIC_INFO); +#endif +} + +void restore_blackbox_msg_state() +{ +#ifdef VERIFIC_SYSTEMVERILOG_SUPPORT + Message::ClearMessageType("VERI-1063") ; + if (Message::GetMessageType("VERI-1063")!=prev_1063) + Message::SetMessageType("VERI-1063", prev_1063); +#endif +#ifdef VERIFIC_VHDL_SUPPORT + Message::ClearMessageType("VHDL-1240") ; + Message::ClearMessageType("VHDL-1241") ; + if (Message::GetMessageType("VHDL-1240")!=prev_1240) + Message::SetMessageType("VHDL-1240", prev_1240); + if (Message::GetMessageType("VHDL-1241")!=prev_1241) + Message::SetMessageType("VHDL-1241", prev_1241); +#endif +} + void import_all(const char* work, std::map *nl_todo, Map *parameters, bool show_message, std::string ppfile YS_MAYBE_UNUSED) { #ifdef YOSYSHQ_VERIFIC_EXTENSIONS + save_blackbox_msg_state(); VerificExtensions::ElaborateAndRewrite(work, parameters); verific_error_msg.clear(); + restore_blackbox_msg_state(); #endif #ifdef VERIFIC_SYSTEMVERILOG_SUPPORT if (!ppfile.empty()) @@ -2823,8 +2863,10 @@ std::set import_tops(const char* work, std::mapSetCompileAsBlackbox(); } } - Message::ClearMessageType("VHDL-1240") ; - Message::ClearMessageType("VHDL-1241") ; - if (Message::GetMessageType("VHDL-1240")!=prev_1240) - Message::SetMessageType("VHDL-1240", prev_1240); - if (Message::GetMessageType("VHDL-1241")!=prev_1241) - Message::SetMessageType("VHDL-1241", prev_1241); - + restore_blackbox_msg_state(); } #endif - msg_type_t prev_1063; #ifdef VERIFIC_SYSTEMVERILOG_SUPPORT void add_modules_to_map(Map &map, std::string work, bool flag_lib) { @@ -3349,9 +3378,7 @@ struct VerificPass : public Pass { map.Insert(veri_module,veri_module); } } - - prev_1063 = Message::GetMessageType("VERI-1063") ; - Message::SetMessageType("VERI-1063", VERIFIC_INFO); + save_blackbox_msg_state(); } void set_modules_to_blackbox(Map &map, std::string work, bool flag_lib) @@ -3366,9 +3393,6 @@ struct VerificPass : public Pass { veri_module->SetCompileAsBlackbox(); } } - Message::ClearMessageType("VERI-1063") ; - if (Message::GetMessageType("VERI-1063")!=prev_1063) - Message::SetMessageType("VERI-1063", prev_1063); } #endif @@ -3424,7 +3448,6 @@ struct VerificPass : public Pass { RuntimeFlags::SetVar("veri_preserve_assignments", 1); RuntimeFlags::SetVar("veri_preserve_comments", 1); RuntimeFlags::SetVar("veri_preserve_drivers", 1); - RuntimeFlags::SetVar("veri_create_empty_box", 1); // Workaround for VIPER #13851 RuntimeFlags::SetVar("veri_create_name_for_unnamed_gen_block", 1); diff --git a/tests/verific/blackbox_empty.ys b/tests/verific/blackbox_empty.ys new file mode 100644 index 00000000000..fb407fe0688 --- /dev/null +++ b/tests/verific/blackbox_empty.ys @@ -0,0 +1,17 @@ +verific -sv <