DMA_for_RoCC/DMA_CONTROLLER.vhd

118 lines
7.3 KiB
VHDL
Raw Permalink Normal View History

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
);
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
);
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);
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');
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'
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');
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';
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');
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');
end if;
end if;
end process;
end architecture;