User Tools


Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
verilog_coding_standards [2019/05/09 12:47]
jgoeders
verilog_coding_standards [2020/05/11 17:30] (current)
Line 1: Line 1:
 ====== SystemVerilog Coding Standards ====== ====== SystemVerilog Coding Standards ======
 **HDL**s (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. **HDL**s (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.
 +
 +<color red>
 +NEW video standard recently added... ​ See below!!
 +</​color>​
 +
 +=== Videos ===
 +If you are asked to attach a video to your project, please do it as follows.
 +
 +There is a about a 150MB limit to the size of video you can upload. ​ On a cellphone at default resolution that is not that long.  ​
 +You can try to reduce the recording resolution but, at least on an iPhone, you cannot reduce it much.  If it is too large, you can try
 +one of the following:
 +
 +  * Process it using a program to convert it to a 640x480 size video. ​ That should be big enough.
 +  * Upload it to one of Youtube, Dropbox, Google Drive, or Box and enter a link where the TA's can find it instead of actually uploading your video to LearningSuite.
 +  * Find a website that will let you upload and it it will downconvert it for you.  CAUTION: these are notorious for installing junk on your computer so be careful if you go this route and use it as a method of last resort. ​
 +
 +Of these, Youtube is pretty painless but any of the second group will work.
 + 
  
 === Files=== === Files===
Line 9: Line 27:
  
   * Each .sv file will have a header as follows:   * Each .sv file will have a header as follows:
-<​code>​+<​code ​verilog>
 /​*************************************************************************** /​***************************************************************************
  
Line 15: Line 33:
 * *
 * Author: <Your Name> * Author: <Your Name>
-* Class: <Class, Section, Semester>​ - ECEN 220, Section 1, Fall 2018+* Class: <Class, Section, Semester>​ - ECEN 220, Section 1, Winter 2020
 * Date: <Date file was created> * Date: <Date file was created>
 * *
Line 32: Line 50:
     * Declare internal signals as ''​logic''​     * Declare internal signals as ''​logic''​
     * The keywords ''​reg'',​ and ''​var''​ are not allowed to be used, and ''​wire''​ can only be used for inputs as described above.     * The keywords ''​reg'',​ and ''​var''​ are not allowed to be used, and ''​wire''​ can only be used for inputs as described above.
-  * Signal names: +  * Signal names: ​   ​
-    * Start with a lower case letter. ​+
     * Are descriptive (''​clrTimer''​ instead of ''​n7''​).  ​     * Are descriptive (''​clrTimer''​ instead of ''​n7''​).  ​
     * Will have a ''​_n''​ suffix for active low signals (eg. ''​write_n''​).     * Will have a ''​_n''​ suffix for active low signals (eg. ''​write_n''​).
-  * Local signal declarations will come just after the module definition and its port declarations. ​+
   * When signals are declared, they will not use an initializer. ​ For example, this is incorrect: ''​logic nextState = 0;''​. ​ Rather, signals will be declared as in ''​logic nextState;''​.  ​   * When signals are declared, they will not use an initializer. ​ For example, this is incorrect: ''​logic nextState = 0;''​. ​ Rather, signals will be declared as in ''​logic nextState;''​.  ​
 /*Any initializations you want done to your registers will be done explicitly via the assertion of signals such as '​clrTimer'​ and the like.*/ /*Any initializations you want done to your registers will be done explicitly via the assertion of signals such as '​clrTimer'​ and the like.*/
Line 44: Line 61:
   * Each ''​always_ff''​ block and every ''​always_comb''​ block will be preceded by a comment describing its function and how it should operate. ​   * Each ''​always_ff''​ block and every ''​always_comb''​ block will be preceded by a comment describing its function and how it should operate. ​
   * If the name of a signal is expressive enough (e.g. ''​clrTimer''​) then a comment describing may not be needed. ​ Otherwise, all signal declarations will have an associated descriptive comment. ​     * If the name of a signal is expressive enough (e.g. ''​clrTimer''​) then a comment describing may not be needed. ​ Otherwise, all signal declarations will have an associated descriptive comment. ​  
-  ​* The code for the different sub-modules in a module will be grouped together. ​ For example, the statements associated with the timer circuitry will appear together, followed by the statements associated with the bit counter circuitry, followed by the state machine. ​ Each such section of circuitry will have comments delimiting it. +  ​
 === Design Requirements === === Design Requirements ===
   * The only assignment operator allowed in an ''​always_ff''​ block is the <​nowiki><​=</​nowiki>​ operator. ​ The only assignment operator allowed in ''​assign''​ statements and ''​always_comb blocks''​ is the = operator. ​     * The only assignment operator allowed in an ''​always_ff''​ block is the <​nowiki><​=</​nowiki>​ operator. ​ The only assignment operator allowed in ''​assign''​ statements and ''​always_comb blocks''​ is the = operator. ​  
Line 52: Line 68:
 /*  * The exception to this may be something like a shift register which will eventually shift in known data and therefore which does not necessarily require an explicit ''​clr''​ or ''​load''​ signal. */ /*  * The exception to this may be something like a shift register which will eventually shift in known data and therefore which does not necessarily require an explicit ''​clr''​ or ''​load''​ signal. */
   * Outputs from counters, state machines, etc. will be combinational except in very rare cases. ​   * Outputs from counters, state machines, etc. will be combinational except in very rare cases. ​
-  * Finite state machines will be coded using the style of the textbook including the use of an enumerated type for the state type, an ''​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.+  * Finite state machines will be coded using the style of the textbook including the use of an enumerated type for the state type, an ''​always_comb''​ for the combined IFL/OFL, and an ''​always_ff''​ for the state register.  ​
  
-/* +=== Suggested Style=== 
-=== Other === +  * The code for the different sub-modules ​in a module will be grouped together. ​ For example, the statements associated with the timer circuitry ​will appear together, followed by the statements associated with the bit counter circuitry, followed by the state machine. ​ Each such section of circuitry will have comments delimiting it. 
-  * When modules ​are instantiated hierarchically, the instance name will be all uppercase. ​  ​ +  * Local signal declarations will come just after the module definition and its port declarations.  
-*/+  * In programming (as well as HDL-based design) there are two common ways of naming signals so that their meaning is obvious. ​  
 +    * One way is called camel case and consists of starting the signal name with a lower case letter and then capitalizing subsequent words as in: clearTimer, resetConfigurationRegisters,​ or launchMissile. ​  
 +    * The second way is to make everything lower case and use underscores to separate the pieces as in: clear_timer,​ reset_configuration_registers,​ and launch_missile. 
 +    * Choose one of these two styles, ​be consistent, and use descriptive signal names. 
 +  * Similarly, there are common ways of naming modules and constants. ​ For modules, it is common practice to start their names with a capital letter as in: EventCounter or InitializationRegisters. ​ For constants (sometimes called parameters in SystemVerilog),​ it is common to make them uppercase ​as in INITVAL, THRESHOLD, or DATAWIDTH
 +  Why would any of this be important? ​ In a large design with literally 100,​000'​s of signals and 1,​000'​s of modules, this will add uniformity to the design to help make the code more readable and maintain-able.
  
 +  ​