⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sram.vhd

📁 free hardware ip core about sparcv8,a soc cpu in vhdl
💻 VHD
字号:
--------------------------------------------------------------------------------  This file is a part of the GRLIB VHDL IP LIBRARY--  Copyright (C) 2003, Gaisler Research----  This program is free software; you can redistribute it and/or modify--  it under the terms of the GNU General Public License as published by--  the Free Software Foundation; either version 2 of the License, or--  (at your option) any later version.----  This program is distributed in the hope that it will be useful,--  but WITHOUT ANY WARRANTY; without even the implied warranty of--  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the--  GNU General Public License for more details.----  You should have received a copy of the GNU General Public License--  along with this program; if not, write to the Free Software--  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA ------------------------------------------------------------------------------- Entity: 	sram-- File:	sram.vhd-- Author:	Jiri Gaisler Gaisler Research-- Description:	Simulation model of generic async SRAM-------------------------------------------------------------------------------- pragma translate_offlibrary ieee;use ieee.std_logic_1164.all;use std.textio.all;library gaisler;use gaisler.sim.all;library grlib;use grlib.stdlib.all;entity sram is  generic (    index : integer := 0;		-- Byte lane (0 - 3)    abits: Positive := 10;		-- Default 10 address bits (1 Kbyte)    tacc : integer := 10;		-- access time (ns)    fname : string := "ram.dat");	-- File to read from  port (      a : in std_logic_vector(abits-1 downto 0);    d : inout std_logic_vector(7 downto 0);    ce1 : in std_logic;    we : in std_ulogic;    oe : in std_ulogic);end;     architecture sim of sram is  subtype BYTE is std_logic_vector(7 downto 0);  type MEM is array(0 to ((2**Abits)-1)) of BYTE;  signal DINT,DI,DO : BYTE;  constant ahigh : integer := abits - 1;  signal wrpre : std_ulogic;  function Vpar(vec : std_logic_vector) return std_ulogic is  variable par : std_ulogic := '1';  begin    for i in vec'range loop	--'      par := par xor vec(i);    end loop;    return par;  end;begin  RAM : process(CE1,WE,DI,A,OE,D)  variable MEMA : MEM;  variable L1 : line;  variable FIRST : boolean := true;  variable ADR : std_logic_vector(19 downto 0);  variable BUF : std_logic_vector(31 downto 0);  variable CH : character;  variable ai : integer := 0;  file TCF : text open read_mode is fname;  variable rectype : std_logic_vector(3 downto 0);  variable recaddr : std_logic_vector(31 downto 0);  variable reclen  : std_logic_vector(7 downto 0);  variable recdata : std_logic_vector(0 to 16*8-1);  begin    if FIRST then      L1:= new string'("");	--'      while not endfile(TCF) loop        readline(TCF,L1);        if (L1'length /= 0) then	--'          while (not (L1'length=0)) and (L1(L1'left) = ' ') loop            std.textio.read(L1,CH);          end loop;          if L1'length > 0 then	--'            read(L1, ch);            if (ch = 'S') or (ch = 's') then              hexread(L1, rectype);              hexread(L1, reclen);	      recaddr := (others => '0');	      case rectype is 		when "0001" =>                  hexread(L1, recaddr(15 downto 0));		when "0010" =>                  hexread(L1, recaddr(23 downto 0));		when "0011" =>                  hexread(L1, recaddr);		  recaddr(31 downto 24) := (others => '0');		when others => next;	      end case;              hexread(L1, recdata);              if index = 6 then	        ai := conv_integer(recaddr); 	        for i in 0 to 15 loop                  MEMA(ai+i) := recdata((i*8) to (i*8+7));	        end loop;              elsif (index = 4) or (index = 5) then	        ai := conv_integer(recaddr)/2; 	        for i in 0 to 7 loop                  MEMA(ai+i) := recdata((i*16+(index-4)*8) to (i*16+(index-4)*8+7));	        end loop;              else 	        ai := conv_integer(recaddr)/4; 	        for i in 0 to 3 loop                  MEMA(ai+i) := recdata((i*32+index*8) to (i*32+index*8+7));	        end loop;              end if;            end if;          end if;        end if;      end loop;      FIRST := false;    else      if (TO_X01(not CE1) = '1') then        if not is_x(a) then ai := conv_integer(A(abits-1 downto 0)); else ai := 0; end if;        dint <= mema(ai);      end if;      if (TO_X01(CE1 or WE) = '1') then        if wrpre = '1' then          mema(ai) := to_x01(std_logic_vector(DI));        end if;      end if;    end if;    wrpre <= TO_X01((not CE1) and (not WE));    DI <= D;  end process;   BUFS : process(CE1,WE,DINT,OE)  variable DRIVEB : std_logic;  begin    DRIVEB := TO_X01((not CE1) and (not OE) and WE);    case DRIVEB is      when '1' => D <= DINT after tacc * 1 ns;      when '0' => D <= "ZZZZZZZZ" after 8 ns;      when others => D <= "XXXXXXXX";    end case;  end process;end sim;-- pragma translate_on

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -