【计算机组成 课程笔记】2.1 设计自己的计算机

news2024/12/23 22:54:00

课程链接:

计算机组成_北京大学_中国大学MOOC(慕课)

2 - 1 - 201-设计自己的计算机(14‘24’‘)_哔哩哔哩_bilibili

什么是指令系统体系结构?这个问题其实非常简单,但要想解释清楚也没有那么容易。我们还是从一个小故事开始吧。

有一天有两个小伙伴碰了面,发现对方都很愁苦,沟通后发现双方都碰到了一些运算上的问题,于是两人一拍即合,准备一起解决这个问题。怎么解决呢?不如一起设计一个计算机吧。那怎么分工呢?一个小伙伴说:我是软件程序猿,我来编写如何运算的软件指令。另一个小伙伴说:那正好,我是硬件攻城狮,我来设计计算机的硬件,主要是CPU。

OK, 那我们就分头干活吧!

真的就可以这么开始了吗?怎么保证软件程序猿写的软件就能在硬件攻城狮设计的硬件上运行起来呢?所以他们还得商量商量,把共同的接口定义好,然后才能分头去设计软件和硬件。

那他们要商量的共同的接口,就是指令系统体系结构。

他们面临的计算任务并不复杂,所以只需要一个简单的指令系统就可以了。看上去需要一个加法,所以先设计一个加法指令,另外存储器和寄存器之间的数据传送需要两条指令:LOAD和STORE。另外由于CPU是按照PC寄存器++来顺序执行指令的,有时候我们可能需要跳转到其他位置执行,这样的话就还需要一条跳转指令JMP。

这样我们就设计出了一个简单的计算机指令系统,能够满足当前所需要进行的运算。

但是这个用英文单词和字母描述的指令并不是计算机能识别的二进制代码,因此我们还要做进一步的规定。

我们约定每条指令都是等长的,都是2个字节。其中第一个字节的高4位是操作码,我们目前支持4种操作,所以只用到了其中的2位,实际上可以扩展到16个操作。第一个字节的低4位是寄存器号,我们约定目前只提供4个寄存器(R0~R3),实际上可以扩展到16个寄存器。第二个字节是存储单元地址,一共8位,所以可以索引256个存储器。

在约定好指令格式以后,我们再来看一个可以执行的任务的例子。

基于这样的任务,软件程序猿就可以编写出下面的机器语言程序。当然直接编写机器语言程序是非常困难的,随着计算机技术的发展,我们现在可以通过编写高级语言程序,再通过编译器转换成汇编语言程序,最后再转换成机器语言程序。

现在我们已经写好了一个程序,根据冯·诺依曼计算机存储程序的概念,我们把这个程序放到存储器当中。这里仅展示存储器的一个片段,即存储器的地址为5~18的存储单元中的内容。

与此同时,硬件攻城狮也完成了CPU的设计,并将CPU和存储器进行连接,构建出了完整的计算机系统。(为了便于理解,存储器中的内容还是以汇编代码的形式呈现。)

此时,如果CPU中的PC寄存器已经装入了0000 1000的地址,那么接下来的指令执行过程,我们已经很熟悉了。

现在我们已经对什么是指令系统体系结构有了初步了解,也知道了如何开始着手设计一个属于自己的计算机。下一节我们将分析一些真实的体系结构。

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

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

相关文章

兄弟 Goland 咱能一次性将注释设置好不

大家好,我是阿兵云原生 工作中我们都只是写注释是一个好习惯,作为新生代的农名工,特别烦的就是别人不写注释,但是自己偏偏又不喜欢写注释😂😂😂 对于 golang 的注释,我发现很多新朋…

攻防世界-What-is-this

原题 解题思路 解压后文件 没有后缀,不知道是什么文件。用notepad打开找不到flag。 尝试当成压缩包解压。 用stegsolve以打开图片1, 合成两张图片。

MySQL中的表与视图:解密数据库世界的基石

🏆作者简介,黑夜开发者,CSDN领军人物,全栈领域优质创作者✌,CSDN博客专家,阿里云社区专家博主,2023年6月CSDN上海赛道top4。 🏆数年电商行业从业经验,历任核心研发工程师…

vue中axios请求篇

vue中如何发起请求? 利用axios来发起请求,但是前期需要配置 首先安装axios 可以使用npm、yarn等进行安装 npm安装方式 npm install axios -sava //在项目文件夹中打开cmd或者终端进行安装依赖 yarn安装方式 yarn add axios 引入axios。我一般是在src下创建一个u…

【C++】学习C++STL中的数组——vector

❤️前言 好久不见大家!今天的这篇博客是关于我对于STL(C标准模板库)中的容器vector的学习和理解,希望大家能够喜欢。 正文 vector是STL中的一种序列容器,对应着数据结构中的顺序表,也可以说是数组。在我们正式学习了解vector之前…

spring boot 测试用例

依赖包 <dependency><groupId>org.springframework</groupId><artifactId>spring-test</artifactId><version>5.2.5.RELEASE</version><scope>compile</scope></dependency><dependency><groupId>ju…

Autoware.universe部署05:实车调试

文章目录 一、建图1.1 点云地图1.2 高精地图 二、参数配置三、传感器数据通信接口3.1 雷达点云3.2 图像3.3 IMU3.4 GNSS RTK 四、实车调试4.1 编写启动4.2 修改传感器外参4.3 修改车身参数4.4 实车调试 本文介绍了 Autoware.universe 在实车上的部署&#xff0c;本系列其他文章…

《Web安全基础》04. 文件上传漏洞

web 1&#xff1a;文件上传漏洞2&#xff1a;WAF 绕过2.1&#xff1a;数据溢出2.2&#xff1a;符号变异2.3&#xff1a;数据截断2.4&#xff1a;重复数据 本系列侧重方法论&#xff0c;各工具只是实现目标的载体。 命令与工具只做简单介绍&#xff0c;其使用另见《安全工具录》…

2023京东口腔护理赛道行业数据分析(京东销售数据分析)

近年来&#xff0c;口腔护理逐渐成为年轻人重视的健康领域&#xff0c;从口腔护理整体市场来看&#xff0c;牙膏和牙刷等基础口腔护理产品仍占据主导地位。不过&#xff0c;随着口腔护理市场逐步朝向精致化、专业化、多元化等方向发展&#xff0c;不少新兴口腔护理产品受到消费…

C++学习|CUDA内存管理代码实例

前言&#xff1a;之前介绍了CUDA入门知识&#xff0c;对CUDA编程有了一个基本了解&#xff0c;但是实际写起来还是遇到很多问题&#xff0c;例如cpp文件该怎么调用cuda文件、cpu和gpu之间内存数据怎么交换、如何编写.cu和.cuh文件之类的。本篇文章将会以一个实现向量相加的代码…

【数据结构】二叉数的存储与基本操作的实现

文章目录 &#x1f340;二叉树的存储&#x1f333;二叉树的基本操作&#x1f431;‍&#x1f464;二叉树的创建&#x1f431;‍&#x1f453;二叉树的遍历&#x1f3a1;前中后序遍历&#x1f4cc;前序遍历&#x1f4cc;中序遍历&#x1f4cc;后续遍历 &#x1f6eb;层序遍历&am…

什么是Python爬虫分布式架构,可能遇到哪些问题,如何解决

目录 什么是Python爬虫分布式架构 1. 调度中心&#xff08;Scheduler&#xff09;&#xff1a; 2. 爬虫节点&#xff08;Crawler Node&#xff09;&#xff1a; 3. 数据存储&#xff08;Data Storage&#xff09;&#xff1a; 4. 反爬虫处理&#xff08;Anti-Scraping&…

2023-08-30力扣每日一题

链接&#xff1a; 1654. 到家的最少跳跃次数 题意&#xff1a; 从0出发&#xff0c;到X的最少步数 它可以 往前 跳恰好 a 个位置&#xff08;即往右跳&#xff09;。它可以 往后 跳恰好 b 个位置&#xff08;即往左跳&#xff09;。它不能 连续 往后跳 2 次。它不能跳到任何…

2023新版医保目录明细(药品查询)

查询医保目录的主要目的是为了了解医保政策对于特定医疗服务、药品和医疗器械的覆盖范围和支付标准。大众可以通过查看医保目录可以确定哪些药品可以被医保支付以及报销的比例和限额&#xff1b;医药从业者可通过查看医保目录可以即使了解医保政策的变化&#xff0c;便于做出相…

Window10 安装 Lua

1、下载地址&#xff1a;https://luabinaries.sourceforge.net/download.html 2、下载 3、解压后共有4个文件&#xff0c;这里我把这几个文件放到如下目录 D:\Program Files\lua-5.4.2\bin 4、定义环境变量 5、打开 powershell&#xff0c;运行 lua54 -v PS C:\Windows\syste…

qt设计界面

widget.h #ifndef WIDGET_H #define WIDGET_H //防止文件重复包含#include <QWidget> //QWidget类所在的头文件&#xff0c;父类头文件 #include<QIcon> #include<QPushButton> …

Facebook Shops免费面世 Facebook与Instagram携手并肩

图片来源&#xff1a;SaleSmartly官网 近年来网上购物剧增&#xff0c;电子商务越趋重要&#xff0c;Facebook 和Instragram乘势推出Facebook Shops&#xff0c;免费让零售商户在全球最多使用者的两个社交平台创建线上商户&#xff0c;展示产品和进行交易&#xff0c;助零售业走…

DataTable扩展 列转行方法(2*2矩阵转换)

源数据 如图所示 // <summary>/// DataTable扩展 列转行方法&#xff08;2*2矩阵转换&#xff09;/// </summary>/// <param name"dtSource">数据源</param>/// <param name"columnFilter">逗号分隔 如SDateTime,PM25,PM10…

SmokePing网络延迟和丢包监测工具

SmokePing是一种网络延迟和丢包监测工具&#xff0c;其监控原理如下&#xff1a; 监测目标选择&#xff1a;SmokePing通过配置文件&#xff08;Targets&#xff09;定义了要监测的目标&#xff0c;可以是主机、路由器、服务器或其他网络设备。每个目标都有一个唯一的名称和IP地…

9个实用的交互设计软件,Get更简单的原型制作方式!

好用的原型图软件不仅可以快速可视化产品经理的想法&#xff0c;提高沟通效率&#xff0c;还可以加快测试进度&#xff0c;打造更真实的用户体验。今天本文为大家整理了9个好用的原型图工具&#xff0c;一起来看看吧&#xff01; 1、即时设计 在设计场景中&#xff0c;即时设…