B-Lang-org/bsc

Generate appropriate empty argument lists for Verilog system tasks/functions

Open

#304 opened on Feb 3, 2021

View on GitHub
 (0 comments) (0 reactions) (0 assignees)Haskell (1,108 stars) (178 forks)batch import
good first issuepre-github

Description

When system tasks appear in the generated Verilog, this code in Verilog.hs omits the parenthesis when there are no arguments:

-- no parens when calling a task if it has no arguments                                                                                   
pPrint d p (VTask task []) = pPrint d 0 task <> text ";"

This was probably added because that is how the Verilog standard says that $finish should be written. However, for $fflush, the standard says that it must have empty parentheses, and some tools will be sticklers and issue a warning if the parentheses are missing.

The pPrint code will probably need to check the task name, to handle each specifically.

This is bug 1925 in Bluespec Inc's pre-GitHub bug database.

Contributor guide