2018-2019-1 20165225《信息安全系统设计基础》第三周学习总结

2018-2019-1 20165225《信息安全系统设计基础》第三周学习总结


教材学习内容总结

gcc -Og -o p p1.c p2.c:-Og告诉编译器使用会生成符合原始C代码整体结构的机器代码的优化等级。
gcc -Og -S xxx.c:可看到编译器产生的汇编代码。
objdump -d xxx.o:可查看机器代码文件的内容。
C语言调用机制使用了栈数据结构提供的后进先出的内存管理原则。
call指令有一个目标,即指明被调用过程起始的指令地址。
有些情况下局部数据必须存放在内存中。
寄存器不够存放所有本底数据。
对一个局部变量使用地址运算符“&”。
某些局部变量是数组活结构。
寄存器组是唯一被所有过程共享的资源。必须确保一个过程调用另一过程时,寄存器值不会被覆盖。
处理器:
  • 程序处理器:只是下条将要执行的指令在存储器中的地址
  • 整数寄存器:包含16个命名的位置,分别存储64位值。可用来记录某些文件状态,也可用来保存临时值。
  • 条纹寄存器:保存最近执行的算数或逻辑指令的状态信息。
  • 浮点寄存器:一组向量寄存器可以存放一个或多个证书或浮点数值。

处理器的通用目的寄存器
X86-64的中央处理单元(cpu)包含一组16个存储64位值的通用目的寄存器.

GDB调试
  • 反汇编:objdump -d mstore.o
  • 可在函数入口设置断点,查看各个寄存器和存储器,还可单步跟踪程序,一次执行几条命令
汇编指令
mov类指令:源操作数的值复制到目的操作数中。
movb 传送字节
movw 传送字
movvl 传送双字
movz 零扩展
一元操作
INC 加一
DEC 减一
NEG 取负
NOT 取补
二元操作
ADD 加
SUB 减
IMUL 乘
XOR 异或
OR 或
AND 与
CF:进位标志
ZF:零标志
SF:符号标志
OF:溢出标志
寻址方式

立即数寻址:操作数在指令中直接给出,只能用于源操作数,数据长度应与目的操作数长度匹配。
寄存器寻址:数放在CPU的内部寄存器中,源操作数与目的操作数长度应一致。
存储器寻址:操作数存放在存储器中,指令中给出操作数的偏移地址信息。

本周错题总结

有关gdb调试汇编,下面说法正确的是()

A .可以用disas反汇编当前函数

B .以16进制形式打印%rax中内容的命令是 print /x $rax

C .可以用info registers查看所有寄存器的值

D .可以用info frame 查看所有栈帧的信息

E .可以使用up,down切换栈帧

正确答案: A B C E  你的答案: A E 

- /x是16进制的打印,info registers可查看所有寄存器的值。
下面的跳转指令与ZF有关的是()

A .jmp

B .je

C .js

D .ja

E .jb

F .jbe

正确答案: B D F  你的答案: A B D

- jbe为小于等于跳转,zf可判断跳转结果是否为0
假设用ADD指令完成C表达式t=a+b的功能,有关条件码寄存器的说法正确的是()

A .若t==0  ,则ZF=1

B .若t<0, 则CF=1

C .若t<0, 则SF=1

D .若(a<0==b<0)&&(t<0 != a<0), 则OF=1

E .若(a<0==b<0)&&(t<0 != a<0), 则CF=1

F .leaq指令不影响条件码寄存器

G .cmp指令不影响条件码寄存器

正确答案: A C D F  你的答案: A D F

- 计算结果为负时,sf为1
x86-64 Linux中,函数调用的返回值存在()寄存器中。

A .%rax

B .%rbx

C .%rcx

D .%rsp

E .%rbp

正确答案: A  你的答案: D

- rsp是指向栈顶的寄存器,rax才是寄存器

结对学习

  • 本周依然和5221同学一起复习。

学习进度条

代码行数(新增/累积) 博客量(新增/累积) 学习时间(新增/累积) 重要成长
目标 3500行 12 14小时
第一周 63/150 1/12 3小时
第二周 150/150 2/12 10小时
第三周 150/150 3/12 13小时
posted @ 2018-10-14 17:48  牛奶仔丶  Views(136)  Comments(1Edit  收藏  举报