module top(input clk, stb, di, output do); localparam integer DIN_N = 256; localparam integer DOUT_N = 256; reg [DIN_N-1:0] din; wire [DOUT_N-1:0] dout; reg [DIN_N-1:0] din_shr; reg [DOUT_N-1:0] dout_shr; always @(posedge clk) begin din_shr <= {din_shr, di}; dout_shr <= {dout_shr, din_shr[DIN_N-1]}; if (stb) begin din <= din_shr; dout_shr <= dout; end end assign do = dout_shr[DOUT_N-1]; roi roi ( .clk(clk), .din(din), .dout(dout) ); endmodule (* KEEP_HIERARCHY *) module roi(input clk, input [255:0] din, output [255:0] dout); clb_a clb_a (.clk(clk), .din(din[ 0 +: 16]), .dout(dout[ 0 +: 16])); clb_b clb_b (.clk(clk), .din(din[ 16 +: 16]), .dout(dout[ 16 +: 16])); clb_c clb_c (.clk(clk), .din(din[ 32 +: 16]), .dout(dout[ 32 +: 16])); clb_d clb_d (.clk(clk), .din(din[ 48 +: 16]), .dout(dout[ 48 +: 16])); clb_e clb_e (.clk(clk), .din(din[ 64 +: 16]), .dout(dout[ 64 +: 16])); clb_f clb_f (.clk(clk), .din(din[ 80 +: 16]), .dout(dout[ 80 +: 16])); clb_g clb_g (.clk(clk), .din(din[ 96 +: 16]), .dout(dout[ 96 +: 16])); clb_h clb_h (.clk(clk), .din(din[112 +: 16]), .dout(dout[112 +: 16])); clb_i clb_i (.clk(clk), .din(din[128 +: 16]), .dout(dout[128 +: 16])); clb_j clb_j (.clk(clk), .din(din[144 +: 16]), .dout(dout[144 +: 16])); clb_k clb_k (.clk(clk), .din(din[160 +: 16]), .dout(dout[160 +: 16])); clb_l clb_l (.clk(clk), .din(din[176 +: 16]), .dout(dout[176 +: 16])); clb_m clb_m (.clk(clk), .din(din[192 +: 16]), .dout(dout[192 +: 16])); clb_n clb_n (.clk(clk), .din(din[208 +: 16]), .dout(dout[208 +: 16])); clb_o clb_o (.clk(clk), .din(din[224 +: 16]), .dout(dout[224 +: 16])); clb_p clb_p (.clk(clk), .din(din[240 +: 16]), .dout(dout[240 +: 16])); endmodule // --------------------------------------------------------------------- module clb_a (input clk, input [15:0] din, output [15:0] dout); (* LOC="SLICE_X16Y100", BEL="AFF", DONT_TOUCH *) FDRE ff ( .C(clk), .Q(dout[0]), .CE(din[0]), .R(din[1]), .D(din[2]) ); assign dout[15:1] = 0; endmodule module clb_b (input clk, input [15:0] din, output [15:0] dout); (* LOC="SLICE_X16Y101", BEL="AFF", DONT_TOUCH *) FDSE ff ( .C(clk), .Q(dout[0]), .CE(din[0]), .S(din[1]), .D(din[2]) ); assign dout[15:1] = 0; endmodule module clb_c (input clk, input [15:0] din, output [15:0] dout); (* LOC="SLICE_X16Y102", BEL="AFF", DONT_TOUCH *) FDCE ff ( .C(clk), .Q(dout[0]), .CE(din[0]), .CLR(din[1]), .D(din[2]) ); assign dout[15:1] = 0; endmodule module clb_d (input clk, input [15:0] din, output [15:0] dout); (* LOC="SLICE_X16Y103", BEL="AFF", DONT_TOUCH *) FDPE ff ( .C(clk), .Q(dout[0]), .CE(din[0]), .PRE(din[1]), .D(din[2]) ); assign dout[15:1] = 0; endmodule // --------------------------------------------------------------------- module clb_e (input clk, input [15:0] din, output [15:0] dout); wire tmp; (* LOC="SLICE_X16Y104", BEL="D6LUT", LOCK_PINS="I0:A1", DONT_TOUCH *) LUT1 #( .INIT(2'b01) ) lut ( .I0(din[2]), .O(tmp) ); (* LOC="SLICE_X16Y104", BEL="BFF", DONT_TOUCH *) FDRE ff ( .C(clk), .Q(dout[0]), .CE(din[0]), .R(din[1]), .D(tmp) ); assign dout[15:1] = 0; endmodule module clb_f (input clk, input [15:0] din, output [15:0] dout); wire tmp; (* LOC="SLICE_X16Y105", BEL="D5LUT", LOCK_PINS="I0:A1", DONT_TOUCH *) LUT1 #( .INIT(2'b01) ) lut ( .I0(din[2]), .O(tmp) ); (* LOC="SLICE_X16Y105", BEL="BFF", DONT_TOUCH *) FDRE ff ( .C(clk), .Q(dout[0]), .CE(din[0]), .R(din[1]), .D(tmp) ); assign dout[15:1] = 0; endmodule module clb_g (input clk, input [15:0] din, output [15:0] dout); wire a, b, c; (* LOC="SLICE_X16Y106", BEL="D6LUT", LOCK_PINS="I0:A1", DONT_TOUCH *) LUT1 #( .INIT(2'b01) ) lut ( .I0(din[2]), .O(a) ); (* LOC="SLICE_X16Y106", BEL="F7BMUX", DONT_TOUCH *) MUXF7 mux1 ( .I0(a), .I1(din[3]), .S(din[4]), .O(b) ); (* LOC="SLICE_X16Y106", BEL="F8MUX", DONT_TOUCH *) MUXF8 mux2 ( .I0(b), .I1(din[5]), .S(din[6]), .O(c) ); (* LOC="SLICE_X16Y106", BEL="BFF", DONT_TOUCH *) FDRE ff ( .C(clk), .Q(dout[0]), .CE(din[0]), .R(din[1]), .D(c) ); assign dout[15:1] = 0; endmodule module clb_h (input clk, input [15:0] din, output [15:0] dout); wire a, b, c; (* LOC="SLICE_X16Y107", BEL="D5LUT", LOCK_PINS="I0:A1", DONT_TOUCH *) LUT1 #( .INIT(2'b01) ) lut ( .I0(din[2]), .O(a) ); (* LOC="SLICE_X16Y107", BEL="F7BMUX", DONT_TOUCH *) MUXF7 mux1 ( .I0(a), .I1(din[3]), .S(din[4]), .O(b) ); (* LOC="SLICE_X16Y107", BEL="F8MUX", DONT_TOUCH *) MUXF8 mux2 ( .I0(b), .I1(din[5]), .S(din[6]), .O(c) ); (* LOC="SLICE_X16Y107", BEL="BFF", DONT_TOUCH *) FDRE ff ( .C(clk), .Q(dout[0]), .CE(din[0]), .R(din[1]), .D(c) ); assign dout[15:1] = 0; endmodule // --------------------------------------------------------------------- module clb_i (input clk, input [15:0] din, output [15:0] dout); assign dout = 0; endmodule module clb_j (input clk, input [15:0] din, output [15:0] dout); assign dout = 0; endmodule module clb_k (input clk, input [15:0] din, output [15:0] dout); assign dout = 0; endmodule module clb_l (input clk, input [15:0] din, output [15:0] dout); assign dout = 0; endmodule module clb_m (input clk, input [15:0] din, output [15:0] dout); assign dout = 0; endmodule module clb_n (input clk, input [15:0] din, output [15:0] dout); assign dout = 0; endmodule module clb_o (input clk, input [15:0] din, output [15:0] dout); assign dout = 0; endmodule module clb_p (input clk, input [15:0] din, output [15:0] dout); assign dout = 0; endmodule