; 1 "crypto/sha/sha256-masm-x86_64.S.tmp"
; 1 "<built-in>" 1
; 1 "<built-in>" 3
; 340 "<built-in>" 3
; 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