B-Lang-org/bsc

bsc does not update generated verilog/sim when BSV preprocessor macros changed

Open

#290 opened on Jan 8, 2021

View on GitHub
 (1 comment) (0 reactions) (0 assignees)Haskell (1,108 stars) (178 forks)batch import
good first issue

Description

package A;

module mkA();
`ifdef MY_MACRO
// behavior 1
rule behavior_1;
$display("behavior 1");
endrule
`else
// behavior 2
rule behavior_2;
$display("behavior 2");
endrule
`endif
endmodule
endpackage

If I first run

bsc -verilog -g mkA -D MY_MACRO  A.bsv

the generated verilog is based on the code in "behavior 1" block. But then, if I subsequently run:

bsc -u -verilog -g mkA A.bsv

The module is not recompiled and the Verilog is still based on "behavior 1" block. I expect bsc to analyze the module again and re-generate the verilog based on "behavior 2".

I need to manually remove the .bo files and rerun bsc to get the expected behavior.

Contributor guide