forked from github/verilator
74 lines
1.4 KiB
Coq
74 lines
1.4 KiB
Coq
|
// $Id:$
|
||
|
// DESCRIPTION: Verilator: Verilog Test module
|
||
|
//
|
||
|
// This file ONLY is placed into the Public Domain, for any use,
|
||
|
// without warranty, 2003 by Wilson Snyder.
|
||
|
|
||
|
module t;
|
||
|
reg [2:0] value;
|
||
|
reg [31:0] global;
|
||
|
|
||
|
initial begin
|
||
|
global = 1;
|
||
|
value = 2;
|
||
|
if (add(value) != 3'd3) $stop;
|
||
|
if (global != 2) $stop;
|
||
|
if (add(add(3'd1)) != 3'd3) $stop;
|
||
|
if (global != 4) $stop;
|
||
|
if (munge4(4'b0010) != 4'b1011) $stop;
|
||
|
if (global != 5) $stop;
|
||
|
setit;
|
||
|
incr(global,global,32'h10);
|
||
|
if (global != 32'h17) $stop;
|
||
|
nop(32'h11);
|
||
|
|
||
|
$write("*-* All Finished *-*\n");
|
||
|
$finish;
|
||
|
end
|
||
|
|
||
|
function [2:0] add;
|
||
|
input [2:0] from;
|
||
|
begin
|
||
|
add = from + 3'd1;
|
||
|
begin : named
|
||
|
reg [31:0] flocal;
|
||
|
flocal = 1;
|
||
|
global = global + flocal;
|
||
|
end
|
||
|
end
|
||
|
endfunction
|
||
|
|
||
|
function [3:0] munge4;
|
||
|
input [3:0] from; // Different from the 'from' signal above
|
||
|
reg one;
|
||
|
begin : named
|
||
|
reg [1:0] flocal;
|
||
|
// Function calling a function
|
||
|
one = 1'b1;
|
||
|
munge4 = {one, add(from[2:0])};
|
||
|
end
|
||
|
endfunction
|
||
|
|
||
|
task setit;
|
||
|
reg [31:0] temp;
|
||
|
begin
|
||
|
temp = global + 32'h1;
|
||
|
global = temp + 32'h1;
|
||
|
end
|
||
|
endtask
|
||
|
|
||
|
task incr;
|
||
|
output [31:0] z;
|
||
|
input [31:0] a;
|
||
|
input [31:0] inc;
|
||
|
z = a + inc;
|
||
|
endtask
|
||
|
|
||
|
task nop;
|
||
|
input [31:0] a;
|
||
|
begin
|
||
|
end
|
||
|
endtask
|
||
|
|
||
|
endmodule
|