Хорошо, так происходит, когда я рекурсивно вызываю мою факториальную процедуру из моей комбинации. Выдает исключение прямо на факториальную процедуру. Я включил весь свой код, но проблема связана со стеком и моей факториальной процедурой. Это когда я пытаюсь подтолкнуть rax по какой-то причине. Я не могу понять, почему это так. Вот мой код:
INCLUDELIB libcmt.lib
INCLUDELIB legacy_stdio_definitions.lib
EXTERN printf:PROC
EXTERN scanf:PROC
.DATA
promt BYTE "1permutation..2)combination ",0
inFmt BYTE "%d",0
disp BYTE "You entered %d", 10, 0
num QWORD ?
fct_num QWORD ?
num2 REAL8 1.5
factpromt BYTE "What number do you want to find the factorial of?",0
factFmt BYTE "%d",0
factNum BYTE "The result is = %d", 10, 0
n QWORD ?
r QWORD ?
result QWORD ?
answer QWORD ?
divisor QWORD ?
.CODE
main PROC
push divisor ;ebp+20
push n ;ebp+16
push r ;ebp+12
push result ;ebp+8
sub rsp, 24
lea rcx, promt ;for x64
call printf
lea rdx, num ;for x64
lea rcx, inFmt ;for x64
call scanf
mov rdx, num
cmp rdx, 2
je run_comb
jmp run_perm
run_perm:
call permutation
run_comb:
call combination
;lea rcx, disp
;call printf
add rsp, 24
mov eax,0
ret
main ENDP
factorial PROC
mov rax,qword ptr [rsp+8]
cmp rax,1
jle endRecursive
dec rax
push rax;throws exception here
call factorial
mov rsi,qword ptr [rsp+8]
mul rsi
endRecursive:
ret 8
factorial ENDP
permutation PROC
mov ecx, 5
mov eax, ecx
ret
permutation ENDP
combination PROC
push rbp
mov rbp,rsp
mov rax, [rbp+32] ;find (n-r)!
sub rax, [rbp+24]
mov rbx, rax
push rbx
call factorial
mov rdx,[rbp+40] ;move (n-r)! into result
mov [rdx],rax
mov rbx, [rbp+24] ;find r!
push rbx
call factorial
mov rdx,[rbp+40]
mov rbx, [rdx]
mul rbx ;r!*(n-r)!, store product in eax
mov rbx, [rbp+40]
mov [rbx], rax ;store product in divisor variable
mov rbx, [rbp+32] ;find n!
push rbx
call factorial
mov rdx,[rbp+40]
mov rbx,[rdx] ;move value of divisor into ebx
mov rdx, 0
div rbx ;divide n! by divisor (r!*(n-r)!)
mov rbx, [rbp+16]
mov [rbx],rax ;move quotient into result
pop rbp
ret 32
combination ENDP
END