《计算机组成原理课程设计求负数平方和CISC》由会员分享,可在线阅读,更多相关《计算机组成原理课程设计求负数平方和CISC(66页珍藏版)》请在金锄头文库上搜索。
1、计算机组成原理课程设计报告题 目:求负数平方和CISC模型院 系:计算机科学与工程学院专 业:计算机科学与技术指导教师:陈智勇 2014年3月30号目 录1课程设计的题目与内容12课程设计完成的内容13系统开发环境及VHDL语言介绍14系统总体设计25MAX PLUS II软件编译仿真测试和结果分析96遇到的问题及解决办法117 心得体会118 参考文献129 附录12一:课程设计的题目及内容题目输入包含5个整数(有符号数)的数组M,输出所有负数的平方和。 要求采用定长CPU周期、联合控制方式,并运行能完成一定功能的机器语言源程序进行验证,机器语言源程序功能如下:五个有符号数从外部输入,一定要
2、使用符号位(比如说SF),并且要使用负的时候转移(比如说JS)或不为负的时候转移(比如说JNS)指令;采用三数据总线结构的运算器,采用RAM,先将输入数据依次存放在RAM的某一连续的存储区域内,再依次读出判断是否为负数,若为负数再求其平方和。二:课程设计的要求1.完成系统的总体设计,画出模型机数据通路框图;2.设计微程序控制器(CISC模型计算机)的逻辑结构框图; 3.设计机器指令格式和指令系统; 4.设计时序产生器电路; 5.设计所有机器指令的微程序流程图; 6.设计操作控制器单元; 在CISC模型计算机中,设计的内容包括微指令格式(建议采用全水平型微指令)、微指令代码表(根据微程序流程图和
3、微指令格式来设计)和微程序控制器硬件电路(包括地址转移逻辑电路、微地址寄存器、微命令寄存器和控制存储器等。具体电路根据微程序控制器的逻辑结构框图、微指令格式和微指令代码来设计)。7.设计模型机的所有单元电路,并用VHDL语言(也可使用GDF文件-图形描述文件)对模型机中的各个部件进行编程,并使之成为一个统一的整体,即形成顶层电路或顶层文件; 8.由给出的题目和设计的指令系统编写相应的汇编语言源程序;9.根据设计的指令格式,将汇编语言源程序手工转换成机器语言源程序,并将其设计到模型机中的ROM中去;10.使用EDA软件进行功能仿真,要保证其结果满足题目的要求;(其中要利用EDA软件提供的波形编辑
4、器,选择合适的输入输出信号及中间信号进行调试。)11.器件编程,并在EDA实验平台上进行操作演示三:系统开发环境及语言介绍Max plus IIMax+plus是Altera公司上一代的PLD开发软件,Max+plus界面友好,使用便捷,主要用于设计新器件和大规模CPLD/FPGA).使用MAX+PLUSII的设计者不需精通器件内部的复杂结构。设计者可以用自己熟悉的设计工具(如原理图输入或硬件描述语言)建立设计,MAX+PLUSII把这些设计转自动换成最终所需的格式。其设计速度非常快。对于一般几千门的电路设计,使用MAX+PLUSII,从设计输入到器件编程完毕,用户拿到设计好的逻辑电路,大约只
5、需几小时。在Max+plus上可以完成设计输入、元件适配、时序仿真和功能仿真、编程下载整个流程,它提供了一种与结构无关的设计环境,使设计者能方便地进行设计输入、快速处理和器件编程。设计处理一般在数分钟内内完成。特别是在原理图输入等方面,Maxplus2被公认为是最易使用,人机界面最友善的PLD开发软件,特别适合初学者使用使用Maxplus2基本上也是以上几个步骤,可简化为:(1设计输入(2)设计编译(3)设计仿真(4)优化(5)布局布线(6)后仿真(7)生产 VHDL 全称超高速集成电路硬件描述语言(英语:VHSIC hardware description language),在基于复杂可编
6、程逻辑器件、现场可编程逻辑门阵列和专用集成电路的数字系统设计中有着广泛的应用。VHDL语言诞生于1983年,1987年被美国国防部和IEEE确定为标准的硬件描述语言。自从IEEE发布了VHDL的第一个标准版本IEEE 1076-1987后,各大EDA公司都先后推出了自己支援VHDL的EDA工具。VHDL在电子设计行业得到了广泛的认同VHDL和Verilog作为IEEE的工业标准硬件描述语言,得到众多EDA公司支持,在电子工程领域,已成为事实上的通用硬件描述语言。VHDL主要用于描述数字系统的结构,行为,功能和接口。除了含有许多具有硬件特征的语句外,VHDL的语言形式、描述风格以及语法是十分类似
7、于一般的计算机高级语言。VHDL的程序结构特点是将一项工程设计,或称设计实体(可以是一个元件,一个电路模块或一个系统)分成外部(或称可视部分,及端口)和内部(或称不可视部分),既涉及实体的内部功能和算法完成部分。在对一个设计实体定义了外部界面后,一旦其内部开发完成后,其他的设计就可以直接调用这个实体。这种将设计实体分成内外部分的概念是VHDL系统设计的基本点 四:系统总体设计嵌入式CISI模型机系统总体设计嵌入式CISC系统控制器的逻辑结构框图 模型机的指令系统和所有指令的指令格式设计输入指令(IN1)格式:15 14 13 1211 109 87 6 5 4 3 2 1 0操作码 RdMOV
8、指令格式:15 14 13 1211 109 87 6 5 4 3 2 1 0操作码 Rd立即数im取数指令(LAD)格式:15 14 13 1211 109 87 6 5 4 3 2 1 0操作码RsRd相加指令(ADD)格式:15 14 13 1211 109 87 6 5 4 3 2 1 0操作码RsRd加1指令(INC)格式:15 14 13 1211 109 87 6 5 4 3 2 1 0操作码Rd减1指令(DEC)格式:15 14 13 1211 109 87 6 5 4 3 2 1 0操作码Rd非零条件转移指令(JNZ)格式:15 14 13 1211 109 87 6 5 4
9、 3 2 1 0操作码 地址addr传送指令(STO)格式:15 14 13 1211 109 87 6 5 4 3 2 1 0操作码Rs地址addr无条件转移指令(JMP)格式:15 14 13 1211 109 87 6 5 4 3 2 1 0操作码 地址addr输出指令(OUT1)格式:15 14 13 1211 109 87 6 5 4 3 2 1 0操作码Rs存数指令(STOI)格式:15 14 13 1211 109 87 6 5 4 3 2 1 0操作码RsRd乘法指令(IMUL)格式:15 14 13 1211 109 87 6 5 4 3 2 1 0操作码Rd判断箱号位转移(
10、TEST)格式:15 14 13 1211 109 87 6 5 4 3 2 1 0操作码 地址addr非负条件转移指令(JNS)格式:15 14 13 1211 109 87 6 5 4 3 2 1 0操作码 地址addr模型机规定数据的表示采用定点整数补码表示,单字长为8位,其格式如下: 76 5 4 3 2 1 0符号位尾数对于Rs或Rd的格式我们规定如下:Rs或Rd选定的寄存器00R001R110R211R3其中S2,S1,S0表示的是算术逻辑运算单元ALU,其功能表为:S2S1S0功能000X+Y001X-Y010X+1011X-1100SF101XY110SF=TEMP(7)111
11、YY指令系统表如下指令助记符指令格式功能15-1211 109 87-0IN1 Rd0001Rd输入设备RdMOV Rd,im0010Rdim立即数RdLAD (Rs),Rd0011RsRd(Rs)RdADD Rs,Rd0100RsRd(Rs)+(Rd)Rd,锁存标志位INC Rd0101Rd(Rd)+1Rd,锁存标志位DEC Rd0110Rd(Rd)-1Rd,锁存标志位JNZ addr0111addr若不等,则addrPCSTO Rs,addr1000Rsaddr(Rs)addrJMP addr1001addraddrPCOUT1 Rs1010Rs(Rs)输出设备STOI Rs,(Rd)10
12、11RsRd(Rs)(Rd)IMUL Rd,Rd1100Rd(Rd) (Rd)RdTESTRd1101Rd(RD)TEMP SF标志位JNS addr1110addr若不为正,则addrPC时序产生器时序信号产生器用于产生多级食醋系统中需要的时序信号,本实验采用的是微程序控制器的时序产生器,如下图微程序控制器的设计全过程微程序控制器的设计包括以下几个阶段:(1)机器指令的微程序流程图(2)设计微指令格式和微指令代码表(3)设计地址转移逻辑电路(4)设计微程序控制器中的其它逻辑单元电路,包括微地址寄存器、微命令寄存器和控制存储器(5)设计微程序控制器的顶层电路(由多个模块组成)。地址转移逻辑电路的设计地址转移逻辑电路是根据微程序流程图中的棱形框部分及多个分支微地址,利