2018-2019-1 20165318《信息安全系统设计基础》第八周课上测试

2018-2019-1 20165318《信息安全系统设计基础》第八周课上测试

测试-1-ch03

  • 任务详情

    • 通过输入gcc -S -o main.s main.c,将下面c程序“week04学号.c”编译成汇编代码
    int g(int x)
    {
    return x+3;
    }
    int f(int x)
    {
    int i = 学号后两位;
    return g(x)+i;
    }
    int main(void)
    {
       return f(8)+1;
    }
    • 删除汇编代码中 . 开头的代码,提交f函数的汇编代码截图,图中用矩形标出函数栈帧的形成和销毁的代码
  • 测试截图

测试-1-ch03

  • 任务详情

    • 通过输入gcc -S -o main.s main.c,将下面c程序“week04学号.c”编译成汇编代码
    int g(int x)
    {
    return x+3;
    }
    int f(int x)
    {
    int i = 学号后两位;
    return g(x)+i;
    }
    int main(void)
    {
       return f(8)+1;
    }
    • 参考http://www.cnblogs.com/lxm20145215----/p/5982554.html,使用gdb跟踪汇编代码,在纸上画出f中每一条语句引起的eip(rip),ebp(rbp),esp(rsb),eax(rax)的值和栈的变化情况。提交照片,要有学号信息。
  • 命令汇总:
    • “gcc -g week060420165318.c -o week0604 -m32”产生32位汇编,生成可执行文件week0604
    • gdb week0604:使用gdb调试器
    • (以下为在调试状态下的输入)b 10:在主函数处设置行断点
    • r:运行
    • disassemble:显示当前所处函数的反汇编机器码
    • i r:显示各寄存器的值
    • display /i $pc:每次执行下一条汇编语句时,均打印出当前执行的代码
    • si:执行下一条汇编语句
    • x/参数 + 栈指针的值:以参数规定的形式查看栈中某地址单元中的值。eg:x/u 0xffffcfe8;x/2a 0xffffcfe0
  • 实验过程
    • 进入之后先在main函数处设置一个断点,再run一下,使用disassemble指令获取汇编代码

    • i(info) r(registers)指令查看各寄存器的值

    • 可见此时主函数的栈基址为0xffffd108,用x(examine)指令查看内存地址中的值,但目前%esp所指堆栈内容为0,%ebp所指内容也为0

    • 结合display命令和寄存器或pc内部变量,做如下设置:display /i $pc,这样在每次执行下一条汇编语句时,都会显示出当前执行的语句。下面展示每一步时%esp、%ebp和堆栈内容的变化:

    • call指令将下一条指令的地址入栈,此时%esp,%ebp和堆栈的值为:

    • 将上一个函数的基址入栈,从当前%esp开始作为新基址:

    • 先为传参做准备:

    • f函数的汇编代码:

    • 实参入栈:

    • call指令将下一条指令的地址入栈:

    • 计算short+int:

    • pop %ebp指令将栈顶弹到%ebp中,同时%esp增加4字节:

    • ret指令将栈顶弹给%eip:

    • 因为函数f修改了%esp,所以用leave指令恢复。leave指令先将%esp对其到%ebp,然后把栈顶弹给%ebp:

    • 寄存器变化情况
指令 esp ebp eax eip
push %ebp 0xffffd0fc 0x56556fdc 0x56555503
mov %esp,%ebp 0xffffd0fc 0xffffd0fc 0x56556fdc 0x56555505
sub $0x10,%esp 0xffffd0fc 0xffffd0fc 0x56556fdc 0x56555508
call 0x56555549 0xffffd0e8 0xffffd0fc 0x56556fdc 0x56555549
add $0x1acf,%eax 0xffffd0ec 0xffffd0fc 0x56556fdc 0x56555512
movl $0x12,-0x4(%ebp) 0xffffd0ec 0xffffd0fc 0x56556fdc 0x56555519
pushl 0x8(%ebp) 0xffffd0e8 0xffffd0fc 0x56556fdc 0x5655551c
call 0x565554ed 0xffffd0e4 0xffffd0fc 0x56556fdc 0x565554ed
add $0x4,%esp 0x56556fdc 0xffffd0fc 0x1d 0x5655550b
mov %eax,%edx 0xffffd0ec 0xffffd0fc 0x1d 0x56555510
mov -0x4(%ebp),%eax 0xffffd0ec 0xffffd0fc 0x1d 0x5655551a
add %edx,%eax 0xffffd0ec 0xffffd0fc 0x1d 0x5655552b
leave 0xffffd100 0xffffd108 0x1d 0x5655552c
ret 0xffff104 0xffff108 0x1d 0x56555541

原文地址:https://www.cnblogs.com/sunxiaoxuan/p/9867940.html

时间: 2025-01-07 02:37:27

2018-2019-1 20165318《信息安全系统设计基础》第八周课上测试的相关文章

信息安全系统设计基础第八周总结

Linux基本概念 命令行操作 [Tab] 使用Tab键来进行命令补全 [Ctrl+c] 立即停止并恢复到可控状态,可以使用Ctrl+c键来强行终止当前程序(并不会使终端退出) 用户及文件管理权限 一.Linux用户管理 由于 Linux 的 用户管理 和 权限机制 ,不同用户不可以轻易地查看.修改彼此的文件. who 命令其它常用参数 (3)用户组 方式1.使用groups命令 方式2.查看/etc/group文件 /etc/group文件格式说明: /etc/group 的内容包括用户组(G

信息安全系统设计基础第八周学习总结

第十章 系统级I/O 怎样学习系统编程(利用Linux学习Linux编程) 一.Unix I/O 一个Unix文件就是一个m字节的序列:B0,B1,B2,…,Bk,…,Bm-1 二.打开和关闭文件 1.进程通过调用open函数来打开一个已存在的文件或者创建一个新文件的: Int open(char *filename, int flags, mode_t mode); 2.通过调用close函数关闭一个打开的文件: Int close(int fd); 三.读和写文件 1.分别调用read和wr

信息安全系统设计基础第八周学习总结-吕松鸿

第10章 系统级I/O I/O:在主存和外部设备之间拷贝数据的过程. 10.1Unix I/O 一个Unix文件就是一个m个字节的序列: B0,B1,B2…Bk…B(m-1) 1.所有的输入输出都能以一种统一且一致的方式来执行: (1)打开文件 a.描述符:内核返回一个小的非负整数,它在后续对此文件的所有操作中标识这个文件. b. Unix外壳创建的每个进程开始时都有三个打开的文件:标准输入(描述符为0).标准输出(描述符为1).标准错误(描述符为2). (2)改变当前的文件设置. (3)读写文

信息安全系统设计基础第八周学习笔记

系统级I/O 前言:输入/输出是在主存和外部设备(如磁盘驱动器.终端和网络)之间拷贝数据的过程.输入操作时从I/O设备拷贝数据到主存,而输出操作时从主存拷贝数据到I/O设备. 10.1  Unix I/O 一个Unix文件就是一个m个字节的序列:B0,B1,B2,B3...Bk...Bm-1. 所有的I/O设备,如网络.磁盘盒终端,都被模型化为文件,而所有的输入和输出都被当做对相应的文件的读和写来执行.这是一种应用接口,成为Unix I/O. ①打开文件:一个应用程序通过要求内核打开相应地文件,

20145216 史婧瑶《信息安全系统设计基础》第一周学习总结

20145216 <信息安全系统设计基础>第一周学习总结 教材学习内容总结 Linux基础 1.ls命令 ls或ls .显示是当前目录的内容,这里“.”就是参数,表示当前目录,是缺省的可以省略.我们可以用ls -a .显示当前目录中的所有内容,包括隐藏文件和目录.其中“-a” 就是选项,改变了显示的内容.如图所示: 2.man命令 man命令可以查看帮助文档,如 man man : 若在shell中输入 man+数字+命令/函数 即可以查到相关的命令和函数:若不加数字,那man命令默认从数字较

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

20145311 <信息安全系统设计基础>第一周学习总结 教材学习内容总结 常用的部分命令 CTRL+SHIFT+T:新建标签页,编程时有重要应用: ALT+数字N:终端中切换到第N个标签页,编程时有重要应用: Tab:终端中命令补全,当输入某个命令的开头的一部分后,按下Tab键就可以得到提示或者帮助完成: CTRL+C:中断程序运行 Ctrl+D:键盘输入结束或退出终端 Ctrl+S: 暂定当前程序,暂停后按下任意键恢复运行 Ctrl+A: 将光标移至输入行头,相当于Home键 Ctrl+E

20145216史婧瑶《信息安全系统设计基础》第九周学习总结

20145216史婧瑶<信息安全系统设计基础>第九周学习总结 教材内容总结 第十章 系统级I/O 输入/输出(I/O)是在主存和外部设备之间拷贝数据的过程. 第一节 Unix I/O 这一节涉及到操作系统的基本抽象之一--文件.也就是说,所有的I/O设备都被模型化为文件,而所有的输入输出都被当做对相应文件的读/写.相关的执行动作如下: 1.打开文件: 应用程序向内核发出请求→要求内核打开相应的文件→内核返回文件描述符 文件描述符:一个小的非负整数,用来在后续对此文件的所有操作中标识这个文件.有

信息安全系统设计基础第八周期中总结

信息安全系统设计基础第八周期中总结 [学习时间:12小时] [学习内容:CHAPTER1——CHAPTER7内容重点:疑问与考试错题分析:实验环节难点回顾] 一.课本章节内容重点 (一)第一章 1.信息就是“位+上下文”. [理解:信息本身的表示形式是相对固定的,在linux系统内(以及其他的操作系统内),操作信息.数据信息等都是以二进制形式存储的:这些二进制位如何理解.怎么划分,是靠上下文的要求决定的.二者联系起来组成了“信息”的概念.] 2.系统的硬件组成 总线:携带信息字节并负责在各个部件

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

20145311 <信息安全系统设计基础>第二周学习总结 教材学习内容总结 重新学习了一下上周的一部分命令:grep main wyx.c(grep的全文检索功能)ls > ls.txt :ls内容输出到文本find pathname -mtime -n/+nfind -size -n/+n (find的功能还是比较强大) 简单地学习了一下vim编辑器,跟着vimtutor简单地学了一些,在linux bash中使用vim能够极大地提高效率, vim的用法比较多,只学习了其中简单的一部分