mirror of
https://github.com/MiSTer-devel/CDi_MiSTer.git
synced 2026-06-14 03:04:32 +00:00
Replaced memory arrays of video decoder with dual port RAM for FPGA usage Added planar YCbCr frame player to display decoded frames Added DDR3 interface for frame player and pixel worker Added DDR3 interface mux for multiple masters MCD212: Added EV bit usage to replace backdrop with external video Shows Dragon's Lair intro with artefacts on MiSTer because the worker currently cannot read from DDR3 For some reason, the EV bit is not working correctly
87 lines
1.7 KiB
Systemverilog
87 lines
1.7 KiB
Systemverilog
`ifndef BUS_SVH
|
|
`define BUS_SVH
|
|
|
|
interface bus68k (
|
|
input clk
|
|
);
|
|
bit write_strobe;
|
|
bit as;
|
|
bit lds;
|
|
bit uds;
|
|
bit [15:0] data_out;
|
|
bit [23:1] addr;
|
|
bit bus_ack;
|
|
bit [15:0] data_in;
|
|
|
|
modport master(output write_strobe, as, lds, uds, data_out, addr, input bus_ack, data_in);
|
|
modport slave(input write_strobe, as, lds, uds, data_out, addr, output bus_ack, data_in);
|
|
|
|
endinterface
|
|
|
|
|
|
interface pixelstream (
|
|
input clk
|
|
);
|
|
|
|
bit write;
|
|
bit strobe;
|
|
bit [7:0] pixel;
|
|
|
|
modport source(output write, pixel, input strobe);
|
|
modport sink(input write, pixel, output strobe);
|
|
endinterface
|
|
|
|
interface bytestream ();
|
|
bit write;
|
|
bit [7:0] data;
|
|
|
|
modport source(output write, data);
|
|
modport sink(input write, data);
|
|
endinterface
|
|
|
|
interface parallelel_spi ();
|
|
bit [7:0] miso;
|
|
bit [7:0] mosi;
|
|
bit write;
|
|
|
|
modport master(output mosi, write, input miso);
|
|
modport slave(input mosi, write, output miso);
|
|
endinterface
|
|
|
|
|
|
interface audiostream ();
|
|
bit write;
|
|
bit strobe;
|
|
bit signed [15:0] sample;
|
|
|
|
modport source(output write, sample, input strobe);
|
|
modport sink(input write, sample, output strobe);
|
|
endinterface
|
|
|
|
|
|
interface ddr_if;
|
|
bit acquire;
|
|
|
|
bit [28:0] addr;
|
|
bit [63:0] wdata;
|
|
bit [63:0] rdata;
|
|
bit read;
|
|
bit write;
|
|
bit [ 7:0] burstcnt;
|
|
bit [ 7:0] byteenable;
|
|
bit busy;
|
|
bit rdata_ready;
|
|
|
|
modport to_host(
|
|
output addr, wdata, read, write, burstcnt, byteenable, acquire,
|
|
input rdata, busy, rdata_ready
|
|
);
|
|
|
|
modport from_host(
|
|
output rdata, busy, rdata_ready,
|
|
input addr, wdata, read, write, burstcnt, byteenable, acquire
|
|
);
|
|
endinterface
|
|
|
|
`endif
|