csapp深入理解计算机系统 bomb lab(1)phase_4

使用 disas phase_4 查看phase_4的汇编代码

按照惯例,查看一下0x4025cf内存单元存放的字符串的值是什么

所以phase_4的输入应该是两个整数。

下面使用先猜想后验证的方法尝试找出两个整数的值,猜想两个整数为1,2,在ans.txt写入1,2(前面3行是前面3个phase的答案。)vim ans.txt

Border relations with Canada have never been better.
1 2 4 8 16 32
1 311
1 2

在phase_4的地方打上断点

(gdb) b phase_4
Breakpoint 1 at 0x40100c

 使用ans.txt作为输入进行调试

(gdb) run ans.txt
Starting program: /root/CSAPP-Labs/labs/bomb/bomb ans.txt
[Thread debugging using libthread_db enabled]
Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
Welcome to my fiendish little bomb. You have 6 phases with
which to blow yourself up. Have a nice day!
Phase 1 defused. How about the next one?
That's number 2.  Keep going!
Halfway there!

Breakpoint 1, 0x000000000040100c in phase_4 ()

使用si以逐个指令的方式进入phase_4

注意进入scanf后需要输入finish跳出scanf,执行call 下一条指令。

打印$eax的值发现是2,所以cmp $0x2,%eax的作用是判断输入整数的个数是否是2,如果不是2,就跳到41行explode。

接下来比较0xe,和0x8(%rsp)的值。

可以使用p *(int *)($rsp+0x8)看到0x8(%rsp)存放第一个输入的数字。

之后,保存了一些变量之后进入fun4。直接使用finish跳出fun4。

test %eax,%eax判断%eax是否是0。

当第一个数为1时,%eax为0(瞎猜的),所以继续。

之后又比较0xc(%rsp)和0的大小,不相同时explode,所以第二个数为0。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值