Verilog HDL: The First Example

Module, I/O Ports, Bus, and Assign

A Verilog module of a circuit encapsulates a description of its functionality as a structural or behavioral view of its input-output relationship. A structural view could be as simple as a netlist of gates or as complex as a high level architectural partition of the circuit into major functional blocks, such as an arithmetic and logic unit (ALU). A behavioral view could be a simple Boolean equation model, a register transfer level (RTL), or an algorithm. This section will look at the basics of a Verilog file.

一个简单的例子

The general format for a Verilog circuit description is shown in the code below in Fig. 1. Required keywords have been shown in blue, comments in green, and key text strings the user must supply are shown in italics.

Figure 1. The first example.

Module

In a schematic capture environment, a graphical symbol defines a given logic circuit by showing a “bounding box” as well as input and output connections. In Verilog, this same concept is used, only the bounding box must be explicitly typed into the text editor. The bounding box is defined with a module block and a corresponding port statement. The module block (as shown in the example) gives the circuit a name and defines all input and output ports, and so plays the same role as a symbol in a schematic environment. The module is closed by an “endmodule” statement, and all the statement between module declaration and “endmodule” describes the functionality of the module, i.e., the internal circuit connection of the module.

Input, Output, and Bus

Whenever you are writing a Verilog module, the first thing to do is to define the input and output signals. In the example in Fig. 1, there is one input signal “sw” coming from an on-board switch, and one output signal “led” connected to LED0. Note, however, that input and output can be a group of wires as well. We call these groupings a bus. To declare the input or output as a bus, we need to provide the CAD tools with the index of the most significant bit (MSB) of the bus and the index of the least significant bit (LSB) of the bus. For example, the following code defines an 8-bit wide bus “sw”, where the left-most bit (MSB) has the index 7 and the right-most bit (LSB) has the index 0.

input[7:0]sw

Indexing a bus in Verilog is similar to indexing an array in the C language. For example, if we want to index the second bit of sw bus declared above, we will use sw[1].

Assign Statement

The assign statement in the example above assigns the signal value on the net “sw” to the net “led”. In implementation, it creates a wire that connects the input port sw to the output port引领.

An assign statement can also be used to assign one signal of a bus to one signal of another bus. For example, if we declared sw as an 8-bit wide bus and引领as an 8-bit wide bus, and we want to use second switch to control fourth引领, the code will be:

module led_sw(output[7:0]led, input[7:0]sw);assign led[3]=sw[1];... endmodule

Constants

You can also assign a constant number to a signal or a bus to tie them to either logic '1' (VDD) or logic '0' (GND). The basic syntax for a constant number in Verilog is:

<位宽度>'<基本字母> <数字>

例如:

Constant in Verilog Explanation Value in Binary
12'h123 12 bits Hexadecimal 123 0001 0010 0011
20'd44 20 bits Decimal 44 0000 0000 0000 0010 1100
4'b1010 4 bits Binary 1010 1010

要将信号或总线绑定到恒定,我们也可以使用分配语句。例如,如果我们打算将8位巴士“ SEG”绑在地面上,我们将写道:

module top(... output[7:0]seg, ...);assign seg=8'd0;... endmodule

重要的想法

  • Verilog HDL中的模块的作用类似于电路原理图中的边界框。
  • Bus is a group of signals (wires).
  • 赋值语句中通过价值啊f a signal/bus to another signal/bus.
  • Constant in Verilog HDL is presented in form of<位宽度>'<基本字母> <数字>