В настоящее время я пишу простой компилятор C, который принимает .c файл в качестве входных данных и генерирует код сборки (X86, AT & T синтаксис). Everyting хорошо, но когда я пытаюсь выполнить команду IDIVQ, я получаю исключение с плавающей запятой. Вот мой вклад:X86 assembly - Обработка инструкции IDIV
int mymain(int x){
int d;
int e;
d = 3;
e = 6/d;
return e;
}
А вот мой сгенерированный код:
mymain:
.LFB1:
.cfi_startproc
pushq %rbp
.cfi_def_cfa_offset 16
movq %rsp, %rbp
.cfi_offset 6, -16
.cfi_def_cfa_register 6
movq %rdi, -40(%rbp)
movq $3, -8(%rbp)
movq $6, %rax
movq -8(%rbp), %rdx
movq %rdx, %rbx
idivq %rbx
movq %rax, -16(%rbp)
movq -16(%rbp), %rax
leave
.cfi_def_cfa 7, 8
ret
.cfi_endproc
.LFE1:
.size mymain, .-mymain
Согласно http://www.cs.virginia.edu/~evans/cs216/guides/x86.html, idivq% RBX следует производить 6/сут (Факторпространство) в % бараков. Но я получаю исключение с плавающей точкой, и я не могу найти проблему.
Любая помощь будет очень признательна!
Не относится к этому вопросу, но вы должны делать 'movq% rdi, -40 (% rbp)' без корректировки регистра 'esp'? Или это нормально из-за «красной зоны» x64? –