把4*4矩阵rom改为16*16矩阵rom
我用VHDL编辑一个4*4的矩阵交织器。这只是其中一个模块,要求是能储存一个16*16的矩阵。
ibrary ieee;
use ieee.std_logic_1164.all;
entity rom is
generic(n:integer:=16);
port(addr: in integer range 0 to n-1;
clk: in std_logic;
data: out std_logic_vector(7 downto 0));
end rom;
architecture rtl of ROM is
subtype rom_word is std_logic_vector(7 downto 0);
type rom_table is array(0 to 15) of rom_word;
constant rom: rom_table:=rom_table'(
rom_word'("00000000"),
rom_word'("00000100"),
rom_word'("00001000"),
rom_word'("00001100"),
rom_word'("00000001"),
rom_word'("00000101"),
rom_word'("00001001"),
rom_word'("00001101"),
rom_word'("00000010"),
rom_word'("00001010"),
rom_word'("00001110"),
rom_word'("00000110"),
rom_word'("00000011"),
rom_word'("00000111"),
rom_word'("00001011"),
rom_word'("00001111"));
begin process(clk)
begin
if clk'event and clk='1' then
data<=rom(addr);
end if;
end process;
end rtl;
现在我想把这矩阵改为16*16的。我应该怎么改? 这个得调用256个字节大小的rom,然后把数据保存到rom中,再根据地址调用就好了 昵小筑 发表于 2014-4-18 09:36
这个得调用256个字节大小的rom,然后把数据保存到rom中,再根据地址调用就好了
恩,这样,那我应该在原有的程序上怎么改? 建立一个256个字节大小的rom,把相应的数值写进去。 再将ROM例化进模块里不行吗
页:
[1]