#cpu与简单模型机

  姓名:             学号:            班级:计科班实验名称:CPU与简单模型机    实验性质:综合型实验   时间:2018.12.1

一、实验目的

(1) 掌握一个简单 CPU 的组成原理。

(2) 在掌握部件单元电路的基础上,进一步将其构造一台基本模型计算机。

(3) 为其定义五条机器指令,编写相应的微程序,并上机调试掌握整机概念。

二、实验原理与内容

本实验要实现一个简单的 CPU,并且在此 CPU 的基础上,继续构建一个简单的模型计算机。CPU 由运算器(ALU)、微程序控制器(MC)、通用寄存器(R0),指令寄存器(IR)、程序计数器(PC)和地址寄存器(AR)组成,

除了程序计数器(PC),其余部件在前面的实验中都已用到,在此不再讨论。系统的程序计数器(PC)和地址寄存器(AR)集成在一片 CPLD 芯片中 。CLR
连接至 CON 单元的总清端CLR,按下 CLR 按钮,将使 PC 清零,LDPC
和 T3 相与后作为计数器的计数时钟,当 LOAD为低时,计数时钟到来后将 CPU 内总线上的数据打入 PC。

本模型机和前面微程序控制器实验相比,新增加一条跳转指令 JMP,共有五条指令:IN(输入)、ADD(二进制加法)、OUT(输出)、JMP(无条件转移),HLT(停机),其指令格式如下(高4位为操作码):

其中 JMP 为双字节指令,其余均为单字节指令,********为 addr 对应的二进制地址码。微程序控制器实验的指令是通过手动给出的,现在要求 CPU
自动从存储器读取指令并执行。根据以上要求,设计数据通路图,如图 5-1-3 所示。

本实验在前一个实验的基础上增加了三个部件,一是 PC(程序计数器),另一个是 AR(地址寄存器),还有就是 MEM(主存)。因而在微指令中应增加相应的控制位

系统涉及到的微程序流程见图 5-1-4 所示,当拟定“取指”微指令时,该微指令的判别测试字段为
P<1>测试。指令译码原理见图 3-2-3 所示,由于“取指”微指令是所有微程序都使用的公用微指令,因此 P<1> 的测试结果出现多路分支。本机用指令寄存器的高 6 位(IR7—IR2)作为测试条件,出现5路分支,占用5个固定微地址单元,剩下的其它地方就可以一条微指令占用控存一个微地址单元随意填写,微程序流程图上的单元地址为 16 进制。

当全部微程序设计完毕后,应将每条微指令代码化,表 5-1-2 即为将图 5-1-4 的微程序流程图按微指令格式转化而成的“二进制微代码表”。

设计一段机器程序,要求从 IN 单元读入一个数据,存于 R0,将
R0 和自身相加,结果存于 R0,再将 R0 的值送 OUT 单元显示。

根据要求可以得到如下程序,地址和内容均为二进制数。


三、实验过程

  1. 按图 5-1-5 连接实验线路。

  2. 写入实验程序,并进行校验,分两种方式,手动写入和联机写入。

  1. 手动写入和校验

(1) 手动写入微程序

① 将时序与操作台单元的开关 KK1 置为‘停止’档,KK3 置为‘编程’档,KK4 置为‘控

存’档,KK5 置为‘置数’档。

② 使用 CON 单元的 SD05——SD00 给出微地址,IN
单元给出低 8 位应写入的数据,连续两次按动时序与操作台的开关
ST,将 IN 单元的数据写到该单元的低 8 位。

③ 将时序与操作台单元的开关 KK5 置为‘加 1’档。

④ IN 单元给出中
8 位应写入的数据,连续两次按动时序与操作台的开关 ST,将
IN 单元的数据写到该单元的中 8 位。IN 单元给出高 8 位应写入的数据,连续两次按动时序与操作台的开关 ST,将 IN 单元的数据写到该单元的高 8 位。

⑤ 重复①、②、③、④四步,将表 5-1-2 的微代码写入 2816 芯片中。

(2) 手动校验微程序

① 将时序与操作台单元的开关 KK1 置为‘停止’档,KK3 置为‘校验’档,KK4 置为‘控

存’档,KK5 置为‘置数’档。

② 使用 CON 单元的 SD05——SD00 给出微地址,连续两次按动时序与操作台的开关 ST,

MC 单元的指数据指示灯 M7——M0 显示该单元的低 8 位。

③ 将时序与操作台单元的开关 KK5 置为‘加 1’档。

④ 连续两次按动时序与操作台的开关 ST,MC 单元的指数据指示灯 M15——M8
显示该单元的中 8 位,MC 单元的指数据指示灯 M23——M16 显示该单元的高 8 位。

⑤ 重复①、②、③、④四步,完成对微代码的校验。如果校验出微代码写入错误,重新写

入、校验,直至确认微指令的输入无误为止。

(3) 手动写入机器程序

① 将时序与操作台单元的开关 KK1 置为‘停止’档,KK3 置为‘编程’档,KK4 置为‘主

存’档,KK5 置为‘置数’档。

② 使用 CON 单元的 SD07——SD00 给出地址,IN 单元给出该单元应写入的数据,连续两次按动时序与操作台的开关 ST,将 IN 单元的数据写到该存储器单元。

③ 将时序与操作台单元的开关 KK5 置为‘加 1’档。

④ IN 单元给出下一地址(地址自动加 1)应写入的数据,连续两次按动时序与操作台的开关 ST,将 IN 单元的数据写到该单元中。然后地址会又自加 1,只需在 IN 单元输入后续地址的数据,连续两次按动时序与操作台的开关 ST,即可完成对该单元的写入。

⑤ 亦可重复①、②两步,将所有机器指令写入主存芯片中。

(4) 手动校验机器程序

①将时序与操作台单元的开关 KK1 置为‘停止’档,KK3 置为‘校验’档,KK4 置为‘主

存’档,KK5 置为‘置数’档。

② 使用 CON 单元的 SD07——SD00 给出地址,连续两次按动时序与操作台的开关 ST,CPU内总线的指数据指示灯 D7——D0 显示该单元的数据。

③ 将时序与操作台单元的开关 KK5 置为‘加 1’档。

④ 连续两次按动时序与操作台的开关 ST,地址自动加 1,CPU 内总线的指数据指示灯 D7

——D0 显示该单元的数据。此后每两次按动时序与操作台的开关 ST,地址自动加 1,CPU 内总线的指数据指示灯 D7——D0 显示该单元的数据,继续进行该操作,直至完成校验,如发现错误,则返回写入,然后校验,直至确认输入的所有指令准确无误。

⑤ 亦可重复①、②两步,完成对指令码的校验。如果校验出指令码写入错误,重新写入、

校验,直至确认指令码的输入无误为止。

  1. 联机写入和校验

联机软件提供了微程序和机器程序下载功能,以代替手动读写微程序和机器程序,但是微

程序和机器程序得以指定的格式写入到以TXT为后缀的文件中,微程序和机器程序的格式如下:

选择联机软件的“【转储】—【装载】”功能,在打开文件对话框中选择上面所保存的文件,软件自动将机器程序和微程序写入指定单元。

选择联机软件的“【转储】—【刷新指令区】”可以读出下位机所有的机器指令和微指令,

并在指令区显示,对照文件检查微程序和机器程序是否正确,如果不正确,则说明写入操作失败,应重新写入,可以通过联机软件单独修改某个单元的指令,以修改微指令为例,先用鼠标左键单击指令区的‘微存’TAB 按钮,然后再单击需修改单元的数据,此时该单元变为编辑框,输入 6 位数据并回车,编辑框消失,并以红色显示写入的数据。

  1. 运行程序

方法一:本机运行

将时序与操作台单元的开关 KK1、KK3 置为‘运行’档,按动 CON 单元的总清按钮 CLR,将使程序计数器 PC、地址寄存器 AR 和微程序地址为 00H,程序可以从头开始运行,暂存器 A、B,指令寄存器 IR 和 OUT 单元也会被清零。

将时序与操作台单元的开关 KK2 置为‘单步’档,每按动一次 ST 按钮,即可单步运行一

条微指令,对照微程序流程图,观察微地址显示灯是否和流程一致。每运行完一条微指令,观测一次 CPU 内总线和地址总线,对照数据通路图,分析总线上的数据是否正确。

当模型机执行完 JMP 指令后,检查 OUT 单元显示的数是否为 IN 单元值的 2 倍,按下 CON单元的总清按钮
CLR,改变 IN 单元的值,再次执行机器程序,从 OUT 单元显示的数判别程序执行是否正确。

方法二:联机运行

将时序与操作台单元的开关 KK1 和 KK3 置为‘运行’档,进入软件界面,选择菜单命令“【实验】—【简单模型机】”,打开简单模型机数据通路图。

按动 CON 单元的总清按钮 CLR,然后通过软件运行程序,选择相应的功能命令,即可联机

运行、监控、调试程序,当模型机执行完 JMP 指令后,检查 OUT 单元显示的数是否为 IN 单元值的 2 倍。在数据通路图和微程序流中观测指令的执行过程,并观测软件中地址总线、数据总线以及微指令显示和下位机是否一致。

本次实验程序如下,程序中分号‘;’为注释符,分号后面的内容在下载时将被忽略掉:

; //*************************************** //; // //; // CPU 与简单模型机实验指令文件 //; // //; // By TangDu CO.,LTD //; // //; //*************************************** //; //****** Start Of Main Memory Data ****** //$P 00 20 ; START: IN R0 从 IN 单元读入数据送 R0$P 01 00 ; ADD R0,R0 R0 和自身相加,结果送 R0$P 02 30 ; OUT R0 R0 的值送 OUT 单元显示$P 03 E0 ; JMP START 跳转至 00H 地址$P 04 00 ;$P 05 50 ; HLT 停机; //******* End Of Main Memory Data ******* //; //**** Start Of MicroController Data **** //$M 00 000001 ; NOP$M 01 006D43 ; PC->AR,PC 加 1$M 03 107070 ; MEM->IR, P<1>

实验心得:

在本次实验过程中开始的步骤是重复以前的实验过程。我的实验线路也再次出现了问题,经过检查,发现是接线有问题,总是犯错误。这次实验让我更加了解了微程序以及CPU。CPU需要运算器、微程序控制器、通用寄存器、指令寄存器、程序计数器、地址寄存器组成。在这个过程中程序计数器决定下一.条执行的指令是什么。整体感觉这次的实验较为有效的帮助我们理解,但是感觉还是需要好好的看书。

计算机组成原理——cpu的简单模型实验报告相关推荐

  1. 概念模型计算机实验总结,计算机组成原理——cpu的简单模型实验报告

    #cpu与简单模型机 姓名:学号: 班级:计科班 实验名称:CPU与简单模型机实验性质:综合型实验时间:2018.12.1 一.实验目的 (1) 掌握一个简单 CPU 的组成原理. (2) 在掌握部件 ...

  2. 计算机组成原理简单模型机实验,CPU 与简单模型机设计实验

    计算机科学与技术系 实 验 报 告 专业名称 计算机科学与技术 课程名称 计算机组成原理 项目名称 CPU 与简单模型机设计实验 班 级 学 号 姓 名 同组人员 无 实验日期 2016.6 一.实验 ...

  3. 计算机组成原理课程设计——CPU与简单模型机设计

    一.设计目的 1.掌握一个简单CPU的组成原理. 2.在掌握部件单元电路的基础上,进一步将其构造一台基本模型计算机. 3.掌握微程序控制器设计. 二.设计任务与要求 设计任务: 用所学知识,设计并构造 ...

  4. 计算机组成原理课程设计基本模型机,广东海洋大学计算机组成原理课程设计-基本模型机的设计与实现讲解...

    <计算机组成与结构>课程实习 基本模型机的设计与实现 系 别: 信息学院 班 级: 计科1141 指导教师: 刘桃丽 姓名 邓超荣 何涛 邓周光 学号 分工 成绩 201411621110 ...

  5. 计算机组成原理课程设计复杂模型机设计,计算机组成原理课程设计(复杂模型机设计).pdf...

    计算机组成原理课程设计(复杂模型机设计) 一.课程设计的目的与要求 1.1 实验目的 1.掌握时序产生器的组成及工作原理:掌握微程序控制器的组成及工作原理: 2.根据给出的指令系统.微指令格式.微命令 ...

  6. 计算机组成原理地址码方案,《计算机组成原理》课程设计汇本案报告

    <计算机组成原理>课程设计汇本案报告 (24页) 本资源提供全文预览,点击全文预览即可全文预览,如果喜欢文档就下载吧,查找使用更方便哦! 14.9 积分 电子信息学院实验报告书课程名:&l ...

  7. 计算机组成原理时序与启停实验,计算机组成原理时序与启停实验.doc

    <计算机组成原理时序与启停实验.doc>由会员分享,提供在线免费全文阅读可下载,此文档格式为doc,更多相关<计算机组成原理时序与启停实验.doc>文档请在天天文库搜索. 1. ...

  8. 计算机组成原理 控制器.ppt,计算机组成原理(CPU的控制器部件)课件.ppt

    <计算机组成原理(CPU的控制器部件)课件.ppt>由会员分享,提供在线免费全文阅读可下载,此文档格式为ppt,更多相关<计算机组成原理(CPU的控制器部件)课件.ppt>文档 ...

  9. 杭电 2016 计算机组成原理,杭电计算机组成原理多功能ALU设计实验

    <杭电计算机组成原理多功能ALU设计实验>由会员分享,可在线阅读,更多相关<杭电计算机组成原理多功能ALU设计实验(6页珍藏版)>请在人人文库网上搜索. 1.杭州电子科技大学计 ...

最新文章

  1. HashMap和HashSet原理及底层实现
  2. linux shell bash 内置变量参考
  3. java中char占的二进制,java数据类型与二进制详细介绍
  4. eclipse编码设置
  5. 【物联网工厂大揭秘】电路板、数传模块 是怎么生产制造出来的?
  6. 前端学习(2549):模板解析指令
  7. 这篇顶会paper,讲述了疫情期间憋疯的你和我
  8. qc成果报告范例_质量引领创新 扬子江勇夺医药行业QC“十五连冠”
  9. python多标签分类_如何通过sklearn实现多标签分类?
  10. iOS 两种易混淆的存储路径
  11. Sun公司开源游戏服务器Project Darkstar Server——(Sun game server , 简称 sgs)学习笔记(二):多人游戏...
  12. 工具使用教程(四) 【VSCode使用教程】
  13. Gson解析json数据
  14. 《英语语法新思维 基础版1》读书笔记(三)
  15. 愿以三生烟火,换君一世迷离
  16. js Qrcode.js实现文字内容通过二维码展示
  17. 设计模式 - 抽象工厂模式(abstract factory pattern) 详解
  18. Live800:教育行业新拐点,在线客服系统如何提供价值?
  19. JavaScript笔试题(一)
  20. prim算法 源码(java)

热门文章

  1. opencv获取外接摄像头_opencv获取摄像头视频
  2. 七夜在线音乐台开发 第三弹 爬虫篇 (原创)
  3. 第一代电子计算机物理器件,第一代电子计算机采用的物理器件是。
  4. 如果你要开发一个中小学生学习数学的软件,你应该找谁去做用户调研
  5. HNU软件能力实训2-10. 拼写检查
  6. 亿客CRM系统被评定为湖北省优秀软件产品
  7. 发现了在公司的电脑中影响Windows性能,造成硬盘唱狂响曲的罪魁祸首!
  8. Web安全工程师必须要知道XSS漏洞的几个要点,你知道吗?
  9. みつあみの猫 Mitsuami no Neko | mmd动作+镜头
  10. 传奇客户端版本出现刷元宝,非法Gm,和漏洞的详细解读