URL
https://opencores.org/ocsvn/amber/amber/trunk
Subversion Repositories amber
[/] [amber/] [trunk/] [hw/] [vlog/] [lib/] [generic_sram_line_en.v] - Rev 2
Compare with Previous | Blame | View Log
////////////////////////////////////////////////////////////////// // // // Generic Library SRAM with single write enable // // // // This file is part of the Amber project // // http://www.opencores.org/project,amber // // // // Description // // Configurable depth and width. // // // // Author(s): // // - Conor Santifort, csantifort.amber@gmail.com // // // ////////////////////////////////////////////////////////////////// // // // Copyright (C) 2010 Authors and OPENCORES.ORG // // // // This source file may be used and distributed without // // restriction provided that this copyright statement is not // // removed from the file and that any derivative work contains // // the original copyright notice and the associated disclaimer. // // // // This source file is free software; you can redistribute it // // and/or modify it under the terms of the GNU Lesser General // // Public License as published by the Free Software Foundation; // // either version 2.1 of the License, or (at your option) any // // later version. // // // // This source is distributed in the hope that it will be // // useful, but WITHOUT ANY WARRANTY; without even the implied // // warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR // // PURPOSE. See the GNU Lesser General Public License for more // // details. // // // // You should have received a copy of the GNU Lesser General // // Public License along with this source; if not, download it // // from http://www.opencores.org/lgpl.shtml // // // ////////////////////////////////////////////////////////////////// module generic_sram_line_en #( parameter DATA_WIDTH = 128, parameter ADDRESS_WIDTH = 7, parameter INITIALIZE_TO_ZERO = 0 ) ( input i_clk, input [DATA_WIDTH-1:0] i_write_data, input i_write_enable, input [ADDRESS_WIDTH-1:0] i_address, output reg [DATA_WIDTH-1:0] o_read_data ); reg [DATA_WIDTH-1:0] mem [0:2**ADDRESS_WIDTH-1]; generate if ( INITIALIZE_TO_ZERO ) begin : init0 integer i; initial begin for (i=0;i<2**ADDRESS_WIDTH;i=i+1) mem[i] <= 'd0; end end endgenerate always @(posedge i_clk) begin // read o_read_data <= i_write_enable ? {DATA_WIDTH{1'd0}} : mem[i_address]; // write if (i_write_enable) mem[i_address] <= i_write_data; end endmodule