共2条
1/1 1 跳转至页
FPGA节省资源设计的一个例子(vhdl)

fpga的结构化特点导致近似的设计会产生交大差别的MAPING(综合之后)之结果,
因此,设计时应充分学习FPGA之结构,才可以充分利用资源。
现举例如下:
设计方法1:
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
entity counter is
port (
inti : in std_logic;
clock : in std_logic;
reset : in std_logic;
bout : out std_logic_vector(4 downto 0));
end counter;
architecture behavior of counter is
signal counter : std_logic_vector(4 downto 0);
begin
counter_machine:process(clock)
begin
if clock'event and clock='1' then
if inti='0' then
counter<="00001";
*****************
elsif reset='1' then
if counter=19 then
counter<=(others=>'0');
else
counter<=counter+1;
end if;
else
counter<=(others=>'0');
end if;
end if;
end process;
bout<=counter;
end behavior;
设计方法2
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
entity counter is
port (
inti : in std_logic;
clock : in std_logic;
reset : in std_logic;
bout : out std_logic_vector(4 downto 0));
end counter;
architecture behavior of counter is
signal counter : std_logic_vector(4 downto 0);
begin
counter_machine:process(clock)
begin
if clock'event and clock='1' then
if inti='0' then
counter<="00000";
*****************
elsif reset='1' then
if counter=19 then
counter<=(others=>'0');
else
counter<=counter+1;
end if;
else
counter<=(others=>'0');
end if;
end if;
end process;
bout<=counter;
end behavior;
对于设计1,由于init和reset的counter置位是不同的,所以额外的LE完成
组合逻辑。
而对于设计2,
由于inti和reset可以用LE中的LUT和cascade_in和cascade_out实现计数器
的加,用programable register实现计数器的状态,所以资源利用率是比较
高的。
二者的速度几乎没有差别。
好了,该干活了。
关键词: 节省 资源 设计 一个 例子
共2条
1/1 1 跳转至页
回复
打赏帖 | |
---|---|
【Cortex-M】Systick Timer使用被打赏10分 | |
分享汽车防盗系统的组成与分类(一)被打赏5分 | |
VOFA+波形显示+JYD-31蓝牙发送和解析不定长数据被打赏10分 | |
【换取手持数字示波器】-STM32F4PWM控制LED灯管亮度被打赏22分 | |
【换取手持数字示波器】STM32F4驱动RPR-0521RS照度、接近一体型传感器被打赏23分 | |
宏定义和const关键字定义被打赏5分 | |
【分享开发笔记,赚取电动螺丝刀】几个单片机I2S外设的BLCK时钟对比被打赏20分 | |
【功率监测与控制系统DIY活动成果贴】DIY功率计与LabVIEW数据采集被打赏100分 | |
【分享开发笔记,赚取电动螺丝刀】使用ESP32S3调试I2S音频模块MAX98357被打赏22分 | |
【Freertos】任务管理被打赏10分 |