将大型数组写入内存 x86 程序集 - 使用堆栈的段错误 space

Writing large arrays to memory x86 assembly - segfaults using stack space

我正在尝试使用 AT&T (GAS) 语法将数组写入 x86 程序集中的堆栈。我遇到了一个问题 运行,我可以将 ~837 万个条目写入堆栈,然后如果我尝试再写,我会得到一个 Segmentation fault。我不知道这是为什么,这是我使用的代码:

    mov %rsp, %rbp
    mov 78658, %rdx
writeDataLoop:
    sub %rdx, %rbp
    movb [=11=]b1, (%rbp)

    add %rdx, %rbp

    sub , %rdx
    cmp [=11=], %rdx
    jg writeDataLoop

我发现的另一个奇怪的事情是,我可以写入数据的限制随着每个 运行 的变化非常小(大约在 8378658,这在十六进制中也没有什么意义(0x7fd922 )。谁能告诉我如何向堆栈写入更多数据,并可能解释一下这个任意堆栈写入限制是什么?谢谢。

首先,默认堆栈大小为 8MB,这是我达到的堆栈限制。这可以通过 ulimit -a 命令找到。但是,不应该 对大量数据(通常是数组)使用堆栈。相反,应该使用 .space 指令,它使用 AT&T 语法,以字节为单位获取要存储的数据量:.space <buffersize>。这可以被标记,例如:

buffer: .space 1024

这会为标签 buffer 分配 1024 字节的存储空间。此标签应位于程序的 .bss 部分,允许读写访问。

最后,要访问此数据(读取或写入),可以使用 buffer(%rax),其中 rax 是偏移量。

编辑: 使用 .bss 部分在文件大小方面比使用 .data 部分更有效,您只需手动初始化数组。