обертка для закидывания аргументов в стек переписана на nasm

This commit is contained in:
root
2024-10-10 20:18:47 +03:00
parent fa92aeebd4
commit 9fb1bbcc2c
3 changed files with 65 additions and 49 deletions

View File

@ -1,10 +1,10 @@
global task_regs
global task_stack
global task_stack_wrapper
section .note.GNU-stack
section .text
task_regs: ; rdi - указатель первое на число, rsi - указатель второе на число, rdx - результат
push rax
mov rax, [rdi]
@ -17,11 +17,48 @@ task_regs: ; rdi - указатель первое на число, rsi - ука
adc [rdx], rax
pop rax
ret
task_stack_wrapper: ;rdi - указатель, rsi - сколько
push rbp
mov rbp, rsp
push rdi
push rsi
shr rsi, 3 ; делим на 8 в ускоренном порядке. (приводим к байтам)
; вычитаем 2 раза так как поверьте, циклы городить намного труднее
sub rsp, rsi
sub rsp, rsi
sub rsp, rsi
sub rsp, rsi
; сыграем в чихарду
mov rcx, rsi
shl rcx, 2 ; сносим 2 числа, поэтому байтов в 2 раза больше + по 2 числа на число
mov rsi, rdi
mov rdi, rsp
rep movsb
; закинем байт разрядности
;push si
;shl word [rsp], 8
dec rsp
mov al, [rbp - 16]
mov [rsp], al
;add rsp, 1
; вызов
call task_stack
; восстанавливаемся
add rsp, 1 ; pачищаем разрядность
; Циклы, как я уже и говорил, я делать отказываюсь
mov rcx, [rbp - 16]
shr rcx, 1 ; делим на 8 умножаем на 4, того множим на 2
add rsp, rcx ; затираем бедный стек
pop rsi
pop rdi
pop rbp
ret
task_stack: ; разрядность - 1 байт. Дальше читаем сколько надо. Читает в 2 раза больше разрядности
push rbp
mov rbp, rsp
mov al, [rbp + 8]
mov al, [rbp + 16]
test al, 64
jnz .64bit
test al, 32
@ -31,32 +68,35 @@ task_stack: ; разрядность - 1 байт. Дальше читаем с
test al, 8
.8bit:
xor rax, rax
mov al, [rbp + 9]
mov ah, [rbp + 10]
mov cl, [rbp + 11]
mov ch, [rbp + 12]
mov al, [rbp + 17]
mov ah, [rbp + 18]
mov cl, [rbp + 19]
mov ch, [rbp + 20]
add al, cl
adc ah, ch
jmp .end
.16bit:
xor rax, rax
mov ax, [rbp + 11] ; старшая часть 1-го
mov dx, [rbp + 15] ; старшая часть 2-го
mov cx, [rbp + 9] ; младшая
mov bx, [rbp + 13] ;младшая
add cx, bx
adc ax, dx
mov ax, [rbp + 23] ; старшая
mov dx, [rbp + 21] ; младшая
mov cx, [rbp + 17] ; младшая
mov bx, [rbp + 19] ; старшая
;add cx, bx
;adc ax, dx
add dx, cx
adc ax, bx
pushfq ; Сохраним флаги на всякий
sal eax, 16
mov ax, cx
mov ax, dx
popfq
jmp .end
.32bit:
xor rax, rax
mov eax, [rbp + 11] ; старшая часть 1-го
mov edx, [rbp + 15] ; старшая часть 2-го
mov ecx, [rbp + 9] ; младшая
mov ebx, [rbp + 13] ;младшая
; Не выровнянные данные - vae soli, но тут уже оставлю talis qualis, мне влом
mov eax, [rbp + 21] ; старшая часть 1-го
mov edx, [rbp + 29] ; старшая часть 2-го
mov ecx, [rbp + 17] ; младшая
mov ebx, [rbp + 25] ;младшая
add ecx, ebx
adc eax, edx
pushfq ; Сохраним флаги на всякий
@ -67,4 +107,5 @@ task_stack: ; разрядность - 1 байт. Дальше читаем с
.64bit:
;crush
.end:
pop rbp
ret