pineapple-src/externals/libressl/crypto/sha/sha256-masm-x86_64.S

1865 lines
24 KiB
ArmAsm
Raw Normal View History

2020-12-28 16:15:37 +01:00
; 1 "crypto/sha/sha256-masm-x86_64.S.tmp"
; 1 "<built-in>" 1
; 1 "<built-in>" 3
2022-04-24 22:29:35 +02:00
; 343 "<built-in>" 3
2020-12-28 16:15:37 +01:00
; 1 "<command line>" 1
; 1 "<built-in>" 2
; 1 "crypto/sha/sha256-masm-x86_64.S.tmp" 2
OPTION DOTNAME
; 1 "./crypto/x86_arch.h" 1
; 16 "./crypto/x86_arch.h"
; 40 "./crypto/x86_arch.h"
; 3 "crypto/sha/sha256-masm-x86_64.S.tmp" 2
.text$ SEGMENT ALIGN(64) 'CODE'
PUBLIC sha256_block_data_order
ALIGN 16
sha256_block_data_order PROC PUBLIC
mov QWORD PTR[8+rsp],rdi ;WIN64 prologue
mov QWORD PTR[16+rsp],rsi
mov rax,rsp
$L$SEH_begin_sha256_block_data_order::
mov rdi,rcx
mov rsi,rdx
mov rdx,r8
mov rcx,r9
push rbx
push rbp
push r12
push r13
push r14
push r15
mov r11,rsp
shl rdx,4
sub rsp,16*4+4*8
lea rdx,QWORD PTR[rdx*4+rsi]
and rsp,-64
mov QWORD PTR[((64+0))+rsp],rdi
mov QWORD PTR[((64+8))+rsp],rsi
mov QWORD PTR[((64+16))+rsp],rdx
mov QWORD PTR[((64+24))+rsp],r11
$L$prologue::
lea rbp,QWORD PTR[K256]
mov eax,DWORD PTR[rdi]
mov ebx,DWORD PTR[4+rdi]
mov ecx,DWORD PTR[8+rdi]
mov edx,DWORD PTR[12+rdi]
mov r8d,DWORD PTR[16+rdi]
mov r9d,DWORD PTR[20+rdi]
mov r10d,DWORD PTR[24+rdi]
mov r11d,DWORD PTR[28+rdi]
jmp $L$loop
ALIGN 16
$L$loop::
xor rdi,rdi
mov r12d,DWORD PTR[rsi]
mov r13d,r8d
mov r14d,eax
bswap r12d
ror r13d,14
mov r15d,r9d
mov DWORD PTR[rsp],r12d
ror r14d,9
xor r13d,r8d
xor r15d,r10d
ror r13d,5
add r12d,r11d
xor r14d,eax
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,r8d
mov r11d,ebx
ror r14d,11
xor r13d,r8d
xor r15d,r10d
xor r11d,ecx
xor r14d,eax
add r12d,r15d
mov r15d,ebx
ror r13d,6
and r11d,eax
and r15d,ecx
ror r14d,2
add r12d,r13d
add r11d,r15d
add edx,r12d
add r11d,r12d
lea rdi,QWORD PTR[1+rdi]
add r11d,r14d
mov r12d,DWORD PTR[4+rsi]
mov r13d,edx
mov r14d,r11d
bswap r12d
ror r13d,14
mov r15d,r8d
mov DWORD PTR[4+rsp],r12d
ror r14d,9
xor r13d,edx
xor r15d,r9d
ror r13d,5
add r12d,r10d
xor r14d,r11d
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,edx
mov r10d,eax
ror r14d,11
xor r13d,edx
xor r15d,r9d
xor r10d,ebx
xor r14d,r11d
add r12d,r15d
mov r15d,eax
ror r13d,6
and r10d,r11d
and r15d,ebx
ror r14d,2
add r12d,r13d
add r10d,r15d
add ecx,r12d
add r10d,r12d
lea rdi,QWORD PTR[1+rdi]
add r10d,r14d
mov r12d,DWORD PTR[8+rsi]
mov r13d,ecx
mov r14d,r10d
bswap r12d
ror r13d,14
mov r15d,edx
mov DWORD PTR[8+rsp],r12d
ror r14d,9
xor r13d,ecx
xor r15d,r8d
ror r13d,5
add r12d,r9d
xor r14d,r10d
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,ecx
mov r9d,r11d
ror r14d,11
xor r13d,ecx
xor r15d,r8d
xor r9d,eax
xor r14d,r10d
add r12d,r15d
mov r15d,r11d
ror r13d,6
and r9d,r10d
and r15d,eax
ror r14d,2
add r12d,r13d
add r9d,r15d
add ebx,r12d
add r9d,r12d
lea rdi,QWORD PTR[1+rdi]
add r9d,r14d
mov r12d,DWORD PTR[12+rsi]
mov r13d,ebx
mov r14d,r9d
bswap r12d
ror r13d,14
mov r15d,ecx
mov DWORD PTR[12+rsp],r12d
ror r14d,9
xor r13d,ebx
xor r15d,edx
ror r13d,5
add r12d,r8d
xor r14d,r9d
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,ebx
mov r8d,r10d
ror r14d,11
xor r13d,ebx
xor r15d,edx
xor r8d,r11d
xor r14d,r9d
add r12d,r15d
mov r15d,r10d
ror r13d,6
and r8d,r9d
and r15d,r11d
ror r14d,2
add r12d,r13d
add r8d,r15d
add eax,r12d
add r8d,r12d
lea rdi,QWORD PTR[1+rdi]
add r8d,r14d
mov r12d,DWORD PTR[16+rsi]
mov r13d,eax
mov r14d,r8d
bswap r12d
ror r13d,14
mov r15d,ebx
mov DWORD PTR[16+rsp],r12d
ror r14d,9
xor r13d,eax
xor r15d,ecx
ror r13d,5
add r12d,edx
xor r14d,r8d
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,eax
mov edx,r9d
ror r14d,11
xor r13d,eax
xor r15d,ecx
xor edx,r10d
xor r14d,r8d
add r12d,r15d
mov r15d,r9d
ror r13d,6
and edx,r8d
and r15d,r10d
ror r14d,2
add r12d,r13d
add edx,r15d
add r11d,r12d
add edx,r12d
lea rdi,QWORD PTR[1+rdi]
add edx,r14d
mov r12d,DWORD PTR[20+rsi]
mov r13d,r11d
mov r14d,edx
bswap r12d
ror r13d,14
mov r15d,eax
mov DWORD PTR[20+rsp],r12d
ror r14d,9
xor r13d,r11d
xor r15d,ebx
ror r13d,5
add r12d,ecx
xor r14d,edx
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,r11d
mov ecx,r8d
ror r14d,11
xor r13d,r11d
xor r15d,ebx
xor ecx,r9d
xor r14d,edx
add r12d,r15d
mov r15d,r8d
ror r13d,6
and ecx,edx
and r15d,r9d
ror r14d,2
add r12d,r13d
add ecx,r15d
add r10d,r12d
add ecx,r12d
lea rdi,QWORD PTR[1+rdi]
add ecx,r14d
mov r12d,DWORD PTR[24+rsi]
mov r13d,r10d
mov r14d,ecx
bswap r12d
ror r13d,14
mov r15d,r11d
mov DWORD PTR[24+rsp],r12d
ror r14d,9
xor r13d,r10d
xor r15d,eax
ror r13d,5
add r12d,ebx
xor r14d,ecx
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,r10d
mov ebx,edx
ror r14d,11
xor r13d,r10d
xor r15d,eax
xor ebx,r8d
xor r14d,ecx
add r12d,r15d
mov r15d,edx
ror r13d,6
and ebx,ecx
and r15d,r8d
ror r14d,2
add r12d,r13d
add ebx,r15d
add r9d,r12d
add ebx,r12d
lea rdi,QWORD PTR[1+rdi]
add ebx,r14d
mov r12d,DWORD PTR[28+rsi]
mov r13d,r9d
mov r14d,ebx
bswap r12d
ror r13d,14
mov r15d,r10d
mov DWORD PTR[28+rsp],r12d
ror r14d,9
xor r13d,r9d
xor r15d,r11d
ror r13d,5
add r12d,eax
xor r14d,ebx
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,r9d
mov eax,ecx
ror r14d,11
xor r13d,r9d
xor r15d,r11d
xor eax,edx
xor r14d,ebx
add r12d,r15d
mov r15d,ecx
ror r13d,6
and eax,ebx
and r15d,edx
ror r14d,2
add r12d,r13d
add eax,r15d
add r8d,r12d
add eax,r12d
lea rdi,QWORD PTR[1+rdi]
add eax,r14d
mov r12d,DWORD PTR[32+rsi]
mov r13d,r8d
mov r14d,eax
bswap r12d
ror r13d,14
mov r15d,r9d
mov DWORD PTR[32+rsp],r12d
ror r14d,9
xor r13d,r8d
xor r15d,r10d
ror r13d,5
add r12d,r11d
xor r14d,eax
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,r8d
mov r11d,ebx
ror r14d,11
xor r13d,r8d
xor r15d,r10d
xor r11d,ecx
xor r14d,eax
add r12d,r15d
mov r15d,ebx
ror r13d,6
and r11d,eax
and r15d,ecx
ror r14d,2
add r12d,r13d
add r11d,r15d
add edx,r12d
add r11d,r12d
lea rdi,QWORD PTR[1+rdi]
add r11d,r14d
mov r12d,DWORD PTR[36+rsi]
mov r13d,edx
mov r14d,r11d
bswap r12d
ror r13d,14
mov r15d,r8d
mov DWORD PTR[36+rsp],r12d
ror r14d,9
xor r13d,edx
xor r15d,r9d
ror r13d,5
add r12d,r10d
xor r14d,r11d
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,edx
mov r10d,eax
ror r14d,11
xor r13d,edx
xor r15d,r9d
xor r10d,ebx
xor r14d,r11d
add r12d,r15d
mov r15d,eax
ror r13d,6
and r10d,r11d
and r15d,ebx
ror r14d,2
add r12d,r13d
add r10d,r15d
add ecx,r12d
add r10d,r12d
lea rdi,QWORD PTR[1+rdi]
add r10d,r14d
mov r12d,DWORD PTR[40+rsi]
mov r13d,ecx
mov r14d,r10d
bswap r12d
ror r13d,14
mov r15d,edx
mov DWORD PTR[40+rsp],r12d
ror r14d,9
xor r13d,ecx
xor r15d,r8d
ror r13d,5
add r12d,r9d
xor r14d,r10d
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,ecx
mov r9d,r11d
ror r14d,11
xor r13d,ecx
xor r15d,r8d
xor r9d,eax
xor r14d,r10d
add r12d,r15d
mov r15d,r11d
ror r13d,6
and r9d,r10d
and r15d,eax
ror r14d,2
add r12d,r13d
add r9d,r15d
add ebx,r12d
add r9d,r12d
lea rdi,QWORD PTR[1+rdi]
add r9d,r14d
mov r12d,DWORD PTR[44+rsi]
mov r13d,ebx
mov r14d,r9d
bswap r12d
ror r13d,14
mov r15d,ecx
mov DWORD PTR[44+rsp],r12d
ror r14d,9
xor r13d,ebx
xor r15d,edx
ror r13d,5
add r12d,r8d
xor r14d,r9d
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,ebx
mov r8d,r10d
ror r14d,11
xor r13d,ebx
xor r15d,edx
xor r8d,r11d
xor r14d,r9d
add r12d,r15d
mov r15d,r10d
ror r13d,6
and r8d,r9d
and r15d,r11d
ror r14d,2
add r12d,r13d
add r8d,r15d
add eax,r12d
add r8d,r12d
lea rdi,QWORD PTR[1+rdi]
add r8d,r14d
mov r12d,DWORD PTR[48+rsi]
mov r13d,eax
mov r14d,r8d
bswap r12d
ror r13d,14
mov r15d,ebx
mov DWORD PTR[48+rsp],r12d
ror r14d,9
xor r13d,eax
xor r15d,ecx
ror r13d,5
add r12d,edx
xor r14d,r8d
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,eax
mov edx,r9d
ror r14d,11
xor r13d,eax
xor r15d,ecx
xor edx,r10d
xor r14d,r8d
add r12d,r15d
mov r15d,r9d
ror r13d,6
and edx,r8d
and r15d,r10d
ror r14d,2
add r12d,r13d
add edx,r15d
add r11d,r12d
add edx,r12d
lea rdi,QWORD PTR[1+rdi]
add edx,r14d
mov r12d,DWORD PTR[52+rsi]
mov r13d,r11d
mov r14d,edx
bswap r12d
ror r13d,14
mov r15d,eax
mov DWORD PTR[52+rsp],r12d
ror r14d,9
xor r13d,r11d
xor r15d,ebx
ror r13d,5
add r12d,ecx
xor r14d,edx
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,r11d
mov ecx,r8d
ror r14d,11
xor r13d,r11d
xor r15d,ebx
xor ecx,r9d
xor r14d,edx
add r12d,r15d
mov r15d,r8d
ror r13d,6
and ecx,edx
and r15d,r9d
ror r14d,2
add r12d,r13d
add ecx,r15d
add r10d,r12d
add ecx,r12d
lea rdi,QWORD PTR[1+rdi]
add ecx,r14d
mov r12d,DWORD PTR[56+rsi]
mov r13d,r10d
mov r14d,ecx
bswap r12d
ror r13d,14
mov r15d,r11d
mov DWORD PTR[56+rsp],r12d
ror r14d,9
xor r13d,r10d
xor r15d,eax
ror r13d,5
add r12d,ebx
xor r14d,ecx
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,r10d
mov ebx,edx
ror r14d,11
xor r13d,r10d
xor r15d,eax
xor ebx,r8d
xor r14d,ecx
add r12d,r15d
mov r15d,edx
ror r13d,6
and ebx,ecx
and r15d,r8d
ror r14d,2
add r12d,r13d
add ebx,r15d
add r9d,r12d
add ebx,r12d
lea rdi,QWORD PTR[1+rdi]
add ebx,r14d
mov r12d,DWORD PTR[60+rsi]
mov r13d,r9d
mov r14d,ebx
bswap r12d
ror r13d,14
mov r15d,r10d
mov DWORD PTR[60+rsp],r12d
ror r14d,9
xor r13d,r9d
xor r15d,r11d
ror r13d,5
add r12d,eax
xor r14d,ebx
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,r9d
mov eax,ecx
ror r14d,11
xor r13d,r9d
xor r15d,r11d
xor eax,edx
xor r14d,ebx
add r12d,r15d
mov r15d,ecx
ror r13d,6
and eax,ebx
and r15d,edx
ror r14d,2
add r12d,r13d
add eax,r15d
add r8d,r12d
add eax,r12d
lea rdi,QWORD PTR[1+rdi]
add eax,r14d
jmp $L$rounds_16_xx
ALIGN 16
$L$rounds_16_xx::
mov r13d,DWORD PTR[4+rsp]
mov r14d,DWORD PTR[56+rsp]
mov r12d,r13d
mov r15d,r14d
ror r12d,11
xor r12d,r13d
shr r13d,3
ror r12d,7
xor r13d,r12d
mov r12d,DWORD PTR[36+rsp]
ror r15d,2
xor r15d,r14d
shr r14d,10
ror r15d,17
add r12d,r13d
xor r14d,r15d
add r12d,DWORD PTR[rsp]
mov r13d,r8d
add r12d,r14d
mov r14d,eax
ror r13d,14
mov r15d,r9d
mov DWORD PTR[rsp],r12d
ror r14d,9
xor r13d,r8d
xor r15d,r10d
ror r13d,5
add r12d,r11d
xor r14d,eax
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,r8d
mov r11d,ebx
ror r14d,11
xor r13d,r8d
xor r15d,r10d
xor r11d,ecx
xor r14d,eax
add r12d,r15d
mov r15d,ebx
ror r13d,6
and r11d,eax
and r15d,ecx
ror r14d,2
add r12d,r13d
add r11d,r15d
add edx,r12d
add r11d,r12d
lea rdi,QWORD PTR[1+rdi]
add r11d,r14d
mov r13d,DWORD PTR[8+rsp]
mov r14d,DWORD PTR[60+rsp]
mov r12d,r13d
mov r15d,r14d
ror r12d,11
xor r12d,r13d
shr r13d,3
ror r12d,7
xor r13d,r12d
mov r12d,DWORD PTR[40+rsp]
ror r15d,2
xor r15d,r14d
shr r14d,10
ror r15d,17
add r12d,r13d
xor r14d,r15d
add r12d,DWORD PTR[4+rsp]
mov r13d,edx
add r12d,r14d
mov r14d,r11d
ror r13d,14
mov r15d,r8d
mov DWORD PTR[4+rsp],r12d
ror r14d,9
xor r13d,edx
xor r15d,r9d
ror r13d,5
add r12d,r10d
xor r14d,r11d
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,edx
mov r10d,eax
ror r14d,11
xor r13d,edx
xor r15d,r9d
xor r10d,ebx
xor r14d,r11d
add r12d,r15d
mov r15d,eax
ror r13d,6
and r10d,r11d
and r15d,ebx
ror r14d,2
add r12d,r13d
add r10d,r15d
add ecx,r12d
add r10d,r12d
lea rdi,QWORD PTR[1+rdi]
add r10d,r14d
mov r13d,DWORD PTR[12+rsp]
mov r14d,DWORD PTR[rsp]
mov r12d,r13d
mov r15d,r14d
ror r12d,11
xor r12d,r13d
shr r13d,3
ror r12d,7
xor r13d,r12d
mov r12d,DWORD PTR[44+rsp]
ror r15d,2
xor r15d,r14d
shr r14d,10
ror r15d,17
add r12d,r13d
xor r14d,r15d
add r12d,DWORD PTR[8+rsp]
mov r13d,ecx
add r12d,r14d
mov r14d,r10d
ror r13d,14
mov r15d,edx
mov DWORD PTR[8+rsp],r12d
ror r14d,9
xor r13d,ecx
xor r15d,r8d
ror r13d,5
add r12d,r9d
xor r14d,r10d
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,ecx
mov r9d,r11d
ror r14d,11
xor r13d,ecx
xor r15d,r8d
xor r9d,eax
xor r14d,r10d
add r12d,r15d
mov r15d,r11d
ror r13d,6
and r9d,r10d
and r15d,eax
ror r14d,2
add r12d,r13d
add r9d,r15d
add ebx,r12d
add r9d,r12d
lea rdi,QWORD PTR[1+rdi]
add r9d,r14d
mov r13d,DWORD PTR[16+rsp]
mov r14d,DWORD PTR[4+rsp]
mov r12d,r13d
mov r15d,r14d
ror r12d,11
xor r12d,r13d
shr r13d,3
ror r12d,7
xor r13d,r12d
mov r12d,DWORD PTR[48+rsp]
ror r15d,2
xor r15d,r14d
shr r14d,10
ror r15d,17
add r12d,r13d
xor r14d,r15d
add r12d,DWORD PTR[12+rsp]
mov r13d,ebx
add r12d,r14d
mov r14d,r9d
ror r13d,14
mov r15d,ecx
mov DWORD PTR[12+rsp],r12d
ror r14d,9
xor r13d,ebx
xor r15d,edx
ror r13d,5
add r12d,r8d
xor r14d,r9d
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,ebx
mov r8d,r10d
ror r14d,11
xor r13d,ebx
xor r15d,edx
xor r8d,r11d
xor r14d,r9d
add r12d,r15d
mov r15d,r10d
ror r13d,6
and r8d,r9d
and r15d,r11d
ror r14d,2
add r12d,r13d
add r8d,r15d
add eax,r12d
add r8d,r12d
lea rdi,QWORD PTR[1+rdi]
add r8d,r14d
mov r13d,DWORD PTR[20+rsp]
mov r14d,DWORD PTR[8+rsp]
mov r12d,r13d
mov r15d,r14d
ror r12d,11
xor r12d,r13d
shr r13d,3
ror r12d,7
xor r13d,r12d
mov r12d,DWORD PTR[52+rsp]
ror r15d,2
xor r15d,r14d
shr r14d,10
ror r15d,17
add r12d,r13d
xor r14d,r15d
add r12d,DWORD PTR[16+rsp]
mov r13d,eax
add r12d,r14d
mov r14d,r8d
ror r13d,14
mov r15d,ebx
mov DWORD PTR[16+rsp],r12d
ror r14d,9
xor r13d,eax
xor r15d,ecx
ror r13d,5
add r12d,edx
xor r14d,r8d
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,eax
mov edx,r9d
ror r14d,11
xor r13d,eax
xor r15d,ecx
xor edx,r10d
xor r14d,r8d
add r12d,r15d
mov r15d,r9d
ror r13d,6
and edx,r8d
and r15d,r10d
ror r14d,2
add r12d,r13d
add edx,r15d
add r11d,r12d
add edx,r12d
lea rdi,QWORD PTR[1+rdi]
add edx,r14d
mov r13d,DWORD PTR[24+rsp]
mov r14d,DWORD PTR[12+rsp]
mov r12d,r13d
mov r15d,r14d
ror r12d,11
xor r12d,r13d
shr r13d,3
ror r12d,7
xor r13d,r12d
mov r12d,DWORD PTR[56+rsp]
ror r15d,2
xor r15d,r14d
shr r14d,10
ror r15d,17
add r12d,r13d
xor r14d,r15d
add r12d,DWORD PTR[20+rsp]
mov r13d,r11d
add r12d,r14d
mov r14d,edx
ror r13d,14
mov r15d,eax
mov DWORD PTR[20+rsp],r12d
ror r14d,9
xor r13d,r11d
xor r15d,ebx
ror r13d,5
add r12d,ecx
xor r14d,edx
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,r11d
mov ecx,r8d
ror r14d,11
xor r13d,r11d
xor r15d,ebx
xor ecx,r9d
xor r14d,edx
add r12d,r15d
mov r15d,r8d
ror r13d,6
and ecx,edx
and r15d,r9d
ror r14d,2
add r12d,r13d
add ecx,r15d
add r10d,r12d
add ecx,r12d
lea rdi,QWORD PTR[1+rdi]
add ecx,r14d
mov r13d,DWORD PTR[28+rsp]
mov r14d,DWORD PTR[16+rsp]
mov r12d,r13d
mov r15d,r14d
ror r12d,11
xor r12d,r13d
shr r13d,3
ror r12d,7
xor r13d,r12d
mov r12d,DWORD PTR[60+rsp]
ror r15d,2
xor r15d,r14d
shr r14d,10
ror r15d,17
add r12d,r13d
xor r14d,r15d
add r12d,DWORD PTR[24+rsp]
mov r13d,r10d
add r12d,r14d
mov r14d,ecx
ror r13d,14
mov r15d,r11d
mov DWORD PTR[24+rsp],r12d
ror r14d,9
xor r13d,r10d
xor r15d,eax
ror r13d,5
add r12d,ebx
xor r14d,ecx
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,r10d
mov ebx,edx
ror r14d,11
xor r13d,r10d
xor r15d,eax
xor ebx,r8d
xor r14d,ecx
add r12d,r15d
mov r15d,edx
ror r13d,6
and ebx,ecx
and r15d,r8d
ror r14d,2
add r12d,r13d
add ebx,r15d
add r9d,r12d
add ebx,r12d
lea rdi,QWORD PTR[1+rdi]
add ebx,r14d
mov r13d,DWORD PTR[32+rsp]
mov r14d,DWORD PTR[20+rsp]
mov r12d,r13d
mov r15d,r14d
ror r12d,11
xor r12d,r13d
shr r13d,3
ror r12d,7
xor r13d,r12d
mov r12d,DWORD PTR[rsp]
ror r15d,2
xor r15d,r14d
shr r14d,10
ror r15d,17
add r12d,r13d
xor r14d,r15d
add r12d,DWORD PTR[28+rsp]
mov r13d,r9d
add r12d,r14d
mov r14d,ebx
ror r13d,14
mov r15d,r10d
mov DWORD PTR[28+rsp],r12d
ror r14d,9
xor r13d,r9d
xor r15d,r11d
ror r13d,5
add r12d,eax
xor r14d,ebx
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,r9d
mov eax,ecx
ror r14d,11
xor r13d,r9d
xor r15d,r11d
xor eax,edx
xor r14d,ebx
add r12d,r15d
mov r15d,ecx
ror r13d,6
and eax,ebx
and r15d,edx
ror r14d,2
add r12d,r13d
add eax,r15d
add r8d,r12d
add eax,r12d
lea rdi,QWORD PTR[1+rdi]
add eax,r14d
mov r13d,DWORD PTR[36+rsp]
mov r14d,DWORD PTR[24+rsp]
mov r12d,r13d
mov r15d,r14d
ror r12d,11
xor r12d,r13d
shr r13d,3
ror r12d,7
xor r13d,r12d
mov r12d,DWORD PTR[4+rsp]
ror r15d,2
xor r15d,r14d
shr r14d,10
ror r15d,17
add r12d,r13d
xor r14d,r15d
add r12d,DWORD PTR[32+rsp]
mov r13d,r8d
add r12d,r14d
mov r14d,eax
ror r13d,14
mov r15d,r9d
mov DWORD PTR[32+rsp],r12d
ror r14d,9
xor r13d,r8d
xor r15d,r10d
ror r13d,5
add r12d,r11d
xor r14d,eax
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,r8d
mov r11d,ebx
ror r14d,11
xor r13d,r8d
xor r15d,r10d
xor r11d,ecx
xor r14d,eax
add r12d,r15d
mov r15d,ebx
ror r13d,6
and r11d,eax
and r15d,ecx
ror r14d,2
add r12d,r13d
add r11d,r15d
add edx,r12d
add r11d,r12d
lea rdi,QWORD PTR[1+rdi]
add r11d,r14d
mov r13d,DWORD PTR[40+rsp]
mov r14d,DWORD PTR[28+rsp]
mov r12d,r13d
mov r15d,r14d
ror r12d,11
xor r12d,r13d
shr r13d,3
ror r12d,7
xor r13d,r12d
mov r12d,DWORD PTR[8+rsp]
ror r15d,2
xor r15d,r14d
shr r14d,10
ror r15d,17
add r12d,r13d
xor r14d,r15d
add r12d,DWORD PTR[36+rsp]
mov r13d,edx
add r12d,r14d
mov r14d,r11d
ror r13d,14
mov r15d,r8d
mov DWORD PTR[36+rsp],r12d
ror r14d,9
xor r13d,edx
xor r15d,r9d
ror r13d,5
add r12d,r10d
xor r14d,r11d
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,edx
mov r10d,eax
ror r14d,11
xor r13d,edx
xor r15d,r9d
xor r10d,ebx
xor r14d,r11d
add r12d,r15d
mov r15d,eax
ror r13d,6
and r10d,r11d
and r15d,ebx
ror r14d,2
add r12d,r13d
add r10d,r15d
add ecx,r12d
add r10d,r12d
lea rdi,QWORD PTR[1+rdi]
add r10d,r14d
mov r13d,DWORD PTR[44+rsp]
mov r14d,DWORD PTR[32+rsp]
mov r12d,r13d
mov r15d,r14d
ror r12d,11
xor r12d,r13d
shr r13d,3
ror r12d,7
xor r13d,r12d
mov r12d,DWORD PTR[12+rsp]
ror r15d,2
xor r15d,r14d
shr r14d,10
ror r15d,17
add r12d,r13d
xor r14d,r15d
add r12d,DWORD PTR[40+rsp]
mov r13d,ecx
add r12d,r14d
mov r14d,r10d
ror r13d,14
mov r15d,edx
mov DWORD PTR[40+rsp],r12d
ror r14d,9
xor r13d,ecx
xor r15d,r8d
ror r13d,5
add r12d,r9d
xor r14d,r10d
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,ecx
mov r9d,r11d
ror r14d,11
xor r13d,ecx
xor r15d,r8d
xor r9d,eax
xor r14d,r10d
add r12d,r15d
mov r15d,r11d
ror r13d,6
and r9d,r10d
and r15d,eax
ror r14d,2
add r12d,r13d
add r9d,r15d
add ebx,r12d
add r9d,r12d
lea rdi,QWORD PTR[1+rdi]
add r9d,r14d
mov r13d,DWORD PTR[48+rsp]
mov r14d,DWORD PTR[36+rsp]
mov r12d,r13d
mov r15d,r14d
ror r12d,11
xor r12d,r13d
shr r13d,3
ror r12d,7
xor r13d,r12d
mov r12d,DWORD PTR[16+rsp]
ror r15d,2
xor r15d,r14d
shr r14d,10
ror r15d,17
add r12d,r13d
xor r14d,r15d
add r12d,DWORD PTR[44+rsp]
mov r13d,ebx
add r12d,r14d
mov r14d,r9d
ror r13d,14
mov r15d,ecx
mov DWORD PTR[44+rsp],r12d
ror r14d,9
xor r13d,ebx
xor r15d,edx
ror r13d,5
add r12d,r8d
xor r14d,r9d
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,ebx
mov r8d,r10d
ror r14d,11
xor r13d,ebx
xor r15d,edx
xor r8d,r11d
xor r14d,r9d
add r12d,r15d
mov r15d,r10d
ror r13d,6
and r8d,r9d
and r15d,r11d
ror r14d,2
add r12d,r13d
add r8d,r15d
add eax,r12d
add r8d,r12d
lea rdi,QWORD PTR[1+rdi]
add r8d,r14d
mov r13d,DWORD PTR[52+rsp]
mov r14d,DWORD PTR[40+rsp]
mov r12d,r13d
mov r15d,r14d
ror r12d,11
xor r12d,r13d
shr r13d,3
ror r12d,7
xor r13d,r12d
mov r12d,DWORD PTR[20+rsp]
ror r15d,2
xor r15d,r14d
shr r14d,10
ror r15d,17
add r12d,r13d
xor r14d,r15d
add r12d,DWORD PTR[48+rsp]
mov r13d,eax
add r12d,r14d
mov r14d,r8d
ror r13d,14
mov r15d,ebx
mov DWORD PTR[48+rsp],r12d
ror r14d,9
xor r13d,eax
xor r15d,ecx
ror r13d,5
add r12d,edx
xor r14d,r8d
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,eax
mov edx,r9d
ror r14d,11
xor r13d,eax
xor r15d,ecx
xor edx,r10d
xor r14d,r8d
add r12d,r15d
mov r15d,r9d
ror r13d,6
and edx,r8d
and r15d,r10d
ror r14d,2
add r12d,r13d
add edx,r15d
add r11d,r12d
add edx,r12d
lea rdi,QWORD PTR[1+rdi]
add edx,r14d
mov r13d,DWORD PTR[56+rsp]
mov r14d,DWORD PTR[44+rsp]
mov r12d,r13d
mov r15d,r14d
ror r12d,11
xor r12d,r13d
shr r13d,3
ror r12d,7
xor r13d,r12d
mov r12d,DWORD PTR[24+rsp]
ror r15d,2
xor r15d,r14d
shr r14d,10
ror r15d,17
add r12d,r13d
xor r14d,r15d
add r12d,DWORD PTR[52+rsp]
mov r13d,r11d
add r12d,r14d
mov r14d,edx
ror r13d,14
mov r15d,eax
mov DWORD PTR[52+rsp],r12d
ror r14d,9
xor r13d,r11d
xor r15d,ebx
ror r13d,5
add r12d,ecx
xor r14d,edx
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,r11d
mov ecx,r8d
ror r14d,11
xor r13d,r11d
xor r15d,ebx
xor ecx,r9d
xor r14d,edx
add r12d,r15d
mov r15d,r8d
ror r13d,6
and ecx,edx
and r15d,r9d
ror r14d,2
add r12d,r13d
add ecx,r15d
add r10d,r12d
add ecx,r12d
lea rdi,QWORD PTR[1+rdi]
add ecx,r14d
mov r13d,DWORD PTR[60+rsp]
mov r14d,DWORD PTR[48+rsp]
mov r12d,r13d
mov r15d,r14d
ror r12d,11
xor r12d,r13d
shr r13d,3
ror r12d,7
xor r13d,r12d
mov r12d,DWORD PTR[28+rsp]
ror r15d,2
xor r15d,r14d
shr r14d,10
ror r15d,17
add r12d,r13d
xor r14d,r15d
add r12d,DWORD PTR[56+rsp]
mov r13d,r10d
add r12d,r14d
mov r14d,ecx
ror r13d,14
mov r15d,r11d
mov DWORD PTR[56+rsp],r12d
ror r14d,9
xor r13d,r10d
xor r15d,eax
ror r13d,5
add r12d,ebx
xor r14d,ecx
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,r10d
mov ebx,edx
ror r14d,11
xor r13d,r10d
xor r15d,eax
xor ebx,r8d
xor r14d,ecx
add r12d,r15d
mov r15d,edx
ror r13d,6
and ebx,ecx
and r15d,r8d
ror r14d,2
add r12d,r13d
add ebx,r15d
add r9d,r12d
add ebx,r12d
lea rdi,QWORD PTR[1+rdi]
add ebx,r14d
mov r13d,DWORD PTR[rsp]
mov r14d,DWORD PTR[52+rsp]
mov r12d,r13d
mov r15d,r14d
ror r12d,11
xor r12d,r13d
shr r13d,3
ror r12d,7
xor r13d,r12d
mov r12d,DWORD PTR[32+rsp]
ror r15d,2
xor r15d,r14d
shr r14d,10
ror r15d,17
add r12d,r13d
xor r14d,r15d
add r12d,DWORD PTR[60+rsp]
mov r13d,r9d
add r12d,r14d
mov r14d,ebx
ror r13d,14
mov r15d,r10d
mov DWORD PTR[60+rsp],r12d
ror r14d,9
xor r13d,r9d
xor r15d,r11d
ror r13d,5
add r12d,eax
xor r14d,ebx
add r12d,DWORD PTR[rdi*4+rbp]
and r15d,r9d
mov eax,ecx
ror r14d,11
xor r13d,r9d
xor r15d,r11d
xor eax,edx
xor r14d,ebx
add r12d,r15d
mov r15d,ecx
ror r13d,6
and eax,ebx
and r15d,edx
ror r14d,2
add r12d,r13d
add eax,r15d
add r8d,r12d
add eax,r12d
lea rdi,QWORD PTR[1+rdi]
add eax,r14d
cmp rdi,64
jb $L$rounds_16_xx
mov rdi,QWORD PTR[((64+0))+rsp]
lea rsi,QWORD PTR[64+rsi]
add eax,DWORD PTR[rdi]
add ebx,DWORD PTR[4+rdi]
add ecx,DWORD PTR[8+rdi]
add edx,DWORD PTR[12+rdi]
add r8d,DWORD PTR[16+rdi]
add r9d,DWORD PTR[20+rdi]
add r10d,DWORD PTR[24+rdi]
add r11d,DWORD PTR[28+rdi]
cmp rsi,QWORD PTR[((64+16))+rsp]
mov DWORD PTR[rdi],eax
mov DWORD PTR[4+rdi],ebx
mov DWORD PTR[8+rdi],ecx
mov DWORD PTR[12+rdi],edx
mov DWORD PTR[16+rdi],r8d
mov DWORD PTR[20+rdi],r9d
mov DWORD PTR[24+rdi],r10d
mov DWORD PTR[28+rdi],r11d
jb $L$loop
mov rsi,QWORD PTR[((64+24))+rsp]
mov r15,QWORD PTR[rsi]
mov r14,QWORD PTR[8+rsi]
mov r13,QWORD PTR[16+rsi]
mov r12,QWORD PTR[24+rsi]
mov rbp,QWORD PTR[32+rsi]
mov rbx,QWORD PTR[40+rsi]
lea rsp,QWORD PTR[48+rsi]
$L$epilogue::
mov rdi,QWORD PTR[8+rsp] ;WIN64 epilogue
mov rsi,QWORD PTR[16+rsp]
DB 0F3h,0C3h ;repret
$L$SEH_end_sha256_block_data_order::
sha256_block_data_order ENDP
ALIGN 64
K256::
DD 0428a2f98h,071374491h,0b5c0fbcfh,0e9b5dba5h
DD 03956c25bh,059f111f1h,0923f82a4h,0ab1c5ed5h
DD 0d807aa98h,012835b01h,0243185beh,0550c7dc3h
DD 072be5d74h,080deb1feh,09bdc06a7h,0c19bf174h
DD 0e49b69c1h,0efbe4786h,00fc19dc6h,0240ca1cch
DD 02de92c6fh,04a7484aah,05cb0a9dch,076f988dah
DD 0983e5152h,0a831c66dh,0b00327c8h,0bf597fc7h
DD 0c6e00bf3h,0d5a79147h,006ca6351h,014292967h
DD 027b70a85h,02e1b2138h,04d2c6dfch,053380d13h
DD 0650a7354h,0766a0abbh,081c2c92eh,092722c85h
DD 0a2bfe8a1h,0a81a664bh,0c24b8b70h,0c76c51a3h
DD 0d192e819h,0d6990624h,0f40e3585h,0106aa070h
DD 019a4c116h,01e376c08h,02748774ch,034b0bcb5h
DD 0391c0cb3h,04ed8aa4ah,05b9cca4fh,0682e6ff3h
DD 0748f82eeh,078a5636fh,084c87814h,08cc70208h
DD 090befffah,0a4506cebh,0bef9a3f7h,0c67178f2h
.text$ ENDS
END