diff options
author | Matt Ettus <matt@ettus.com> | 2010-05-28 18:02:18 -0700 |
---|---|---|
committer | Matt Ettus <matt@ettus.com> | 2010-05-28 18:02:18 -0700 |
commit | d4791a6257d31503d4ce4895181a90b5d9972cfe (patch) | |
tree | d425f8c7ac13b99fdc5135091d66e6fe30fcaff1 /usrp2/control_lib/ram_harvard.v | |
parent | d488c6b2cc40221d395f053891c1c89c1305fae5 (diff) | |
parent | 1c8fc02f8787b8f809335d18a6691c2d7510be9a (diff) | |
download | uhd-d4791a6257d31503d4ce4895181a90b5d9972cfe.tar.gz uhd-d4791a6257d31503d4ce4895181a90b5d9972cfe.tar.bz2 uhd-d4791a6257d31503d4ce4895181a90b5d9972cfe.zip |
Merge branch 'master_nocache' into master_nocache_post_merge
Seems to work on raw ethernet version which was automatically merged
UDP version untested, and the following files were merged manually:
u2_core_udp.v
Makefile.udp
* master_nocache:
change the debug pins, which makes it more reliable. This is unnerving.
fixes from IJB from 5/24. Basically connect unconnected wires.
removes the icache and pipelines the reads
Diffstat (limited to 'usrp2/control_lib/ram_harvard.v')
-rw-r--r-- | usrp2/control_lib/ram_harvard.v | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/usrp2/control_lib/ram_harvard.v b/usrp2/control_lib/ram_harvard.v new file mode 100644 index 000000000..3c00f87c7 --- /dev/null +++ b/usrp2/control_lib/ram_harvard.v @@ -0,0 +1,73 @@ + + +// Dual ported, Harvard architecture, cached ram + +module ram_harvard + #(parameter AWIDTH=15, + parameter RAM_SIZE=16384, + parameter ICWIDTH=6, + parameter DCWIDTH=6) + + (input wb_clk_i, + input wb_rst_i, + // Firmware download port. + input [AWIDTH-1:0] ram_loader_adr_i, + input [31:0] ram_loader_dat_i, + input ram_loader_stb_i, + input [3:0] ram_loader_sel_i, + input ram_loader_we_i, + output ram_loader_ack_o, + input ram_loader_done_i, + // Instruction fetch port. + input [AWIDTH-1:0] if_adr, + output [31:0] if_data, + // Data access port. + input [AWIDTH-1:0] dwb_adr_i, + input [31:0] dwb_dat_i, + output [31:0] dwb_dat_o, + input dwb_we_i, + output dwb_ack_o, + input dwb_stb_i, + input [3:0] dwb_sel_i, + + input flush_icache ); + + reg ack_d1; + reg stb_d1; + + + assign ram_loader_ack_o = ram_loader_stb_i; + + dpram32 #(.AWIDTH(AWIDTH),.RAM_SIZE(RAM_SIZE)) + sys_ram + (.clk(wb_clk_i), + .adr1_i(ram_loader_done_i ? if_adr : ram_loader_adr_i), + .dat1_i(ram_loader_dat_i), + .dat1_o(if_data), + .we1_i(ram_loader_done_i ? 1'b0 : ram_loader_we_i), + .en1_i(ram_loader_done_i ? 1'b1 : ram_loader_stb_i), + .sel1_i(ram_loader_done_i ? 4'hF : ram_loader_sel_i), + .adr2_i(dwb_adr_i), + .dat2_i(dwb_dat_i), + .dat2_o(dwb_dat_o), + .we2_i(dwb_we_i), + .en2_i(dwb_stb_i), + .sel2_i(dwb_sel_i) + ); + + assign dwb_ack_o = dwb_stb_i & (dwb_we_i | (stb_d1 & ~ack_d1)); + + always @(posedge wb_clk_i) + if(wb_rst_i) + ack_d1 <= 1'b0; + else + ack_d1 <= dwb_ack_o; + + always @(posedge wb_clk_i) + if(wb_rst_i) + stb_d1 <= 0; + else + stb_d1 <= dwb_stb_i; + + +endmodule // ram_harv_cache |