This is an old revision of the document!
HDLs (Hardware Description Languages) like SystemVerilog can be difficult to understand. To make SystemVerilog code more readable and maintainable, you are required to follow coding standards. These standards are explained below. Each lab will be graded against this coding standard.
FourFunctions
, the filename will be FourFunctions.sv./*************************************************************************** * * Module: <module Name> * * Author: <Your Name> * Class: <Class, Section, Semester> - ECEN 220, Section 1, Fall 2018 * Date: <Date file was created> * * Description: <Provide a brief description of what this SystemVerilog file does> * * ****************************************************************************/
Timer
.`default_nettype none
macro directive and will use the “old” style of module definitions (see textbook Program 8.4.2 for an example).logic
. (The keywords wire
, reg
, and var
are not allowed to be used.)clrTimer
instead of n7
). _n
suffix for active low signals (eg. write_n
).logic nextState = 0;
. Rather, signals will be declared as in logic nextState;
. always_ff
block and every always_comb
block will be preceded by a comment describing its function and how it should operate. clrTimer
) then a comment describing may not be needed. Otherwise, all signal declarations will have an associated descriptive comment. always_comb
block must begin by assigning default values to all signals being driven in the block. always_ff
block is the <= operator. The only assignment operator allowed in assign
statements and always_comb blocks
is the = operator. clr
or load
signal. always_comb
for the combined IFL/OFL, and an always_ff
for the state register. You may choose whether to use the “normal” state machine coding style shown in the book or the “defensive” style shown in the book.[[ta:tutorials#verilog_coding_standards| TA Feedback]