FPGA内部结构原理

时间:2024-03-26 22:48:41

EP1K50QC208

1,该芯片是ALTERA公司ACEX® 1K系列下的FPGA芯片,但不推荐在新的设计中。

FPGA内部结构原理

2,内部资源。

FPGA内部结构原理

对比cyclone系列

FPGA内部结构原理

3,FPGA介绍

1

FPGA内部结构原理

FPGA的基本结构由以下单元组成:

  • 查找表(LUT):执行逻辑运算;
  • 触发器(FF):该寄存器存储LUT的结果;
  • 乘加器(DSP48等):乘加计算单元;
  • 线路(Wires):连接不同的单元;
  • 输入/输出(I/O):数据进出FPGA的物理端口。


FPGA内部结构原理

FPGA内部结构原理

altera器件的结构组成:嵌入式阵列块(EAB)(用于存储)、逻辑阵列块(LAB)(用于逻辑实现)、快速通道互联(Fast Track),IO单元(IOE)。对于其基本的组成单位LE有:

FPGA内部结构原理

LE作为FPGA的最小组成单元,其组成部分包括LUT,用于同步的D触发器,进位链,级联链。

cyclone的LE具体内部组成:

FPGA内部结构原理

简化后如下图:

FPGA内部结构原理FPGA内部结构原理

FPGA内部结构原理

多个LE通过级联链以及进位链以及行列快速通道相连接,得到一个个LAB,对于Cyclone而言,是10个LE组成一个LAB,如下图

FPGA内部结构原理

更加直观的话:

FPGA内部结构原理

结论:LUT可以直接生成移位寄存器,怎么生成的呢?

FPGA内部结构原理

IOB的具体组成:

FPGA内部结构原理

EAB的组成:

FPGA内部结构原理

EAB的字长可以控制 ,此外,EAB可以组合成更大的模块。它可以用来实现乘法器,实际上是一个输入输出上都带有寄存器的灵活的RAM电路,即可以用来做存储器,也可以实现逻辑功能。

FPGA内部结构原理

EAB与LAB之间的关系:

FPGA内部结构原理

但是在具体编程中如何实现指定所使用的资源是什么呢?

此外

 

扇入扇出太大或者太小的处理方法http://blog.sina.com.cn/s/blog_b381ebd10102vw6g.html

 

关于如何减少FPGA设计中逻辑资源的占用:(网上找的主要的几种解决的方法)
 

更改综合策略,采用资源共享;(如何更改?)如果某个某块大量使用寄存器时可以考虑是否可以采用RAM代替;从架构上分析冗余并进行优化,之后再结合个别FPGA的实现特征,如果实在对资源比较在意而对性能要求不高,就可以考虑用时间换空间,用并行替串行;良好的代码习惯和风格 暂时就那么多,以下都是我在编程时发现的问题,总结一下,怕以后忘了,以我目前的水平不明白类似关键路径,组合数目什么高深理论,这都是我从实际中学到的,比看书学的印象深刻得多.慢慢来吧,我想我以后也会明白那些高级的东西了!

一....尽量不要使用"大于""小于"这样的判断语句, 这样会明显增加使用的逻辑单元数量 .看一下报告,资源使用差别很大.

例程:[email protected](posedge clk)
begin
count1=count1+1;
if(count1==10000000)
feng=1; //no_ring
else if(count1==90000000)
begin
feng=0; //ring
count1=0;
end
end //这么写会用107个逻辑单元

// 如果把这句话if(count1==10000000)改成大于小于,报告中用了135个逻辑单元

二.....一定要想尽办法减少reg寄存器的长度

上次把[30:0]改到[50:0],报告里逻辑单元从100多直升到2000多!!!太吓人了,至于为什么我就不知道了哈!

三....case语句里一定要加default if一定要加else

如果是组合逻辑的设计,不加default或else的话,不能保证所有的情况都有赋值,就会在内部形成一个锁存器,不再是一个纯粹的组合逻辑了,电路性能就会下降.

例如:case({a,b})

2'b11 e=b;

2'b10 e=a;

endcase

//不加default,虽然只关心a=1时的结果,但是a=0的时候,e就会保存原来的值,直到a变为1

//那么e要保存原来的值,就要在内部生成锁存器了.

四....尽量使用Case语句 而不是if--else语句

复杂的if--else语句通常会生成优先级译码逻辑,这将会增加这些路径上的组合时延
用来产生复杂逻辑的Case语句通常会生成不会有太多时延的并行逻辑

五...组合逻辑的always块中,要注意所有的输入全部放入敏感变量表里

比如:[email protected](a or b)

begin

out=(a&b&c);

end