美文网首页
一些汇编的知识顺便填上 通用gadget_libc_csu_in

一些汇编的知识顺便填上 通用gadget_libc_csu_in

作者: zs0zrc | 来源:发表于2018-05-09 20:54 被阅读120次

我写这篇博客主要是因为某人对我发起的灵魂拷问
为什么level5利用_libc_csu_init 的gadget构造的payload要在末尾加上0x38个填充字符
我听到这个问题是很蒙蔽的,我当时想当然的讲是用来维持栈平衡的,然rsp的值变成初始状态,可是经过一番深刻的讨论发现,不是这样子的,然后那个diaomao 就出去浪了,留我一个人思考这个问题,网上也没有大佬说明过这个问题,所以自己想了想
首先这个问题需要有一定的汇编基础:(因为这道题是64位的,所以我主要讲64位的汇编)

pop (出栈):将栈顶的元素弹出栈,然后栈指针rsp + 8
相当于:

mov (%rsp),%register
add $8,%rsp

push(入栈):栈指针rsp - 8 然后将元素压入栈中
相当于:

sub $8,%rsp
mov $argument,(%rsp)

leave : 将栈帧指针rbp的值赋给rsp ,然后将栈中保存的上一级函数的rbp值弹出
相当于:

mov %rbp,%rsp
pop %rbp

ret :返回,将当前栈顶的元素弹出栈中,传到rip中
相当于:

pop %rip

call:格式: call &address 先将address地址压入rip中,然后将call下一条指令作为返回地址压入栈中

enter:用作函数的开头
相当于:

push %rbp
mov %rsp,%rbp

汇编基础了解完了还要了解一下栈的空间分布(以level5的栈空间为例)在脚本发送完payload后 函数的栈空间布局

image.png

基本上就是这个样子,函数的返回地址被精心构造的payload覆盖成gadget的地址
然后我们就可以开始解释为什么payload后面要填充0x38个字符了

image.png

rsp的变化:

image.png

上面两幅图应该解释的很清楚了,所以填充0x38个字符'a'是为了控制rsp最后指向我们想要返回的函数的地址,正确的返回

相关文章

  • 一些汇编的知识顺便填上 通用gadget_libc_csu_in

    我写这篇博客主要是因为某人对我发起的灵魂拷问为什么level5利用_libc_csu_init 的gadget构造...

  • 汇编简介

    学习汇编两大知识点:1.汇编指令2.寄存器 64bit:RAX \RBX\RCX\RDX :通用寄存器32bit:...

  • 【Note】Assembler

    简单回顾下汇编相应知识点 一.寄存器 通用寄存器:ax(累加) bx(基址) cx(计数) dx(数据)段寄存器:...

  • 函数调用约定

    最近在研究反汇编相关的东西,看到了一些汇编中函数调用的约定,顺便记录下来。 cdeclx86体系结构的许多C编译器...

  • ARM64 学习

    iOS汇编 真机 arm64汇编,GNU 模拟器 x86, AT&T 汇编 寄存器 指令 堆栈 通用寄存器 64b...

  • 补充一些汇编的知识

    关于指令和数据 指令和数据都是应用上的概念, 在内存和磁盘中,指令和数据没有任何区别 一个CPU有N根地址线, 可...

  • 一些汇编知识总结

    一、参数和局部变量的布局:_cdecl调用约定,stdcall约定,函数参数入栈:(从右往左)(只有pascal是...

  • 汇编跟踪 Objc alloc 实现 & init

    今天看了一些关于 Objc 相关的知识,也是一些基础部分的知识。使用汇编来查看 alloc 的实现过程。 然后分享...

  • 2.4通用寄存器下

    2.4通用寄存器下 本节必须掌握的知识点: u掌握DTDebug界面、并熟练使用 u熟记汇编窗口的组成及寄存器窗口...

  • 通用寄存器和初识汇编

    title: 通用寄存器date: 2018-12-11tags:- 滴水逆向- 汇编- 32位通用寄存器cate...

网友评论

      本文标题:一些汇编的知识顺便填上 通用gadget_libc_csu_in

      本文链接:https://www.haomeiwen.com/subject/abgorftx.html