diff options
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/arch/xilinx/tribuf.sh | 6 | ||||
| -rw-r--r-- | tests/svtypes/enum_simple.sv | 5 | ||||
| -rw-r--r-- | tests/svtypes/typedef_memory.sv | 2 | ||||
| -rw-r--r-- | tests/svtypes/typedef_memory_2.sv | 2 | ||||
| -rw-r--r-- | tests/svtypes/typedef_package.sv | 4 | ||||
| -rw-r--r-- | tests/svtypes/typedef_param.sv | 10 | ||||
| -rw-r--r-- | tests/svtypes/typedef_scopes.sv | 18 | ||||
| -rw-r--r-- | tests/svtypes/typedef_simple.sv | 10 | ||||
| -rw-r--r-- | tests/various/bug1781.ys | 33 | ||||
| -rw-r--r-- | tests/various/exec.ys | 6 | ||||
| -rw-r--r-- | tests/various/ice40_mince_abc9.ys | 17 | 
11 files changed, 85 insertions, 28 deletions
| diff --git a/tests/arch/xilinx/tribuf.sh b/tests/arch/xilinx/tribuf.sh index 636aed12a..bd44395cb 100644 --- a/tests/arch/xilinx/tribuf.sh +++ b/tests/arch/xilinx/tribuf.sh @@ -1,5 +1,5 @@ -! ../../../yosys ../common/tribuf.v -qp "synth_xilinx" -../../../yosys ../common/tribuf.v -qp "synth_xilinx -iopad; \ +! ../../../yosys -qp "synth_xilinx" ../common/tribuf.v +../../../yosys -qp "synth_xilinx -iopad; \  select -assert-count 2 t:IBUF; \  select -assert-count 1 t:INV; \ -select -assert-count 1 t:OBUFT" +select -assert-count 1 t:OBUFT" ../common/tribuf.v diff --git a/tests/svtypes/enum_simple.sv b/tests/svtypes/enum_simple.sv index ccaf50da0..4e4d5871c 100644 --- a/tests/svtypes/enum_simple.sv +++ b/tests/svtypes/enum_simple.sv @@ -5,8 +5,9 @@ module enum_simple(input clk, input rst);  	typedef enum logic [1:0] {  		ts0, ts1, ts2, ts3  	} states_t; -	(states_t) state; -	(states_t) enum_const = ts1; +	states_t state; +	(states_t) state1; +	states_t enum_const = ts1;  	always @(posedge clk) begin  		if (rst) begin diff --git a/tests/svtypes/typedef_memory.sv b/tests/svtypes/typedef_memory.sv index 577e484ad..37e63c1d0 100644 --- a/tests/svtypes/typedef_memory.sv +++ b/tests/svtypes/typedef_memory.sv @@ -1,7 +1,7 @@  module top(input [3:0] addr, wdata, input clk, wen, output reg [3:0] rdata);  	typedef logic [3:0] ram16x4_t[0:15]; -	(ram16x4_t) mem; +	ram16x4_t mem;  	always @(posedge clk) begin  		if (wen) mem[addr] <= wdata; diff --git a/tests/svtypes/typedef_memory_2.sv b/tests/svtypes/typedef_memory_2.sv index f3089bf55..6d65131db 100644 --- a/tests/svtypes/typedef_memory_2.sv +++ b/tests/svtypes/typedef_memory_2.sv @@ -1,7 +1,7 @@  module top(input [3:0] addr, wdata, input clk, wen, output reg [3:0] rdata);  	typedef logic [3:0] nibble; -	(nibble) mem[0:15]; +	nibble mem[0:15];  	always @(posedge clk) begin  		if (wen) mem[addr] <= wdata; diff --git a/tests/svtypes/typedef_package.sv b/tests/svtypes/typedef_package.sv index b766f10cf..57a78c53a 100644 --- a/tests/svtypes/typedef_package.sv +++ b/tests/svtypes/typedef_package.sv @@ -5,8 +5,8 @@ endpackage  module top; -	(* keep *) (pkg::uint8_t) a = 8'hAA; -	(* keep *) (pkg::enum8_t) b_enum = pkg::bb; +	(* keep *) pkg::uint8_t a = 8'hAA; +	(* keep *) pkg::enum8_t b_enum = pkg::bb;  	always @* assert(a == 8'hAA);  	always @* assert(b_enum == 8'hBB); diff --git a/tests/svtypes/typedef_param.sv b/tests/svtypes/typedef_param.sv index ddbd471e0..d838dd828 100644 --- a/tests/svtypes/typedef_param.sv +++ b/tests/svtypes/typedef_param.sv @@ -6,12 +6,12 @@ module top;  	typedef logic [1:0] uint2_t;  	typedef logic signed [3:0] int4_t;  	typedef logic signed [7:0] int8_t; -	typedef (int8_t) char_t; +	typedef int8_t char_t; -	parameter (uint2_t) int2 = 2'b10; -	localparam (int4_t) int4 = -1; -	localparam (int8_t) int8 = int4; -	localparam (char_t) ch = int8; +	parameter uint2_t int2 = 2'b10; +	localparam int4_t int4 = -1; +	localparam int8_t int8 = int4; +	localparam char_t ch = int8;  	`STATIC_ASSERT(int2 == 2'b10); diff --git a/tests/svtypes/typedef_scopes.sv b/tests/svtypes/typedef_scopes.sv index 1c45c7057..d41a58147 100644 --- a/tests/svtypes/typedef_scopes.sv +++ b/tests/svtypes/typedef_scopes.sv @@ -4,30 +4,30 @@ typedef enum logic {s0, s1} outer_enum_t;  module top; -	(outer_uint4_t) u4_i = 8'hA5; -	(outer_enum_t) enum4_i = s0; +	outer_uint4_t u4_i = 8'hA5; +	outer_enum_t enum4_i = s0;  	always @(*) assert(u4_i == 4'h5);  	always @(*) assert(enum4_i == 1'b0);  	typedef logic [3:0] inner_type;  	typedef enum logic [2:0] {s2=2, s3, s4} inner_enum_t; -	(inner_type) inner_i1 = 8'h5A; -	(inner_enum_t) inner_enum1 = s3; +	inner_type inner_i1 = 8'h5A; +	inner_enum_t inner_enum1 = s3;  	always @(*) assert(inner_i1 == 4'hA);  	always @(*) assert(inner_enum1 == 3'h3);  	if (1) begin: genblock  		typedef logic [7:0] inner_type; -		parameter (inner_type) inner_const = 8'hA5; +		parameter inner_type inner_const = 8'hA5;   		typedef enum logic [2:0] {s5=5, s6, s7} inner_enum_t; -		(inner_type) inner_gb_i = inner_const; //8'hA5; - 		(inner_enum_t) inner_gb_enum1 = s7; +		inner_type inner_gb_i = inner_const; //8'hA5; + 		inner_enum_t inner_gb_enum1 = s7;  		always @(*) assert(inner_gb_i == 8'hA5);   		always @(*) assert(inner_gb_enum1 == 3'h7);  	end -	(inner_type) inner_i2 = 8'h42; -	(inner_enum_t) inner_enum2 = s4; +	inner_type inner_i2 = 8'h42; +	inner_enum_t inner_enum2 = s4;  	always @(*) assert(inner_i2 == 4'h2);  	always @(*) assert(inner_enum2 == 3'h4); diff --git a/tests/svtypes/typedef_simple.sv b/tests/svtypes/typedef_simple.sv index 7e760dee4..8f89910e5 100644 --- a/tests/svtypes/typedef_simple.sv +++ b/tests/svtypes/typedef_simple.sv @@ -3,12 +3,12 @@ module top;  	typedef logic [1:0] uint2_t;  	typedef logic signed [3:0] int4_t;  	typedef logic signed [7:0] int8_t; -	typedef (int8_t) char_t; +	typedef int8_t char_t; -	(* keep *) (uint2_t) int2 = 2'b10; -	(* keep *) (int4_t) int4 = -1; -	(* keep *) (int8_t) int8 = int4; -	(* keep *) (char_t) ch = int8; +	(* keep *) uint2_t int2 = 2'b10; +	(* keep *) int4_t int4 = -1; +	(* keep *) int8_t int8 = int4; +	(* keep *) char_t ch = int8;  	always @* assert(int2 == 2'b10); diff --git a/tests/various/bug1781.ys b/tests/various/bug1781.ys new file mode 100644 index 000000000..60dcc0830 --- /dev/null +++ b/tests/various/bug1781.ys @@ -0,0 +1,33 @@ +read_verilog <<EOT + +module top(input clk, input rst); + +reg [1:0] state; + +always @(posedge clk, posedge rst) begin +	if (rst) +		state <= 0; +	else +		case (state) +			2'b00: state <= 2'b01; +			2'b01: state <= 2'b10; +			2'b10: state <= 2'b00; +		endcase +end + +sub sub_i(.i(state == 0)); + +endmodule + + +(* blackbox, keep *) +module sub(input i); +endmodule + +EOT + +proc +fsm + +# Make sure there is a driver +select -assert-any t:sub %ci %a w:* %i %ci c:* %i diff --git a/tests/various/exec.ys b/tests/various/exec.ys new file mode 100644 index 000000000..0eec00719 --- /dev/null +++ b/tests/various/exec.ys @@ -0,0 +1,6 @@ +exec -expect-return 0 -- exit 0 +exec -expect-return 27 -- exit 27 +exec -expect-stdout nana -expect-stdout api -not-expect-stdout giraffe -- echo "bananapie" + +logger -expect error "stdout did have a line" 1 +exec -not-expect-stdout giraffe -- echo "giraffe" diff --git a/tests/various/ice40_mince_abc9.ys b/tests/various/ice40_mince_abc9.ys new file mode 100644 index 000000000..408e16f05 --- /dev/null +++ b/tests/various/ice40_mince_abc9.ys @@ -0,0 +1,17 @@ +read_verilog <<EOT + +module top(input clk, ce, input [2:0] a, b, output reg [2:0] q); + +	reg [2:0] aa, bb; + +	always @(posedge clk) begin +		if (ce) begin +			aa <= a; +		end +		bb <= b; +		q <= aa + bb; +	end +endmodule +EOT + +synth_ice40 -abc9 -dffe_min_ce_use 4 | 
