]> Joshua Wise's Git repositories - firearm.git/blob - BlockRAM.v
Memory: Split out bus address and data control logic. Split out LDM/STM register...
[firearm.git] / BlockRAM.v
1 module BlockRAM(
2         input clk,
3         input [31:0] bus_addr,
4         output wire [31:0] bus_rdata,
5         input [31:0] bus_wdata,
6         input bus_rd,
7         input bus_wr,
8         output wire bus_ready
9         );
10         
11         /* This module is mapped in physical memory from 0x00000000 to
12          * 0x00004000.  rdata and ready must be driven to zero if the
13          * address is not within the range of this module.
14          */
15         wire decode = bus_addr[31:14] == 18'b0;
16         wire [13:0] ramaddr = {bus_addr[13:2], 2'b0};   /* mask off lower two bits
17                                                          * for word alignment */
18
19         reg [31:0] data [(16384 / 4 - 1):0];
20         
21         reg [31:0] temprdata = 0;
22         reg [13:0] lastread = 14'h3FFF;
23         assign bus_rdata = (bus_rd && decode) ? temprdata : 32'h0;
24         
25         assign bus_ready = decode &&
26                 (bus_wr || (bus_rd && (lastread == ramaddr)));
27         
28         initial
29                 $readmemh("ram.hex", data);
30         
31         always @(posedge clk)
32         begin
33                 if (bus_wr && decode)
34                         data[ramaddr[13:2]] <= bus_wdata;
35                 
36                 /* This is not allowed to be conditional -- stupid Xilinx
37                  * blockram. */
38                 temprdata <= (bus_wr && decode) ? bus_wdata : data[ramaddr[13:2]];
39                 lastread <= ramaddr;
40         end
41 endmodule
This page took 0.030874 seconds and 4 git commands to generate.