20145328 《信息安全系统设计基础》第5周学习总结

20145328 《信息安全系统设计基础》第5周学习总结

教材学习内容总结

本周学习内容为《深入理解计算机系统》第三章,主要内容基于两种相关的机器语言:Intel IA32x86-64

3.1 历史观点

简要介绍了从最开始78年29K个晶体管的8086到08年781M个晶体管的Core i7的Intel系列处理器发展过程

X86寻址方式经历三代
  1. DOS时代的平坦模式,不区分用户空间和内核空间,很不安全
  2. 8086的分段模式
  3. IA32的带保护模式的平坦模式
摩尔定律:

在未来十年,芯片上的晶体管数量每年都会翻一番。

事实证明摩尔定律的预测不仅有点乐观,而且短视。在超过45年中,半导体工业一直能够使晶体管数目每18个月翻一番。

备注:一开始并不能理解乐观且短视是什么意思,多次阅读进行理解才明白。短视是因为在摩尔定律中的预测是未来十年,而实际中已超过45年,乐观则是因为预测中翻一番的时间是以每年来进行计算,而实际情况中则是每18个月才翻一番。这就是摩尔定律乐观且短视的原因。

3.2 程序编码

两种抽象
  • 指令集体系结构
    • 定义:机器级程序的格式和行为,即指令集体系结构(Instruction set architecture,ISA)
    • 定义了处理器状态、指令的格式,以及每条指令对状态的影响。
  • 虚拟地址
    • 定义:机器级程序使用的存储器地址
    • 虚拟地址所提供的存储器模型看上去是一个非常大的字符数组。
    • 实际实现:将多个硬件存储器和操作系统软件组合起来。
汇编代码
  • 在表示上非常接近于机器代码
  • 比起机器代码的二进制格式,汇编代码的文本格式可读性更高

  • 与C语言差别非常大
  • 通常对C语言程序员隐藏的处理器状态是可见的。
    • 程序计数器%eip:指示将要执行的下一条指令在存储器中的位置
    • 整数寄存器文件:包含8个命名的位置,分别存储32位的值
    • 条件码寄存器:保存着最近执行的算术或逻辑指令的状态信息。用来实现控制或数据流中的条件变化。
    • 浮点寄存器:存放浮点数据
  • 程序存储器包含:
    • 程序的可执行机器代码
    • 操作系统需要的一些信息
    • 用来管理过程调用和返回的运行时栈
    • 用户分配的存储器块
代码示例

885560-20161016195349983-687091799.png

  • 通过gcc -S xxx.c -o xxx.s获得汇编代码
  • Ubuntu中gcc编译无法识别-01,所以直接使用gcc -S code.c即可
  • 64位Ubuntu下得到的汇编代码如下,

885560-20161016195447217-146386304.png

  • 在64位机器上输入gcc -m32 -S xxx.c可以得到32位汇编代码

885560-20161016195426030-683643641.png

  • objdump -d xxx反汇编

885560-20161016221617452-1996696912.png

-------博客内容加载中,请稍后--------

课后练习

885560-20161016234717983-392423548.png

885560-20161016234807624-1458444749.png

代码托管情况

885560-20161016234830983-1264249780.png

代码托管地址→代码托管地址

学习中遇到的问题

好多。。。看不完。。。。

心得体会

本周学习的内容是汇编相关的,由于上个学期没有选汇编这门课,没有汇编基础,所以在看书的时候只能一点一点的来,感觉这一块的只是其实并没有想象中的那么难,但是量真的好大,从上个星期说了要边看书边写博客之后,这周基本上都是对着书一点一点的来,但是好像又看得太细了,导致速度真的很慢,还有好多东西并没有看完,可能之后还是要稍微加快点进度,分辨出哪些东西需要细看哪些不需要。

学习进度条

代码行数(新增/累积)博客量(新增/累积)学习时间(新增/累积)重要成长
目标5000行30篇400小时
第一周0/01/220/40
第二周63/631/320/60
第三周0/631/420/80
第四周0/631/520/100
第五周45/631/620/120

参考资料

转载于:https://www.cnblogs.com/rebrust/p/5968265.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值