|  | 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 | 
|  |  | 
|  | module roi(input clk, input [255:0] din, output [255:0] dout); | 
|  | clb_NCY0_MX # (.LOC("SLICE_X20Y100"), .BEL("A6LUT"), .N(0)) | 
|  | am (.clk(clk), .din(din[  0 +: 8]), .dout(dout[0 +: 8])); | 
|  | clb_NCY0_O5 # (.LOC("SLICE_X20Y101"), .BEL("A6LUT"), .N(0)) | 
|  | a5 (.clk(clk), .din(din[  8 +: 8]), .dout(dout[8 +: 8])); | 
|  |  | 
|  | clb_NCY0_MX # (.LOC("SLICE_X20Y102"), .BEL("B6LUT"), .N(1)) | 
|  | bm (.clk(clk), .din(din[  16 +: 8]), .dout(dout[16 +: 8])); | 
|  | clb_NCY0_O5 # (.LOC("SLICE_X20Y103"), .BEL("B6LUT"), .N(1)) | 
|  | b5 (.clk(clk), .din(din[  24 +: 8]), .dout(dout[24 +: 8])); | 
|  |  | 
|  | clb_NCY0_MX # (.LOC("SLICE_X20Y104"), .BEL("C6LUT"), .N(2)) | 
|  | cm (.clk(clk), .din(din[  32 +: 8]), .dout(dout[32 +: 8])); | 
|  | clb_NCY0_O5 # (.LOC("SLICE_X20Y105"), .BEL("C6LUT"), .N(2)) | 
|  | c5 (.clk(clk), .din(din[  40 +: 8]), .dout(dout[40 +: 8])); | 
|  |  | 
|  | clb_NCY0_MX # (.LOC("SLICE_X20Y106"), .BEL("D6LUT"), .N(3)) | 
|  | dm (.clk(clk), .din(din[  48 +: 8]), .dout(dout[48 +: 8])); | 
|  | clb_NCY0_O5 # (.LOC("SLICE_X20Y107"), .BEL("D6LUT"), .N(3)) | 
|  | d5 (.clk(clk), .din(din[  56 +: 8]), .dout(dout[56 +: 8])); | 
|  | endmodule | 
|  |  | 
|  | module clb_NCY0_MX (input clk, input [7:0] din, output [7:0] dout); | 
|  | parameter LOC="SLICE_X16Y129_FIXME"; | 
|  | parameter BEL="A6LUT_FIXME"; | 
|  | parameter N=-1; | 
|  |  | 
|  | wire [3:0] o; | 
|  | assign dout[0] = o[1]; | 
|  | wire o6, o5; | 
|  | reg [3:0] s; | 
|  |  | 
|  | always @(*) begin | 
|  | s = din[7:4]; | 
|  | s[N] = o6; | 
|  | end | 
|  |  | 
|  | (* LOC=LOC, BEL=BEL, KEEP, DONT_TOUCH *) | 
|  | LUT6_2 #( | 
|  | .INIT(64'h8000_0000_0000_0001) | 
|  | ) lut ( | 
|  | .I0(din[0]), | 
|  | .I1(din[1]), | 
|  | .I2(din[2]), | 
|  | .I3(din[3]), | 
|  | .I4(din[4]), | 
|  | .I5(din[5]), | 
|  | .O5(o5), | 
|  | .O6(o6)); | 
|  |  | 
|  | (* LOC=LOC, KEEP, DONT_TOUCH *) | 
|  | CARRY4 carry4(.O(o), .CO(), .DI(din[3:0]), .S(s), .CYINIT(1'b0), .CI()); | 
|  | endmodule | 
|  |  | 
|  | module clb_NCY0_O5 (input clk, input [7:0] din, output [7:0] dout); | 
|  | parameter LOC="SLICE_X16Y129_FIXME"; | 
|  | parameter BEL="A6LUT_FIXME"; | 
|  | parameter N=-1; | 
|  |  | 
|  | wire [3:0] o; | 
|  | assign dout[0] = o[1]; | 
|  | wire o6, o5; | 
|  | reg [3:0] s; | 
|  | reg [3:0] di; | 
|  |  | 
|  | always @(*) begin | 
|  | s = din[7:4]; | 
|  | s[N] = o6; | 
|  |  | 
|  | di = {din[3:0]}; | 
|  | di[N] = o5; | 
|  | end | 
|  |  | 
|  | (* LOC=LOC, BEL=BEL, KEEP, DONT_TOUCH *) | 
|  | LUT6_2 #( | 
|  | .INIT(64'h8000_0000_0000_0001) | 
|  | ) lut ( | 
|  | .I0(din[0]), | 
|  | .I1(din[1]), | 
|  | .I2(din[2]), | 
|  | .I3(din[3]), | 
|  | .I4(din[4]), | 
|  | .I5(din[5]), | 
|  | .O5(o5), | 
|  | .O6(o6)); | 
|  |  | 
|  | (* LOC=LOC, KEEP, DONT_TOUCH *) | 
|  | CARRY4 carry4(.O(o), .CO(), .DI(di), .S(s), .CYINIT(1'b0), .CI()); | 
|  | endmodule | 
|  |  |