diff options
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/arch/xilinx/dsp_fastfir.ys | 69 | ||||
| -rw-r--r-- | tests/opt/bug1525.ys | 13 | ||||
| -rw-r--r-- | tests/simple_abc9/abc9.v | 9 | 
3 files changed, 82 insertions, 9 deletions
| diff --git a/tests/arch/xilinx/dsp_fastfir.ys b/tests/arch/xilinx/dsp_fastfir.ys new file mode 100644 index 000000000..0067a822b --- /dev/null +++ b/tests/arch/xilinx/dsp_fastfir.ys @@ -0,0 +1,69 @@ +read_verilog <<EOT +// Citation https://github.com/ZipCPU/dspfilters/blob/master/rtl/fastfir.v +module fastfir_dynamictaps(i_clk, i_reset, i_tap_wr, i_tap, i_ce, i_sample, o_result); +  wire [30:0] _00_; +  wire [23:0] _01_; +  wire [11:0] _02_; +  wire [30:0] _03_; +  wire [23:0] _04_; +  wire [30:0] _05_; +  wire [23:0] _06_; +  wire [30:0] _07_; +  wire [23:0] _08_; +  wire [11:0] _09_; +  wire [30:0] _10_; +  wire [23:0] _11_; +  wire [30:0] _12_; +  wire [23:0] _13_; +  wire [11:0] \fir.FILTER[0].tapk.delayed_sample ; +  reg [30:0] \fir.FILTER[0].tapk.o_acc  = 31'h00000000; +  wire [11:0] \fir.FILTER[0].tapk.o_sample ; +  reg [23:0] \fir.FILTER[0].tapk.product ; +  reg [11:0] \fir.FILTER[0].tapk.tap  = 12'h000; +  wire [11:0] \fir.FILTER[1].tapk.delayed_sample ; +  wire [30:0] \fir.FILTER[1].tapk.o_acc ; +  wire [11:0] \fir.FILTER[1].tapk.o_sample ; +  reg [23:0] \fir.FILTER[1].tapk.product ; +  reg [11:0] \fir.FILTER[1].tapk.tap  = 12'h000; +  input i_ce; +  input i_clk; +  input i_reset; +  input [11:0] i_sample; +  input [11:0] i_tap; +  input i_tap_wr; +  output [30:0] o_result; +  reg [30:0] o_result; +  assign _03_ = 31'h00000000 + { \fir.FILTER[0].tapk.product [23], \fir.FILTER[0].tapk.product [23], \fir.FILTER[0].tapk.product [23], \fir.FILTER[0].tapk.product [23], \fir.FILTER[0].tapk.product [23], \fir.FILTER[0].tapk.product [23], \fir.FILTER[0].tapk.product [23], \fir.FILTER[0].tapk.product  }; +  assign _04_ = $signed(\fir.FILTER[0].tapk.tap ) * $signed(i_sample); +  always @(posedge i_clk) +      \fir.FILTER[0].tapk.tap  <= _02_; +  always @(posedge i_clk) +      \fir.FILTER[0].tapk.o_acc  <= _00_; +  always @(posedge i_clk) +      \fir.FILTER[0].tapk.product  <= _01_; +  assign _02_ = i_tap_wr ? i_tap : \fir.FILTER[0].tapk.tap ; +  assign _05_ = i_ce ? _03_ : \fir.FILTER[0].tapk.o_acc ; +  assign _00_ = i_reset ? 31'h00000000 : _05_; +  assign _06_ = i_ce ? _04_ : \fir.FILTER[0].tapk.product ; +  assign _01_ = i_reset ? 24'h000000 : _06_; +  assign _10_ = \fir.FILTER[0].tapk.o_acc  + { \fir.FILTER[1].tapk.product [23], \fir.FILTER[1].tapk.product [23], \fir.FILTER[1].tapk.product [23], \fir.FILTER[1].tapk.product [23], \fir.FILTER[1].tapk.product [23], \fir.FILTER[1].tapk.product [23], \fir.FILTER[1].tapk.product [23], \fir.FILTER[1].tapk.product  }; +  assign _11_ = $signed(\fir.FILTER[1].tapk.tap ) * $signed(i_sample); +  always @(posedge i_clk) +      \fir.FILTER[1].tapk.tap  <= _09_; +  always @(posedge i_clk) +      o_result <= _07_; +  always @(posedge i_clk) +      \fir.FILTER[1].tapk.product  <= _08_; +  assign _09_ = i_tap_wr ? \fir.FILTER[0].tapk.tap  : \fir.FILTER[1].tapk.tap ; +  assign _12_ = i_ce ? _10_ : o_result; +  assign _07_ = i_reset ? 31'h00000000 : _12_; +  assign _13_ = i_ce ? _11_ : \fir.FILTER[1].tapk.product ; +  assign _08_ = i_reset ? 24'h000000 : _13_; +  assign \fir.FILTER[1].tapk.o_acc  = o_result; +endmodule +EOT + +synth_xilinx +cd fastfir_dynamictaps +select -assert-count 2 t:DSP48E1 +select -assert-none t:* t:DSP48E1 %d t:BUFG %d diff --git a/tests/opt/bug1525.ys b/tests/opt/bug1525.ys new file mode 100644 index 000000000..972bc0ac7 --- /dev/null +++ b/tests/opt/bug1525.ys @@ -0,0 +1,13 @@ +read_verilog << EOF +module top(...); +input A1, A2, B, S; +output O; + +assign O = S ? (A1 & B) : (A2 & B); + +endmodule +EOF + +simplemap +opt_share +dump diff --git a/tests/simple_abc9/abc9.v b/tests/simple_abc9/abc9.v index 64b625efe..4d5879e6f 100644 --- a/tests/simple_abc9/abc9.v +++ b/tests/simple_abc9/abc9.v @@ -218,12 +218,6 @@ module MUXF8(input I0, I1, S, output O);  endmodule  // Citation: https://github.com/alexforencich/verilog-ethernet -// TODO: yosys -p "synth_xilinx -abc9 -top abc9_test022" abc9.v -q -// returns before b4321a31 -//   Warning: Wire abc9_test022.\m_eth_payload_axis_tkeep [7] is used but has no -//   driver. -//   Warning: Wire abc9_test022.\m_eth_payload_axis_tkeep [3] is used but has no -//   driver.  module abc9_test022  (      input  wire        clk, @@ -237,9 +231,6 @@ module abc9_test022  endmodule  // Citation: https://github.com/riscv/riscv-bitmanip -// TODO: yosys -p "synth_xilinx -abc9 -top abc9_test023" abc9.v -q -// returns before 14233843 -//   Warning: Wire abc9_test023.\dout [1] is used but has no driver.  module abc9_test023 #(  	parameter integer N = 2,  	parameter integer M = 2 | 
