FPGA简单CPU设计过程学习ppt课件.ppt

FPGA简单CPU设计过程学习ppt课件.ppt

ID:59419535

大小:1.37 MB

页数:45页

时间:2020-09-19

FPGA简单CPU设计过程学习ppt课件.ppt_第1页
FPGA简单CPU设计过程学习ppt课件.ppt_第2页
FPGA简单CPU设计过程学习ppt课件.ppt_第3页
FPGA简单CPU设计过程学习ppt课件.ppt_第4页
FPGA简单CPU设计过程学习ppt课件.ppt_第5页
资源描述:

《FPGA简单CPU设计过程学习ppt课件.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、电信系通信1032葛毅简单的CPU设计自强不息博学精艺前言这个CPU模型只是从原理上说明了一个简单的CPU的构成。我们了解学习它的目的是想表明:VerilogHDL仿真和综合工具的潜力和设计方法对软硬件联合设计是有重要意义的。我希望通过与大家分享我的学习经验能够引起对CPU原理和复杂数字逻辑系统设计有兴趣的同学的注意,加入我们的设计队伍。由于我们的经验与学识有限,不足之处敬请大家指正。什么是CPU?CPU即中央处理单元的英文缩写,它是计算机的核心部件。计算机进行信息处理可分为两个步骤:1)将数据和程序(即指令序列)输入到计算机的存储器中。2)从第一条指令的地址起开始执行该程序,得

2、到所需结果,结束运行。CPU的作用是协调并控制计算机的各个部件执行程序的指令序列,使其有条不紊地进行。因此它必须具有以下基本功能:a)取指令:当程序已在存储器中时,首先根据程序入口地址取出一条程序,为此要发出指令地址及控制信号。b)分析指令:即指令译码。是对当前取得的指令进行分析,指出它要求什么操作,并产生相应的操作控制命令。将其功能进一步细化,可概括如下:1)能对指令进行译码并执行规定的动作;2)可以进行算术和逻辑运算;3)能与存储器,外设交换数据;4)提供整个系统所需要的控制;c)执行指令:根据分析指令时产生的“操作命令”形成相应的操作控制信号序列,通过运算器,存储器及输入/

3、输出设备的执行,实现每条指令的功能,其中包括对运算结果的处理以及下条指令地址的形成。一二三四五六存储器设计程序计数器逻辑运算器指令解码器多路选择器控制器设计目录存储器ALU控制器指令解码器PC数据出数据入走进CPU<一、ram>存储器的设计,存储器的作用就是把我们要执行的指令和数据暂存起来,等待控制器的调用。走进CPU<一.ram>具体我们都需要在这一模块上设计什么呢?关键在于我们应该了解输入的是什么,而我们又想得到什么。。。走进CPU<一.ram>或者我们可以直接调用FPGA的内部ram,及我们课本中曾学习过的LPM-ram。这样可以大大缩减我们的设计时间。这一点需要我们多多学

4、习,因为FPGA内部资源挺多的,希望我们可以一一深入地了解,并可以灵活的运用。走进CPU<二.pc程序计数器>累加器顾名思义就是加一计数器,一个周期加一一次,PC(程序计数器)负责生成存储器的地址值(在下一步骤中会将对应地址的存储器中的指令取出),然后将自身+1,使其指向下一条将要执行的指令,为取下一条指令的执行做好准备。走进CPU<三.ALU>逻辑运算单元(ALU)为了使所有的单元都受控制器的控制,使设计简单化,分别设置几个运算控制使能端,完成不同的运算使能。另外,为了能够监测运算结果的特殊性,设置以下相应的标志位,n输出负标志z输出0标志c输出进位标志v输出溢出标志走进CPU

5、<三.ALU>算术逻辑运算单元根据输入的8种不同操作码分别实现相应的加、减、与、或、跳转等8种基本操作运算。利用这几种基本运算可以实现很多种其它运算以及逻辑判断等操作。走进CPU<三.ALU>改进后的ALU,注意这需要与control一致改进。在这里把所有的指令用ALUcontrol来代替了,简化了电路。1)HLT停机操作。该操作将空一个指令周期,即8个时钟周期。2)SKZ为零跳过下一条语句。该操作先判断当前alu中的结果是否为零,若是零就跳过下一条语句,否则继续执行。3)ADD相加。该操作将累加器中的值与地址所指的存储器或端口的数据相加,结果仍送回累加器中。4)AND相与。该操

6、作将累加器的值与地址所指的存储器或端口的数据相与,结果仍送回累加器中。5)XOR异或。该操作将累加器的值与指令中给出地址的数据异或,结果仍送回累加器中。6)LDA读数据。该操作将指令中给出地址的数据放入累加器。7)STO写数据。该操作将累加器的数据放入指令中给出的地址。8)JMP无条件跳转语句。该操作将跳转至指令给出的目的地址,继续执行。RISC_CPU是8位微处理器,一律采用直接寻址方式,即数据总是放在存储器中,寻址单元的地址由指令直接给出。这是最简单的寻址方式。走进CPU<三.ALU>modulealu(clk,reset,en,din,n,z,c,v,ALUcontrol,

7、ALUresult);inputclk,reset,en;input[2:0]ALUcontrol;input[7:0]din;outputn;//负数标志outputz;//零标志outputc;//进位标志outputv;//溢出标志outputreg[7:0]ALUresult;regc;always@(posedgeclkorposedgereset)if(reset)beginALUresult<=0;c<=0;end走进CPU<三.ALU>elseif(en)begi

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。