gpt4 book ai didi

c - 修改栈上的返回地址

转载 作者:太空狗 更新时间:2023-10-29 17:13:23 26 4
gpt4 key购买 nike

我查看了缓冲区溢出漏洞的基础知识,并试图了解堆栈的工作原理。为此,我想编写一个简单的程序,将返回地址的地址更改为某个值。谁能帮我计算出基指针的大小以获得第一个参数的偏移量?

void foo(void)
{
char ret;
char *ptr;

ptr = &ret; //add some offset value here
*ptr = 0x00;
}

int main(int argc, char **argv)
{
foo();

return 1;
}

生成的汇编代码如下所示:

    .file   "test.c"
.text
.globl foo
.type foo, @function
foo:
.LFB0:
.cfi_startproc
pushq %rbp
.cfi_def_cfa_offset 16
.cfi_offset 6, -16
movq %rsp, %rbp
.cfi_def_cfa_register 6
leaq -9(%rbp), %rax
movq %rax, -8(%rbp)
movq -8(%rbp), %rax
movb $0, (%rax)
popq %rbp
.cfi_def_cfa 7, 8
ret
.cfi_endproc
.LFE0:
.size foo, .-foo
.globl main
.type main, @function
main:
.LFB1:
.cfi_startproc
pushq %rbp
.cfi_def_cfa_offset 16
.cfi_offset 6, -16
movq %rsp, %rbp
.cfi_def_cfa_register 6
subq $16, %rsp
movl %edi, -4(%rbp)
movq %rsi, -16(%rbp)
call foo
movl $1, %eax
leave
.cfi_def_cfa 7, 8
ret
.cfi_endproc
.LFE1:
.size main, .-main
.ident "GCC: (GNU) 4.7.1 20120721 (prerelease)"
.section .note.GNU-stack,"",@progbits

foo 帧段的相关部分应如下所示:

[char ret] [基址指针] [返回地址]

我有第一个只有 1 个字节大小的位置。它是否仅比基指针或字的大小更远 1 个字节,如 http://insecure.org/stf/smashstack.html 中所述?我如何知道基指针的大小?

最佳答案

您无法在 vanilla C 中执行此操作,您无法控制编译器如何布置堆栈帧。

在 x86-64 中,返回地址应该在 %rbp + 8。您可以使用一些内联汇编来获取它(gcc 语法):

uint64_t returnaddr;
asm("mov 8(%%rbp),%0" : "=r"(returnaddr) : : );

类似地设置它。

即使这样也有点粗略,因为您不知道编译器是否会设置 %rbp。 YMMV.

关于c - 修改栈上的返回地址,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12630213/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com