将大型数组写入内存 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
部分更有效,您只需手动初始化数组。
我正在尝试使用 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
部分更有效,您只需手动初始化数组。