chump0912 发表于 2014-4-18 08:35:41

把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的。我应该怎么改?

昵小筑 发表于 2014-4-18 09:36:31

这个得调用256个字节大小的rom,然后把数据保存到rom中,再根据地址调用就好了

chump0912 发表于 2014-4-18 10:01:43

昵小筑 发表于 2014-4-18 09:36
这个得调用256个字节大小的rom,然后把数据保存到rom中,再根据地址调用就好了

恩,这样,那我应该在原有的程序上怎么改?

昵小筑 发表于 2014-5-11 15:09:32

建立一个256个字节大小的rom,把相应的数值写进去。 再将ROM例化进模块里不行吗
页: [1]
查看完整版本: 把4*4矩阵rom改为16*16矩阵rom