Skip to content

Verilog Examples

Leonard Pfeiffer edited this page Oct 25, 2023 · 40 revisions

File ending

.v  // Verilog 2001 standard
.sv // SystemVerilog 2006 standard

Module

module <name> #(
    <params>
)(
    <ports>
);
    <params>
    <regs>
    <wires>
    <ints>
    <proc>
    <ass>
endmodule

Ports

input <name>,               // Input
input [x:y] <name>, <name>, // Multiple array "x downto y" inputs
inout reg <name>,           // Simultaneus in- and output register
output <name>               // Output

Registers / Wires

reg <type> <name>, <name>; // Registers (Save Data at end of clock cycle)
wire <type> [x:y] <name>;  // Wire "from x downto y" (Transmits data almost instantly)
reg a = 0;                 // With initial value this time (mostly for sim)

Parameters aka Generics & Constants

parameter <type> <name>;            // Generic (in port definition)
parameter <type> <name> = <value>;  // Constant
localparam <type> <name> = <value>; // Constant inside module (can be computed from generics)

Instantionation

<module> #(
    <params> // sep by ","
) <instance> (
    <ports>  // seq by ","
);

Assignments

.<port>(<connection/value>)
.<parameter(<connection/value>)

Logical values

0 // Logical zero
1 // Logical one
x // Unknown/undefined
z // What the actual f*ck

Types (interpreted from values)

Values and their types

-7 46 123      // Integer
1.3 0.2 3e-5   // Real
"Hello kitty!" // String

Logical radix

d46 D23 // Decimal
hFA HAE // Hexadecimal
o17 O77 // Octal
b10 b01 // Binary

Length

32'd46      // 32 bit filled with (one!) decimal 46
8'b10101010 // "10101010" in binary as 8 bit-value
18'o777777  // 18 bits of ones from octal code

Types why is this a subcategory

// Can be interpreted by totally not stupid compiler that will totally not produce untraceable errors
real
string
time    // For simulations
event   // Complex (probably represents change of value of sensitivity list connections or the sensitivity list itself)
integer

Processes

Always @

always @ (<condition>) <actions>

Intitial (Sim only!)

initial <stmt>
initial begin
    <stmts>
end

Clock

posedge clk // Rising edge of clock
negedge clk // Falling edge o clock
posedge rst // Rising edge of reset

Conditions

If

if (<condition1>) begin
    <stmts>
end else if (<condition>) begin
    <stmts>
end else begin
    <stmts>
end

Switch / Case

case (<expr>)
    <value> : begin
        <stmts>
    end
    <value> : begin
        <stmts>
    end
    default : begin
        <stmts>
    end
endcase
case (<expr>)
    2'bxz : <expr>;
    2'bzx : <expr>;
    2'bxx : <expr>;
    default : <expr>;
endcase

Assignments

Assign all indices

assign x = '1;        // Assign all indexes to logical one (works with logic zero too
assign x = 25'd69;    // lol
assign x = a ? b : c; // Best of them all: Assign a if b (condition) else assign c to x

Package

package <name>
    <params>
    <funcs?>
    <types>
endpackage

Type

// Elements separated by ","
typedef logic [x:y] <name>;      // Arrays
typedef enum state {<e>} <name>; // For united states machines
typedef enum {<e>} <name>;       // Not a state enum bruh
typedef enum [x:y] {<e>} <name>; // Enum with specified range
Clone this wiki locally