4

我正在尝试为 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

50x50 像素的编译报告

4

1 回答 1

5

首先,一些背景:

由于图像的大小,您可能会收到“未满足时序要求” - 50x50x8x3 是相当数量的存储位,如果它试图将它们存储到逻辑而不是片上 RAM 中。

一个 640x480 的图像是 900 kB,因此只有最大的 FPGA 才能存储它们,即使在片上 RAM 中也是如此——例如,最大的 Cyclone IV 只有 810 kB 的嵌入式存储器。如果您打算使用这种大小的图像,请考虑连接片外 RAM。

您在启动时看到的图像很可能是存储在 EPCS 中的图像 - 一个 2MB 到 16MB 的闪存,用于在启动时加载默认配置。它加载配置(就像通过 USB 编程一样)和任何片上存储器。如果您使用的是 Altera DE 系列板卡之一,则启动图像不会存储为 640x480 - 它由硬件放大到该分辨率。

另外,您提到的 15 分钟是指编译时间还是将 .sof 加载到芯片所需的时间?请注意,如果您指的是 HDL 编译,则并非不合理。Quartus 不仅需要编译您的 HDL,还需要确定它需要哪些逻辑元素、将它们放置在芯片上的什么位置以及如何连接它们。大型设计可能需要数小时或更长时间才能构建。

最后,至于您的问题,您可能还需要查看 .mif(内存初始化文件)和/或 .hex 文件以及片上/片外 RAM IP 内核,因为它们可能更适合您的需求。见:http: //quartushelp.altera.com/14.1/master.htm#mergedProjects/reference/glossary/def_mif.htm

于 2015-05-24T01:09:26.073 回答