2021-09-25 20:00:36 +02:00
|
|
|
interface if_n64_bus ();
|
|
|
|
|
|
|
|
localparam sc64::e_n64_id NUM_DEVICES = sc64::__ID_N64_END;
|
|
|
|
|
|
|
|
sc64::e_n64_id id;
|
|
|
|
logic request;
|
|
|
|
logic ack;
|
|
|
|
logic write;
|
|
|
|
logic [31:0] address;
|
|
|
|
logic [15:0] wdata;
|
|
|
|
logic [15:0] rdata;
|
2021-12-24 23:51:30 +01:00
|
|
|
logic [31:0] real_address;
|
|
|
|
logic read_op;
|
|
|
|
logic write_op;
|
2021-09-25 20:00:36 +02:00
|
|
|
|
|
|
|
logic device_ack [(NUM_DEVICES - 1):0];
|
|
|
|
logic [15:0] device_rdata [(NUM_DEVICES - 1):0];
|
|
|
|
|
|
|
|
always_comb begin
|
|
|
|
ack = 1'b0;
|
|
|
|
rdata = 16'd0;
|
|
|
|
|
|
|
|
for (integer i = 0; i < NUM_DEVICES; i++) begin
|
|
|
|
ack = ack | device_ack[i];
|
|
|
|
rdata = rdata | device_rdata[i];
|
|
|
|
end
|
2021-12-27 00:01:07 +01:00
|
|
|
|
|
|
|
if (id >= NUM_DEVICES) begin
|
|
|
|
ack = request;
|
|
|
|
end
|
2021-09-25 20:00:36 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
modport n64 (
|
|
|
|
output id,
|
|
|
|
output request,
|
|
|
|
input ack,
|
|
|
|
output write,
|
|
|
|
output address,
|
|
|
|
output wdata,
|
2021-12-24 23:51:30 +01:00
|
|
|
input rdata,
|
|
|
|
output real_address,
|
|
|
|
output read_op,
|
|
|
|
output write_op
|
2021-09-25 20:00:36 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
genvar n;
|
|
|
|
generate
|
|
|
|
for (n = 0; n < NUM_DEVICES; n++) begin : at
|
|
|
|
logic device_request;
|
|
|
|
|
|
|
|
always_comb begin
|
|
|
|
device_request = request && id == sc64::e_n64_id'(n);
|
|
|
|
end
|
|
|
|
|
|
|
|
modport device (
|
|
|
|
input .request(device_request),
|
|
|
|
output .ack(device_ack[n]),
|
|
|
|
input .write(write),
|
|
|
|
input .address(address),
|
|
|
|
input .wdata(wdata),
|
2021-12-24 23:51:30 +01:00
|
|
|
output .rdata(device_rdata[n]),
|
|
|
|
input .real_address(real_address),
|
|
|
|
input .read_op(read_op),
|
|
|
|
input .write_op(write_op)
|
2021-09-25 20:00:36 +02:00
|
|
|
);
|
|
|
|
end
|
|
|
|
endgenerate
|
|
|
|
|
|
|
|
endinterface
|