Verilog HDL [18EC56]
MODULE -5
USEFUL MODELING TECHNIQUES &
LOGIC SYNTHESIS WITH VERILOG
5.1: Objectives
To describe procedural continuous assignment statements assign, deassign, force, and release. Explain
their significance in modeling and debugging.
Understand how to override parameters by using the defparam statement at the time of module
instantiation.
5.2: Procedural Continuous Assignments
Procedural assignments assign a value to a register. The value stays in the register until another procedural
assignment puts another value in that register. Procedural continuous assignments behave differently. They are
procedural statements which allow values of expressions to be driven continuously onto registers or nets for
limited periods of time. Procedural continuous assignments override existing assignments to a register or net.
They provide a useful extension to the regular procedural assignment statement.
5.2.1 assign and deassign
The keywords assign and deassign are used to express the first type of procedural continuous assignment. The
left-hand side of procedural continuous assignments can only be a register or a concatenation of registers. It
cannot be a part or bit select of a net or an array of registers. Procedural continuous assignments override the
effect of regular procedural assignments. Procedural continuous assignments are normally used for controlled
periods of time.
In the below Example, we overrode the assignment on q and qbar and assigned new values to them when reset
signal went high. The register variables retain the continuously assigned value after the deassisn until they are
changed by a future procedural assignment.
Dept.of ECE/ATMECE, Mysuru Page 109
Available At VTU HUB (Android App)
Verilog HDL [18EC56]
D-flip flop with Procedural Continuous Assignments
Dept.of ECE/ATMECE, Mysuru Page 110
Available At VTU HUB (Android App)
Verilog HDL [18EC56]
5.2.2 force and release
Keywords force and release are used to express the second form of the procedural continuous assignments.
They can be used to override assignments on both registers and nets. force and release statements are typically
used in the interactive debugging process, where certain registers or nets are forced to a value and the effect on
other registers and nets is noted. It is recommended that force and release statements not be used inside design
blocks. They should appear only in stimulus or as debug statements.
force and release on registers
A force on a register overrides any procedural assignments or procedural continuous assignments on the
register until the register is released. The register variables will continue to store the forced value after being
released but can then be changed by a future procedural assignment. To override the values of q and qbar in D
flip flop example for a limited period of time, we could do the following.
Dept.of ECE/ATMECE, Mysuru Page 111
Available At VTU HUB (Android App)
Verilog HDL [18EC56]
force and release on nets
force on nets overrides any continuous assignments until the net is released. The net will immediately return to
its normal driven value when it is released. A net can be forced to an expression or a value.
In the example above, a new expression is forced on the net from time 50 to time 100. From time 50 to time
100, when the force statement is active, the expression a | b & c will be reevaluated and assigned to out
whenever values of signals a or b or c change. Thus, the force statement behaves like a continuous assignment
except that it is active only for a limited period of time.
5. 3. Overriding Parameters
Parameters can be defined in a module definition. However, during compilation of Verilog modules, parameter
values can be altered separately for each module instance. This allows us to pass a distinct set of parameter
values to each module during compilation regardless of predefined parameter values. There are two ways to
override parameter values: through the defparam statement or through module instance parameter value
assignment.
5.3.1 defparam Statement
Parameter values can be changed in any module instance in the design with the keyword defparam. The
hierarchical name of the module instance can be used to override parameter values.
Dept.of ECE/ATMECE, Mysuru Page 112
Available At VTU HUB (Android App)
Verilog HDL [18EC56]
Defparam Statement
module hello-world was defined with a default id-num = 0. When the module instances w1 and w2 of the type
hello-world are created, their id-num values are modified with the defparam statement. If we simulate the
above design, we would get the following output:
Multiple defparam statements can appear in a module. Any parameter can be overridden with the defparam
statement.
5.3.2 Module-Instance Parameter Values
Parameter values can be overridden when a module is instantiated. The new parameter values are passed during
module instantiation. The top-level module can pass parameters to the instances w1 and w2 as shown below.
Note: the defparam is not needed. The simulation output will be identical to the output obtained with the
defparaxn statement.
Dept.of ECE/ATMECE, Mysuru Page 113
Available At VTU HUB (Android App)
Verilog HDL [18EC56]
If multiple parameters are defined in the module, during module instantiation they can be overridden by
specifying the new values in the same order as the parameter declarations in the module. If an overriding value
is not specified, the default parameter declaration values are taken.
Module-instance, parameter value assignment is a very useful method used to override parameter values and to
customize module instances.
Dept.of ECE/ATMECE, Mysuru Page 114
Available At VTU HUB (Android App)
Verilog HDL [18EC56]
5. 4. Conditional Compilation and Execution
A portion of Verilog might be suitable for one environment and not for the other. The designer does not wish to
create two versions of Verilog design for the two environments. Instead, the designer can specify that the
particular portion of the code be compiled only if a certain flag is set. This is called conditional compilation.
A designer might also want to execute certain parts of the Verilog design only when a flag is set at run time.
This is called conditional execution.
5.4.1 Conditional Compilation
Conditional compilation can be accomplished by using compiler directives 'ifdef, 'else, and 'endif.
The ' ifdef statement can appear anywhere in the design. A designer can conditionally compile statements,
modules, blocks, declarations, and other compiler directives. The 'else statement is optional. A maximum of one
'else statement can accompany the 'ifdef. An 'ifdef is always closed by a corresponding ' endif. The conditional
compile flag can be set by using the 'define statement inside the Verilog file.
Dept.of ECE/ATMECE, Mysuru Page 115
Available At VTU HUB (Android App)
Verilog HDL [18EC56]
5.4.2 Conditional Execution
Conditional execution flags allow the designer to control statement execution flow at run time. All statements
are compiled but executed conditionally. Conditional execution flags can be used only for behavioral
statements. The system task keyword $teet$plusargs is used for conditional execution. This option is not
provided as a part of the IEEE Language Reference Manual. This facility is available in Verilog-XL but may
not be supported in other simulators because it is not a standard.
Example of Conditional Execution
5.5 Useful System Tasks
Useful system tasks are file output, displaying hierarchy, strobing, random number generation, memory
initialization, and value change dump.
5.5.1 File Output
Opening a file
A file can be opened with the system task $fopen.
Usage: $f open("<name-of-plc>");
Usage: <file-handle> = $fopen("<name-of-file>");
Writing to files
The system tasks Sfdisplay, Sfmonitor, Sfwrite, and $f strobe are used to write to files.
consider $f display and $fmonitor tasks.
Usage: $fdisplay(<file-descriptor>, pl, p2 . . ., pn);
$fmonitor(<file-descriptor>, pl, p2, ..., pn);
pl, p2, . . ., pn can be variables, signal names, or quoted strings.
Dept.of ECE/ATMECE, Mysuru Page 116
Available At VTU HUB (Android App)
Verilog HDL [18EC56]
Closing files
Files can be closed with the system task $fclose.
Usage: $fclose(<file-handle>);
A file cannot be written to once it is closed. The corresponding bit in the multichannel descriptor is set to 0. The
next $fopen call can reuse the bit.
5.5.2 Displaying Hierarchy
Hierarchy at any level can be displayed by means of the %m option in any of the display tasks, $display, $write
task, $monitor, or $strobe Hierarchical Names. For example, when multiple instances of a module execute the
same Verilog code, the %m option will distinguish which model instance the output is coming from. No
argument is needed for the %m option in the display tasks.
Example of Displaying Hierarchy
The output from the simulation will look like the following
Dept.of ECE/ATMECE, Mysuru Page 117
Available At VTU HUB (Android App)
Verilog HDL [18EC56]
5.5.3 Strobing
Strobing is done with the system task keyword $strobe.
If $strobe is used, it is always executed after all other assignment statements in the same time unit have
executed. Thus, $strobe provides a synchronization mechanism to ensure that data is displayed only after all
other assignment statements, which change the data in that time step, have executed.
In the above Example the values at positive edge of clock will be displayed only after statements a = b and c = d
execute. If $display was used, $display might execute before statements a = b and c = d, thus displaying
different values.
5.5.4 Value Change Dump File
value change dump (VCD) is an ASCII file that contains information about simulation time, scope and signal
definitions, and signal value changes in the simulation run. All signals or a selected set of signals in a design
can be written to a VCD file during simulation. Postprocessing tools can take the VCD file as input and visually
display hierarchical information, signal values, and signal waveforms. For simulation of large designs,
designers dump selected signals to a VCD file and use a postprocessing tool to debug, analyze, and verify the
simulation output. The use of VCD file in the debug process is shown in Figure.
Dept.of ECE/ATMECE, Mysuru Page 118
Available At VTU HUB (Android App)
Verilog HDL [18EC56]
System tasks are provided for selecting module instances or module instance signals to dump ($dumpvars),
name of VCD file ($dumpfile), starting and stopping the dump process ($dumpon, $dumpoff), and generating
checkpoints ($dumpall).
5.6 What Is Logic Synthesis?
Logic synthesis is the process of converting a high-level description of the design into an optimized gate-level
representation, given a standard cell library and certain design constraints. A standard cell library can have
simple cells, such as basic logic gates like and, or, and nor, or macro cells, such as adders, muxes, and special
flip-flops. A standard cell library is also known as the technology library.
Designer's Mind as the Logic Synthesis Tool
Dept.of ECE/ATMECE, Mysuru Page 119
Available At VTU HUB (Android App)
Verilog HDL [18EC56]
The advent of computer-aided logic synthesis tools has automated the process of converting the high-level
description to logic gates. Instead of trying to do logic synthesis in their minds, designers can now concentrate
on the architectural trade-offs, high-level description of the design, accurate design constraints, and
optimization of cells in the standard cell library. These are fed to the compute raided logic synthesis tool, which
performs several iterations internally and generates the optimized gate-level description. Also, instead of
drawing the high level description on a screen or a piece of paper, designers describe the high-level design in
terms of HDLs.
Basic Computer-Aided Logic Synthesis Process
Dept.of ECE/ATMECE, Mysuru Page 120
Available At VTU HUB (Android App)
Verilog HDL [18EC56]
5.7 Impact of Logic Synthesis
Limitations of the manual design process.
For large designs, manual conversion was prone to human error. A small gate missed somewhere could
mean redesign of entire blocks.
The designer could never be sure that the design constraints were going to be met until the gate-level
implementation was completed and tested.
A significant portion of the design cycle was dominated by the time taken to convert a high-level design
into gates.
If the gate-level design did not meet requirements, the turnaround time for redesign of blocks was very
high.
What-if scenarios were hard to verify. For example, the designer designed a block in gates that could run
at a cycle time of 20 ns. If the designer wanted to find out whether the circuit could be optimized to run
faster at 15 ns, the entire block had to be redesigned. Thus, redesign was needed to verify what if
scenarios.
Each designer would implement design blocks differently. There was little consistency in design styles.
For large designs, this could mean that smaller blocks were optimized but the overall design was not
optimal.
If a bug was found in the final, gate-level design, this would sometimes require redesign of thousands of
gates.
Timing, area, and power dissipation in library cells are fabrication technology specific. Thus if the
company changed the IC fabrication vendor after the gate-level design was complete, this would mean
redesign of entire circuit and a possible change in design methodology.
Design reuse was not possible. Designs were technology specific, hard to port, and very difficult to
reuse.
Dept.of ECE/ATMECE, Mysuru Page 121
Available At VTU HUB (Android App)
Verilog HDL [18EC56]
Automated logic synthesis tools addressed these problems as follows.
High-level design is less prone to human error because designs are described at a higher level of
abstraction.
High-level design is done without significant concern about design constraints. Logic synthesis will
convert a high-level design to a gate-level netlist and ensure that all constraints have been met. If not,
the designer goes back, modifies the high-level design and repeats the process until a gate-level netlist
that satisfies timing, area, and power constraints is obtained.
Conversion from high-level design to gates is fast. With this improvement, design cycle times are
shortened considerably. What took months before can now be done in hours or days.
Turnaround time for redesign of blocks is shorter because changes are required only at the register-
transfer level; then, the design is simply resynthesized to obtain the gate-level netlist.
What-if scenarios are easy to verify. The high-level description does not change. The designer has
merely to change the timing constraint from 20 ns to 15 ns and resynthesize the design to get the new
gate-level netlist that is optimized to achieve a cycle time of 15 ns.
Logic synthesis tools optimize the design as a whole. This removes the problem with varied designer
styles for the different blocks in the design and suboptimal designs.
If a bug is found in the gate-level design, the designer goes back and changes the high-level description
to eliminate the bug. Then, the high-level description is again read into the logic synthesis tool to
automatically generate a new gate-level description.
Logic synthesis tools allow technology-independent design. A high-level description may be written
without the IC fabrication technology in mind.
Logic synthesis tools convert the design to gates, using cells in the standard cell library provided by an
IC fabrication vendor. If the technology changes or IC fabrication vendor changes, designers simply use
logic synthesis to retarget the design to gates, using the standard cell library for the new technology.
Design reuse is possible for technology-independent descriptions. For example, if the functionality of
the I/O block in a microprocessor does not change, the RTL description of the I/O block can be reused in
the design of derivative microprocessors. If the technology changes, the synthesis tool simply maps to
the desired technology.
Dept.of ECE/ATMECE, Mysuru Page 122
Available At VTU HUB (Android App)
Verilog HDL [18EC56]
5.7.1. Verilog Constructs
Not all constructs can be used when writing a description for a logic synthesis tool. In general, any construct
that is used to define a cycle-by-cycle RTL description is acceptable to the logic synthesis tool.
List Verilog HDL Constructs for Logic Synthesis
Dept.of ECE/ATMECE, Mysuru Page 123
Available At VTU HUB (Android App)
Verilog HDL [18EC56]
5.7.2 Verilog Operators
Almost all operators in Verilog are allowed for logic synthesis
Dept.of ECE/ATMECE, Mysuru Page 124
Available At VTU HUB (Android App)
Verilog HDL [18EC56]
5.7.3 Interpretation of a Few Verilog Constructs
The assign statement
The assign construct is the most fundamental construct used to describe combinational logic at an RTL level.
Given below is a logic expression that uses the assign statement.
assign out = (a & b) I c;
This will frequently translate to the following gate-level
representation.
If a, b, c, and out are 2-bit vectors [1:0], then the above assign statement will frequently translate to two
identical circuits for each bit.
A l-bit full adder
Dept.of ECE/ATMECE, Mysuru Page 125
Available At VTU HUB (Android App)
Verilog HDL [18EC56]
If a conditional operator ? is used, a multiplexer
The case statement
The for loops can be used to build cascaded combinational logic: For example, the following for loop builds an
8 bit full adder.
The always statement can be used to infer sequential and combinational logic. For sequential logic, the always
statement must be controlled by the change in the value of a clock signal clk.
Dept.of ECE/ATMECE, Mysuru Page 126
Available At VTU HUB (Android App)
Verilog HDL [18EC56]
5.8 Synthesis Design Flow
Logic Synthesis Flow from RTL to Gates
Dept.of ECE/ATMECE, Mysuru Page 127
Available At VTU HUB (Android App)