2017-2018-1 20155301 《信息安全系统设计基础》第7周学习总结

2017-2018-1 20155301 《信息安全系统设计基础》第7周学习总结

教材学习内容总结

  • 作为我们处理器实现的运行实例,因为受x86-64指令集的启发,它被俗称为“x86”,所以我们称我们的指令集为“Y86-64”,与“x86-64”相比,Y86-64指令集的数据类型、指令和寻址方式都要少一些。它的字节级编码也比较简单,机器代码没有相应的x86-64代码紧凑,不过设计他的CPU译码逻辑也要简单一些。
  • 定义Y86指令集体系结构:包括定义各种状态元素、指令集和它们的编码、一组编程规范和异常事件处理。
  • Y86-64的状态类似于x86-64。有15个程序寄存器:%rax、%rcx、%rdx、%rbx、%rsp、%rbp、%rsi、%rdi和%r8到%r14。
  • 内存从概念上来说就是一个很大的字节数组,保存着程序和数据。
  • 下图给出了Y86-64 ISA中各个指令的简单描述。Y86-64指令集基本上是x86-64指令集的一个子集。它只包括8字节整数操作,寻址方式较少,操作也较少。

1072918-20171104104135591-104788335.png

  • x86-64的movq指令分成了4个不同的指令:irmovq、rrmovq、mrmovq、rmmovq分别显示地指明源和目的的格式。源可以是立即数(i)、寄存器(r)或内存(m)。目的可以是寄存器(r)或内存(m)。两个内存传送指令中的内存引用方式是简单的基址和偏移量形式。
  • 有4个整数操作指令,如下图中的OPq。它们是addq、subq、andq和xorq。它们只对寄存器数据进行操作,而x86-64还允许对内存数据进行这些操作,这些指令会设置3个条件码ZF、SF和OF。
  • 7个跳转指令是jmp、jle、jl、je、jne、jge、jg。
  • 有6个条件传送指令:cmovle、cmovl、cmove、cmovne、cmovge、cmovg。这些指令的格式与寄存器-寄存器传送指令rrmovq一样,但是只有当条件码满足所需要的约束时,才会更新目的寄存器的值。
  • call指令将返回地址入栈,然后跳到目的地址。ret指令从这样的调用中返回。
  • pushq和popq指令实现了入栈和出栈,就像在x86-64中一样。
  • halt指令停止指令的执行。x86-64中有一个与之相当的指令hlt。x86-64的应用程序不允许使用这条指令,因为他会导致整个系统暂停运行。
  • 每个指令需要1~10个不等的字节。每条指令的第一个字节表明指令的类型。这个字节分为两部分,每部分4位:高4位是代码部分,低4位是功能部分。
  • 在指令编码中以及在我们的硬件设计中,当需要指明不应该访问任何寄存器时,就用ID值0xF来表示。
数字寄存器名字数字寄存器名字
0%rax8%r8
1%rcx9%r9
2%rdxA%r10
3%rbxB%r11
4%rspC%r12
5%rbpD%r13
6%rsiE%r14
7%rdiF无寄存器

-Y86-64异常,对于Y86-64来说,程序员可见的状态包括状态码State,它描述程序执行的总体状态。当遇到这些异常的时候,我们就简单地让处理器停止执行指令

名字含义
1AOK正常操作
2HLT遇到器执行halt指令
3ADR遇到非法地址
4INS遇到非法指令
  • 逻辑设计和硬件控制语言HCL,在硬件设计中,用电子电路来计算对位进行运算的函数,以及在各种存储器单元中存储位,逻辑1是用1.0伏特左右的高电压表示的,而逻辑0是用0.0伏特左右的低电压表示的。
  • AND用&&表示,OR用||表示,而NOT用!表示,我们用这些符号而不用C语言中的位运算符&、|和~,这是因为逻辑们只对单个位的数进行操作。
  • 将很多的逻辑们组合成一个网,就能构建计算块,称为组合电路。如何构建这些网有几个限制:
    1.每个逻辑们的输入必须连接到下述选项之一:

    1)一个系统输入(成为主输入)

    2)某个存储单元的输出

    3)某个逻辑门的输出。

    2.两个或多个逻辑们的输出不能连接在一起。否则它们可能会实现上的信号矛盾,可能会导致一个不合法的电压或电路故障。

    3.这个网必须是无环的,也就是在网中不能有路经经过一系列的门而形成一个回路,这样的回路会导致该网络计算的函数有歧义。
  • HCL表达式很清楚地表明了组合逻辑电路和C语言中逻辑表达式的对应之处。它们都是用布尔操作来对输入进行计算的函数,但是有以下区别:
    1.因为组合电路是由一系列的逻辑门组成,它的属性输出会持续地响应输入的变化,如果电路的输入变化了,在一定的延迟之后,输出也会相应地变化,而C表达式只会在程序执行过程中被遇到时才进行求值。
    2.C的逻辑表达式允许参数是任意整数,0表示FLASE,其他任何值都表示TRUE,而逻辑门只对位值0和1进行操作。
    3.C的逻辑表达式有个属性就是它们可能只被部分求值。如果一个AND或OR操作的结果只用对第一个参数求值就能确定,那么就不会对第二个参数求值了。
  • 在处理器设计中,很多时候都需要将一个信号与许多可能匹配的信号做比较,以此来检测正在处理的某个指令代码是否属于某一类指令代码。
  • 时钟寄存器存储单个位或字。时钟信号控制寄存器加载输入值。
  • 随机访问存储器存储多个字,用地址来选择该读或该写哪个字。
  • 通常,处理一条指令包括很多操作,将他们组织成某个特殊的阶段序列,即使指令的动作差异很大,但所有的指令都遵循统一的序列。下面是关于各个阶段以及各阶段内执行操作的简略描述:
    1.取指:取指阶段从内存读取指令字节,地址为程序计数器(PC)的值。从指令中抽取出指令指示符字节的两个四位部分,称为icode和ifun。它可能去出一个寄存器值指示符字节,指明一个或两个寄存器操作数指示符rA和rB。他还可能取出一个四字节常数字valC。他按顺序方式计算当前指令的下一跳指令的地址valP。
    2.译码:译码阶段从寄存器文件读入最多两个操作数,得到值valA和/或valB。通常,他读入指令rA和rB字段指明的寄存器,不过有些指令是读寄存器%rsp的。

    3.执行:在执行阶段,算术\逻辑单元要么执行指令指明的操作,计算内存引用的有效地址,要么增加或减少栈指针。得到的值我们称为value。在此,也可能设置条件码。对一条条件传送指令来说,这个阶段会检验条件码和传送条件,如果条件成立,则更新目标寄存器。

    4.访存:访存阶段可以将数据写入内存,或者从内存中读出数据。读出的值为valM。

    5.写回:写回阶段最多可以写两个结果到寄存器文件。

    6.更新PC:将PC设置成下一条指令的地址。
  • SEQ阶段的实现
    在控制逻辑中必须被显式引用的常数:(常数值都是大写的)

1072918-20171104104153060-1550489194.png

nop指令只是简单的经过各个阶段,除了将PC加1,不进行任何处理。halt指令是处理器状态被设置为HLT,导致处理器停止运行。
实验楼环境

1072918-20171104104202701-1229261320.png

教材学习中的问题和解决过程

代码调试中的问题和解决过程

代码托管

image

上周考试错题总结

  • 错题1及原因,理解情况
  • 错题2及原因,理解情况
  • ...

结对及互评

点评模板:

  • 博客中值得学习的或问题:
    • xxx
    • xxx
    • ...
  • 代码中值得学习的或问题:
    • xxx
    • xxx
    • ...
  • 其他

本周结对学习情况

[20155317](http://www.cnblogs.com/wxwddp/p/7671075.html)
![image](http://note.youdao.com/favicon.ico)
- 结对学习内容- XXXX- XXXX- ...

其他(感悟、思考等,可选)

xxx
xxx

学习进度条

代码行数(新增/累积)博客量(新增/累积)学习时间(新增/累积)重要成长
目标5000行30篇400小时
第一周200/2002/220/20
第二周300/5002/418/38
第三周500/10003/722/60
第四周300/13002/930/90

尝试一下记录「计划学习时间」和「实际学习时间」,到期末看看能不能改进自己的计划能力。这个工作学习中很重要,也很有用。
耗时估计的公式
:Y=X+X/N ,Y=X-X/N,训练次数多了,X、Y就接近了。

参考:软件工程软件的估计为什么这么难,软件工程 估计方法

  • 计划学习时间:XX小时

  • 实际学习时间:XX小时

  • 改进情况:

(有空多看看现代软件工程 课件
软件工程师能力自我评价表)

参考资料

  • 《深入理解计算机系统V3》学习指导
  • ...

转载于:https://www.cnblogs.com/fengxingck/p/7782690.html

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

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

相关文章

Dubbo原理解析-监控

Dubbo发布代码中,自带了一个简易的监控中心实现。对于一般的小业务这个监控中心应该能够满足需求,对于那些大业务量的大公司一般都会有自己的监控中心,更加丰富的功能如常用的报警短信通知等等。这章讲解分析使得读者能够了解一般的监控中心实…

学习笔记(04):Python网络编程并发编程-什么是socket

立即学习:https://edu.csdn.net/course/play/24458/296233?utm_sourceblogtoedu 1.什么是网络编程? 答:网络编程也叫做socket编程即套接字编程,基于遵循socket套接字的规定进行的编程 2.什么是socket? 答:socket就是…

JeeSite 4.0 说说前端的那些事

2019独角兽企业重金招聘Python工程师标准>>> 引言 一个不得不说的话题,经过近几年的发展,Web前端开发已经不是一个新有的岗位了,前端技术发展非常迅速,技术更新换代也很快,对于前端工程师来说是一个很大的挑…

程序包com.sun.istack.internal不存在

添加一下依赖 <!-- https://mvnrepository.com/artifact/com.sun.xml.bind/jaxb-impl --><dependency> <groupId>com.sun.xml.bind</groupId> <artifactId>jaxb-impl</artifactId> <version>2.2.11</version></dependency&…

iOS微博项目(七)发微博和定位

class a导入class b&#xff0c;class b导入class a 会出现错误 如果keyboard不显示&#xff0c;应该是hardware-》connect选择了 1. 发微博UI 2.定位 一直不回调&#xff0c;后来发现是ios8后方法更新了&#xff1a;http://blog.devzeng.com/blog/ios8-corelocation-framework…

设计模式之UML类图

在学设计模式的过程中经常碰到各式各样的UML类图。那些眼花缭乱的符号有什么含义呢&#xff1f; 类图含义 类图中的关系 从网上找来一张图作为实例 依赖关系&#xff1a;比如动物依赖氧气和水&#xff0c;这里如学生要依赖自行车。用虚线箭头表示。关联关系&#xff1a;学生和身…

tomcat启动报:No Spring WebApplicationInitializer types detected on classpath

2019独角兽企业重金招聘Python工程师标准>>> 对于maven项目&#xff0c;tomcat启动不加载spring配置文件&#xff0c;是因为找不到web.xml文件 右键项目properties 选择 Deployment Assembly 编辑 Web Deployment Assembly&#xff0c;注意主要是红色线框中的路径 …

Linux-正则表达式学习(精)

正则表达式30分钟入门教程 来园子之前写的一篇正则表达式教程&#xff0c;部分翻译自codeproject的The 30 Minute Regex Tutorial。 由于评论里有过长的URL,所以本页排版比较混乱,推荐你到原处查看,看完了如果有问题,再到这里来提出. 一些要说的话&#xff1a; 如果你没有正则表…

Flume sink=avro rpc connection error

要求 conf 文件 a1.sourcesr1 a1.sinksk1 a1.channelsc1a1.sources.r1.typeavro a1.sources.r1.bindmaster a1.sources.r1.port9999a1.sinks.k1.typeavro a1.sinks.k1.hostnameslave1 a1.sinks.k1.port7777a1.channels.c1.typememory a1.channels.c1.capacity1000 a1.channels.…

【腾许Bugly干货分享】“HTTPS”安全在哪里?

背景 最近基于兴趣学学习了下 HTTPS 相关的知识&#xff0c;在此记录下学习心得。 在上网获取信息的过程中&#xff0c;我们接触最多的信息加密传输方式也莫过于 HTTPS 了。每当访问一个站点&#xff0c;浏览器的地址栏中出现绿色图标时&#xff0c;意味着该站点支持 HTTPS 信息…

CCNP精粹系列之十八--路由映射实战二,博主推荐文章

路由映射实战二 本篇博文和上一篇是紧密结合的&#xff0c;只是在上个试验的基础上作了改动&#xff0c;达到其他的试验效果。试验二&#xff1a;在R1上增加一个网段&#xff0c;并发布路由。这里采用三种方法。 如下是第一种&#xff0c;是在试验一的基础上直接增加一个网段&a…

【JUC】JDK1.8源码分析之ConcurrentLinkedQueue(五)

一、前言 接着前面的分析&#xff0c;接下来分析ConcurrentLinkedQueue&#xff0c;ConcurerntLinkedQueue一个基于链接节点的无界线程安全队列。此队列按照 FIFO&#xff08;先进先出&#xff09;原则对元素进行排序。队列的头部是队列中时间最长的元素。队列的尾部 是队列中时…

学习笔记(10):Python网络编程并发编程-粘包现象

立即学习:https://edu.csdn.net/course/play/24458/296240?utm_sourceblogtoedu粘包现象&#xff1a;服务器接收到客户端的命令后&#xff0c;进行执行得到结果后&#xff0c;再发送回给客户端&#xff0c;在这个过程中如果服务器返回的结果的字节数会大于客户端所接收最大字节…

学习笔记(11):Python网络编程并发编程-粘包底层原理分析

立即学习:https://edu.csdn.net/course/play/24458/296241?utm_sourceblogtoedu1.send和recv底层分析 1&#xff09;不管是recv还是send都不是直接接收对方数据或者发送给对方数据&#xff0c;而是对自己的操作系统内存进行操作&#xff1b; 2&#xff09;客户端与服务端并不是…

VMware内存回收与分配机质

VMware内存回收与分配机质 整理了下学习过的东西&#xff0c;为了防止以后忘记。^_^VMware内存回收按照内存回收先后顺充&#xff0c;依次为&#xff1a;1.TPS 透明页共享2.Ballooning 气球回收3.Compressiong 内存压缩4.Swapping 内存交换网上对这个的解释也挺多&#xff…

关于for循环中的变量int i 如果跳出了这个for循环后,i的值是继续保留还是被释放掉了

#include<iostream> using namespace std;int main() {char a[10]; //定义一个一维数组用来存放字符串int i,j; //定义变量cout<<"请输入字符&#xff1a;“;for(i0;i<10;i) //接收用户的输入{ ci…

C#多态

C#多态 多态性&#xff08;C# 编程指南&#xff09;转自MSDN通过继承&#xff0c;一个类可以用作多种类型&#xff1a;可以用作它自己的类型、任何基类型&#xff0c;或者在实现接口时用作任何接口类型。这称为多态性。C# 中的每种类型都是多态的。类型可用作它们自己的类型或用…

C#项目中常用到的设计模式

C#项目中常用到的设计模式 1. 引言 一个项目的通常都是从Demo开始&#xff0c;不断为项目添加新的功能以及重构&#xff0c;也许刚开始的时候代码显得非常凌乱&#xff0c;毫无设计可言。但是随着项目的迭代&#xff0c;往往需要将很多相同功能的代码抽取出来&#xff0c;这也是…

分布式数据库 HBase

原文地址&#xff1a;http://www.oschina.net/p/hbase/ HBase 概念 HBase – Hadoop Database&#xff0c;是一个高可靠性、高性能、面向列、可伸缩的分布式存储系统&#xff0c;利用HBase技术可在廉价PC Server上搭建起大规模结构化存储集群。 HBase是Google Bigtable的开源实…

学习笔记(15):Python网络编程并发编程-进程理论

立即学习:https://edu.csdn.net/course/play/24458/296423?utm_sourceblogtoedu 1.进程&#xff1a;正在运行的一个过程或者一个任务&#xff1b; 2.进程与程序的区别&#xff1a;程序是一堆代码&#xff0c;程序运行起来就是进程了&#xff0c;一个程序运行两次&#xff0c;算…