URL
https://opencores.org/ocsvn/bluespec-h264/bluespec-h264/trunk
Subversion Repositories bluespec-h264
[/] [bluespec-h264/] [trunk/] [src_fpga/] [mkSRAMMemController.bsv] - Rev 3
Go to most recent revision | Compare with Previous | Blame | View Log
package mkSRAMMemController;
import MemControllerTypes::*;
import IMemClient::*;
import IMemClientBackend::*;
import IMemController::*;
import IMemScheduler::*;
import mkMemClient::*;
import SRAM::*;
import BlueSRAM::*;
import BlueBRAM::*;
import FIFOF::*;
import FIFO::*;
import Vector::*;
import ISRAMWires::*;
`define FIFO_SIZE 4
interface ISRAMMemController#(type client_number, type address_type, type data_type);
interface Vector#(client_number, IMemClient#(address_type, data_type)) client_interfaces;
interface ISRAMWires wires;
endinterface
module mkSRAMMemController#(IMemScheduler#(client_number, address_type) scheduler) (ISRAMMemController#(client_number, address_type, data_type))
provisos
(Bits#(address_type, addr_p),
Bits#(data_type, data_p),
Add#(addr_p, xxx, 18),
Add#(data_p, yyy, 32),
Bitwise#(address_type),
Bitwise#(data_type),
Bits#(MemReq#(address_type, data_type), mem_req_p),
Literal#(address_type),
Literal#(data_type),
Eq#(data_type),
Bounded#(address_type)
);
BlueSRAM#(address_type, data_type) sram <- mkBlueSRAM_Full();
BlueBRAM#(address_type, data_type) bram <- mkBlueBRAM_Full();
Vector#(client_number, IMemClientBackend#(address_type, data_type)) client_backends = newVector();
Vector#(client_number, IMemClient#(address_type, data_type)) mem_clients = newVector();
FIFO#(Bit#((TAdd#(1,TLog#(client_number))))) client_tags_fifo <- mkSizedFIFO(`FIFO_SIZE);
for (Integer i = 0; i < valueof(client_number); i = i+1)
begin
client_backends[i] <- mkMemClient(i);
mem_clients[i] = client_backends[i].client_interface;
end
rule send_request;
Vector#(client_number, MemReqType#(address_type)) req_vec = newVector();
//make a vector of the appropriate data
for(int index = 0; index < fromInteger(valueof(client_number)); index = index + 1)
begin
if(client_backends[index].request_fifo.notEmpty())
begin
req_vec[index] = case(client_backends[index].request_fifo.first()) matches
tagged StoreReq .sreq: return MemReqType{ prio: client_backends[index].get_priority(),
req: tagged StoreReq sreq.addr};
tagged LoadReq .lreq : return MemReqType{ prio: client_backends[index].get_priority(),
req: tagged LoadReq lreq.addr};
endcase;
end
else
begin
req_vec[index] = MemReqType{ prio:client_backends[index].get_priority(), req: tagged Nop};
end
end
Maybe#(Bit#(TAdd#(1, TLog#(client_number)))) scheduling_result <- scheduler.choose_client(req_vec);
// Throw request to SRAM
if(scheduling_result matches tagged Valid .v)
begin
case (client_backends[v].request_fifo.first()) matches
tagged StoreReq .sreq:
begin
$display("SRAMMemController: Write request, addr: %x data: %x, from client %d", sreq.addr, sreq.data, v);
bram.write(sreq.addr, sreq.data);
end
tagged LoadReq .lreq:
begin
bram.read_req(lreq.addr);
client_tags_fifo.enq(v);
$display("SRAMMemController: Read request, addr: %x , from client %d", lreq.addr, v);
end
endcase
client_backends[v].request_fifo.deq();
end
endrule
// read response and shove it into the appropriate buffer.
rule read_sram_response;
Bit#((TAdd#(1, TLog#(client_number)))) target_client = client_tags_fifo.first();
data_type read_result <- bram.read_resp();
client_backends[target_client].enqueue_response(read_result);
client_tags_fifo.deq();
$display("SRAMMemController: Read response, data: %x , to client %d", read_result, target_client);
endrule
interface client_interfaces = mem_clients;
interface ISRAMWires wires;
method Bit#(18) address_out();
return sram.address_out();
endmethod
method Bit#(32) data_O();
return sram.data_out();
endmethod
method Action data_I(Bit#(32) data);
sram.data_in(data);
endmethod
method Bit#(1) data_T();
return sram.data_tri();
endmethod
method Bit#(4) we_bytes_out();
return sram.we_bytes_out();
endmethod
method Bit#(1) we_out();
return sram.we_out();
endmethod
method Bit#(1) ce_out();
return sram.ce_out();
endmethod
method Bit#(1) oe_out();
return sram.oe_out();
endmethod
method Bit#(1) cen_out();
return sram.cen_out();
endmethod
method Bit#(1) adv_ld_out();
return sram.adv_ld_out();
endmethod
endinterface
endmodule
endpackage
Go to most recent revision | Compare with Previous | Blame | View Log