现代计算机的各个部件到底是如何通过逻辑电路构成的呢   半加器 我们说过了门电路 看似简单的三种门电路却是组成了整个逻辑电路的根基 真值表--其实就是根据输入输出状态枚举罗列出来的所有可能 比如有一台设备,他有两个输入A和B 无论何时,他们都有电或者都没有电的时候是正常,任何一个有电就是不正常 那么他的真值表就是这样子的 AB表示输入  F表示输出…
引言 computer(计算机),顾名思义,就是用来compute(计算)的.计算机体系结构在上世纪五六十年代的时候,主要就是研究如何设计运算部件,就是想办法用最少的元器件(那时元器件很贵),最快的速度,完成加减乘除......等等这些运算.后来发现运算已经足够快了,快到已经无法提供足够的运算指令和运算的操作数了,人们才开始研究如何给运算部件提供足够的指令和数据,这就产生了cache啊,分支预测啊,流水线啊,等等技术. 本小节,我们就分析一下or1200的运算部件. 1,基础 在上世纪50年代中…
FPGA设计的是数字逻辑,在开始用HDL设计之前,需要先了解一下基本的数字逻辑设计-- 一门抽象的艺术. 现实世界是一个模拟的世界,有很多模拟量,比如温度,声音······都是模拟信号,通过对模拟信号进行约束,我们就会抽象出来高电平和低电平,也就是0和1,用来构建整个数字逻辑世界,这个约束就是电平规则约束,比如常见的有以下几种: 电平约束 VDD/VCC 0 1 CMOS 3~8V 0~0.3VDD 0.7~1VDD TTL 5V±5% 0~0.7 2.4~5 LVCMOS 3.3 0~0.9…
从<十进制和二进制的运算---我所理解到的人类的运算的本质>这里我们知道,人类进行运算的本质是查表,并且我们存储的表是有限的.那么计算机是怎进行四则运算的呢,也是查表吗,肯定不是,今天,我们先来说一说CPU是如何计算1+1的.现代计算机又叫电子计算机,肯定是由电路和电子元件来实现的呗.我们都知道一台计算机的核心就是处理器(CPU),它的职责就是运算,而CPU是一块超大规模的集成电路,所以我们要想弄清楚计算机的运算机制就要了解集成电路是如何具有运算能力的,而集成电路是由大量晶体管等电子元件封装而…
目录 Hardware Description Languages Verilog SystemVerilog 对Cracking Digital VLSI Verification Interview:Interview Success这本书的汉化,最新更新请关注微信公众号 摸鱼范式 Hardware Description Languages Verilog [159] verilog中的阻塞赋值和非阻塞赋值有什么区别? verilog支持阻塞与非阻塞两种赋值方式.使用阻塞赋值时,计算和赋值…
相信很多朋友对于逻辑式编程语言,都有一种最熟悉的陌生人的感觉.一方面,平时在书籍.在资讯网站,偶尔能看到一些吹嘘逻辑式编程的话语.但另一方面,也没见过周围有人真正用到它(除了SQL). 遥记当时看<The Reasoned Schemer>(一本讲逻辑式编程语言的小人书),被最后两页的解释器实现惊艳到了.看似如此复杂的计算逻辑,其实现竟然这么简洁.不过碍于当时水平有限,也就囫囵吞枣般看了过去.后来有一天,不知何故脑子灵光一闪,把图遍历和流计算模式联系在一起,瞬间明白了<The Reaso…
在fpga工程应用设计中,随处可见加法器,乘法器等等.现在将一些常用模块和心得体会先记录下来,以便日后使用. 一位半加器: module halfadder(cout,sum,a,b); outputcout,sum; //不申明,默认是wire变量 input  a,b; assign{cout,sum}=a+b;//cout为进位,sum为和 endmodule 一位全加器: module fulladder(a,b,cin,cout,sum); inputa,b,cin; outputco…
###### [该随笔部分内容转载自小梅哥] ######### 组合逻辑:    多路选择器.加法器.译码器.乘法器 时序逻辑:    计数器.分频器.定时器.移位寄存器 一.Verilog文件的基本结构      1.模块声明     模块名    端口列表      2.端口类型.位宽定义      3.功能描述 //模块描述方式一(先列出端口,再描述端口类型) //此方式虽然行数多,但是方便后面例化端口,推荐使用 module name( , , //最后一个不需要"," );…
类似半加器和全加器,也有半减器和全减器. 半减器只考虑当前两位二进制数相减,输出为差以及是否向高位借位,而全减器还要考虑当前位的低位是否曾有借位.它们的真值表如下: 对半减器,diff = x ^y, cin = ~x&y 对全减器,要理解真值表,可以用举列子的方法得到,比如4'b1000-4b'0001,则第一位对应0 1 0 1 1第二位对应的是0 0 1 1 1 从真值表中,可以得到 diff = x ^ y ^cout, cin = (~x&(y^cout))|(y&cou…