我正在尝试为 FPGA 编程编译一个 verilog 代码,我将在其中实现一个 VGA 应用程序。我使用 QuartusII 和 Altera。我正在尝试正确使用 readmemh 逐像素获取图片。
目前,我已经使用 matlab 将图片转换为 rgb 文本。每个都具有以下格式,仅此而已(示例):03 A0 15 B7 ...
目前我没有收到任何语法错误,但是我必须定义三个寄存器,每个寄存器都有 50x50 = 2500 位,而且编译速度很慢,并且我收到“不满足时序要求”警告。
当我想使用具有更好分辨率的文件时(640x480 会很棒,但似乎是禁区),情况要糟糕得多。获得 200x200 像素图像需要 15 分钟,.sof 文件大约 6MB。
没有办法将 readmemh 用于大输入吗?
这就是我所做的阅读
...
reg [7:0] mem_R[0:2499];
reg [7:0] mem_G[0:2499];
reg [7:0] mem_B[0:2499];
initial begin
...
$readmemh("menuR.txt", mem_R);
$readmemh("menuG.txt", mem_G);
$readmemh("menuB.txt", mem_B);
end
我按如下方式访问它
if( mem_R[total_current-127510] > 0)
begin
menu_red = 1;
end