diff options
| author | Zachary Snow <zach@zachjs.com> | 2021-10-19 18:46:26 -0600 | 
|---|---|---|
| committer | Zachary Snow <zachary.j.snow@gmail.com> | 2021-10-25 18:25:50 -0700 | 
| commit | e833c6a418103feb30f0cc3e5c482da00ee9f820 (patch) | |
| tree | ef7d028ed17200f04558f3d2426f3db7ef6134cd /tests | |
| parent | bd16d01c0eed5c96a241e6ee9e56b8f7890319a1 (diff) | |
| download | yosys-e833c6a418103feb30f0cc3e5c482da00ee9f820.tar.gz yosys-e833c6a418103feb30f0cc3e5c482da00ee9f820.tar.bz2 yosys-e833c6a418103feb30f0cc3e5c482da00ee9f820.zip | |
verilog: use derived module info to elaborate cell connections
- Attempt to lookup a derived module if it potentially contains a port
  connection with elaboration ambiguities
- Mark the cell if module has not yet been derived
- This can be extended to implement automatic hierarchical port
  connections in a future change
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/simple/memwr_port_connection.sv | 13 | ||||
| -rw-r--r-- | tests/simple/signed_full_slice.v | 29 | ||||
| -rw-r--r-- | tests/verilog/unbased_unsized_tern.sv | 31 | ||||
| -rw-r--r-- | tests/verilog/unbased_unsized_tern.ys | 6 | 
4 files changed, 79 insertions, 0 deletions
| diff --git a/tests/simple/memwr_port_connection.sv b/tests/simple/memwr_port_connection.sv new file mode 100644 index 000000000..5bf414e08 --- /dev/null +++ b/tests/simple/memwr_port_connection.sv @@ -0,0 +1,13 @@ +module producer( +    output logic [3:0] out +); +    assign out = 4'hA; +endmodule + +module top( +    output logic [3:0] out +); +    logic [3:0] v[0:0]; +    producer p(v[0]); +    assign out = v[0]; +endmodule diff --git a/tests/simple/signed_full_slice.v b/tests/simple/signed_full_slice.v new file mode 100644 index 000000000..f8a331578 --- /dev/null +++ b/tests/simple/signed_full_slice.v @@ -0,0 +1,29 @@ +module pass_through_a( +    input wire [31:0] inp, +    output wire [31:0] out +); +    assign out[31:0] = inp[31:0]; +endmodule + +module top_a( +    input wire signed [31:0] inp, +    output wire signed [31:0] out +); +    pass_through_a pt(inp[31:0], out[31:0]); +endmodule + +// tests both module declaration orderings + +module top_b( +    input wire signed [31:0] inp, +    output wire signed [31:0] out +); +    pass_through_b pt(inp[31:0], out[31:0]); +endmodule + +module pass_through_b( +    input wire [31:0] inp, +    output wire [31:0] out +); +    assign out[31:0] = inp[31:0]; +endmodule diff --git a/tests/verilog/unbased_unsized_tern.sv b/tests/verilog/unbased_unsized_tern.sv new file mode 100644 index 000000000..ad8493394 --- /dev/null +++ b/tests/verilog/unbased_unsized_tern.sv @@ -0,0 +1,31 @@ +module pass_through #( +	parameter WIDTH = 1 +) ( +	input logic [WIDTH-1:0] inp, +	output logic [WIDTH-1:0] out +); +	assign out = inp; +endmodule + +module gate ( +	input logic inp, +	output logic [63:0] +		out1, out2, out3, out4 +); +	pass_through #(40) pt1('1, out1); +	pass_through #(40) pt2(inp ? '1 : '0, out2); +	pass_through #(40) pt3(inp ? '1 : 2'b10, out3); +	pass_through #(40) pt4(inp ? '1 : inp, out4); +endmodule + +module gold ( +	input logic inp, +	output logic [63:0] +		out1, out2, out3, out4 +); +	localparam ONES = 40'hFF_FFFF_FFFF; +	pass_through #(40) pt1(ONES, out1); +	pass_through #(40) pt2(inp ? ONES : 0, out2); +	pass_through #(40) pt3(inp ? ONES : 2'sb10, out3); +	pass_through #(40) pt4(inp ? ONES : inp, out4); +endmodule diff --git a/tests/verilog/unbased_unsized_tern.ys b/tests/verilog/unbased_unsized_tern.ys new file mode 100644 index 000000000..5ef63c559 --- /dev/null +++ b/tests/verilog/unbased_unsized_tern.ys @@ -0,0 +1,6 @@ +read_verilog -sv unbased_unsized_tern.sv +hierarchy +proc +equiv_make gold gate equiv +equiv_simple +equiv_status -assert | 
