2018-12-31 18:06:45 +00:00
|
|
|
;# callee-saved registers - System V AMD64 ABI
|
|
|
|
push rbx
|
|
|
|
push rbp
|
|
|
|
push r12
|
|
|
|
push r13
|
|
|
|
push r14
|
|
|
|
push r15
|
|
|
|
|
|
|
|
;# function arguments
|
2019-01-27 09:52:30 +00:00
|
|
|
mov rbx, rcx ;# loop counter
|
2019-01-10 21:04:55 +00:00
|
|
|
push rdi ;# RegisterFile& registerFile
|
2019-01-27 09:52:30 +00:00
|
|
|
mov rcx, rdi
|
2019-01-10 21:04:55 +00:00
|
|
|
mov rbp, qword ptr [rsi] ;# "mx", "ma"
|
2019-01-27 09:52:30 +00:00
|
|
|
mov rdi, qword ptr [rsi+8] ;# uint8_t* dataset
|
2019-02-11 17:13:03 +00:00
|
|
|
mov rsi, rdx ;# uint8_t* scratchpad
|
2018-12-31 18:06:45 +00:00
|
|
|
|
2019-02-11 17:13:03 +00:00
|
|
|
mov rax, rbp
|
|
|
|
|
|
|
|
;# zero integer registers
|
|
|
|
xor r8, r8
|
|
|
|
xor r9, r9
|
|
|
|
xor r10, r10
|
|
|
|
xor r11, r11
|
|
|
|
xor r12, r12
|
|
|
|
xor r13, r13
|
|
|
|
xor r14, r14
|
|
|
|
xor r15, r15
|
|
|
|
|
|
|
|
;# load constant registers
|
|
|
|
lea rcx, [rcx+120]
|
|
|
|
movapd xmm8, xmmword ptr [rcx+72]
|
|
|
|
movapd xmm9, xmmword ptr [rcx+88]
|
|
|
|
movapd xmm10, xmmword ptr [rcx+104]
|
|
|
|
movapd xmm11, xmmword ptr [rcx+120]
|