2021-09-25 20:00:36 +02:00
|
|
|
module n64_sdram (
|
|
|
|
if_system sys,
|
|
|
|
if_n64_bus bus,
|
2022-02-02 19:07:43 +01:00
|
|
|
if_memory_dma.memory usb_dma,
|
2021-09-25 20:00:36 +02:00
|
|
|
if_sdram.memory sdram,
|
|
|
|
|
|
|
|
output sdram_cs,
|
|
|
|
output sdram_ras,
|
|
|
|
output sdram_cas,
|
|
|
|
output sdram_we,
|
|
|
|
output [1:0] sdram_ba,
|
|
|
|
output [12:0] sdram_a,
|
|
|
|
inout [15:0] sdram_dq
|
|
|
|
);
|
|
|
|
|
|
|
|
logic mem_request;
|
|
|
|
logic mem_ack;
|
|
|
|
logic mem_write;
|
|
|
|
logic [31:0] mem_address;
|
|
|
|
logic [15:0] mem_rdata;
|
|
|
|
logic [15:0] mem_wdata;
|
|
|
|
|
|
|
|
typedef enum bit [1:0] {
|
|
|
|
T_BUS,
|
2022-02-02 19:07:43 +01:00
|
|
|
T_SDRAM,
|
|
|
|
T_USB_DMA
|
2021-09-25 20:00:36 +02:00
|
|
|
} e_source_request;
|
|
|
|
|
|
|
|
e_source_request source_request;
|
|
|
|
|
|
|
|
always_ff @(posedge sys.clk) begin
|
|
|
|
if (sys.reset) begin
|
|
|
|
mem_request <= 1'b0;
|
|
|
|
end else begin
|
2022-02-02 19:07:43 +01:00
|
|
|
if (!mem_request && (bus.request || sdram.request || usb_dma.request)) begin
|
|
|
|
mem_request <= 1'b1;
|
|
|
|
if (bus.request) begin
|
|
|
|
mem_write <= bus.write;
|
|
|
|
mem_address <= bus.address;
|
|
|
|
mem_wdata <= bus.wdata;
|
|
|
|
source_request <= T_BUS;
|
|
|
|
end else if (sdram.request) begin
|
|
|
|
mem_write <= sdram.write;
|
|
|
|
mem_address <= sdram.address;
|
|
|
|
mem_wdata <= sdram.wdata;
|
|
|
|
source_request <= T_SDRAM;
|
|
|
|
end else if (usb_dma.request) begin
|
|
|
|
mem_write <= usb_dma.write;
|
|
|
|
mem_address <= usb_dma.address;
|
|
|
|
mem_wdata <= usb_dma.wdata;
|
|
|
|
source_request <= T_USB_DMA;
|
2021-09-25 20:00:36 +02:00
|
|
|
end
|
2022-02-02 19:07:43 +01:00
|
|
|
end
|
|
|
|
if (mem_ack) begin
|
|
|
|
mem_request <= 1'b0;
|
|
|
|
end
|
2021-09-25 20:00:36 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
always_comb begin
|
|
|
|
bus.ack = source_request == T_BUS && mem_ack;
|
|
|
|
bus.rdata = bus.ack ? mem_rdata : 16'd0;
|
|
|
|
|
|
|
|
sdram.ack = source_request == T_SDRAM && mem_ack;
|
|
|
|
sdram.rdata = mem_rdata;
|
2022-02-02 19:07:43 +01:00
|
|
|
|
|
|
|
usb_dma.ack = source_request == T_USB_DMA && mem_ack;
|
|
|
|
usb_dma.rdata = mem_rdata;
|
2021-09-25 20:00:36 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
memory_sdram memory_sdram_inst (
|
|
|
|
.sys(sys),
|
|
|
|
|
|
|
|
.request(mem_request),
|
|
|
|
.ack(mem_ack),
|
|
|
|
.write(mem_write),
|
|
|
|
.address(mem_address[25:0]),
|
|
|
|
.rdata(mem_rdata),
|
|
|
|
.wdata(mem_wdata),
|
|
|
|
|
|
|
|
.sdram_cs(sdram_cs),
|
|
|
|
.sdram_ras(sdram_ras),
|
|
|
|
.sdram_cas(sdram_cas),
|
|
|
|
.sdram_we(sdram_we),
|
|
|
|
.sdram_ba(sdram_ba),
|
|
|
|
.sdram_a(sdram_a),
|
|
|
|
.sdram_dq(sdram_dq)
|
|
|
|
);
|
|
|
|
|
|
|
|
endmodule
|