杨科计算机组成原理课程设计.doc
《杨科计算机组成原理课程设计.doc》由会员分享,可在线阅读,更多相关《杨科计算机组成原理课程设计.doc(21页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、 计算机组成原理 课 程 设 计 报 告 学部: 信息科学与技术 专业班级: 软件工程2班 学生姓名: 杨 科 学生学号: 3 指导教师: 陈 艳 课设时间: 2015.4.42015.4.12 目录一、课设目的2二、课设任务2三、使用的设备及软件2 设备2 软件3四、设备连接4五、编程题目4六、程序流程图4七、程序6八、程序每条指令对应的机器代码和对应的微指令.7九、调试过程151、程序编译152、加载154、总清试验机175、程序运行17十、结果20 1.计算结果20 2.查看方法17 一、课设目的通过课程设计更清楚地理解下列基本概念:1、计算机的硬件基本组成;2、计算机中机器指令的设计;
2、3、计算机中机器指令的执行过程;4、微程序控制器的工作原理;5、微指令的格式设计原理。6、通过使用软件HKCPT,了解程序编译、加载的过程。7、通过微单步、单拍调试,理解模型机中的数据流向。 二、课设任务1、在掌握各模块功能的基础上,构成模型机;2、熟悉模型机的通路、微指令系统、与汇编指令的关系;3、使用微机与模型机连接调试的应用程序HKCPT;4、编辑程序,了解程序编译、加载及运行的过程。三、使用的设备及软件 设备 此次课设使用HK-CPT-IV型计算机组成原理实验平台,实验平台简介如下:基本功能模块:运算器模块、指令部件模块、堆栈寄存器模块、存储器模块、总线传输模块、微程序模块、启停和时序
3、模块,以及用于调试和观察数据的监控模块。1 组成结构:采用总线结构。总线分为:内部、外部地址总线,内部、外部数据总线。2 监控模块:为实验调试和程序设计带来了相当的便利。实验者可以通过监控模块来修改微程序和内存中的程序。3 操作方式 : 单机方式整个系统可单独使用;联机方式系统可 与PC机相连。 软件 此次课设使用的软件为HKCPT,其使用介绍如下:1 启动HKCPT:第一次启动HKCPT,用户需设置实验平台通讯端口。退出HKCPT时,会自动保存用户最后一次的设置。用户选择“设置实验平台”菜单项,在弹出的对话框中,选择相应的通讯串口、通讯波特率和延时因子。点击确定按钮,即可使用。2 程序编写:
4、选择“文件新文件”菜单项,将新建一个空的编辑窗口。用户在编辑窗口中输入以下程序。输入完毕,选择“文件另存为”菜单项,把该文件保存为demo.asm。因为编译器支持长文件名,用户也可以把该文件保存在如“我的文档”之类的目录夹中。用户可以直接选择“文件打开”菜单项打开该文件。3 程序编译:编译是检查源文件的语法错误,如果源文件没有语法错误,编译器将生成源文件的目标代码,由于是单汇编文件,编译产生的目标代码可以直接加载调试。用户选择“编译编译当前文件”菜单项,将编译当前活动窗口中的源文件,编译结果的信息显示在输出窗口中。用户可以根据输出窗口中错误信息直接定位到源文件的相应位置。4 程序运行:加载后,
5、可以运行程序,有三种运行方式: 微单步:每执行一条微程序,PC指针加1,微指令向后移动一步,同时结构图中绘出执行步及上一步的数据流向,各个寄存器和控制线状态会相应改变。 程序单步:从当前PC指针行执行源文件的一行语句,然后又停止。结构图中显示的寄存器值和控制线都会随之刷新,但不显示数据流。 全速运行:全速运行程序,遇到用户断点或按暂停键或执行到halt指令停止。 四、设备连接 实验过程中的设备连接包括3部分的内容:1 数据总线的连接:接口1DJ1DJ2 DJ3 DJ4 DJ5 DJ6DJ7PC_OUT接口2ALU_INALU_OUTR_INR_OUTRA_INRA_OUTPC_INAJ12 各
6、模块的连线:由于实验平台提供了连线板,在实验时,只要将连线板插在指定的地方,这样,各个模块就成功的连接了。3 与计算机的连线:实验平台提供的连接线将实验平台与计算机相连,这样,计算机通过软件可以和平台相互通讯。 五、编程题目从1加到10,再带进位右移三位,最后,再加上自已学号的后三位,结果存放到RAM的40H号字节单元中。六、程序流程图 寄存器分配:1 R1作为计数器,控制循环次数,判断是否退出循环;2 R0用来存放累加和,把最终的结果放入A中。3. R2不变,固定为1,通过R1每次减1实现累加和需要的累加数。4. R3用来存放学号。 开始 10-R0 10-R1 1-R2 R1-A R1-A
7、 A-R2-A A-R1A-A A+R0-A A-R0 R1-A否A=10?-是 R0-A A3A中的值带进位右移3位 7BHR3 A+R0-AA-40H将A的内容存入RAM 结束 七、程序根据程序流程图所示,可以进行代码的编写: MOV R2,#1 MOV R0,#0A MOV R1,#0A MOV A,R1 SUB A,R2 MOV R1,A ADD A,R0 MOV R0,A MOV A,R1 JZ 10 JMP 06 MOV A,R0 RRC A RRC A RRC A MOV R3,#7B ADD A,R3 STA 40 HALT HALT程序分析: MOV A,R1 SUB A,R
8、2R1作为计数器,控制循环次数,判断是否退出循环R2不变,固定为1,通过R1每次减1实现累加和需要的累加数。 ADD A,R0 MOV R0,AR0用来存放累加和,把最终的结果放入A中 MOV R3,#7B R3用来存放学号。 RRC A RRC A RRC A实现3次右移操作,得到所要求的结果。 MOV R0,#C6 加上学号 STA 41 将结果放入内存40(H)号单元 程序总体分析如下: 当每进行一次循环,R0减1,直到减到1,且减完后A和R0均保存了下一次循环当加的数,R2不变,固定位1,故而用A 和 R2进行比较,如果A和R2相等,则不执行循环了,如不相等则执行下一次循环。R1作为计
9、数器,控制循环次数,判断是否退出循环。R0从10减到1总共循环了10次,R0用来存放累加和,把最终的结果放入A中,带进位右移三位后加上R3的内容存入A中,把A的结果存放到40号单元。八、 程序每条指令对应的机器代码和对应的微指令 用软件HKCPT来编辑、编译、加载实验平台,或通过键盘(键盘使用方法见第四章)把以下程序以16进制输入程序存储器。 1.代码的微指令运行过程内存地址 指令助记符指令码或立即数说明00HMOV R2,#16EH立即数01H-R201H01H02HMOV R0,#0A6CH立即数 0AH-R003H0AH04HMOV R1,#0A6DH立即数0AH-R105H0AH06H
10、MOV A,R13DH(R1)-A07HSUB A,R21EH(A)-(R2)-A08HMOV R1,A4DH(A)-R109HADD A,R00CH(A)+(R)-A0AHMOV R0,A4CH(A)-R00BHMOV A,R13DH(R1)-A0CHJZ 10B3H(A)=0,跳转到10号指令0DH10OEHJMP 06BFH无条件跳转到06号指令0F06循环10HMOV A,R03CH(R0)-A11HRRC 9FHA112HRRC 9FHA113HRRC 9FHA114HMOV R3,#7B6FH7BH-R37BH15HADD A,R30FH(A)+(R3)-A16HSTA 40 8F
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机 组成 原理 课程设计
限制150内