请考虑以下短程序。movq指令中的段错误?
int main(){
asm("movq 0x5F5E100, %rcx;"
"startofloop: ; "
"sub 0x1, %rcx; "
"jne startofloop; ");
}
这个程序编译罚款,但在运行时,它出现segfaults初始movq
指令。
我必须错过一些明显的东西,但我希望这里有人能为我指出。
我在Debian 8上运行,内核为3.16.0-4-amd64,以防万一。
为了将来的参考,这是编译器生成的。
main:
.LFB0:
.cfi_startproc
pushq %rbp
.cfi_def_cfa_offset 16
.cfi_offset 6, -16
movq %rsp, %rbp
.cfi_def_cfa_register 6
#APP
# 2 "asm_fail.c" 1
movq 0x5F5E100, %rcx;startofloop: ; sub 0x1, %rcx; jne startofloop;
# 0 "" 2
#NO_APP
我几乎不知道装配的任何事情。但是也许你想将0x5F5E100的值复制到%rcx中,并且在没有意识到的情况下交换操作数? – andre
请将编译器生成的汇编代码(用'-S'编译)添加到您的问题中。 – user3386109