gdb调试

gdb常用命令:

  1. Run :跑一遍程序
  2. Start :通过 gdb 内部识别程序的入口点(没有反调试程序下),并下断点,给出反编译指令
  3. i:查看内部(insight) I r 就是查看寄存器 ,I b 就是查看断点
  4. Disassemble 某个函数名字(地址):反编译
    Disassemble $rip :寄存器内容看作地址,反编译
    Set disassembly-flavor intel :设置x86下的汇编,再反编译即可
  5. B 设置断点  ,使用方式: b *地址
  6. Ni   下一条指令 (单步执行)
  7. D (number of interrupt) 删除某断点
  8. Disable b (number of interrupt)让某断点失效
  9. Finish (步出),执行完某个函数
  10. Print $rip  打印某个寄存器的值
  11. X     :
    /20gx :16进制(x),g是8个字节为一组
    /20i $rip : 从 $rip 开始,反编译 20 行
    /20b $rip:从某个地址,一个一个字节去看内存的值,20个字节
    注:x命令,组间地址是从左到右递增的,但是组内地址是从右到左由低变高。什么意思?x/20gx :8字节为一组,从左到右每一组地址递增,但是一组间(8字节)地址却从右到左递增
  12. 如果是x/20wx:则是4个字节为一组,以此类推

  13. P :显示内容,即print
  14. Set 赋值指令:set * 地址=值  ; set $rip=值
  15. 寄存器:

    Eflags : 为了记住,直接贴图

  16. Eflags 下的跳转指令:

  17. 关于 64位 对 32 位的兼容:

    老配方,rax 前32位就是 eax,以此类推

  18. 编译器视角下的寄存器:一段程序,无论定义多少变量。在使用这些变量时,编译出来的机器码(汇编),多数情况会用寄存器来操作这些变量,很少会放进进程的虚拟内存中,因为慢(涉及到分页过程,从cpu到内存,再从内存到寄存器)。

    汇编指令:

  19. Lea : 以前是用来载入偏移地址到某个寄存器中,现在的编译器(升级)把它当成一条计算指令,即 lea rax,[rbp-0x18]  等于 把rbp减去0x18 再赋值给 rax。这些变化,习惯就好。
  20. JNE
  21. 其中,cmp al,0x61 让al 与 0x61相减,结果保留在 ZF 位(是否相等)、CF位(看谁大谁小);jne 0x4007bc (如果ZF位不等于0,则跳转到该地址)

    其中,源码为 if (b[0]='a'){ fun (sh);} else { return 0;}
     

    Cmp 与 sub 的区别:前者不会赋值只作比较,后者会将结果赋给寄存器

  22. Movzx eax,byte ptr [rbp-0x10]
  23. BYTE WORD DWORD QWORD

     8 位    16 位     32 位     64 位

    ptr : 指针 ,意味着要去 [rbp-0x10]这个地址取内容,放入eax中

  24. Test 与 and 区别:前者不会修改内容,只作计算,后者会
  25. 练习:

  26. 练习二:不可见字符

  27. 不可见字符:shell 中输入的字符都是可见字符,但是程序中的(cmp al,0x10 ) :0x10 是不可见字符,怎么办?

  28. 直接修改内存,将$rbp-0x10 处地址的值修改为0x10
  29. 修改rax寄存器
  30. 在shell终端输入不可见字符是不行的,需要利用py脚本
  31. 练习三:指针跳转

    代码逻辑:
     

    if([rdp-0x10]==0){

    Goto <main+92>;

    Else{

    Rdx = [rdp-0x10];

    Goto Rdx;

    }
    按照逻辑,查找getshell的函数地址,赋值给rdx

    Set $rdx = func



  32. 并没有跳转到func,发现是源码有问题:

     

    把 system(cmd)修改为 system(sh),编译后再试一下。

    同样的操作,让程序断在 call edx 时,直接修改rdx

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
FreeRTOS是一个开源的实时操作系统,它提供了一套用嵌入式系统的任务调度和管理机制。GDB(GNU Debugger)是一个功能强大的调试工具,可以用于调试C/C++程序。在使用FreeRTOS进行开发时,可以结合GDB进行调试。 要在FreeRTOS中使用GDB进行调试,需要进行以下几个步骤: 1. 配置编译器:首先,需要确保你的编译器支持GDB调试功能。常用的编译器如GCC和Keil都支持GDB调试。 2. 编译选项:在编译FreeRTOS应用程序时,需要添加一些编译选项以支持GDB调试。例如,在GCC中,可以使用"-g"选项来生成调试信息。 3. 连接器脚本:在链接应用程序时,需要使用连接器脚本来指定调试信息的位置。连接器脚本可以告诉GDB在哪里找到符号表和调试信息。 4. 启动GDB调试:在编译和链接完成后,可以使用GDB启动调试会话。可以通过命令行输入"gdb"命令来启动GDB,并使用"target remote"命令连接到目标设备。 5. 设置断点:在GDB中,可以使用"break"命令设置断点。可以设置函数断点、行号断点或地址断点等。 6. 执行调试:一旦设置好断点,可以使用GDB调试命令来执行程序。可以使用"run"命令来运行程序,使用"step"命令逐行执行,使用"next"命令执行下一行,使用"continue"命令继续执行等。 7. 查看变量:在调试过程中,可以使用GDB的"print"命令来查看变量的值。可以使用"info locals"命令查看局部变量,使用"info global"命令查看全局变量等。 8. 结束调试:当调试完成后,可以使用GDB的"quit"命令退出调试会话。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值