quick.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

   

space.gif

   

space.gif

  ../../images/main/bullet_green_ball.gif Single Port RAM Asynch Read, Synch Write
   

space.gif


  1 -------------------------------------------------------
  2 -- Design Name : ram_sp_ar_sw
  3 -- File Name   : ram_sp_ar_sw.vhd
  4 -- Function    : Asynchronous 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_sp_ar_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 :in    std_logic_vector (ADDR_WIDTH-1 downto 0); -- address Input
 20         data    :inout std_logic_vector (DATA_WIDTH-1 downto 0); -- data bi-directional
 21         cs      :in    std_logic;                                -- Chip Select
 22         we      :in    std_logic;                                -- Write Enable/Read Enable
 23         oe      :in    std_logic                                 -- Output Enable
 24 
 25     );
 26 end entity;
 27 architecture rtl of ram_sp_ar_sw is
 28    ----------------Internal variables----------------
 29     constant RAM_DEPTH :integer := 2**ADDR_WIDTH;
 30 
 31     signal data_out :std_logic_vector (DATA_WIDTH-1 downto 0);
 32 
 33     type RAM is array (integer range <>)of std_logic_vector (DATA_WIDTH-1 downto 0);
 34     signal mem : RAM (0 to RAM_DEPTH-1);
 35 begin
 36    ----------------Code Starts Here------------------
 37    -- Tri-State Buffer control
 38    -- output : When we = 0, oe = 1, cs = 1
 39     data <= data_out when (cs = '1' and oe = '1' and we = '0') else (others=>'Z');
 40 
 41    -- Memory Write Block
 42    -- Write Operation : When we = 1, cs = 1
 43     MEM_WRITE:
 44     process (clk) begin
 45         if (rising_edge(clk)) then
 46             if (cs = '1' and we = '1') then
 47                 mem(conv_integer(address)) <= data;
 48             end if;
 49         end if;
 50     end process;
 51 
 52    -- Memory Read Block
 53    -- Read Operation : When we = 0, oe = 1, cs = 1
 54     MEM_READ:
 55     process (address, cs, we, oe, mem) begin
 56         if (cs = '1' and we = '0' and oe = '1') then
 57              data_out <= mem(conv_integer(address));
 58         end if;
 59     end process;
 60 
 61 end architecture;
You could download file vhdl_examples here
   

space.gif

   

space.gif

   

space.gif

   

space.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

  

Copyright © 1998-2025

Deepak Kumar Tala - All rights reserved

Do you have any Comment? mail me at:deepak@asic-world.com