1

使用 YASM 我尝试为 2000 个四字保留空间,但是当我这样做时,当我尝试写入保留的四字块时,我得到一个 SIGSEGV。如果我只为 300 个四字保留空间,程序运行不会出错。这是什么原因造成的?

; Using Windows 7 (Intel Celeron 64-bits)
; yasm -f win64 -l forth.lst forth.asm
; gcc -o forth forth.obj

segment .data
controlstr db "%x", 13, 10, 0

segment .bss
dictionaryspace resq 2000
datastackspace  resq 300
databottom  dq 0
returnstackspace resq 300
returnbottom dq 0

segment .text
global main
extern printf

main:
push rbp                ; setup stack frame
mov rbp, rsp
sub rsp, 32             ; reserve space

lea r15, [databottom]   ; initialize data stack pointer
sub r15, 8              ; point to the last word in data stack

mov rax, 666
mov [r15], rax          ; SIGSEGV happens here.

mov rdx, [r15]
lea rcx, [controlstr]
call printf

leave
ret

; End of code.
4

0 回答 0