01-Verilog Introduction
Download
Report
Transcript 01-Verilog Introduction
Digital System Design
Verilog® HDL
Maziar Goudarzi
Today program
History of Verilog® HDL
Overview of Digital Design with Verilog®
HDL
Hello World!
Hierarchical Modeling Concepts
2005
Verilog HDL
2
History of Verilog® HDL
Beginning: 1983
“Gateway Design Automation” company
Simulation environment
Comprising various levels of abstraction
• Switch (transistors), gate, register-transfer, and higher
levels
2005
Verilog HDL
3
History of Verilog® HDL (cont’d)
Three factors to success of Verilog
Programming Language Interface (PLI)
Extend and customize simulation environment
Close attention to the needs of ASIC foundries
“Gateway Design Automation” partnership with
Motorola, National, and UTMC in 1987-89
Verilog-based synthesis technology
“Gateway Design Automation” licensed Verilog to
Synopsys
Synopsys introduced synthesis from Verilog in 1987
2005
Verilog HDL
4
History of Verilog® HDL (cont’d)
VHDL
VHSIC (Very High Speed Integrated Circuit)
Hardware Description Language
Developed under contract from DARPA
IEEE standard
Public domain
Other EDA vendors adapted VHDL
“Gateway” put Verilog in public domain
2005
Verilog HDL
5
History of Verilog® HDL (cont’d)
Today
Market divided between Verilog & VHDL
VHDL mostly in Europe
Verilog dominant in US
VHDL
More general language
Not all constructs are synthesizable
Verilog:
Not as general as VHDL
Most constructs are synthesizable
2005
Verilog HDL
6
Verilog® HDL
Overview of Digital Design
Using Verilog
Overview of Digital Design Using Verilog
Evolution of Computer-Aided Digital Design
Emergence of HDLs
Typical Design Flow
Importance of HDLs
Popularity of Verilog HDL
Trends in HDLs
2005
Verilog HDL
8
Evolution of Computer-Aided Digital
Design
SSI: Small scale integration
A few gates on a chip
MSI: Medium scale integration
Hundreds of gates on a chip
LSI: Large scale integration
Thousands of gates on a chip
CAD: Computer-Aided Design
CAD vs. CAE
Logic and circuit simulators
Prototyping on bread board
Layout by hand (on paper or a computer terminal)
2005
Verilog HDL
9
Evolution of Computer-Aided Digital
Design (cont’d)
VLSI: Very Large Scale Integration
Hundred thousands of gates
Not feasible anymore:
Bread boarding
Manual layout design
Simulator programs
Automatic place-and-route
Bottom-Up design
Design small building blocks
Combine them to develop bigger ones
More and more emphasis on logic simulation
2005
Verilog HDL
10
Emergence of HDLs
The need to a standardized language for
hardware description
Verilog® and VHDL
Simulators emerged
Usage: functional verification
Path to implementation: manual translation into gates
Logic synthesis technology
Late 1980s
Dramatic change in digital design
Design at Register-Transfer Level (RTL) using an HDL
2005
Verilog HDL
11
Typical Design Flow (in 1996)
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
2005
Design specification
Behavioral description
RTL description
Functional verification and testing
Logic synthesis
Gate-level netlist
Logical verification and testing
Floor planning, automatic place & route
Physical layout
Layout verification
Implementation
Verilog HDL
12
Typical Design Flow (cont’d)
Most design activity
In 1996:
Manually optimizing the RTL design
CAD tools take care of generating lower-level details
Reducing design time to months from years
Today
Still RTL is used in many cases
But, synthesis from behavioral-level also possible
Digital design now resembles high-level computer
programming
2005
Verilog HDL
13
Typical Design Flow (cont’d)
NOTE:
CAD tools help, but the designer still has the
main role
GIGO (Garbage-In Garbage-Out) concept
To obtain an optimized design, the designer needs to
know about the synthesis technology
• Compare to software programming and compilation
2005
Verilog HDL
14
Importance of HDLs
Retargeting to a new fabrication
technology
Functional verification earlier in the design
cycle
Textual concise representation of the
design
Similar to computer programs
Easier to understand
2005
Verilog HDL
15
Popularity of Verilog HDL
Verilog HDL
General-purpose
Easy to learn, easy to use
Similar in syntax to C
Allows different levels of abstraction and mixing them
Supported by most popular logic synthesis tools
Post-logic-synthesis simulation libraries by all fabrication
vendors
PLI to customize Verilog simulators to designers’ needs
2005
Verilog HDL
16
Trends in HDLs
Design at behavioral level
Formal verification techniques
Very high speed and time critical circuits
e.g. microprocessors
Mixed gate-level and RTL designs
Hardware-Software Co-design
System-level languages: SystemC, SpecC, …
2005
Verilog HDL
17
Verilog® HDL
Hello World!
Basics of Digital Design Using HDLs
Stimulus block
Generating
inputs
to CUD
Circuit Under Design
(CUD)
4
Checking
outputs
of CUD
8
Test bench
2005
Verilog HDL
19
ModelSim® Simulation Environment
You’ll see in the laboratory
2005
Verilog HDL
20
Verilog Basic Building Block
Module
module not_gate(in, out); // module name+ports
// comments: declaring port type
input in;
output out;
// Defining circuit functionality
assign out = ~in;
endmodule
2005
Verilog HDL
21
useless Verilog Example
module useless;
initial
$display(“Hello World!”);
endmodule
Note the message-display statement
Compare to printf() in C
2005
Verilog HDL
22
Verilog® HDL
Hierarchical Modeling Concepts
Design Methodologies
2005
Verilog HDL
24
4-bit Ripple Carry Counter
2005
Verilog HDL
25
T-flipflop and the Hierarchy
2005
Verilog HDL
26
Modules
module <module_name>(<module_terminal_list>);
...
<module internals>
...
endmodule
Example:
module T_ff(q, clock, reset);
...
<functionality of T_flipflop>
...
endmodule
2005
Verilog HDL
27
Modules (cont’d)
Verilog supported levels of abstraction
Behavioral (algorithmic) level
Describe the algorithm used
Very similar to C programming
Dataflow level
Describe how data flows between registers and is processed
Gate level
Interconnect logic gates
Switch level
Interconnect transistors (MOS transistors)
Register-Transfer Level (RTL)
Generally known as a combination of behavioral+dataflow that is
synthesizable by EDA tools
2005
Verilog HDL
28
Instances
module ripple_carry_counter(q, clk, reset);
output [3:0] q;
input clk, reset;
//4
TFF
TFF
TFF
TFF
instances of the module TFF are created.
tff0(q[0],clk, reset);
tff1(q[1],q[0], reset);
tff2(q[2],q[1], reset);
tff3(q[3],q[2], reset);
endmodule
2005
Verilog HDL
29
Instances (cont’d)
module TFF(q, clk, reset);
output q;
input clk, reset;
wire d;
DFF dff0(q, d, clk, reset);
not n1(d, q); // not is a Verilog provided primitive.
endmodule
// module DFF with asynchronous reset
module DFF(q, d, clk, reset);
output q;
input d, clk, reset;
reg q;
always @(posedge reset or negedge clk)
if (reset)
q = 1'b0;
else
q = d;
2005
endmodule
Verilog HDL
30
Instances (cont’d)
Illegal instantiation example:
Nested module definition not allowed
Note the difference between module definition and module instantiation
// Define the top level module called ripple carry
// counter. It is illegal to define the module T_FF inside
// this module.
module ripple_carry_counter(q, clk, reset);
output [3:0] q;
input clk, reset;
module T_FF(q, clock, reset);// ILLEGAL MODULE NESTING
:
<module T_FF internals>
:
endmodule // END OF ILLEGAL MODULE NESTING
endmodule
2005
Verilog HDL
31
Simulation- Test Bench Styles
2005
Verilog HDL
32
Example
Design block was shown before
ripple_carry_counter, T_FF, and D_FF modules
Stimulus block
2005
Verilog HDL
33
Example (cont’d)
module stimulus;
reg clk; reg reset; wire[3:0] q;
// instantiate the design block
ripple_carry_counter r1(q, clk, reset);
// Control the clk signal that drives the design block.
initial clk = 1'b0;
always #5 clk = ~clk;
// Control the reset signal that drives the design block
initial
begin
reset = 1'b1;
#15 reset = 1'b0;
#180 reset = 1'b1;
#10 reset = 1'b0;
#20 $stop;
end
initial // Monitor the outputs
$monitor($time, " Output q = %d", q);
2005
Verilog HDL
endmodule
34
What we learned today
History of Verilog HDL
Principles of digital design using HDLs
Our first Verilog design example
2005
Verilog HDL
35
Other Notes
Course web-page
http://ce.sharif.edu/courses
Exercise 1
Install and use ModelSim in the lab. to simulate
ripple_carry_counter example
Chapter 2 exercises
2005
Verilog HDL
36