blob: 3e7cfcca0775845ccd543072ee65f621069c43ed [file] [log] [blame]
%ifidn __OUTPUT_FORMAT__,obj
section code use32 class=code align=64
%elifidn __OUTPUT_FORMAT__,win32
%ifdef __YASM_VERSION_ID__
%if __YASM_VERSION_ID__ < 01010000h
%error yasm version 1.1.0 or later needed.
%endif
; Yasm automatically includes .00 and complains about redefining it.
; https://www.tortall.net/projects/yasm/manual/html/objfmt-win32-safeseh.html
%else
$@feat.00 equ 1
%endif
section .text code align=64
%else
section .text code
%endif
;extern _OPENSSL_ia32cap_P
global _sha256_block_data_order
align 16
_sha256_block_data_order:
L$_sha256_block_data_order_begin:
push ebp
push ebx
push esi
push edi
mov esi,DWORD [20+esp]
mov edi,DWORD [24+esp]
mov eax,DWORD [28+esp]
mov ebx,esp
call L$000pic_point
L$000pic_point:
pop ebp
lea ebp,[(L$001K256-L$000pic_point)+ebp]
sub esp,16
and esp,-64
shl eax,6
add eax,edi
mov DWORD [esp],esi
mov DWORD [4+esp],edi
mov DWORD [8+esp],eax
mov DWORD [12+esp],ebx
lea edx,[_OPENSSL_ia32cap_P]
mov ecx,DWORD [edx]
mov ebx,DWORD [4+edx]
test ecx,1048576
jnz NEAR L$002loop
mov edx,DWORD [8+edx]
test ecx,16777216
jz NEAR L$003no_xmm
and ecx,1073741824
and ebx,268435968
or ecx,ebx
and ecx,1342177280
cmp ecx,1342177280
je NEAR L$004AVX
test ebx,512
jnz NEAR L$005SSSE3
L$003no_xmm:
sub eax,edi
cmp eax,256
jae NEAR L$006unrolled
jmp NEAR L$002loop
align 16
L$002loop:
mov eax,DWORD [edi]
mov ebx,DWORD [4+edi]
mov ecx,DWORD [8+edi]
bswap eax
mov edx,DWORD [12+edi]
bswap ebx
push eax
bswap ecx
push ebx
bswap edx
push ecx
push edx
mov eax,DWORD [16+edi]
mov ebx,DWORD [20+edi]
mov ecx,DWORD [24+edi]
bswap eax
mov edx,DWORD [28+edi]
bswap ebx
push eax
bswap ecx
push ebx
bswap edx
push ecx
push edx
mov eax,DWORD [32+edi]
mov ebx,DWORD [36+edi]
mov ecx,DWORD [40+edi]
bswap eax
mov edx,DWORD [44+edi]
bswap ebx
push eax
bswap ecx
push ebx
bswap edx
push ecx
push edx
mov eax,DWORD [48+edi]
mov ebx,DWORD [52+edi]
mov ecx,DWORD [56+edi]
bswap eax
mov edx,DWORD [60+edi]
bswap ebx
push eax
bswap ecx
push ebx
bswap edx
push ecx
push edx
add edi,64
lea esp,[esp-36]
mov DWORD [104+esp],edi
mov eax,DWORD [esi]
mov ebx,DWORD [4+esi]
mov ecx,DWORD [8+esi]
mov edi,DWORD [12+esi]
mov DWORD [8+esp],ebx
xor ebx,ecx
mov DWORD [12+esp],ecx
mov DWORD [16+esp],edi
mov DWORD [esp],ebx
mov edx,DWORD [16+esi]
mov ebx,DWORD [20+esi]
mov ecx,DWORD [24+esi]
mov edi,DWORD [28+esi]
mov DWORD [24+esp],ebx
mov DWORD [28+esp],ecx
mov DWORD [32+esp],edi
align 16
L$00700_15:
mov ecx,edx
mov esi,DWORD [24+esp]
ror ecx,14
mov edi,DWORD [28+esp]
xor ecx,edx
xor esi,edi
mov ebx,DWORD [96+esp]
ror ecx,5
and esi,edx
mov DWORD [20+esp],edx
xor edx,ecx
add ebx,DWORD [32+esp]
xor esi,edi
ror edx,6
mov ecx,eax
add ebx,esi
ror ecx,9
add ebx,edx
mov edi,DWORD [8+esp]
xor ecx,eax
mov DWORD [4+esp],eax
lea esp,[esp-4]
ror ecx,11
mov esi,DWORD [ebp]
xor ecx,eax
mov edx,DWORD [20+esp]
xor eax,edi
ror ecx,2
add ebx,esi
mov DWORD [esp],eax
add edx,ebx
and eax,DWORD [4+esp]
add ebx,ecx
xor eax,edi
add ebp,4
add eax,ebx
cmp esi,3248222580
jne NEAR L$00700_15
mov ecx,DWORD [156+esp]
jmp NEAR L$00816_63
align 16
L$00816_63:
mov ebx,ecx
mov esi,DWORD [104+esp]
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [160+esp]
shr edi,10
add ebx,DWORD [124+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [24+esp]
ror ecx,14
add ebx,edi
mov edi,DWORD [28+esp]
xor ecx,edx
xor esi,edi
mov DWORD [96+esp],ebx
ror ecx,5
and esi,edx
mov DWORD [20+esp],edx
xor edx,ecx
add ebx,DWORD [32+esp]
xor esi,edi
ror edx,6
mov ecx,eax
add ebx,esi
ror ecx,9
add ebx,edx
mov edi,DWORD [8+esp]
xor ecx,eax
mov DWORD [4+esp],eax
lea esp,[esp-4]
ror ecx,11
mov esi,DWORD [ebp]
xor ecx,eax
mov edx,DWORD [20+esp]
xor eax,edi
ror ecx,2
add ebx,esi
mov DWORD [esp],eax
add edx,ebx
and eax,DWORD [4+esp]
add ebx,ecx
xor eax,edi
mov ecx,DWORD [156+esp]
add ebp,4
add eax,ebx
cmp esi,3329325298
jne NEAR L$00816_63
mov esi,DWORD [356+esp]
mov ebx,DWORD [8+esp]
mov ecx,DWORD [16+esp]
add eax,DWORD [esi]
add ebx,DWORD [4+esi]
add edi,DWORD [8+esi]
add ecx,DWORD [12+esi]
mov DWORD [esi],eax
mov DWORD [4+esi],ebx
mov DWORD [8+esi],edi
mov DWORD [12+esi],ecx
mov eax,DWORD [24+esp]
mov ebx,DWORD [28+esp]
mov ecx,DWORD [32+esp]
mov edi,DWORD [360+esp]
add edx,DWORD [16+esi]
add eax,DWORD [20+esi]
add ebx,DWORD [24+esi]
add ecx,DWORD [28+esi]
mov DWORD [16+esi],edx
mov DWORD [20+esi],eax
mov DWORD [24+esi],ebx
mov DWORD [28+esi],ecx
lea esp,[356+esp]
sub ebp,256
cmp edi,DWORD [8+esp]
jb NEAR L$002loop
mov esp,DWORD [12+esp]
pop edi
pop esi
pop ebx
pop ebp
ret
align 64
L$001K256:
dd 1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298
dd 66051,67438087,134810123,202182159
db 83,72,65,50,53,54,32,98,108,111,99,107,32,116,114,97
db 110,115,102,111,114,109,32,102,111,114,32,120,56,54,44,32
db 67,82,89,80,84,79,71,65,77,83,32,98,121,32,60,97
db 112,112,114,111,64,111,112,101,110,115,115,108,46,111,114,103
db 62,0
align 16
L$006unrolled:
lea esp,[esp-96]
mov eax,DWORD [esi]
mov ebp,DWORD [4+esi]
mov ecx,DWORD [8+esi]
mov ebx,DWORD [12+esi]
mov DWORD [4+esp],ebp
xor ebp,ecx
mov DWORD [8+esp],ecx
mov DWORD [12+esp],ebx
mov edx,DWORD [16+esi]
mov ebx,DWORD [20+esi]
mov ecx,DWORD [24+esi]
mov esi,DWORD [28+esi]
mov DWORD [20+esp],ebx
mov DWORD [24+esp],ecx
mov DWORD [28+esp],esi
jmp NEAR L$009grand_loop
align 16
L$009grand_loop:
mov ebx,DWORD [edi]
mov ecx,DWORD [4+edi]
bswap ebx
mov esi,DWORD [8+edi]
bswap ecx
mov DWORD [32+esp],ebx
bswap esi
mov DWORD [36+esp],ecx
mov DWORD [40+esp],esi
mov ebx,DWORD [12+edi]
mov ecx,DWORD [16+edi]
bswap ebx
mov esi,DWORD [20+edi]
bswap ecx
mov DWORD [44+esp],ebx
bswap esi
mov DWORD [48+esp],ecx
mov DWORD [52+esp],esi
mov ebx,DWORD [24+edi]
mov ecx,DWORD [28+edi]
bswap ebx
mov esi,DWORD [32+edi]
bswap ecx
mov DWORD [56+esp],ebx
bswap esi
mov DWORD [60+esp],ecx
mov DWORD [64+esp],esi
mov ebx,DWORD [36+edi]
mov ecx,DWORD [40+edi]
bswap ebx
mov esi,DWORD [44+edi]
bswap ecx
mov DWORD [68+esp],ebx
bswap esi
mov DWORD [72+esp],ecx
mov DWORD [76+esp],esi
mov ebx,DWORD [48+edi]
mov ecx,DWORD [52+edi]
bswap ebx
mov esi,DWORD [56+edi]
bswap ecx
mov DWORD [80+esp],ebx
bswap esi
mov DWORD [84+esp],ecx
mov DWORD [88+esp],esi
mov ebx,DWORD [60+edi]
add edi,64
bswap ebx
mov DWORD [100+esp],edi
mov DWORD [92+esp],ebx
mov ecx,edx
mov esi,DWORD [20+esp]
ror edx,14
mov edi,DWORD [24+esp]
xor edx,ecx
mov ebx,DWORD [32+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [16+esp],ecx
xor edx,ecx
add ebx,DWORD [28+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [4+esp]
xor ecx,eax
mov DWORD [esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[1116352408+edx*1+ebx]
xor ecx,esi
xor ebp,edi
ror ecx,2
add ebp,edx
add edx,DWORD [12+esp]
add ebp,ecx
mov esi,edx
mov ecx,DWORD [16+esp]
ror edx,14
mov edi,DWORD [20+esp]
xor edx,esi
mov ebx,DWORD [36+esp]
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [12+esp],esi
xor edx,esi
add ebx,DWORD [24+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [esp]
xor esi,ebp
mov DWORD [28+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[1899447441+edx*1+ebx]
xor esi,ecx
xor eax,edi
ror esi,2
add eax,edx
add edx,DWORD [8+esp]
add eax,esi
mov ecx,edx
mov esi,DWORD [12+esp]
ror edx,14
mov edi,DWORD [16+esp]
xor edx,ecx
mov ebx,DWORD [40+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [8+esp],ecx
xor edx,ecx
add ebx,DWORD [20+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [28+esp]
xor ecx,eax
mov DWORD [24+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[3049323471+edx*1+ebx]
xor ecx,esi
xor ebp,edi
ror ecx,2
add ebp,edx
add edx,DWORD [4+esp]
add ebp,ecx
mov esi,edx
mov ecx,DWORD [8+esp]
ror edx,14
mov edi,DWORD [12+esp]
xor edx,esi
mov ebx,DWORD [44+esp]
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [4+esp],esi
xor edx,esi
add ebx,DWORD [16+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [24+esp]
xor esi,ebp
mov DWORD [20+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[3921009573+edx*1+ebx]
xor esi,ecx
xor eax,edi
ror esi,2
add eax,edx
add edx,DWORD [esp]
add eax,esi
mov ecx,edx
mov esi,DWORD [4+esp]
ror edx,14
mov edi,DWORD [8+esp]
xor edx,ecx
mov ebx,DWORD [48+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [esp],ecx
xor edx,ecx
add ebx,DWORD [12+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [20+esp]
xor ecx,eax
mov DWORD [16+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[961987163+edx*1+ebx]
xor ecx,esi
xor ebp,edi
ror ecx,2
add ebp,edx
add edx,DWORD [28+esp]
add ebp,ecx
mov esi,edx
mov ecx,DWORD [esp]
ror edx,14
mov edi,DWORD [4+esp]
xor edx,esi
mov ebx,DWORD [52+esp]
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [28+esp],esi
xor edx,esi
add ebx,DWORD [8+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [16+esp]
xor esi,ebp
mov DWORD [12+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[1508970993+edx*1+ebx]
xor esi,ecx
xor eax,edi
ror esi,2
add eax,edx
add edx,DWORD [24+esp]
add eax,esi
mov ecx,edx
mov esi,DWORD [28+esp]
ror edx,14
mov edi,DWORD [esp]
xor edx,ecx
mov ebx,DWORD [56+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [24+esp],ecx
xor edx,ecx
add ebx,DWORD [4+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [12+esp]
xor ecx,eax
mov DWORD [8+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[2453635748+edx*1+ebx]
xor ecx,esi
xor ebp,edi
ror ecx,2
add ebp,edx
add edx,DWORD [20+esp]
add ebp,ecx
mov esi,edx
mov ecx,DWORD [24+esp]
ror edx,14
mov edi,DWORD [28+esp]
xor edx,esi
mov ebx,DWORD [60+esp]
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [20+esp],esi
xor edx,esi
add ebx,DWORD [esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [8+esp]
xor esi,ebp
mov DWORD [4+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[2870763221+edx*1+ebx]
xor esi,ecx
xor eax,edi
ror esi,2
add eax,edx
add edx,DWORD [16+esp]
add eax,esi
mov ecx,edx
mov esi,DWORD [20+esp]
ror edx,14
mov edi,DWORD [24+esp]
xor edx,ecx
mov ebx,DWORD [64+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [16+esp],ecx
xor edx,ecx
add ebx,DWORD [28+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [4+esp]
xor ecx,eax
mov DWORD [esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[3624381080+edx*1+ebx]
xor ecx,esi
xor ebp,edi
ror ecx,2
add ebp,edx
add edx,DWORD [12+esp]
add ebp,ecx
mov esi,edx
mov ecx,DWORD [16+esp]
ror edx,14
mov edi,DWORD [20+esp]
xor edx,esi
mov ebx,DWORD [68+esp]
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [12+esp],esi
xor edx,esi
add ebx,DWORD [24+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [esp]
xor esi,ebp
mov DWORD [28+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[310598401+edx*1+ebx]
xor esi,ecx
xor eax,edi
ror esi,2
add eax,edx
add edx,DWORD [8+esp]
add eax,esi
mov ecx,edx
mov esi,DWORD [12+esp]
ror edx,14
mov edi,DWORD [16+esp]
xor edx,ecx
mov ebx,DWORD [72+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [8+esp],ecx
xor edx,ecx
add ebx,DWORD [20+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [28+esp]
xor ecx,eax
mov DWORD [24+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[607225278+edx*1+ebx]
xor ecx,esi
xor ebp,edi
ror ecx,2
add ebp,edx
add edx,DWORD [4+esp]
add ebp,ecx
mov esi,edx
mov ecx,DWORD [8+esp]
ror edx,14
mov edi,DWORD [12+esp]
xor edx,esi
mov ebx,DWORD [76+esp]
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [4+esp],esi
xor edx,esi
add ebx,DWORD [16+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [24+esp]
xor esi,ebp
mov DWORD [20+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[1426881987+edx*1+ebx]
xor esi,ecx
xor eax,edi
ror esi,2
add eax,edx
add edx,DWORD [esp]
add eax,esi
mov ecx,edx
mov esi,DWORD [4+esp]
ror edx,14
mov edi,DWORD [8+esp]
xor edx,ecx
mov ebx,DWORD [80+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [esp],ecx
xor edx,ecx
add ebx,DWORD [12+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [20+esp]
xor ecx,eax
mov DWORD [16+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[1925078388+edx*1+ebx]
xor ecx,esi
xor ebp,edi
ror ecx,2
add ebp,edx
add edx,DWORD [28+esp]
add ebp,ecx
mov esi,edx
mov ecx,DWORD [esp]
ror edx,14
mov edi,DWORD [4+esp]
xor edx,esi
mov ebx,DWORD [84+esp]
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [28+esp],esi
xor edx,esi
add ebx,DWORD [8+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [16+esp]
xor esi,ebp
mov DWORD [12+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[2162078206+edx*1+ebx]
xor esi,ecx
xor eax,edi
ror esi,2
add eax,edx
add edx,DWORD [24+esp]
add eax,esi
mov ecx,edx
mov esi,DWORD [28+esp]
ror edx,14
mov edi,DWORD [esp]
xor edx,ecx
mov ebx,DWORD [88+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [24+esp],ecx
xor edx,ecx
add ebx,DWORD [4+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [12+esp]
xor ecx,eax
mov DWORD [8+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[2614888103+edx*1+ebx]
xor ecx,esi
xor ebp,edi
ror ecx,2
add ebp,edx
add edx,DWORD [20+esp]
add ebp,ecx
mov esi,edx
mov ecx,DWORD [24+esp]
ror edx,14
mov edi,DWORD [28+esp]
xor edx,esi
mov ebx,DWORD [92+esp]
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [20+esp],esi
xor edx,esi
add ebx,DWORD [esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [8+esp]
xor esi,ebp
mov DWORD [4+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[3248222580+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [36+esp]
ror esi,2
add eax,edx
add edx,DWORD [16+esp]
add eax,esi
mov esi,DWORD [88+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [32+esp]
shr edi,10
add ebx,DWORD [68+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [20+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [24+esp]
xor edx,ecx
mov DWORD [32+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [16+esp],ecx
xor edx,ecx
add ebx,DWORD [28+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [4+esp]
xor ecx,eax
mov DWORD [esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[3835390401+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [40+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [12+esp]
add ebp,ecx
mov ecx,DWORD [92+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [36+esp]
shr edi,10
add ebx,DWORD [72+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [16+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [20+esp]
xor edx,esi
mov DWORD [36+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [12+esp],esi
xor edx,esi
add ebx,DWORD [24+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [esp]
xor esi,ebp
mov DWORD [28+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[4022224774+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [44+esp]
ror esi,2
add eax,edx
add edx,DWORD [8+esp]
add eax,esi
mov esi,DWORD [32+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [40+esp]
shr edi,10
add ebx,DWORD [76+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [12+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [16+esp]
xor edx,ecx
mov DWORD [40+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [8+esp],ecx
xor edx,ecx
add ebx,DWORD [20+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [28+esp]
xor ecx,eax
mov DWORD [24+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[264347078+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [48+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [4+esp]
add ebp,ecx
mov ecx,DWORD [36+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [44+esp]
shr edi,10
add ebx,DWORD [80+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [8+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [12+esp]
xor edx,esi
mov DWORD [44+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [4+esp],esi
xor edx,esi
add ebx,DWORD [16+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [24+esp]
xor esi,ebp
mov DWORD [20+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[604807628+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [52+esp]
ror esi,2
add eax,edx
add edx,DWORD [esp]
add eax,esi
mov esi,DWORD [40+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [48+esp]
shr edi,10
add ebx,DWORD [84+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [4+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [8+esp]
xor edx,ecx
mov DWORD [48+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [esp],ecx
xor edx,ecx
add ebx,DWORD [12+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [20+esp]
xor ecx,eax
mov DWORD [16+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[770255983+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [56+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [28+esp]
add ebp,ecx
mov ecx,DWORD [44+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [52+esp]
shr edi,10
add ebx,DWORD [88+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [esp]
ror edx,14
add ebx,edi
mov edi,DWORD [4+esp]
xor edx,esi
mov DWORD [52+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [28+esp],esi
xor edx,esi
add ebx,DWORD [8+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [16+esp]
xor esi,ebp
mov DWORD [12+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[1249150122+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [60+esp]
ror esi,2
add eax,edx
add edx,DWORD [24+esp]
add eax,esi
mov esi,DWORD [48+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [56+esp]
shr edi,10
add ebx,DWORD [92+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [28+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [esp]
xor edx,ecx
mov DWORD [56+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [24+esp],ecx
xor edx,ecx
add ebx,DWORD [4+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [12+esp]
xor ecx,eax
mov DWORD [8+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[1555081692+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [64+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [20+esp]
add ebp,ecx
mov ecx,DWORD [52+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [60+esp]
shr edi,10
add ebx,DWORD [32+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [24+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [28+esp]
xor edx,esi
mov DWORD [60+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [20+esp],esi
xor edx,esi
add ebx,DWORD [esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [8+esp]
xor esi,ebp
mov DWORD [4+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[1996064986+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [68+esp]
ror esi,2
add eax,edx
add edx,DWORD [16+esp]
add eax,esi
mov esi,DWORD [56+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [64+esp]
shr edi,10
add ebx,DWORD [36+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [20+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [24+esp]
xor edx,ecx
mov DWORD [64+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [16+esp],ecx
xor edx,ecx
add ebx,DWORD [28+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [4+esp]
xor ecx,eax
mov DWORD [esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[2554220882+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [72+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [12+esp]
add ebp,ecx
mov ecx,DWORD [60+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [68+esp]
shr edi,10
add ebx,DWORD [40+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [16+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [20+esp]
xor edx,esi
mov DWORD [68+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [12+esp],esi
xor edx,esi
add ebx,DWORD [24+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [esp]
xor esi,ebp
mov DWORD [28+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[2821834349+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [76+esp]
ror esi,2
add eax,edx
add edx,DWORD [8+esp]
add eax,esi
mov esi,DWORD [64+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [72+esp]
shr edi,10
add ebx,DWORD [44+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [12+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [16+esp]
xor edx,ecx
mov DWORD [72+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [8+esp],ecx
xor edx,ecx
add ebx,DWORD [20+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [28+esp]
xor ecx,eax
mov DWORD [24+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[2952996808+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [80+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [4+esp]
add ebp,ecx
mov ecx,DWORD [68+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [76+esp]
shr edi,10
add ebx,DWORD [48+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [8+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [12+esp]
xor edx,esi
mov DWORD [76+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [4+esp],esi
xor edx,esi
add ebx,DWORD [16+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [24+esp]
xor esi,ebp
mov DWORD [20+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[3210313671+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [84+esp]
ror esi,2
add eax,edx
add edx,DWORD [esp]
add eax,esi
mov esi,DWORD [72+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [80+esp]
shr edi,10
add ebx,DWORD [52+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [4+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [8+esp]
xor edx,ecx
mov DWORD [80+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [esp],ecx
xor edx,ecx
add ebx,DWORD [12+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [20+esp]
xor ecx,eax
mov DWORD [16+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[3336571891+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [88+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [28+esp]
add ebp,ecx
mov ecx,DWORD [76+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [84+esp]
shr edi,10
add ebx,DWORD [56+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [esp]
ror edx,14
add ebx,edi
mov edi,DWORD [4+esp]
xor edx,esi
mov DWORD [84+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [28+esp],esi
xor edx,esi
add ebx,DWORD [8+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [16+esp]
xor esi,ebp
mov DWORD [12+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[3584528711+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [92+esp]
ror esi,2
add eax,edx
add edx,DWORD [24+esp]
add eax,esi
mov esi,DWORD [80+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [88+esp]
shr edi,10
add ebx,DWORD [60+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [28+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [esp]
xor edx,ecx
mov DWORD [88+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [24+esp],ecx
xor edx,ecx
add ebx,DWORD [4+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [12+esp]
xor ecx,eax
mov DWORD [8+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[113926993+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [32+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [20+esp]
add ebp,ecx
mov ecx,DWORD [84+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [92+esp]
shr edi,10
add ebx,DWORD [64+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [24+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [28+esp]
xor edx,esi
mov DWORD [92+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [20+esp],esi
xor edx,esi
add ebx,DWORD [esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [8+esp]
xor esi,ebp
mov DWORD [4+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[338241895+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [36+esp]
ror esi,2
add eax,edx
add edx,DWORD [16+esp]
add eax,esi
mov esi,DWORD [88+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [32+esp]
shr edi,10
add ebx,DWORD [68+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [20+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [24+esp]
xor edx,ecx
mov DWORD [32+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [16+esp],ecx
xor edx,ecx
add ebx,DWORD [28+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [4+esp]
xor ecx,eax
mov DWORD [esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[666307205+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [40+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [12+esp]
add ebp,ecx
mov ecx,DWORD [92+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [36+esp]
shr edi,10
add ebx,DWORD [72+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [16+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [20+esp]
xor edx,esi
mov DWORD [36+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [12+esp],esi
xor edx,esi
add ebx,DWORD [24+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [esp]
xor esi,ebp
mov DWORD [28+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[773529912+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [44+esp]
ror esi,2
add eax,edx
add edx,DWORD [8+esp]
add eax,esi
mov esi,DWORD [32+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [40+esp]
shr edi,10
add ebx,DWORD [76+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [12+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [16+esp]
xor edx,ecx
mov DWORD [40+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [8+esp],ecx
xor edx,ecx
add ebx,DWORD [20+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [28+esp]
xor ecx,eax
mov DWORD [24+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[1294757372+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [48+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [4+esp]
add ebp,ecx
mov ecx,DWORD [36+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [44+esp]
shr edi,10
add ebx,DWORD [80+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [8+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [12+esp]
xor edx,esi
mov DWORD [44+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [4+esp],esi
xor edx,esi
add ebx,DWORD [16+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [24+esp]
xor esi,ebp
mov DWORD [20+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[1396182291+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [52+esp]
ror esi,2
add eax,edx
add edx,DWORD [esp]
add eax,esi
mov esi,DWORD [40+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [48+esp]
shr edi,10
add ebx,DWORD [84+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [4+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [8+esp]
xor edx,ecx
mov DWORD [48+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [esp],ecx
xor edx,ecx
add ebx,DWORD [12+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [20+esp]
xor ecx,eax
mov DWORD [16+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[1695183700+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [56+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [28+esp]
add ebp,ecx
mov ecx,DWORD [44+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [52+esp]
shr edi,10
add ebx,DWORD [88+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [esp]
ror edx,14
add ebx,edi
mov edi,DWORD [4+esp]
xor edx,esi
mov DWORD [52+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [28+esp],esi
xor edx,esi
add ebx,DWORD [8+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [16+esp]
xor esi,ebp
mov DWORD [12+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[1986661051+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [60+esp]
ror esi,2
add eax,edx
add edx,DWORD [24+esp]
add eax,esi
mov esi,DWORD [48+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [56+esp]
shr edi,10
add ebx,DWORD [92+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [28+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [esp]
xor edx,ecx
mov DWORD [56+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [24+esp],ecx
xor edx,ecx
add ebx,DWORD [4+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [12+esp]
xor ecx,eax
mov DWORD [8+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[2177026350+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [64+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [20+esp]
add ebp,ecx
mov ecx,DWORD [52+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [60+esp]
shr edi,10
add ebx,DWORD [32+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [24+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [28+esp]
xor edx,esi
mov DWORD [60+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [20+esp],esi
xor edx,esi
add ebx,DWORD [esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [8+esp]
xor esi,ebp
mov DWORD [4+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[2456956037+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [68+esp]
ror esi,2
add eax,edx
add edx,DWORD [16+esp]
add eax,esi
mov esi,DWORD [56+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [64+esp]
shr edi,10
add ebx,DWORD [36+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [20+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [24+esp]
xor edx,ecx
mov DWORD [64+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [16+esp],ecx
xor edx,ecx
add ebx,DWORD [28+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [4+esp]
xor ecx,eax
mov DWORD [esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[2730485921+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [72+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [12+esp]
add ebp,ecx
mov ecx,DWORD [60+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [68+esp]
shr edi,10
add ebx,DWORD [40+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [16+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [20+esp]
xor edx,esi
mov DWORD [68+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [12+esp],esi
xor edx,esi
add ebx,DWORD [24+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [esp]
xor esi,ebp
mov DWORD [28+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[2820302411+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [76+esp]
ror esi,2
add eax,edx
add edx,DWORD [8+esp]
add eax,esi
mov esi,DWORD [64+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [72+esp]
shr edi,10
add ebx,DWORD [44+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [12+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [16+esp]
xor edx,ecx
mov DWORD [72+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [8+esp],ecx
xor edx,ecx
add ebx,DWORD [20+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [28+esp]
xor ecx,eax
mov DWORD [24+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[3259730800+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [80+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [4+esp]
add ebp,ecx
mov ecx,DWORD [68+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [76+esp]
shr edi,10
add ebx,DWORD [48+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [8+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [12+esp]
xor edx,esi
mov DWORD [76+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [4+esp],esi
xor edx,esi
add ebx,DWORD [16+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [24+esp]
xor esi,ebp
mov DWORD [20+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[3345764771+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [84+esp]
ror esi,2
add eax,edx
add edx,DWORD [esp]
add eax,esi
mov esi,DWORD [72+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [80+esp]
shr edi,10
add ebx,DWORD [52+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [4+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [8+esp]
xor edx,ecx
mov DWORD [80+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [esp],ecx
xor edx,ecx
add ebx,DWORD [12+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [20+esp]
xor ecx,eax
mov DWORD [16+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[3516065817+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [88+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [28+esp]
add ebp,ecx
mov ecx,DWORD [76+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [84+esp]
shr edi,10
add ebx,DWORD [56+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [esp]
ror edx,14
add ebx,edi
mov edi,DWORD [4+esp]
xor edx,esi
mov DWORD [84+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [28+esp],esi
xor edx,esi
add ebx,DWORD [8+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [16+esp]
xor esi,ebp
mov DWORD [12+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[3600352804+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [92+esp]
ror esi,2
add eax,edx
add edx,DWORD [24+esp]
add eax,esi
mov esi,DWORD [80+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [88+esp]
shr edi,10
add ebx,DWORD [60+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [28+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [esp]
xor edx,ecx
mov DWORD [88+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [24+esp],ecx
xor edx,ecx
add ebx,DWORD [4+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [12+esp]
xor ecx,eax
mov DWORD [8+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[4094571909+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [32+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [20+esp]
add ebp,ecx
mov ecx,DWORD [84+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [92+esp]
shr edi,10
add ebx,DWORD [64+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [24+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [28+esp]
xor edx,esi
mov DWORD [92+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [20+esp],esi
xor edx,esi
add ebx,DWORD [esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [8+esp]
xor esi,ebp
mov DWORD [4+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[275423344+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [36+esp]
ror esi,2
add eax,edx
add edx,DWORD [16+esp]
add eax,esi
mov esi,DWORD [88+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [32+esp]
shr edi,10
add ebx,DWORD [68+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [20+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [24+esp]
xor edx,ecx
mov DWORD [32+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [16+esp],ecx
xor edx,ecx
add ebx,DWORD [28+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [4+esp]
xor ecx,eax
mov DWORD [esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[430227734+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [40+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [12+esp]
add ebp,ecx
mov ecx,DWORD [92+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [36+esp]
shr edi,10
add ebx,DWORD [72+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [16+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [20+esp]
xor edx,esi
mov DWORD [36+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [12+esp],esi
xor edx,esi
add ebx,DWORD [24+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [esp]
xor esi,ebp
mov DWORD [28+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[506948616+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [44+esp]
ror esi,2
add eax,edx
add edx,DWORD [8+esp]
add eax,esi
mov esi,DWORD [32+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [40+esp]
shr edi,10
add ebx,DWORD [76+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [12+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [16+esp]
xor edx,ecx
mov DWORD [40+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [8+esp],ecx
xor edx,ecx
add ebx,DWORD [20+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [28+esp]
xor ecx,eax
mov DWORD [24+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[659060556+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [48+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [4+esp]
add ebp,ecx
mov ecx,DWORD [36+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [44+esp]
shr edi,10
add ebx,DWORD [80+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [8+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [12+esp]
xor edx,esi
mov DWORD [44+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [4+esp],esi
xor edx,esi
add ebx,DWORD [16+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [24+esp]
xor esi,ebp
mov DWORD [20+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[883997877+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [52+esp]
ror esi,2
add eax,edx
add edx,DWORD [esp]
add eax,esi
mov esi,DWORD [40+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [48+esp]
shr edi,10
add ebx,DWORD [84+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [4+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [8+esp]
xor edx,ecx
mov DWORD [48+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [esp],ecx
xor edx,ecx
add ebx,DWORD [12+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [20+esp]
xor ecx,eax
mov DWORD [16+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[958139571+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [56+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [28+esp]
add ebp,ecx
mov ecx,DWORD [44+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [52+esp]
shr edi,10
add ebx,DWORD [88+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [esp]
ror edx,14
add ebx,edi
mov edi,DWORD [4+esp]
xor edx,esi
mov DWORD [52+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [28+esp],esi
xor edx,esi
add ebx,DWORD [8+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [16+esp]
xor esi,ebp
mov DWORD [12+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[1322822218+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [60+esp]
ror esi,2
add eax,edx
add edx,DWORD [24+esp]
add eax,esi
mov esi,DWORD [48+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [56+esp]
shr edi,10
add ebx,DWORD [92+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [28+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [esp]
xor edx,ecx
mov DWORD [56+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [24+esp],ecx
xor edx,ecx
add ebx,DWORD [4+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [12+esp]
xor ecx,eax
mov DWORD [8+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[1537002063+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [64+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [20+esp]
add ebp,ecx
mov ecx,DWORD [52+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [60+esp]
shr edi,10
add ebx,DWORD [32+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [24+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [28+esp]
xor edx,esi
mov DWORD [60+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [20+esp],esi
xor edx,esi
add ebx,DWORD [esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [8+esp]
xor esi,ebp
mov DWORD [4+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[1747873779+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [68+esp]
ror esi,2
add eax,edx
add edx,DWORD [16+esp]
add eax,esi
mov esi,DWORD [56+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [64+esp]
shr edi,10
add ebx,DWORD [36+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [20+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [24+esp]
xor edx,ecx
mov DWORD [64+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [16+esp],ecx
xor edx,ecx
add ebx,DWORD [28+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [4+esp]
xor ecx,eax
mov DWORD [esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[1955562222+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [72+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [12+esp]
add ebp,ecx
mov ecx,DWORD [60+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [68+esp]
shr edi,10
add ebx,DWORD [40+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [16+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [20+esp]
xor edx,esi
mov DWORD [68+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [12+esp],esi
xor edx,esi
add ebx,DWORD [24+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [esp]
xor esi,ebp
mov DWORD [28+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[2024104815+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [76+esp]
ror esi,2
add eax,edx
add edx,DWORD [8+esp]
add eax,esi
mov esi,DWORD [64+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [72+esp]
shr edi,10
add ebx,DWORD [44+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [12+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [16+esp]
xor edx,ecx
mov DWORD [72+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [8+esp],ecx
xor edx,ecx
add ebx,DWORD [20+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [28+esp]
xor ecx,eax
mov DWORD [24+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[2227730452+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [80+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [4+esp]
add ebp,ecx
mov ecx,DWORD [68+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [76+esp]
shr edi,10
add ebx,DWORD [48+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [8+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [12+esp]
xor edx,esi
mov DWORD [76+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [4+esp],esi
xor edx,esi
add ebx,DWORD [16+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [24+esp]
xor esi,ebp
mov DWORD [20+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[2361852424+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [84+esp]
ror esi,2
add eax,edx
add edx,DWORD [esp]
add eax,esi
mov esi,DWORD [72+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [80+esp]
shr edi,10
add ebx,DWORD [52+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [4+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [8+esp]
xor edx,ecx
mov DWORD [80+esp],ebx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [esp],ecx
xor edx,ecx
add ebx,DWORD [12+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [20+esp]
xor ecx,eax
mov DWORD [16+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[2428436474+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [88+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [28+esp]
add ebp,ecx
mov ecx,DWORD [76+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [84+esp]
shr edi,10
add ebx,DWORD [56+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [esp]
ror edx,14
add ebx,edi
mov edi,DWORD [4+esp]
xor edx,esi
mov DWORD [84+esp],ebx
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [28+esp],esi
xor edx,esi
add ebx,DWORD [8+esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [16+esp]
xor esi,ebp
mov DWORD [12+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[2756734187+edx*1+ebx]
xor esi,ecx
xor eax,edi
mov ecx,DWORD [92+esp]
ror esi,2
add eax,edx
add edx,DWORD [24+esp]
add eax,esi
mov esi,DWORD [80+esp]
mov ebx,ecx
ror ecx,11
mov edi,esi
ror esi,2
xor ecx,ebx
shr ebx,3
ror ecx,7
xor esi,edi
xor ebx,ecx
ror esi,17
add ebx,DWORD [88+esp]
shr edi,10
add ebx,DWORD [60+esp]
mov ecx,edx
xor edi,esi
mov esi,DWORD [28+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [esp]
xor edx,ecx
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [24+esp],ecx
xor edx,ecx
add ebx,DWORD [4+esp]
xor edi,esi
ror edx,6
mov ecx,eax
add ebx,edi
ror ecx,9
mov esi,eax
mov edi,DWORD [12+esp]
xor ecx,eax
mov DWORD [8+esp],eax
xor eax,edi
ror ecx,11
and ebp,eax
lea edx,[3204031479+edx*1+ebx]
xor ecx,esi
xor ebp,edi
mov esi,DWORD [32+esp]
ror ecx,2
add ebp,edx
add edx,DWORD [20+esp]
add ebp,ecx
mov ecx,DWORD [84+esp]
mov ebx,esi
ror esi,11
mov edi,ecx
ror ecx,2
xor esi,ebx
shr ebx,3
ror esi,7
xor ecx,edi
xor ebx,esi
ror ecx,17
add ebx,DWORD [92+esp]
shr edi,10
add ebx,DWORD [64+esp]
mov esi,edx
xor edi,ecx
mov ecx,DWORD [24+esp]
ror edx,14
add ebx,edi
mov edi,DWORD [28+esp]
xor edx,esi
xor ecx,edi
ror edx,5
and ecx,esi
mov DWORD [20+esp],esi
xor edx,esi
add ebx,DWORD [esp]
xor edi,ecx
ror edx,6
mov esi,ebp
add ebx,edi
ror esi,9
mov ecx,ebp
mov edi,DWORD [8+esp]
xor esi,ebp
mov DWORD [4+esp],ebp
xor ebp,edi
ror esi,11
and eax,ebp
lea edx,[3329325298+edx*1+ebx]
xor esi,ecx
xor eax,edi
ror esi,2
add eax,edx
add edx,DWORD [16+esp]
add eax,esi
mov esi,DWORD [96+esp]
xor ebp,edi
mov ecx,DWORD [12+esp]
add eax,DWORD [esi]
add ebp,DWORD [4+esi]
add edi,DWORD [8+esi]
add ecx,DWORD [12+esi]
mov DWORD [esi],eax
mov DWORD [4+esi],ebp
mov DWORD [8+esi],edi
mov DWORD [12+esi],ecx
mov DWORD [4+esp],ebp
xor ebp,edi
mov DWORD [8+esp],edi
mov DWORD [12+esp],ecx
mov edi,DWORD [20+esp]
mov ebx,DWORD [24+esp]
mov ecx,DWORD [28+esp]
add edx,DWORD [16+esi]
add edi,DWORD [20+esi]
add ebx,DWORD [24+esi]
add ecx,DWORD [28+esi]
mov DWORD [16+esi],edx
mov DWORD [20+esi],edi
mov DWORD [24+esi],ebx
mov DWORD [28+esi],ecx
mov DWORD [20+esp],edi
mov edi,DWORD [100+esp]
mov DWORD [24+esp],ebx
mov DWORD [28+esp],ecx
cmp edi,DWORD [104+esp]
jb NEAR L$009grand_loop
mov esp,DWORD [108+esp]
pop edi
pop esi
pop ebx
pop ebp
ret
align 32
L$005SSSE3:
lea esp,[esp-96]
mov eax,DWORD [esi]
mov ebx,DWORD [4+esi]
mov ecx,DWORD [8+esi]
mov edi,DWORD [12+esi]
mov DWORD [4+esp],ebx
xor ebx,ecx
mov DWORD [8+esp],ecx
mov DWORD [12+esp],edi
mov edx,DWORD [16+esi]
mov edi,DWORD [20+esi]
mov ecx,DWORD [24+esi]
mov esi,DWORD [28+esi]
mov DWORD [20+esp],edi
mov edi,DWORD [100+esp]
mov DWORD [24+esp],ecx
mov DWORD [28+esp],esi
movdqa xmm7,[256+ebp]
jmp NEAR L$010grand_ssse3
align 16
L$010grand_ssse3:
movdqu xmm0,[edi]
movdqu xmm1,[16+edi]
movdqu xmm2,[32+edi]
movdqu xmm3,[48+edi]
add edi,64
db 102,15,56,0,199
mov DWORD [100+esp],edi
db 102,15,56,0,207
movdqa xmm4,[ebp]
db 102,15,56,0,215
movdqa xmm5,[16+ebp]
paddd xmm4,xmm0
db 102,15,56,0,223
movdqa xmm6,[32+ebp]
paddd xmm5,xmm1
movdqa xmm7,[48+ebp]
movdqa [32+esp],xmm4
paddd xmm6,xmm2
movdqa [48+esp],xmm5
paddd xmm7,xmm3
movdqa [64+esp],xmm6
movdqa [80+esp],xmm7
jmp NEAR L$011ssse3_00_47
align 16
L$011ssse3_00_47:
add ebp,64
mov ecx,edx
movdqa xmm4,xmm1
ror edx,14
mov esi,DWORD [20+esp]
movdqa xmm7,xmm3
xor edx,ecx
mov edi,DWORD [24+esp]
db 102,15,58,15,224,4
xor esi,edi
ror edx,5
and esi,ecx
db 102,15,58,15,250,4
mov DWORD [16+esp],ecx
xor edx,ecx
xor edi,esi
movdqa xmm5,xmm4
ror edx,6
mov ecx,eax
movdqa xmm6,xmm4
add edx,edi
mov edi,DWORD [4+esp]
psrld xmm4,3
mov esi,eax
ror ecx,9
paddd xmm0,xmm7
mov DWORD [esp],eax
xor ecx,eax
psrld xmm6,7
xor eax,edi
add edx,DWORD [28+esp]
ror ecx,11
and ebx,eax
pshufd xmm7,xmm3,250
xor ecx,esi
add edx,DWORD [32+esp]
pslld xmm5,14
xor ebx,edi
ror ecx,2
pxor xmm4,xmm6
add ebx,edx
add edx,DWORD [12+esp]
psrld xmm6,11
add ebx,ecx
mov ecx,edx
ror edx,14
pxor xmm4,xmm5
mov esi,DWORD [16+esp]
xor edx,ecx
pslld xmm5,11
mov edi,DWORD [20+esp]
xor esi,edi
ror edx,5
pxor xmm4,xmm6
and esi,ecx
mov DWORD [12+esp],ecx
movdqa xmm6,xmm7
xor edx,ecx
xor edi,esi
ror edx,6
pxor xmm4,xmm5
mov ecx,ebx
add edx,edi
psrld xmm7,10
mov edi,DWORD [esp]
mov esi,ebx
ror ecx,9
paddd xmm0,xmm4
mov DWORD [28+esp],ebx
xor ecx,ebx
psrlq xmm6,17
xor ebx,edi
add edx,DWORD [24+esp]
ror ecx,11
pxor xmm7,xmm6
and eax,ebx
xor ecx,esi
psrlq xmm6,2
add edx,DWORD [36+esp]
xor eax,edi
ror ecx,2
pxor xmm7,xmm6
add eax,edx
add edx,DWORD [8+esp]
pshufd xmm7,xmm7,128
add eax,ecx
mov ecx,edx
ror edx,14
mov esi,DWORD [12+esp]
xor edx,ecx
mov edi,DWORD [16+esp]
xor esi,edi
ror edx,5
and esi,ecx
psrldq xmm7,8
mov DWORD [8+esp],ecx
xor edx,ecx
xor edi,esi
paddd xmm0,xmm7
ror edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [28+esp]
mov esi,eax
ror ecx,9
mov DWORD [24+esp],eax
pshufd xmm7,xmm0,80
xor ecx,eax
xor eax,edi
add edx,DWORD [20+esp]
movdqa xmm6,xmm7
ror ecx,11
psrld xmm7,10
and ebx,eax
psrlq xmm6,17
xor ecx,esi
add edx,DWORD [40+esp]
xor ebx,edi
ror ecx,2
pxor xmm7,xmm6
add ebx,edx
add edx,DWORD [4+esp]
psrlq xmm6,2
add ebx,ecx
mov ecx,edx
ror edx,14
pxor xmm7,xmm6
mov esi,DWORD [8+esp]
xor edx,ecx
mov edi,DWORD [12+esp]
pshufd xmm7,xmm7,8
xor esi,edi
ror edx,5
movdqa xmm6,[ebp]
and esi,ecx
mov DWORD [4+esp],ecx
pslldq xmm7,8
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [24+esp]
mov esi,ebx
ror ecx,9
paddd xmm0,xmm7
mov DWORD [20+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [16+esp]
paddd xmm6,xmm0
ror ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [44+esp]
xor eax,edi
ror ecx,2
add eax,edx
add edx,DWORD [esp]
add eax,ecx
movdqa [32+esp],xmm6
mov ecx,edx
movdqa xmm4,xmm2
ror edx,14
mov esi,DWORD [4+esp]
movdqa xmm7,xmm0
xor edx,ecx
mov edi,DWORD [8+esp]
db 102,15,58,15,225,4
xor esi,edi
ror edx,5
and esi,ecx
db 102,15,58,15,251,4
mov DWORD [esp],ecx
xor edx,ecx
xor edi,esi
movdqa xmm5,xmm4
ror edx,6
mov ecx,eax
movdqa xmm6,xmm4
add edx,edi
mov edi,DWORD [20+esp]
psrld xmm4,3
mov esi,eax
ror ecx,9
paddd xmm1,xmm7
mov DWORD [16+esp],eax
xor ecx,eax
psrld xmm6,7
xor eax,edi
add edx,DWORD [12+esp]
ror ecx,11
and ebx,eax
pshufd xmm7,xmm0,250
xor ecx,esi
add edx,DWORD [48+esp]
pslld xmm5,14
xor ebx,edi
ror ecx,2
pxor xmm4,xmm6
add ebx,edx
add edx,DWORD [28+esp]
psrld xmm6,11
add ebx,ecx
mov ecx,edx
ror edx,14
pxor xmm4,xmm5
mov esi,DWORD [esp]
xor edx,ecx
pslld xmm5,11
mov edi,DWORD [4+esp]
xor esi,edi
ror edx,5
pxor xmm4,xmm6
and esi,ecx
mov DWORD [28+esp],ecx
movdqa xmm6,xmm7
xor edx,ecx
xor edi,esi
ror edx,6
pxor xmm4,xmm5
mov ecx,ebx
add edx,edi
psrld xmm7,10
mov edi,DWORD [16+esp]
mov esi,ebx
ror ecx,9
paddd xmm1,xmm4
mov DWORD [12+esp],ebx
xor ecx,ebx
psrlq xmm6,17
xor ebx,edi
add edx,DWORD [8+esp]
ror ecx,11
pxor xmm7,xmm6
and eax,ebx
xor ecx,esi
psrlq xmm6,2
add edx,DWORD [52+esp]
xor eax,edi
ror ecx,2
pxor xmm7,xmm6
add eax,edx
add edx,DWORD [24+esp]
pshufd xmm7,xmm7,128
add eax,ecx
mov ecx,edx
ror edx,14
mov esi,DWORD [28+esp]
xor edx,ecx
mov edi,DWORD [esp]
xor esi,edi
ror edx,5
and esi,ecx
psrldq xmm7,8
mov DWORD [24+esp],ecx
xor edx,ecx
xor edi,esi
paddd xmm1,xmm7
ror edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [12+esp]
mov esi,eax
ror ecx,9
mov DWORD [8+esp],eax
pshufd xmm7,xmm1,80
xor ecx,eax
xor eax,edi
add edx,DWORD [4+esp]
movdqa xmm6,xmm7
ror ecx,11
psrld xmm7,10
and ebx,eax
psrlq xmm6,17
xor ecx,esi
add edx,DWORD [56+esp]
xor ebx,edi
ror ecx,2
pxor xmm7,xmm6
add ebx,edx
add edx,DWORD [20+esp]
psrlq xmm6,2
add ebx,ecx
mov ecx,edx
ror edx,14
pxor xmm7,xmm6
mov esi,DWORD [24+esp]
xor edx,ecx
mov edi,DWORD [28+esp]
pshufd xmm7,xmm7,8
xor esi,edi
ror edx,5
movdqa xmm6,[16+ebp]
and esi,ecx
mov DWORD [20+esp],ecx
pslldq xmm7,8
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [8+esp]
mov esi,ebx
ror ecx,9
paddd xmm1,xmm7
mov DWORD [4+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [esp]
paddd xmm6,xmm1
ror ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [60+esp]
xor eax,edi
ror ecx,2
add eax,edx
add edx,DWORD [16+esp]
add eax,ecx
movdqa [48+esp],xmm6
mov ecx,edx
movdqa xmm4,xmm3
ror edx,14
mov esi,DWORD [20+esp]
movdqa xmm7,xmm1
xor edx,ecx
mov edi,DWORD [24+esp]
db 102,15,58,15,226,4
xor esi,edi
ror edx,5
and esi,ecx
db 102,15,58,15,248,4
mov DWORD [16+esp],ecx
xor edx,ecx
xor edi,esi
movdqa xmm5,xmm4
ror edx,6
mov ecx,eax
movdqa xmm6,xmm4
add edx,edi
mov edi,DWORD [4+esp]
psrld xmm4,3
mov esi,eax
ror ecx,9
paddd xmm2,xmm7
mov DWORD [esp],eax
xor ecx,eax
psrld xmm6,7
xor eax,edi
add edx,DWORD [28+esp]
ror ecx,11
and ebx,eax
pshufd xmm7,xmm1,250
xor ecx,esi
add edx,DWORD [64+esp]
pslld xmm5,14
xor ebx,edi
ror ecx,2
pxor xmm4,xmm6
add ebx,edx
add edx,DWORD [12+esp]
psrld xmm6,11
add ebx,ecx
mov ecx,edx
ror edx,14
pxor xmm4,xmm5
mov esi,DWORD [16+esp]
xor edx,ecx
pslld xmm5,11
mov edi,DWORD [20+esp]
xor esi,edi
ror edx,5
pxor xmm4,xmm6
and esi,ecx
mov DWORD [12+esp],ecx
movdqa xmm6,xmm7
xor edx,ecx
xor edi,esi
ror edx,6
pxor xmm4,xmm5
mov ecx,ebx
add edx,edi
psrld xmm7,10
mov edi,DWORD [esp]
mov esi,ebx
ror ecx,9
paddd xmm2,xmm4
mov DWORD [28+esp],ebx
xor ecx,ebx
psrlq xmm6,17
xor ebx,edi
add edx,DWORD [24+esp]
ror ecx,11
pxor xmm7,xmm6
and eax,ebx
xor ecx,esi
psrlq xmm6,2
add edx,DWORD [68+esp]
xor eax,edi
ror ecx,2
pxor xmm7,xmm6
add eax,edx
add edx,DWORD [8+esp]
pshufd xmm7,xmm7,128
add eax,ecx
mov ecx,edx
ror edx,14
mov esi,DWORD [12+esp]
xor edx,ecx
mov edi,DWORD [16+esp]
xor esi,edi
ror edx,5
and esi,ecx
psrldq xmm7,8
mov DWORD [8+esp],ecx
xor edx,ecx
xor edi,esi
paddd xmm2,xmm7
ror edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [28+esp]
mov esi,eax
ror ecx,9
mov DWORD [24+esp],eax
pshufd xmm7,xmm2,80
xor ecx,eax
xor eax,edi
add edx,DWORD [20+esp]
movdqa xmm6,xmm7
ror ecx,11
psrld xmm7,10
and ebx,eax
psrlq xmm6,17
xor ecx,esi
add edx,DWORD [72+esp]
xor ebx,edi
ror ecx,2
pxor xmm7,xmm6
add ebx,edx
add edx,DWORD [4+esp]
psrlq xmm6,2
add ebx,ecx
mov ecx,edx
ror edx,14
pxor xmm7,xmm6
mov esi,DWORD [8+esp]
xor edx,ecx
mov edi,DWORD [12+esp]
pshufd xmm7,xmm7,8
xor esi,edi
ror edx,5
movdqa xmm6,[32+ebp]
and esi,ecx
mov DWORD [4+esp],ecx
pslldq xmm7,8
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [24+esp]
mov esi,ebx
ror ecx,9
paddd xmm2,xmm7
mov DWORD [20+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [16+esp]
paddd xmm6,xmm2
ror ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [76+esp]
xor eax,edi
ror ecx,2
add eax,edx
add edx,DWORD [esp]
add eax,ecx
movdqa [64+esp],xmm6
mov ecx,edx
movdqa xmm4,xmm0
ror edx,14
mov esi,DWORD [4+esp]
movdqa xmm7,xmm2
xor edx,ecx
mov edi,DWORD [8+esp]
db 102,15,58,15,227,4
xor esi,edi
ror edx,5
and esi,ecx
db 102,15,58,15,249,4
mov DWORD [esp],ecx
xor edx,ecx
xor edi,esi
movdqa xmm5,xmm4
ror edx,6
mov ecx,eax
movdqa xmm6,xmm4
add edx,edi
mov edi,DWORD [20+esp]
psrld xmm4,3
mov esi,eax
ror ecx,9
paddd xmm3,xmm7
mov DWORD [16+esp],eax
xor ecx,eax
psrld xmm6,7
xor eax,edi
add edx,DWORD [12+esp]
ror ecx,11
and ebx,eax
pshufd xmm7,xmm2,250
xor ecx,esi
add edx,DWORD [80+esp]
pslld xmm5,14
xor ebx,edi
ror ecx,2
pxor xmm4,xmm6
add ebx,edx
add edx,DWORD [28+esp]
psrld xmm6,11
add ebx,ecx
mov ecx,edx
ror edx,14
pxor xmm4,xmm5
mov esi,DWORD [esp]
xor edx,ecx
pslld xmm5,11
mov edi,DWORD [4+esp]
xor esi,edi
ror edx,5
pxor xmm4,xmm6
and esi,ecx
mov DWORD [28+esp],ecx
movdqa xmm6,xmm7
xor edx,ecx
xor edi,esi
ror edx,6
pxor xmm4,xmm5
mov ecx,ebx
add edx,edi
psrld xmm7,10
mov edi,DWORD [16+esp]
mov esi,ebx
ror ecx,9
paddd xmm3,xmm4
mov DWORD [12+esp],ebx
xor ecx,ebx
psrlq xmm6,17
xor ebx,edi
add edx,DWORD [8+esp]
ror ecx,11
pxor xmm7,xmm6
and eax,ebx
xor ecx,esi
psrlq xmm6,2
add edx,DWORD [84+esp]
xor eax,edi
ror ecx,2
pxor xmm7,xmm6
add eax,edx
add edx,DWORD [24+esp]
pshufd xmm7,xmm7,128
add eax,ecx
mov ecx,edx
ror edx,14
mov esi,DWORD [28+esp]
xor edx,ecx
mov edi,DWORD [esp]
xor esi,edi
ror edx,5
and esi,ecx
psrldq xmm7,8
mov DWORD [24+esp],ecx
xor edx,ecx
xor edi,esi
paddd xmm3,xmm7
ror edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [12+esp]
mov esi,eax
ror ecx,9
mov DWORD [8+esp],eax
pshufd xmm7,xmm3,80
xor ecx,eax
xor eax,edi
add edx,DWORD [4+esp]
movdqa xmm6,xmm7
ror ecx,11
psrld xmm7,10
and ebx,eax
psrlq xmm6,17
xor ecx,esi
add edx,DWORD [88+esp]
xor ebx,edi
ror ecx,2
pxor xmm7,xmm6
add ebx,edx
add edx,DWORD [20+esp]
psrlq xmm6,2
add ebx,ecx
mov ecx,edx
ror edx,14
pxor xmm7,xmm6
mov esi,DWORD [24+esp]
xor edx,ecx
mov edi,DWORD [28+esp]
pshufd xmm7,xmm7,8
xor esi,edi
ror edx,5
movdqa xmm6,[48+ebp]
and esi,ecx
mov DWORD [20+esp],ecx
pslldq xmm7,8
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [8+esp]
mov esi,ebx
ror ecx,9
paddd xmm3,xmm7
mov DWORD [4+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [esp]
paddd xmm6,xmm3
ror ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [92+esp]
xor eax,edi
ror ecx,2
add eax,edx
add edx,DWORD [16+esp]
add eax,ecx
movdqa [80+esp],xmm6
cmp DWORD [64+ebp],66051
jne NEAR L$011ssse3_00_47
mov ecx,edx
ror edx,14
mov esi,DWORD [20+esp]
xor edx,ecx
mov edi,DWORD [24+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [16+esp],ecx
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [4+esp]
mov esi,eax
ror ecx,9
mov DWORD [esp],eax
xor ecx,eax
xor eax,edi
add edx,DWORD [28+esp]
ror ecx,11
and ebx,eax
xor ecx,esi
add edx,DWORD [32+esp]
xor ebx,edi
ror ecx,2
add ebx,edx
add edx,DWORD [12+esp]
add ebx,ecx
mov ecx,edx
ror edx,14
mov esi,DWORD [16+esp]
xor edx,ecx
mov edi,DWORD [20+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [12+esp],ecx
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [esp]
mov esi,ebx
ror ecx,9
mov DWORD [28+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [24+esp]
ror ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [36+esp]
xor eax,edi
ror ecx,2
add eax,edx
add edx,DWORD [8+esp]
add eax,ecx
mov ecx,edx
ror edx,14
mov esi,DWORD [12+esp]
xor edx,ecx
mov edi,DWORD [16+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [8+esp],ecx
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [28+esp]
mov esi,eax
ror ecx,9
mov DWORD [24+esp],eax
xor ecx,eax
xor eax,edi
add edx,DWORD [20+esp]
ror ecx,11
and ebx,eax
xor ecx,esi
add edx,DWORD [40+esp]
xor ebx,edi
ror ecx,2
add ebx,edx
add edx,DWORD [4+esp]
add ebx,ecx
mov ecx,edx
ror edx,14
mov esi,DWORD [8+esp]
xor edx,ecx
mov edi,DWORD [12+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [4+esp],ecx
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [24+esp]
mov esi,ebx
ror ecx,9
mov DWORD [20+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [16+esp]
ror ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [44+esp]
xor eax,edi
ror ecx,2
add eax,edx
add edx,DWORD [esp]
add eax,ecx
mov ecx,edx
ror edx,14
mov esi,DWORD [4+esp]
xor edx,ecx
mov edi,DWORD [8+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [esp],ecx
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [20+esp]
mov esi,eax
ror ecx,9
mov DWORD [16+esp],eax
xor ecx,eax
xor eax,edi
add edx,DWORD [12+esp]
ror ecx,11
and ebx,eax
xor ecx,esi
add edx,DWORD [48+esp]
xor ebx,edi
ror ecx,2
add ebx,edx
add edx,DWORD [28+esp]
add ebx,ecx
mov ecx,edx
ror edx,14
mov esi,DWORD [esp]
xor edx,ecx
mov edi,DWORD [4+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [28+esp],ecx
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [16+esp]
mov esi,ebx
ror ecx,9
mov DWORD [12+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [8+esp]
ror ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [52+esp]
xor eax,edi
ror ecx,2
add eax,edx
add edx,DWORD [24+esp]
add eax,ecx
mov ecx,edx
ror edx,14
mov esi,DWORD [28+esp]
xor edx,ecx
mov edi,DWORD [esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [24+esp],ecx
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [12+esp]
mov esi,eax
ror ecx,9
mov DWORD [8+esp],eax
xor ecx,eax
xor eax,edi
add edx,DWORD [4+esp]
ror ecx,11
and ebx,eax
xor ecx,esi
add edx,DWORD [56+esp]
xor ebx,edi
ror ecx,2
add ebx,edx
add edx,DWORD [20+esp]
add ebx,ecx
mov ecx,edx
ror edx,14
mov esi,DWORD [24+esp]
xor edx,ecx
mov edi,DWORD [28+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [20+esp],ecx
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [8+esp]
mov esi,ebx
ror ecx,9
mov DWORD [4+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [esp]
ror ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [60+esp]
xor eax,edi
ror ecx,2
add eax,edx
add edx,DWORD [16+esp]
add eax,ecx
mov ecx,edx
ror edx,14
mov esi,DWORD [20+esp]
xor edx,ecx
mov edi,DWORD [24+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [16+esp],ecx
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [4+esp]
mov esi,eax
ror ecx,9
mov DWORD [esp],eax
xor ecx,eax
xor eax,edi
add edx,DWORD [28+esp]
ror ecx,11
and ebx,eax
xor ecx,esi
add edx,DWORD [64+esp]
xor ebx,edi
ror ecx,2
add ebx,edx
add edx,DWORD [12+esp]
add ebx,ecx
mov ecx,edx
ror edx,14
mov esi,DWORD [16+esp]
xor edx,ecx
mov edi,DWORD [20+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [12+esp],ecx
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [esp]
mov esi,ebx
ror ecx,9
mov DWORD [28+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [24+esp]
ror ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [68+esp]
xor eax,edi
ror ecx,2
add eax,edx
add edx,DWORD [8+esp]
add eax,ecx
mov ecx,edx
ror edx,14
mov esi,DWORD [12+esp]
xor edx,ecx
mov edi,DWORD [16+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [8+esp],ecx
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [28+esp]
mov esi,eax
ror ecx,9
mov DWORD [24+esp],eax
xor ecx,eax
xor eax,edi
add edx,DWORD [20+esp]
ror ecx,11
and ebx,eax
xor ecx,esi
add edx,DWORD [72+esp]
xor ebx,edi
ror ecx,2
add ebx,edx
add edx,DWORD [4+esp]
add ebx,ecx
mov ecx,edx
ror edx,14
mov esi,DWORD [8+esp]
xor edx,ecx
mov edi,DWORD [12+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [4+esp],ecx
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [24+esp]
mov esi,ebx
ror ecx,9
mov DWORD [20+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [16+esp]
ror ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [76+esp]
xor eax,edi
ror ecx,2
add eax,edx
add edx,DWORD [esp]
add eax,ecx
mov ecx,edx
ror edx,14
mov esi,DWORD [4+esp]
xor edx,ecx
mov edi,DWORD [8+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [esp],ecx
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [20+esp]
mov esi,eax
ror ecx,9
mov DWORD [16+esp],eax
xor ecx,eax
xor eax,edi
add edx,DWORD [12+esp]
ror ecx,11
and ebx,eax
xor ecx,esi
add edx,DWORD [80+esp]
xor ebx,edi
ror ecx,2
add ebx,edx
add edx,DWORD [28+esp]
add ebx,ecx
mov ecx,edx
ror edx,14
mov esi,DWORD [esp]
xor edx,ecx
mov edi,DWORD [4+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [28+esp],ecx
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [16+esp]
mov esi,ebx
ror ecx,9
mov DWORD [12+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [8+esp]
ror ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [84+esp]
xor eax,edi
ror ecx,2
add eax,edx
add edx,DWORD [24+esp]
add eax,ecx
mov ecx,edx
ror edx,14
mov esi,DWORD [28+esp]
xor edx,ecx
mov edi,DWORD [esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [24+esp],ecx
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [12+esp]
mov esi,eax
ror ecx,9
mov DWORD [8+esp],eax
xor ecx,eax
xor eax,edi
add edx,DWORD [4+esp]
ror ecx,11
and ebx,eax
xor ecx,esi
add edx,DWORD [88+esp]
xor ebx,edi
ror ecx,2
add ebx,edx
add edx,DWORD [20+esp]
add ebx,ecx
mov ecx,edx
ror edx,14
mov esi,DWORD [24+esp]
xor edx,ecx
mov edi,DWORD [28+esp]
xor esi,edi
ror edx,5
and esi,ecx
mov DWORD [20+esp],ecx
xor edx,ecx
xor edi,esi
ror edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [8+esp]
mov esi,ebx
ror ecx,9
mov DWORD [4+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [esp]
ror ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [92+esp]
xor eax,edi
ror ecx,2
add eax,edx
add edx,DWORD [16+esp]
add eax,ecx
mov esi,DWORD [96+esp]
xor ebx,edi
mov ecx,DWORD [12+esp]
add eax,DWORD [esi]
add ebx,DWORD [4+esi]
add edi,DWORD [8+esi]
add ecx,DWORD [12+esi]
mov DWORD [esi],eax
mov DWORD [4+esi],ebx
mov DWORD [8+esi],edi
mov DWORD [12+esi],ecx
mov DWORD [4+esp],ebx
xor ebx,edi
mov DWORD [8+esp],edi
mov DWORD [12+esp],ecx
mov edi,DWORD [20+esp]
mov ecx,DWORD [24+esp]
add edx,DWORD [16+esi]
add edi,DWORD [20+esi]
add ecx,DWORD [24+esi]
mov DWORD [16+esi],edx
mov DWORD [20+esi],edi
mov DWORD [20+esp],edi
mov edi,DWORD [28+esp]
mov DWORD [24+esi],ecx
add edi,DWORD [28+esi]
mov DWORD [24+esp],ecx
mov DWORD [28+esi],edi
mov DWORD [28+esp],edi
mov edi,DWORD [100+esp]
movdqa xmm7,[64+ebp]
sub ebp,192
cmp edi,DWORD [104+esp]
jb NEAR L$010grand_ssse3
mov esp,DWORD [108+esp]
pop edi
pop esi
pop ebx
pop ebp
ret
align 32
L$004AVX:
lea esp,[esp-96]
vzeroall
mov eax,DWORD [esi]
mov ebx,DWORD [4+esi]
mov ecx,DWORD [8+esi]
mov edi,DWORD [12+esi]
mov DWORD [4+esp],ebx
xor ebx,ecx
mov DWORD [8+esp],ecx
mov DWORD [12+esp],edi
mov edx,DWORD [16+esi]
mov edi,DWORD [20+esi]
mov ecx,DWORD [24+esi]
mov esi,DWORD [28+esi]
mov DWORD [20+esp],edi
mov edi,DWORD [100+esp]
mov DWORD [24+esp],ecx
mov DWORD [28+esp],esi
vmovdqa xmm7,[256+ebp]
jmp NEAR L$012grand_avx
align 32
L$012grand_avx:
vmovdqu xmm0,[edi]
vmovdqu xmm1,[16+edi]
vmovdqu xmm2,[32+edi]
vmovdqu xmm3,[48+edi]
add edi,64
vpshufb xmm0,xmm0,xmm7
mov DWORD [100+esp],edi
vpshufb xmm1,xmm1,xmm7
vpshufb xmm2,xmm2,xmm7
vpaddd xmm4,xmm0,[ebp]
vpshufb xmm3,xmm3,xmm7
vpaddd xmm5,xmm1,[16+ebp]
vpaddd xmm6,xmm2,[32+ebp]
vpaddd xmm7,xmm3,[48+ebp]
vmovdqa [32+esp],xmm4
vmovdqa [48+esp],xmm5
vmovdqa [64+esp],xmm6
vmovdqa [80+esp],xmm7
jmp NEAR L$013avx_00_47
align 16
L$013avx_00_47:
add ebp,64
vpalignr xmm4,xmm1,xmm0,4
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [20+esp]
vpalignr xmm7,xmm3,xmm2,4
xor edx,ecx
mov edi,DWORD [24+esp]
xor esi,edi
vpsrld xmm6,xmm4,7
shrd edx,edx,5
and esi,ecx
mov DWORD [16+esp],ecx
vpaddd xmm0,xmm0,xmm7
xor edx,ecx
xor edi,esi
shrd edx,edx,6
vpsrld xmm7,xmm4,3
mov ecx,eax
add edx,edi
mov edi,DWORD [4+esp]
vpslld xmm5,xmm4,14
mov esi,eax
shrd ecx,ecx,9
mov DWORD [esp],eax
vpxor xmm4,xmm7,xmm6
xor ecx,eax
xor eax,edi
add edx,DWORD [28+esp]
vpshufd xmm7,xmm3,250
shrd ecx,ecx,11
and ebx,eax
xor ecx,esi
vpsrld xmm6,xmm6,11
add edx,DWORD [32+esp]
xor ebx,edi
shrd ecx,ecx,2
vpxor xmm4,xmm4,xmm5
add ebx,edx
add edx,DWORD [12+esp]
add ebx,ecx
vpslld xmm5,xmm5,11
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [16+esp]
vpxor xmm4,xmm4,xmm6
xor edx,ecx
mov edi,DWORD [20+esp]
xor esi,edi
vpsrld xmm6,xmm7,10
shrd edx,edx,5
and esi,ecx
mov DWORD [12+esp],ecx
vpxor xmm4,xmm4,xmm5
xor edx,ecx
xor edi,esi
shrd edx,edx,6
vpsrlq xmm5,xmm7,17
mov ecx,ebx
add edx,edi
mov edi,DWORD [esp]
vpaddd xmm0,xmm0,xmm4
mov esi,ebx
shrd ecx,ecx,9
mov DWORD [28+esp],ebx
vpxor xmm6,xmm6,xmm5
xor ecx,ebx
xor ebx,edi
add edx,DWORD [24+esp]
vpsrlq xmm7,xmm7,19
shrd ecx,ecx,11
and eax,ebx
xor ecx,esi
vpxor xmm6,xmm6,xmm7
add edx,DWORD [36+esp]
xor eax,edi
shrd ecx,ecx,2
vpshufd xmm7,xmm6,132
add eax,edx
add edx,DWORD [8+esp]
add eax,ecx
vpsrldq xmm7,xmm7,8
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [12+esp]
vpaddd xmm0,xmm0,xmm7
xor edx,ecx
mov edi,DWORD [16+esp]
xor esi,edi
vpshufd xmm7,xmm0,80
shrd edx,edx,5
and esi,ecx
mov DWORD [8+esp],ecx
vpsrld xmm6,xmm7,10
xor edx,ecx
xor edi,esi
shrd edx,edx,6
vpsrlq xmm5,xmm7,17
mov ecx,eax
add edx,edi
mov edi,DWORD [28+esp]
vpxor xmm6,xmm6,xmm5
mov esi,eax
shrd ecx,ecx,9
mov DWORD [24+esp],eax
vpsrlq xmm7,xmm7,19
xor ecx,eax
xor eax,edi
add edx,DWORD [20+esp]
vpxor xmm6,xmm6,xmm7
shrd ecx,ecx,11
and ebx,eax
xor ecx,esi
vpshufd xmm7,xmm6,232
add edx,DWORD [40+esp]
xor ebx,edi
shrd ecx,ecx,2
vpslldq xmm7,xmm7,8
add ebx,edx
add edx,DWORD [4+esp]
add ebx,ecx
vpaddd xmm0,xmm0,xmm7
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [8+esp]
vpaddd xmm6,xmm0,[ebp]
xor edx,ecx
mov edi,DWORD [12+esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [4+esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [24+esp]
mov esi,ebx
shrd ecx,ecx,9
mov DWORD [20+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [16+esp]
shrd ecx,ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [44+esp]
xor eax,edi
shrd ecx,ecx,2
add eax,edx
add edx,DWORD [esp]
add eax,ecx
vmovdqa [32+esp],xmm6
vpalignr xmm4,xmm2,xmm1,4
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [4+esp]
vpalignr xmm7,xmm0,xmm3,4
xor edx,ecx
mov edi,DWORD [8+esp]
xor esi,edi
vpsrld xmm6,xmm4,7
shrd edx,edx,5
and esi,ecx
mov DWORD [esp],ecx
vpaddd xmm1,xmm1,xmm7
xor edx,ecx
xor edi,esi
shrd edx,edx,6
vpsrld xmm7,xmm4,3
mov ecx,eax
add edx,edi
mov edi,DWORD [20+esp]
vpslld xmm5,xmm4,14
mov esi,eax
shrd ecx,ecx,9
mov DWORD [16+esp],eax
vpxor xmm4,xmm7,xmm6
xor ecx,eax
xor eax,edi
add edx,DWORD [12+esp]
vpshufd xmm7,xmm0,250
shrd ecx,ecx,11
and ebx,eax
xor ecx,esi
vpsrld xmm6,xmm6,11
add edx,DWORD [48+esp]
xor ebx,edi
shrd ecx,ecx,2
vpxor xmm4,xmm4,xmm5
add ebx,edx
add edx,DWORD [28+esp]
add ebx,ecx
vpslld xmm5,xmm5,11
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [esp]
vpxor xmm4,xmm4,xmm6
xor edx,ecx
mov edi,DWORD [4+esp]
xor esi,edi
vpsrld xmm6,xmm7,10
shrd edx,edx,5
and esi,ecx
mov DWORD [28+esp],ecx
vpxor xmm4,xmm4,xmm5
xor edx,ecx
xor edi,esi
shrd edx,edx,6
vpsrlq xmm5,xmm7,17
mov ecx,ebx
add edx,edi
mov edi,DWORD [16+esp]
vpaddd xmm1,xmm1,xmm4
mov esi,ebx
shrd ecx,ecx,9
mov DWORD [12+esp],ebx
vpxor xmm6,xmm6,xmm5
xor ecx,ebx
xor ebx,edi
add edx,DWORD [8+esp]
vpsrlq xmm7,xmm7,19
shrd ecx,ecx,11
and eax,ebx
xor ecx,esi
vpxor xmm6,xmm6,xmm7
add edx,DWORD [52+esp]
xor eax,edi
shrd ecx,ecx,2
vpshufd xmm7,xmm6,132
add eax,edx
add edx,DWORD [24+esp]
add eax,ecx
vpsrldq xmm7,xmm7,8
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [28+esp]
vpaddd xmm1,xmm1,xmm7
xor edx,ecx
mov edi,DWORD [esp]
xor esi,edi
vpshufd xmm7,xmm1,80
shrd edx,edx,5
and esi,ecx
mov DWORD [24+esp],ecx
vpsrld xmm6,xmm7,10
xor edx,ecx
xor edi,esi
shrd edx,edx,6
vpsrlq xmm5,xmm7,17
mov ecx,eax
add edx,edi
mov edi,DWORD [12+esp]
vpxor xmm6,xmm6,xmm5
mov esi,eax
shrd ecx,ecx,9
mov DWORD [8+esp],eax
vpsrlq xmm7,xmm7,19
xor ecx,eax
xor eax,edi
add edx,DWORD [4+esp]
vpxor xmm6,xmm6,xmm7
shrd ecx,ecx,11
and ebx,eax
xor ecx,esi
vpshufd xmm7,xmm6,232
add edx,DWORD [56+esp]
xor ebx,edi
shrd ecx,ecx,2
vpslldq xmm7,xmm7,8
add ebx,edx
add edx,DWORD [20+esp]
add ebx,ecx
vpaddd xmm1,xmm1,xmm7
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [24+esp]
vpaddd xmm6,xmm1,[16+ebp]
xor edx,ecx
mov edi,DWORD [28+esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [20+esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [8+esp]
mov esi,ebx
shrd ecx,ecx,9
mov DWORD [4+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [esp]
shrd ecx,ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [60+esp]
xor eax,edi
shrd ecx,ecx,2
add eax,edx
add edx,DWORD [16+esp]
add eax,ecx
vmovdqa [48+esp],xmm6
vpalignr xmm4,xmm3,xmm2,4
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [20+esp]
vpalignr xmm7,xmm1,xmm0,4
xor edx,ecx
mov edi,DWORD [24+esp]
xor esi,edi
vpsrld xmm6,xmm4,7
shrd edx,edx,5
and esi,ecx
mov DWORD [16+esp],ecx
vpaddd xmm2,xmm2,xmm7
xor edx,ecx
xor edi,esi
shrd edx,edx,6
vpsrld xmm7,xmm4,3
mov ecx,eax
add edx,edi
mov edi,DWORD [4+esp]
vpslld xmm5,xmm4,14
mov esi,eax
shrd ecx,ecx,9
mov DWORD [esp],eax
vpxor xmm4,xmm7,xmm6
xor ecx,eax
xor eax,edi
add edx,DWORD [28+esp]
vpshufd xmm7,xmm1,250
shrd ecx,ecx,11
and ebx,eax
xor ecx,esi
vpsrld xmm6,xmm6,11
add edx,DWORD [64+esp]
xor ebx,edi
shrd ecx,ecx,2
vpxor xmm4,xmm4,xmm5
add ebx,edx
add edx,DWORD [12+esp]
add ebx,ecx
vpslld xmm5,xmm5,11
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [16+esp]
vpxor xmm4,xmm4,xmm6
xor edx,ecx
mov edi,DWORD [20+esp]
xor esi,edi
vpsrld xmm6,xmm7,10
shrd edx,edx,5
and esi,ecx
mov DWORD [12+esp],ecx
vpxor xmm4,xmm4,xmm5
xor edx,ecx
xor edi,esi
shrd edx,edx,6
vpsrlq xmm5,xmm7,17
mov ecx,ebx
add edx,edi
mov edi,DWORD [esp]
vpaddd xmm2,xmm2,xmm4
mov esi,ebx
shrd ecx,ecx,9
mov DWORD [28+esp],ebx
vpxor xmm6,xmm6,xmm5
xor ecx,ebx
xor ebx,edi
add edx,DWORD [24+esp]
vpsrlq xmm7,xmm7,19
shrd ecx,ecx,11
and eax,ebx
xor ecx,esi
vpxor xmm6,xmm6,xmm7
add edx,DWORD [68+esp]
xor eax,edi
shrd ecx,ecx,2
vpshufd xmm7,xmm6,132
add eax,edx
add edx,DWORD [8+esp]
add eax,ecx
vpsrldq xmm7,xmm7,8
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [12+esp]
vpaddd xmm2,xmm2,xmm7
xor edx,ecx
mov edi,DWORD [16+esp]
xor esi,edi
vpshufd xmm7,xmm2,80
shrd edx,edx,5
and esi,ecx
mov DWORD [8+esp],ecx
vpsrld xmm6,xmm7,10
xor edx,ecx
xor edi,esi
shrd edx,edx,6
vpsrlq xmm5,xmm7,17
mov ecx,eax
add edx,edi
mov edi,DWORD [28+esp]
vpxor xmm6,xmm6,xmm5
mov esi,eax
shrd ecx,ecx,9
mov DWORD [24+esp],eax
vpsrlq xmm7,xmm7,19
xor ecx,eax
xor eax,edi
add edx,DWORD [20+esp]
vpxor xmm6,xmm6,xmm7
shrd ecx,ecx,11
and ebx,eax
xor ecx,esi
vpshufd xmm7,xmm6,232
add edx,DWORD [72+esp]
xor ebx,edi
shrd ecx,ecx,2
vpslldq xmm7,xmm7,8
add ebx,edx
add edx,DWORD [4+esp]
add ebx,ecx
vpaddd xmm2,xmm2,xmm7
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [8+esp]
vpaddd xmm6,xmm2,[32+ebp]
xor edx,ecx
mov edi,DWORD [12+esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [4+esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [24+esp]
mov esi,ebx
shrd ecx,ecx,9
mov DWORD [20+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [16+esp]
shrd ecx,ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [76+esp]
xor eax,edi
shrd ecx,ecx,2
add eax,edx
add edx,DWORD [esp]
add eax,ecx
vmovdqa [64+esp],xmm6
vpalignr xmm4,xmm0,xmm3,4
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [4+esp]
vpalignr xmm7,xmm2,xmm1,4
xor edx,ecx
mov edi,DWORD [8+esp]
xor esi,edi
vpsrld xmm6,xmm4,7
shrd edx,edx,5
and esi,ecx
mov DWORD [esp],ecx
vpaddd xmm3,xmm3,xmm7
xor edx,ecx
xor edi,esi
shrd edx,edx,6
vpsrld xmm7,xmm4,3
mov ecx,eax
add edx,edi
mov edi,DWORD [20+esp]
vpslld xmm5,xmm4,14
mov esi,eax
shrd ecx,ecx,9
mov DWORD [16+esp],eax
vpxor xmm4,xmm7,xmm6
xor ecx,eax
xor eax,edi
add edx,DWORD [12+esp]
vpshufd xmm7,xmm2,250
shrd ecx,ecx,11
and ebx,eax
xor ecx,esi
vpsrld xmm6,xmm6,11
add edx,DWORD [80+esp]
xor ebx,edi
shrd ecx,ecx,2
vpxor xmm4,xmm4,xmm5
add ebx,edx
add edx,DWORD [28+esp]
add ebx,ecx
vpslld xmm5,xmm5,11
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [esp]
vpxor xmm4,xmm4,xmm6
xor edx,ecx
mov edi,DWORD [4+esp]
xor esi,edi
vpsrld xmm6,xmm7,10
shrd edx,edx,5
and esi,ecx
mov DWORD [28+esp],ecx
vpxor xmm4,xmm4,xmm5
xor edx,ecx
xor edi,esi
shrd edx,edx,6
vpsrlq xmm5,xmm7,17
mov ecx,ebx
add edx,edi
mov edi,DWORD [16+esp]
vpaddd xmm3,xmm3,xmm4
mov esi,ebx
shrd ecx,ecx,9
mov DWORD [12+esp],ebx
vpxor xmm6,xmm6,xmm5
xor ecx,ebx
xor ebx,edi
add edx,DWORD [8+esp]
vpsrlq xmm7,xmm7,19
shrd ecx,ecx,11
and eax,ebx
xor ecx,esi
vpxor xmm6,xmm6,xmm7
add edx,DWORD [84+esp]
xor eax,edi
shrd ecx,ecx,2
vpshufd xmm7,xmm6,132
add eax,edx
add edx,DWORD [24+esp]
add eax,ecx
vpsrldq xmm7,xmm7,8
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [28+esp]
vpaddd xmm3,xmm3,xmm7
xor edx,ecx
mov edi,DWORD [esp]
xor esi,edi
vpshufd xmm7,xmm3,80
shrd edx,edx,5
and esi,ecx
mov DWORD [24+esp],ecx
vpsrld xmm6,xmm7,10
xor edx,ecx
xor edi,esi
shrd edx,edx,6
vpsrlq xmm5,xmm7,17
mov ecx,eax
add edx,edi
mov edi,DWORD [12+esp]
vpxor xmm6,xmm6,xmm5
mov esi,eax
shrd ecx,ecx,9
mov DWORD [8+esp],eax
vpsrlq xmm7,xmm7,19
xor ecx,eax
xor eax,edi
add edx,DWORD [4+esp]
vpxor xmm6,xmm6,xmm7
shrd ecx,ecx,11
and ebx,eax
xor ecx,esi
vpshufd xmm7,xmm6,232
add edx,DWORD [88+esp]
xor ebx,edi
shrd ecx,ecx,2
vpslldq xmm7,xmm7,8
add ebx,edx
add edx,DWORD [20+esp]
add ebx,ecx
vpaddd xmm3,xmm3,xmm7
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [24+esp]
vpaddd xmm6,xmm3,[48+ebp]
xor edx,ecx
mov edi,DWORD [28+esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [20+esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [8+esp]
mov esi,ebx
shrd ecx,ecx,9
mov DWORD [4+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [esp]
shrd ecx,ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [92+esp]
xor eax,edi
shrd ecx,ecx,2
add eax,edx
add edx,DWORD [16+esp]
add eax,ecx
vmovdqa [80+esp],xmm6
cmp DWORD [64+ebp],66051
jne NEAR L$013avx_00_47
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [20+esp]
xor edx,ecx
mov edi,DWORD [24+esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [16+esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [4+esp]
mov esi,eax
shrd ecx,ecx,9
mov DWORD [esp],eax
xor ecx,eax
xor eax,edi
add edx,DWORD [28+esp]
shrd ecx,ecx,11
and ebx,eax
xor ecx,esi
add edx,DWORD [32+esp]
xor ebx,edi
shrd ecx,ecx,2
add ebx,edx
add edx,DWORD [12+esp]
add ebx,ecx
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [16+esp]
xor edx,ecx
mov edi,DWORD [20+esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [12+esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [esp]
mov esi,ebx
shrd ecx,ecx,9
mov DWORD [28+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [24+esp]
shrd ecx,ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [36+esp]
xor eax,edi
shrd ecx,ecx,2
add eax,edx
add edx,DWORD [8+esp]
add eax,ecx
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [12+esp]
xor edx,ecx
mov edi,DWORD [16+esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [8+esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [28+esp]
mov esi,eax
shrd ecx,ecx,9
mov DWORD [24+esp],eax
xor ecx,eax
xor eax,edi
add edx,DWORD [20+esp]
shrd ecx,ecx,11
and ebx,eax
xor ecx,esi
add edx,DWORD [40+esp]
xor ebx,edi
shrd ecx,ecx,2
add ebx,edx
add edx,DWORD [4+esp]
add ebx,ecx
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [8+esp]
xor edx,ecx
mov edi,DWORD [12+esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [4+esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [24+esp]
mov esi,ebx
shrd ecx,ecx,9
mov DWORD [20+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [16+esp]
shrd ecx,ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [44+esp]
xor eax,edi
shrd ecx,ecx,2
add eax,edx
add edx,DWORD [esp]
add eax,ecx
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [4+esp]
xor edx,ecx
mov edi,DWORD [8+esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [20+esp]
mov esi,eax
shrd ecx,ecx,9
mov DWORD [16+esp],eax
xor ecx,eax
xor eax,edi
add edx,DWORD [12+esp]
shrd ecx,ecx,11
and ebx,eax
xor ecx,esi
add edx,DWORD [48+esp]
xor ebx,edi
shrd ecx,ecx,2
add ebx,edx
add edx,DWORD [28+esp]
add ebx,ecx
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [esp]
xor edx,ecx
mov edi,DWORD [4+esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [28+esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [16+esp]
mov esi,ebx
shrd ecx,ecx,9
mov DWORD [12+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [8+esp]
shrd ecx,ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [52+esp]
xor eax,edi
shrd ecx,ecx,2
add eax,edx
add edx,DWORD [24+esp]
add eax,ecx
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [28+esp]
xor edx,ecx
mov edi,DWORD [esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [24+esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [12+esp]
mov esi,eax
shrd ecx,ecx,9
mov DWORD [8+esp],eax
xor ecx,eax
xor eax,edi
add edx,DWORD [4+esp]
shrd ecx,ecx,11
and ebx,eax
xor ecx,esi
add edx,DWORD [56+esp]
xor ebx,edi
shrd ecx,ecx,2
add ebx,edx
add edx,DWORD [20+esp]
add ebx,ecx
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [24+esp]
xor edx,ecx
mov edi,DWORD [28+esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [20+esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [8+esp]
mov esi,ebx
shrd ecx,ecx,9
mov DWORD [4+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [esp]
shrd ecx,ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [60+esp]
xor eax,edi
shrd ecx,ecx,2
add eax,edx
add edx,DWORD [16+esp]
add eax,ecx
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [20+esp]
xor edx,ecx
mov edi,DWORD [24+esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [16+esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [4+esp]
mov esi,eax
shrd ecx,ecx,9
mov DWORD [esp],eax
xor ecx,eax
xor eax,edi
add edx,DWORD [28+esp]
shrd ecx,ecx,11
and ebx,eax
xor ecx,esi
add edx,DWORD [64+esp]
xor ebx,edi
shrd ecx,ecx,2
add ebx,edx
add edx,DWORD [12+esp]
add ebx,ecx
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [16+esp]
xor edx,ecx
mov edi,DWORD [20+esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [12+esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [esp]
mov esi,ebx
shrd ecx,ecx,9
mov DWORD [28+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [24+esp]
shrd ecx,ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [68+esp]
xor eax,edi
shrd ecx,ecx,2
add eax,edx
add edx,DWORD [8+esp]
add eax,ecx
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [12+esp]
xor edx,ecx
mov edi,DWORD [16+esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [8+esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [28+esp]
mov esi,eax
shrd ecx,ecx,9
mov DWORD [24+esp],eax
xor ecx,eax
xor eax,edi
add edx,DWORD [20+esp]
shrd ecx,ecx,11
and ebx,eax
xor ecx,esi
add edx,DWORD [72+esp]
xor ebx,edi
shrd ecx,ecx,2
add ebx,edx
add edx,DWORD [4+esp]
add ebx,ecx
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [8+esp]
xor edx,ecx
mov edi,DWORD [12+esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [4+esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [24+esp]
mov esi,ebx
shrd ecx,ecx,9
mov DWORD [20+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [16+esp]
shrd ecx,ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [76+esp]
xor eax,edi
shrd ecx,ecx,2
add eax,edx
add edx,DWORD [esp]
add eax,ecx
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [4+esp]
xor edx,ecx
mov edi,DWORD [8+esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [20+esp]
mov esi,eax
shrd ecx,ecx,9
mov DWORD [16+esp],eax
xor ecx,eax
xor eax,edi
add edx,DWORD [12+esp]
shrd ecx,ecx,11
and ebx,eax
xor ecx,esi
add edx,DWORD [80+esp]
xor ebx,edi
shrd ecx,ecx,2
add ebx,edx
add edx,DWORD [28+esp]
add ebx,ecx
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [esp]
xor edx,ecx
mov edi,DWORD [4+esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [28+esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [16+esp]
mov esi,ebx
shrd ecx,ecx,9
mov DWORD [12+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [8+esp]
shrd ecx,ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [84+esp]
xor eax,edi
shrd ecx,ecx,2
add eax,edx
add edx,DWORD [24+esp]
add eax,ecx
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [28+esp]
xor edx,ecx
mov edi,DWORD [esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [24+esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,eax
add edx,edi
mov edi,DWORD [12+esp]
mov esi,eax
shrd ecx,ecx,9
mov DWORD [8+esp],eax
xor ecx,eax
xor eax,edi
add edx,DWORD [4+esp]
shrd ecx,ecx,11
and ebx,eax
xor ecx,esi
add edx,DWORD [88+esp]
xor ebx,edi
shrd ecx,ecx,2
add ebx,edx
add edx,DWORD [20+esp]
add ebx,ecx
mov ecx,edx
shrd edx,edx,14
mov esi,DWORD [24+esp]
xor edx,ecx
mov edi,DWORD [28+esp]
xor esi,edi
shrd edx,edx,5
and esi,ecx
mov DWORD [20+esp],ecx
xor edx,ecx
xor edi,esi
shrd edx,edx,6
mov ecx,ebx
add edx,edi
mov edi,DWORD [8+esp]
mov esi,ebx
shrd ecx,ecx,9
mov DWORD [4+esp],ebx
xor ecx,ebx
xor ebx,edi
add edx,DWORD [esp]
shrd ecx,ecx,11
and eax,ebx
xor ecx,esi
add edx,DWORD [92+esp]
xor eax,edi
shrd ecx,ecx,2
add eax,edx
add edx,DWORD [16+esp]
add eax,ecx
mov esi,DWORD [96+esp]
xor ebx,edi
mov ecx,DWORD [12+esp]
add eax,DWORD [esi]
add ebx,DWORD [4+esi]
add edi,DWORD [8+esi]
add ecx,DWORD [12+esi]
mov DWORD [esi],eax
mov DWORD [4+esi],ebx
mov DWORD [8+esi],edi
mov DWORD [12+esi],ecx
mov DWORD [4+esp],ebx
xor ebx,edi
mov DWORD [8+esp],edi
mov DWORD [12+esp],ecx
mov edi,DWORD [20+esp]
mov ecx,DWORD [24+esp]
add edx,DWORD [16+esi]
add edi,DWORD [20+esi]
add ecx,DWORD [24+esi]
mov DWORD [16+esi],edx
mov DWORD [20+esi],edi
mov DWORD [20+esp],edi
mov edi,DWORD [28+esp]
mov DWORD [24+esi],ecx
add edi,DWORD [28+esi]
mov DWORD [24+esp],ecx
mov DWORD [28+esi],edi
mov DWORD [28+esp],edi
mov edi,DWORD [100+esp]
vmovdqa xmm7,[64+ebp]
sub ebp,192
cmp edi,DWORD [104+esp]
jb NEAR L$012grand_avx
mov esp,DWORD [108+esp]
vzeroall
pop edi
pop esi
pop ebx
pop ebp
ret
segment .bss
common _OPENSSL_ia32cap_P 16