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 [2020/01/24 09:37]
nelson
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 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 56: Line 74:
   * Local signal declarations will come just after the module definition and its port declarations. ​   * 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.  ​   * 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 ​camelCase ​and consists of starting the signal name lower case and then as additional descriptive terms are added to the name, capitalizing the first letter of each.  Examples would be: clearTimer, resetConfigurationRegisters,​ or launchMissile.  ​+    * 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.     * 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.     * 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.   * 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.
  
   ​   ​