DMA_for_RoCC/DMA_CONTROLLER.vhd

130 lines
8.2 KiB
VHDL
Raw 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
-- constant DATA_SIZE : integer := 7; -- Define constant for vector size for data of 8 bits
-- constant ADDRESS_SIZE : integer := 6; -- Define constant for vector size for address 7 bits
-- constant ID_SIZE : integer := 4; -- Define constant for vector size for size of Id's 5 bits
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_from_noc : std_logic_vector(ID_SIZE downto 0);
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_from_noc <= (others => '0');
count_to_noc <= (others => '0');
address_to_ram <= (others => '0');
elsif rising_edge(clk) then
----------------------Writing to RAM from NOC------------------------
2024-12-16 23:26:48 +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 --+10 will reproduce same valid signal comparing rx_packet_length_noc_to_dma = size_core_to_dma
if count_to_noc = "00000" then ---count_from_noc but not working in the wave simulation
address_to_ram <= address_core_to_dma;
count_to_noc <= std_logic_vector(unsigned(count_to_noc) + 1);
--write_enable_from_dma <= '1'; --Write Enable
2024-12-09 21:09:33 +01:00
--end if;
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";
write_enable_from_dma <= '1'; --Write Enable ----<<<<Why the value is not updateded>>>>
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";
write_enable_from_dma <= '0'; --Write Enable ----<<<<Why the value is not updateded>>>>
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";
write_enable_from_dma <= '0'; --Write Enable ----<<<<Why the value is not updateded>>>>
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
-- count_from_noc <= (others => '0');
-- read_enable_from_dma <= '0';
-- write_enable_from_dma <= 'Z';--'0';
-- sent_valid_from_dma_to_noc <= '0';
2024-12-09 21:09:33 +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
if unsigned(count_to_noc) < unsigned(size_core_to_dma) then --sent_ack_to_dma_from_noc could be used instead of the count to Noc
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);
---sent_valid_from_dma_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
data_trans_from_dma_to_core <= sent_ack_to_dma_from_noc;
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
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-16 23:26:48 +01:00
read_enable_from_dma <= '0';
write_enable_from_dma <= '0';
sent_valid_from_dma_to_noc <= '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';
sent_valid_from_dma_to_noc <= '0';
end if;
end if;
end process;
end architecture;