**Verilog**

**What is difference between blocking (=) and non-blocking (<=) statements? *(This is a very common question)***

The blocking assignment statement (= operator) acts much like in traditional programming languages. The whole statement is done before control passes on to the next statement.

The non-blocking (<= operator) evaluates all the right-hand sides for the current time unit and assigns the left-hand sides at the end of the time unit. Non-blocking statements allow you to schedule assignments without blocking the procedural flow. You can use the non-blocking procedural statement whenever you want to make several register assignments within the same time step without regard to order or dependence upon each other. It means that non-blocking statements resemble actual hardware more than blocking assignments.

**Write a Verilog code for synchronous and asynchronous reset? *(This is a very common question)***

Synchronous reset, synchronous means clock dependent so reset must not be present in sensitivity disk e.g.:   
always @ (posedge clk )  
begin if (reset)  
. . . end  
Asynchronous means clock independent so reset must be present in sensitivity list.  
E.g.:   
Always @ (posedge clock or posedge reset)  
begin  
if (reset)  
. . . end  
Asynchronous Reset : works immediately, as soon as it is applied. Sync reset: waits for the clock to have effect. Neither is superior, it depends upon application.  
I would use Sync Resets everywhere in the design to make it fully synchronous. But in some cases, when the chip is being powered up, you don’t have a clock yet, in those cases asynchronous reset would help.

**Write a Verilog code to swap contents of two registers with and without a temporary register?**  
With temp reg ;  
always @ (posedge clock) begin   
 temp=b;  
 b=a;  
 a=temp;  
end  
  
Without temp reg;  
always @ (posedge clock) begin   
 a <= b;  
 b <= a;  
end

**What is PLI? Why is it used?**   
Programming Language Interface (PLI) of Verilog HDL is a mechanism to interface Verilog programs with programs written in C language. It also provides mechanism to access internal databases of the simulator from the C program.   
PLI is used for implementing system calls which would have been hard to do otherwise (or impossible) using Verilog syntax. In other words, you can take advantage of both the paradigms - parallel and hardware related features of Verilog and sequential flow of C - using PLI.

**Specify few Verilog constructs which are not supported by the synthesis tool.**

initial, delays, real and time data types, force and release, fork join.

**Difference between task and function?**

tasks can have any number of inputs and outputs. A task shall not return a value.  
Function:   
A function is unable to enable a task however functions can enable other functions.   
A function will carry out its required duty in zero simulation time. (The program time will not be incremented during the function routine)

functions cannot include timing delays, like posedge, negedge, # delay, which means that functions should be executed in "zero" time delay.

functions can have any number of inputs but only one output.  
Within a function, no event, delay or timing control statements are permitted   
module simple\_task();

**task convert;**

**input [7:0] temp\_in;**

**output [7:0] temp\_out;**

**begin**

**temp\_out = (9/5) \*( temp\_in + 32)**

**end**

**endtask**

**endmodule**

Verilog functions are synthesizable today and Verilog tasks are synthesizable as long as there are no timing controls in the body of the task, such as @(posedge clk). The #delay construct is ignored by synthesis tools.

**Difference between $monitor, $display & $strobe?**   
These commands have the same syntax, and display text on the screen during simulation. $display and $strobe display once every time they are executed, whereas $monitor displays every time one of its parameters changes.   
The difference between $display and $strobe is that $strobe displays the parameters at the very end of the current simulation time unit rather than exactly where it is executed.

**What is difference between Verilog full case and parallel case?**   
A "full" case statement is a case statement in which all possible case-expression binary patterns can be matched to a case item or to a case default. If a case statement does not include case default and if it is possible to find a binary case expression that does not match any of the defined case items, the case statement is not "full."   
A "parallel" case statement is a case statement in which it is only possible to match a case expression to one and only one case item. If it is possible to find a case expression that would match more than one case item, the matching case items are called "overlapping" case items and the case statement is not "parallel."   
  
**What is meant by inferring latches, how to avoid it?**   
Consider the following:   
*always @ (s1 or s0 or i0 or i1 or i2 or i3)  
 case ({s1, s0})   
 2’d0: out = i0;  
 2’d1: out = i1;  
 2'd2: out = i2;  
 endcase*  
In a case statement if all the possible combinations are not compared and default is also not specified like in example above a latch will be inferred, a latch is inferred because to reproduce the previous value when unknown branch is specified. For example in above case if {s1, s0} = 3, the previous stored value is reproduced for this storing a latch is inferred.   
The same may be observed in IF statement in case an ELSE IF is not specified. To avoid inferring latches make sure that all the cases are mentioned if not default condition is provided. 

**Variable and signal which will be updated first?**  
Signals.  
  
**What is sensitivity list?**  
The sensitivity list indicates that when a change occurs to any one of elements in the list, begin…end statement inside that always block will get executed.   
  
**In a pure combinational circuit, is it necessary to mention all the inputs in sensitivity disk? If yes, why?**  
Yes in a pure combinational circuit is it necessary to mention all the inputs in sensitivity disk otherwise it will result in pre and post synthesis mismatch.   
  
**Can you tell me some of system tasks and their purpose?**   
$display, $displayb, $displayh, $displayo, $write, $writeb, $writeh, $writeo.   
The most useful of these is $display. This can be used for displaying strings, expression or values of variables.   
Here are some examples of usage.   
$display("Hello world"); --- output: Hello world  
$display($time) // current simulation time.  
counter = 4'b10;  
$display(" The count is %b", counter); --- output: The count is 0010  
$reset resets the simulation back to time 0;

$stop halts the simulator and puts it in interactive mode where the user can enter commands; $finish exits the simulator back to the operating system

**Tell me about Verilog file I/O?**   
OPEN A FILE  
integer file;  
file = $fopen("filename", “r”);  
file = $fopenw("filename", “w”);  
file = $fopena("filename");  
The function $fopenr opens an existing file for reading. $fopenw opens a new file for writing, and $fopena opens a new file for writing where any data will be appended to the end of the file. The file name can be either a quoted string or a reg holding the file name. If the file was successfully opened, it returns an integer containing the file number (1..MAX\_FILES) or NULL (0) if there was an error. Note that these functions are not the same as the built-in system function $fopen which opens a file for writing by $fdisplay. The files are opened in C with 'rb', 'wb', and 'ab' which allows reading and writing binary data on the PC. The 'b' is ignored on Unix.

**Close a file**

integer file, r;  
r = $fcloser(file);  
r = $fclosew(file);  
The function $fcloser closes a file for input. $fclosew closes a file for output. It returns EOF if there was an error, otherwise 0. Note that these are not the same as $fclose which closes files for writing.

**Input output port**

case (control)

1: out = in1;

default out = z;

endcase

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAR4AAACACAIAAABSsJEGAAAAAXNSR0IArs4c6QAAAAlwSFlzAAAOxAAADsMB2mqY3AAAE0lJREFUeF7tXVlsHMUWtcO+PFaJRSARwDZgTCAIEIxZBYjY+SBsIUhAEgkygBA2YgubABGJIATYiM3+YPkBZAkISPYgQEBANg9+AMkYiAexiVXsYYeH35m+43J1T093dXV1V0/P7Y/IsavqVp2q03ep21WtMzMzLfwwAoyAaQTmmW6Q22MEGIEKAkwtXgeMQCIIMLUSgTUrjZaKra2txVJWutNU/WBqKU93ebAb63Tu6R4sK9flgs2HAFNLZc4dVrX3T7jKTvS3m1YIxF7WMipzkvkyTK3wKSoViVWFgWnEU2ef6YFCeFUu0bwIMLXC5r48uGYYZVaNzYz3tUmF2/rGZ2aGesKq89+bFQGmVsjMl0dHoLEKA1eFk8iJGcw9HrtORBRkn23OX5NszuFeaqT6x9mKop6r4WChzbqsszBuplbwLFSZtXSxrLB8qlRWeG9Fu809FYZ43abK72SfDf6aWjRkck23qDe5oRo/URSahXXWhH1gaqlMeldHMLNKRYdWMBrFM7aq0vDwmtowonDZyFubGBmtMMWxL+k3s83IBujExISoV/19JKEqo+QyRhFgasWHk7wxrHzZ8+oZcnhSJY4QIrtsbX2POkWmpsP7gNbdrl4UoeHNcwnzCDC1VDAVJlj9woUam7Ft8dIa4hQ621XkqZZRE6raGpczigBTKxjOto6uitEWqFimp9wbXkYnqF5jVoSmMrK8CGFqhcxkz5KK0zTcG7CP297pY/m1tFQjIGb1lOitFaF5WfWpjIOpFQZzz1VObAGxPXcsz4mFO4SrWn797TL9qvvMq25wbYaFCCMdObxOIenPnNAwAPjveggwtUJxQ+yOwn2VzKa5R4qhV+MRFfqJpxoyjLin7Oii2XaCw/LmhIYiwAV0EGBqqaDWMzQbGJdKV4Lhs8yphM6Jf+KphNCjEOvmm2+uhOCdoCE9YSF/A0JVBs9l9BBo5a+M9YAzXgv6jufCOKoWG2StZRF8Fp1nBJhaeZ5dHptFBJhaFsFn0XlGgKmV59nlsVlEgKllEXwWnWcEmFp5nl0em0UEmFoWwWfReUaAqZXn2eWxWUSAqWURfBadZwSYWnmeXR6bRQSYWhbBZ9F5RoCplefZ5bFZRICpZRF8Fp1nBJhaeZ5dHptFBJhaFsFn0XlGgKmV59nlsVlEgKllEXwWnWcEmFp5nl0em0UEmFoWwWfReUaAqZXn2eWxWUSAqWURfBadZwSYWnmeXR6bRQSYWhbBZ9F5RoCplefZ5bFZRICpZRF8Fp1nBJhaeZ5dHptFBJhaFsFn0XlGgKmV59nlsVlEgKllEXwWnWcEmFp5nl0em0UE+OIZA+B7Lu/BdT4ajfIlQBqgZbkKa61YswNS4fn3339PO+20u+++Gz/Qb/imrFiw5qIyU0t/GolC/3OeZ5555rXXXjvwwAOffPJJ/FdwzLf15557buXKlaGC1zpPaDEukFEExFuWf4iKAPjzzz///PHHHxs3bsTsovrLL798yCGHHHvssW+88cbff/9NHJNVGYn4/fff58+fXyqVZInUgni+/PLLHXbYAf9G7RWXzwgCrunMSJ8aohsgDJjz119//fLLL99++61MjIcffni33XY777zzPv30U0Ewz6CefvppkDCAWkuWLLnpppsaAgrupC8CbBDGsiZIcf35559yKytWrPjoo4/22WefI444Apd/g3hCd4liYA6U0sDAgK/4/zrP6tWrY3UuTuXyYDfiKsVSnDaavC5TS38BCF8LusvTypZbbglSvfXWW999992CBQvuv/9+2Tikwgh73H777V999VVtDy6++OIHHngAjeh3jmvaRoCpFWsGwC5SXL6twCwEQxC0GBsbO+yww0ZHR+UIBwzCZcuWgV2eug8++CAUGtRarJ5xZesIsKGshwAx6rfffvvmm28++OADTxCitk0ELfbff/+TTz75nXfeEQ7YF198AfpBuaE8tfDDDz8gwkG/0X/GVrnW1aoxV1POXwsD0/IvpwcK+KVTkH50PZ7C+h1rppqstQy83IgYwc+iRYvee++9008//ZRTTrnkkks+//xzaLBdd9316quvvvzyy0XdW265BfoKCi2svbp/LxVbW3uHXX8e7mW3SRtP7YpMLW3odCpedNFFINjOO++MCMdtt92G6OJll132448/ImCI5t5+++1169YhMKjTNNUpFR1ayXqKVNjwmsGyWrNtfeOzqmu2mfG+NrW6XGoOAaZW2qsBfhRIBZNvampqv/32e+yxx+644w7oMfTj2muvveaaa1BAt0/lwTUgFsy3oZ65JnqGHBNv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)

**Structural vs. Behavioral**

Verilog can be structural or behavioral. Structural definition specifies the gates and their connections explicitly.

Behavioral definition specifies the functionality of a design, and does not contain any structural information such as transistors or gates. Logic synthesis software implements the structural.