Verilog format

This commit is contained in:
Wilson Snyder 2026-02-22 13:50:01 -05:00
parent 7f0be8a072
commit e238a2ca5e
22 changed files with 211 additions and 178 deletions

View File

@ -5,17 +5,17 @@
// SPDX-License-Identifier: CC0-1.0
class Base;
int value;
int value;
endclass
module t;
Base b;
Base a;
initial begin
b = null;
a = new b; // BAD: null handle dereference (IEEE 8.7)
if (a != null) $write("unexpected clone\n");
$write("*-* All Finished *-*\n");
$finish;
end
Base b;
Base a;
initial begin
b = null;
a = new b; // BAD: null handle dereference (IEEE 8.7)
if (a != null) $write("unexpected clone\n");
$write("*-* All Finished *-*\n");
$finish;
end
endmodule

View File

@ -24,8 +24,8 @@ end
class Cls;
int d;
rand int y;
rand bit i;
rand int y;
rand bit i;
constraint q {
if (i) {

View File

@ -17,50 +17,60 @@
module t;
class XorTest;
rand bit [7:0] data [];
rand bit [7:0] data[];
rand bit [7:0] result;
function new(); data = new[4]; endfunction
constraint c_size { data.size() == 4; }
constraint c_xor { result == data.xor(); }
function new();
data = new[4];
endfunction
constraint c_size {data.size() == 4;}
constraint c_xor {result == data.xor();}
endclass
class SumTest;
rand bit [7:0] data [];
rand bit [7:0] data[];
rand bit [7:0] result;
function new(); data = new[4]; endfunction
constraint c_size { data.size() == 4; }
constraint c_sum { result == data.sum(); }
function new();
data = new[4];
endfunction
constraint c_size {data.size() == 4;}
constraint c_sum {result == data.sum();}
endclass
class AndTest;
rand bit [7:0] data [];
rand bit [7:0] data[];
rand bit [7:0] result;
function new(); data = new[4]; endfunction
constraint c_size { data.size() == 4; }
constraint c_and { result == data.and(); }
function new();
data = new[4];
endfunction
constraint c_size {data.size() == 4;}
constraint c_and {result == data.and();}
endclass
class OrTest;
rand bit [7:0] data [];
rand bit [7:0] data[];
rand bit [7:0] result;
function new(); data = new[4]; endfunction
constraint c_size { data.size() == 4; }
constraint c_or { result == data.or(); }
function new();
data = new[4];
endfunction
constraint c_size {data.size() == 4;}
constraint c_or {result == data.or();}
endclass
class ProductTest;
rand bit [7:0] data [];
rand bit [7:0] data[];
rand bit [7:0] result;
function new(); data = new[4]; endfunction
constraint c_size { data.size() == 4; }
constraint c_prod { result == data.product(); }
function new();
data = new[4];
endfunction
constraint c_size {data.size() == 4;}
constraint c_prod {result == data.product();}
endclass
initial begin
static XorTest t_xor = new();
static SumTest t_sum = new();
static AndTest t_and = new();
static OrTest t_or = new();
static XorTest t_xor = new();
static SumTest t_sum = new();
static AndTest t_and = new();
static OrTest t_or = new();
static ProductTest t_prod = new();
repeat (10) begin

View File

@ -23,7 +23,7 @@ class FuncConstraintTest;
endfunction
constraint func_con {
mask inside {[8'h10:8'hF0]};
mask inside {[8'h10 : 8'hF0]};
value >= get_min_value(mask);
value <= get_max_value(mask);
}

View File

@ -1,6 +1,6 @@
%Warning-CONSTRAINTIGN: t/t_constraint_func_call_unsup.v:18:23: Unsupported: complex function in constraint, treating as state
18 | constraint c { x <= complex_func(y); }
| ^~~~~~~~~~~~
%Warning-CONSTRAINTIGN: t/t_constraint_func_call_unsup.v:16:22: Unsupported: complex function in constraint, treating as state
16 | constraint c {x <= complex_func(y);}
| ^~~~~~~~~~~~
... For warning description see https://verilator.org/warn/CONSTRAINTIGN?v=latest
... Use "/* verilator lint_off CONSTRAINTIGN */" and lint_on around source to disable this message.
%Error: Exiting due to

View File

@ -9,13 +9,11 @@ class Cls;
rand bit [7:0] y;
function bit [7:0] complex_func(bit [7:0] m);
if (m > 128)
return m;
else
return m + 1;
if (m > 128) return m;
else return m + 1;
endfunction
constraint c { x <= complex_func(y); }
constraint c {x <= complex_func(y);}
endclass
module t;

View File

@ -9,8 +9,8 @@
`include "../include/t_flag_relinc.vh"
module t_flag_relinc_sub ();
initial begin
`all_finished;
$finish;
end
initial begin
`all_finished;
$finish;
end
endmodule

View File

@ -5,17 +5,17 @@
// SPDX-License-Identifier: CC0-1.0
module t;
Iface ifc();
rvlab_tests uut (.ifc);
Iface ifc ();
rvlab_tests uut (.ifc);
always begin
uut.test_idcode();
end
initial begin
#1;
$write("*-* All Finished *-*\n");
$finish;
end
always begin
uut.test_idcode();
end
initial begin
#1;
$write("*-* All Finished *-*\n");
$finish;
end
endmodule
interface Iface;
@ -23,15 +23,16 @@ interface Iface;
logic tdo;
task tsk(output logic [31:0] data_o, input logic [31:0] data_i);
@(posedge tck);
data_o[$size(data_i)-1] <= tdo;
@(posedge tck);
data_o[$size(data_i)-1] <= tdo;
endtask
endinterface
module rvlab_tests (
Iface ifc);
task test_idcode();
bit [31:0] idcode_read;
ifc.tsk(idcode_read, '0);
endtask
Iface ifc
);
task test_idcode();
bit [31:0] idcode_read;
ifc.tsk(idcode_read, '0);
endtask
endmodule

View File

@ -1,15 +1,18 @@
// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed under the Creative Commons Public Domain, for
// any use, without warranty, 2026 by Antmicro Ltd.
// This file ONLY is placed under the Creative Commons Public Domain.
// SPDX-FileCopyrightText: 2026 Antmicro Ltd
// SPDX-License-Identifier: CC0-1.0
module t;
initial fork
#0 $write("This should be last\n");
begin
fork $write("This should be second\n"); join_none
$write("This should be first\n");
end
initial
fork
#0 $write("This should be last\n");
begin
fork
$write("This should be second\n");
join_none
$write("This should be first\n");
end
join_none
endmodule

View File

@ -1,7 +1,7 @@
// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed under the Creative Commons Public Domain, for
// any use, without warranty, 2026 by Antmicro Ltd.
// This file ONLY is placed under the Creative Commons Public Domain.
// SPDX-FileCopyrightText: 2026 Antmicro Ltd
// SPDX-License-Identifier: CC0-1.0
module test;
@ -10,7 +10,7 @@ module test;
mbox = new();
fork
repeat(2) begin
repeat (2) begin
int val;
mbox.get(val);
fork

View File

@ -1,7 +1,7 @@
// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed under the Creative Commons Public Domain, for
// any use, without warranty, 2026 by Antmicro Ltd.
// This file ONLY is placed under the Creative Commons Public Domain.
// SPDX-FileCopyrightText: 2026 Antmicro Ltd
// SPDX-License-Identifier: CC0-1.0
class events_holder;

View File

@ -7,5 +7,5 @@
// SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0
module subA (output bit [31:0] out); /*verilator hier_block*/
subsub subsub(.out(out));
subsub subsub(.out(out));
endmodule

View File

@ -8,5 +8,5 @@
// Note: no hier_block pragma here to validate partial hier_block design
module subB (output bit [31:0] out);
assign out = `VALUE_B;
assign out = `VALUE_B;
endmodule

View File

@ -6,10 +6,10 @@
// SPDX-FileCopyrightText: 2024 Antmicro
// SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0
module subsub
#(
`include "t_hier_block_import.vh"
)
(output bit [31:0] out); /*verilator hier_block*/
assign out = pt.PARAM_VALUE;
module subsub #(
`include "t_hier_block_import.vh"
) (
output bit [31:0] out
); /*verilator hier_block*/
assign out = pt.PARAM_VALUE;
endmodule

View File

@ -4,45 +4,47 @@
// SPDX-FileCopyrightText: 2024 Wilson Snyder
// SPDX-License-Identifier: CC0-1.0
module detail_code(
module detail_code (
input clk,
input reset_l);
input reset_l
);
endmodule
module sub_top(
module sub_top (
input clk,
input reset_l);
input reset_l
);
detail_code u0(
.clk(clk),
.reset_l(reset_l)
);
detail_code u1(
.clk(clk),
.reset_l(reset_l)
);
detail_code u2(
.clk(clk),
.reset_l(reset_l)
);
detail_code u3(
.clk(clk),
.reset_l(reset_l)
);
detail_code u4(
.clk(clk),
.reset_l(reset_l)
);
detail_code u5(
.clk(clk),
.reset_l(reset_l)
);
detail_code u6(
.clk(clk),
.reset_l(reset_l)
);
detail_code u7(
.clk(clk),
.reset_l(reset_l)
);
detail_code u0 (
.clk(clk),
.reset_l(reset_l)
);
detail_code u1 (
.clk(clk),
.reset_l(reset_l)
);
detail_code u2 (
.clk(clk),
.reset_l(reset_l)
);
detail_code u3 (
.clk(clk),
.reset_l(reset_l)
);
detail_code u4 (
.clk(clk),
.reset_l(reset_l)
);
detail_code u5 (
.clk(clk),
.reset_l(reset_l)
);
detail_code u6 (
.clk(clk),
.reset_l(reset_l)
);
detail_code u7 (
.clk(clk),
.reset_l(reset_l)
);
endmodule

View File

@ -4,17 +4,21 @@
// SPDX-FileCopyrightText: 2026 Wilson Snyder
// SPDX-License-Identifier: CC0-1.0
interface ifc #(parameter int width)(input logic [width-1:0] b);
interface ifc #(
parameter int width
) (
input logic [width-1:0] b
);
logic [width-1:0] a;
typedef logic[width-1:0] type_t;
typedef logic [width-1:0] type_t;
always_comb a = type_t'(b);
endinterface
module t;
logic [15:0] x;
ifc #(.width(16)) x_ifc(x);
ifc #(.width(16)) x_ifc (x);
logic [7:0] y;
ifc #(.width(8)) y_ifc(y);
ifc #(.width(8)) y_ifc (y);
initial begin
$write("*-* All Finished *-*\n");

View File

@ -4,28 +4,29 @@ lint_off -rule NONSTD
`begin_keywords "1800-2023"
`timescale 1ns/1ps
module top(
input logic clk,
input logic rst,
output logic top_out
input logic clk,
input logic rst,
output logic top_out
);
submod u_submod (
.clk (clk),
.rst (rst),
.out_signal(top_out)
);
submod u_submod (
.clk (clk),
.rst (rst),
.out_signal(top_out)
);
endmodule
`begin_keywords "1800-2023"
`timescale 1ns/1ps
module submod(
input logic clk,
input logic rst,
output logic out_signal
`timescale 1ns / 1ps
module submod (
input logic clk,
input logic rst,
output logic out_signal
);
always_ff @(posedge clk or posedge rst) begin
if (rst) begin
out_signal <= 1'b0;
end else begin
out_signal <= ~out_signal;
end
end
always_ff @(posedge clk or posedge rst) begin
if (rst) begin
out_signal <= 1'b0;
end
else begin
out_signal <= ~out_signal;
end
end
endmodule

View File

@ -6,13 +6,13 @@
`timescale 1ns/1ps
module top(/*AUTOARG*/
input logic clk,
input logic rst,
output logic top_out
input logic clk,
input logic rst,
output logic top_out
);
submod u_submod (/*AUTOINST*/
.clk (clk),
.rst (rst),
.out_signal(top_out)
);
submod u_submod (/*AUTOINST*/
.clk (clk),
.rst (rst),
.out_signal(top_out)
);
endmodule

View File

@ -4,17 +4,18 @@
// SPDX-FileCopyrightText: 2025 Antmicro Ltd
// SPDX-License-Identifier: CC0-1.0
`timescale 1ns/1ps
module submod(/*AUTOARG*/
input logic clk,
input logic rst,
output logic out_signal
`timescale 1ns / 1ps
module submod (
input logic clk,
input logic rst,
output logic out_signal
);
always_ff @(posedge clk or posedge rst) begin
if (rst) begin
out_signal <= 1'b0;
end else begin
out_signal <= ~out_signal;
end
end
always_ff @(posedge clk or posedge rst) begin
if (rst) begin
out_signal <= 1'b0;
end
else begin
out_signal <= ~out_signal;
end
end
endmodule

View File

@ -20,7 +20,7 @@ module t ( /*AUTOARG*/
int passs;
} result_t;
result_t results [int];
result_t results[int];
result_t expected[int];
localparam MAX = 15;
@ -41,9 +41,9 @@ module t ( /*AUTOARG*/
always @(clk) begin
++cyc;
if (cyc == MAX) begin
expected[1] = '{2, 3};
// expected[2] shouldn't be initialized
expected[3] = '{6, 0};
expected[1] = '{2, 3};
// expected[2] shouldn't be initialized
expected[3] = '{6, 0};
`checkh(results, expected);
$write("*-* All Finished *-*\n");
$finish;

View File

@ -14,13 +14,13 @@ module t;
// String-key associative array with size constraint
class StringKeyTest;
rand int data[string];
constraint c_size { data.size() == 3; }
constraint c_size {data.size() == 3;}
endclass
// Int-key associative array with size constraint
class IntKeyTest;
rand bit [7:0] values[int];
constraint c_size { values.size() == 2; }
constraint c_size {values.size() == 2;}
endclass
initial begin

View File

@ -16,7 +16,7 @@
class DataItem;
rand bit [7:0] value;
rand bit [7:0] limit;
constraint default_con { limit inside {[8'd50:8'd200]}; }
constraint default_con {limit inside {[8'd50 : 8'd200]};}
endclass
// Test 4: 'this' in inline constraint called from another class method.
@ -24,7 +24,10 @@ endclass
class Caller;
rand bit [7:0] own_value;
function int do_rand(DataItem item);
return item.randomize() with { this.value > 8'd30; this.value < 8'd40; };
return item.randomize() with {
this.value > 8'd30;
this.value < 8'd40;
};
endfunction
endclass
@ -35,18 +38,28 @@ module t;
automatic int rand_ok;
// Test 1: 'this.member' in inline constraint from module-level code
rand_ok = item.randomize() with { this.value > 8'd10; this.value < 8'd50; };
rand_ok = item.randomize() with {
this.value > 8'd10;
this.value < 8'd50;
};
`checkd(rand_ok, 1)
`check_range(item.value, 11, 49)
`check_range(item.limit, 50, 200)
// Test 2: multiple 'this.member' references
rand_ok = item.randomize() with { this.value > 8'd20; this.value < 8'd30; };
rand_ok = item.randomize() with {
this.value > 8'd20;
this.value < 8'd30;
};
`checkd(rand_ok, 1)
`check_range(item.value, 21, 29)
// Test 3: mix of 'this.member' and unqualified member
rand_ok = item.randomize() with { this.value > 8'd5; this.value < 8'd100; limit > 8'd150; };
rand_ok = item.randomize() with {
this.value > 8'd5;
this.value < 8'd100;
limit > 8'd150;
};
`checkd(rand_ok, 1)
`check_range(item.value, 6, 99)
`check_range(item.limit, 151, 200)