| ; This file is generated from a similarly-named Perl script in the BoringSSL |
| ; source tree. Do not edit by hand. |
| |
| %ifdef BORINGSSL_PREFIX |
| %include "boringssl_prefix_symbols_nasm.inc" |
| %endif |
| %ifidn __OUTPUT_FORMAT__, win32 |
| %ifidn __OUTPUT_FORMAT__,obj |
| section code use32 class=code align=64 |
| %elifidn __OUTPUT_FORMAT__,win32 |
| $@feat.00 equ 1 |
| section .text code align=64 |
| %else |
| section .text code |
| %endif |
| global _sha256_block_data_order_nohw |
| align 16 |
| _sha256_block_data_order_nohw: |
| L$_sha256_block_data_order_nohw_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$K256-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 |
| L$001no_xmm: |
| sub eax,edi |
| cmp eax,256 |
| jae NEAR L$002unrolled |
| jmp NEAR L$003loop |
| align 16 |
| L$003loop: |
| 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$00400_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$00400_15 |
| mov ecx,DWORD [156+esp] |
| jmp NEAR L$00516_63 |
| align 16 |
| L$00516_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$00516_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$003loop |
| mov esp,DWORD [12+esp] |
| pop edi |
| pop esi |
| pop ebx |
| pop ebp |
| ret |
| align 64 |
| L$K256: |
| 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$002unrolled: |
| 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$006grand_loop |
| align 16 |
| L$006grand_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$006grand_loop |
| mov esp,DWORD [108+esp] |
| pop edi |
| pop esi |
| pop ebx |
| pop ebp |
| ret |
| global _sha256_block_data_order_ssse3 |
| align 16 |
| _sha256_block_data_order_ssse3: |
| L$_sha256_block_data_order_ssse3_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$007pic_point |
| L$007pic_point: |
| pop ebp |
| lea ebp,[(L$K256-L$007pic_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 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$008grand_ssse3 |
| align 16 |
| L$008grand_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$009ssse3_00_47 |
| align 16 |
| L$009ssse3_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$009ssse3_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$008grand_ssse3 |
| mov esp,DWORD [108+esp] |
| pop edi |
| pop esi |
| pop ebx |
| pop ebp |
| ret |
| global _sha256_block_data_order_avx |
| align 16 |
| _sha256_block_data_order_avx: |
| L$_sha256_block_data_order_avx_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$010pic_point |
| L$010pic_point: |
| pop ebp |
| lea ebp,[(L$K256-L$010pic_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 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$011grand_avx |
| align 32 |
| L$011grand_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$012avx_00_47 |
| align 16 |
| L$012avx_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$012avx_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$011grand_avx |
| mov esp,DWORD [108+esp] |
| vzeroall |
| pop edi |
| pop esi |
| pop ebx |
| pop ebp |
| ret |
| %else |
| ; Work around https://bugzilla.nasm.us/show_bug.cgi?id=3392738 |
| ret |
| %endif |