重庆大学计算机课程设计,计算机组成原理课程设计报告重庆大学.doc

计算机组成原理课程设计报告重庆大学

计算机组成原理课程设计报告

题目:微程序设计

专业:计算机科学与技术

班级:

指导老师:

目录

一、摘要

二、设计要求

三、微程序控制器原理

四、总体设计

五、测试

六、结论

七、参考文献目录

八、 个人总结

重庆大学本科学生课程设计任务书

课程设计题目微程序设计学院计算机学院专业计算机科学与技术年级2008已知参数和设计要求:

用微程序控制器实现以下指令功能:

交换指令:

xchgrm reg, addr ;功能:(reg)(((addr),addr是8位二进制地址

加法指令:

addi rd,rs,imme ;功能:rd((rs)+imme

addm rd,rs,addr ;功能:rd((rs)+(addr)

带右移的加法运算:

add ri ,rj , n; ri ((ri)+(rj)任务下达日期  年 月   日完成日期 年 月 日指导教师 (签名)学 生 (签名)

(签名)

摘要

利用CPU与复杂机设计实验中所学到的实验原理以及编程思想,硬件设备,

自拟编写指令的应用程序,用微程序控制器实现了一系列的指令功能。完成了各指令的格式以及编码设计,实现了各机器指令微代码,形成具有一定功能的完整的应用程序。

在本设计中完成了,交换指令:XCHGRM reg addr ;加法指令:ADDI rd,rs,imme;ADDM rd,rs,addr;带右移(n位)的加法运算:ADDN ri ,rj , n。

关键词:微程序控制器原理微指令编码机器指令微代码

指令格式设计流程图

设计要求

要求:用微程序控制器实现以下指令功能(各类指令至少包括一条),设计各机器指令格式以及编码,并实现各机器指令功能的微代码,根据定义的机器指令,自拟编写包含以下机器指令的应用程序。

交换指令:

xchgrm reg, addr ;功能:(reg)(((addr),addr是8位二进制地址

xchgmm addr1,addr2 ;功能:(addr1)(((addr2),addr是8位二进制地址

加法指令:

addi rd,rs,imme ;功能:rd((rs)+imme

addm rd,rs,addr ;功能:rd((rs)+(addr)

带右移的加法运算:

add ri ,rj , n; ri ((ri)+(rj)

1.数据格式

模型机规定采用定点补码表示法表示数据,字长为8位,8 位全用来表示数据(最高位不表示符号),数值表示范围是: 0≤X≤28-1。

2.指令设计

模型机设计三大类指令共十五条,其中包括运算类指令、控制转移类指令,数据传送类指令。运算类指令包含三种运算,算术运算、逻辑运算和移位运算,设计有6 条运算类指令,分别为:ADD、AND、INC、SUB、OR、RR,所有运算类指令都为单字节,寻址方式采用寄存器直接寻址。控制转移类指令有三条HLT、JMP、BZC,用以控制程序的分支和转移,其中HLT为单字节指令,JMP 和BZC 为双字节指令。数据传送类指令有IN、OUT、MOV、LDI、LAD、STA 共6 条,用以完成寄存器和寄存器、寄存器和I/O、寄存器和存储器之间的数据交换,除MOV 指令为单字节指令外,其余均为双字节指令。实验中我们将指令LDI、OR、RR分别替换为ADDI、ADDM、XECHAGE、ADDN,并对流程控制做相应的修改。

3.指令格式

所有单字节指令(ADD、AND、INC、SUB、OR、RR、HLT 和MOV)格式如下:

7 6 5 43 21 0OP-CODERSRD

其中,OP-CODE 为操作码,RS 为源寄存器,RD 为目的寄存器,并规定:

RS或RD选定的寄存器00

01

10

11R0

R1

R2

R3

IN 和OUT 的指令格式为:

7 6 5 4(1)3 2(1)1 0(1)7-0(2)OP-CODERSRDP

其中括号中的1 表示指令的第一字节,2 表示指令的第二字节,OP-CODE 为操作码,RS为源寄存器,RD 为目的寄存器,P 为I/O 端口号,占用一个字节,系统的I/O 地址译码原理见图3-1(在地址总线单元)。

图3-1 I/O 地址译码原理图

由于用的是地址总线的高两位进行译码,I/O 地址空间被分为四个区,如表3-1 所示:

表3-1 I/O 地址空间分配

A7 A6选定地址空间00IOY000-3F

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/287002.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一些服务器编程的概念

IO线程:有Event loop的线程,每个线程有且有一个loop,用per thread变量记录这个loop的对象地址,如果这个变量非空可以知道这个线程是IO线程 Channel:绑定到一个且只能一个loop,即某个IO线程,负责…

南方方洲号无人测量船系统简介

南方智能测量船系统由小型无人船、自动导航模块、声纳探测模块、外围传感模块、岸基操控终端、无人船专用软件等部分组成。将先进的卫星定位、声纳、传感器与智能导航控制等众多技术相结合,提出了高精度、智能化、集成化、机动化、网络化的勘测解决方案。该系统能自主航行并完…

1小时1篇文学会python再做个飞机大战游戏

注: 想慢慢学习的同学可以看我的 《python 入门到游戏实战专栏》(更新中) 想学 C 的同学可以看《大话系列之C语言》(基本更新完) 想学 C 的同学可以看《大话C》(更新中) 想做习题的可以看《大学…

Android之app作为服务器解决跨域问题

1 问题 APP用socket写了服务器,然后PC发送请求到APP出现跨域问题。 2 解决办法 在APP用socket服务器返回头里面添加如下关键代码 header="Content-Type: "+ JSON_TYPE + "; charset=utf-8 \r\n"+ "Connection: close\r\n"+ "Access-Cont…

如何优雅的编写git的提交信息

前言在公司的日常工作当中或者个人的开源项目,将代码提交到代码库时。都会遇到下面这样的对话框,通常都会随便写点内容在里面。当遇到问题需要回溯的时候就成了给自己造成的麻烦,因为无法通过commit message来非常直观的看到这一次提交了什么…

android快捷开发之Retrofit网络加载框架的简单使用

大家都知道,安卓最大的特点就是开源化,这自然会产生很多十分好用的第三方API,而基本每一个APP都会与网络操作和缓存处理机制打交道,当然,你可以自己通过HttpUrlConnection再通过返回数据进行解析解决,而我们…

如何线性求乘法逆元

ny[i](ny[p%i]*(p-p/i))%p;不如背一发板子?转载于:https://www.cnblogs.com/paozi/p/7788640.html

打开计算机无法显示工具栏,任务栏不显示打开的窗口怎么办教程

我们在使用电脑的时候,打开很多程序的时候,会最小化某些窗口,只留在用的窗口,而最小化都是缩小为一个图标放入屏幕下方的任务栏的,但有时候不知道为什么任务栏不显示打开的窗口了,这时候也就无法直接用鼠标…

rsync文件同步、Inotify-tools参数详解

inotifywait用于等待文件或文件集上的一个待定事件,可以监控任何文件和目录设置,并且可以递归地监控整个目录树; inotifywatch用于收集被监控的文件系统计数据,包括每个inotify事件发生多少次等信息从上面可知inotifywait是一个…

ArcGIS 10.6提取道路中心线的两种方法经典教程

我们工作中碰到的道路数据通常为面状,需要提取道路中心线,本文讲解ArcGIS10.6中从面状道路数据中提取道路中心线的两种常用经典方法。 方法一:使用ArcGIS 10.6提供的提取道路中心线工具 本实验中使用到面状数据如下所示: 首先,将面状数据转为线状数据。 转完之后,道路尽头…

衡量计算机浮点数操作性能,计算机系统基础:计算机性能评价知识笔记

1、计算机性能常用的性能评测方法1.1 时钟频率计算机的时钟频率可以反映出机器的运行速度。一般主频越高,速度越快。1.2 指令执行速度加法指令执行速度是衡量计算机性能指标的重要指标之一。1.3 等效指令速度法随着计算机指令系统发展,种类越来越多&…

Android之用HttpURLConnection断点下载谷歌云存储(google cloud storage)文件

1 需求 在Android app里面实现断点下载谷歌云存储(google cloud storage)文件,也就是说用户下载谷歌云存储(google cloud storage)文件的时候可以暂停下载,后续可以再继续下载 测试的图片谷歌云的下载地址:https://storage.googleapis.com/keepdrop/common_dev/file-6fb695ac…

python 写游戏好简单啊,我用键盘可以随意控制角色了【python 游戏实战 04】

前言 本系列文章将会以通俗易懂的对话方式进行教学,对话中将涵盖了新手在学习中的一般问题。此系列将会持续更新,包括别的语言以及实战都将使用对话的方式进行教学,基础编程语言教学适用于零基础小白,之后实战课程也将会逐步更新…

ASP.NET登录以及注册

数据模型&#xff1a; 1 public class Model2 {3 public Model()4 {5 //6 // TODO: 在此处添加构造函数逻辑7 //8 }9 private string _Ucode; 10 /// <summary> 11 /// 账号 12 /// </summary> 13 public…

树形表的平行查询设计

本文由网友长空X投稿&#xff0c;欢迎转载、分享原文作者&#xff1a;长空X&#xff08;CSDN同名“长空X“&#xff0c;CkTools的作者&#xff0c;github: https://github.com/hjkl950217&#xff09;原文链接&#xff1a;https://www.cnblogs.com/gtxck/articles/16293295.htm…

Ubuntu 16.04安装SQLite Browser操作SQLite数据库

安装&#xff1a; sudo apt-get install sqlitebrowser 启动&#xff1a;

ArcGIS10从入门到精通系列实验视频教程合集(持续更新)

全集视频请点击&#xff1a;《ArcGIS10.X从入门到精通系列实验教程》

(13)python 字典 2 分钟速解

本系列文章将会以通俗易懂的对话方式进行教学&#xff0c;对话中将涵盖了新手在学习中的一般问题。此系列将会持续更新&#xff0c;包括别的语言以及实战都将使用对话的方式进行教学&#xff0c;基础编程语言教学适用于零基础小白&#xff0c;之后实战课程也将会逐步更新。 若…

Kotlin之函数作为参数传递

1 、Kotlin之函数作为参数传递 我们在写BaseQuickAdapter适配器的时候,有时候嵌套多个BaseQuickAdapter,如果最里面的view触发点击事件,我们可以把函数作为参数通过构造函数一层一层传递进去。 2、代码测试 private var test: (Boolean, Int, Int) -> Unit = {result, a…

计算机绘画作品 星空,关于近期绘画作品《星空系列》的自述:

《星空系列》是一个很偶然的念想下产生的&#xff0c;但又绝非偶然。最开初的点是高一刚开始学画的时候&#xff0c;高中的老师给我们免费提供油画材料给我们练习&#xff0c;那时候我并没有“安分”地练习高考绘画&#xff0c;总想做一些关于自己想法的作品&#xff0c;那时候…