我可以访问高于初始堆栈指针多远而不会出错?

问题描述

在这个 GAS 代码中:

    .text
    .section    .rodata
.LC0:
    .string "%ld\n"
    .text
    .globl  main
    .type   main,@function
main:
    endbr64 
    pushq   %rbp    
    movq    %rsp,%rbp  
    subq    $16,%rsp   
    #HOW FAR CAN I GO FROM BASE POINTER?
    movq    10000(%rbp),%rax   
    movq    %rax,%rsi  
    leaq    .LC0(%rip),%rdi    
    movl    $0,%eax    
    call    printf@plt  
    movl    $0,%eax    
    leave   
    ret 

我正在寻址 10000(%rbp),它有时会终止,有时会在该地址处给出一个值。所以问题是,我可以寻址离堆栈中的基指针多远,换句话说,内核为我的进程分配了多大的堆栈?是常数吗?它是可变的?我在哪里可以找到?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)