; 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 ;extern _OPENSSL_ia32cap_P global _sha1_block_data_order align 16 _sha1_block_data_order: L$_sha1_block_data_order_begin: push ebp push ebx push esi push edi call L$000pic_point L$000pic_point: pop ebp lea esi,[_OPENSSL_ia32cap_P] lea ebp,[(L$K_XX_XX-L$000pic_point)+ebp] mov eax,DWORD [esi] mov edx,DWORD [4+esi] test edx,512 jz NEAR L$001x86 mov ecx,DWORD [8+esi] test eax,16777216 jz NEAR L$001x86 and edx,268435456 and eax,1073741824 or eax,edx cmp eax,1342177280 je NEAR L$avx_shortcut jmp NEAR L$ssse3_shortcut align 16 L$001x86: mov ebp,DWORD [20+esp] mov esi,DWORD [24+esp] mov eax,DWORD [28+esp] sub esp,76 shl eax,6 add eax,esi mov DWORD [104+esp],eax mov edi,DWORD [16+ebp] jmp NEAR L$002loop align 16 L$002loop: mov eax,DWORD [esi] mov ebx,DWORD [4+esi] mov ecx,DWORD [8+esi] mov edx,DWORD [12+esi] bswap eax bswap ebx bswap ecx bswap edx mov DWORD [esp],eax mov DWORD [4+esp],ebx mov DWORD [8+esp],ecx mov DWORD [12+esp],edx mov eax,DWORD [16+esi] mov ebx,DWORD [20+esi] mov ecx,DWORD [24+esi] mov edx,DWORD [28+esi] bswap eax bswap ebx bswap ecx bswap edx mov DWORD [16+esp],eax mov DWORD [20+esp],ebx mov DWORD [24+esp],ecx mov DWORD [28+esp],edx mov eax,DWORD [32+esi] mov ebx,DWORD [36+esi] mov ecx,DWORD [40+esi] mov edx,DWORD [44+esi] bswap eax bswap ebx bswap ecx bswap edx mov DWORD [32+esp],eax mov DWORD [36+esp],ebx mov DWORD [40+esp],ecx mov DWORD [44+esp],edx mov eax,DWORD [48+esi] mov ebx,DWORD [52+esi] mov ecx,DWORD [56+esi] mov edx,DWORD [60+esi] bswap eax bswap ebx bswap ecx bswap edx mov DWORD [48+esp],eax mov DWORD [52+esp],ebx mov DWORD [56+esp],ecx mov DWORD [60+esp],edx mov DWORD [100+esp],esi mov eax,DWORD [ebp] mov ebx,DWORD [4+ebp] mov ecx,DWORD [8+ebp] mov edx,DWORD [12+ebp] ; 00_15 0 mov esi,ecx mov ebp,eax rol ebp,5 xor esi,edx add ebp,edi mov edi,DWORD [esp] and esi,ebx ror ebx,2 xor esi,edx lea ebp,[1518500249+edi*1+ebp] add ebp,esi ; 00_15 1 mov edi,ebx mov esi,ebp rol ebp,5 xor edi,ecx add ebp,edx mov edx,DWORD [4+esp] and edi,eax ror eax,2 xor edi,ecx lea ebp,[1518500249+edx*1+ebp] add ebp,edi ; 00_15 2 mov edx,eax mov edi,ebp rol ebp,5 xor edx,ebx add ebp,ecx mov ecx,DWORD [8+esp] and edx,esi ror esi,2 xor edx,ebx lea ebp,[1518500249+ecx*1+ebp] add ebp,edx ; 00_15 3 mov ecx,esi mov edx,ebp rol ebp,5 xor ecx,eax add ebp,ebx mov ebx,DWORD [12+esp] and ecx,edi ror edi,2 xor ecx,eax lea ebp,[1518500249+ebx*1+ebp] add ebp,ecx ; 00_15 4 mov ebx,edi mov ecx,ebp rol ebp,5 xor ebx,esi add ebp,eax mov eax,DWORD [16+esp] and ebx,edx ror edx,2 xor ebx,esi lea ebp,[1518500249+eax*1+ebp] add ebp,ebx ; 00_15 5 mov eax,edx mov ebx,ebp rol ebp,5 xor eax,edi add ebp,esi mov esi,DWORD [20+esp] and eax,ecx ror ecx,2 xor eax,edi lea ebp,[1518500249+esi*1+ebp] add ebp,eax ; 00_15 6 mov esi,ecx mov eax,ebp rol ebp,5 xor esi,edx add ebp,edi mov edi,DWORD [24+esp] and esi,ebx ror ebx,2 xor esi,edx lea ebp,[1518500249+edi*1+ebp] add ebp,esi ; 00_15 7 mov edi,ebx mov esi,ebp rol ebp,5 xor edi,ecx add ebp,edx mov edx,DWORD [28+esp] and edi,eax ror eax,2 xor edi,ecx lea ebp,[1518500249+edx*1+ebp] add ebp,edi ; 00_15 8 mov edx,eax mov edi,ebp rol ebp,5 xor edx,ebx add ebp,ecx mov ecx,DWORD [32+esp] and edx,esi ror esi,2 xor edx,ebx lea ebp,[1518500249+ecx*1+ebp] add ebp,edx ; 00_15 9 mov ecx,esi mov edx,ebp rol ebp,5 xor ecx,eax add ebp,ebx mov ebx,DWORD [36+esp] and ecx,edi ror edi,2 xor ecx,eax lea ebp,[1518500249+ebx*1+ebp] add ebp,ecx ; 00_15 10 mov ebx,edi mov ecx,ebp rol ebp,5 xor ebx,esi add ebp,eax mov eax,DWORD [40+esp] and ebx,edx ror edx,2 xor ebx,esi lea ebp,[1518500249+eax*1+ebp] add ebp,ebx ; 00_15 11 mov eax,edx mov ebx,ebp rol ebp,5 xor eax,edi add ebp,esi mov esi,DWORD [44+esp] and eax,ecx ror ecx,2 xor eax,edi lea ebp,[1518500249+esi*1+ebp] add ebp,eax ; 00_15 12 mov esi,ecx mov eax,ebp rol ebp,5 xor esi,edx add ebp,edi mov edi,DWORD [48+esp] and esi,ebx ror ebx,2 xor esi,edx lea ebp,[1518500249+edi*1+ebp] add ebp,esi ; 00_15 13 mov edi,ebx mov esi,ebp rol ebp,5 xor edi,ecx add ebp,edx mov edx,DWORD [52+esp] and edi,eax ror eax,2 xor edi,ecx lea ebp,[1518500249+edx*1+ebp] add ebp,edi ; 00_15 14 mov edx,eax mov edi,ebp rol ebp,5 xor edx,ebx add ebp,ecx mov ecx,DWORD [56+esp] and edx,esi ror esi,2 xor edx,ebx lea ebp,[1518500249+ecx*1+ebp] add ebp,edx ; 00_15 15 mov ecx,esi mov edx,ebp rol ebp,5 xor ecx,eax add ebp,ebx mov ebx,DWORD [60+esp] and ecx,edi ror edi,2 xor ecx,eax lea ebp,[1518500249+ebx*1+ebp] mov ebx,DWORD [esp] add ecx,ebp ; 16_19 16 mov ebp,edi xor ebx,DWORD [8+esp] xor ebp,esi xor ebx,DWORD [32+esp] and ebp,edx xor ebx,DWORD [52+esp] rol ebx,1 xor ebp,esi add eax,ebp mov ebp,ecx ror edx,2 mov DWORD [esp],ebx rol ebp,5 lea ebx,[1518500249+eax*1+ebx] mov eax,DWORD [4+esp] add ebx,ebp ; 16_19 17 mov ebp,edx xor eax,DWORD [12+esp] xor ebp,edi xor eax,DWORD [36+esp] and ebp,ecx xor eax,DWORD [56+esp] rol eax,1 xor ebp,edi add esi,ebp mov ebp,ebx ror ecx,2 mov DWORD [4+esp],eax rol ebp,5 lea eax,[1518500249+esi*1+eax] mov esi,DWORD [8+esp] add eax,ebp ; 16_19 18 mov ebp,ecx xor esi,DWORD [16+esp] xor ebp,edx xor esi,DWORD [40+esp] and ebp,ebx xor esi,DWORD [60+esp] rol esi,1 xor ebp,edx add edi,ebp mov ebp,eax ror ebx,2 mov DWORD [8+esp],esi rol ebp,5 lea esi,[1518500249+edi*1+esi] mov edi,DWORD [12+esp] add esi,ebp ; 16_19 19 mov ebp,ebx xor edi,DWORD [20+esp] xor ebp,ecx xor edi,DWORD [44+esp] and ebp,eax xor edi,DWORD [esp] rol edi,1 xor ebp,ecx add edx,ebp mov ebp,esi ror eax,2 mov DWORD [12+esp],edi rol ebp,5 lea edi,[1518500249+edx*1+edi] mov edx,DWORD [16+esp] add edi,ebp ; 20_39 20 mov ebp,esi xor edx,DWORD [24+esp] xor ebp,eax xor edx,DWORD [48+esp] xor ebp,ebx xor edx,DWORD [4+esp] rol edx,1 add ecx,ebp ror esi,2 mov ebp,edi rol ebp,5 mov DWORD [16+esp],edx lea edx,[1859775393+ecx*1+edx] mov ecx,DWORD [20+esp] add edx,ebp ; 20_39 21 mov ebp,edi xor ecx,DWORD [28+esp] xor ebp,esi xor ecx,DWORD [52+esp] xor ebp,eax xor ecx,DWORD [8+esp] rol ecx,1 add ebx,ebp ror edi,2 mov ebp,edx rol ebp,5 mov DWORD [20+esp],ecx lea ecx,[1859775393+ebx*1+ecx] mov ebx,DWORD [24+esp] add ecx,ebp ; 20_39 22 mov ebp,edx xor ebx,DWORD [32+esp] xor ebp,edi xor ebx,DWORD [56+esp] xor ebp,esi xor ebx,DWORD [12+esp] rol ebx,1 add eax,ebp ror edx,2 mov ebp,ecx rol ebp,5 mov DWORD [24+esp],ebx lea ebx,[1859775393+eax*1+ebx] mov eax,DWORD [28+esp] add ebx,ebp ; 20_39 23 mov ebp,ecx xor eax,DWORD [36+esp] xor ebp,edx xor eax,DWORD [60+esp] xor ebp,edi xor eax,DWORD [16+esp] rol eax,1 add esi,ebp ror ecx,2 mov ebp,ebx rol ebp,5 mov DWORD [28+esp],eax lea eax,[1859775393+esi*1+eax] mov esi,DWORD [32+esp] add eax,ebp ; 20_39 24 mov ebp,ebx xor esi,DWORD [40+esp] xor ebp,ecx xor esi,DWORD [esp] xor ebp,edx xor esi,DWORD [20+esp] rol esi,1 add edi,ebp ror ebx,2 mov ebp,eax rol ebp,5 mov DWORD [32+esp],esi lea esi,[1859775393+edi*1+esi] mov edi,DWORD [36+esp] add esi,ebp ; 20_39 25 mov ebp,eax xor edi,DWORD [44+esp] xor ebp,ebx xor edi,DWORD [4+esp] xor ebp,ecx xor edi,DWORD [24+esp] rol edi,1 add edx,ebp ror eax,2 mov ebp,esi rol ebp,5 mov DWORD [36+esp],edi lea edi,[1859775393+edx*1+edi] mov edx,DWORD [40+esp] add edi,ebp ; 20_39 26 mov ebp,esi xor edx,DWORD [48+esp] xor ebp,eax xor edx,DWORD [8+esp] xor ebp,ebx xor edx,DWORD [28+esp] rol edx,1 add ecx,ebp ror esi,2 mov ebp,edi rol ebp,5 mov DWORD [40+esp],edx lea edx,[1859775393+ecx*1+edx] mov ecx,DWORD [44+esp] add edx,ebp ; 20_39 27 mov ebp,edi xor ecx,DWORD [52+esp] xor ebp,esi xor ecx,DWORD [12+esp] xor ebp,eax xor ecx,DWORD [32+esp] rol ecx,1 add ebx,ebp ror edi,2 mov ebp,edx rol ebp,5 mov DWORD [44+esp],ecx lea ecx,[1859775393+ebx*1+ecx] mov ebx,DWORD [48+esp] add ecx,ebp ; 20_39 28 mov ebp,edx xor ebx,DWORD [56+esp] xor ebp,edi xor ebx,DWORD [16+esp] xor ebp,esi xor ebx,DWORD [36+esp] rol ebx,1 add eax,ebp ror edx,2 mov ebp,ecx rol ebp,5 mov DWORD [48+esp],ebx lea ebx,[1859775393+eax*1+ebx] mov eax,DWORD [52+esp] add ebx,ebp ; 20_39 29 mov ebp,ecx xor eax,DWORD [60+esp] xor ebp,edx xor eax,DWORD [20+esp] xor ebp,edi xor eax,DWORD [40+esp] rol eax,1 add esi,ebp ror ecx,2 mov ebp,ebx rol ebp,5 mov DWORD [52+esp],eax lea eax,[1859775393+esi*1+eax] mov esi,DWORD [56+esp] add eax,ebp ; 20_39 30 mov ebp,ebx xor esi,DWORD [esp] xor ebp,ecx xor esi,DWORD [24+esp] xor ebp,edx xor esi,DWORD [44+esp] rol esi,1 add edi,ebp ror ebx,2 mov ebp,eax rol ebp,5 mov DWORD [56+esp],esi lea esi,[1859775393+edi*1+esi] mov edi,DWORD [60+esp] add esi,ebp ; 20_39 31 mov ebp,eax xor edi,DWORD [4+esp] xor ebp,ebx xor edi,DWORD [28+esp] xor ebp,ecx xor edi,DWORD [48+esp] rol edi,1 add edx,ebp ror eax,2 mov ebp,esi rol ebp,5 mov DWORD [60+esp],edi lea edi,[1859775393+edx*1+edi] mov edx,DWORD [esp] add edi,ebp ; 20_39 32 mov ebp,esi xor edx,DWORD [8+esp] xor ebp,eax xor edx,DWORD [32+esp] xor ebp,ebx xor edx,DWORD [52+esp] rol edx,1 add ecx,ebp ror esi,2 mov ebp,edi rol ebp,5 mov DWORD [esp],edx lea edx,[1859775393+ecx*1+edx] mov ecx,DWORD [4+esp] add edx,ebp ; 20_39 33 mov ebp,edi xor ecx,DWORD [12+esp] xor ebp,esi xor ecx,DWORD [36+esp] xor ebp,eax xor ecx,DWORD [56+esp] rol ecx,1 add ebx,ebp ror edi,2 mov ebp,edx rol ebp,5 mov DWORD [4+esp],ecx lea ecx,[1859775393+ebx*1+ecx] mov ebx,DWORD [8+esp] add ecx,ebp ; 20_39 34 mov ebp,edx xor ebx,DWORD [16+esp] xor ebp,edi xor ebx,DWORD [40+esp] xor ebp,esi xor ebx,DWORD [60+esp] rol ebx,1 add eax,ebp ror edx,2 mov ebp,ecx rol ebp,5 mov DWORD [8+esp],ebx lea ebx,[1859775393+eax*1+ebx] mov eax,DWORD [12+esp] add ebx,ebp ; 20_39 35 mov ebp,ecx xor eax,DWORD [20+esp] xor ebp,edx xor eax,DWORD [44+esp] xor ebp,edi xor eax,DWORD [esp] rol eax,1 add esi,ebp ror ecx,2 mov ebp,ebx rol ebp,5 mov DWORD [12+esp],eax lea eax,[1859775393+esi*1+eax] mov esi,DWORD [16+esp] add eax,ebp ; 20_39 36 mov ebp,ebx xor esi,DWORD [24+esp] xor ebp,ecx xor esi,DWORD [48+esp] xor ebp,edx xor esi,DWORD [4+esp] rol esi,1 add edi,ebp ror ebx,2 mov ebp,eax rol ebp,5 mov DWORD [16+esp],esi lea esi,[1859775393+edi*1+esi] mov edi,DWORD [20+esp] add esi,ebp ; 20_39 37 mov ebp,eax xor edi,DWORD [28+esp] xor ebp,ebx xor edi,DWORD [52+esp] xor ebp,ecx xor edi,DWORD [8+esp] rol edi,1 add edx,ebp ror eax,2 mov ebp,esi rol ebp,5 mov DWORD [20+esp],edi lea edi,[1859775393+edx*1+edi] mov edx,DWORD [24+esp] add edi,ebp ; 20_39 38 mov ebp,esi xor edx,DWORD [32+esp] xor ebp,eax xor edx,DWORD [56+esp] xor ebp,ebx xor edx,DWORD [12+esp] rol edx,1 add ecx,ebp ror esi,2 mov ebp,edi rol ebp,5 mov DWORD [24+esp],edx lea edx,[1859775393+ecx*1+edx] mov ecx,DWORD [28+esp] add edx,ebp ; 20_39 39 mov ebp,edi xor ecx,DWORD [36+esp] xor ebp,esi xor ecx,DWORD [60+esp] xor ebp,eax xor ecx,DWORD [16+esp] rol ecx,1 add ebx,ebp ror edi,2 mov ebp,edx rol ebp,5 mov DWORD [28+esp],ecx lea ecx,[1859775393+ebx*1+ecx] mov ebx,DWORD [32+esp] add ecx,ebp ; 40_59 40 mov ebp,edi xor ebx,DWORD [40+esp] xor ebp,esi xor ebx,DWORD [esp] and ebp,edx xor ebx,DWORD [20+esp] rol ebx,1 add ebp,eax ror edx,2 mov eax,ecx rol eax,5 mov DWORD [32+esp],ebx lea ebx,[2400959708+ebp*1+ebx] mov ebp,edi add ebx,eax and ebp,esi mov eax,DWORD [36+esp] add ebx,ebp ; 40_59 41 mov ebp,edx xor eax,DWORD [44+esp] xor ebp,edi xor eax,DWORD [4+esp] and ebp,ecx xor eax,DWORD [24+esp] rol eax,1 add ebp,esi ror ecx,2 mov esi,ebx rol esi,5 mov DWORD [36+esp],eax lea eax,[2400959708+ebp*1+eax] mov ebp,edx add eax,esi and ebp,edi mov esi,DWORD [40+esp] add eax,ebp ; 40_59 42 mov ebp,ecx xor esi,DWORD [48+esp] xor ebp,edx xor esi,DWORD [8+esp] and ebp,ebx xor esi,DWORD [28+esp] rol esi,1 add ebp,edi ror ebx,2 mov edi,eax rol edi,5 mov DWORD [40+esp],esi lea esi,[2400959708+ebp*1+esi] mov ebp,ecx add esi,edi and ebp,edx mov edi,DWORD [44+esp] add esi,ebp ; 40_59 43 mov ebp,ebx xor edi,DWORD [52+esp] xor ebp,ecx xor edi,DWORD [12+esp] and ebp,eax xor edi,DWORD [32+esp] rol edi,1 add ebp,edx ror eax,2 mov edx,esi rol edx,5 mov DWORD [44+esp],edi lea edi,[2400959708+ebp*1+edi] mov ebp,ebx add edi,edx and ebp,ecx mov edx,DWORD [48+esp] add edi,ebp ; 40_59 44 mov ebp,eax xor edx,DWORD [56+esp] xor ebp,ebx xor edx,DWORD [16+esp] and ebp,esi xor edx,DWORD [36+esp] rol edx,1 add ebp,ecx ror esi,2 mov ecx,edi rol ecx,5 mov DWORD [48+esp],edx lea edx,[2400959708+ebp*1+edx] mov ebp,eax add edx,ecx and ebp,ebx mov ecx,DWORD [52+esp] add edx,ebp ; 40_59 45 mov ebp,esi xor ecx,DWORD [60+esp] xor ebp,eax xor ecx,DWORD [20+esp] and ebp,edi xor ecx,DWORD [40+esp] rol ecx,1 add ebp,ebx ror edi,2 mov ebx,edx rol ebx,5 mov DWORD [52+esp],ecx lea ecx,[2400959708+ebp*1+ecx] mov ebp,esi add ecx,ebx and ebp,eax mov ebx,DWORD [56+esp] add ecx,ebp ; 40_59 46 mov ebp,edi xor ebx,DWORD [esp] xor ebp,esi xor ebx,DWORD [24+esp] and ebp,edx xor ebx,DWORD [44+esp] rol ebx,1 add ebp,eax ror edx,2 mov eax,ecx rol eax,5 mov DWORD [56+esp],ebx lea ebx,[2400959708+ebp*1+ebx] mov ebp,edi add ebx,eax and ebp,esi mov eax,DWORD [60+esp] add ebx,ebp ; 40_59 47 mov ebp,edx xor eax,DWORD [4+esp] xor ebp,edi xor eax,DWORD [28+esp] and ebp,ecx xor eax,DWORD [48+esp] rol eax,1 add ebp,esi ror ecx,2 mov esi,ebx rol esi,5 mov DWORD [60+esp],eax lea eax,[2400959708+ebp*1+eax] mov ebp,edx add eax,esi and ebp,edi mov esi,DWORD [esp] add eax,ebp ; 40_59 48 mov ebp,ecx xor esi,DWORD [8+esp] xor ebp,edx xor esi,DWORD [32+esp] and ebp,ebx xor esi,DWORD [52+esp] rol esi,1 add ebp,edi ror ebx,2 mov edi,eax rol edi,5 mov DWORD [esp],esi lea esi,[2400959708+ebp*1+esi] mov ebp,ecx add esi,edi and ebp,edx mov edi,DWORD [4+esp] add esi,ebp ; 40_59 49 mov ebp,ebx xor edi,DWORD [12+esp] xor ebp,ecx xor edi,DWORD [36+esp] and ebp,eax xor edi,DWORD [56+esp] rol edi,1 add ebp,edx ror eax,2 mov edx,esi rol edx,5 mov DWORD [4+esp],edi lea edi,[2400959708+ebp*1+edi] mov ebp,ebx add edi,edx and ebp,ecx mov edx,DWORD [8+esp] add edi,ebp ; 40_59 50 mov ebp,eax xor edx,DWORD [16+esp] xor ebp,ebx xor edx,DWORD [40+esp] and ebp,esi xor edx,DWORD [60+esp] rol edx,1 add ebp,ecx ror esi,2 mov ecx,edi rol ecx,5 mov DWORD [8+esp],edx lea edx,[2400959708+ebp*1+edx] mov ebp,eax add edx,ecx and ebp,ebx mov ecx,DWORD [12+esp] add edx,ebp ; 40_59 51 mov ebp,esi xor ecx,DWORD [20+esp] xor ebp,eax xor ecx,DWORD [44+esp] and ebp,edi xor ecx,DWORD [esp] rol ecx,1 add ebp,ebx ror edi,2 mov ebx,edx rol ebx,5 mov DWORD [12+esp],ecx lea ecx,[2400959708+ebp*1+ecx] mov ebp,esi add ecx,ebx and ebp,eax mov ebx,DWORD [16+esp] add ecx,ebp ; 40_59 52 mov ebp,edi xor ebx,DWORD [24+esp] xor ebp,esi xor ebx,DWORD [48+esp] and ebp,edx xor ebx,DWORD [4+esp] rol ebx,1 add ebp,eax ror edx,2 mov eax,ecx rol eax,5 mov DWORD [16+esp],ebx lea ebx,[2400959708+ebp*1+ebx] mov ebp,edi add ebx,eax and ebp,esi mov eax,DWORD [20+esp] add ebx,ebp ; 40_59 53 mov ebp,edx xor eax,DWORD [28+esp] xor ebp,edi xor eax,DWORD [52+esp] and ebp,ecx xor eax,DWORD [8+esp] rol eax,1 add ebp,esi ror ecx,2 mov esi,ebx rol esi,5 mov DWORD [20+esp],eax lea eax,[2400959708+ebp*1+eax] mov ebp,edx add eax,esi and ebp,edi mov esi,DWORD [24+esp] add eax,ebp ; 40_59 54 mov ebp,ecx xor esi,DWORD [32+esp] xor ebp,edx xor esi,DWORD [56+esp] and ebp,ebx xor esi,DWORD [12+esp] rol esi,1 add ebp,edi ror ebx,2 mov edi,eax rol edi,5 mov DWORD [24+esp],esi lea esi,[2400959708+ebp*1+esi] mov ebp,ecx add esi,edi and ebp,edx mov edi,DWORD [28+esp] add esi,ebp ; 40_59 55 mov ebp,ebx xor edi,DWORD [36+esp] xor ebp,ecx xor edi,DWORD [60+esp] and ebp,eax xor edi,DWORD [16+esp] rol edi,1 add ebp,edx ror eax,2 mov edx,esi rol edx,5 mov DWORD [28+esp],edi lea edi,[2400959708+ebp*1+edi] mov ebp,ebx add edi,edx and ebp,ecx mov edx,DWORD [32+esp] add edi,ebp ; 40_59 56 mov ebp,eax xor edx,DWORD [40+esp] xor ebp,ebx xor edx,DWORD [esp] and ebp,esi xor edx,DWORD [20+esp] rol edx,1 add ebp,ecx ror esi,2 mov ecx,edi rol ecx,5 mov DWORD [32+esp],edx lea edx,[2400959708+ebp*1+edx] mov ebp,eax add edx,ecx and ebp,ebx mov ecx,DWORD [36+esp] add edx,ebp ; 40_59 57 mov ebp,esi xor ecx,DWORD [44+esp] xor ebp,eax xor ecx,DWORD [4+esp] and ebp,edi xor ecx,DWORD [24+esp] rol ecx,1 add ebp,ebx ror edi,2 mov ebx,edx rol ebx,5 mov DWORD [36+esp],ecx lea ecx,[2400959708+ebp*1+ecx] mov ebp,esi add ecx,ebx and ebp,eax mov ebx,DWORD [40+esp] add ecx,ebp ; 40_59 58 mov ebp,edi xor ebx,DWORD [48+esp] xor ebp,esi xor ebx,DWORD [8+esp] and ebp,edx xor ebx,DWORD [28+esp] rol ebx,1 add ebp,eax ror edx,2 mov eax,ecx rol eax,5 mov DWORD [40+esp],ebx lea ebx,[2400959708+ebp*1+ebx] mov ebp,edi add ebx,eax and ebp,esi mov eax,DWORD [44+esp] add ebx,ebp ; 40_59 59 mov ebp,edx xor eax,DWORD [52+esp] xor ebp,edi xor eax,DWORD [12+esp] and ebp,ecx xor eax,DWORD [32+esp] rol eax,1 add ebp,esi ror ecx,2 mov esi,ebx rol esi,5 mov DWORD [44+esp],eax lea eax,[2400959708+ebp*1+eax] mov ebp,edx add eax,esi and ebp,edi mov esi,DWORD [48+esp] add eax,ebp ; 20_39 60 mov ebp,ebx xor esi,DWORD [56+esp] xor ebp,ecx xor esi,DWORD [16+esp] xor ebp,edx xor esi,DWORD [36+esp] rol esi,1 add edi,ebp ror ebx,2 mov ebp,eax rol ebp,5 mov DWORD [48+esp],esi lea esi,[3395469782+edi*1+esi] mov edi,DWORD [52+esp] add esi,ebp ; 20_39 61 mov ebp,eax xor edi,DWORD [60+esp] xor ebp,ebx xor edi,DWORD [20+esp] xor ebp,ecx xor edi,DWORD [40+esp] rol edi,1 add edx,ebp ror eax,2 mov ebp,esi rol ebp,5 mov DWORD [52+esp],edi lea edi,[3395469782+edx*1+edi] mov edx,DWORD [56+esp] add edi,ebp ; 20_39 62 mov ebp,esi xor edx,DWORD [esp] xor ebp,eax xor edx,DWORD [24+esp] xor ebp,ebx xor edx,DWORD [44+esp] rol edx,1 add ecx,ebp ror esi,2 mov ebp,edi rol ebp,5 mov DWORD [56+esp],edx lea edx,[3395469782+ecx*1+edx] mov ecx,DWORD [60+esp] add edx,ebp ; 20_39 63 mov ebp,edi xor ecx,DWORD [4+esp] xor ebp,esi xor ecx,DWORD [28+esp] xor ebp,eax xor ecx,DWORD [48+esp] rol ecx,1 add ebx,ebp ror edi,2 mov ebp,edx rol ebp,5 mov DWORD [60+esp],ecx lea ecx,[3395469782+ebx*1+ecx] mov ebx,DWORD [esp] add ecx,ebp ; 20_39 64 mov ebp,edx xor ebx,DWORD [8+esp] xor ebp,edi xor ebx,DWORD [32+esp] xor ebp,esi xor ebx,DWORD [52+esp] rol ebx,1 add eax,ebp ror edx,2 mov ebp,ecx rol ebp,5 mov DWORD [esp],ebx lea ebx,[3395469782+eax*1+ebx] mov eax,DWORD [4+esp] add ebx,ebp ; 20_39 65 mov ebp,ecx xor eax,DWORD [12+esp] xor ebp,edx xor eax,DWORD [36+esp] xor ebp,edi xor eax,DWORD [56+esp] rol eax,1 add esi,ebp ror ecx,2 mov ebp,ebx rol ebp,5 mov DWORD [4+esp],eax lea eax,[3395469782+esi*1+eax] mov esi,DWORD [8+esp] add eax,ebp ; 20_39 66 mov ebp,ebx xor esi,DWORD [16+esp] xor ebp,ecx xor esi,DWORD [40+esp] xor ebp,edx xor esi,DWORD [60+esp] rol esi,1 add edi,ebp ror ebx,2 mov ebp,eax rol ebp,5 mov DWORD [8+esp],esi lea esi,[3395469782+edi*1+esi] mov edi,DWORD [12+esp] add esi,ebp ; 20_39 67 mov ebp,eax xor edi,DWORD [20+esp] xor ebp,ebx xor edi,DWORD [44+esp] xor ebp,ecx xor edi,DWORD [esp] rol edi,1 add edx,ebp ror eax,2 mov ebp,esi rol ebp,5 mov DWORD [12+esp],edi lea edi,[3395469782+edx*1+edi] mov edx,DWORD [16+esp] add edi,ebp ; 20_39 68 mov ebp,esi xor edx,DWORD [24+esp] xor ebp,eax xor edx,DWORD [48+esp] xor ebp,ebx xor edx,DWORD [4+esp] rol edx,1 add ecx,ebp ror esi,2 mov ebp,edi rol ebp,5 mov DWORD [16+esp],edx lea edx,[3395469782+ecx*1+edx] mov ecx,DWORD [20+esp] add edx,ebp ; 20_39 69 mov ebp,edi xor ecx,DWORD [28+esp] xor ebp,esi xor ecx,DWORD [52+esp] xor ebp,eax xor ecx,DWORD [8+esp] rol ecx,1 add ebx,ebp ror edi,2 mov ebp,edx rol ebp,5 mov DWORD [20+esp],ecx lea ecx,[3395469782+ebx*1+ecx] mov ebx,DWORD [24+esp] add ecx,ebp ; 20_39 70 mov ebp,edx xor ebx,DWORD [32+esp] xor ebp,edi xor ebx,DWORD [56+esp] xor ebp,esi xor ebx,DWORD [12+esp] rol ebx,1 add eax,ebp ror edx,2 mov ebp,ecx rol ebp,5 mov DWORD [24+esp],ebx lea ebx,[3395469782+eax*1+ebx] mov eax,DWORD [28+esp] add ebx,ebp ; 20_39 71 mov ebp,ecx xor eax,DWORD [36+esp] xor ebp,edx xor eax,DWORD [60+esp] xor ebp,edi xor eax,DWORD [16+esp] rol eax,1 add esi,ebp ror ecx,2 mov ebp,ebx rol ebp,5 mov DWORD [28+esp],eax lea eax,[3395469782+esi*1+eax] mov esi,DWORD [32+esp] add eax,ebp ; 20_39 72 mov ebp,ebx xor esi,DWORD [40+esp] xor ebp,ecx xor esi,DWORD [esp] xor ebp,edx xor esi,DWORD [20+esp] rol esi,1 add edi,ebp ror ebx,2 mov ebp,eax rol ebp,5 mov DWORD [32+esp],esi lea esi,[3395469782+edi*1+esi] mov edi,DWORD [36+esp] add esi,ebp ; 20_39 73 mov ebp,eax xor edi,DWORD [44+esp] xor ebp,ebx xor edi,DWORD [4+esp] xor ebp,ecx xor edi,DWORD [24+esp] rol edi,1 add edx,ebp ror eax,2 mov ebp,esi rol ebp,5 mov DWORD [36+esp],edi lea edi,[3395469782+edx*1+edi] mov edx,DWORD [40+esp] add edi,ebp ; 20_39 74 mov ebp,esi xor edx,DWORD [48+esp] xor ebp,eax xor edx,DWORD [8+esp] xor ebp,ebx xor edx,DWORD [28+esp] rol edx,1 add ecx,ebp ror esi,2 mov ebp,edi rol ebp,5 mov DWORD [40+esp],edx lea edx,[3395469782+ecx*1+edx] mov ecx,DWORD [44+esp] add edx,ebp ; 20_39 75 mov ebp,edi xor ecx,DWORD [52+esp] xor ebp,esi xor ecx,DWORD [12+esp] xor ebp,eax xor ecx,DWORD [32+esp] rol ecx,1 add ebx,ebp ror edi,2 mov ebp,edx rol ebp,5 mov DWORD [44+esp],ecx lea ecx,[3395469782+ebx*1+ecx] mov ebx,DWORD [48+esp] add ecx,ebp ; 20_39 76 mov ebp,edx xor ebx,DWORD [56+esp] xor ebp,edi xor ebx,DWORD [16+esp] xor ebp,esi xor ebx,DWORD [36+esp] rol ebx,1 add eax,ebp ror edx,2 mov ebp,ecx rol ebp,5 mov DWORD [48+esp],ebx lea ebx,[3395469782+eax*1+ebx] mov eax,DWORD [52+esp] add ebx,ebp ; 20_39 77 mov ebp,ecx xor eax,DWORD [60+esp] xor ebp,edx xor eax,DWORD [20+esp] xor ebp,edi xor eax,DWORD [40+esp] rol eax,1 add esi,ebp ror ecx,2 mov ebp,ebx rol ebp,5 lea eax,[3395469782+esi*1+eax] mov esi,DWORD [56+esp] add eax,ebp ; 20_39 78 mov ebp,ebx xor esi,DWORD [esp] xor ebp,ecx xor esi,DWORD [24+esp] xor ebp,edx xor esi,DWORD [44+esp] rol esi,1 add edi,ebp ror ebx,2 mov ebp,eax rol ebp,5 lea esi,[3395469782+edi*1+esi] mov edi,DWORD [60+esp] add esi,ebp ; 20_39 79 mov ebp,eax xor edi,DWORD [4+esp] xor ebp,ebx xor edi,DWORD [28+esp] xor ebp,ecx xor edi,DWORD [48+esp] rol edi,1 add edx,ebp ror eax,2 mov ebp,esi rol ebp,5 lea edi,[3395469782+edx*1+edi] add edi,ebp mov ebp,DWORD [96+esp] mov edx,DWORD [100+esp] add edi,DWORD [ebp] add esi,DWORD [4+ebp] add eax,DWORD [8+ebp] add ebx,DWORD [12+ebp] add ecx,DWORD [16+ebp] mov DWORD [ebp],edi add edx,64 mov DWORD [4+ebp],esi cmp edx,DWORD [104+esp] mov DWORD [8+ebp],eax mov edi,ecx mov DWORD [12+ebp],ebx mov esi,edx mov DWORD [16+ebp],ecx jb NEAR L$002loop add esp,76 pop edi pop esi pop ebx pop ebp ret align 16 __sha1_block_data_order_ssse3: push ebp push ebx push esi push edi call L$003pic_point L$003pic_point: pop ebp lea ebp,[(L$K_XX_XX-L$003pic_point)+ebp] L$ssse3_shortcut: movdqa xmm7,[ebp] movdqa xmm0,[16+ebp] movdqa xmm1,[32+ebp] movdqa xmm2,[48+ebp] movdqa xmm6,[64+ebp] mov edi,DWORD [20+esp] mov ebp,DWORD [24+esp] mov edx,DWORD [28+esp] mov esi,esp sub esp,208 and esp,-64 movdqa [112+esp],xmm0 movdqa [128+esp],xmm1 movdqa [144+esp],xmm2 shl edx,6 movdqa [160+esp],xmm7 add edx,ebp movdqa [176+esp],xmm6 add ebp,64 mov DWORD [192+esp],edi mov DWORD [196+esp],ebp mov DWORD [200+esp],edx mov DWORD [204+esp],esi mov eax,DWORD [edi] mov ebx,DWORD [4+edi] mov ecx,DWORD [8+edi] mov edx,DWORD [12+edi] mov edi,DWORD [16+edi] mov esi,ebx movdqu xmm0,[ebp-64] movdqu xmm1,[ebp-48] movdqu xmm2,[ebp-32] movdqu xmm3,[ebp-16] db 102,15,56,0,198 db 102,15,56,0,206 db 102,15,56,0,214 movdqa [96+esp],xmm7 db 102,15,56,0,222 paddd xmm0,xmm7 paddd xmm1,xmm7 paddd xmm2,xmm7 movdqa [esp],xmm0 psubd xmm0,xmm7 movdqa [16+esp],xmm1 psubd xmm1,xmm7 movdqa [32+esp],xmm2 mov ebp,ecx psubd xmm2,xmm7 xor ebp,edx pshufd xmm4,xmm0,238 and esi,ebp jmp NEAR L$004loop align 16 L$004loop: ror ebx,2 xor esi,edx mov ebp,eax punpcklqdq xmm4,xmm1 movdqa xmm6,xmm3 add edi,DWORD [esp] xor ebx,ecx paddd xmm7,xmm3 movdqa [64+esp],xmm0 rol eax,5 add edi,esi psrldq xmm6,4 and ebp,ebx xor ebx,ecx pxor xmm4,xmm0 add edi,eax ror eax,7 pxor xmm6,xmm2 xor ebp,ecx mov esi,edi add edx,DWORD [4+esp] pxor xmm4,xmm6 xor eax,ebx rol edi,5 movdqa [48+esp],xmm7 add edx,ebp and esi,eax movdqa xmm0,xmm4 xor eax,ebx add edx,edi ror edi,7 movdqa xmm6,xmm4 xor esi,ebx pslldq xmm0,12 paddd xmm4,xmm4 mov ebp,edx add ecx,DWORD [8+esp] psrld xmm6,31 xor edi,eax rol edx,5 movdqa xmm7,xmm0 add ecx,esi and ebp,edi xor edi,eax psrld xmm0,30 add ecx,edx ror edx,7 por xmm4,xmm6 xor ebp,eax mov esi,ecx add ebx,DWORD [12+esp] pslld xmm7,2 xor edx,edi rol ecx,5 pxor xmm4,xmm0 movdqa xmm0,[96+esp] add ebx,ebp and esi,edx pxor xmm4,xmm7 pshufd xmm5,xmm1,238 xor edx,edi add ebx,ecx ror ecx,7 xor esi,edi mov ebp,ebx punpcklqdq xmm5,xmm2 movdqa xmm7,xmm4 add eax,DWORD [16+esp] xor ecx,edx paddd xmm0,xmm4 movdqa [80+esp],xmm1 rol ebx,5 add eax,esi psrldq xmm7,4 and ebp,ecx xor ecx,edx pxor xmm5,xmm1 add eax,ebx ror ebx,7 pxor xmm7,xmm3 xor ebp,edx mov esi,eax add edi,DWORD [20+esp] pxor xmm5,xmm7 xor ebx,ecx rol eax,5 movdqa [esp],xmm0 add edi,ebp and esi,ebx movdqa xmm1,xmm5 xor ebx,ecx add edi,eax ror eax,7 movdqa xmm7,xmm5 xor esi,ecx pslldq xmm1,12 paddd xmm5,xmm5 mov ebp,edi add edx,DWORD [24+esp] psrld xmm7,31 xor eax,ebx rol edi,5 movdqa xmm0,xmm1 add edx,esi and ebp,eax xor eax,ebx psrld xmm1,30 add edx,edi ror edi,7 por xmm5,xmm7 xor ebp,ebx mov esi,edx add ecx,DWORD [28+esp] pslld xmm0,2 xor edi,eax rol edx,5 pxor xmm5,xmm1 movdqa xmm1,[112+esp] add ecx,ebp and esi,edi pxor xmm5,xmm0 pshufd xmm6,xmm2,238 xor edi,eax add ecx,edx ror edx,7 xor esi,eax mov ebp,ecx punpcklqdq xmm6,xmm3 movdqa xmm0,xmm5 add ebx,DWORD [32+esp] xor edx,edi paddd xmm1,xmm5 movdqa [96+esp],xmm2 rol ecx,5 add ebx,esi psrldq xmm0,4 and ebp,edx xor edx,edi pxor xmm6,xmm2 add ebx,ecx ror ecx,7 pxor xmm0,xmm4 xor ebp,edi mov esi,ebx add eax,DWORD [36+esp] pxor xmm6,xmm0 xor ecx,edx rol ebx,5 movdqa [16+esp],xmm1 add eax,ebp and esi,ecx movdqa xmm2,xmm6 xor ecx,edx add eax,ebx ror ebx,7 movdqa xmm0,xmm6 xor esi,edx pslldq xmm2,12 paddd xmm6,xmm6 mov ebp,eax add edi,DWORD [40+esp] psrld xmm0,31 xor ebx,ecx rol eax,5 movdqa xmm1,xmm2 add edi,esi and ebp,ebx xor ebx,ecx psrld xmm2,30 add edi,eax ror eax,7 por xmm6,xmm0 xor ebp,ecx movdqa xmm0,[64+esp] mov esi,edi add edx,DWORD [44+esp] pslld xmm1,2 xor eax,ebx rol edi,5 pxor xmm6,xmm2 movdqa xmm2,[112+esp] add edx,ebp and esi,eax pxor xmm6,xmm1 pshufd xmm7,xmm3,238 xor eax,ebx add edx,edi ror edi,7 xor esi,ebx mov ebp,edx punpcklqdq xmm7,xmm4 movdqa xmm1,xmm6 add ecx,DWORD [48+esp] xor edi,eax paddd xmm2,xmm6 movdqa [64+esp],xmm3 rol edx,5 add ecx,esi psrldq xmm1,4 and ebp,edi xor edi,eax pxor xmm7,xmm3 add ecx,edx ror edx,7 pxor xmm1,xmm5 xor ebp,eax mov esi,ecx add ebx,DWORD [52+esp] pxor xmm7,xmm1 xor edx,edi rol ecx,5 movdqa [32+esp],xmm2 add ebx,ebp and esi,edx movdqa xmm3,xmm7 xor edx,edi add ebx,ecx ror ecx,7 movdqa xmm1,xmm7 xor esi,edi pslldq xmm3,12 paddd xmm7,xmm7 mov ebp,ebx add eax,DWORD [56+esp] psrld xmm1,31 xor ecx,edx rol ebx,5 movdqa xmm2,xmm3 add eax,esi and ebp,ecx xor ecx,edx psrld xmm3,30 add eax,ebx ror ebx,7 por xmm7,xmm1 xor ebp,edx movdqa xmm1,[80+esp] mov esi,eax add edi,DWORD [60+esp] pslld xmm2,2 xor ebx,ecx rol eax,5 pxor xmm7,xmm3 movdqa xmm3,[112+esp] add edi,ebp and esi,ebx pxor xmm7,xmm2 pshufd xmm2,xmm6,238 xor ebx,ecx add edi,eax ror eax,7 pxor xmm0,xmm4 punpcklqdq xmm2,xmm7 xor esi,ecx mov ebp,edi add edx,DWORD [esp] pxor xmm0,xmm1 movdqa [80+esp],xmm4 xor eax,ebx rol edi,5 movdqa xmm4,xmm3 add edx,esi paddd xmm3,xmm7 and ebp,eax pxor xmm0,xmm2 xor eax,ebx add edx,edi ror edi,7 xor ebp,ebx movdqa xmm2,xmm0 movdqa [48+esp],xmm3 mov esi,edx add ecx,DWORD [4+esp] xor edi,eax rol edx,5 pslld xmm0,2 add ecx,ebp and esi,edi psrld xmm2,30 xor edi,eax add ecx,edx ror edx,7 xor esi,eax mov ebp,ecx add ebx,DWORD [8+esp] xor edx,edi rol ecx,5 por xmm0,xmm2 add ebx,esi and ebp,edx movdqa xmm2,[96+esp] xor edx,edi add ebx,ecx add eax,DWORD [12+esp] xor ebp,edi mov esi,ebx pshufd xmm3,xmm7,238 rol ebx,5 add eax,ebp xor esi,edx ror ecx,7 add eax,ebx add edi,DWORD [16+esp] pxor xmm1,xmm5 punpcklqdq xmm3,xmm0 xor esi,ecx mov ebp,eax rol eax,5 pxor xmm1,xmm2 movdqa [96+esp],xmm5 add edi,esi xor ebp,ecx movdqa xmm5,xmm4 ror ebx,7 paddd xmm4,xmm0 add edi,eax pxor xmm1,xmm3 add edx,DWORD [20+esp] xor ebp,ebx mov esi,edi rol edi,5 movdqa xmm3,xmm1 movdqa [esp],xmm4 add edx,ebp xor esi,ebx ror eax,7 add edx,edi pslld xmm1,2 add ecx,DWORD [24+esp] xor esi,eax psrld xmm3,30 mov ebp,edx rol edx,5 add ecx,esi xor ebp,eax ror edi,7 add ecx,edx por xmm1,xmm3 add ebx,DWORD [28+esp] xor ebp,edi movdqa xmm3,[64+esp] mov esi,ecx rol ecx,5 add ebx,ebp xor esi,edi ror edx,7 pshufd xmm4,xmm0,238 add ebx,ecx add eax,DWORD [32+esp] pxor xmm2,xmm6 punpcklqdq xmm4,xmm1 xor esi,edx mov ebp,ebx rol ebx,5 pxor xmm2,xmm3 movdqa [64+esp],xmm6 add eax,esi xor ebp,edx movdqa xmm6,[128+esp] ror ecx,7 paddd xmm5,xmm1 add eax,ebx pxor xmm2,xmm4 add edi,DWORD [36+esp] xor ebp,ecx mov esi,eax rol eax,5 movdqa xmm4,xmm2 movdqa [16+esp],xmm5 add edi,ebp xor esi,ecx ror ebx,7 add edi,eax pslld xmm2,2 add edx,DWORD [40+esp] xor esi,ebx psrld xmm4,30 mov ebp,edi rol edi,5 add edx,esi xor ebp,ebx ror eax,7 add edx,edi por xmm2,xmm4 add ecx,DWORD [44+esp] xor ebp,eax movdqa xmm4,[80+esp] mov esi,edx rol edx,5 add ecx,ebp xor esi,eax ror edi,7 pshufd xmm5,xmm1,238 add ecx,edx add ebx,DWORD [48+esp] pxor xmm3,xmm7 punpcklqdq xmm5,xmm2 xor esi,edi mov ebp,ecx rol ecx,5 pxor xmm3,xmm4 movdqa [80+esp],xmm7 add ebx,esi xor ebp,edi movdqa xmm7,xmm6 ror edx,7 paddd xmm6,xmm2 add ebx,ecx pxor xmm3,xmm5 add eax,DWORD [52+esp] xor ebp,edx mov esi,ebx rol ebx,5 movdqa xmm5,xmm3 movdqa [32+esp],xmm6 add eax,ebp xor esi,edx ror ecx,7 add eax,ebx pslld xmm3,2 add edi,DWORD [56+esp] xor esi,ecx psrld xmm5,30 mov ebp,eax rol eax,5 add edi,esi xor ebp,ecx ror ebx,7 add edi,eax por xmm3,xmm5 add edx,DWORD [60+esp] xor ebp,ebx movdqa xmm5,[96+esp] mov esi,edi rol edi,5 add edx,ebp xor esi,ebx ror eax,7 pshufd xmm6,xmm2,238 add edx,edi add ecx,DWORD [esp] pxor xmm4,xmm0 punpcklqdq xmm6,xmm3 xor esi,eax mov ebp,edx rol edx,5 pxor xmm4,xmm5 movdqa [96+esp],xmm0 add ecx,esi xor ebp,eax movdqa xmm0,xmm7 ror edi,7 paddd xmm7,xmm3 add ecx,edx pxor xmm4,xmm6 add ebx,DWORD [4+esp] xor ebp,edi mov esi,ecx rol ecx,5 movdqa xmm6,xmm4 movdqa [48+esp],xmm7 add ebx,ebp xor esi,edi ror edx,7 add ebx,ecx pslld xmm4,2 add eax,DWORD [8+esp] xor esi,edx psrld xmm6,30 mov ebp,ebx rol ebx,5 add eax,esi xor ebp,edx ror ecx,7 add eax,ebx por xmm4,xmm6 add edi,DWORD [12+esp] xor ebp,ecx movdqa xmm6,[64+esp] mov esi,eax rol eax,5 add edi,ebp xor esi,ecx ror ebx,7 pshufd xmm7,xmm3,238 add edi,eax add edx,DWORD [16+esp] pxor xmm5,xmm1 punpcklqdq xmm7,xmm4 xor esi,ebx mov ebp,edi rol edi,5 pxor xmm5,xmm6 movdqa [64+esp],xmm1 add edx,esi xor ebp,ebx movdqa xmm1,xmm0 ror eax,7 paddd xmm0,xmm4 add edx,edi pxor xmm5,xmm7 add ecx,DWORD [20+esp] xor ebp,eax mov esi,edx rol edx,5 movdqa xmm7,xmm5 movdqa [esp],xmm0 add ecx,ebp xor esi,eax ror edi,7 add ecx,edx pslld xmm5,2 add ebx,DWORD [24+esp] xor esi,edi psrld xmm7,30 mov ebp,ecx rol ecx,5 add ebx,esi xor ebp,edi ror edx,7 add ebx,ecx por xmm5,xmm7 add eax,DWORD [28+esp] movdqa xmm7,[80+esp] ror ecx,7 mov esi,ebx xor ebp,edx rol ebx,5 pshufd xmm0,xmm4,238 add eax,ebp xor esi,ecx xor ecx,edx add eax,ebx add edi,DWORD [32+esp] pxor xmm6,xmm2 punpcklqdq xmm0,xmm5 and esi,ecx xor ecx,edx ror ebx,7 pxor xmm6,xmm7 movdqa [80+esp],xmm2 mov ebp,eax xor esi,ecx rol eax,5 movdqa xmm2,xmm1 add edi,esi paddd xmm1,xmm5 xor ebp,ebx pxor xmm6,xmm0 xor ebx,ecx add edi,eax add edx,DWORD [36+esp] and ebp,ebx movdqa xmm0,xmm6 movdqa [16+esp],xmm1 xor ebx,ecx ror eax,7 mov esi,edi xor ebp,ebx rol edi,5 pslld xmm6,2 add edx,ebp xor esi,eax psrld xmm0,30 xor eax,ebx add edx,edi add ecx,DWORD [40+esp] and esi,eax xor eax,ebx ror edi,7 por xmm6,xmm0 mov ebp,edx xor esi,eax movdqa xmm0,[96+esp] rol edx,5 add ecx,esi xor ebp,edi xor edi,eax add ecx,edx pshufd xmm1,xmm5,238 add ebx,DWORD [44+esp] and ebp,edi xor edi,eax ror edx,7 mov esi,ecx xor ebp,edi rol ecx,5 add ebx,ebp xor esi,edx xor edx,edi add ebx,ecx add eax,DWORD [48+esp] pxor xmm7,xmm3 punpcklqdq xmm1,xmm6 and esi,edx xor edx,edi ror ecx,7 pxor xmm7,xmm0 movdqa [96+esp],xmm3 mov ebp,ebx xor esi,edx rol ebx,5 movdqa xmm3,[144+esp] add eax,esi paddd xmm2,xmm6 xor ebp,ecx pxor xmm7,xmm1 xor ecx,edx add eax,ebx add edi,DWORD [52+esp] and ebp,ecx movdqa xmm1,xmm7 movdqa [32+esp],xmm2 xor ecx,edx ror ebx,7 mov esi,eax xor ebp,ecx rol eax,5 pslld xmm7,2 add edi,ebp xor esi,ebx psrld xmm1,30 xor ebx,ecx add edi,eax add edx,DWORD [56+esp] and esi,ebx xor ebx,ecx ror eax,7 por xmm7,xmm1 mov ebp,edi xor esi,ebx movdqa xmm1,[64+esp] rol edi,5 add edx,esi xor ebp,eax xor eax,ebx add edx,edi pshufd xmm2,xmm6,238 add ecx,DWORD [60+esp] and ebp,eax xor eax,ebx ror edi,7 mov esi,edx xor ebp,eax rol edx,5 add ecx,ebp xor esi,edi xor edi,eax add ecx,edx add ebx,DWORD [esp] pxor xmm0,xmm4 punpcklqdq xmm2,xmm7 and esi,edi xor edi,eax ror edx,7 pxor xmm0,xmm1 movdqa [64+esp],xmm4 mov ebp,ecx xor esi,edi rol ecx,5 movdqa xmm4,xmm3 add ebx,esi paddd xmm3,xmm7 xor ebp,edx pxor xmm0,xmm2 xor edx,edi add ebx,ecx add eax,DWORD [4+esp] and ebp,edx movdqa xmm2,xmm0 movdqa [48+esp],xmm3 xor edx,edi ror ecx,7 mov esi,ebx xor ebp,edx rol ebx,5 pslld xmm0,2 add eax,ebp xor esi,ecx psrld xmm2,30 xor ecx,edx add eax,ebx add edi,DWORD [8+esp] and esi,ecx xor ecx,edx ror ebx,7 por xmm0,xmm2 mov ebp,eax xor esi,ecx movdqa xmm2,[80+esp] rol eax,5 add edi,esi xor ebp,ebx xor ebx,ecx add edi,eax pshufd xmm3,xmm7,238 add edx,DWORD [12+esp] and ebp,ebx xor ebx,ecx ror eax,7 mov esi,edi xor ebp,ebx rol edi,5 add edx,ebp xor esi,eax xor eax,ebx add edx,edi add ecx,DWORD [16+esp] pxor xmm1,xmm5 punpcklqdq xmm3,xmm0 and esi,eax xor eax,ebx ror edi,7 pxor xmm1,xmm2 movdqa [80+esp],xmm5 mov ebp,edx xor esi,eax rol edx,5 movdqa xmm5,xmm4 add ecx,esi paddd xmm4,xmm0 xor ebp,edi pxor xmm1,xmm3 xor edi,eax add ecx,edx add ebx,DWORD [20+esp] and ebp,edi movdqa xmm3,xmm1 movdqa [esp],xmm4 xor edi,eax ror edx,7 mov esi,ecx xor ebp,edi rol ecx,5 pslld xmm1,2 add ebx,ebp xor esi,edx psrld xmm3,30 xor edx,edi add ebx,ecx add eax,DWORD [24+esp] and esi,edx xor edx,edi ror ecx,7 por xmm1,xmm3 mov ebp,ebx xor esi,edx movdqa xmm3,[96+esp] rol ebx,5 add eax,esi xor ebp,ecx xor ecx,edx add eax,ebx pshufd xmm4,xmm0,238 add edi,DWORD [28+esp] and ebp,ecx xor ecx,edx ror ebx,7 mov esi,eax xor ebp,ecx rol eax,5 add edi,ebp xor esi,ebx xor ebx,ecx add edi,eax add edx,DWORD [32+esp] pxor xmm2,xmm6 punpcklqdq xmm4,xmm1 and esi,ebx xor ebx,ecx ror eax,7 pxor xmm2,xmm3 movdqa [96+esp],xmm6 mov ebp,edi xor esi,ebx rol edi,5 movdqa xmm6,xmm5 add edx,esi paddd xmm5,xmm1 xor ebp,eax pxor xmm2,xmm4 xor eax,ebx add edx,edi add ecx,DWORD [36+esp] and ebp,eax movdqa xmm4,xmm2 movdqa [16+esp],xmm5 xor eax,ebx ror edi,7 mov esi,edx xor ebp,eax rol edx,5 pslld xmm2,2 add ecx,ebp xor esi,edi psrld xmm4,30 xor edi,eax add ecx,edx add ebx,DWORD [40+esp] and esi,edi xor edi,eax ror edx,7 por xmm2,xmm4 mov ebp,ecx xor esi,edi movdqa xmm4,[64+esp] rol ecx,5 add ebx,esi xor ebp,edx xor edx,edi add ebx,ecx pshufd xmm5,xmm1,238 add eax,DWORD [44+esp] and ebp,edx xor edx,edi ror ecx,7 mov esi,ebx xor ebp,edx rol ebx,5 add eax,ebp xor esi,edx add eax,ebx add edi,DWORD [48+esp] pxor xmm3,xmm7 punpcklqdq xmm5,xmm2 xor esi,ecx mov ebp,eax rol eax,5 pxor xmm3,xmm4 movdqa [64+esp],xmm7 add edi,esi xor ebp,ecx movdqa xmm7,xmm6 ror ebx,7 paddd xmm6,xmm2 add edi,eax pxor xmm3,xmm5 add edx,DWORD [52+esp] xor ebp,ebx mov esi,edi rol edi,5 movdqa xmm5,xmm3 movdqa [32+esp],xmm6 add edx,ebp xor esi,ebx ror eax,7 add edx,edi pslld xmm3,2 add ecx,DWORD [56+esp] xor esi,eax psrld xmm5,30 mov ebp,edx rol edx,5 add ecx,esi xor ebp,eax ror edi,7 add ecx,edx por xmm3,xmm5 add ebx,DWORD [60+esp] xor ebp,edi mov esi,ecx rol ecx,5 add ebx,ebp xor esi,edi ror edx,7 add ebx,ecx add eax,DWORD [esp] xor esi,edx mov ebp,ebx rol ebx,5 add eax,esi xor ebp,edx ror ecx,7 paddd xmm7,xmm3 add eax,ebx add edi,DWORD [4+esp] xor ebp,ecx mov esi,eax movdqa [48+esp],xmm7 rol eax,5 add edi,ebp xor esi,ecx ror ebx,7 add edi,eax add edx,DWORD [8+esp] xor esi,ebx mov ebp,edi rol edi,5 add edx,esi xor ebp,ebx ror eax,7 add edx,edi add ecx,DWORD [12+esp] xor ebp,eax mov esi,edx rol edx,5 add ecx,ebp xor esi,eax ror edi,7 add ecx,edx mov ebp,DWORD [196+esp] cmp ebp,DWORD [200+esp] je NEAR L$005done movdqa xmm7,[160+esp] movdqa xmm6,[176+esp] movdqu xmm0,[ebp] movdqu xmm1,[16+ebp] movdqu xmm2,[32+ebp] movdqu xmm3,[48+ebp] add ebp,64 db 102,15,56,0,198 mov DWORD [196+esp],ebp movdqa [96+esp],xmm7 add ebx,DWORD [16+esp] xor esi,edi mov ebp,ecx rol ecx,5 add ebx,esi xor ebp,edi ror edx,7 db 102,15,56,0,206 add ebx,ecx add eax,DWORD [20+esp] xor ebp,edx mov esi,ebx paddd xmm0,xmm7 rol ebx,5 add eax,ebp xor esi,edx ror ecx,7 movdqa [esp],xmm0 add eax,ebx add edi,DWORD [24+esp] xor esi,ecx mov ebp,eax psubd xmm0,xmm7 rol eax,5 add edi,esi xor ebp,ecx ror ebx,7 add edi,eax add edx,DWORD [28+esp] xor ebp,ebx mov esi,edi rol edi,5 add edx,ebp xor esi,ebx ror eax,7 add edx,edi add ecx,DWORD [32+esp] xor esi,eax mov ebp,edx rol edx,5 add ecx,esi xor ebp,eax ror edi,7 db 102,15,56,0,214 add ecx,edx add ebx,DWORD [36+esp] xor ebp,edi mov esi,ecx paddd xmm1,xmm7 rol ecx,5 add ebx,ebp xor esi,edi ror edx,7 movdqa [16+esp],xmm1 add ebx,ecx add eax,DWORD [40+esp] xor esi,edx mov ebp,ebx psubd xmm1,xmm7 rol ebx,5 add eax,esi xor ebp,edx ror ecx,7 add eax,ebx add edi,DWORD [44+esp] xor ebp,ecx mov esi,eax rol eax,5 add edi,ebp xor esi,ecx ror ebx,7 add edi,eax add edx,DWORD [48+esp] xor esi,ebx mov ebp,edi rol edi,5 add edx,esi xor ebp,ebx ror eax,7 db 102,15,56,0,222 add edx,edi add ecx,DWORD [52+esp] xor ebp,eax mov esi,edx paddd xmm2,xmm7 rol edx,5 add ecx,ebp xor esi,eax ror edi,7 movdqa [32+esp],xmm2 add ecx,edx add ebx,DWORD [56+esp] xor esi,edi mov ebp,ecx psubd xmm2,xmm7 rol ecx,5 add ebx,esi xor ebp,edi ror edx,7 add ebx,ecx add eax,DWORD [60+esp] xor ebp,edx mov esi,ebx rol ebx,5 add eax,ebp ror ecx,7 add eax,ebx mov ebp,DWORD [192+esp] add eax,DWORD [ebp] add esi,DWORD [4+ebp] add ecx,DWORD [8+ebp] mov DWORD [ebp],eax add edx,DWORD [12+ebp] mov DWORD [4+ebp],esi add edi,DWORD [16+ebp] mov DWORD [8+ebp],ecx mov ebx,ecx mov DWORD [12+ebp],edx xor ebx,edx mov DWORD [16+ebp],edi mov ebp,esi pshufd xmm4,xmm0,238 and esi,ebx mov ebx,ebp jmp NEAR L$004loop align 16 L$005done: add ebx,DWORD [16+esp] xor esi,edi mov ebp,ecx rol ecx,5 add ebx,esi xor ebp,edi ror edx,7 add ebx,ecx add eax,DWORD [20+esp] xor ebp,edx mov esi,ebx rol ebx,5 add eax,ebp xor esi,edx ror ecx,7 add eax,ebx add edi,DWORD [24+esp] xor esi,ecx mov ebp,eax rol eax,5 add edi,esi xor ebp,ecx ror ebx,7 add edi,eax add edx,DWORD [28+esp] xor ebp,ebx mov esi,edi rol edi,5 add edx,ebp xor esi,ebx ror eax,7 add edx,edi add ecx,DWORD [32+esp] xor esi,eax mov ebp,edx rol edx,5 add ecx,esi xor ebp,eax ror edi,7 add ecx,edx add ebx,DWORD [36+esp] xor ebp,edi mov esi,ecx rol ecx,5 add ebx,ebp xor esi,edi ror edx,7 add ebx,ecx add eax,DWORD [40+esp] xor esi,edx mov ebp,ebx rol ebx,5 add eax,esi xor ebp,edx ror ecx,7 add eax,ebx add edi,DWORD [44+esp] xor ebp,ecx mov esi,eax rol eax,5 add edi,ebp xor esi,ecx ror ebx,7 add edi,eax add edx,DWORD [48+esp] xor esi,ebx mov ebp,edi rol edi,5 add edx,esi xor ebp,ebx ror eax,7 add edx,edi add ecx,DWORD [52+esp] xor ebp,eax mov esi,edx rol edx,5 add ecx,ebp xor esi,eax ror edi,7 add ecx,edx add ebx,DWORD [56+esp] xor esi,edi mov ebp,ecx rol ecx,5 add ebx,esi xor ebp,edi ror edx,7 add ebx,ecx add eax,DWORD [60+esp] xor ebp,edx mov esi,ebx rol ebx,5 add eax,ebp ror ecx,7 add eax,ebx mov ebp,DWORD [192+esp] add eax,DWORD [ebp] mov esp,DWORD [204+esp] add esi,DWORD [4+ebp] add ecx,DWORD [8+ebp] mov DWORD [ebp],eax add edx,DWORD [12+ebp] mov DWORD [4+ebp],esi add edi,DWORD [16+ebp] mov DWORD [8+ebp],ecx mov DWORD [12+ebp],edx mov DWORD [16+ebp],edi pop edi pop esi pop ebx pop ebp ret align 16 __sha1_block_data_order_avx: push ebp push ebx push esi push edi call L$006pic_point L$006pic_point: pop ebp lea ebp,[(L$K_XX_XX-L$006pic_point)+ebp] L$avx_shortcut: vzeroall vmovdqa xmm7,[ebp] vmovdqa xmm0,[16+ebp] vmovdqa xmm1,[32+ebp] vmovdqa xmm2,[48+ebp] vmovdqa xmm6,[64+ebp] mov edi,DWORD [20+esp] mov ebp,DWORD [24+esp] mov edx,DWORD [28+esp] mov esi,esp sub esp,208 and esp,-64 vmovdqa [112+esp],xmm0 vmovdqa [128+esp],xmm1 vmovdqa [144+esp],xmm2 shl edx,6 vmovdqa [160+esp],xmm7 add edx,ebp vmovdqa [176+esp],xmm6 add ebp,64 mov DWORD [192+esp],edi mov DWORD [196+esp],ebp mov DWORD [200+esp],edx mov DWORD [204+esp],esi mov eax,DWORD [edi] mov ebx,DWORD [4+edi] mov ecx,DWORD [8+edi] mov edx,DWORD [12+edi] mov edi,DWORD [16+edi] mov esi,ebx vmovdqu xmm0,[ebp-64] vmovdqu xmm1,[ebp-48] vmovdqu xmm2,[ebp-32] vmovdqu xmm3,[ebp-16] vpshufb xmm0,xmm0,xmm6 vpshufb xmm1,xmm1,xmm6 vpshufb xmm2,xmm2,xmm6 vmovdqa [96+esp],xmm7 vpshufb xmm3,xmm3,xmm6 vpaddd xmm4,xmm0,xmm7 vpaddd xmm5,xmm1,xmm7 vpaddd xmm6,xmm2,xmm7 vmovdqa [esp],xmm4 mov ebp,ecx vmovdqa [16+esp],xmm5 xor ebp,edx vmovdqa [32+esp],xmm6 and esi,ebp jmp NEAR L$007loop align 16 L$007loop: shrd ebx,ebx,2 xor esi,edx vpalignr xmm4,xmm1,xmm0,8 mov ebp,eax add edi,DWORD [esp] vpaddd xmm7,xmm7,xmm3 vmovdqa [64+esp],xmm0 xor ebx,ecx shld eax,eax,5 vpsrldq xmm6,xmm3,4 add edi,esi and ebp,ebx vpxor xmm4,xmm4,xmm0 xor ebx,ecx add edi,eax vpxor xmm6,xmm6,xmm2 shrd eax,eax,7 xor ebp,ecx vmovdqa [48+esp],xmm7 mov esi,edi add edx,DWORD [4+esp] vpxor xmm4,xmm4,xmm6 xor eax,ebx shld edi,edi,5 add edx,ebp and esi,eax vpsrld xmm6,xmm4,31 xor eax,ebx add edx,edi shrd edi,edi,7 xor esi,ebx vpslldq xmm0,xmm4,12 vpaddd xmm4,xmm4,xmm4 mov ebp,edx add ecx,DWORD [8+esp] xor edi,eax shld edx,edx,5 vpsrld xmm7,xmm0,30 vpor xmm4,xmm4,xmm6 add ecx,esi and ebp,edi xor edi,eax add ecx,edx vpslld xmm0,xmm0,2 shrd edx,edx,7 xor ebp,eax vpxor xmm4,xmm4,xmm7 mov esi,ecx add ebx,DWORD [12+esp] xor edx,edi shld ecx,ecx,5 vpxor xmm4,xmm4,xmm0 add ebx,ebp and esi,edx vmovdqa xmm0,[96+esp] xor edx,edi add ebx,ecx shrd ecx,ecx,7 xor esi,edi vpalignr xmm5,xmm2,xmm1,8 mov ebp,ebx add eax,DWORD [16+esp] vpaddd xmm0,xmm0,xmm4 vmovdqa [80+esp],xmm1 xor ecx,edx shld ebx,ebx,5 vpsrldq xmm7,xmm4,4 add eax,esi and ebp,ecx vpxor xmm5,xmm5,xmm1 xor ecx,edx add eax,ebx vpxor xmm7,xmm7,xmm3 shrd ebx,ebx,7 xor ebp,edx vmovdqa [esp],xmm0 mov esi,eax add edi,DWORD [20+esp] vpxor xmm5,xmm5,xmm7 xor ebx,ecx shld eax,eax,5 add edi,ebp and esi,ebx vpsrld xmm7,xmm5,31 xor ebx,ecx add edi,eax shrd eax,eax,7 xor esi,ecx vpslldq xmm1,xmm5,12 vpaddd xmm5,xmm5,xmm5 mov ebp,edi add edx,DWORD [24+esp] xor eax,ebx shld edi,edi,5 vpsrld xmm0,xmm1,30 vpor xmm5,xmm5,xmm7 add edx,esi and ebp,eax xor eax,ebx add edx,edi vpslld xmm1,xmm1,2 shrd edi,edi,7 xor ebp,ebx vpxor xmm5,xmm5,xmm0 mov esi,edx add ecx,DWORD [28+esp] xor edi,eax shld edx,edx,5 vpxor xmm5,xmm5,xmm1 add ecx,ebp and esi,edi vmovdqa xmm1,[112+esp] xor edi,eax add ecx,edx shrd edx,edx,7 xor esi,eax vpalignr xmm6,xmm3,xmm2,8 mov ebp,ecx add ebx,DWORD [32+esp] vpaddd xmm1,xmm1,xmm5 vmovdqa [96+esp],xmm2 xor edx,edi shld ecx,ecx,5 vpsrldq xmm0,xmm5,4 add ebx,esi and ebp,edx vpxor xmm6,xmm6,xmm2 xor edx,edi add ebx,ecx vpxor xmm0,xmm0,xmm4 shrd ecx,ecx,7 xor ebp,edi vmovdqa [16+esp],xmm1 mov esi,ebx add eax,DWORD [36+esp] vpxor xmm6,xmm6,xmm0 xor ecx,edx shld ebx,ebx,5 add eax,ebp and esi,ecx vpsrld xmm0,xmm6,31 xor ecx,edx add eax,ebx shrd ebx,ebx,7 xor esi,edx vpslldq xmm2,xmm6,12 vpaddd xmm6,xmm6,xmm6 mov ebp,eax add edi,DWORD [40+esp] xor ebx,ecx shld eax,eax,5 vpsrld xmm1,xmm2,30 vpor xmm6,xmm6,xmm0 add edi,esi and ebp,ebx xor ebx,ecx add edi,eax vpslld xmm2,xmm2,2 vmovdqa xmm0,[64+esp] shrd eax,eax,7 xor ebp,ecx vpxor xmm6,xmm6,xmm1 mov esi,edi add edx,DWORD [44+esp] xor eax,ebx shld edi,edi,5 vpxor xmm6,xmm6,xmm2 add edx,ebp and esi,eax vmovdqa xmm2,[112+esp] xor eax,ebx add edx,edi shrd edi,edi,7 xor esi,ebx vpalignr xmm7,xmm4,xmm3,8 mov ebp,edx add ecx,DWORD [48+esp] vpaddd xmm2,xmm2,xmm6 vmovdqa [64+esp],xmm3 xor edi,eax shld edx,edx,5 vpsrldq xmm1,xmm6,4 add ecx,esi and ebp,edi vpxor xmm7,xmm7,xmm3 xor edi,eax add ecx,edx vpxor xmm1,xmm1,xmm5 shrd edx,edx,7 xor ebp,eax vmovdqa [32+esp],xmm2 mov esi,ecx add ebx,DWORD [52+esp] vpxor xmm7,xmm7,xmm1 xor edx,edi shld ecx,ecx,5 add ebx,ebp and esi,edx vpsrld xmm1,xmm7,31 xor edx,edi add ebx,ecx shrd ecx,ecx,7 xor esi,edi vpslldq xmm3,xmm7,12 vpaddd xmm7,xmm7,xmm7 mov ebp,ebx add eax,DWORD [56+esp] xor ecx,edx shld ebx,ebx,5 vpsrld xmm2,xmm3,30 vpor xmm7,xmm7,xmm1 add eax,esi and ebp,ecx xor ecx,edx add eax,ebx vpslld xmm3,xmm3,2 vmovdqa xmm1,[80+esp] shrd ebx,ebx,7 xor ebp,edx vpxor xmm7,xmm7,xmm2 mov esi,eax add edi,DWORD [60+esp] xor ebx,ecx shld eax,eax,5 vpxor xmm7,xmm7,xmm3 add edi,ebp and esi,ebx vmovdqa xmm3,[112+esp] xor ebx,ecx add edi,eax vpalignr xmm2,xmm7,xmm6,8 vpxor xmm0,xmm0,xmm4 shrd eax,eax,7 xor esi,ecx mov ebp,edi add edx,DWORD [esp] vpxor xmm0,xmm0,xmm1 vmovdqa [80+esp],xmm4 xor eax,ebx shld edi,edi,5 vmovdqa xmm4,xmm3 vpaddd xmm3,xmm3,xmm7 add edx,esi and ebp,eax vpxor xmm0,xmm0,xmm2 xor eax,ebx add edx,edi shrd edi,edi,7 xor ebp,ebx vpsrld xmm2,xmm0,30 vmovdqa [48+esp],xmm3 mov esi,edx add ecx,DWORD [4+esp] xor edi,eax shld edx,edx,5 vpslld xmm0,xmm0,2 add ecx,ebp and esi,edi xor edi,eax add ecx,edx shrd edx,edx,7 xor esi,eax mov ebp,ecx add ebx,DWORD [8+esp] vpor xmm0,xmm0,xmm2 xor edx,edi shld ecx,ecx,5 vmovdqa xmm2,[96+esp] add ebx,esi and ebp,edx xor edx,edi add ebx,ecx add eax,DWORD [12+esp] xor ebp,edi mov esi,ebx shld ebx,ebx,5 add eax,ebp xor esi,edx shrd ecx,ecx,7 add eax,ebx vpalignr xmm3,xmm0,xmm7,8 vpxor xmm1,xmm1,xmm5 add edi,DWORD [16+esp] xor esi,ecx mov ebp,eax shld eax,eax,5 vpxor xmm1,xmm1,xmm2 vmovdqa [96+esp],xmm5 add edi,esi xor ebp,ecx vmovdqa xmm5,xmm4 vpaddd xmm4,xmm4,xmm0 shrd ebx,ebx,7 add edi,eax vpxor xmm1,xmm1,xmm3 add edx,DWORD [20+esp] xor ebp,ebx mov esi,edi shld edi,edi,5 vpsrld xmm3,xmm1,30 vmovdqa [esp],xmm4 add edx,ebp xor esi,ebx shrd eax,eax,7 add edx,edi vpslld xmm1,xmm1,2 add ecx,DWORD [24+esp] xor esi,eax mov ebp,edx shld edx,edx,5 add ecx,esi xor ebp,eax shrd edi,edi,7 add ecx,edx vpor xmm1,xmm1,xmm3 add ebx,DWORD [28+esp] xor ebp,edi vmovdqa xmm3,[64+esp] mov esi,ecx shld ecx,ecx,5 add ebx,ebp xor esi,edi shrd edx,edx,7 add ebx,ecx vpalignr xmm4,xmm1,xmm0,8 vpxor xmm2,xmm2,xmm6 add eax,DWORD [32+esp] xor esi,edx mov ebp,ebx shld ebx,ebx,5 vpxor xmm2,xmm2,xmm3 vmovdqa [64+esp],xmm6 add eax,esi xor ebp,edx vmovdqa xmm6,[128+esp] vpaddd xmm5,xmm5,xmm1 shrd ecx,ecx,7 add eax,ebx vpxor xmm2,xmm2,xmm4 add edi,DWORD [36+esp] xor ebp,ecx mov esi,eax shld eax,eax,5 vpsrld xmm4,xmm2,30 vmovdqa [16+esp],xmm5 add edi,ebp xor esi,ecx shrd ebx,ebx,7 add edi,eax vpslld xmm2,xmm2,2 add edx,DWORD [40+esp] xor esi,ebx mov ebp,edi shld edi,edi,5 add edx,esi xor ebp,ebx shrd eax,eax,7 add edx,edi vpor xmm2,xmm2,xmm4 add ecx,DWORD [44+esp] xor ebp,eax vmovdqa xmm4,[80+esp] mov esi,edx shld edx,edx,5 add ecx,ebp xor esi,eax shrd edi,edi,7 add ecx,edx vpalignr xmm5,xmm2,xmm1,8 vpxor xmm3,xmm3,xmm7 add ebx,DWORD [48+esp] xor esi,edi mov ebp,ecx shld ecx,ecx,5 vpxor xmm3,xmm3,xmm4 vmovdqa [80+esp],xmm7 add ebx,esi xor ebp,edi vmovdqa xmm7,xmm6 vpaddd xmm6,xmm6,xmm2 shrd edx,edx,7 add ebx,ecx vpxor xmm3,xmm3,xmm5 add eax,DWORD [52+esp] xor ebp,edx mov esi,ebx shld ebx,ebx,5 vpsrld xmm5,xmm3,30 vmovdqa [32+esp],xmm6 add eax,ebp xor esi,edx shrd ecx,ecx,7 add eax,ebx vpslld xmm3,xmm3,2 add edi,DWORD [56+esp] xor esi,ecx mov ebp,eax shld eax,eax,5 add edi,esi xor ebp,ecx shrd ebx,ebx,7 add edi,eax vpor xmm3,xmm3,xmm5 add edx,DWORD [60+esp] xor ebp,ebx vmovdqa xmm5,[96+esp] mov esi,edi shld edi,edi,5 add edx,ebp xor esi,ebx shrd eax,eax,7 add edx,edi vpalignr xmm6,xmm3,xmm2,8 vpxor xmm4,xmm4,xmm0 add ecx,DWORD [esp] xor esi,eax mov ebp,edx shld edx,edx,5 vpxor xmm4,xmm4,xmm5 vmovdqa [96+esp],xmm0 add ecx,esi xor ebp,eax vmovdqa xmm0,xmm7 vpaddd xmm7,xmm7,xmm3 shrd edi,edi,7 add ecx,edx vpxor xmm4,xmm4,xmm6 add ebx,DWORD [4+esp] xor ebp,edi mov esi,ecx shld ecx,ecx,5 vpsrld xmm6,xmm4,30 vmovdqa [48+esp],xmm7 add ebx,ebp xor esi,edi shrd edx,edx,7 add ebx,ecx vpslld xmm4,xmm4,2 add eax,DWORD [8+esp] xor esi,edx mov ebp,ebx shld ebx,ebx,5 add eax,esi xor ebp,edx shrd ecx,ecx,7 add eax,ebx vpor xmm4,xmm4,xmm6 add edi,DWORD [12+esp] xor ebp,ecx vmovdqa xmm6,[64+esp] mov esi,eax shld eax,eax,5 add edi,ebp xor esi,ecx shrd ebx,ebx,7 add edi,eax vpalignr xmm7,xmm4,xmm3,8 vpxor xmm5,xmm5,xmm1 add edx,DWORD [16+esp] xor esi,ebx mov ebp,edi shld edi,edi,5 vpxor xmm5,xmm5,xmm6 vmovdqa [64+esp],xmm1 add edx,esi xor ebp,ebx vmovdqa xmm1,xmm0 vpaddd xmm0,xmm0,xmm4 shrd eax,eax,7 add edx,edi vpxor xmm5,xmm5,xmm7 add ecx,DWORD [20+esp] xor ebp,eax mov esi,edx shld edx,edx,5 vpsrld xmm7,xmm5,30 vmovdqa [esp],xmm0 add ecx,ebp xor esi,eax shrd edi,edi,7 add ecx,edx vpslld xmm5,xmm5,2 add ebx,DWORD [24+esp] xor esi,edi mov ebp,ecx shld ecx,ecx,5 add ebx,esi xor ebp,edi shrd edx,edx,7 add ebx,ecx vpor xmm5,xmm5,xmm7 add eax,DWORD [28+esp] vmovdqa xmm7,[80+esp] shrd ecx,ecx,7 mov esi,ebx xor ebp,edx shld ebx,ebx,5 add eax,ebp xor esi,ecx xor ecx,edx add eax,ebx vpalignr xmm0,xmm5,xmm4,8 vpxor xmm6,xmm6,xmm2 add edi,DWORD [32+esp] and esi,ecx xor ecx,edx shrd ebx,ebx,7 vpxor xmm6,xmm6,xmm7 vmovdqa [80+esp],xmm2 mov ebp,eax xor esi,ecx vmovdqa xmm2,xmm1 vpaddd xmm1,xmm1,xmm5 shld eax,eax,5 add edi,esi vpxor xmm6,xmm6,xmm0 xor ebp,ebx xor ebx,ecx add edi,eax add edx,DWORD [36+esp] vpsrld xmm0,xmm6,30 vmovdqa [16+esp],xmm1 and ebp,ebx xor ebx,ecx shrd eax,eax,7 mov esi,edi vpslld xmm6,xmm6,2 xor ebp,ebx shld edi,edi,5 add edx,ebp xor esi,eax xor eax,ebx add edx,edi add ecx,DWORD [40+esp] and esi,eax vpor xmm6,xmm6,xmm0 xor eax,ebx shrd edi,edi,7 vmovdqa xmm0,[96+esp] mov ebp,edx xor esi,eax shld edx,edx,5 add ecx,esi xor ebp,edi xor edi,eax add ecx,edx add ebx,DWORD [44+esp] and ebp,edi xor edi,eax shrd edx,edx,7 mov esi,ecx xor ebp,edi shld ecx,ecx,5 add ebx,ebp xor esi,edx xor edx,edi add ebx,ecx vpalignr xmm1,xmm6,xmm5,8 vpxor xmm7,xmm7,xmm3 add eax,DWORD [48+esp] and esi,edx xor edx,edi shrd ecx,ecx,7 vpxor xmm7,xmm7,xmm0 vmovdqa [96+esp],xmm3 mov ebp,ebx xor esi,edx vmovdqa xmm3,[144+esp] vpaddd xmm2,xmm2,xmm6 shld ebx,ebx,5 add eax,esi vpxor xmm7,xmm7,xmm1 xor ebp,ecx xor ecx,edx add eax,ebx add edi,DWORD [52+esp] vpsrld xmm1,xmm7,30 vmovdqa [32+esp],xmm2 and ebp,ecx xor ecx,edx shrd ebx,ebx,7 mov esi,eax vpslld xmm7,xmm7,2 xor ebp,ecx shld eax,eax,5 add edi,ebp xor esi,ebx xor ebx,ecx add edi,eax add edx,DWORD [56+esp] and esi,ebx vpor xmm7,xmm7,xmm1 xor ebx,ecx shrd eax,eax,7 vmovdqa xmm1,[64+esp] mov ebp,edi xor esi,ebx shld edi,edi,5 add edx,esi xor ebp,eax xor eax,ebx add edx,edi add ecx,DWORD [60+esp] and ebp,eax xor eax,ebx shrd edi,edi,7 mov esi,edx xor ebp,eax shld edx,edx,5 add ecx,ebp xor esi,edi xor edi,eax add ecx,edx vpalignr xmm2,xmm7,xmm6,8 vpxor xmm0,xmm0,xmm4 add ebx,DWORD [esp] and esi,edi xor edi,eax shrd edx,edx,7 vpxor xmm0,xmm0,xmm1 vmovdqa [64+esp],xmm4 mov ebp,ecx xor esi,edi vmovdqa xmm4,xmm3 vpaddd xmm3,xmm3,xmm7 shld ecx,ecx,5 add ebx,esi vpxor xmm0,xmm0,xmm2 xor ebp,edx xor edx,edi add ebx,ecx add eax,DWORD [4+esp] vpsrld xmm2,xmm0,30 vmovdqa [48+esp],xmm3 and ebp,edx xor edx,edi shrd ecx,ecx,7 mov esi,ebx vpslld xmm0,xmm0,2 xor ebp,edx shld ebx,ebx,5 add eax,ebp xor esi,ecx xor ecx,edx add eax,ebx add edi,DWORD [8+esp] and esi,ecx vpor xmm0,xmm0,xmm2 xor ecx,edx shrd ebx,ebx,7 vmovdqa xmm2,[80+esp] mov ebp,eax xor esi,ecx shld eax,eax,5 add edi,esi xor ebp,ebx xor ebx,ecx add edi,eax add edx,DWORD [12+esp] and ebp,ebx xor ebx,ecx shrd eax,eax,7 mov esi,edi xor ebp,ebx shld edi,edi,5 add edx,ebp xor esi,eax xor eax,ebx add edx,edi vpalignr xmm3,xmm0,xmm7,8 vpxor xmm1,xmm1,xmm5 add ecx,DWORD [16+esp] and esi,eax xor eax,ebx shrd edi,edi,7 vpxor xmm1,xmm1,xmm2 vmovdqa [80+esp],xmm5 mov ebp,edx xor esi,eax vmovdqa xmm5,xmm4 vpaddd xmm4,xmm4,xmm0 shld edx,edx,5 add ecx,esi vpxor xmm1,xmm1,xmm3 xor ebp,edi xor edi,eax add ecx,edx add ebx,DWORD [20+esp] vpsrld xmm3,xmm1,30 vmovdqa [esp],xmm4 and ebp,edi xor edi,eax shrd edx,edx,7 mov esi,ecx vpslld xmm1,xmm1,2 xor ebp,edi shld ecx,ecx,5 add ebx,ebp xor esi,edx xor edx,edi add ebx,ecx add eax,DWORD [24+esp] and esi,edx vpor xmm1,xmm1,xmm3 xor edx,edi shrd ecx,ecx,7 vmovdqa xmm3,[96+esp] mov ebp,ebx xor esi,edx shld ebx,ebx,5 add eax,esi xor ebp,ecx xor ecx,edx add eax,ebx add edi,DWORD [28+esp] and ebp,ecx xor ecx,edx shrd ebx,ebx,7 mov esi,eax xor ebp,ecx shld eax,eax,5 add edi,ebp xor esi,ebx xor ebx,ecx add edi,eax vpalignr xmm4,xmm1,xmm0,8 vpxor xmm2,xmm2,xmm6 add edx,DWORD [32+esp] and esi,ebx xor ebx,ecx shrd eax,eax,7 vpxor xmm2,xmm2,xmm3 vmovdqa [96+esp],xmm6 mov ebp,edi xor esi,ebx vmovdqa xmm6,xmm5 vpaddd xmm5,xmm5,xmm1 shld edi,edi,5 add edx,esi vpxor xmm2,xmm2,xmm4 xor ebp,eax xor eax,ebx add edx,edi add ecx,DWORD [36+esp] vpsrld xmm4,xmm2,30 vmovdqa [16+esp],xmm5 and ebp,eax xor eax,ebx shrd edi,edi,7 mov esi,edx vpslld xmm2,xmm2,2 xor ebp,eax shld edx,edx,5 add ecx,ebp xor esi,edi xor edi,eax add ecx,edx add ebx,DWORD [40+esp] and esi,edi vpor xmm2,xmm2,xmm4 xor edi,eax shrd edx,edx,7 vmovdqa xmm4,[64+esp] mov ebp,ecx xor esi,edi shld ecx,ecx,5 add ebx,esi xor ebp,edx xor edx,edi add ebx,ecx add eax,DWORD [44+esp] and ebp,edx xor edx,edi shrd ecx,ecx,7 mov esi,ebx xor ebp,edx shld ebx,ebx,5 add eax,ebp xor esi,edx add eax,ebx vpalignr xmm5,xmm2,xmm1,8 vpxor xmm3,xmm3,xmm7 add edi,DWORD [48+esp] xor esi,ecx mov ebp,eax shld eax,eax,5 vpxor xmm3,xmm3,xmm4 vmovdqa [64+esp],xmm7 add edi,esi xor ebp,ecx vmovdqa xmm7,xmm6 vpaddd xmm6,xmm6,xmm2 shrd ebx,ebx,7 add edi,eax vpxor xmm3,xmm3,xmm5 add edx,DWORD [52+esp] xor ebp,ebx mov esi,edi shld edi,edi,5 vpsrld xmm5,xmm3,30 vmovdqa [32+esp],xmm6 add edx,ebp xor esi,ebx shrd eax,eax,7 add edx,edi vpslld xmm3,xmm3,2 add ecx,DWORD [56+esp] xor esi,eax mov ebp,edx shld edx,edx,5 add ecx,esi xor ebp,eax shrd edi,edi,7 add ecx,edx vpor xmm3,xmm3,xmm5 add ebx,DWORD [60+esp] xor ebp,edi mov esi,ecx shld ecx,ecx,5 add ebx,ebp xor esi,edi shrd edx,edx,7 add ebx,ecx add eax,DWORD [esp] vpaddd xmm7,xmm7,xmm3 xor esi,edx mov ebp,ebx shld ebx,ebx,5 add eax,esi vmovdqa [48+esp],xmm7 xor ebp,edx shrd ecx,ecx,7 add eax,ebx add edi,DWORD [4+esp] xor ebp,ecx mov esi,eax shld eax,eax,5 add edi,ebp xor esi,ecx shrd ebx,ebx,7 add edi,eax add edx,DWORD [8+esp] xor esi,ebx mov ebp,edi shld edi,edi,5 add edx,esi xor ebp,ebx shrd eax,eax,7 add edx,edi add ecx,DWORD [12+esp] xor ebp,eax mov esi,edx shld edx,edx,5 add ecx,ebp xor esi,eax shrd edi,edi,7 add ecx,edx mov ebp,DWORD [196+esp] cmp ebp,DWORD [200+esp] je NEAR L$008done vmovdqa xmm7,[160+esp] vmovdqa xmm6,[176+esp] vmovdqu xmm0,[ebp] vmovdqu xmm1,[16+ebp] vmovdqu xmm2,[32+ebp] vmovdqu xmm3,[48+ebp] add ebp,64 vpshufb xmm0,xmm0,xmm6 mov DWORD [196+esp],ebp vmovdqa [96+esp],xmm7 add ebx,DWORD [16+esp] xor esi,edi vpshufb xmm1,xmm1,xmm6 mov ebp,ecx shld ecx,ecx,5 vpaddd xmm4,xmm0,xmm7 add ebx,esi xor ebp,edi shrd edx,edx,7 add ebx,ecx vmovdqa [esp],xmm4 add eax,DWORD [20+esp] xor ebp,edx mov esi,ebx shld ebx,ebx,5 add eax,ebp xor esi,edx shrd ecx,ecx,7 add eax,ebx add edi,DWORD [24+esp] xor esi,ecx mov ebp,eax shld eax,eax,5 add edi,esi xor ebp,ecx shrd ebx,ebx,7 add edi,eax add edx,DWORD [28+esp] xor ebp,ebx mov esi,edi shld edi,edi,5 add edx,ebp xor esi,ebx shrd eax,eax,7 add edx,edi add ecx,DWORD [32+esp] xor esi,eax vpshufb xmm2,xmm2,xmm6 mov ebp,edx shld edx,edx,5 vpaddd xmm5,xmm1,xmm7 add ecx,esi xor ebp,eax shrd edi,edi,7 add ecx,edx vmovdqa [16+esp],xmm5 add ebx,DWORD [36+esp] xor ebp,edi mov esi,ecx shld ecx,ecx,5 add ebx,ebp xor esi,edi shrd edx,edx,7 add ebx,ecx add eax,DWORD [40+esp] xor esi,edx mov ebp,ebx shld ebx,ebx,5 add eax,esi xor ebp,edx shrd ecx,ecx,7 add eax,ebx add edi,DWORD [44+esp] xor ebp,ecx mov esi,eax shld eax,eax,5 add edi,ebp xor esi,ecx shrd ebx,ebx,7 add edi,eax add edx,DWORD [48+esp] xor esi,ebx vpshufb xmm3,xmm3,xmm6 mov ebp,edi shld edi,edi,5 vpaddd xmm6,xmm2,xmm7 add edx,esi xor ebp,ebx shrd eax,eax,7 add edx,edi vmovdqa [32+esp],xmm6 add ecx,DWORD [52+esp] xor ebp,eax mov esi,edx shld edx,edx,5 add ecx,ebp xor esi,eax shrd edi,edi,7 add ecx,edx add ebx,DWORD [56+esp] xor esi,edi mov ebp,ecx shld ecx,ecx,5 add ebx,esi xor ebp,edi shrd edx,edx,7 add ebx,ecx add eax,DWORD [60+esp] xor ebp,edx mov esi,ebx shld ebx,ebx,5 add eax,ebp shrd ecx,ecx,7 add eax,ebx mov ebp,DWORD [192+esp] add eax,DWORD [ebp] add esi,DWORD [4+ebp] add ecx,DWORD [8+ebp] mov DWORD [ebp],eax add edx,DWORD [12+ebp] mov DWORD [4+ebp],esi add edi,DWORD [16+ebp] mov ebx,ecx mov DWORD [8+ebp],ecx xor ebx,edx mov DWORD [12+ebp],edx mov DWORD [16+ebp],edi mov ebp,esi and esi,ebx mov ebx,ebp jmp NEAR L$007loop align 16 L$008done: add ebx,DWORD [16+esp] xor esi,edi mov ebp,ecx shld ecx,ecx,5 add ebx,esi xor ebp,edi shrd edx,edx,7 add ebx,ecx add eax,DWORD [20+esp] xor ebp,edx mov esi,ebx shld ebx,ebx,5 add eax,ebp xor esi,edx shrd ecx,ecx,7 add eax,ebx add edi,DWORD [24+esp] xor esi,ecx mov ebp,eax shld eax,eax,5 add edi,esi xor ebp,ecx shrd ebx,ebx,7 add edi,eax add edx,DWORD [28+esp] xor ebp,ebx mov esi,edi shld edi,edi,5 add edx,ebp xor esi,ebx shrd eax,eax,7 add edx,edi add ecx,DWORD [32+esp] xor esi,eax mov ebp,edx shld edx,edx,5 add ecx,esi xor ebp,eax shrd edi,edi,7 add ecx,edx add ebx,DWORD [36+esp] xor ebp,edi mov esi,ecx shld ecx,ecx,5 add ebx,ebp xor esi,edi shrd edx,edx,7 add ebx,ecx add eax,DWORD [40+esp] xor esi,edx mov ebp,ebx shld ebx,ebx,5 add eax,esi xor ebp,edx shrd ecx,ecx,7 add eax,ebx add edi,DWORD [44+esp] xor ebp,ecx mov esi,eax shld eax,eax,5 add edi,ebp xor esi,ecx shrd ebx,ebx,7 add edi,eax add edx,DWORD [48+esp] xor esi,ebx mov ebp,edi shld edi,edi,5 add edx,esi xor ebp,ebx shrd eax,eax,7 add edx,edi add ecx,DWORD [52+esp] xor ebp,eax mov esi,edx shld edx,edx,5 add ecx,ebp xor esi,eax shrd edi,edi,7 add ecx,edx add ebx,DWORD [56+esp] xor esi,edi mov ebp,ecx shld ecx,ecx,5 add ebx,esi xor ebp,edi shrd edx,edx,7 add ebx,ecx add eax,DWORD [60+esp] xor ebp,edx mov esi,ebx shld ebx,ebx,5 add eax,ebp shrd ecx,ecx,7 add eax,ebx vzeroall mov ebp,DWORD [192+esp] add eax,DWORD [ebp] mov esp,DWORD [204+esp] add esi,DWORD [4+ebp] add ecx,DWORD [8+ebp] mov DWORD [ebp],eax add edx,DWORD [12+ebp] mov DWORD [4+ebp],esi add edi,DWORD [16+ebp] mov DWORD [8+ebp],ecx mov DWORD [12+ebp],edx mov DWORD [16+ebp],edi pop edi pop esi pop ebx pop ebp ret align 64 L$K_XX_XX: dd 1518500249,1518500249,1518500249,1518500249 dd 1859775393,1859775393,1859775393,1859775393 dd 2400959708,2400959708,2400959708,2400959708 dd 3395469782,3395469782,3395469782,3395469782 dd 66051,67438087,134810123,202182159 db 15,14,13,12,11,10,9,8,7,6,5,4,3,2,1,0 db 83,72,65,49,32,98,108,111,99,107,32,116,114,97,110,115 db 102,111,114,109,32,102,111,114,32,120,56,54,44,32,67,82 db 89,80,84,79,71,65,77,83,32,98,121,32,60,97,112,112 db 114,111,64,111,112,101,110,115,115,108,46,111,114,103,62,0 segment .bss common _OPENSSL_ia32cap_P 16 %else ; Work around https://bugzilla.nasm.us/show_bug.cgi?id=3392738 ret %endif