首先回答题目问题:FPGA的逻辑结果不是算出来的,是查出来的。也就是说FPGA的逻辑功能实现是基于查找表的。
1.CPLD如何实现逻辑运算
CPLD,复杂可编程逻辑器件。逻辑阵列的每一个交叉点都可以通过编程实现导通从而实现与逻辑,乘积项选择矩阵可实现或逻辑。也就是CPLD的组合逻辑都是直接通过内部的与非门实现的。
2.FPGA如何实现逻辑运算
FPGA,现场可编程门阵列,前面说是基于查找表,那什么是查找表?
查找表可以理解为保存了逻辑表达式真值表的RAM,我们将设计好的逻辑电路的真值表存在查找表里面。每次根据输入信号查找对应的结果,然后输出就可以了。所以说FPGA的工作像一个RAM,根据不同的输入信号(地址)输出相应的数据。
一个4输入查找表如下所示
现在实现一个Y=A&B+C+D的组合逻辑功能,Verilog语句为:
reg Y;
reg [