|
|
|
|
|
|
|
|
|
|
|
|
Dual Port RAM Synchronous Read/Write
|
|
|
|
|
|
1 -------------------------------------------------------
2 -- Design Name : ram_dp_sr_sw
3 -- File Name : ram_dp_sr_sw.vhd
4 -- Function : Synchronous read write RAM
5 -- Coder : Deepak Kumar Tala (Verilog)
6 -- Translator : Alexander H Pham (VHDL)
7 -------------------------------------------------------
8 library ieee;
9 use ieee.std_logic_1164.all;
10 use ieee.std_logic_unsigned.all;
11
12 entity ram_dp_sr_sw is
13 generic (
14 DATA_WIDTH :integer := 8;
15 ADDR_WIDTH :integer := 8
16 );
17 port (
18 clk :in std_logic; -- Clock Input
19 address_0 :in std_logic_vector (ADDR_WIDTH-1 downto 0); -- address_0 Input
20 data_0 :inout std_logic_vector (DATA_WIDTH-1 downto 0); -- data_0 bi-directional
21 cs_0 :in std_logic; -- Chip Select
22 we_0 :in std_logic; -- Write Enable/Read Enable
23 oe_0 :in std_logic; -- Output Enable
24 address_1 :in std_logic_vector (ADDR_WIDTH-1 downto 0); -- address_1 Input
25 data_1 :inout std_logic_vector (DATA_WIDTH-1 downto 0); -- data_1 bi-directional
26 cs_1 :in std_logic; -- Chip Select
27 we_1 :in std_logic; -- Write Enable/Read Enable
28 oe_1 :in std_logic -- Output Enable
29 );
30 end entity;
31 architecture rtl of ram_dp_sr_sw is
32 ----------------Internal variables----------------
33 constant RAM_DEPTH :integer := 2**ADDR_WIDTH;
34
35 signal data_0_out :std_logic_vector (DATA_WIDTH-1 downto 0);
36 signal data_1_out :std_logic_vector (DATA_WIDTH-1 downto 0);
37
38 type RAM is array (integer range <>)of std_logic_vector (DATA_WIDTH-1 downto 0);
39 signal mem : RAM (0 to RAM_DEPTH-1);
40
41 begin
42 ----------------Code Starts Here------------------
43 -- Memory Write Block
44 -- Write Operation : When we_0 = 1, cs_0 = 1
45 MEM_WRITE:
46 process (clk) begin
47 if (rising_edge(clk)) then
48 if ( cs_0 = '1' and we_0 = '1') then
49 mem(conv_integer(address_0)) <= data_0;
50 elsif (cs_1 = '1' and we_1 = '1') then
51 mem(conv_integer(address_1)) <= data_1;
52 end if;
53 end if;
54 end process;
55
56 -- Tri-State Buffer control
57 data_0 <= data_0_out when (cs_0 = '1' and oe_0 = '1' and we_0 = '0') else (others=>'Z');
58
59 -- Memory Read Block
60 MEM_READ_0:
61 process (clk) begin
62 if (rising_edge(clk)) then
63 if (cs_0 = '1' and we_0 = '0' and oe_0 = '1') then
64 data_0_out <= mem(conv_integer(address_0));
65 else
66 data_0_out <= (others=>'0');
67 end if;
68 end if;
69 end process;
70
71 --Second Port of RAM
72 -- Tri-State Buffer control
73 -- output : When we_0 = 0, oe_0 = 1, cs_0 = 1
74 data_1 <= data_1_out when (cs_1 = '1' and oe_1 = '1' and we_1 = '0') else (others=>'Z');
75
76 -- Memory Read Block 1
77 MEM_READ_1:
78 process (clk) begin
79 if (rising_edge(clk)) then
80 if (cs_1 = '1' and we_1 = '0' and oe_1 = '1') then
81 data_1_out <= mem(conv_integer(address_1));
82 else
83 data_1_out <= (others=>'0');
84 end if;
85 end if;
86 end process;
87
88 end architecture;
You could download file vhdl_examples here
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Copyright © 1998-2025 |
Deepak Kumar Tala - All rights reserved |
Do you have any Comment? mail me at:deepak@asic-world.com
|
|