2024-12-02 21:51:14 +01:00
|
|
|
library ieee;
|
|
|
|
use ieee.std_logic_1164.all;
|
|
|
|
use ieee.numeric_std.all;
|
|
|
|
|
|
|
|
----------------------DMA Controller Entity---------------------------
|
2024-12-16 23:26:48 +01:00
|
|
|
entity dma_controller is
|
2024-12-09 21:09:33 +01:00
|
|
|
generic (
|
2024-12-16 23:26:48 +01:00
|
|
|
RAM_WRITE_CMD : natural := 15; -- Writing to ram command from rocc
|
|
|
|
RAM_READ_CMD : natural := 127; -- Reading from ram command from rocc
|
|
|
|
DATA_SIZE : natural := 7; -- Define constant for vector size for data of 8 bits
|
|
|
|
ADDRESS_SIZE : natural := 6; -- Define constant for vector size for address 7 bits
|
|
|
|
ID_SIZE : natural := 4 -- Define constant for vector size for size of Id's 5 bits
|
2024-12-09 21:09:33 +01:00
|
|
|
);
|
2024-12-02 21:51:14 +01:00
|
|
|
port(
|
|
|
|
clk : in std_logic;
|
|
|
|
rst : in std_logic;
|
2024-12-16 23:26:48 +01:00
|
|
|
rx_packet_length_noc_to_dma : in std_logic_vector(ID_SIZE downto 0); --To DMA From Noc
|
|
|
|
receive_valid_to_dma_from_noc : in std_logic; --To DMA From Noc
|
|
|
|
sent_ack_to_dma_from_noc : in std_logic_vector(ID_SIZE downto 0);--------To DMA From Noc
|
|
|
|
funct_core_to_dma : in std_logic_vector(ADDRESS_SIZE downto 0); --To DMA From Core
|
|
|
|
address_core_to_dma : in std_logic_vector(ADDRESS_SIZE downto 0); --To DMA From Core
|
|
|
|
size_core_to_dma : in std_logic_vector(ID_SIZE downto 0); --To DMA From Core
|
|
|
|
address_bus_from_dma : out std_logic_vector(ADDRESS_SIZE downto 0); --From DMA To RAM
|
|
|
|
read_enable_from_dma : out std_logic; --From DMA To RAM
|
|
|
|
write_enable_from_dma : out std_logic; --From DMA To RAM
|
|
|
|
sent_valid_from_dma_to_noc : out std_logic; --From DMA To NoC
|
|
|
|
tx_packet_length_noc_from_dma : out std_logic_vector(ID_SIZE downto 0); --From DMA To NoC
|
|
|
|
data_trans_from_dma_to_core : out std_logic_vector(ID_SIZE downto 0) --From DMA To Core
|
2024-12-02 21:51:14 +01:00
|
|
|
);
|
|
|
|
end entity;
|
|
|
|
|
|
|
|
----------------------DMA Controller Behaviour------------------------
|
|
|
|
|
2024-12-16 23:26:48 +01:00
|
|
|
architecture dma_controller_arch of dma_controller is
|
|
|
|
Signal count_to_noc : std_logic_vector(ID_SIZE downto 0);
|
|
|
|
Signal address_to_ram : std_logic_vector(ADDRESS_SIZE downto 0);
|
2024-12-02 21:51:14 +01:00
|
|
|
begin
|
|
|
|
process(clk, rst)
|
|
|
|
begin
|
|
|
|
if rst = '0' then
|
2024-12-16 23:26:48 +01:00
|
|
|
sent_valid_from_dma_to_noc <= '0';
|
|
|
|
read_enable_from_dma <= '0';
|
|
|
|
write_enable_from_dma <= '0';
|
|
|
|
address_bus_from_dma <= (others => '0');
|
|
|
|
tx_packet_length_noc_from_dma <= (others => '0');
|
|
|
|
data_trans_from_dma_to_core <= (others => '0');
|
|
|
|
count_to_noc <= (others => '0');
|
|
|
|
address_to_ram <= (others => '0');
|
2024-12-02 21:51:14 +01:00
|
|
|
|
|
|
|
elsif rising_edge(clk) then
|
|
|
|
----------------------Writing to RAM from NOC------------------------
|
|
|
|
|
2024-12-23 14:03:57 +01:00
|
|
|
if funct_core_to_dma = std_logic_vector(to_unsigned(RAM_WRITE_CMD, DATA_SIZE)) then --- x"0f" 15 Its arbitarly choosen from RoCC_Interface
|
|
|
|
if unsigned(count_to_noc) < (unsigned(size_core_to_dma)) then
|
2024-12-16 23:26:48 +01:00
|
|
|
if count_to_noc = "00000" then ---count_from_noc but not working in the wave simulation
|
2024-12-23 14:03:57 +01:00
|
|
|
address_to_ram <= address_core_to_dma;
|
|
|
|
count_to_noc <= std_logic_vector(unsigned(count_to_noc) + 1);
|
2024-12-16 23:26:48 +01:00
|
|
|
elsif receive_valid_to_dma_from_noc = '1' then
|
|
|
|
address_bus_from_dma <= address_to_ram;
|
|
|
|
--report "write_enable_from_dma is 1 from Line 68";
|
2024-12-23 14:03:57 +01:00
|
|
|
write_enable_from_dma <= '1'; --Write Enable
|
2024-12-16 23:26:48 +01:00
|
|
|
read_enable_from_dma <= '0'; --'0'
|
|
|
|
data_trans_from_dma_to_core <= count_to_noc ;-- std_logic_vector(unsigned(count_to_noc) - 1)
|
|
|
|
address_to_ram <= std_logic_vector(unsigned(address_to_ram) + 1);
|
|
|
|
count_to_noc <= std_logic_vector(unsigned(count_to_noc) + 1);
|
2024-12-09 21:09:33 +01:00
|
|
|
else
|
2024-12-16 23:26:48 +01:00
|
|
|
----report "write_enable_from_dma is 0 from Line 75";
|
2024-12-23 14:03:57 +01:00
|
|
|
write_enable_from_dma <= '0'; --Write Enable
|
2024-12-16 23:26:48 +01:00
|
|
|
read_enable_from_dma <= '0'; --'0'
|
2024-12-02 21:51:14 +01:00
|
|
|
end if;
|
2024-12-09 21:09:33 +01:00
|
|
|
|
|
|
|
else
|
2024-12-16 23:26:48 +01:00
|
|
|
----report "write_enable_from_dma is 0 from Line 75";
|
2024-12-23 14:03:57 +01:00
|
|
|
write_enable_from_dma <= '0'; --Write Enable
|
2024-12-16 23:26:48 +01:00
|
|
|
read_enable_from_dma <= '0'; --'0'
|
2024-12-23 14:03:57 +01:00
|
|
|
count_to_noc <= (others => '0');
|
|
|
|
data_trans_from_dma_to_core <= (others => '0');
|
|
|
|
|
2024-12-02 21:51:14 +01:00
|
|
|
end if;
|
|
|
|
|
|
|
|
----------------------Reading from RAM to NOC------------------------
|
2024-12-16 23:26:48 +01:00
|
|
|
elsif funct_core_to_dma = std_logic_vector(to_unsigned(RAM_READ_CMD, DATA_SIZE)) then --- x"7f" 127 Its arbitarly choosen from RoCC_Interface
|
2024-12-23 14:03:57 +01:00
|
|
|
if unsigned(count_to_noc) < unsigned(size_core_to_dma) then
|
2024-12-16 23:26:48 +01:00
|
|
|
if count_to_noc = "00000" then
|
|
|
|
address_to_ram <= address_core_to_dma;
|
|
|
|
tx_packet_length_noc_from_dma <= size_core_to_dma; --giving the size to the header of the NoC flit
|
|
|
|
count_to_noc <= std_logic_vector(unsigned(count_to_noc) + 1);
|
2024-12-09 21:09:33 +01:00
|
|
|
else
|
2024-12-16 23:26:48 +01:00
|
|
|
address_bus_from_dma <= address_to_ram;
|
|
|
|
write_enable_from_dma <= '0';
|
|
|
|
read_enable_from_dma <= '1'; --Read Enable
|
2024-12-23 14:03:57 +01:00
|
|
|
data_trans_from_dma_to_core <= count_to_noc;--sent_ack_to_dma_from_noc;
|
2024-12-16 23:26:48 +01:00
|
|
|
address_to_ram <= std_logic_vector(unsigned(address_to_ram) + 1);
|
|
|
|
count_to_noc <= std_logic_vector(unsigned(count_to_noc) + 1);
|
|
|
|
sent_valid_from_dma_to_noc <= '1';
|
2024-12-02 21:51:14 +01:00
|
|
|
end if;
|
2024-12-16 23:26:48 +01:00
|
|
|
elsif unsigned(count_to_noc) < (unsigned(size_core_to_dma)+2) then
|
2024-12-23 14:03:57 +01:00
|
|
|
count_to_noc <= std_logic_vector(unsigned(count_to_noc) + 1);
|
|
|
|
sent_valid_from_dma_to_noc <= '1';
|
2024-12-09 21:09:33 +01:00
|
|
|
else
|
2024-12-23 14:03:57 +01:00
|
|
|
read_enable_from_dma <= '0';
|
|
|
|
write_enable_from_dma <= '0';
|
|
|
|
sent_valid_from_dma_to_noc <= '0';
|
|
|
|
count_to_noc <= (others => '0');
|
2024-12-02 21:51:14 +01:00
|
|
|
end if;
|
|
|
|
else
|
2024-12-16 23:26:48 +01:00
|
|
|
count_to_noc <= (others => '0');
|
|
|
|
read_enable_from_dma <= '0';
|
|
|
|
--report "write_enable_from_dma is 0 from Line 111";
|
|
|
|
write_enable_from_dma <= '0';
|
2024-12-23 14:03:57 +01:00
|
|
|
sent_valid_from_dma_to_noc <= '0';
|
|
|
|
data_trans_from_dma_to_core <= (others => '0');
|
2024-12-02 21:51:14 +01:00
|
|
|
end if;
|
|
|
|
end if;
|
|
|
|
end process;
|
|
|
|
end architecture;
|
|
|
|
|