Index: third_party/boringssl/win-x86/crypto/aes/aes-586.asm |
diff --git a/third_party/boringssl/win-x86/crypto/aes/aes-586.asm b/third_party/boringssl/win-x86/crypto/aes/aes-586.asm |
deleted file mode 100644 |
index 42ca0267e7a108462bb7d4914e6623c0e48c0c36..0000000000000000000000000000000000000000 |
--- a/third_party/boringssl/win-x86/crypto/aes/aes-586.asm |
+++ /dev/null |
@@ -1,3219 +0,0 @@ |
-%ifidn __OUTPUT_FORMAT__,obj |
-section code use32 class=code align=64 |
-%elifidn __OUTPUT_FORMAT__,win32 |
-%ifdef __YASM_VERSION_ID__ |
-%if __YASM_VERSION_ID__ < 01010000h |
-%error yasm version 1.1.0 or later needed. |
-%endif |
-; Yasm automatically includes .00 and complains about redefining it. |
-; https://www.tortall.net/projects/yasm/manual/html/objfmt-win32-safeseh.html |
-%else |
-$@feat.00 equ 1 |
-%endif |
-section .text code align=64 |
-%else |
-section .text code |
-%endif |
-align 16 |
-__x86_AES_encrypt_compact: |
- mov DWORD [20+esp],edi |
- xor eax,DWORD [edi] |
- xor ebx,DWORD [4+edi] |
- xor ecx,DWORD [8+edi] |
- xor edx,DWORD [12+edi] |
- mov esi,DWORD [240+edi] |
- lea esi,[esi*1+esi-2] |
- lea esi,[esi*8+edi] |
- mov DWORD [24+esp],esi |
- mov edi,DWORD [ebp-128] |
- mov esi,DWORD [ebp-96] |
- mov edi,DWORD [ebp-64] |
- mov esi,DWORD [ebp-32] |
- mov edi,DWORD [ebp] |
- mov esi,DWORD [32+ebp] |
- mov edi,DWORD [64+ebp] |
- mov esi,DWORD [96+ebp] |
-align 16 |
-L$000loop: |
- mov esi,eax |
- and esi,255 |
- movzx esi,BYTE [esi*1+ebp-128] |
- movzx edi,bh |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,8 |
- xor esi,edi |
- mov edi,ecx |
- shr edi,16 |
- and edi,255 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,16 |
- xor esi,edi |
- mov edi,edx |
- shr edi,24 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,24 |
- xor esi,edi |
- mov DWORD [4+esp],esi |
- mov esi,ebx |
- and esi,255 |
- shr ebx,16 |
- movzx esi,BYTE [esi*1+ebp-128] |
- movzx edi,ch |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,8 |
- xor esi,edi |
- mov edi,edx |
- shr edi,16 |
- and edi,255 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,16 |
- xor esi,edi |
- mov edi,eax |
- shr edi,24 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,24 |
- xor esi,edi |
- mov DWORD [8+esp],esi |
- mov esi,ecx |
- and esi,255 |
- shr ecx,24 |
- movzx esi,BYTE [esi*1+ebp-128] |
- movzx edi,dh |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,8 |
- xor esi,edi |
- mov edi,eax |
- shr edi,16 |
- and edx,255 |
- and edi,255 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,16 |
- xor esi,edi |
- movzx edi,bh |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,24 |
- xor esi,edi |
- and edx,255 |
- movzx edx,BYTE [edx*1+ebp-128] |
- movzx eax,ah |
- movzx eax,BYTE [eax*1+ebp-128] |
- shl eax,8 |
- xor edx,eax |
- mov eax,DWORD [4+esp] |
- and ebx,255 |
- movzx ebx,BYTE [ebx*1+ebp-128] |
- shl ebx,16 |
- xor edx,ebx |
- mov ebx,DWORD [8+esp] |
- movzx ecx,BYTE [ecx*1+ebp-128] |
- shl ecx,24 |
- xor edx,ecx |
- mov ecx,esi |
- mov ebp,2155905152 |
- and ebp,ecx |
- lea edi,[ecx*1+ecx] |
- mov esi,ebp |
- shr ebp,7 |
- and edi,4278124286 |
- sub esi,ebp |
- mov ebp,ecx |
- and esi,454761243 |
- ror ebp,16 |
- xor esi,edi |
- mov edi,ecx |
- xor ecx,esi |
- ror edi,24 |
- xor esi,ebp |
- rol ecx,24 |
- xor esi,edi |
- mov ebp,2155905152 |
- xor ecx,esi |
- and ebp,edx |
- lea edi,[edx*1+edx] |
- mov esi,ebp |
- shr ebp,7 |
- and edi,4278124286 |
- sub esi,ebp |
- mov ebp,edx |
- and esi,454761243 |
- ror ebp,16 |
- xor esi,edi |
- mov edi,edx |
- xor edx,esi |
- ror edi,24 |
- xor esi,ebp |
- rol edx,24 |
- xor esi,edi |
- mov ebp,2155905152 |
- xor edx,esi |
- and ebp,eax |
- lea edi,[eax*1+eax] |
- mov esi,ebp |
- shr ebp,7 |
- and edi,4278124286 |
- sub esi,ebp |
- mov ebp,eax |
- and esi,454761243 |
- ror ebp,16 |
- xor esi,edi |
- mov edi,eax |
- xor eax,esi |
- ror edi,24 |
- xor esi,ebp |
- rol eax,24 |
- xor esi,edi |
- mov ebp,2155905152 |
- xor eax,esi |
- and ebp,ebx |
- lea edi,[ebx*1+ebx] |
- mov esi,ebp |
- shr ebp,7 |
- and edi,4278124286 |
- sub esi,ebp |
- mov ebp,ebx |
- and esi,454761243 |
- ror ebp,16 |
- xor esi,edi |
- mov edi,ebx |
- xor ebx,esi |
- ror edi,24 |
- xor esi,ebp |
- rol ebx,24 |
- xor esi,edi |
- xor ebx,esi |
- mov edi,DWORD [20+esp] |
- mov ebp,DWORD [28+esp] |
- add edi,16 |
- xor eax,DWORD [edi] |
- xor ebx,DWORD [4+edi] |
- xor ecx,DWORD [8+edi] |
- xor edx,DWORD [12+edi] |
- cmp edi,DWORD [24+esp] |
- mov DWORD [20+esp],edi |
- jb NEAR L$000loop |
- mov esi,eax |
- and esi,255 |
- movzx esi,BYTE [esi*1+ebp-128] |
- movzx edi,bh |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,8 |
- xor esi,edi |
- mov edi,ecx |
- shr edi,16 |
- and edi,255 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,16 |
- xor esi,edi |
- mov edi,edx |
- shr edi,24 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,24 |
- xor esi,edi |
- mov DWORD [4+esp],esi |
- mov esi,ebx |
- and esi,255 |
- shr ebx,16 |
- movzx esi,BYTE [esi*1+ebp-128] |
- movzx edi,ch |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,8 |
- xor esi,edi |
- mov edi,edx |
- shr edi,16 |
- and edi,255 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,16 |
- xor esi,edi |
- mov edi,eax |
- shr edi,24 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,24 |
- xor esi,edi |
- mov DWORD [8+esp],esi |
- mov esi,ecx |
- and esi,255 |
- shr ecx,24 |
- movzx esi,BYTE [esi*1+ebp-128] |
- movzx edi,dh |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,8 |
- xor esi,edi |
- mov edi,eax |
- shr edi,16 |
- and edx,255 |
- and edi,255 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,16 |
- xor esi,edi |
- movzx edi,bh |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,24 |
- xor esi,edi |
- mov edi,DWORD [20+esp] |
- and edx,255 |
- movzx edx,BYTE [edx*1+ebp-128] |
- movzx eax,ah |
- movzx eax,BYTE [eax*1+ebp-128] |
- shl eax,8 |
- xor edx,eax |
- mov eax,DWORD [4+esp] |
- and ebx,255 |
- movzx ebx,BYTE [ebx*1+ebp-128] |
- shl ebx,16 |
- xor edx,ebx |
- mov ebx,DWORD [8+esp] |
- movzx ecx,BYTE [ecx*1+ebp-128] |
- shl ecx,24 |
- xor edx,ecx |
- mov ecx,esi |
- xor eax,DWORD [16+edi] |
- xor ebx,DWORD [20+edi] |
- xor ecx,DWORD [24+edi] |
- xor edx,DWORD [28+edi] |
- ret |
-align 16 |
-__sse_AES_encrypt_compact: |
- pxor mm0,[edi] |
- pxor mm4,[8+edi] |
- mov esi,DWORD [240+edi] |
- lea esi,[esi*1+esi-2] |
- lea esi,[esi*8+edi] |
- mov DWORD [24+esp],esi |
- mov eax,454761243 |
- mov DWORD [8+esp],eax |
- mov DWORD [12+esp],eax |
- mov eax,DWORD [ebp-128] |
- mov ebx,DWORD [ebp-96] |
- mov ecx,DWORD [ebp-64] |
- mov edx,DWORD [ebp-32] |
- mov eax,DWORD [ebp] |
- mov ebx,DWORD [32+ebp] |
- mov ecx,DWORD [64+ebp] |
- mov edx,DWORD [96+ebp] |
-align 16 |
-L$001loop: |
- pshufw mm1,mm0,8 |
- pshufw mm5,mm4,13 |
- movd eax,mm1 |
- movd ebx,mm5 |
- mov DWORD [20+esp],edi |
- movzx esi,al |
- movzx edx,ah |
- pshufw mm2,mm0,13 |
- movzx ecx,BYTE [esi*1+ebp-128] |
- movzx edi,bl |
- movzx edx,BYTE [edx*1+ebp-128] |
- shr eax,16 |
- shl edx,8 |
- movzx esi,BYTE [edi*1+ebp-128] |
- movzx edi,bh |
- shl esi,16 |
- pshufw mm6,mm4,8 |
- or ecx,esi |
- movzx esi,BYTE [edi*1+ebp-128] |
- movzx edi,ah |
- shl esi,24 |
- shr ebx,16 |
- or edx,esi |
- movzx esi,BYTE [edi*1+ebp-128] |
- movzx edi,bh |
- shl esi,8 |
- or ecx,esi |
- movzx esi,BYTE [edi*1+ebp-128] |
- movzx edi,al |
- shl esi,24 |
- or ecx,esi |
- movzx esi,BYTE [edi*1+ebp-128] |
- movzx edi,bl |
- movd eax,mm2 |
- movd mm0,ecx |
- movzx ecx,BYTE [edi*1+ebp-128] |
- movzx edi,ah |
- shl ecx,16 |
- movd ebx,mm6 |
- or ecx,esi |
- movzx esi,BYTE [edi*1+ebp-128] |
- movzx edi,bh |
- shl esi,24 |
- or ecx,esi |
- movzx esi,BYTE [edi*1+ebp-128] |
- movzx edi,bl |
- shl esi,8 |
- shr ebx,16 |
- or ecx,esi |
- movzx esi,BYTE [edi*1+ebp-128] |
- movzx edi,al |
- shr eax,16 |
- movd mm1,ecx |
- movzx ecx,BYTE [edi*1+ebp-128] |
- movzx edi,ah |
- shl ecx,16 |
- and eax,255 |
- or ecx,esi |
- punpckldq mm0,mm1 |
- movzx esi,BYTE [edi*1+ebp-128] |
- movzx edi,bh |
- shl esi,24 |
- and ebx,255 |
- movzx eax,BYTE [eax*1+ebp-128] |
- or ecx,esi |
- shl eax,16 |
- movzx esi,BYTE [edi*1+ebp-128] |
- or edx,eax |
- shl esi,8 |
- movzx ebx,BYTE [ebx*1+ebp-128] |
- or ecx,esi |
- or edx,ebx |
- mov edi,DWORD [20+esp] |
- movd mm4,ecx |
- movd mm5,edx |
- punpckldq mm4,mm5 |
- add edi,16 |
- cmp edi,DWORD [24+esp] |
- ja NEAR L$002out |
- movq mm2,[8+esp] |
- pxor mm3,mm3 |
- pxor mm7,mm7 |
- movq mm1,mm0 |
- movq mm5,mm4 |
- pcmpgtb mm3,mm0 |
- pcmpgtb mm7,mm4 |
- pand mm3,mm2 |
- pand mm7,mm2 |
- pshufw mm2,mm0,177 |
- pshufw mm6,mm4,177 |
- paddb mm0,mm0 |
- paddb mm4,mm4 |
- pxor mm0,mm3 |
- pxor mm4,mm7 |
- pshufw mm3,mm2,177 |
- pshufw mm7,mm6,177 |
- pxor mm1,mm0 |
- pxor mm5,mm4 |
- pxor mm0,mm2 |
- pxor mm4,mm6 |
- movq mm2,mm3 |
- movq mm6,mm7 |
- pslld mm3,8 |
- pslld mm7,8 |
- psrld mm2,24 |
- psrld mm6,24 |
- pxor mm0,mm3 |
- pxor mm4,mm7 |
- pxor mm0,mm2 |
- pxor mm4,mm6 |
- movq mm3,mm1 |
- movq mm7,mm5 |
- movq mm2,[edi] |
- movq mm6,[8+edi] |
- psrld mm1,8 |
- psrld mm5,8 |
- mov eax,DWORD [ebp-128] |
- pslld mm3,24 |
- pslld mm7,24 |
- mov ebx,DWORD [ebp-64] |
- pxor mm0,mm1 |
- pxor mm4,mm5 |
- mov ecx,DWORD [ebp] |
- pxor mm0,mm3 |
- pxor mm4,mm7 |
- mov edx,DWORD [64+ebp] |
- pxor mm0,mm2 |
- pxor mm4,mm6 |
- jmp NEAR L$001loop |
-align 16 |
-L$002out: |
- pxor mm0,[edi] |
- pxor mm4,[8+edi] |
- ret |
-align 16 |
-__x86_AES_encrypt: |
- mov DWORD [20+esp],edi |
- xor eax,DWORD [edi] |
- xor ebx,DWORD [4+edi] |
- xor ecx,DWORD [8+edi] |
- xor edx,DWORD [12+edi] |
- mov esi,DWORD [240+edi] |
- lea esi,[esi*1+esi-2] |
- lea esi,[esi*8+edi] |
- mov DWORD [24+esp],esi |
-align 16 |
-L$003loop: |
- mov esi,eax |
- and esi,255 |
- mov esi,DWORD [esi*8+ebp] |
- movzx edi,bh |
- xor esi,DWORD [3+edi*8+ebp] |
- mov edi,ecx |
- shr edi,16 |
- and edi,255 |
- xor esi,DWORD [2+edi*8+ebp] |
- mov edi,edx |
- shr edi,24 |
- xor esi,DWORD [1+edi*8+ebp] |
- mov DWORD [4+esp],esi |
- mov esi,ebx |
- and esi,255 |
- shr ebx,16 |
- mov esi,DWORD [esi*8+ebp] |
- movzx edi,ch |
- xor esi,DWORD [3+edi*8+ebp] |
- mov edi,edx |
- shr edi,16 |
- and edi,255 |
- xor esi,DWORD [2+edi*8+ebp] |
- mov edi,eax |
- shr edi,24 |
- xor esi,DWORD [1+edi*8+ebp] |
- mov DWORD [8+esp],esi |
- mov esi,ecx |
- and esi,255 |
- shr ecx,24 |
- mov esi,DWORD [esi*8+ebp] |
- movzx edi,dh |
- xor esi,DWORD [3+edi*8+ebp] |
- mov edi,eax |
- shr edi,16 |
- and edx,255 |
- and edi,255 |
- xor esi,DWORD [2+edi*8+ebp] |
- movzx edi,bh |
- xor esi,DWORD [1+edi*8+ebp] |
- mov edi,DWORD [20+esp] |
- mov edx,DWORD [edx*8+ebp] |
- movzx eax,ah |
- xor edx,DWORD [3+eax*8+ebp] |
- mov eax,DWORD [4+esp] |
- and ebx,255 |
- xor edx,DWORD [2+ebx*8+ebp] |
- mov ebx,DWORD [8+esp] |
- xor edx,DWORD [1+ecx*8+ebp] |
- mov ecx,esi |
- add edi,16 |
- xor eax,DWORD [edi] |
- xor ebx,DWORD [4+edi] |
- xor ecx,DWORD [8+edi] |
- xor edx,DWORD [12+edi] |
- cmp edi,DWORD [24+esp] |
- mov DWORD [20+esp],edi |
- jb NEAR L$003loop |
- mov esi,eax |
- and esi,255 |
- mov esi,DWORD [2+esi*8+ebp] |
- and esi,255 |
- movzx edi,bh |
- mov edi,DWORD [edi*8+ebp] |
- and edi,65280 |
- xor esi,edi |
- mov edi,ecx |
- shr edi,16 |
- and edi,255 |
- mov edi,DWORD [edi*8+ebp] |
- and edi,16711680 |
- xor esi,edi |
- mov edi,edx |
- shr edi,24 |
- mov edi,DWORD [2+edi*8+ebp] |
- and edi,4278190080 |
- xor esi,edi |
- mov DWORD [4+esp],esi |
- mov esi,ebx |
- and esi,255 |
- shr ebx,16 |
- mov esi,DWORD [2+esi*8+ebp] |
- and esi,255 |
- movzx edi,ch |
- mov edi,DWORD [edi*8+ebp] |
- and edi,65280 |
- xor esi,edi |
- mov edi,edx |
- shr edi,16 |
- and edi,255 |
- mov edi,DWORD [edi*8+ebp] |
- and edi,16711680 |
- xor esi,edi |
- mov edi,eax |
- shr edi,24 |
- mov edi,DWORD [2+edi*8+ebp] |
- and edi,4278190080 |
- xor esi,edi |
- mov DWORD [8+esp],esi |
- mov esi,ecx |
- and esi,255 |
- shr ecx,24 |
- mov esi,DWORD [2+esi*8+ebp] |
- and esi,255 |
- movzx edi,dh |
- mov edi,DWORD [edi*8+ebp] |
- and edi,65280 |
- xor esi,edi |
- mov edi,eax |
- shr edi,16 |
- and edx,255 |
- and edi,255 |
- mov edi,DWORD [edi*8+ebp] |
- and edi,16711680 |
- xor esi,edi |
- movzx edi,bh |
- mov edi,DWORD [2+edi*8+ebp] |
- and edi,4278190080 |
- xor esi,edi |
- mov edi,DWORD [20+esp] |
- and edx,255 |
- mov edx,DWORD [2+edx*8+ebp] |
- and edx,255 |
- movzx eax,ah |
- mov eax,DWORD [eax*8+ebp] |
- and eax,65280 |
- xor edx,eax |
- mov eax,DWORD [4+esp] |
- and ebx,255 |
- mov ebx,DWORD [ebx*8+ebp] |
- and ebx,16711680 |
- xor edx,ebx |
- mov ebx,DWORD [8+esp] |
- mov ecx,DWORD [2+ecx*8+ebp] |
- and ecx,4278190080 |
- xor edx,ecx |
- mov ecx,esi |
- add edi,16 |
- xor eax,DWORD [edi] |
- xor ebx,DWORD [4+edi] |
- xor ecx,DWORD [8+edi] |
- xor edx,DWORD [12+edi] |
- ret |
-align 64 |
-L$AES_Te: |
-dd 2774754246,2774754246 |
-dd 2222750968,2222750968 |
-dd 2574743534,2574743534 |
-dd 2373680118,2373680118 |
-dd 234025727,234025727 |
-dd 3177933782,3177933782 |
-dd 2976870366,2976870366 |
-dd 1422247313,1422247313 |
-dd 1345335392,1345335392 |
-dd 50397442,50397442 |
-dd 2842126286,2842126286 |
-dd 2099981142,2099981142 |
-dd 436141799,436141799 |
-dd 1658312629,1658312629 |
-dd 3870010189,3870010189 |
-dd 2591454956,2591454956 |
-dd 1170918031,1170918031 |
-dd 2642575903,2642575903 |
-dd 1086966153,1086966153 |
-dd 2273148410,2273148410 |
-dd 368769775,368769775 |
-dd 3948501426,3948501426 |
-dd 3376891790,3376891790 |
-dd 200339707,200339707 |
-dd 3970805057,3970805057 |
-dd 1742001331,1742001331 |
-dd 4255294047,4255294047 |
-dd 3937382213,3937382213 |
-dd 3214711843,3214711843 |
-dd 4154762323,4154762323 |
-dd 2524082916,2524082916 |
-dd 1539358875,1539358875 |
-dd 3266819957,3266819957 |
-dd 486407649,486407649 |
-dd 2928907069,2928907069 |
-dd 1780885068,1780885068 |
-dd 1513502316,1513502316 |
-dd 1094664062,1094664062 |
-dd 49805301,49805301 |
-dd 1338821763,1338821763 |
-dd 1546925160,1546925160 |
-dd 4104496465,4104496465 |
-dd 887481809,887481809 |
-dd 150073849,150073849 |
-dd 2473685474,2473685474 |
-dd 1943591083,1943591083 |
-dd 1395732834,1395732834 |
-dd 1058346282,1058346282 |
-dd 201589768,201589768 |
-dd 1388824469,1388824469 |
-dd 1696801606,1696801606 |
-dd 1589887901,1589887901 |
-dd 672667696,672667696 |
-dd 2711000631,2711000631 |
-dd 251987210,251987210 |
-dd 3046808111,3046808111 |
-dd 151455502,151455502 |
-dd 907153956,907153956 |
-dd 2608889883,2608889883 |
-dd 1038279391,1038279391 |
-dd 652995533,652995533 |
-dd 1764173646,1764173646 |
-dd 3451040383,3451040383 |
-dd 2675275242,2675275242 |
-dd 453576978,453576978 |
-dd 2659418909,2659418909 |
-dd 1949051992,1949051992 |
-dd 773462580,773462580 |
-dd 756751158,756751158 |
-dd 2993581788,2993581788 |
-dd 3998898868,3998898868 |
-dd 4221608027,4221608027 |
-dd 4132590244,4132590244 |
-dd 1295727478,1295727478 |
-dd 1641469623,1641469623 |
-dd 3467883389,3467883389 |
-dd 2066295122,2066295122 |
-dd 1055122397,1055122397 |
-dd 1898917726,1898917726 |
-dd 2542044179,2542044179 |
-dd 4115878822,4115878822 |
-dd 1758581177,1758581177 |
-dd 0,0 |
-dd 753790401,753790401 |
-dd 1612718144,1612718144 |
-dd 536673507,536673507 |
-dd 3367088505,3367088505 |
-dd 3982187446,3982187446 |
-dd 3194645204,3194645204 |
-dd 1187761037,1187761037 |
-dd 3653156455,3653156455 |
-dd 1262041458,1262041458 |
-dd 3729410708,3729410708 |
-dd 3561770136,3561770136 |
-dd 3898103984,3898103984 |
-dd 1255133061,1255133061 |
-dd 1808847035,1808847035 |
-dd 720367557,720367557 |
-dd 3853167183,3853167183 |
-dd 385612781,385612781 |
-dd 3309519750,3309519750 |
-dd 3612167578,3612167578 |
-dd 1429418854,1429418854 |
-dd 2491778321,2491778321 |
-dd 3477423498,3477423498 |
-dd 284817897,284817897 |
-dd 100794884,100794884 |
-dd 2172616702,2172616702 |
-dd 4031795360,4031795360 |
-dd 1144798328,1144798328 |
-dd 3131023141,3131023141 |
-dd 3819481163,3819481163 |
-dd 4082192802,4082192802 |
-dd 4272137053,4272137053 |
-dd 3225436288,3225436288 |
-dd 2324664069,2324664069 |
-dd 2912064063,2912064063 |
-dd 3164445985,3164445985 |
-dd 1211644016,1211644016 |
-dd 83228145,83228145 |
-dd 3753688163,3753688163 |
-dd 3249976951,3249976951 |
-dd 1977277103,1977277103 |
-dd 1663115586,1663115586 |
-dd 806359072,806359072 |
-dd 452984805,452984805 |
-dd 250868733,250868733 |
-dd 1842533055,1842533055 |
-dd 1288555905,1288555905 |
-dd 336333848,336333848 |
-dd 890442534,890442534 |
-dd 804056259,804056259 |
-dd 3781124030,3781124030 |
-dd 2727843637,2727843637 |
-dd 3427026056,3427026056 |
-dd 957814574,957814574 |
-dd 1472513171,1472513171 |
-dd 4071073621,4071073621 |
-dd 2189328124,2189328124 |
-dd 1195195770,1195195770 |
-dd 2892260552,2892260552 |
-dd 3881655738,3881655738 |
-dd 723065138,723065138 |
-dd 2507371494,2507371494 |
-dd 2690670784,2690670784 |
-dd 2558624025,2558624025 |
-dd 3511635870,3511635870 |
-dd 2145180835,2145180835 |
-dd 1713513028,1713513028 |
-dd 2116692564,2116692564 |
-dd 2878378043,2878378043 |
-dd 2206763019,2206763019 |
-dd 3393603212,3393603212 |
-dd 703524551,703524551 |
-dd 3552098411,3552098411 |
-dd 1007948840,1007948840 |
-dd 2044649127,2044649127 |
-dd 3797835452,3797835452 |
-dd 487262998,487262998 |
-dd 1994120109,1994120109 |
-dd 1004593371,1004593371 |
-dd 1446130276,1446130276 |
-dd 1312438900,1312438900 |
-dd 503974420,503974420 |
-dd 3679013266,3679013266 |
-dd 168166924,168166924 |
-dd 1814307912,1814307912 |
-dd 3831258296,3831258296 |
-dd 1573044895,1573044895 |
-dd 1859376061,1859376061 |
-dd 4021070915,4021070915 |
-dd 2791465668,2791465668 |
-dd 2828112185,2828112185 |
-dd 2761266481,2761266481 |
-dd 937747667,937747667 |
-dd 2339994098,2339994098 |
-dd 854058965,854058965 |
-dd 1137232011,1137232011 |
-dd 1496790894,1496790894 |
-dd 3077402074,3077402074 |
-dd 2358086913,2358086913 |
-dd 1691735473,1691735473 |
-dd 3528347292,3528347292 |
-dd 3769215305,3769215305 |
-dd 3027004632,3027004632 |
-dd 4199962284,4199962284 |
-dd 133494003,133494003 |
-dd 636152527,636152527 |
-dd 2942657994,2942657994 |
-dd 2390391540,2390391540 |
-dd 3920539207,3920539207 |
-dd 403179536,403179536 |
-dd 3585784431,3585784431 |
-dd 2289596656,2289596656 |
-dd 1864705354,1864705354 |
-dd 1915629148,1915629148 |
-dd 605822008,605822008 |
-dd 4054230615,4054230615 |
-dd 3350508659,3350508659 |
-dd 1371981463,1371981463 |
-dd 602466507,602466507 |
-dd 2094914977,2094914977 |
-dd 2624877800,2624877800 |
-dd 555687742,555687742 |
-dd 3712699286,3712699286 |
-dd 3703422305,3703422305 |
-dd 2257292045,2257292045 |
-dd 2240449039,2240449039 |
-dd 2423288032,2423288032 |
-dd 1111375484,1111375484 |
-dd 3300242801,3300242801 |
-dd 2858837708,2858837708 |
-dd 3628615824,3628615824 |
-dd 84083462,84083462 |
-dd 32962295,32962295 |
-dd 302911004,302911004 |
-dd 2741068226,2741068226 |
-dd 1597322602,1597322602 |
-dd 4183250862,4183250862 |
-dd 3501832553,3501832553 |
-dd 2441512471,2441512471 |
-dd 1489093017,1489093017 |
-dd 656219450,656219450 |
-dd 3114180135,3114180135 |
-dd 954327513,954327513 |
-dd 335083755,335083755 |
-dd 3013122091,3013122091 |
-dd 856756514,856756514 |
-dd 3144247762,3144247762 |
-dd 1893325225,1893325225 |
-dd 2307821063,2307821063 |
-dd 2811532339,2811532339 |
-dd 3063651117,3063651117 |
-dd 572399164,572399164 |
-dd 2458355477,2458355477 |
-dd 552200649,552200649 |
-dd 1238290055,1238290055 |
-dd 4283782570,4283782570 |
-dd 2015897680,2015897680 |
-dd 2061492133,2061492133 |
-dd 2408352771,2408352771 |
-dd 4171342169,4171342169 |
-dd 2156497161,2156497161 |
-dd 386731290,386731290 |
-dd 3669999461,3669999461 |
-dd 837215959,837215959 |
-dd 3326231172,3326231172 |
-dd 3093850320,3093850320 |
-dd 3275833730,3275833730 |
-dd 2962856233,2962856233 |
-dd 1999449434,1999449434 |
-dd 286199582,286199582 |
-dd 3417354363,3417354363 |
-dd 4233385128,4233385128 |
-dd 3602627437,3602627437 |
-dd 974525996,974525996 |
-db 99,124,119,123,242,107,111,197 |
-db 48,1,103,43,254,215,171,118 |
-db 202,130,201,125,250,89,71,240 |
-db 173,212,162,175,156,164,114,192 |
-db 183,253,147,38,54,63,247,204 |
-db 52,165,229,241,113,216,49,21 |
-db 4,199,35,195,24,150,5,154 |
-db 7,18,128,226,235,39,178,117 |
-db 9,131,44,26,27,110,90,160 |
-db 82,59,214,179,41,227,47,132 |
-db 83,209,0,237,32,252,177,91 |
-db 106,203,190,57,74,76,88,207 |
-db 208,239,170,251,67,77,51,133 |
-db 69,249,2,127,80,60,159,168 |
-db 81,163,64,143,146,157,56,245 |
-db 188,182,218,33,16,255,243,210 |
-db 205,12,19,236,95,151,68,23 |
-db 196,167,126,61,100,93,25,115 |
-db 96,129,79,220,34,42,144,136 |
-db 70,238,184,20,222,94,11,219 |
-db 224,50,58,10,73,6,36,92 |
-db 194,211,172,98,145,149,228,121 |
-db 231,200,55,109,141,213,78,169 |
-db 108,86,244,234,101,122,174,8 |
-db 186,120,37,46,28,166,180,198 |
-db 232,221,116,31,75,189,139,138 |
-db 112,62,181,102,72,3,246,14 |
-db 97,53,87,185,134,193,29,158 |
-db 225,248,152,17,105,217,142,148 |
-db 155,30,135,233,206,85,40,223 |
-db 140,161,137,13,191,230,66,104 |
-db 65,153,45,15,176,84,187,22 |
-db 99,124,119,123,242,107,111,197 |
-db 48,1,103,43,254,215,171,118 |
-db 202,130,201,125,250,89,71,240 |
-db 173,212,162,175,156,164,114,192 |
-db 183,253,147,38,54,63,247,204 |
-db 52,165,229,241,113,216,49,21 |
-db 4,199,35,195,24,150,5,154 |
-db 7,18,128,226,235,39,178,117 |
-db 9,131,44,26,27,110,90,160 |
-db 82,59,214,179,41,227,47,132 |
-db 83,209,0,237,32,252,177,91 |
-db 106,203,190,57,74,76,88,207 |
-db 208,239,170,251,67,77,51,133 |
-db 69,249,2,127,80,60,159,168 |
-db 81,163,64,143,146,157,56,245 |
-db 188,182,218,33,16,255,243,210 |
-db 205,12,19,236,95,151,68,23 |
-db 196,167,126,61,100,93,25,115 |
-db 96,129,79,220,34,42,144,136 |
-db 70,238,184,20,222,94,11,219 |
-db 224,50,58,10,73,6,36,92 |
-db 194,211,172,98,145,149,228,121 |
-db 231,200,55,109,141,213,78,169 |
-db 108,86,244,234,101,122,174,8 |
-db 186,120,37,46,28,166,180,198 |
-db 232,221,116,31,75,189,139,138 |
-db 112,62,181,102,72,3,246,14 |
-db 97,53,87,185,134,193,29,158 |
-db 225,248,152,17,105,217,142,148 |
-db 155,30,135,233,206,85,40,223 |
-db 140,161,137,13,191,230,66,104 |
-db 65,153,45,15,176,84,187,22 |
-db 99,124,119,123,242,107,111,197 |
-db 48,1,103,43,254,215,171,118 |
-db 202,130,201,125,250,89,71,240 |
-db 173,212,162,175,156,164,114,192 |
-db 183,253,147,38,54,63,247,204 |
-db 52,165,229,241,113,216,49,21 |
-db 4,199,35,195,24,150,5,154 |
-db 7,18,128,226,235,39,178,117 |
-db 9,131,44,26,27,110,90,160 |
-db 82,59,214,179,41,227,47,132 |
-db 83,209,0,237,32,252,177,91 |
-db 106,203,190,57,74,76,88,207 |
-db 208,239,170,251,67,77,51,133 |
-db 69,249,2,127,80,60,159,168 |
-db 81,163,64,143,146,157,56,245 |
-db 188,182,218,33,16,255,243,210 |
-db 205,12,19,236,95,151,68,23 |
-db 196,167,126,61,100,93,25,115 |
-db 96,129,79,220,34,42,144,136 |
-db 70,238,184,20,222,94,11,219 |
-db 224,50,58,10,73,6,36,92 |
-db 194,211,172,98,145,149,228,121 |
-db 231,200,55,109,141,213,78,169 |
-db 108,86,244,234,101,122,174,8 |
-db 186,120,37,46,28,166,180,198 |
-db 232,221,116,31,75,189,139,138 |
-db 112,62,181,102,72,3,246,14 |
-db 97,53,87,185,134,193,29,158 |
-db 225,248,152,17,105,217,142,148 |
-db 155,30,135,233,206,85,40,223 |
-db 140,161,137,13,191,230,66,104 |
-db 65,153,45,15,176,84,187,22 |
-db 99,124,119,123,242,107,111,197 |
-db 48,1,103,43,254,215,171,118 |
-db 202,130,201,125,250,89,71,240 |
-db 173,212,162,175,156,164,114,192 |
-db 183,253,147,38,54,63,247,204 |
-db 52,165,229,241,113,216,49,21 |
-db 4,199,35,195,24,150,5,154 |
-db 7,18,128,226,235,39,178,117 |
-db 9,131,44,26,27,110,90,160 |
-db 82,59,214,179,41,227,47,132 |
-db 83,209,0,237,32,252,177,91 |
-db 106,203,190,57,74,76,88,207 |
-db 208,239,170,251,67,77,51,133 |
-db 69,249,2,127,80,60,159,168 |
-db 81,163,64,143,146,157,56,245 |
-db 188,182,218,33,16,255,243,210 |
-db 205,12,19,236,95,151,68,23 |
-db 196,167,126,61,100,93,25,115 |
-db 96,129,79,220,34,42,144,136 |
-db 70,238,184,20,222,94,11,219 |
-db 224,50,58,10,73,6,36,92 |
-db 194,211,172,98,145,149,228,121 |
-db 231,200,55,109,141,213,78,169 |
-db 108,86,244,234,101,122,174,8 |
-db 186,120,37,46,28,166,180,198 |
-db 232,221,116,31,75,189,139,138 |
-db 112,62,181,102,72,3,246,14 |
-db 97,53,87,185,134,193,29,158 |
-db 225,248,152,17,105,217,142,148 |
-db 155,30,135,233,206,85,40,223 |
-db 140,161,137,13,191,230,66,104 |
-db 65,153,45,15,176,84,187,22 |
-dd 1,2,4,8 |
-dd 16,32,64,128 |
-dd 27,54,0,0 |
-dd 0,0,0,0 |
-global _asm_AES_encrypt |
-align 16 |
-_asm_AES_encrypt: |
-L$_asm_AES_encrypt_begin: |
- push ebp |
- push ebx |
- push esi |
- push edi |
- mov esi,DWORD [20+esp] |
- mov edi,DWORD [28+esp] |
- mov eax,esp |
- sub esp,36 |
- and esp,-64 |
- lea ebx,[edi-127] |
- sub ebx,esp |
- neg ebx |
- and ebx,960 |
- sub esp,ebx |
- add esp,4 |
- mov DWORD [28+esp],eax |
- call L$004pic_point |
-L$004pic_point: |
- pop ebp |
- lea eax,[_OPENSSL_ia32cap_P] |
- lea ebp,[(L$AES_Te-L$004pic_point)+ebp] |
- lea ebx,[764+esp] |
- sub ebx,ebp |
- and ebx,768 |
- lea ebp,[2176+ebx*1+ebp] |
- bt DWORD [eax],25 |
- jnc NEAR L$005x86 |
- movq mm0,[esi] |
- movq mm4,[8+esi] |
- call __sse_AES_encrypt_compact |
- mov esp,DWORD [28+esp] |
- mov esi,DWORD [24+esp] |
- movq [esi],mm0 |
- movq [8+esi],mm4 |
- emms |
- pop edi |
- pop esi |
- pop ebx |
- pop ebp |
- ret |
-align 16 |
-L$005x86: |
- mov DWORD [24+esp],ebp |
- mov eax,DWORD [esi] |
- mov ebx,DWORD [4+esi] |
- mov ecx,DWORD [8+esi] |
- mov edx,DWORD [12+esi] |
- call __x86_AES_encrypt_compact |
- mov esp,DWORD [28+esp] |
- mov esi,DWORD [24+esp] |
- mov DWORD [esi],eax |
- mov DWORD [4+esi],ebx |
- mov DWORD [8+esi],ecx |
- mov DWORD [12+esi],edx |
- pop edi |
- pop esi |
- pop ebx |
- pop ebp |
- ret |
-align 16 |
-__x86_AES_decrypt_compact: |
- mov DWORD [20+esp],edi |
- xor eax,DWORD [edi] |
- xor ebx,DWORD [4+edi] |
- xor ecx,DWORD [8+edi] |
- xor edx,DWORD [12+edi] |
- mov esi,DWORD [240+edi] |
- lea esi,[esi*1+esi-2] |
- lea esi,[esi*8+edi] |
- mov DWORD [24+esp],esi |
- mov edi,DWORD [ebp-128] |
- mov esi,DWORD [ebp-96] |
- mov edi,DWORD [ebp-64] |
- mov esi,DWORD [ebp-32] |
- mov edi,DWORD [ebp] |
- mov esi,DWORD [32+ebp] |
- mov edi,DWORD [64+ebp] |
- mov esi,DWORD [96+ebp] |
-align 16 |
-L$006loop: |
- mov esi,eax |
- and esi,255 |
- movzx esi,BYTE [esi*1+ebp-128] |
- movzx edi,dh |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,8 |
- xor esi,edi |
- mov edi,ecx |
- shr edi,16 |
- and edi,255 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,16 |
- xor esi,edi |
- mov edi,ebx |
- shr edi,24 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,24 |
- xor esi,edi |
- mov DWORD [4+esp],esi |
- mov esi,ebx |
- and esi,255 |
- movzx esi,BYTE [esi*1+ebp-128] |
- movzx edi,ah |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,8 |
- xor esi,edi |
- mov edi,edx |
- shr edi,16 |
- and edi,255 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,16 |
- xor esi,edi |
- mov edi,ecx |
- shr edi,24 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,24 |
- xor esi,edi |
- mov DWORD [8+esp],esi |
- mov esi,ecx |
- and esi,255 |
- movzx esi,BYTE [esi*1+ebp-128] |
- movzx edi,bh |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,8 |
- xor esi,edi |
- mov edi,eax |
- shr edi,16 |
- and edi,255 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,16 |
- xor esi,edi |
- mov edi,edx |
- shr edi,24 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,24 |
- xor esi,edi |
- and edx,255 |
- movzx edx,BYTE [edx*1+ebp-128] |
- movzx ecx,ch |
- movzx ecx,BYTE [ecx*1+ebp-128] |
- shl ecx,8 |
- xor edx,ecx |
- mov ecx,esi |
- shr ebx,16 |
- and ebx,255 |
- movzx ebx,BYTE [ebx*1+ebp-128] |
- shl ebx,16 |
- xor edx,ebx |
- shr eax,24 |
- movzx eax,BYTE [eax*1+ebp-128] |
- shl eax,24 |
- xor edx,eax |
- mov edi,2155905152 |
- and edi,ecx |
- mov esi,edi |
- shr edi,7 |
- lea eax,[ecx*1+ecx] |
- sub esi,edi |
- and eax,4278124286 |
- and esi,454761243 |
- xor eax,esi |
- mov edi,2155905152 |
- and edi,eax |
- mov esi,edi |
- shr edi,7 |
- lea ebx,[eax*1+eax] |
- sub esi,edi |
- and ebx,4278124286 |
- and esi,454761243 |
- xor eax,ecx |
- xor ebx,esi |
- mov edi,2155905152 |
- and edi,ebx |
- mov esi,edi |
- shr edi,7 |
- lea ebp,[ebx*1+ebx] |
- sub esi,edi |
- and ebp,4278124286 |
- and esi,454761243 |
- xor ebx,ecx |
- rol ecx,8 |
- xor ebp,esi |
- xor ecx,eax |
- xor eax,ebp |
- xor ecx,ebx |
- xor ebx,ebp |
- rol eax,24 |
- xor ecx,ebp |
- rol ebx,16 |
- xor ecx,eax |
- rol ebp,8 |
- xor ecx,ebx |
- mov eax,DWORD [4+esp] |
- xor ecx,ebp |
- mov DWORD [12+esp],ecx |
- mov edi,2155905152 |
- and edi,edx |
- mov esi,edi |
- shr edi,7 |
- lea ebx,[edx*1+edx] |
- sub esi,edi |
- and ebx,4278124286 |
- and esi,454761243 |
- xor ebx,esi |
- mov edi,2155905152 |
- and edi,ebx |
- mov esi,edi |
- shr edi,7 |
- lea ecx,[ebx*1+ebx] |
- sub esi,edi |
- and ecx,4278124286 |
- and esi,454761243 |
- xor ebx,edx |
- xor ecx,esi |
- mov edi,2155905152 |
- and edi,ecx |
- mov esi,edi |
- shr edi,7 |
- lea ebp,[ecx*1+ecx] |
- sub esi,edi |
- and ebp,4278124286 |
- and esi,454761243 |
- xor ecx,edx |
- rol edx,8 |
- xor ebp,esi |
- xor edx,ebx |
- xor ebx,ebp |
- xor edx,ecx |
- xor ecx,ebp |
- rol ebx,24 |
- xor edx,ebp |
- rol ecx,16 |
- xor edx,ebx |
- rol ebp,8 |
- xor edx,ecx |
- mov ebx,DWORD [8+esp] |
- xor edx,ebp |
- mov DWORD [16+esp],edx |
- mov edi,2155905152 |
- and edi,eax |
- mov esi,edi |
- shr edi,7 |
- lea ecx,[eax*1+eax] |
- sub esi,edi |
- and ecx,4278124286 |
- and esi,454761243 |
- xor ecx,esi |
- mov edi,2155905152 |
- and edi,ecx |
- mov esi,edi |
- shr edi,7 |
- lea edx,[ecx*1+ecx] |
- sub esi,edi |
- and edx,4278124286 |
- and esi,454761243 |
- xor ecx,eax |
- xor edx,esi |
- mov edi,2155905152 |
- and edi,edx |
- mov esi,edi |
- shr edi,7 |
- lea ebp,[edx*1+edx] |
- sub esi,edi |
- and ebp,4278124286 |
- and esi,454761243 |
- xor edx,eax |
- rol eax,8 |
- xor ebp,esi |
- xor eax,ecx |
- xor ecx,ebp |
- xor eax,edx |
- xor edx,ebp |
- rol ecx,24 |
- xor eax,ebp |
- rol edx,16 |
- xor eax,ecx |
- rol ebp,8 |
- xor eax,edx |
- xor eax,ebp |
- mov edi,2155905152 |
- and edi,ebx |
- mov esi,edi |
- shr edi,7 |
- lea ecx,[ebx*1+ebx] |
- sub esi,edi |
- and ecx,4278124286 |
- and esi,454761243 |
- xor ecx,esi |
- mov edi,2155905152 |
- and edi,ecx |
- mov esi,edi |
- shr edi,7 |
- lea edx,[ecx*1+ecx] |
- sub esi,edi |
- and edx,4278124286 |
- and esi,454761243 |
- xor ecx,ebx |
- xor edx,esi |
- mov edi,2155905152 |
- and edi,edx |
- mov esi,edi |
- shr edi,7 |
- lea ebp,[edx*1+edx] |
- sub esi,edi |
- and ebp,4278124286 |
- and esi,454761243 |
- xor edx,ebx |
- rol ebx,8 |
- xor ebp,esi |
- xor ebx,ecx |
- xor ecx,ebp |
- xor ebx,edx |
- xor edx,ebp |
- rol ecx,24 |
- xor ebx,ebp |
- rol edx,16 |
- xor ebx,ecx |
- rol ebp,8 |
- xor ebx,edx |
- mov ecx,DWORD [12+esp] |
- xor ebx,ebp |
- mov edx,DWORD [16+esp] |
- mov edi,DWORD [20+esp] |
- mov ebp,DWORD [28+esp] |
- add edi,16 |
- xor eax,DWORD [edi] |
- xor ebx,DWORD [4+edi] |
- xor ecx,DWORD [8+edi] |
- xor edx,DWORD [12+edi] |
- cmp edi,DWORD [24+esp] |
- mov DWORD [20+esp],edi |
- jb NEAR L$006loop |
- mov esi,eax |
- and esi,255 |
- movzx esi,BYTE [esi*1+ebp-128] |
- movzx edi,dh |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,8 |
- xor esi,edi |
- mov edi,ecx |
- shr edi,16 |
- and edi,255 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,16 |
- xor esi,edi |
- mov edi,ebx |
- shr edi,24 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,24 |
- xor esi,edi |
- mov DWORD [4+esp],esi |
- mov esi,ebx |
- and esi,255 |
- movzx esi,BYTE [esi*1+ebp-128] |
- movzx edi,ah |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,8 |
- xor esi,edi |
- mov edi,edx |
- shr edi,16 |
- and edi,255 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,16 |
- xor esi,edi |
- mov edi,ecx |
- shr edi,24 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,24 |
- xor esi,edi |
- mov DWORD [8+esp],esi |
- mov esi,ecx |
- and esi,255 |
- movzx esi,BYTE [esi*1+ebp-128] |
- movzx edi,bh |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,8 |
- xor esi,edi |
- mov edi,eax |
- shr edi,16 |
- and edi,255 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,16 |
- xor esi,edi |
- mov edi,edx |
- shr edi,24 |
- movzx edi,BYTE [edi*1+ebp-128] |
- shl edi,24 |
- xor esi,edi |
- mov edi,DWORD [20+esp] |
- and edx,255 |
- movzx edx,BYTE [edx*1+ebp-128] |
- movzx ecx,ch |
- movzx ecx,BYTE [ecx*1+ebp-128] |
- shl ecx,8 |
- xor edx,ecx |
- mov ecx,esi |
- shr ebx,16 |
- and ebx,255 |
- movzx ebx,BYTE [ebx*1+ebp-128] |
- shl ebx,16 |
- xor edx,ebx |
- mov ebx,DWORD [8+esp] |
- shr eax,24 |
- movzx eax,BYTE [eax*1+ebp-128] |
- shl eax,24 |
- xor edx,eax |
- mov eax,DWORD [4+esp] |
- xor eax,DWORD [16+edi] |
- xor ebx,DWORD [20+edi] |
- xor ecx,DWORD [24+edi] |
- xor edx,DWORD [28+edi] |
- ret |
-align 16 |
-__sse_AES_decrypt_compact: |
- pxor mm0,[edi] |
- pxor mm4,[8+edi] |
- mov esi,DWORD [240+edi] |
- lea esi,[esi*1+esi-2] |
- lea esi,[esi*8+edi] |
- mov DWORD [24+esp],esi |
- mov eax,454761243 |
- mov DWORD [8+esp],eax |
- mov DWORD [12+esp],eax |
- mov eax,DWORD [ebp-128] |
- mov ebx,DWORD [ebp-96] |
- mov ecx,DWORD [ebp-64] |
- mov edx,DWORD [ebp-32] |
- mov eax,DWORD [ebp] |
- mov ebx,DWORD [32+ebp] |
- mov ecx,DWORD [64+ebp] |
- mov edx,DWORD [96+ebp] |
-align 16 |
-L$007loop: |
- pshufw mm1,mm0,12 |
- pshufw mm5,mm4,9 |
- movd eax,mm1 |
- movd ebx,mm5 |
- mov DWORD [20+esp],edi |
- movzx esi,al |
- movzx edx,ah |
- pshufw mm2,mm0,6 |
- movzx ecx,BYTE [esi*1+ebp-128] |
- movzx edi,bl |
- movzx edx,BYTE [edx*1+ebp-128] |
- shr eax,16 |
- shl edx,8 |
- movzx esi,BYTE [edi*1+ebp-128] |
- movzx edi,bh |
- shl esi,16 |
- pshufw mm6,mm4,3 |
- or ecx,esi |
- movzx esi,BYTE [edi*1+ebp-128] |
- movzx edi,ah |
- shl esi,24 |
- shr ebx,16 |
- or edx,esi |
- movzx esi,BYTE [edi*1+ebp-128] |
- movzx edi,bh |
- shl esi,24 |
- or ecx,esi |
- movzx esi,BYTE [edi*1+ebp-128] |
- movzx edi,al |
- shl esi,8 |
- movd eax,mm2 |
- or ecx,esi |
- movzx esi,BYTE [edi*1+ebp-128] |
- movzx edi,bl |
- shl esi,16 |
- movd ebx,mm6 |
- movd mm0,ecx |
- movzx ecx,BYTE [edi*1+ebp-128] |
- movzx edi,al |
- or ecx,esi |
- movzx esi,BYTE [edi*1+ebp-128] |
- movzx edi,bl |
- or edx,esi |
- movzx esi,BYTE [edi*1+ebp-128] |
- movzx edi,ah |
- shl esi,16 |
- shr eax,16 |
- or edx,esi |
- movzx esi,BYTE [edi*1+ebp-128] |
- movzx edi,bh |
- shr ebx,16 |
- shl esi,8 |
- movd mm1,edx |
- movzx edx,BYTE [edi*1+ebp-128] |
- movzx edi,bh |
- shl edx,24 |
- and ebx,255 |
- or edx,esi |
- punpckldq mm0,mm1 |
- movzx esi,BYTE [edi*1+ebp-128] |
- movzx edi,al |
- shl esi,8 |
- movzx eax,ah |
- movzx ebx,BYTE [ebx*1+ebp-128] |
- or ecx,esi |
- movzx esi,BYTE [edi*1+ebp-128] |
- or edx,ebx |
- shl esi,16 |
- movzx eax,BYTE [eax*1+ebp-128] |
- or edx,esi |
- shl eax,24 |
- or ecx,eax |
- mov edi,DWORD [20+esp] |
- movd mm4,edx |
- movd mm5,ecx |
- punpckldq mm4,mm5 |
- add edi,16 |
- cmp edi,DWORD [24+esp] |
- ja NEAR L$008out |
- movq mm3,mm0 |
- movq mm7,mm4 |
- pshufw mm2,mm0,228 |
- pshufw mm6,mm4,228 |
- movq mm1,mm0 |
- movq mm5,mm4 |
- pshufw mm0,mm0,177 |
- pshufw mm4,mm4,177 |
- pslld mm2,8 |
- pslld mm6,8 |
- psrld mm3,8 |
- psrld mm7,8 |
- pxor mm0,mm2 |
- pxor mm4,mm6 |
- pxor mm0,mm3 |
- pxor mm4,mm7 |
- pslld mm2,16 |
- pslld mm6,16 |
- psrld mm3,16 |
- psrld mm7,16 |
- pxor mm0,mm2 |
- pxor mm4,mm6 |
- pxor mm0,mm3 |
- pxor mm4,mm7 |
- movq mm3,[8+esp] |
- pxor mm2,mm2 |
- pxor mm6,mm6 |
- pcmpgtb mm2,mm1 |
- pcmpgtb mm6,mm5 |
- pand mm2,mm3 |
- pand mm6,mm3 |
- paddb mm1,mm1 |
- paddb mm5,mm5 |
- pxor mm1,mm2 |
- pxor mm5,mm6 |
- movq mm3,mm1 |
- movq mm7,mm5 |
- movq mm2,mm1 |
- movq mm6,mm5 |
- pxor mm0,mm1 |
- pxor mm4,mm5 |
- pslld mm3,24 |
- pslld mm7,24 |
- psrld mm2,8 |
- psrld mm6,8 |
- pxor mm0,mm3 |
- pxor mm4,mm7 |
- pxor mm0,mm2 |
- pxor mm4,mm6 |
- movq mm2,[8+esp] |
- pxor mm3,mm3 |
- pxor mm7,mm7 |
- pcmpgtb mm3,mm1 |
- pcmpgtb mm7,mm5 |
- pand mm3,mm2 |
- pand mm7,mm2 |
- paddb mm1,mm1 |
- paddb mm5,mm5 |
- pxor mm1,mm3 |
- pxor mm5,mm7 |
- pshufw mm3,mm1,177 |
- pshufw mm7,mm5,177 |
- pxor mm0,mm1 |
- pxor mm4,mm5 |
- pxor mm0,mm3 |
- pxor mm4,mm7 |
- pxor mm3,mm3 |
- pxor mm7,mm7 |
- pcmpgtb mm3,mm1 |
- pcmpgtb mm7,mm5 |
- pand mm3,mm2 |
- pand mm7,mm2 |
- paddb mm1,mm1 |
- paddb mm5,mm5 |
- pxor mm1,mm3 |
- pxor mm5,mm7 |
- pxor mm0,mm1 |
- pxor mm4,mm5 |
- movq mm3,mm1 |
- movq mm7,mm5 |
- pshufw mm2,mm1,177 |
- pshufw mm6,mm5,177 |
- pxor mm0,mm2 |
- pxor mm4,mm6 |
- pslld mm1,8 |
- pslld mm5,8 |
- psrld mm3,8 |
- psrld mm7,8 |
- movq mm2,[edi] |
- movq mm6,[8+edi] |
- pxor mm0,mm1 |
- pxor mm4,mm5 |
- pxor mm0,mm3 |
- pxor mm4,mm7 |
- mov eax,DWORD [ebp-128] |
- pslld mm1,16 |
- pslld mm5,16 |
- mov ebx,DWORD [ebp-64] |
- psrld mm3,16 |
- psrld mm7,16 |
- mov ecx,DWORD [ebp] |
- pxor mm0,mm1 |
- pxor mm4,mm5 |
- mov edx,DWORD [64+ebp] |
- pxor mm0,mm3 |
- pxor mm4,mm7 |
- pxor mm0,mm2 |
- pxor mm4,mm6 |
- jmp NEAR L$007loop |
-align 16 |
-L$008out: |
- pxor mm0,[edi] |
- pxor mm4,[8+edi] |
- ret |
-align 16 |
-__x86_AES_decrypt: |
- mov DWORD [20+esp],edi |
- xor eax,DWORD [edi] |
- xor ebx,DWORD [4+edi] |
- xor ecx,DWORD [8+edi] |
- xor edx,DWORD [12+edi] |
- mov esi,DWORD [240+edi] |
- lea esi,[esi*1+esi-2] |
- lea esi,[esi*8+edi] |
- mov DWORD [24+esp],esi |
-align 16 |
-L$009loop: |
- mov esi,eax |
- and esi,255 |
- mov esi,DWORD [esi*8+ebp] |
- movzx edi,dh |
- xor esi,DWORD [3+edi*8+ebp] |
- mov edi,ecx |
- shr edi,16 |
- and edi,255 |
- xor esi,DWORD [2+edi*8+ebp] |
- mov edi,ebx |
- shr edi,24 |
- xor esi,DWORD [1+edi*8+ebp] |
- mov DWORD [4+esp],esi |
- mov esi,ebx |
- and esi,255 |
- mov esi,DWORD [esi*8+ebp] |
- movzx edi,ah |
- xor esi,DWORD [3+edi*8+ebp] |
- mov edi,edx |
- shr edi,16 |
- and edi,255 |
- xor esi,DWORD [2+edi*8+ebp] |
- mov edi,ecx |
- shr edi,24 |
- xor esi,DWORD [1+edi*8+ebp] |
- mov DWORD [8+esp],esi |
- mov esi,ecx |
- and esi,255 |
- mov esi,DWORD [esi*8+ebp] |
- movzx edi,bh |
- xor esi,DWORD [3+edi*8+ebp] |
- mov edi,eax |
- shr edi,16 |
- and edi,255 |
- xor esi,DWORD [2+edi*8+ebp] |
- mov edi,edx |
- shr edi,24 |
- xor esi,DWORD [1+edi*8+ebp] |
- mov edi,DWORD [20+esp] |
- and edx,255 |
- mov edx,DWORD [edx*8+ebp] |
- movzx ecx,ch |
- xor edx,DWORD [3+ecx*8+ebp] |
- mov ecx,esi |
- shr ebx,16 |
- and ebx,255 |
- xor edx,DWORD [2+ebx*8+ebp] |
- mov ebx,DWORD [8+esp] |
- shr eax,24 |
- xor edx,DWORD [1+eax*8+ebp] |
- mov eax,DWORD [4+esp] |
- add edi,16 |
- xor eax,DWORD [edi] |
- xor ebx,DWORD [4+edi] |
- xor ecx,DWORD [8+edi] |
- xor edx,DWORD [12+edi] |
- cmp edi,DWORD [24+esp] |
- mov DWORD [20+esp],edi |
- jb NEAR L$009loop |
- lea ebp,[2176+ebp] |
- mov edi,DWORD [ebp-128] |
- mov esi,DWORD [ebp-96] |
- mov edi,DWORD [ebp-64] |
- mov esi,DWORD [ebp-32] |
- mov edi,DWORD [ebp] |
- mov esi,DWORD [32+ebp] |
- mov edi,DWORD [64+ebp] |
- mov esi,DWORD [96+ebp] |
- lea ebp,[ebp-128] |
- mov esi,eax |
- and esi,255 |
- movzx esi,BYTE [esi*1+ebp] |
- movzx edi,dh |
- movzx edi,BYTE [edi*1+ebp] |
- shl edi,8 |
- xor esi,edi |
- mov edi,ecx |
- shr edi,16 |
- and edi,255 |
- movzx edi,BYTE [edi*1+ebp] |
- shl edi,16 |
- xor esi,edi |
- mov edi,ebx |
- shr edi,24 |
- movzx edi,BYTE [edi*1+ebp] |
- shl edi,24 |
- xor esi,edi |
- mov DWORD [4+esp],esi |
- mov esi,ebx |
- and esi,255 |
- movzx esi,BYTE [esi*1+ebp] |
- movzx edi,ah |
- movzx edi,BYTE [edi*1+ebp] |
- shl edi,8 |
- xor esi,edi |
- mov edi,edx |
- shr edi,16 |
- and edi,255 |
- movzx edi,BYTE [edi*1+ebp] |
- shl edi,16 |
- xor esi,edi |
- mov edi,ecx |
- shr edi,24 |
- movzx edi,BYTE [edi*1+ebp] |
- shl edi,24 |
- xor esi,edi |
- mov DWORD [8+esp],esi |
- mov esi,ecx |
- and esi,255 |
- movzx esi,BYTE [esi*1+ebp] |
- movzx edi,bh |
- movzx edi,BYTE [edi*1+ebp] |
- shl edi,8 |
- xor esi,edi |
- mov edi,eax |
- shr edi,16 |
- and edi,255 |
- movzx edi,BYTE [edi*1+ebp] |
- shl edi,16 |
- xor esi,edi |
- mov edi,edx |
- shr edi,24 |
- movzx edi,BYTE [edi*1+ebp] |
- shl edi,24 |
- xor esi,edi |
- mov edi,DWORD [20+esp] |
- and edx,255 |
- movzx edx,BYTE [edx*1+ebp] |
- movzx ecx,ch |
- movzx ecx,BYTE [ecx*1+ebp] |
- shl ecx,8 |
- xor edx,ecx |
- mov ecx,esi |
- shr ebx,16 |
- and ebx,255 |
- movzx ebx,BYTE [ebx*1+ebp] |
- shl ebx,16 |
- xor edx,ebx |
- mov ebx,DWORD [8+esp] |
- shr eax,24 |
- movzx eax,BYTE [eax*1+ebp] |
- shl eax,24 |
- xor edx,eax |
- mov eax,DWORD [4+esp] |
- lea ebp,[ebp-2048] |
- add edi,16 |
- xor eax,DWORD [edi] |
- xor ebx,DWORD [4+edi] |
- xor ecx,DWORD [8+edi] |
- xor edx,DWORD [12+edi] |
- ret |
-align 64 |
-L$AES_Td: |
-dd 1353184337,1353184337 |
-dd 1399144830,1399144830 |
-dd 3282310938,3282310938 |
-dd 2522752826,2522752826 |
-dd 3412831035,3412831035 |
-dd 4047871263,4047871263 |
-dd 2874735276,2874735276 |
-dd 2466505547,2466505547 |
-dd 1442459680,1442459680 |
-dd 4134368941,4134368941 |
-dd 2440481928,2440481928 |
-dd 625738485,625738485 |
-dd 4242007375,4242007375 |
-dd 3620416197,3620416197 |
-dd 2151953702,2151953702 |
-dd 2409849525,2409849525 |
-dd 1230680542,1230680542 |
-dd 1729870373,1729870373 |
-dd 2551114309,2551114309 |
-dd 3787521629,3787521629 |
-dd 41234371,41234371 |
-dd 317738113,317738113 |
-dd 2744600205,2744600205 |
-dd 3338261355,3338261355 |
-dd 3881799427,3881799427 |
-dd 2510066197,2510066197 |
-dd 3950669247,3950669247 |
-dd 3663286933,3663286933 |
-dd 763608788,763608788 |
-dd 3542185048,3542185048 |
-dd 694804553,694804553 |
-dd 1154009486,1154009486 |
-dd 1787413109,1787413109 |
-dd 2021232372,2021232372 |
-dd 1799248025,1799248025 |
-dd 3715217703,3715217703 |
-dd 3058688446,3058688446 |
-dd 397248752,397248752 |
-dd 1722556617,1722556617 |
-dd 3023752829,3023752829 |
-dd 407560035,407560035 |
-dd 2184256229,2184256229 |
-dd 1613975959,1613975959 |
-dd 1165972322,1165972322 |
-dd 3765920945,3765920945 |
-dd 2226023355,2226023355 |
-dd 480281086,480281086 |
-dd 2485848313,2485848313 |
-dd 1483229296,1483229296 |
-dd 436028815,436028815 |
-dd 2272059028,2272059028 |
-dd 3086515026,3086515026 |
-dd 601060267,601060267 |
-dd 3791801202,3791801202 |
-dd 1468997603,1468997603 |
-dd 715871590,715871590 |
-dd 120122290,120122290 |
-dd 63092015,63092015 |
-dd 2591802758,2591802758 |
-dd 2768779219,2768779219 |
-dd 4068943920,4068943920 |
-dd 2997206819,2997206819 |
-dd 3127509762,3127509762 |
-dd 1552029421,1552029421 |
-dd 723308426,723308426 |
-dd 2461301159,2461301159 |
-dd 4042393587,4042393587 |
-dd 2715969870,2715969870 |
-dd 3455375973,3455375973 |
-dd 3586000134,3586000134 |
-dd 526529745,526529745 |
-dd 2331944644,2331944644 |
-dd 2639474228,2639474228 |
-dd 2689987490,2689987490 |
-dd 853641733,853641733 |
-dd 1978398372,1978398372 |
-dd 971801355,971801355 |
-dd 2867814464,2867814464 |
-dd 111112542,111112542 |
-dd 1360031421,1360031421 |
-dd 4186579262,4186579262 |
-dd 1023860118,1023860118 |
-dd 2919579357,2919579357 |
-dd 1186850381,1186850381 |
-dd 3045938321,3045938321 |
-dd 90031217,90031217 |
-dd 1876166148,1876166148 |
-dd 4279586912,4279586912 |
-dd 620468249,620468249 |
-dd 2548678102,2548678102 |
-dd 3426959497,3426959497 |
-dd 2006899047,2006899047 |
-dd 3175278768,3175278768 |
-dd 2290845959,2290845959 |
-dd 945494503,945494503 |
-dd 3689859193,3689859193 |
-dd 1191869601,1191869601 |
-dd 3910091388,3910091388 |
-dd 3374220536,3374220536 |
-dd 0,0 |
-dd 2206629897,2206629897 |
-dd 1223502642,1223502642 |
-dd 2893025566,2893025566 |
-dd 1316117100,1316117100 |
-dd 4227796733,4227796733 |
-dd 1446544655,1446544655 |
-dd 517320253,517320253 |
-dd 658058550,658058550 |
-dd 1691946762,1691946762 |
-dd 564550760,564550760 |
-dd 3511966619,3511966619 |
-dd 976107044,976107044 |
-dd 2976320012,2976320012 |
-dd 266819475,266819475 |
-dd 3533106868,3533106868 |
-dd 2660342555,2660342555 |
-dd 1338359936,1338359936 |
-dd 2720062561,2720062561 |
-dd 1766553434,1766553434 |
-dd 370807324,370807324 |
-dd 179999714,179999714 |
-dd 3844776128,3844776128 |
-dd 1138762300,1138762300 |
-dd 488053522,488053522 |
-dd 185403662,185403662 |
-dd 2915535858,2915535858 |
-dd 3114841645,3114841645 |
-dd 3366526484,3366526484 |
-dd 2233069911,2233069911 |
-dd 1275557295,1275557295 |
-dd 3151862254,3151862254 |
-dd 4250959779,4250959779 |
-dd 2670068215,2670068215 |
-dd 3170202204,3170202204 |
-dd 3309004356,3309004356 |
-dd 880737115,880737115 |
-dd 1982415755,1982415755 |
-dd 3703972811,3703972811 |
-dd 1761406390,1761406390 |
-dd 1676797112,1676797112 |
-dd 3403428311,3403428311 |
-dd 277177154,277177154 |
-dd 1076008723,1076008723 |
-dd 538035844,538035844 |
-dd 2099530373,2099530373 |
-dd 4164795346,4164795346 |
-dd 288553390,288553390 |
-dd 1839278535,1839278535 |
-dd 1261411869,1261411869 |
-dd 4080055004,4080055004 |
-dd 3964831245,3964831245 |
-dd 3504587127,3504587127 |
-dd 1813426987,1813426987 |
-dd 2579067049,2579067049 |
-dd 4199060497,4199060497 |
-dd 577038663,577038663 |
-dd 3297574056,3297574056 |
-dd 440397984,440397984 |
-dd 3626794326,3626794326 |
-dd 4019204898,4019204898 |
-dd 3343796615,3343796615 |
-dd 3251714265,3251714265 |
-dd 4272081548,4272081548 |
-dd 906744984,906744984 |
-dd 3481400742,3481400742 |
-dd 685669029,685669029 |
-dd 646887386,646887386 |
-dd 2764025151,2764025151 |
-dd 3835509292,3835509292 |
-dd 227702864,227702864 |
-dd 2613862250,2613862250 |
-dd 1648787028,1648787028 |
-dd 3256061430,3256061430 |
-dd 3904428176,3904428176 |
-dd 1593260334,1593260334 |
-dd 4121936770,4121936770 |
-dd 3196083615,3196083615 |
-dd 2090061929,2090061929 |
-dd 2838353263,2838353263 |
-dd 3004310991,3004310991 |
-dd 999926984,999926984 |
-dd 2809993232,2809993232 |
-dd 1852021992,1852021992 |
-dd 2075868123,2075868123 |
-dd 158869197,158869197 |
-dd 4095236462,4095236462 |
-dd 28809964,28809964 |
-dd 2828685187,2828685187 |
-dd 1701746150,1701746150 |
-dd 2129067946,2129067946 |
-dd 147831841,147831841 |
-dd 3873969647,3873969647 |
-dd 3650873274,3650873274 |
-dd 3459673930,3459673930 |
-dd 3557400554,3557400554 |
-dd 3598495785,3598495785 |
-dd 2947720241,2947720241 |
-dd 824393514,824393514 |
-dd 815048134,815048134 |
-dd 3227951669,3227951669 |
-dd 935087732,935087732 |
-dd 2798289660,2798289660 |
-dd 2966458592,2966458592 |
-dd 366520115,366520115 |
-dd 1251476721,1251476721 |
-dd 4158319681,4158319681 |
-dd 240176511,240176511 |
-dd 804688151,804688151 |
-dd 2379631990,2379631990 |
-dd 1303441219,1303441219 |
-dd 1414376140,1414376140 |
-dd 3741619940,3741619940 |
-dd 3820343710,3820343710 |
-dd 461924940,461924940 |
-dd 3089050817,3089050817 |
-dd 2136040774,2136040774 |
-dd 82468509,82468509 |
-dd 1563790337,1563790337 |
-dd 1937016826,1937016826 |
-dd 776014843,776014843 |
-dd 1511876531,1511876531 |
-dd 1389550482,1389550482 |
-dd 861278441,861278441 |
-dd 323475053,323475053 |
-dd 2355222426,2355222426 |
-dd 2047648055,2047648055 |
-dd 2383738969,2383738969 |
-dd 2302415851,2302415851 |
-dd 3995576782,3995576782 |
-dd 902390199,902390199 |
-dd 3991215329,3991215329 |
-dd 1018251130,1018251130 |
-dd 1507840668,1507840668 |
-dd 1064563285,1064563285 |
-dd 2043548696,2043548696 |
-dd 3208103795,3208103795 |
-dd 3939366739,3939366739 |
-dd 1537932639,1537932639 |
-dd 342834655,342834655 |
-dd 2262516856,2262516856 |
-dd 2180231114,2180231114 |
-dd 1053059257,1053059257 |
-dd 741614648,741614648 |
-dd 1598071746,1598071746 |
-dd 1925389590,1925389590 |
-dd 203809468,203809468 |
-dd 2336832552,2336832552 |
-dd 1100287487,1100287487 |
-dd 1895934009,1895934009 |
-dd 3736275976,3736275976 |
-dd 2632234200,2632234200 |
-dd 2428589668,2428589668 |
-dd 1636092795,1636092795 |
-dd 1890988757,1890988757 |
-dd 1952214088,1952214088 |
-dd 1113045200,1113045200 |
-db 82,9,106,213,48,54,165,56 |
-db 191,64,163,158,129,243,215,251 |
-db 124,227,57,130,155,47,255,135 |
-db 52,142,67,68,196,222,233,203 |
-db 84,123,148,50,166,194,35,61 |
-db 238,76,149,11,66,250,195,78 |
-db 8,46,161,102,40,217,36,178 |
-db 118,91,162,73,109,139,209,37 |
-db 114,248,246,100,134,104,152,22 |
-db 212,164,92,204,93,101,182,146 |
-db 108,112,72,80,253,237,185,218 |
-db 94,21,70,87,167,141,157,132 |
-db 144,216,171,0,140,188,211,10 |
-db 247,228,88,5,184,179,69,6 |
-db 208,44,30,143,202,63,15,2 |
-db 193,175,189,3,1,19,138,107 |
-db 58,145,17,65,79,103,220,234 |
-db 151,242,207,206,240,180,230,115 |
-db 150,172,116,34,231,173,53,133 |
-db 226,249,55,232,28,117,223,110 |
-db 71,241,26,113,29,41,197,137 |
-db 111,183,98,14,170,24,190,27 |
-db 252,86,62,75,198,210,121,32 |
-db 154,219,192,254,120,205,90,244 |
-db 31,221,168,51,136,7,199,49 |
-db 177,18,16,89,39,128,236,95 |
-db 96,81,127,169,25,181,74,13 |
-db 45,229,122,159,147,201,156,239 |
-db 160,224,59,77,174,42,245,176 |
-db 200,235,187,60,131,83,153,97 |
-db 23,43,4,126,186,119,214,38 |
-db 225,105,20,99,85,33,12,125 |
-db 82,9,106,213,48,54,165,56 |
-db 191,64,163,158,129,243,215,251 |
-db 124,227,57,130,155,47,255,135 |
-db 52,142,67,68,196,222,233,203 |
-db 84,123,148,50,166,194,35,61 |
-db 238,76,149,11,66,250,195,78 |
-db 8,46,161,102,40,217,36,178 |
-db 118,91,162,73,109,139,209,37 |
-db 114,248,246,100,134,104,152,22 |
-db 212,164,92,204,93,101,182,146 |
-db 108,112,72,80,253,237,185,218 |
-db 94,21,70,87,167,141,157,132 |
-db 144,216,171,0,140,188,211,10 |
-db 247,228,88,5,184,179,69,6 |
-db 208,44,30,143,202,63,15,2 |
-db 193,175,189,3,1,19,138,107 |
-db 58,145,17,65,79,103,220,234 |
-db 151,242,207,206,240,180,230,115 |
-db 150,172,116,34,231,173,53,133 |
-db 226,249,55,232,28,117,223,110 |
-db 71,241,26,113,29,41,197,137 |
-db 111,183,98,14,170,24,190,27 |
-db 252,86,62,75,198,210,121,32 |
-db 154,219,192,254,120,205,90,244 |
-db 31,221,168,51,136,7,199,49 |
-db 177,18,16,89,39,128,236,95 |
-db 96,81,127,169,25,181,74,13 |
-db 45,229,122,159,147,201,156,239 |
-db 160,224,59,77,174,42,245,176 |
-db 200,235,187,60,131,83,153,97 |
-db 23,43,4,126,186,119,214,38 |
-db 225,105,20,99,85,33,12,125 |
-db 82,9,106,213,48,54,165,56 |
-db 191,64,163,158,129,243,215,251 |
-db 124,227,57,130,155,47,255,135 |
-db 52,142,67,68,196,222,233,203 |
-db 84,123,148,50,166,194,35,61 |
-db 238,76,149,11,66,250,195,78 |
-db 8,46,161,102,40,217,36,178 |
-db 118,91,162,73,109,139,209,37 |
-db 114,248,246,100,134,104,152,22 |
-db 212,164,92,204,93,101,182,146 |
-db 108,112,72,80,253,237,185,218 |
-db 94,21,70,87,167,141,157,132 |
-db 144,216,171,0,140,188,211,10 |
-db 247,228,88,5,184,179,69,6 |
-db 208,44,30,143,202,63,15,2 |
-db 193,175,189,3,1,19,138,107 |
-db 58,145,17,65,79,103,220,234 |
-db 151,242,207,206,240,180,230,115 |
-db 150,172,116,34,231,173,53,133 |
-db 226,249,55,232,28,117,223,110 |
-db 71,241,26,113,29,41,197,137 |
-db 111,183,98,14,170,24,190,27 |
-db 252,86,62,75,198,210,121,32 |
-db 154,219,192,254,120,205,90,244 |
-db 31,221,168,51,136,7,199,49 |
-db 177,18,16,89,39,128,236,95 |
-db 96,81,127,169,25,181,74,13 |
-db 45,229,122,159,147,201,156,239 |
-db 160,224,59,77,174,42,245,176 |
-db 200,235,187,60,131,83,153,97 |
-db 23,43,4,126,186,119,214,38 |
-db 225,105,20,99,85,33,12,125 |
-db 82,9,106,213,48,54,165,56 |
-db 191,64,163,158,129,243,215,251 |
-db 124,227,57,130,155,47,255,135 |
-db 52,142,67,68,196,222,233,203 |
-db 84,123,148,50,166,194,35,61 |
-db 238,76,149,11,66,250,195,78 |
-db 8,46,161,102,40,217,36,178 |
-db 118,91,162,73,109,139,209,37 |
-db 114,248,246,100,134,104,152,22 |
-db 212,164,92,204,93,101,182,146 |
-db 108,112,72,80,253,237,185,218 |
-db 94,21,70,87,167,141,157,132 |
-db 144,216,171,0,140,188,211,10 |
-db 247,228,88,5,184,179,69,6 |
-db 208,44,30,143,202,63,15,2 |
-db 193,175,189,3,1,19,138,107 |
-db 58,145,17,65,79,103,220,234 |
-db 151,242,207,206,240,180,230,115 |
-db 150,172,116,34,231,173,53,133 |
-db 226,249,55,232,28,117,223,110 |
-db 71,241,26,113,29,41,197,137 |
-db 111,183,98,14,170,24,190,27 |
-db 252,86,62,75,198,210,121,32 |
-db 154,219,192,254,120,205,90,244 |
-db 31,221,168,51,136,7,199,49 |
-db 177,18,16,89,39,128,236,95 |
-db 96,81,127,169,25,181,74,13 |
-db 45,229,122,159,147,201,156,239 |
-db 160,224,59,77,174,42,245,176 |
-db 200,235,187,60,131,83,153,97 |
-db 23,43,4,126,186,119,214,38 |
-db 225,105,20,99,85,33,12,125 |
-global _asm_AES_decrypt |
-align 16 |
-_asm_AES_decrypt: |
-L$_asm_AES_decrypt_begin: |
- push ebp |
- push ebx |
- push esi |
- push edi |
- mov esi,DWORD [20+esp] |
- mov edi,DWORD [28+esp] |
- mov eax,esp |
- sub esp,36 |
- and esp,-64 |
- lea ebx,[edi-127] |
- sub ebx,esp |
- neg ebx |
- and ebx,960 |
- sub esp,ebx |
- add esp,4 |
- mov DWORD [28+esp],eax |
- call L$010pic_point |
-L$010pic_point: |
- pop ebp |
- lea eax,[_OPENSSL_ia32cap_P] |
- lea ebp,[(L$AES_Td-L$010pic_point)+ebp] |
- lea ebx,[764+esp] |
- sub ebx,ebp |
- and ebx,768 |
- lea ebp,[2176+ebx*1+ebp] |
- bt DWORD [eax],25 |
- jnc NEAR L$011x86 |
- movq mm0,[esi] |
- movq mm4,[8+esi] |
- call __sse_AES_decrypt_compact |
- mov esp,DWORD [28+esp] |
- mov esi,DWORD [24+esp] |
- movq [esi],mm0 |
- movq [8+esi],mm4 |
- emms |
- pop edi |
- pop esi |
- pop ebx |
- pop ebp |
- ret |
-align 16 |
-L$011x86: |
- mov DWORD [24+esp],ebp |
- mov eax,DWORD [esi] |
- mov ebx,DWORD [4+esi] |
- mov ecx,DWORD [8+esi] |
- mov edx,DWORD [12+esi] |
- call __x86_AES_decrypt_compact |
- mov esp,DWORD [28+esp] |
- mov esi,DWORD [24+esp] |
- mov DWORD [esi],eax |
- mov DWORD [4+esi],ebx |
- mov DWORD [8+esi],ecx |
- mov DWORD [12+esi],edx |
- pop edi |
- pop esi |
- pop ebx |
- pop ebp |
- ret |
-global _asm_AES_cbc_encrypt |
-align 16 |
-_asm_AES_cbc_encrypt: |
-L$_asm_AES_cbc_encrypt_begin: |
- push ebp |
- push ebx |
- push esi |
- push edi |
- mov ecx,DWORD [28+esp] |
- cmp ecx,0 |
- je NEAR L$012drop_out |
- call L$013pic_point |
-L$013pic_point: |
- pop ebp |
- lea eax,[_OPENSSL_ia32cap_P] |
- cmp DWORD [40+esp],0 |
- lea ebp,[(L$AES_Te-L$013pic_point)+ebp] |
- jne NEAR L$014picked_te |
- lea ebp,[(L$AES_Td-L$AES_Te)+ebp] |
-L$014picked_te: |
- pushfd |
- cld |
- cmp ecx,512 |
- jb NEAR L$015slow_way |
- test ecx,15 |
- jnz NEAR L$015slow_way |
- bt DWORD [eax],28 |
- jc NEAR L$015slow_way |
- lea esi,[esp-324] |
- and esi,-64 |
- mov eax,ebp |
- lea ebx,[2304+ebp] |
- mov edx,esi |
- and eax,4095 |
- and ebx,4095 |
- and edx,4095 |
- cmp edx,ebx |
- jb NEAR L$016tbl_break_out |
- sub edx,ebx |
- sub esi,edx |
- jmp NEAR L$017tbl_ok |
-align 4 |
-L$016tbl_break_out: |
- sub edx,eax |
- and edx,4095 |
- add edx,384 |
- sub esi,edx |
-align 4 |
-L$017tbl_ok: |
- lea edx,[24+esp] |
- xchg esp,esi |
- add esp,4 |
- mov DWORD [24+esp],ebp |
- mov DWORD [28+esp],esi |
- mov eax,DWORD [edx] |
- mov ebx,DWORD [4+edx] |
- mov edi,DWORD [12+edx] |
- mov esi,DWORD [16+edx] |
- mov edx,DWORD [20+edx] |
- mov DWORD [32+esp],eax |
- mov DWORD [36+esp],ebx |
- mov DWORD [40+esp],ecx |
- mov DWORD [44+esp],edi |
- mov DWORD [48+esp],esi |
- mov DWORD [316+esp],0 |
- mov ebx,edi |
- mov ecx,61 |
- sub ebx,ebp |
- mov esi,edi |
- and ebx,4095 |
- lea edi,[76+esp] |
- cmp ebx,2304 |
- jb NEAR L$018do_copy |
- cmp ebx,3852 |
- jb NEAR L$019skip_copy |
-align 4 |
-L$018do_copy: |
- mov DWORD [44+esp],edi |
-dd 2784229001 |
-L$019skip_copy: |
- mov edi,16 |
-align 4 |
-L$020prefetch_tbl: |
- mov eax,DWORD [ebp] |
- mov ebx,DWORD [32+ebp] |
- mov ecx,DWORD [64+ebp] |
- mov esi,DWORD [96+ebp] |
- lea ebp,[128+ebp] |
- sub edi,1 |
- jnz NEAR L$020prefetch_tbl |
- sub ebp,2048 |
- mov esi,DWORD [32+esp] |
- mov edi,DWORD [48+esp] |
- cmp edx,0 |
- je NEAR L$021fast_decrypt |
- mov eax,DWORD [edi] |
- mov ebx,DWORD [4+edi] |
-align 16 |
-L$022fast_enc_loop: |
- mov ecx,DWORD [8+edi] |
- mov edx,DWORD [12+edi] |
- xor eax,DWORD [esi] |
- xor ebx,DWORD [4+esi] |
- xor ecx,DWORD [8+esi] |
- xor edx,DWORD [12+esi] |
- mov edi,DWORD [44+esp] |
- call __x86_AES_encrypt |
- mov esi,DWORD [32+esp] |
- mov edi,DWORD [36+esp] |
- mov DWORD [edi],eax |
- mov DWORD [4+edi],ebx |
- mov DWORD [8+edi],ecx |
- mov DWORD [12+edi],edx |
- lea esi,[16+esi] |
- mov ecx,DWORD [40+esp] |
- mov DWORD [32+esp],esi |
- lea edx,[16+edi] |
- mov DWORD [36+esp],edx |
- sub ecx,16 |
- mov DWORD [40+esp],ecx |
- jnz NEAR L$022fast_enc_loop |
- mov esi,DWORD [48+esp] |
- mov ecx,DWORD [8+edi] |
- mov edx,DWORD [12+edi] |
- mov DWORD [esi],eax |
- mov DWORD [4+esi],ebx |
- mov DWORD [8+esi],ecx |
- mov DWORD [12+esi],edx |
- cmp DWORD [316+esp],0 |
- mov edi,DWORD [44+esp] |
- je NEAR L$023skip_ezero |
- mov ecx,60 |
- xor eax,eax |
-align 4 |
-dd 2884892297 |
-L$023skip_ezero: |
- mov esp,DWORD [28+esp] |
- popfd |
-L$012drop_out: |
- pop edi |
- pop esi |
- pop ebx |
- pop ebp |
- ret |
- pushfd |
-align 16 |
-L$021fast_decrypt: |
- cmp esi,DWORD [36+esp] |
- je NEAR L$024fast_dec_in_place |
- mov DWORD [52+esp],edi |
-align 4 |
-align 16 |
-L$025fast_dec_loop: |
- mov eax,DWORD [esi] |
- mov ebx,DWORD [4+esi] |
- mov ecx,DWORD [8+esi] |
- mov edx,DWORD [12+esi] |
- mov edi,DWORD [44+esp] |
- call __x86_AES_decrypt |
- mov edi,DWORD [52+esp] |
- mov esi,DWORD [40+esp] |
- xor eax,DWORD [edi] |
- xor ebx,DWORD [4+edi] |
- xor ecx,DWORD [8+edi] |
- xor edx,DWORD [12+edi] |
- mov edi,DWORD [36+esp] |
- mov esi,DWORD [32+esp] |
- mov DWORD [edi],eax |
- mov DWORD [4+edi],ebx |
- mov DWORD [8+edi],ecx |
- mov DWORD [12+edi],edx |
- mov ecx,DWORD [40+esp] |
- mov DWORD [52+esp],esi |
- lea esi,[16+esi] |
- mov DWORD [32+esp],esi |
- lea edi,[16+edi] |
- mov DWORD [36+esp],edi |
- sub ecx,16 |
- mov DWORD [40+esp],ecx |
- jnz NEAR L$025fast_dec_loop |
- mov edi,DWORD [52+esp] |
- mov esi,DWORD [48+esp] |
- mov eax,DWORD [edi] |
- mov ebx,DWORD [4+edi] |
- mov ecx,DWORD [8+edi] |
- mov edx,DWORD [12+edi] |
- mov DWORD [esi],eax |
- mov DWORD [4+esi],ebx |
- mov DWORD [8+esi],ecx |
- mov DWORD [12+esi],edx |
- jmp NEAR L$026fast_dec_out |
-align 16 |
-L$024fast_dec_in_place: |
-L$027fast_dec_in_place_loop: |
- mov eax,DWORD [esi] |
- mov ebx,DWORD [4+esi] |
- mov ecx,DWORD [8+esi] |
- mov edx,DWORD [12+esi] |
- lea edi,[60+esp] |
- mov DWORD [edi],eax |
- mov DWORD [4+edi],ebx |
- mov DWORD [8+edi],ecx |
- mov DWORD [12+edi],edx |
- mov edi,DWORD [44+esp] |
- call __x86_AES_decrypt |
- mov edi,DWORD [48+esp] |
- mov esi,DWORD [36+esp] |
- xor eax,DWORD [edi] |
- xor ebx,DWORD [4+edi] |
- xor ecx,DWORD [8+edi] |
- xor edx,DWORD [12+edi] |
- mov DWORD [esi],eax |
- mov DWORD [4+esi],ebx |
- mov DWORD [8+esi],ecx |
- mov DWORD [12+esi],edx |
- lea esi,[16+esi] |
- mov DWORD [36+esp],esi |
- lea esi,[60+esp] |
- mov eax,DWORD [esi] |
- mov ebx,DWORD [4+esi] |
- mov ecx,DWORD [8+esi] |
- mov edx,DWORD [12+esi] |
- mov DWORD [edi],eax |
- mov DWORD [4+edi],ebx |
- mov DWORD [8+edi],ecx |
- mov DWORD [12+edi],edx |
- mov esi,DWORD [32+esp] |
- mov ecx,DWORD [40+esp] |
- lea esi,[16+esi] |
- mov DWORD [32+esp],esi |
- sub ecx,16 |
- mov DWORD [40+esp],ecx |
- jnz NEAR L$027fast_dec_in_place_loop |
-align 4 |
-L$026fast_dec_out: |
- cmp DWORD [316+esp],0 |
- mov edi,DWORD [44+esp] |
- je NEAR L$028skip_dzero |
- mov ecx,60 |
- xor eax,eax |
-align 4 |
-dd 2884892297 |
-L$028skip_dzero: |
- mov esp,DWORD [28+esp] |
- popfd |
- pop edi |
- pop esi |
- pop ebx |
- pop ebp |
- ret |
- pushfd |
-align 16 |
-L$015slow_way: |
- mov eax,DWORD [eax] |
- mov edi,DWORD [36+esp] |
- lea esi,[esp-80] |
- and esi,-64 |
- lea ebx,[edi-143] |
- sub ebx,esi |
- neg ebx |
- and ebx,960 |
- sub esi,ebx |
- lea ebx,[768+esi] |
- sub ebx,ebp |
- and ebx,768 |
- lea ebp,[2176+ebx*1+ebp] |
- lea edx,[24+esp] |
- xchg esp,esi |
- add esp,4 |
- mov DWORD [24+esp],ebp |
- mov DWORD [28+esp],esi |
- mov DWORD [52+esp],eax |
- mov eax,DWORD [edx] |
- mov ebx,DWORD [4+edx] |
- mov esi,DWORD [16+edx] |
- mov edx,DWORD [20+edx] |
- mov DWORD [32+esp],eax |
- mov DWORD [36+esp],ebx |
- mov DWORD [40+esp],ecx |
- mov DWORD [44+esp],edi |
- mov DWORD [48+esp],esi |
- mov edi,esi |
- mov esi,eax |
- cmp edx,0 |
- je NEAR L$029slow_decrypt |
- cmp ecx,16 |
- mov edx,ebx |
- jb NEAR L$030slow_enc_tail |
- bt DWORD [52+esp],25 |
- jnc NEAR L$031slow_enc_x86 |
- movq mm0,[edi] |
- movq mm4,[8+edi] |
-align 16 |
-L$032slow_enc_loop_sse: |
- pxor mm0,[esi] |
- pxor mm4,[8+esi] |
- mov edi,DWORD [44+esp] |
- call __sse_AES_encrypt_compact |
- mov esi,DWORD [32+esp] |
- mov edi,DWORD [36+esp] |
- mov ecx,DWORD [40+esp] |
- movq [edi],mm0 |
- movq [8+edi],mm4 |
- lea esi,[16+esi] |
- mov DWORD [32+esp],esi |
- lea edx,[16+edi] |
- mov DWORD [36+esp],edx |
- sub ecx,16 |
- cmp ecx,16 |
- mov DWORD [40+esp],ecx |
- jae NEAR L$032slow_enc_loop_sse |
- test ecx,15 |
- jnz NEAR L$030slow_enc_tail |
- mov esi,DWORD [48+esp] |
- movq [esi],mm0 |
- movq [8+esi],mm4 |
- emms |
- mov esp,DWORD [28+esp] |
- popfd |
- pop edi |
- pop esi |
- pop ebx |
- pop ebp |
- ret |
- pushfd |
-align 16 |
-L$031slow_enc_x86: |
- mov eax,DWORD [edi] |
- mov ebx,DWORD [4+edi] |
-align 4 |
-L$033slow_enc_loop_x86: |
- mov ecx,DWORD [8+edi] |
- mov edx,DWORD [12+edi] |
- xor eax,DWORD [esi] |
- xor ebx,DWORD [4+esi] |
- xor ecx,DWORD [8+esi] |
- xor edx,DWORD [12+esi] |
- mov edi,DWORD [44+esp] |
- call __x86_AES_encrypt_compact |
- mov esi,DWORD [32+esp] |
- mov edi,DWORD [36+esp] |
- mov DWORD [edi],eax |
- mov DWORD [4+edi],ebx |
- mov DWORD [8+edi],ecx |
- mov DWORD [12+edi],edx |
- mov ecx,DWORD [40+esp] |
- lea esi,[16+esi] |
- mov DWORD [32+esp],esi |
- lea edx,[16+edi] |
- mov DWORD [36+esp],edx |
- sub ecx,16 |
- cmp ecx,16 |
- mov DWORD [40+esp],ecx |
- jae NEAR L$033slow_enc_loop_x86 |
- test ecx,15 |
- jnz NEAR L$030slow_enc_tail |
- mov esi,DWORD [48+esp] |
- mov ecx,DWORD [8+edi] |
- mov edx,DWORD [12+edi] |
- mov DWORD [esi],eax |
- mov DWORD [4+esi],ebx |
- mov DWORD [8+esi],ecx |
- mov DWORD [12+esi],edx |
- mov esp,DWORD [28+esp] |
- popfd |
- pop edi |
- pop esi |
- pop ebx |
- pop ebp |
- ret |
- pushfd |
-align 16 |
-L$030slow_enc_tail: |
- emms |
- mov edi,edx |
- mov ebx,16 |
- sub ebx,ecx |
- cmp edi,esi |
- je NEAR L$034enc_in_place |
-align 4 |
-dd 2767451785 |
- jmp NEAR L$035enc_skip_in_place |
-L$034enc_in_place: |
- lea edi,[ecx*1+edi] |
-L$035enc_skip_in_place: |
- mov ecx,ebx |
- xor eax,eax |
-align 4 |
-dd 2868115081 |
- mov edi,DWORD [48+esp] |
- mov esi,edx |
- mov eax,DWORD [edi] |
- mov ebx,DWORD [4+edi] |
- mov DWORD [40+esp],16 |
- jmp NEAR L$033slow_enc_loop_x86 |
-align 16 |
-L$029slow_decrypt: |
- bt DWORD [52+esp],25 |
- jnc NEAR L$036slow_dec_loop_x86 |
-align 4 |
-L$037slow_dec_loop_sse: |
- movq mm0,[esi] |
- movq mm4,[8+esi] |
- mov edi,DWORD [44+esp] |
- call __sse_AES_decrypt_compact |
- mov esi,DWORD [32+esp] |
- lea eax,[60+esp] |
- mov ebx,DWORD [36+esp] |
- mov ecx,DWORD [40+esp] |
- mov edi,DWORD [48+esp] |
- movq mm1,[esi] |
- movq mm5,[8+esi] |
- pxor mm0,[edi] |
- pxor mm4,[8+edi] |
- movq [edi],mm1 |
- movq [8+edi],mm5 |
- sub ecx,16 |
- jc NEAR L$038slow_dec_partial_sse |
- movq [ebx],mm0 |
- movq [8+ebx],mm4 |
- lea ebx,[16+ebx] |
- mov DWORD [36+esp],ebx |
- lea esi,[16+esi] |
- mov DWORD [32+esp],esi |
- mov DWORD [40+esp],ecx |
- jnz NEAR L$037slow_dec_loop_sse |
- emms |
- mov esp,DWORD [28+esp] |
- popfd |
- pop edi |
- pop esi |
- pop ebx |
- pop ebp |
- ret |
- pushfd |
-align 16 |
-L$038slow_dec_partial_sse: |
- movq [eax],mm0 |
- movq [8+eax],mm4 |
- emms |
- add ecx,16 |
- mov edi,ebx |
- mov esi,eax |
-align 4 |
-dd 2767451785 |
- mov esp,DWORD [28+esp] |
- popfd |
- pop edi |
- pop esi |
- pop ebx |
- pop ebp |
- ret |
- pushfd |
-align 16 |
-L$036slow_dec_loop_x86: |
- mov eax,DWORD [esi] |
- mov ebx,DWORD [4+esi] |
- mov ecx,DWORD [8+esi] |
- mov edx,DWORD [12+esi] |
- lea edi,[60+esp] |
- mov DWORD [edi],eax |
- mov DWORD [4+edi],ebx |
- mov DWORD [8+edi],ecx |
- mov DWORD [12+edi],edx |
- mov edi,DWORD [44+esp] |
- call __x86_AES_decrypt_compact |
- mov edi,DWORD [48+esp] |
- mov esi,DWORD [40+esp] |
- xor eax,DWORD [edi] |
- xor ebx,DWORD [4+edi] |
- xor ecx,DWORD [8+edi] |
- xor edx,DWORD [12+edi] |
- sub esi,16 |
- jc NEAR L$039slow_dec_partial_x86 |
- mov DWORD [40+esp],esi |
- mov esi,DWORD [36+esp] |
- mov DWORD [esi],eax |
- mov DWORD [4+esi],ebx |
- mov DWORD [8+esi],ecx |
- mov DWORD [12+esi],edx |
- lea esi,[16+esi] |
- mov DWORD [36+esp],esi |
- lea esi,[60+esp] |
- mov eax,DWORD [esi] |
- mov ebx,DWORD [4+esi] |
- mov ecx,DWORD [8+esi] |
- mov edx,DWORD [12+esi] |
- mov DWORD [edi],eax |
- mov DWORD [4+edi],ebx |
- mov DWORD [8+edi],ecx |
- mov DWORD [12+edi],edx |
- mov esi,DWORD [32+esp] |
- lea esi,[16+esi] |
- mov DWORD [32+esp],esi |
- jnz NEAR L$036slow_dec_loop_x86 |
- mov esp,DWORD [28+esp] |
- popfd |
- pop edi |
- pop esi |
- pop ebx |
- pop ebp |
- ret |
- pushfd |
-align 16 |
-L$039slow_dec_partial_x86: |
- lea esi,[60+esp] |
- mov DWORD [esi],eax |
- mov DWORD [4+esi],ebx |
- mov DWORD [8+esi],ecx |
- mov DWORD [12+esi],edx |
- mov esi,DWORD [32+esp] |
- mov eax,DWORD [esi] |
- mov ebx,DWORD [4+esi] |
- mov ecx,DWORD [8+esi] |
- mov edx,DWORD [12+esi] |
- mov DWORD [edi],eax |
- mov DWORD [4+edi],ebx |
- mov DWORD [8+edi],ecx |
- mov DWORD [12+edi],edx |
- mov ecx,DWORD [40+esp] |
- mov edi,DWORD [36+esp] |
- lea esi,[60+esp] |
-align 4 |
-dd 2767451785 |
- mov esp,DWORD [28+esp] |
- popfd |
- pop edi |
- pop esi |
- pop ebx |
- pop ebp |
- ret |
-align 16 |
-__x86_AES_set_encrypt_key: |
- push ebp |
- push ebx |
- push esi |
- push edi |
- mov esi,DWORD [24+esp] |
- mov edi,DWORD [32+esp] |
- test esi,-1 |
- jz NEAR L$040badpointer |
- test edi,-1 |
- jz NEAR L$040badpointer |
- call L$041pic_point |
-L$041pic_point: |
- pop ebp |
- lea ebp,[(L$AES_Te-L$041pic_point)+ebp] |
- lea ebp,[2176+ebp] |
- mov eax,DWORD [ebp-128] |
- mov ebx,DWORD [ebp-96] |
- mov ecx,DWORD [ebp-64] |
- mov edx,DWORD [ebp-32] |
- mov eax,DWORD [ebp] |
- mov ebx,DWORD [32+ebp] |
- mov ecx,DWORD [64+ebp] |
- mov edx,DWORD [96+ebp] |
- mov ecx,DWORD [28+esp] |
- cmp ecx,128 |
- je NEAR L$04210rounds |
- cmp ecx,192 |
- je NEAR L$04312rounds |
- cmp ecx,256 |
- je NEAR L$04414rounds |
- mov eax,-2 |
- jmp NEAR L$045exit |
-L$04210rounds: |
- mov eax,DWORD [esi] |
- mov ebx,DWORD [4+esi] |
- mov ecx,DWORD [8+esi] |
- mov edx,DWORD [12+esi] |
- mov DWORD [edi],eax |
- mov DWORD [4+edi],ebx |
- mov DWORD [8+edi],ecx |
- mov DWORD [12+edi],edx |
- xor ecx,ecx |
- jmp NEAR L$04610shortcut |
-align 4 |
-L$04710loop: |
- mov eax,DWORD [edi] |
- mov edx,DWORD [12+edi] |
-L$04610shortcut: |
- movzx esi,dl |
- movzx ebx,BYTE [esi*1+ebp-128] |
- movzx esi,dh |
- shl ebx,24 |
- xor eax,ebx |
- movzx ebx,BYTE [esi*1+ebp-128] |
- shr edx,16 |
- movzx esi,dl |
- xor eax,ebx |
- movzx ebx,BYTE [esi*1+ebp-128] |
- movzx esi,dh |
- shl ebx,8 |
- xor eax,ebx |
- movzx ebx,BYTE [esi*1+ebp-128] |
- shl ebx,16 |
- xor eax,ebx |
- xor eax,DWORD [896+ecx*4+ebp] |
- mov DWORD [16+edi],eax |
- xor eax,DWORD [4+edi] |
- mov DWORD [20+edi],eax |
- xor eax,DWORD [8+edi] |
- mov DWORD [24+edi],eax |
- xor eax,DWORD [12+edi] |
- mov DWORD [28+edi],eax |
- inc ecx |
- add edi,16 |
- cmp ecx,10 |
- jl NEAR L$04710loop |
- mov DWORD [80+edi],10 |
- xor eax,eax |
- jmp NEAR L$045exit |
-L$04312rounds: |
- mov eax,DWORD [esi] |
- mov ebx,DWORD [4+esi] |
- mov ecx,DWORD [8+esi] |
- mov edx,DWORD [12+esi] |
- mov DWORD [edi],eax |
- mov DWORD [4+edi],ebx |
- mov DWORD [8+edi],ecx |
- mov DWORD [12+edi],edx |
- mov ecx,DWORD [16+esi] |
- mov edx,DWORD [20+esi] |
- mov DWORD [16+edi],ecx |
- mov DWORD [20+edi],edx |
- xor ecx,ecx |
- jmp NEAR L$04812shortcut |
-align 4 |
-L$04912loop: |
- mov eax,DWORD [edi] |
- mov edx,DWORD [20+edi] |
-L$04812shortcut: |
- movzx esi,dl |
- movzx ebx,BYTE [esi*1+ebp-128] |
- movzx esi,dh |
- shl ebx,24 |
- xor eax,ebx |
- movzx ebx,BYTE [esi*1+ebp-128] |
- shr edx,16 |
- movzx esi,dl |
- xor eax,ebx |
- movzx ebx,BYTE [esi*1+ebp-128] |
- movzx esi,dh |
- shl ebx,8 |
- xor eax,ebx |
- movzx ebx,BYTE [esi*1+ebp-128] |
- shl ebx,16 |
- xor eax,ebx |
- xor eax,DWORD [896+ecx*4+ebp] |
- mov DWORD [24+edi],eax |
- xor eax,DWORD [4+edi] |
- mov DWORD [28+edi],eax |
- xor eax,DWORD [8+edi] |
- mov DWORD [32+edi],eax |
- xor eax,DWORD [12+edi] |
- mov DWORD [36+edi],eax |
- cmp ecx,7 |
- je NEAR L$05012break |
- inc ecx |
- xor eax,DWORD [16+edi] |
- mov DWORD [40+edi],eax |
- xor eax,DWORD [20+edi] |
- mov DWORD [44+edi],eax |
- add edi,24 |
- jmp NEAR L$04912loop |
-L$05012break: |
- mov DWORD [72+edi],12 |
- xor eax,eax |
- jmp NEAR L$045exit |
-L$04414rounds: |
- mov eax,DWORD [esi] |
- mov ebx,DWORD [4+esi] |
- mov ecx,DWORD [8+esi] |
- mov edx,DWORD [12+esi] |
- mov DWORD [edi],eax |
- mov DWORD [4+edi],ebx |
- mov DWORD [8+edi],ecx |
- mov DWORD [12+edi],edx |
- mov eax,DWORD [16+esi] |
- mov ebx,DWORD [20+esi] |
- mov ecx,DWORD [24+esi] |
- mov edx,DWORD [28+esi] |
- mov DWORD [16+edi],eax |
- mov DWORD [20+edi],ebx |
- mov DWORD [24+edi],ecx |
- mov DWORD [28+edi],edx |
- xor ecx,ecx |
- jmp NEAR L$05114shortcut |
-align 4 |
-L$05214loop: |
- mov edx,DWORD [28+edi] |
-L$05114shortcut: |
- mov eax,DWORD [edi] |
- movzx esi,dl |
- movzx ebx,BYTE [esi*1+ebp-128] |
- movzx esi,dh |
- shl ebx,24 |
- xor eax,ebx |
- movzx ebx,BYTE [esi*1+ebp-128] |
- shr edx,16 |
- movzx esi,dl |
- xor eax,ebx |
- movzx ebx,BYTE [esi*1+ebp-128] |
- movzx esi,dh |
- shl ebx,8 |
- xor eax,ebx |
- movzx ebx,BYTE [esi*1+ebp-128] |
- shl ebx,16 |
- xor eax,ebx |
- xor eax,DWORD [896+ecx*4+ebp] |
- mov DWORD [32+edi],eax |
- xor eax,DWORD [4+edi] |
- mov DWORD [36+edi],eax |
- xor eax,DWORD [8+edi] |
- mov DWORD [40+edi],eax |
- xor eax,DWORD [12+edi] |
- mov DWORD [44+edi],eax |
- cmp ecx,6 |
- je NEAR L$05314break |
- inc ecx |
- mov edx,eax |
- mov eax,DWORD [16+edi] |
- movzx esi,dl |
- movzx ebx,BYTE [esi*1+ebp-128] |
- movzx esi,dh |
- xor eax,ebx |
- movzx ebx,BYTE [esi*1+ebp-128] |
- shr edx,16 |
- shl ebx,8 |
- movzx esi,dl |
- xor eax,ebx |
- movzx ebx,BYTE [esi*1+ebp-128] |
- movzx esi,dh |
- shl ebx,16 |
- xor eax,ebx |
- movzx ebx,BYTE [esi*1+ebp-128] |
- shl ebx,24 |
- xor eax,ebx |
- mov DWORD [48+edi],eax |
- xor eax,DWORD [20+edi] |
- mov DWORD [52+edi],eax |
- xor eax,DWORD [24+edi] |
- mov DWORD [56+edi],eax |
- xor eax,DWORD [28+edi] |
- mov DWORD [60+edi],eax |
- add edi,32 |
- jmp NEAR L$05214loop |
-L$05314break: |
- mov DWORD [48+edi],14 |
- xor eax,eax |
- jmp NEAR L$045exit |
-L$040badpointer: |
- mov eax,-1 |
-L$045exit: |
- pop edi |
- pop esi |
- pop ebx |
- pop ebp |
- ret |
-global _asm_AES_set_encrypt_key |
-align 16 |
-_asm_AES_set_encrypt_key: |
-L$_asm_AES_set_encrypt_key_begin: |
- call __x86_AES_set_encrypt_key |
- ret |
-global _asm_AES_set_decrypt_key |
-align 16 |
-_asm_AES_set_decrypt_key: |
-L$_asm_AES_set_decrypt_key_begin: |
- call __x86_AES_set_encrypt_key |
- cmp eax,0 |
- je NEAR L$054proceed |
- ret |
-L$054proceed: |
- push ebp |
- push ebx |
- push esi |
- push edi |
- mov esi,DWORD [28+esp] |
- mov ecx,DWORD [240+esi] |
- lea ecx,[ecx*4] |
- lea edi,[ecx*4+esi] |
-align 4 |
-L$055invert: |
- mov eax,DWORD [esi] |
- mov ebx,DWORD [4+esi] |
- mov ecx,DWORD [edi] |
- mov edx,DWORD [4+edi] |
- mov DWORD [edi],eax |
- mov DWORD [4+edi],ebx |
- mov DWORD [esi],ecx |
- mov DWORD [4+esi],edx |
- mov eax,DWORD [8+esi] |
- mov ebx,DWORD [12+esi] |
- mov ecx,DWORD [8+edi] |
- mov edx,DWORD [12+edi] |
- mov DWORD [8+edi],eax |
- mov DWORD [12+edi],ebx |
- mov DWORD [8+esi],ecx |
- mov DWORD [12+esi],edx |
- add esi,16 |
- sub edi,16 |
- cmp esi,edi |
- jne NEAR L$055invert |
- mov edi,DWORD [28+esp] |
- mov esi,DWORD [240+edi] |
- lea esi,[esi*1+esi-2] |
- lea esi,[esi*8+edi] |
- mov DWORD [28+esp],esi |
- mov eax,DWORD [16+edi] |
-align 4 |
-L$056permute: |
- add edi,16 |
- mov ebp,2155905152 |
- and ebp,eax |
- lea ebx,[eax*1+eax] |
- mov esi,ebp |
- shr ebp,7 |
- sub esi,ebp |
- and ebx,4278124286 |
- and esi,454761243 |
- xor ebx,esi |
- mov ebp,2155905152 |
- and ebp,ebx |
- lea ecx,[ebx*1+ebx] |
- mov esi,ebp |
- shr ebp,7 |
- sub esi,ebp |
- and ecx,4278124286 |
- and esi,454761243 |
- xor ebx,eax |
- xor ecx,esi |
- mov ebp,2155905152 |
- and ebp,ecx |
- lea edx,[ecx*1+ecx] |
- mov esi,ebp |
- shr ebp,7 |
- xor ecx,eax |
- sub esi,ebp |
- and edx,4278124286 |
- and esi,454761243 |
- rol eax,8 |
- xor edx,esi |
- mov ebp,DWORD [4+edi] |
- xor eax,ebx |
- xor ebx,edx |
- xor eax,ecx |
- rol ebx,24 |
- xor ecx,edx |
- xor eax,edx |
- rol ecx,16 |
- xor eax,ebx |
- rol edx,8 |
- xor eax,ecx |
- mov ebx,ebp |
- xor eax,edx |
- mov DWORD [edi],eax |
- mov ebp,2155905152 |
- and ebp,ebx |
- lea ecx,[ebx*1+ebx] |
- mov esi,ebp |
- shr ebp,7 |
- sub esi,ebp |
- and ecx,4278124286 |
- and esi,454761243 |
- xor ecx,esi |
- mov ebp,2155905152 |
- and ebp,ecx |
- lea edx,[ecx*1+ecx] |
- mov esi,ebp |
- shr ebp,7 |
- sub esi,ebp |
- and edx,4278124286 |
- and esi,454761243 |
- xor ecx,ebx |
- xor edx,esi |
- mov ebp,2155905152 |
- and ebp,edx |
- lea eax,[edx*1+edx] |
- mov esi,ebp |
- shr ebp,7 |
- xor edx,ebx |
- sub esi,ebp |
- and eax,4278124286 |
- and esi,454761243 |
- rol ebx,8 |
- xor eax,esi |
- mov ebp,DWORD [8+edi] |
- xor ebx,ecx |
- xor ecx,eax |
- xor ebx,edx |
- rol ecx,24 |
- xor edx,eax |
- xor ebx,eax |
- rol edx,16 |
- xor ebx,ecx |
- rol eax,8 |
- xor ebx,edx |
- mov ecx,ebp |
- xor ebx,eax |
- mov DWORD [4+edi],ebx |
- mov ebp,2155905152 |
- and ebp,ecx |
- lea edx,[ecx*1+ecx] |
- mov esi,ebp |
- shr ebp,7 |
- sub esi,ebp |
- and edx,4278124286 |
- and esi,454761243 |
- xor edx,esi |
- mov ebp,2155905152 |
- and ebp,edx |
- lea eax,[edx*1+edx] |
- mov esi,ebp |
- shr ebp,7 |
- sub esi,ebp |
- and eax,4278124286 |
- and esi,454761243 |
- xor edx,ecx |
- xor eax,esi |
- mov ebp,2155905152 |
- and ebp,eax |
- lea ebx,[eax*1+eax] |
- mov esi,ebp |
- shr ebp,7 |
- xor eax,ecx |
- sub esi,ebp |
- and ebx,4278124286 |
- and esi,454761243 |
- rol ecx,8 |
- xor ebx,esi |
- mov ebp,DWORD [12+edi] |
- xor ecx,edx |
- xor edx,ebx |
- xor ecx,eax |
- rol edx,24 |
- xor eax,ebx |
- xor ecx,ebx |
- rol eax,16 |
- xor ecx,edx |
- rol ebx,8 |
- xor ecx,eax |
- mov edx,ebp |
- xor ecx,ebx |
- mov DWORD [8+edi],ecx |
- mov ebp,2155905152 |
- and ebp,edx |
- lea eax,[edx*1+edx] |
- mov esi,ebp |
- shr ebp,7 |
- sub esi,ebp |
- and eax,4278124286 |
- and esi,454761243 |
- xor eax,esi |
- mov ebp,2155905152 |
- and ebp,eax |
- lea ebx,[eax*1+eax] |
- mov esi,ebp |
- shr ebp,7 |
- sub esi,ebp |
- and ebx,4278124286 |
- and esi,454761243 |
- xor eax,edx |
- xor ebx,esi |
- mov ebp,2155905152 |
- and ebp,ebx |
- lea ecx,[ebx*1+ebx] |
- mov esi,ebp |
- shr ebp,7 |
- xor ebx,edx |
- sub esi,ebp |
- and ecx,4278124286 |
- and esi,454761243 |
- rol edx,8 |
- xor ecx,esi |
- mov ebp,DWORD [16+edi] |
- xor edx,eax |
- xor eax,ecx |
- xor edx,ebx |
- rol eax,24 |
- xor ebx,ecx |
- xor edx,ecx |
- rol ebx,16 |
- xor edx,eax |
- rol ecx,8 |
- xor edx,ebx |
- mov eax,ebp |
- xor edx,ecx |
- mov DWORD [12+edi],edx |
- cmp edi,DWORD [28+esp] |
- jb NEAR L$056permute |
- xor eax,eax |
- pop edi |
- pop esi |
- pop ebx |
- pop ebp |
- ret |
-db 65,69,83,32,102,111,114,32,120,56,54,44,32,67,82,89 |
-db 80,84,79,71,65,77,83,32,98,121,32,60,97,112,112,114 |
-db 111,64,111,112,101,110,115,115,108,46,111,114,103,62,0 |
-segment .bss |
-common _OPENSSL_ia32cap_P 16 |