mirror of
https://github.com/antonblanchard/microwatt.git
synced 2026-05-02 06:36:01 +00:00
This adds a simple bus that can be mastered from an external system via JTAG, which will be used to hookup various debug modules. It's loosely based on the RiscV model (hence the DMI name). The module currently only supports hooking up to a Xilinx BSCANE2 but it shouldn't be too hard to adapt it to support different TAPs if necessary. The JTAG protocol proper is not exactly the RiscV one at this point, though I might still change it. This comes with some sim variants of Xilinx BSCANE2 and BUFG and a test bench. Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
31 lines
751 B
VHDL
31 lines
751 B
VHDL
-- Dummy/empty DMI interface to make toplevel happy on unsupported FPGAs
|
|
|
|
library ieee;
|
|
use ieee.std_logic_1164.all;
|
|
|
|
library work;
|
|
use work.wishbone_types.all;
|
|
|
|
entity dmi_dtm is
|
|
generic(ABITS : INTEGER:=8;
|
|
DBITS : INTEGER:=32);
|
|
|
|
port(sys_clk : in std_ulogic;
|
|
sys_reset : in std_ulogic;
|
|
dmi_addr : out std_ulogic_vector(ABITS - 1 downto 0);
|
|
dmi_din : in std_ulogic_vector(DBITS - 1 downto 0);
|
|
dmi_dout : out std_ulogic_vector(DBITS - 1 downto 0);
|
|
dmi_req : out std_ulogic;
|
|
dmi_wr : out std_ulogic;
|
|
dmi_ack : in std_ulogic
|
|
);
|
|
end entity dmi_dtm;
|
|
|
|
architecture behaviour of dmi_dtm is
|
|
dmi_addr <= (others => '0');
|
|
dmi_dout <= (others => '0');
|
|
dmi_req <= '0';
|
|
dmi_wr <= '0';
|
|
end architecture behaviour;
|
|
|