This is a beginner friendly tutorial repository to learn verilog easily with all the basics that are required to get started for this language. Also, this repository is read only and is not currently being maintained by the author .
- sudo apt-get update
- sudo apt-get install verilog
- sudo apt-get install gtkwave
Verilog is a hardware language which is a concurrent, case-sensitive and synthesizable language. Examples of such languages are VHDL( VHSIC(Very High Speed Integrated Circuit) HDL). It is vendor independent for example, Xilinx, Verywell etc.Full form verilog is Verify Logic. It is used for Digital ICs not for Analog ICs.It uses gate level design abstraction. It was made at Gateway Design Automation and now is IEEE 1364-2001 standard. HDL came to help with the verification of design of complex circuits that are in place. Also, logic synthesis tools can convert design to any fabrication technology.
Now, verilog's basic building block is a module that provides information about input and output ports but hides internal implementation.
- Behavioral Level( Design of Algorithm ) : Algorithmic and performance oriented programs are written with it.
- Dataflow Level( Design of Equation ) : "assign" keyword is used for dataflow modelling. ex : assign c = a+b;
- Gate Level( Interconnection with Logic Gates ) : Circuits will be defined by logic gates. ex : and(output, input) etc.
- Switch Level( Implementation in terms of switches ) : Transistors either MOS or switches which conduct or are open. This style is complex and decreasing in popularity.
Two primary data-types are as follows :
- Nets : Connection between the components. Internal connection & is needed to be hidden from the user. Like, wire a;
- Registers : Store the data in variable. Like, reg a;
Other data-types are :
- Vectors : nets and registers can be declared as vectors with different widths. Like, wire[2:0] a; reg[7:0] b;
- Values : 0(Logical zero/false), 1(Logical one/true), X(Unknown Logic Value), Z(High Impedance).
Integers, Arrays, Memories, Parameters, Strings are few other data types.
- Module Instantiation : Process of connecting one module to another. Its subparts are Positional Mapping and Nomenclature Based Mapping.
ex 1 : module pos_map(q,clk,rst)
    output[1:0] q;
    input clk, rst;
    tflipflop lab0(q[0], clk, rst);
    tflipflop lab1(q[1], clk, rst);
    end
    
ex 2 : module nom_map(q,clk,rst)
    output[1:0] q;
    input clk, rst;
    tflipflop lab0(.q(q[0]), .clk(clk), .rst(rst));
    tflipflop lab1(.q(q[0]), .clk(clk), .rst(rst));
    end
- 
Comments : // for single line comment and /* ... */ multiple comment lines. 
- 
$display vs $monitor : $dispay is used to display immediate value of variables. It gets executed in an active region. $monitor gets executed whenever the value of the given variable changes in it. It gets executed in the postponed region. Monitor is required only once to be written. 
- Data Flow Modelling and Logic Gate Modelling
- Asynchronous and Synchronous D-FlipFlop
- Four Bit Counter
- Decoder 3x8
- Encoder 4x2
- DeMux 1x4
- Mux 2x1
- SR Flip Flop
- JK Flip Flop
- T Flip Flop
- D Flip Flop
- Blocking Statements and Non-Blocking Statements
- Seven Segment Display
- Mealy '000' Sequence Machine and Mealy '1001' Sequence Machine
- Moore '000' Sequence Machine
- Traffic Lights - Two Lights/4-Point Crossing
- Half Subtractor, Full Subtractor, Half Adder, Full Adder : Using DataFlow, LogicGate Modelling, case statements.
- Master-Slave JK Flip-Flop : Truth table for master and slave latch both.