临时数据如何存储在堆栈帧上

时间:2018-03-03 09:09:47

标签: c gcc stack-overflow buffer-overflow

Int test(){
    char buff[10]

    printf("Enter text: ");

    gets(buff);

    puts(buff);
}

我不知道如何说出这个问题,但我试图理解如何将值存储在堆栈帧上为局部变量分配的缓冲区中。

---------------
Return Address
---------------
old ebp
---------------
local variables
--------------- 

每个块是4个字节还是4个1字节?

------------------
 00 | 40 | 06 | 06
------------------
 ff | ff | de | 70 
------------------

通过gdb,我看到为测试分配的缓冲区是0x10

我输入sssssssss

x/x $rbp = 0xffffde70
x/x $rbp + 8 = 0x00400606
x/s $rbp - 16 = "sssssssss"
x/s $rbp - 8 = "\ns"
x/s $rbp - 4 = ""

那么我输入的字符(十六进制)是如何存储的?喜欢每个街区有多少。这是一个64系统。

 -----------------
 00 | 40 | 06 | 06
------------------
 ff | ff | de | 70 
------------------
    |    |    | 
------------------
    |    |    | s
------------------
 s  | s  | s  | s
------------------
 s  | s  | s  | s 
------------------

1 个答案:

答案 0 :(得分:2)

从严格的C角度来看,我们不知道。

标准没有具体说明。该标准甚至没有提到堆栈的概念。从标准的角度来看,代码是在抽象机器上执行的(即没有描述机器是如何做到的。只有机器必须做的事情。)

所以它是如何完成取决于具体的实现,它(可能)因系统而异。

您需要找到您正在使用的系统的ABI文档。 ABI文档将描述如何在您的系统上完成它。

请参阅en.wikipedia.org/wiki/Application_binary_interface

也许阅读Where is the x86-64 System V ABI documented?