module tag_array_ext( input RW0_clk, input [5:0] RW0_addr, input RW0_en, input RW0_wmode, input [15:0] RW0_wmask, input [351:0] RW0_wdata, output [351:0] RW0_rdata ); reg reg_RW0_ren; reg [5:0] reg_RW0_addr; reg [351:0] ram [63:0]; `ifdef RANDOMIZE_MEM_INIT integer initvar; initial begin #`RANDOMIZE_DELAY begin end for (initvar = 0; initvar < 64; initvar = initvar+1) ram[initvar] = {11 {$random}}; reg_RW0_addr = {1 {$random}}; end `endif integer i; always @(posedge RW0_clk) reg_RW0_ren <= RW0_en && !RW0_wmode; always @(posedge RW0_clk) if (RW0_en && !RW0_wmode) reg_RW0_addr <= RW0_addr; always @(posedge RW0_clk) if (RW0_en && RW0_wmode) begin if (RW0_wmask[0]) ram[RW0_addr][21:0] <= RW0_wdata[21:0]; if (RW0_wmask[1]) ram[RW0_addr][43:22] <= RW0_wdata[43:22]; if (RW0_wmask[2]) ram[RW0_addr][65:44] <= RW0_wdata[65:44]; if (RW0_wmask[3]) ram[RW0_addr][87:66] <= RW0_wdata[87:66]; if (RW0_wmask[4]) ram[RW0_addr][109:88] <= RW0_wdata[109:88]; if (RW0_wmask[5]) ram[RW0_addr][131:110] <= RW0_wdata[131:110]; if (RW0_wmask[6]) ram[RW0_addr][153:132] <= RW0_wdata[153:132]; if (RW0_wmask[7]) ram[RW0_addr][175:154] <= RW0_wdata[175:154]; if (RW0_wmask[8]) ram[RW0_addr][197:176] <= RW0_wdata[197:176]; if (RW0_wmask[9]) ram[RW0_addr][219:198] <= RW0_wdata[219:198]; if (RW0_wmask[10]) ram[RW0_addr][241:220] <= RW0_wdata[241:220]; if (RW0_wmask[11]) ram[RW0_addr][263:242] <= RW0_wdata[263:242]; if (RW0_wmask[12]) ram[RW0_addr][285:264] <= RW0_wdata[285:264]; if (RW0_wmask[13]) ram[RW0_addr][307:286] <= RW0_wdata[307:286]; if (RW0_wmask[14]) ram[RW0_addr][329:308] <= RW0_wdata[329:308]; if (RW0_wmask[15]) ram[RW0_addr][351:330] <= RW0_wdata[351:330]; end `ifdef RANDOMIZE_GARBAGE_ASSIGN reg [351:0] RW0_random; `ifdef RANDOMIZE_MEM_INIT initial begin #`RANDOMIZE_DELAY begin end RW0_random = {$random, $random, $random, $random, $random, $random, $random, $random, $random, $random, $random}; reg_RW0_ren = RW0_random[0]; end `endif always @(posedge RW0_clk) RW0_random <= {$random, $random, $random, $random, $random, $random, $random, $random, $random, $random, $random}; assign RW0_rdata = reg_RW0_ren ? ram[reg_RW0_addr] : RW0_random[351:0]; `else assign RW0_rdata = ram[reg_RW0_addr]; `endif endmodule module array_0_0_ext( input W0_clk, input [8:0] W0_addr, input W0_en, input [63:0] W0_data, input [0:0] W0_mask, input R0_clk, input [8:0] R0_addr, input R0_en, output [63:0] R0_data ); reg reg_R0_ren; reg [8:0] reg_R0_addr; reg [63:0] ram [511:0]; `ifdef RANDOMIZE_MEM_INIT integer initvar; initial begin #`RANDOMIZE_DELAY begin end for (initvar = 0; initvar < 512; initvar = initvar+1) ram[initvar] = {2 {$random}}; reg_R0_addr = {1 {$random}}; end `endif integer i; always @(posedge R0_clk) reg_R0_ren <= R0_en; always @(posedge R0_clk) if (R0_en) reg_R0_addr <= R0_addr; always @(posedge W0_clk) if (W0_en) begin if (W0_mask[0]) ram[W0_addr][63:0] <= W0_data[63:0]; end `ifdef RANDOMIZE_GARBAGE_ASSIGN reg [63:0] R0_random; `ifdef RANDOMIZE_MEM_INIT initial begin #`RANDOMIZE_DELAY begin end R0_random = {$random, $random}; reg_R0_ren = R0_random[0]; end `endif always @(posedge R0_clk) R0_random <= {$random, $random}; assign R0_data = reg_R0_ren ? ram[reg_R0_addr] : R0_random[63:0]; `else assign R0_data = ram[reg_R0_addr]; `endif endmodule module tag_array_0_ext( input RW0_clk, input [5:0] RW0_addr, input RW0_en, input RW0_wmode, input [15:0] RW0_wmask, input [335:0] RW0_wdata, output [335:0] RW0_rdata ); reg reg_RW0_ren; reg [5:0] reg_RW0_addr; reg [335:0] ram [63:0]; `ifdef RANDOMIZE_MEM_INIT integer initvar; initial begin #`RANDOMIZE_DELAY begin end for (initvar = 0; initvar < 64; initvar = initvar+1) ram[initvar] = {11 {$random}}; reg_RW0_addr = {1 {$random}}; end `endif integer i; always @(posedge RW0_clk) reg_RW0_ren <= RW0_en && !RW0_wmode; always @(posedge RW0_clk) if (RW0_en && !RW0_wmode) reg_RW0_addr <= RW0_addr; always @(posedge RW0_clk) if (RW0_en && RW0_wmode) begin if (RW0_wmask[0]) ram[RW0_addr][20:0] <= RW0_wdata[20:0]; if (RW0_wmask[1]) ram[RW0_addr][41:21] <= RW0_wdata[41:21]; if (RW0_wmask[2]) ram[RW0_addr][62:42] <= RW0_wdata[62:42]; if (RW0_wmask[3]) ram[RW0_addr][83:63] <= RW0_wdata[83:63]; if (RW0_wmask[4]) ram[RW0_addr][104:84] <= RW0_wdata[104:84]; if (RW0_wmask[5]) ram[RW0_addr][125:105] <= RW0_wdata[125:105]; if (RW0_wmask[6]) ram[RW0_addr][146:126] <= RW0_wdata[146:126]; if (RW0_wmask[7]) ram[RW0_addr][167:147] <= RW0_wdata[167:147]; if (RW0_wmask[8]) ram[RW0_addr][188:168] <= RW0_wdata[188:168]; if (RW0_wmask[9]) ram[RW0_addr][209:189] <= RW0_wdata[209:189]; if (RW0_wmask[10]) ram[RW0_addr][230:210] <= RW0_wdata[230:210]; if (RW0_wmask[11]) ram[RW0_addr][251:231] <= RW0_wdata[251:231]; if (RW0_wmask[12]) ram[RW0_addr][272:252] <= RW0_wdata[272:252]; if (RW0_wmask[13]) ram[RW0_addr][293:273] <= RW0_wdata[293:273]; if (RW0_wmask[14]) ram[RW0_addr][314:294] <= RW0_wdata[314:294]; if (RW0_wmask[15]) ram[RW0_addr][335:315] <= RW0_wdata[335:315]; end `ifdef RANDOMIZE_GARBAGE_ASSIGN reg [351:0] RW0_random; `ifdef RANDOMIZE_MEM_INIT initial begin #`RANDOMIZE_DELAY begin end RW0_random = {$random, $random, $random, $random, $random, $random, $random, $random, $random, $random, $random}; reg_RW0_ren = RW0_random[0]; end `endif always @(posedge RW0_clk) RW0_random <= {$random, $random, $random, $random, $random, $random, $random, $random, $random, $random, $random}; assign RW0_rdata = reg_RW0_ren ? ram[reg_RW0_addr] : RW0_random[335:0]; `else assign RW0_rdata = ram[reg_RW0_addr]; `endif endmodule module data_arrays_0_ext( input RW0_clk, input [8:0] RW0_addr, input RW0_en, input RW0_wmode, input [15:0] RW0_wmask, input [511:0] RW0_wdata, output [511:0] RW0_rdata ); reg reg_RW0_ren; reg [8:0] reg_RW0_addr; reg [511:0] ram [511:0]; `ifdef RANDOMIZE_MEM_INIT integer initvar; initial begin #`RANDOMIZE_DELAY begin end for (initvar = 0; initvar < 512; initvar = initvar+1) ram[initvar] = {16 {$random}}; reg_RW0_addr = {1 {$random}}; end `endif integer i; always @(posedge RW0_clk) reg_RW0_ren <= RW0_en && !RW0_wmode; always @(posedge RW0_clk) if (RW0_en && !RW0_wmode) reg_RW0_addr <= RW0_addr; always @(posedge RW0_clk) if (RW0_en && RW0_wmode) begin if (RW0_wmask[0]) ram[RW0_addr][31:0] <= RW0_wdata[31:0]; if (RW0_wmask[1]) ram[RW0_addr][63:32] <= RW0_wdata[63:32]; if (RW0_wmask[2]) ram[RW0_addr][95:64] <= RW0_wdata[95:64]; if (RW0_wmask[3]) ram[RW0_addr][127:96] <= RW0_wdata[127:96]; if (RW0_wmask[4]) ram[RW0_addr][159:128] <= RW0_wdata[159:128]; if (RW0_wmask[5]) ram[RW0_addr][191:160] <= RW0_wdata[191:160]; if (RW0_wmask[6]) ram[RW0_addr][223:192] <= RW0_wdata[223:192]; if (RW0_wmask[7]) ram[RW0_addr][255:224] <= RW0_wdata[255:224]; if (RW0_wmask[8]) ram[RW0_addr][287:256] <= RW0_wdata[287:256]; if (RW0_wmask[9]) ram[RW0_addr][319:288] <= RW0_wdata[319:288]; if (RW0_wmask[10]) ram[RW0_addr][351:320] <= RW0_wdata[351:320]; if (RW0_wmask[11]) ram[RW0_addr][383:352] <= RW0_wdata[383:352]; if (RW0_wmask[12]) ram[RW0_addr][415:384] <= RW0_wdata[415:384]; if (RW0_wmask[13]) ram[RW0_addr][447:416] <= RW0_wdata[447:416]; if (RW0_wmask[14]) ram[RW0_addr][479:448] <= RW0_wdata[479:448]; if (RW0_wmask[15]) ram[RW0_addr][511:480] <= RW0_wdata[511:480]; end `ifdef RANDOMIZE_GARBAGE_ASSIGN reg [511:0] RW0_random; `ifdef RANDOMIZE_MEM_INIT initial begin #`RANDOMIZE_DELAY begin end RW0_random = {$random, $random, $random, $random, $random, $random, $random, $random, $random, $random, $random, $random, $random, $random, $random, $random}; reg_RW0_ren = RW0_random[0]; end `endif always @(posedge RW0_clk) RW0_random <= {$random, $random, $random, $random, $random, $random, $random, $random, $random, $random, $random, $random, $random, $random, $random, $random}; assign RW0_rdata = reg_RW0_ren ? ram[reg_RW0_addr] : RW0_random[511:0]; `else assign RW0_rdata = ram[reg_RW0_addr]; `endif endmodule module mem_ext( input W0_clk, input [26:0] W0_addr, input W0_en, input [63:0] W0_data, input [7:0] W0_mask, input R0_clk, input [26:0] R0_addr, input R0_en, output [63:0] R0_data ); reg reg_R0_ren; reg [26:0] reg_R0_addr; reg [63:0] ram [134217727:0]; `ifdef RANDOMIZE_MEM_INIT integer initvar; initial begin #`RANDOMIZE_DELAY begin end for (initvar = 0; initvar < 134217728; initvar = initvar+1) ram[initvar] = {2 {$random}}; reg_R0_addr = {1 {$random}}; end `endif integer i; always @(posedge R0_clk) reg_R0_ren <= R0_en; always @(posedge R0_clk) if (R0_en) reg_R0_addr <= R0_addr; always @(posedge W0_clk) if (W0_en) begin if (W0_mask[0]) ram[W0_addr][7:0] <= W0_data[7:0]; if (W0_mask[1]) ram[W0_addr][15:8] <= W0_data[15:8]; if (W0_mask[2]) ram[W0_addr][23:16] <= W0_data[23:16]; if (W0_mask[3]) ram[W0_addr][31:24] <= W0_data[31:24]; if (W0_mask[4]) ram[W0_addr][39:32] <= W0_data[39:32]; if (W0_mask[5]) ram[W0_addr][47:40] <= W0_data[47:40]; if (W0_mask[6]) ram[W0_addr][55:48] <= W0_data[55:48]; if (W0_mask[7]) ram[W0_addr][63:56] <= W0_data[63:56]; end `ifdef RANDOMIZE_GARBAGE_ASSIGN reg [63:0] R0_random; `ifdef RANDOMIZE_MEM_INIT initial begin #`RANDOMIZE_DELAY begin end R0_random = {$random, $random}; reg_R0_ren = R0_random[0]; end `endif always @(posedge R0_clk) R0_random <= {$random, $random}; assign R0_data = reg_R0_ren ? ram[reg_R0_addr] : R0_random[63:0]; `else assign R0_data = ram[reg_R0_addr]; `endif endmodule module mem_0_ext( input W0_clk, input [8:0] W0_addr, input W0_en, input [63:0] W0_data, input [7:0] W0_mask, input R0_clk, input [8:0] R0_addr, input R0_en, output [63:0] R0_data ); reg reg_R0_ren; reg [8:0] reg_R0_addr; reg [63:0] ram [511:0]; `ifdef RANDOMIZE_MEM_INIT integer initvar; initial begin #`RANDOMIZE_DELAY begin end for (initvar = 0; initvar < 512; initvar = initvar+1) ram[initvar] = {2 {$random}}; reg_R0_addr = {1 {$random}}; end `endif integer i; always @(posedge R0_clk) reg_R0_ren <= R0_en; always @(posedge R0_clk) if (R0_en) reg_R0_addr <= R0_addr; always @(posedge W0_clk) if (W0_en) begin if (W0_mask[0]) ram[W0_addr][7:0] <= W0_data[7:0]; if (W0_mask[1]) ram[W0_addr][15:8] <= W0_data[15:8]; if (W0_mask[2]) ram[W0_addr][23:16] <= W0_data[23:16]; if (W0_mask[3]) ram[W0_addr][31:24] <= W0_data[31:24]; if (W0_mask[4]) ram[W0_addr][39:32] <= W0_data[39:32]; if (W0_mask[5]) ram[W0_addr][47:40] <= W0_data[47:40]; if (W0_mask[6]) ram[W0_addr][55:48] <= W0_data[55:48]; if (W0_mask[7]) ram[W0_addr][63:56] <= W0_data[63:56]; end `ifdef RANDOMIZE_GARBAGE_ASSIGN reg [63:0] R0_random; `ifdef RANDOMIZE_MEM_INIT initial begin #`RANDOMIZE_DELAY begin end R0_random = {$random, $random}; reg_R0_ren = R0_random[0]; end `endif always @(posedge R0_clk) R0_random <= {$random, $random}; assign R0_data = reg_R0_ren ? ram[reg_R0_addr] : R0_random[63:0]; `else assign R0_data = ram[reg_R0_addr]; `endif endmodule