# Verilog notes

Tommy Bui 01-29-2023

# Contents

| 1 | $\mathbf{Ver}$ | ilog Tutorial 3                                 |  |  |  |  |  |  |  |  |  |
|---|----------------|-------------------------------------------------|--|--|--|--|--|--|--|--|--|
|   | 1.1            | Lore                                            |  |  |  |  |  |  |  |  |  |
|   | 1.2            | How is Verilog useful                           |  |  |  |  |  |  |  |  |  |
| 2 | Intr           | ntroduction to Verilog 3                        |  |  |  |  |  |  |  |  |  |
|   | 2.1            | What is a hardware schematic?                   |  |  |  |  |  |  |  |  |  |
|   | 2.2            | What is a Hardware Description Language? 4      |  |  |  |  |  |  |  |  |  |
|   | 2.3            | Sections of Verilog Code                        |  |  |  |  |  |  |  |  |  |
|   |                | 2.3.1 Verilog section template                  |  |  |  |  |  |  |  |  |  |
| 3 | Dat            | Data Types 5                                    |  |  |  |  |  |  |  |  |  |
|   | 3.1            | Verilog Syntax                                  |  |  |  |  |  |  |  |  |  |
|   |                | 3.1.1 White space 6                             |  |  |  |  |  |  |  |  |  |
|   |                | 3.1.2 Operators                                 |  |  |  |  |  |  |  |  |  |
|   |                | 3.1.3 Number Format 6                           |  |  |  |  |  |  |  |  |  |
|   |                | 3.1.4 Unsized                                   |  |  |  |  |  |  |  |  |  |
|   |                | 3.1.5 Negative                                  |  |  |  |  |  |  |  |  |  |
|   |                | 3.1.6 Strings                                   |  |  |  |  |  |  |  |  |  |
|   |                | 3.1.7 Identifiers                               |  |  |  |  |  |  |  |  |  |
|   |                | 3.1.8 Keywords                                  |  |  |  |  |  |  |  |  |  |
|   |                | 3.1.9 Verilog Revisions                         |  |  |  |  |  |  |  |  |  |
|   | 3.2            | Verilog Data Types                              |  |  |  |  |  |  |  |  |  |
|   |                | 3.2.1 What values do variables hold? 10         |  |  |  |  |  |  |  |  |  |
|   |                | 3.2.2 What does the verilog value-set imply? 10 |  |  |  |  |  |  |  |  |  |
|   |                | 3.2.3 Nets & Variables                          |  |  |  |  |  |  |  |  |  |
|   |                | 3.2.4 Other DataTypes                           |  |  |  |  |  |  |  |  |  |
|   |                | 3.2.5 Verilog Strings                           |  |  |  |  |  |  |  |  |  |
|   | 3.3            | Verilog Scalar & Vector                         |  |  |  |  |  |  |  |  |  |
|   |                | 3.3.1 Scalar & Vector                           |  |  |  |  |  |  |  |  |  |
|   |                | 3.3.2 Part-selects                              |  |  |  |  |  |  |  |  |  |
|   | 3.4            | Verilog Arrays & Memories                       |  |  |  |  |  |  |  |  |  |
|   |                | 3.4.1 Example                                   |  |  |  |  |  |  |  |  |  |
|   |                | 3.4.2 Memories                                  |  |  |  |  |  |  |  |  |  |
|   |                | 3.4.3 Register Vector                           |  |  |  |  |  |  |  |  |  |
|   |                | 3.4.4 Array                                     |  |  |  |  |  |  |  |  |  |
| 4 | Bui            | lding Blocks 22                                 |  |  |  |  |  |  |  |  |  |
|   | 4.1            | Verilog Module                                  |  |  |  |  |  |  |  |  |  |
|   |                | 4.1.1 Example                                   |  |  |  |  |  |  |  |  |  |
|   |                | 4.1.2 What is the purpose of a module?          |  |  |  |  |  |  |  |  |  |
|   | 4.2            | Verilog Ports                                   |  |  |  |  |  |  |  |  |  |
|   |                | 4.2.1 Types of Ports                            |  |  |  |  |  |  |  |  |  |
|   |                | 4.2.2 Signed Ports                              |  |  |  |  |  |  |  |  |  |
|   | 43             | Port Variations 24                              |  |  |  |  |  |  |  |  |  |

| 4.4 | Verilog | Module INstratiations           |
|-----|---------|---------------------------------|
|     | 4.4.1   | Port Connection by Ordered List |
|     | 4.4.2   | Port Connection by Name         |
|     | 4.4.3   | Unconected/Floating Ports       |
| 4.5 | Verilog | assign statement                |
|     | 4.5.1   | Assign Syntax                   |

## 1 Verilog Tutorial

Reference to Chipverify

## 1.1 Lore

In the early days of integrated circuits, engineers had to physically draw transistors & their netlist on paper. As circuits became more complex and larger in scale, this process eventually tedious. Languages such as VHDL & Verilog were developed to simply the process of describing the functionality of IC and let tools convert the behavior into hardware using combinational & sequential logic.

## 1.2 How is Verilog useful

Verilog creates a level of abstraction that hides the details of its implementation & technology.

E.g. the design of a D flip-flop requires the knowledge of the transistor layout in order to achieve an edge-triggered FF, rise/setup time, fall/clk-Q times to latch value onto flop, etc.

# 2 Introduction to Verilog

### Source

A digital element such as a FF can be represented using combinational gates such as NAND or NOR gates. The functionality of a FF is determined based on the layout of such gates. How the gates have to be connected is usually determined using K-maps

Below is an schemetic of a Data flip-flop & its corresponding truth table. The output, q is asserted only when rstn & d are both set.



Figure 1: D flip flop

## 2.1 What is a hardware schematic?

A hardware schematic is a daigram that shows how the combinational gates should be connected to implemented a particular behaviour in hardware. From figure 1, a set of NAND gates are connected in order to create a D flip flop.

## 2.2 What is a Hardware Description Language?

It's easier to describe how a block of logic should behave & let software tools convert that behavior into an actual hardware scchematic. The language that describes the hardware functinality is classified as a Hardware Description Language.

## 2.3 Sections of Verilog Code

All behavior code should be described within the keywords module & end module.

## 2.3.1 Verilog section template

- Module definition & port list declaration
- List of input & output ports
- Declaration of Verilog data types
- Module instantiations
- Behavioural code

```
module [design_name] ( [port_list] );

list_of_input_ports]

[list_of_output_ports]

[declaration_of_other_signals]

[other_module_instantiations_if_required]

[behavioral_code_for_this_module]

endmodule
```

Figure 2: Verilog example Template

# 3 Data Types

## 3.1 Verilog Syntax

Source (Lexical item. In lexicography [citation needed], a lexical item is a single word, a part of a word, or a chain of words (catena) that forms the basic elements of a language's lexicon (vocabulary)).

Lexical conventions in Verilog are similar to C in the sense that it contains a sense of tokens. A lexical token may consist of one or more characters and tokens can be comments, keywords, numbers, strings or white space. However, all lines are terminated by a semi-colon.

Verilog is case-sensitive, so variables, var\_a & var\_A differ. Two types of comments:

- Single-line comment uses two forward slashes (e.g. //). Single line comments can be nested in a multiple line comment.
- $\bullet$  Multiple-line comment starts with /\* and ends with \*/ and cannot be nested

## 3.1.1 White space

White space refers to spaces, tabs, newlines, & formfeeds, and is usually ignored by Verilog except when it separates tokens. Be sure to take advantage of this when making readable code.

## 3.1.2 Operators

There are three types of operators: unary, binary, & ternary or conditional.

- Unary operators shall appear to the left of their operand
- Binary operators shall appear between their operands
- Conditional operators have 2 separate operates that separate 3 operands

Figure 3: Example of unary, binary, and ternary/conditional operators

If the expression (y.5) is true, then variable x will get the value w, else y=z.

### 3.1.3 Number Format

```
16 // Number 16 in decimal
0x10 // Number 16 in hexadecimal
10000 // Number 16 in binary
20 // Number 16 in octal
```

Figure 4: number formats

By default, Verilog simulators treat numbers as decimals. In order to represent them in different radixes, there are certain rules which must be used.

### Sized

Sized numbers are represented as show below, where size is written only in decimal to specify the number of bits in the number:

# 1 [size]'[base\_format][number]

Figure 5: Template for sized numbers

- base\_format can be decimal('d or 'D), hex('h or 'H), or octal('o or 'O) & specifies the base of the number
- number can be specified as any valid digit with respect to the specified based format

```
3'b010; // size is 3, base format is binary ('b), and the number is 010 (indicates value 2 in binary)
3'd2; // size is 3, base format is decimal ('d) and the number is 2 (specified in decimals)
8'h70; // size is 8, base format is hexadecimal ('h) and the number is 0x70 (in hex) to represent decimal 112
9'h1FA; // size is 9, base format is hexadecimal ('h) and the number is 0x1FA (in hex) to represent decimal 506

4'hA = 4'd10 = 4'b1010 = 4'012 // Decimal 10 can be represented in any of the four formats 8'd234 = 8'D234 // Legal to use either lower case or upper case for base format 32'hFACE_47B2; // Underscore (_) can be used to separate 16 bit numbers for readability
```

Figure 6: ToDo

## 3.1.4 Unsized

Numbers without a size format specification have a default number of bits depending on the simulator & machine.

## 3.1.5 Negative

Negative numbers are specified with the - sign before the size of a number; It is illegal to have the - between base format & number.

Figure 7: ToDo

## 3.1.6 Strings

A sequence of characters enclosed in double quotes are strings. It cannot be split into multiple lines & every chracter in the string takes 1B to be stored:

```
"Hello World!" // String with 12 characters -> require 12 bytes
"x + z" // String with 5 characters

"How are you
feeling today ?" // Illegal for a string to be split into multiple lines
```

Figure 8: ToDo

## 3.1.7 Identifiers

Identifiers are names of variables; Can be made of alphanumeric characters and symbols. They cannot start with a digit nor a \$:

```
integer var a;
integer $\forall array{\text{Identifier contains alphabets and underscore -> Valid}
integer $\forall array{\text{Identifier starts with $ -> Invalid}}
integer $\forall array{\text{Identifier contains alphabets and $ -> Valid}}
integer 2var;
integer var23_g;
id
integer 23;
// Identifier contains alphanumeric characters and underscore -> Valid
integer 23;
// Identifier contains only numbers -> Invalid
```

Figure 9: ToDo

## 3.1.8 Keywords

Keywords are special identifiers reserved to be define the language constructs & are lower case. A list of important keywords is as follows:

| always and assign automatic begin case casex casez deassign default defparam design disable edge else end endcase endconfig | endfunction endgenerate endmodule endprimitive endspecify endtable endtask event for force forever fork function generate genvar include initial inout | input integer join localparam module nand negedge nmos nor not or output parameter pmos posedge primitive specify specparam | signed task time real realtime reg unsigned wait while wire |
|-----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|
|-----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|

Figure 10: ToDo

## 3.1.9 Verilog Revisions



Figure 11: ToDo

# 3.2 Verilog Data Types

Source

Data-types in Verilog is meant to represent data storage elements like bits in a flip-flop & transmission elements like wires that connect between logic gates & sequential structures.

### 3.2.1 What values do variables hold?

Almost all data-types can have one of the four different values as given below except for  $\underline{\text{real}} \& \underline{\text{event}}$  data types.

| 0            | Represents logic zero or false condition |
|--------------|------------------------------------------|
| 1            | Refresents logic one or a true condition |
| х            | Represents an unknown logic value        |
|              | (could be 0 or 1, metastability)         |
| $\mathbf{z}$ | Represents high impedance state          |

The following image shows how these values are represented in timing diagrams & simulation waveforms. Most simulators use this convention where red stands for X and orange in the middle stands for high-impedance or Z.

:w



Figure 12: ToDo

## 3.2.2 What does the verilog value-set imply?

Since Verilog is essentially used to describe hardware elements like flip-flops & combinational logic like NAND & NOR, it has to model the value system found in hardware. A logic one would represent the voltage supply  $V_{dd}$ .

X or x means that the value is unknown at the time and could either be 1 or 0. This is an issue known as metastability. This differs from the boolean logic X, where it signifies don't care.

As with any incomplete eletric circuit, the wire that is not connected to anything will have high-impedance at that node which is represented by Z or z.

### 3.2.3 Nets & Variables

Nets & variables are the two main groups of data types which represent different hardware structures & differ in the way they are assigned & retain values.

### Nets

Nets are used to connect between hardware entities like logic gates & don't store any values on their own. In the follow image, a net\_11 connects between the output of the AND gate and the first input of the flip\_floped called data\_0. Similarly, the inputs of the AND gate are connected to nets, net\_45 & net\_67.



Figure 13: ToDo

There are different types of nets with various characterisites, the most commonly used net in digital design is of type wire. Wire is a Verilog data-type used to connect elements & to connect nets that are driven by a single gate or continuous assignment.

When there is a requirement for multiple nets, they can be bunched together to form a single wire. In the code below, we can have a 4-bit wire that sends 4 separate values on each one of these wires. A group of such entities is consider a vector.

$$wire [3:0] n0; //4 - bitwire; example of a vector$$

It is illegal to redeclare a variable name already declared by a net, parameter, or variable.

## Variables

A variable is an abstraction of a data storage element & can hold values e.g. A flipflop.

Verilog datatype, reg can be used to model hardware registers since it can hold values between assignments. Note that a reg does not always represent a flipflop as it can also represent combinational logic.

## 3.2.4 Other DataTypes

Integer

Properties of datatypes in SV (hopefully same in Verilog)

An integer is a general purpose variable of 32-bits wide which is signed that can be used for other purposes while modeling hardware & stores integer values.

Time

Time is an unsigned & 64bits wide & can be used to store simulation time quantities for debugging purposes. A realtime variable simply stores time as a floating point quantity.

Real

A real variable can store floating point values & can be assigned the same way as integer & reg (See Don Mills' book for properties).

### 3.2.5 Verilog Strings

Strings are stored in reg, and the width of the reg variable has to be large enough to hold the string. Each character in a string represents an ASCII value & requires 1 byte. If the size of the variable is smaller than the string, then Verilog truncates teh leftmost bits of the string. If the size of the variable is larger then Verilog appends zeros to the beginning of the string.

Figure 14: ToDo

## 3.3 Verilog Scalar & Vector

Reference A single bit can be represented as a flip-flop. However, a 16-bit sequential element is a register that can hold 16 bits, thus Verilog uses scalar & vector net and variables.

## 3.3.1 Scalar & Vector

A net or reg declaration without a range specification is considered a 1-bit wide scalar. If a range is specified, then the net or reg becomes a multibit entity known as a vector.

The most significant bit of the vector should be specified as the left hand value in the range while the least significant bit of the vector should be specified on the right.

```
wire [msb:lsb] name;
integer my_msb;

wire [15:0] priority; // msb = 15, lsb = 0
wire [my_msb: 2] prior; // illegal
```

Figure 15: ToDo

The msb & lsb should be a constant expression and cannot be substituted by a variable (if you need to vary the width of vector, consider using parameters). But they can be any integer value - positive, negative, or zero; and the lsb value can be greater than, equal to, or less than the MSB.

#### 3.3.2 Part-selects

A range of contiguous bits can be selected through <u>part-select</u>. There are two types of part-selects, one with a constant part-select and another with an in-

dexed part-select.

Figure 16: ToDo

Using a variable part-select makes it effect to index parts of a vector in loops. Although the starting bit can be varied, the width has to be constant:

```
[<start_bit> +: <width>]  // part-select increments from start-bit
[<start_bit> -: <width>]  // part-select decrements from start-bit
```

Figure 17: ToDo

```
module des;
         reg [31:0] data;
         initial begin
           data = 32'hFACE_CAFE;
           for (i = 0; i < 4; i++) begin
             $display ("data[8*%0d +: 8] = 0x%0h", i, data[8*i +: 8]);
           $display ("data[7:0] = 0x%0h", data[7:0]);
           $display ("data[15:8] = 0x%0h", data[15:8]);
           $display ("data[23:16] = 0x%0h", data[23:16]);
           $display ("data[31:24] = 0x%0h", data[31:24]);
         end
       endmodule
Simulation Log
 ncsim> run
 data[8*0 +: 8] = 0xfe
                                              // ~ data
                                                          [8*0+8
                                              // ~ data
// ~ data
                                                                   : 8*1]
 data[8*1 +: 8] = 0xca
                                                           [8*1+8
                                                          [8*2+8
 data[8*2 +: 8] = 0xce
 data[8*3 +: 8] = 0xfa
                                              // ~ data [8*3+8
 data[7:0] = 0xfe
data[15:8] = 0xca
data[23:16] = 0xce
                = 0xfe
 data[31:24] = 0xfa
 ncsim: *W,RNQUIE: Simulation is complete.
```

Figure 18: ToDo

## 3.4 Verilog Arrays & Memories

An array declaration of a net or variable can either be scalar or a vector. Any number of dimensions can be created by specifying an address range after the identifier name. Verilog allows the creation of arrays using reg, wire, integer, and real data types.

```
      1
      reg
      y1 [11:0];
      // y is an scalar reg array of depth=12, each 1-bit wide

      2
      wire [0:7] y2 [3:0]
      // y is an 8-bit vector net with a depth of 4

      3
      reg [7:0] y3 [0:1][0:3];
      // y is a 2D array rows=2,cols=4 each 8-bit wide
```

Figure 19: ToDo

An index for every dimension has to be specified to access a particular element of an array & can be an expression of other variables. An array can be formed for any of the different data-types supported in Verilog (note that a memory of N wide 1-bit regs is not the same as an n-bit vector reg).

## Assignment

Figure 20: ToDo

### 3.4.1 Example

mem1 is an 8-bit vector, mem2 is an 8-bit array with a depth of 4 (specified by range of [0:3]) & mem3 is a 16-bit vector 2D array with 4 rows & 2 columns:

```
module des ();
          reg [7:0] mem1;
          reg [7:0] mem2 [0:3];
          reg [15:0] mem3 [0:3][0:1]; // 16-bit wide vector 2D array with rows=4,cols=2
          initial begin
            mem1 = 8'ha9;
             display ("mem1 = 0x%0h", mem1);
            mem2[0] = 8'haa;
            mem2[1] = 8'hbb;
            mem2[2] = 8'hcc;
            mem2[3] = 8'hdd;
               $display("mem2[%0d] = 0x%0h", i, mem2[i]);
                  mem3[i][j] = i + j;
                  $display("mem3[%0d][%0d] = 0x%0h", i, j, mem3[i][j]);
imulation Log
mem1 = 0xa9
mem1 = 0xa9
mem2[0] = 0xaa
mem2[1] = 0xbb
mem2[2] = 0xcc
mem2[3] = 0xdd
mem3[0][0] = 0x0
mem3[0][1] = 0x1
mem3[1][0] = 0x1
mem3[1][1] = 0x2
mem3[1][1]
mem3[2][0]
                 = 0x2= 0x2
mem3[2][0] = 0x3
mem3[3][0] = 0x3
mem3[3][1] = 0x4
ncsim: *W,RNQUIE: Simulation is complete.
```

Figure 21: ToDo

Notice how the inner loop completes before the outer loop.

### 3.4.2 Memories

Memories are digital storage elements that help store data & information in digital circuits. RAMs & ROMs are good examples of such memory elements. Storage elements can be modeled using one-dimensional arrays of type reg and is called a memory. Each element in the memory may represent a word and is referenced using a single array index.



Figure 22: ToDo

## 3.4.3 Register Vector

Verilog vectors are declared using a size range on the left side of the variable name & these get realized into flops that match the size of the variable. In the code show below, the design module accepts a clock, reset, and some other input signals to RD/WR data into a block.

It contains a 16-bit storage element called register, which simply gets updated during writes and returns the current value during reads. The register is written when sel & wr are high on the same clock edge. It returns the current data when sel is high & wr is low:

```
module des (
                      input
                                       clk,
                      input
                                      rstn,
                     input
                                      WΓ,
                     input
                                      sel,
                     input [15:0]
                                      wdata,
                     output [15:0]
                                      rdata);
         reg [15:0] register;
        always @ (posedge clk) begin
10
        if (!rstn)
             register <= 0;
         else begin
13
             if (sel & wr)
14
             register <= wdata;
             else
16
             register <= register;
         end
18
         end
19
20
         assign rdata = (sel & ~wr) ? register : 0;
21
    endmodule
22
```

Figure 23: ToDo

The hardware schematic shows that a 16-bit flop is updated when control logic for writes are active & the current value is returned when control logic is configured for reads:



Figure 24: ToDo

## 3.4.4 Array

In this example, register is an array that has four locations with each having a width of 16-bits. The design module accepts an additional input signal which is called addr to access a particular index in the array.

```
module des (
                                       clk,
                      input
                     input
                                       rstn,
                     input [1:0]
                                       addr,
                     input
                                       WΓ,
                     input
                                       sel,
                     input [15:0]
                                      wdata,
                     output [15:0]
                                       rdata);
    reg [15:0] register [0:3];
    integer i;
    always @ (posedge clk) begin
        if (!rstn) begin
13
             for (i = 0; i < 4; i = i+1) begin
                 register[i] <= 0;</pre>
             end
16
        end else begin
             if (sel & wr)
                 register[addr] <= wdata;
19
             else
20
                 register[addr] <= register[addr];</pre>
         end
    end
    assign rdata = (sel & ~wr) ? register[addr] : 0;
    endmodule
```

Figure 25: ToDo

It can be seen in the hardware schematic that each index of the array is a 16-bit flop and the input address is used to access a particular set of flops.



Figure 26: ToDo

# 4 Building Blocks

# 4.1 Verilog Module

A module is a block of Verilog code that implements a certain functionality. Modules can be embedded within other modules and a higher level module can communicate with its lower level modules using their input & output ports.

A module should be enclosed within module & endmodule keywords. The name of the module should be given after the module keyword as well as a list of optional ports can be declared.

## 4.1.1 Example

The module dff represents a D flip-flop which has 3 input ports d, clk, and rstn and one output port, q. The contents within the module block describe how a D flip flop should behave for different combinations of inputs. Here, input d is always assigned to output q at posedge of clk if rstn is high.

```
// Module called "dff" has 3 inputs and 1 output port
    module dff (
                      input
                                       d,
2
                                                     clk,
                                   input
                                   input
                                                     rstn,
                                   output reg
                                                q);
         always @ (posedge clk) begin
             if (!rstn)
                 q \ll 0;
10
             else
11
                 q \ll d;
12
         end
13
    endmodule
14
```

Figure 27: ToDo



Figure 28: ToDo

## 4.1.2 What is the purpose of a module?

A module represents a design unit that implements certain behavioral characteristics and will get converted into a digital ciruit during synthesis. Any combination of inputs can be given to the module and it will providing the corresponding output. This allows such a module to be reused to form bigger modules that implement more complex designs.

## 4.2 Verilog Ports

#### Source

Ports are a set of signals that define the direction such signals with respect to the module.

## 4.2.1 Types of Ports

| Port   | Description                                                         |
|--------|---------------------------------------------------------------------|
| Input  | The design module recieves values using its input port(s)           |
| Output | The design module sends values using its output port(s)             |
| Inout  | The design module can either send or recieve values using its inout |
|        | port(s)                                                             |

Ports by default are considered as nets of type wire.

### 4.2.2 Signed Ports

The signed attribute can be attached to a port declaration or a net/reg declaration or both. Implicit nets are defaulted to unsigned.

## 4.3 Port Variations

Veriog 1995

Module declaraions had to first list the names of its ports withinbrackets and then specify the direction of those ports within the body of the module.

Figure 29: ToDo

## Veriog 2001

ANSI-C style port naming was introduced in 2001 and allowed the direction to be specified inside the port list.

If a port declaration is declared as a net or variabled type, then it is illegal to redeclare the same port with another declaration.

```
module test (input [7:0] a, // a, e are implicitly declared of type wire output reg [7:0] e );

wire signed [7:0] a; // illegal - declaration of a is already complete -> simulator dependent wire [7:0] e; // illegal - declaration of e is already complete

// Rest of the design code endmodule
```

Figure 30: ToDo

If the port declaration does not include a net or variable type, then the port

can be declared in a net or variable type declaration again.

```
module test (input [7:0] a,
output [7:0] e);

reg [7:0] e; // Okay - net_type was not declared before

// Rest of the design code
endmodule
```

Figure 31: ToDo

## 4.4 Verilog Module INstnatiations

#### source

Bigger and complex designs can be built by integrating multiple modules in a hierarchical manner. Modules can be instantiated within other modules & ports of these instances can be connected with other signals inside the parent module.

The port connections can be done via an ordered list or by name.

## 4.4.1 Port Connection by Ordered List

The connection between the modules can be described by using an ordered list.

In the following example, mydesign is a module insstantiated with the name d0 in another module called  $tb_top.Ports are connected in a certain order which is determined by the position of that position of the position of$ 

```
module mydesign (input x, y, z, // x is at position 1, y at 2, x at 3 and output o); // o is at position 4

endmodule

module tb_top;
wire [1:0] a;
wire b, c;

mydesign d0 (a[0], b, a[1], c); // a[0] is at position 1 so it is automatically connected to x // b is at position 2 so it is automatically connected to y // a[1] is at position 3 so it is connected to z // c is at position 4, and hence connection is with o endmodule
```

Figure 32: ToDo

This method can become inconvenient if the order might change when a new port is added to the list of desired instantiated module or when the number of ports in the design is very large.

### 4.4.2 Port Connection by Name

A better way to connect ports is by explicitly linking ports on both sides using their port name.

The . notation in the port list indicates that the port name following the dot belongs to the design. The signal name to which the design has to be connected is given next within parentheses:

$$mydesignd0(.x(a[0]),.z(a[1]),.y(a[2]));$$

## 4.4.3 Unconected/Floating Ports

Ports that are not connected to any wire in the instantiated module will have a state of high-impedance.

Note that outputs from instantiated modules athat are unconnected are left unconnected in the RTL schematic after sythesis. If the input to such instantiated modules are connected to nets that are not being driven than those ports will be grounded in the RTL schematic.

tion is sufficient in that case. However output ports that need to store values should be declared as reg data ty

All port declarations are implicitly declared as wire and hence the port direc-

Ports of type input or input cannot be declared as reg since they're driven from external signals continuously and should not store values.

## 4.5 Verilog assign statement

source

Signals of type wire or of a similar data type requires a continuous assignment of a value. For example, consider an electrical wire used to connected to different components on a breadboard. As long as the power source is connected & applied to one end of the wire, the component connected to the other end of the wire will get voltage.

In Verilog, this concept is realized by the assign statement where any wire or other similar wire like data-types can be driven continuously with a value. The value may be constant or an expression.

### 4.5.1 Assign Syntax

The assignment syntax starts with the keyword assign followed by the signal name which can be a single signal or concatenation of different signal nets. The drive strength & delay are optional & are mostly used for dataflow modeling

than synthesizing into real hardware. The expression or signal on the RHS is evaluated & assigned to the net or expression of nets on the LHS:

 $assign < net\_expression >= [drive\_strength][delay] < expression or constant value >$ 

Delay values are useful for specifying delays for gates & are used to model timing behavior in real hardware because the value dictates when the net should be assigned with evaluated value.

### Rules

- LHS should always be a scalar or vector net or a concatenation of such nets but never a scalar or vector register
- RHS can contain scalar or vector registers & function calls
- Whenever any operand on the RHS changes in value, LHS will be updated instantly with the new value
- $\bullet$  assign statements are also called continuous assignments & are always active

Continuous assignment statements can be used to represent combinational gates in Verilog.

#### Consider the following example

```
module xyz (input [3:0] x, // x is a 4-bit vector net

input y, // y is a scalar net (1-bit)

output [4:0] z); // z is a 5-bit vector net

wire [1:0] a;
wire b;

// Assume one of the following assignments are chosen in real design
// If x='hC and y='h1 let us see the value of z
```

Figure 33: ToDo