2006-09-25 20:40:52 +00:00
|
|
|
// $Id$
|
2006-08-26 11:35:28 +00:00
|
|
|
// 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;
|
2008-03-28 21:55:23 +00:00
|
|
|
reg [31:0] vec [1:0];
|
2006-08-26 11:35:28 +00:00
|
|
|
|
|
|
|
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;
|
2007-05-16 18:19:23 +00:00
|
|
|
if (toint(2) != 3) $stop;
|
2006-08-26 11:35:28 +00:00
|
|
|
if (global != 5) $stop;
|
|
|
|
setit;
|
|
|
|
incr(global,global,32'h10);
|
|
|
|
if (global != 32'h17) $stop;
|
|
|
|
nop(32'h11);
|
|
|
|
|
2006-09-25 20:40:52 +00:00
|
|
|
global = 32'h00000001;
|
2006-09-26 15:05:35 +00:00
|
|
|
flipupperbit(global,4'd4);
|
|
|
|
flipupperbit(global,4'd12);
|
|
|
|
if (global !== 32'h10100001) $stop;
|
2006-09-25 20:40:52 +00:00
|
|
|
|
2006-10-11 15:41:42 +00:00
|
|
|
if (nil_func(32'h12,32'h12) != 32'h24) $stop;
|
|
|
|
nil_task(32'h012,32'h112,global);
|
|
|
|
if (global !== 32'h124) $stop;
|
|
|
|
|
2008-03-28 21:55:23 +00:00
|
|
|
vec[0] = 32'h333;
|
|
|
|
vec[1] = 32'habc;
|
|
|
|
incr(vec[1],vec[0],vec[1]);
|
|
|
|
if (vec[0] != 32'h333) $stop;
|
|
|
|
if (vec[1] != 32'hdef) $stop;
|
|
|
|
|
|
|
|
incr(vec[2],vec[0],vec[2]); // Reading/Writing past end of vector!
|
|
|
|
|
2006-08-26 11:35:28 +00:00
|
|
|
$write("*-* All Finished *-*\n");
|
|
|
|
$finish;
|
|
|
|
end
|
|
|
|
|
|
|
|
function [2:0] add;
|
2008-03-28 21:55:23 +00:00
|
|
|
input [2:0] fromv;
|
2006-08-26 11:35:28 +00:00
|
|
|
begin
|
2008-03-28 21:55:23 +00:00
|
|
|
add = fromv + 3'd1;
|
2006-08-26 11:35:28 +00:00
|
|
|
begin : named
|
|
|
|
reg [31:0] flocal;
|
|
|
|
flocal = 1;
|
|
|
|
global = global + flocal;
|
2007-07-18 17:58:53 +00:00
|
|
|
end : named // SystemVerilog end labels
|
2006-08-26 11:35:28 +00:00
|
|
|
end
|
|
|
|
endfunction
|
|
|
|
|
|
|
|
function [3:0] munge4;
|
2008-03-28 21:55:23 +00:00
|
|
|
input [3:0] fromv; // Different fromv than the 'fromv' signal above
|
2006-08-26 11:35:28 +00:00
|
|
|
reg one;
|
|
|
|
begin : named
|
|
|
|
reg [1:0] flocal;
|
|
|
|
// Function calling a function
|
|
|
|
one = 1'b1;
|
2008-03-28 21:55:23 +00:00
|
|
|
munge4 = {one, add(fromv[2:0])};
|
2006-08-26 11:35:28 +00:00
|
|
|
end
|
|
|
|
endfunction
|
|
|
|
|
|
|
|
task setit;
|
|
|
|
reg [31:0] temp;
|
|
|
|
begin
|
|
|
|
temp = global + 32'h1;
|
|
|
|
global = temp + 32'h1;
|
|
|
|
end
|
|
|
|
endtask
|
|
|
|
|
2007-06-19 23:43:14 +00:00
|
|
|
task incr (
|
|
|
|
// Check a V2K style input/output list
|
|
|
|
output [31:0] z,
|
|
|
|
input [31:0] a, inc
|
|
|
|
);
|
2006-08-26 11:35:28 +00:00
|
|
|
z = a + inc;
|
|
|
|
endtask
|
|
|
|
|
|
|
|
task nop;
|
|
|
|
input [31:0] a;
|
|
|
|
begin
|
|
|
|
end
|
|
|
|
endtask
|
|
|
|
|
2006-09-26 15:05:35 +00:00
|
|
|
task flipupperbit;
|
2006-09-25 20:40:52 +00:00
|
|
|
inout [31:0] vector;
|
2006-09-26 15:05:35 +00:00
|
|
|
input [3:0] bitnum;
|
|
|
|
reg [4:0] bitnum2;
|
|
|
|
begin
|
|
|
|
bitnum2 = {1'b1, bitnum}; // A little math to test constant propagation
|
|
|
|
vector[bitnum2] = vector[bitnum2] ^ 1'b1;
|
|
|
|
end
|
2006-09-25 20:40:52 +00:00
|
|
|
endtask
|
|
|
|
|
2006-10-11 15:41:42 +00:00
|
|
|
task nil_task;
|
|
|
|
input [31:0] a;
|
|
|
|
input [31:0] b;
|
|
|
|
output [31:0] q;
|
|
|
|
// verilator no_inline_task
|
|
|
|
q = nil_func(a, b);
|
|
|
|
endtask
|
|
|
|
|
|
|
|
function [31:0] nil_func;
|
|
|
|
input [31:0] fa;
|
|
|
|
input [31:0] fb;
|
|
|
|
// verilator no_inline_task
|
|
|
|
nil_func = fa + fb;
|
|
|
|
endfunction
|
|
|
|
|
2007-05-16 18:19:23 +00:00
|
|
|
function integer toint;
|
|
|
|
input integer fa;
|
|
|
|
toint = fa + 32'h1;
|
|
|
|
endfunction
|
|
|
|
|
2006-08-26 11:35:28 +00:00
|
|
|
endmodule
|