; WARNING: do not edit!
; Generated from openssl/crypto/aes/asm/aesni-sha1-x86_64.pl
;
; Copyright 2011-2020 The OpenSSL Project Authors. All Rights Reserved.
;
; Licensed under the OpenSSL license (the "License").  You may not use
; this file except in compliance with the License.  You can obtain a copy
; in the file LICENSE in the source distribution or at
; https://www.openssl.org/source/license.html

default rel
%define XMMWORD
%define YMMWORD
%define ZMMWORD
section .text code align=64

EXTERN  OPENSSL_ia32cap_P

global  aesni_cbc_sha1_enc

ALIGN   32
aesni_cbc_sha1_enc:


        mov     r10d,DWORD[((OPENSSL_ia32cap_P+0))]
        mov     r11,QWORD[((OPENSSL_ia32cap_P+4))]
        bt      r11,61
        jc      NEAR aesni_cbc_sha1_enc_shaext
        jmp     NEAR aesni_cbc_sha1_enc_ssse3
        DB      0F3h,0C3h               ;repret



ALIGN   32
aesni_cbc_sha1_enc_ssse3:
        mov     QWORD[8+rsp],rdi        ;WIN64 prologue
        mov     QWORD[16+rsp],rsi
        mov     rax,rsp
$L$SEH_begin_aesni_cbc_sha1_enc_ssse3:
        mov     rdi,rcx
        mov     rsi,rdx
        mov     rdx,r8
        mov     rcx,r9
        mov     r8,QWORD[40+rsp]
        mov     r9,QWORD[48+rsp]



        mov     r10,QWORD[56+rsp]


        push    rbx

        push    rbp

        push    r12

        push    r13

        push    r14

        push    r15

        lea     rsp,[((-264))+rsp]



        movaps  XMMWORD[(96+0)+rsp],xmm6
        movaps  XMMWORD[(96+16)+rsp],xmm7
        movaps  XMMWORD[(96+32)+rsp],xmm8
        movaps  XMMWORD[(96+48)+rsp],xmm9
        movaps  XMMWORD[(96+64)+rsp],xmm10
        movaps  XMMWORD[(96+80)+rsp],xmm11
        movaps  XMMWORD[(96+96)+rsp],xmm12
        movaps  XMMWORD[(96+112)+rsp],xmm13
        movaps  XMMWORD[(96+128)+rsp],xmm14
        movaps  XMMWORD[(96+144)+rsp],xmm15
$L$prologue_ssse3:
        mov     r12,rdi
        mov     r13,rsi
        mov     r14,rdx
        lea     r15,[112+rcx]
        movdqu  xmm2,XMMWORD[r8]
        mov     QWORD[88+rsp],r8
        shl     r14,6
        sub     r13,r12
        mov     r8d,DWORD[((240-112))+r15]
        add     r14,r10

        lea     r11,[K_XX_XX]
        mov     eax,DWORD[r9]
        mov     ebx,DWORD[4+r9]
        mov     ecx,DWORD[8+r9]
        mov     edx,DWORD[12+r9]
        mov     esi,ebx
        mov     ebp,DWORD[16+r9]
        mov     edi,ecx
        xor     edi,edx
        and     esi,edi

        movdqa  xmm3,XMMWORD[64+r11]
        movdqa  xmm13,XMMWORD[r11]
        movdqu  xmm4,XMMWORD[r10]
        movdqu  xmm5,XMMWORD[16+r10]
        movdqu  xmm6,XMMWORD[32+r10]
        movdqu  xmm7,XMMWORD[48+r10]
DB      102,15,56,0,227
DB      102,15,56,0,235
DB      102,15,56,0,243
        add     r10,64
        paddd   xmm4,xmm13
DB      102,15,56,0,251
        paddd   xmm5,xmm13
        paddd   xmm6,xmm13
        movdqa  XMMWORD[rsp],xmm4
        psubd   xmm4,xmm13
        movdqa  XMMWORD[16+rsp],xmm5
        psubd   xmm5,xmm13
        movdqa  XMMWORD[32+rsp],xmm6
        psubd   xmm6,xmm13
        movups  xmm15,XMMWORD[((-112))+r15]
        movups  xmm0,XMMWORD[((16-112))+r15]
        jmp     NEAR $L$oop_ssse3
ALIGN   32
$L$oop_ssse3:
        ror     ebx,2
        movups  xmm14,XMMWORD[r12]
        xorps   xmm14,xmm15
        xorps   xmm2,xmm14
        movups  xmm1,XMMWORD[((-80))+r15]
DB      102,15,56,220,208
        pshufd  xmm8,xmm4,238
        xor     esi,edx
        movdqa  xmm12,xmm7
        paddd   xmm13,xmm7
        mov     edi,eax
        add     ebp,DWORD[rsp]
        punpcklqdq      xmm8,xmm5
        xor     ebx,ecx
        rol     eax,5
        add     ebp,esi
        psrldq  xmm12,4
        and     edi,ebx
        xor     ebx,ecx
        pxor    xmm8,xmm4
        add     ebp,eax
        ror     eax,7
        pxor    xmm12,xmm6
        xor     edi,ecx
        mov     esi,ebp
        add     edx,DWORD[4+rsp]
        pxor    xmm8,xmm12
        xor     eax,ebx
        rol     ebp,5
        movdqa  XMMWORD[48+rsp],xmm13
        add     edx,edi
        movups  xmm0,XMMWORD[((-64))+r15]
DB      102,15,56,220,209
        and     esi,eax
        movdqa  xmm3,xmm8
        xor     eax,ebx
        add     edx,ebp
        ror     ebp,7
        movdqa  xmm12,xmm8
        xor     esi,ebx
        pslldq  xmm3,12
        paddd   xmm8,xmm8
        mov     edi,edx
        add     ecx,DWORD[8+rsp]
        psrld   xmm12,31
        xor     ebp,eax
        rol     edx,5
        add     ecx,esi
        movdqa  xmm13,xmm3
        and     edi,ebp
        xor     ebp,eax
        psrld   xmm3,30
        add     ecx,edx
        ror     edx,7
        por     xmm8,xmm12
        xor     edi,eax
        mov     esi,ecx
        add     ebx,DWORD[12+rsp]
        movups  xmm1,XMMWORD[((-48))+r15]
DB      102,15,56,220,208
        pslld   xmm13,2
        pxor    xmm8,xmm3
        xor     edx,ebp
        movdqa  xmm3,XMMWORD[r11]
        rol     ecx,5
        add     ebx,edi
        and     esi,edx
        pxor    xmm8,xmm13
        xor     edx,ebp
        add     ebx,ecx
        ror     ecx,7
        pshufd  xmm9,xmm5,238
        xor     esi,ebp
        movdqa  xmm13,xmm8
        paddd   xmm3,xmm8
        mov     edi,ebx
        add     eax,DWORD[16+rsp]
        punpcklqdq      xmm9,xmm6
        xor     ecx,edx
        rol     ebx,5
        add     eax,esi
        psrldq  xmm13,4
        and     edi,ecx
        xor     ecx,edx
        pxor    xmm9,xmm5
        add     eax,ebx
        ror     ebx,7
        movups  xmm0,XMMWORD[((-32))+r15]
DB      102,15,56,220,209
        pxor    xmm13,xmm7
        xor     edi,edx
        mov     esi,eax
        add     ebp,DWORD[20+rsp]
        pxor    xmm9,xmm13
        xor     ebx,ecx
        rol     eax,5
        movdqa  XMMWORD[rsp],xmm3
        add     ebp,edi
        and     esi,ebx
        movdqa  xmm12,xmm9
        xor     ebx,ecx
        add     ebp,eax
        ror     eax,7
        movdqa  xmm13,xmm9
        xor     esi,ecx
        pslldq  xmm12,12
        paddd   xmm9,xmm9
        mov     edi,ebp
        add     edx,DWORD[24+rsp]
        psrld   xmm13,31
        xor     eax,ebx
        rol     ebp,5
        add     edx,esi
        movups  xmm1,XMMWORD[((-16))+r15]
DB      102,15,56,220,208
        movdqa  xmm3,xmm12
        and     edi,eax
        xor     eax,ebx
        psrld   xmm12,30
        add     edx,ebp
        ror     ebp,7
        por     xmm9,xmm13
        xor     edi,ebx
        mov     esi,edx
        add     ecx,DWORD[28+rsp]
        pslld   xmm3,2
        pxor    xmm9,xmm12
        xor     ebp,eax
        movdqa  xmm12,XMMWORD[16+r11]
        rol     edx,5
        add     ecx,edi
        and     esi,ebp
        pxor    xmm9,xmm3
        xor     ebp,eax
        add     ecx,edx
        ror     edx,7
        pshufd  xmm10,xmm6,238
        xor     esi,eax
        movdqa  xmm3,xmm9
        paddd   xmm12,xmm9
        mov     edi,ecx
        add     ebx,DWORD[32+rsp]
        movups  xmm0,XMMWORD[r15]
DB      102,15,56,220,209
        punpcklqdq      xmm10,xmm7
        xor     edx,ebp
        rol     ecx,5
        add     ebx,esi
        psrldq  xmm3,4
        and     edi,edx
        xor     edx,ebp
        pxor    xmm10,xmm6
        add     ebx,ecx
        ror     ecx,7
        pxor    xmm3,xmm8
        xor     edi,ebp
        mov     esi,ebx
        add     eax,DWORD[36+rsp]
        pxor    xmm10,xmm3
        xor     ecx,edx
        rol     ebx,5
        movdqa  XMMWORD[16+rsp],xmm12
        add     eax,edi
        and     esi,ecx
        movdqa  xmm13,xmm10
        xor     ecx,edx
        add     eax,ebx
        ror     ebx,7
        movups  xmm1,XMMWORD[16+r15]
DB      102,15,56,220,208
        movdqa  xmm3,xmm10
        xor     esi,edx
        pslldq  xmm13,12
        paddd   xmm10,xmm10
        mov     edi,eax
        add     ebp,DWORD[40+rsp]
        psrld   xmm3,31
        xor     ebx,ecx
        rol     eax,5
        add     ebp,esi
        movdqa  xmm12,xmm13
        and     edi,ebx
        xor     ebx,ecx
        psrld   xmm13,30
        add     ebp,eax
        ror     eax,7
        por     xmm10,xmm3
        xor     edi,ecx
        mov     esi,ebp
        add     edx,DWORD[44+rsp]
        pslld   xmm12,2
        pxor    xmm10,xmm13
        xor     eax,ebx
        movdqa  xmm13,XMMWORD[16+r11]
        rol     ebp,5
        add     edx,edi
        movups  xmm0,XMMWORD[32+r15]
DB      102,15,56,220,209
        and     esi,eax
        pxor    xmm10,xmm12
        xor     eax,ebx
        add     edx,ebp
        ror     ebp,7
        pshufd  xmm11,xmm7,238
        xor     esi,ebx
        movdqa  xmm12,xmm10
        paddd   xmm13,xmm10
        mov     edi,edx
        add     ecx,DWORD[48+rsp]
        punpcklqdq      xmm11,xmm8
        xor     ebp,eax
        rol     edx,5
        add     ecx,esi
        psrldq  xmm12,4
        and     edi,ebp
        xor     ebp,eax
        pxor    xmm11,xmm7
        add     ecx,edx
        ror     edx,7
        pxor    xmm12,xmm9
        xor     edi,eax
        mov     esi,ecx
        add     ebx,DWORD[52+rsp]
        movups  xmm1,XMMWORD[48+r15]
DB      102,15,56,220,208
        pxor    xmm11,xmm12
        xor     edx,ebp
        rol     ecx,5
        movdqa  XMMWORD[32+rsp],xmm13
        add     ebx,edi
        and     esi,edx
        movdqa  xmm3,xmm11
        xor     edx,ebp
        add     ebx,ecx
        ror     ecx,7
        movdqa  xmm12,xmm11
        xor     esi,ebp
        pslldq  xmm3,12
        paddd   xmm11,xmm11
        mov     edi,ebx
        add     eax,DWORD[56+rsp]
        psrld   xmm12,31
        xor     ecx,edx
        rol     ebx,5
        add     eax,esi
        movdqa  xmm13,xmm3
        and     edi,ecx
        xor     ecx,edx
        psrld   xmm3,30
        add     eax,ebx
        ror     ebx,7
        cmp     r8d,11
        jb      NEAR $L$aesenclast1
        movups  xmm0,XMMWORD[64+r15]
DB      102,15,56,220,209
        movups  xmm1,XMMWORD[80+r15]
DB      102,15,56,220,208
        je      NEAR $L$aesenclast1
        movups  xmm0,XMMWORD[96+r15]
DB      102,15,56,220,209
        movups  xmm1,XMMWORD[112+r15]
DB      102,15,56,220,208
$L$aesenclast1:
DB      102,15,56,221,209
        movups  xmm0,XMMWORD[((16-112))+r15]
        por     xmm11,xmm12
        xor     edi,edx
        mov     esi,eax
        add     ebp,DWORD[60+rsp]
        pslld   xmm13,2
        pxor    xmm11,xmm3
        xor     ebx,ecx
        movdqa  xmm3,XMMWORD[16+r11]
        rol     eax,5
        add     ebp,edi
        and     esi,ebx
        pxor    xmm11,xmm13
        pshufd  xmm13,xmm10,238
        xor     ebx,ecx
        add     ebp,eax
        ror     eax,7
        pxor    xmm4,xmm8
        xor     esi,ecx
        mov     edi,ebp
        add     edx,DWORD[rsp]
        punpcklqdq      xmm13,xmm11
        xor     eax,ebx
        rol     ebp,5
        pxor    xmm4,xmm5
        add     edx,esi
        movups  xmm14,XMMWORD[16+r12]
        xorps   xmm14,xmm15
        movups  XMMWORD[r13*1+r12],xmm2
        xorps   xmm2,xmm14
        movups  xmm1,XMMWORD[((-80))+r15]
DB      102,15,56,220,208
        and     edi,eax
        movdqa  xmm12,xmm3
        xor     eax,ebx
        paddd   xmm3,xmm11
        add     edx,ebp
        pxor    xmm4,xmm13
        ror     ebp,7
        xor     edi,ebx
        mov     esi,edx
        add     ecx,DWORD[4+rsp]
        movdqa  xmm13,xmm4
        xor     ebp,eax
        rol     edx,5
        movdqa  XMMWORD[48+rsp],xmm3
        add     ecx,edi
        and     esi,ebp
        xor     ebp,eax
        pslld   xmm4,2
        add     ecx,edx
        ror     edx,7
        psrld   xmm13,30
        xor     esi,eax
        mov     edi,ecx
        add     ebx,DWORD[8+rsp]
        movups  xmm0,XMMWORD[((-64))+r15]
DB      102,15,56,220,209
        por     xmm4,xmm13
        xor     edx,ebp
        rol     ecx,5
        pshufd  xmm3,xmm11,238
        add     ebx,esi
        and     edi,edx
        xor     edx,ebp
        add     ebx,ecx
        add     eax,DWORD[12+rsp]
        xor     edi,ebp
        mov     esi,ebx
        rol     ebx,5
        add     eax,edi
        xor     esi,edx
        ror     ecx,7
        add     eax,ebx
        pxor    xmm5,xmm9
        add     ebp,DWORD[16+rsp]
        movups  xmm1,XMMWORD[((-48))+r15]
DB      102,15,56,220,208
        xor     esi,ecx
        punpcklqdq      xmm3,xmm4
        mov     edi,eax
        rol     eax,5
        pxor    xmm5,xmm6
        add     ebp,esi
        xor     edi,ecx
        movdqa  xmm13,xmm12
        ror     ebx,7
        paddd   xmm12,xmm4
        add     ebp,eax
        pxor    xmm5,xmm3
        add     edx,DWORD[20+rsp]
        xor     edi,ebx
        mov     esi,ebp
        rol     ebp,5
        movdqa  xmm3,xmm5
        add     edx,edi
        xor     esi,ebx
        movdqa  XMMWORD[rsp],xmm12
        ror     eax,7
        add     edx,ebp
        add     ecx,DWORD[24+rsp]
        pslld   xmm5,2
        xor     esi,eax
        mov     edi,edx
        psrld   xmm3,30
        rol     edx,5
        add     ecx,esi
        movups  xmm0,XMMWORD[((-32))+r15]
DB      102,15,56,220,209
        xor     edi,eax
        ror     ebp,7
        por     xmm5,xmm3
        add     ecx,edx
        add     ebx,DWORD[28+rsp]
        pshufd  xmm12,xmm4,238
        xor     edi,ebp
        mov     esi,ecx
        rol     ecx,5
        add     ebx,edi
        xor     esi,ebp
        ror     edx,7
        add     ebx,ecx
        pxor    xmm6,xmm10
        add     eax,DWORD[32+rsp]
        xor     esi,edx
        punpcklqdq      xmm12,xmm5
        mov     edi,ebx
        rol     ebx,5
        pxor    xmm6,xmm7
        add     eax,esi
        xor     edi,edx
        movdqa  xmm3,XMMWORD[32+r11]
        ror     ecx,7
        paddd   xmm13,xmm5
        add     eax,ebx
        pxor    xmm6,xmm12
        add     ebp,DWORD[36+rsp]
        movups  xmm1,XMMWORD[((-16))+r15]
DB      102,15,56,220,208
        xor     edi,ecx
        mov     esi,eax
        rol     eax,5
        movdqa  xmm12,xmm6
        add     ebp,edi
        xor     esi,ecx
        movdqa  XMMWORD[16+rsp],xmm13
        ror     ebx,7
        add     ebp,eax
        add     edx,DWORD[40+rsp]
        pslld   xmm6,2
        xor     esi,ebx
        mov     edi,ebp
        psrld   xmm12,30
        rol     ebp,5
        add     edx,esi
        xor     edi,ebx
        ror     eax,7
        por     xmm6,xmm12
        add     edx,ebp
        add     ecx,DWORD[44+rsp]
        pshufd  xmm13,xmm5,238
        xor     edi,eax
        mov     esi,edx
        rol     edx,5
        add     ecx,edi
        movups  xmm0,XMMWORD[r15]
DB      102,15,56,220,209
        xor     esi,eax
        ror     ebp,7
        add     ecx,edx
        pxor    xmm7,xmm11
        add     ebx,DWORD[48+rsp]
        xor     esi,ebp
        punpcklqdq      xmm13,xmm6
        mov     edi,ecx
        rol     ecx,5
        pxor    xmm7,xmm8
        add     ebx,esi
        xor     edi,ebp
        movdqa  xmm12,xmm3
        ror     edx,7
        paddd   xmm3,xmm6
        add     ebx,ecx
        pxor    xmm7,xmm13
        add     eax,DWORD[52+rsp]
        xor     edi,edx
        mov     esi,ebx
        rol     ebx,5
        movdqa  xmm13,xmm7
        add     eax,edi
        xor     esi,edx
        movdqa  XMMWORD[32+rsp],xmm3
        ror     ecx,7
        add     eax,ebx
        add     ebp,DWORD[56+rsp]
        movups  xmm1,XMMWORD[16+r15]
DB      102,15,56,220,208
        pslld   xmm7,2
        xor     esi,ecx
        mov     edi,eax
        psrld   xmm13,30
        rol     eax,5
        add     ebp,esi
        xor     edi,ecx
        ror     ebx,7
        por     xmm7,xmm13
        add     ebp,eax
        add     edx,DWORD[60+rsp]
        pshufd  xmm3,xmm6,238
        xor     edi,ebx
        mov     esi,ebp
        rol     ebp,5
        add     edx,edi
        xor     esi,ebx
        ror     eax,7
        add     edx,ebp
        pxor    xmm8,xmm4
        add     ecx,DWORD[rsp]
        xor     esi,eax
        punpcklqdq      xmm3,xmm7
        mov     edi,edx
        rol     edx,5
        pxor    xmm8,xmm9
        add     ecx,esi
        movups  xmm0,XMMWORD[32+r15]
DB      102,15,56,220,209
        xor     edi,eax
        movdqa  xmm13,xmm12
        ror     ebp,7
        paddd   xmm12,xmm7
        add     ecx,edx
        pxor    xmm8,xmm3
        add     ebx,DWORD[4+rsp]
        xor     edi,ebp
        mov     esi,ecx
        rol     ecx,5
        movdqa  xmm3,xmm8
        add     ebx,edi
        xor     esi,ebp
        movdqa  XMMWORD[48+rsp],xmm12
        ror     edx,7
        add     ebx,ecx
        add     eax,DWORD[8+rsp]
        pslld   xmm8,2
        xor     esi,edx
        mov     edi,ebx
        psrld   xmm3,30
        rol     ebx,5
        add     eax,esi
        xor     edi,edx
        ror     ecx,7
        por     xmm8,xmm3
        add     eax,ebx
        add     ebp,DWORD[12+rsp]
        movups  xmm1,XMMWORD[48+r15]
DB      102,15,56,220,208
        pshufd  xmm12,xmm7,238
        xor     edi,ecx
        mov     esi,eax
        rol     eax,5
        add     ebp,edi
        xor     esi,ecx
        ror     ebx,7
        add     ebp,eax
        pxor    xmm9,xmm5
        add     edx,DWORD[16+rsp]
        xor     esi,ebx
        punpcklqdq      xmm12,xmm8
        mov     edi,ebp
        rol     ebp,5
        pxor    xmm9,xmm10
        add     edx,esi
        xor     edi,ebx
        movdqa  xmm3,xmm13
        ror     eax,7
        paddd   xmm13,xmm8
        add     edx,ebp
        pxor    xmm9,xmm12
        add     ecx,DWORD[20+rsp]
        xor     edi,eax
        mov     esi,edx
        rol     edx,5
        movdqa  xmm12,xmm9
        add     ecx,edi
        cmp     r8d,11
        jb      NEAR $L$aesenclast2
        movups  xmm0,XMMWORD[64+r15]
DB      102,15,56,220,209
        movups  xmm1,XMMWORD[80+r15]
DB      102,15,56,220,208
        je      NEAR $L$aesenclast2
        movups  xmm0,XMMWORD[96+r15]
DB      102,15,56,220,209
        movups  xmm1,XMMWORD[112+r15]
DB      102,15,56,220,208
$L$aesenclast2:
DB      102,15,56,221,209
        movups  xmm0,XMMWORD[((16-112))+r15]
        xor     esi,eax
        movdqa  XMMWORD[rsp],xmm13
        ror     ebp,7
        add     ecx,edx
        add     ebx,DWORD[24+rsp]
        pslld   xmm9,2
        xor     esi,ebp
        mov     edi,ecx
        psrld   xmm12,30
        rol     ecx,5
        add     ebx,esi
        xor     edi,ebp
        ror     edx,7
        por     xmm9,xmm12
        add     ebx,ecx
        add     eax,DWORD[28+rsp]
        pshufd  xmm13,xmm8,238
        ror     ecx,7
        mov     esi,ebx
        xor     edi,edx
        rol     ebx,5
        add     eax,edi
        xor     esi,ecx
        xor     ecx,edx
        add     eax,ebx
        pxor    xmm10,xmm6
        add     ebp,DWORD[32+rsp]
        movups  xmm14,XMMWORD[32+r12]
        xorps   xmm14,xmm15
        movups  XMMWORD[16+r12*1+r13],xmm2
        xorps   xmm2,xmm14
        movups  xmm1,XMMWORD[((-80))+r15]
DB      102,15,56,220,208
        and     esi,ecx
        xor     ecx,edx
        ror     ebx,7
        punpcklqdq      xmm13,xmm9
        mov     edi,eax
        xor     esi,ecx
        pxor    xmm10,xmm11
        rol     eax,5
        add     ebp,esi
        movdqa  xmm12,xmm3
        xor     edi,ebx
        paddd   xmm3,xmm9
        xor     ebx,ecx
        pxor    xmm10,xmm13
        add     ebp,eax
        add     edx,DWORD[36+rsp]
        and     edi,ebx
        xor     ebx,ecx
        ror     eax,7
        movdqa  xmm13,xmm10
        mov     esi,ebp
        xor     edi,ebx
        movdqa  XMMWORD[16+rsp],xmm3
        rol     ebp,5
        add     edx,edi
        movups  xmm0,XMMWORD[((-64))+r15]
DB      102,15,56,220,209
        xor     esi,eax
        pslld   xmm10,2
        xor     eax,ebx
        add     edx,ebp
        psrld   xmm13,30
        add     ecx,DWORD[40+rsp]
        and     esi,eax
        xor     eax,ebx
        por     xmm10,xmm13
        ror     ebp,7
        mov     edi,edx
        xor     esi,eax
        rol     edx,5
        pshufd  xmm3,xmm9,238
        add     ecx,esi
        xor     edi,ebp
        xor     ebp,eax
        add     ecx,edx
        add     ebx,DWORD[44+rsp]
        and     edi,ebp
        xor     ebp,eax
        ror     edx,7
        movups  xmm1,XMMWORD[((-48))+r15]
DB      102,15,56,220,208
        mov     esi,ecx
        xor     edi,ebp
        rol     ecx,5
        add     ebx,edi
        xor     esi,edx
        xor     edx,ebp
        add     ebx,ecx
        pxor    xmm11,xmm7
        add     eax,DWORD[48+rsp]
        and     esi,edx
        xor     edx,ebp
        ror     ecx,7
        punpcklqdq      xmm3,xmm10
        mov     edi,ebx
        xor     esi,edx
        pxor    xmm11,xmm4
        rol     ebx,5
        add     eax,esi
        movdqa  xmm13,XMMWORD[48+r11]
        xor     edi,ecx
        paddd   xmm12,xmm10
        xor     ecx,edx
        pxor    xmm11,xmm3
        add     eax,ebx
        add     ebp,DWORD[52+rsp]
        movups  xmm0,XMMWORD[((-32))+r15]
DB      102,15,56,220,209
        and     edi,ecx
        xor     ecx,edx
        ror     ebx,7
        movdqa  xmm3,xmm11
        mov     esi,eax
        xor     edi,ecx
        movdqa  XMMWORD[32+rsp],xmm12
        rol     eax,5
        add     ebp,edi
        xor     esi,ebx
        pslld   xmm11,2
        xor     ebx,ecx
        add     ebp,eax
        psrld   xmm3,30
        add     edx,DWORD[56+rsp]
        and     esi,ebx
        xor     ebx,ecx
        por     xmm11,xmm3
        ror     eax,7
        mov     edi,ebp
        xor     esi,ebx
        rol     ebp,5
        pshufd  xmm12,xmm10,238
        add     edx,esi
        movups  xmm1,XMMWORD[((-16))+r15]
DB      102,15,56,220,208
        xor     edi,eax
        xor     eax,ebx
        add     edx,ebp
        add     ecx,DWORD[60+rsp]
        and     edi,eax
        xor     eax,ebx
        ror     ebp,7
        mov     esi,edx
        xor     edi,eax
        rol     edx,5
        add     ecx,edi
        xor     esi,ebp
        xor     ebp,eax
        add     ecx,edx
        pxor    xmm4,xmm8
        add     ebx,DWORD[rsp]
        and     esi,ebp
        xor     ebp,eax
        ror     edx,7
        movups  xmm0,XMMWORD[r15]
DB      102,15,56,220,209
        punpcklqdq      xmm12,xmm11
        mov     edi,ecx
        xor     esi,ebp
        pxor    xmm4,xmm5
        rol     ecx,5
        add     ebx,esi
        movdqa  xmm3,xmm13
        xor     edi,edx
        paddd   xmm13,xmm11
        xor     edx,ebp
        pxor    xmm4,xmm12
        add     ebx,ecx
        add     eax,DWORD[4+rsp]
        and     edi,edx
        xor     edx,ebp
        ror     ecx,7
        movdqa  xmm12,xmm4
        mov     esi,ebx
        xor     edi,edx
        movdqa  XMMWORD[48+rsp],xmm13
        rol     ebx,5
        add     eax,edi
        xor     esi,ecx
        pslld   xmm4,2
        xor     ecx,edx
        add     eax,ebx
        psrld   xmm12,30
        add     ebp,DWORD[8+rsp]
        movups  xmm1,XMMWORD[16+r15]
DB      102,15,56,220,208
        and     esi,ecx
        xor     ecx,edx
        por     xmm4,xmm12
        ror     ebx,7
        mov     edi,eax
        xor     esi,ecx
        rol     eax,5
        pshufd  xmm13,xmm11,238
        add     ebp,esi
        xor     edi,ebx
        xor     ebx,ecx
        add     ebp,eax
        add     edx,DWORD[12+rsp]
        and     edi,ebx
        xor     ebx,ecx
        ror     eax,7
        mov     esi,ebp
        xor     edi,ebx
        rol     ebp,5
        add     edx,edi
        movups  xmm0,XMMWORD[32+r15]
DB      102,15,56,220,209
        xor     esi,eax
        xor     eax,ebx
        add     edx,ebp
        pxor    xmm5,xmm9
        add     ecx,DWORD[16+rsp]
        and     esi,eax
        xor     eax,ebx
        ror     ebp,7
        punpcklqdq      xmm13,xmm4
        mov     edi,edx
        xor     esi,eax
        pxor    xmm5,xmm6
        rol     edx,5
        add     ecx,esi
        movdqa  xmm12,xmm3
        xor     edi,ebp
        paddd   xmm3,xmm4
        xor     ebp,eax
        pxor    xmm5,xmm13
        add     ecx,edx
        add     ebx,DWORD[20+rsp]
        and     edi,ebp
        xor     ebp,eax
        ror     edx,7
        movups  xmm1,XMMWORD[48+r15]
DB      102,15,56,220,208
        movdqa  xmm13,xmm5
        mov     esi,ecx
        xor     edi,ebp
        movdqa  XMMWORD[rsp],xmm3
        rol     ecx,5
        add     ebx,edi
        xor     esi,edx
        pslld   xmm5,2
        xor     edx,ebp
        add     ebx,ecx
        psrld   xmm13,30
        add     eax,DWORD[24+rsp]
        and     esi,edx
        xor     edx,ebp
        por     xmm5,xmm13
        ror     ecx,7
        mov     edi,ebx
        xor     esi,edx
        rol     ebx,5
        pshufd  xmm3,xmm4,238
        add     eax,esi
        xor     edi,ecx
        xor     ecx,edx
        add     eax,ebx
        add     ebp,DWORD[28+rsp]
        cmp     r8d,11
        jb      NEAR $L$aesenclast3
        movups  xmm0,XMMWORD[64+r15]
DB      102,15,56,220,209
        movups  xmm1,XMMWORD[80+r15]
DB      102,15,56,220,208
        je      NEAR $L$aesenclast3
        movups  xmm0,XMMWORD[96+r15]
DB      102,15,56,220,209
        movups  xmm1,XMMWORD[112+r15]
DB      102,15,56,220,208
$L$aesenclast3:
DB      102,15,56,221,209
        movups  xmm0,XMMWORD[((16-112))+r15]
        and     edi,ecx
        xor     ecx,edx
        ror     ebx,7
        mov     esi,eax
        xor     edi,ecx
        rol     eax,5
        add     ebp,edi
        xor     esi,ebx
        xor     ebx,ecx
        add     ebp,eax
        pxor    xmm6,xmm10
        add     edx,DWORD[32+rsp]
        and     esi,ebx
        xor     ebx,ecx
        ror     eax,7
        punpcklqdq      xmm3,xmm5
        mov     edi,ebp
        xor     esi,ebx
        pxor    xmm6,xmm7
        rol     ebp,5
        add     edx,esi
        movups  xmm14,XMMWORD[48+r12]
        xorps   xmm14,xmm15
        movups  XMMWORD[32+r12*1+r13],xmm2
        xorps   xmm2,xmm14
        movups  xmm1,XMMWORD[((-80))+r15]
DB      102,15,56,220,208
        movdqa  xmm13,xmm12
        xor     edi,eax
        paddd   xmm12,xmm5
        xor     eax,ebx
        pxor    xmm6,xmm3
        add     edx,ebp
        add     ecx,DWORD[36+rsp]
        and     edi,eax
        xor     eax,ebx
        ror     ebp,7
        movdqa  xmm3,xmm6
        mov     esi,edx
        xor     edi,eax
        movdqa  XMMWORD[16+rsp],xmm12
        rol     edx,5
        add     ecx,edi
        xor     esi,ebp
        pslld   xmm6,2
        xor     ebp,eax
        add     ecx,edx
        psrld   xmm3,30
        add     ebx,DWORD[40+rsp]
        and     esi,ebp
        xor     ebp,eax
        por     xmm6,xmm3
        ror     edx,7
        movups  xmm0,XMMWORD[((-64))+r15]
DB      102,15,56,220,209
        mov     edi,ecx
        xor     esi,ebp
        rol     ecx,5
        pshufd  xmm12,xmm5,238
        add     ebx,esi
        xor     edi,edx
        xor     edx,ebp
        add     ebx,ecx
        add     eax,DWORD[44+rsp]
        and     edi,edx
        xor     edx,ebp
        ror     ecx,7
        mov     esi,ebx
        xor     edi,edx
        rol     ebx,5
        add     eax,edi
        xor     esi,edx
        add     eax,ebx
        pxor    xmm7,xmm11
        add     ebp,DWORD[48+rsp]
        movups  xmm1,XMMWORD[((-48))+r15]
DB      102,15,56,220,208
        xor     esi,ecx
        punpcklqdq      xmm12,xmm6
        mov     edi,eax
        rol     eax,5
        pxor    xmm7,xmm8
        add     ebp,esi
        xor     edi,ecx
        movdqa  xmm3,xmm13
        ror     ebx,7
        paddd   xmm13,xmm6
        add     ebp,eax
        pxor    xmm7,xmm12
        add     edx,DWORD[52+rsp]
        xor     edi,ebx
        mov     esi,ebp
        rol     ebp,5
        movdqa  xmm12,xmm7
        add     edx,edi
        xor     esi,ebx
        movdqa  XMMWORD[32+rsp],xmm13
        ror     eax,7
        add     edx,ebp
        add     ecx,DWORD[56+rsp]
        pslld   xmm7,2
        xor     esi,eax
        mov     edi,edx
        psrld   xmm12,30
        rol     edx,5
        add     ecx,esi
        movups  xmm0,XMMWORD[((-32))+r15]
DB      102,15,56,220,209
        xor     edi,eax
        ror     ebp,7
        por     xmm7,xmm12
        add     ecx,edx
        add     ebx,DWORD[60+rsp]
        xor     edi,ebp
        mov     esi,ecx
        rol     ecx,5
        add     ebx,edi
        xor     esi,ebp
        ror     edx,7
        add     ebx,ecx
        add     eax,DWORD[rsp]
        xor     esi,edx
        mov     edi,ebx
        rol     ebx,5
        paddd   xmm3,xmm7
        add     eax,esi
        xor     edi,edx
        movdqa  XMMWORD[48+rsp],xmm3
        ror     ecx,7
        add     eax,ebx
        add     ebp,DWORD[4+rsp]
        movups  xmm1,XMMWORD[((-16))+r15]
DB      102,15,56,220,208
        xor     edi,ecx
        mov     esi,eax
        rol     eax,5
        add     ebp,edi
        xor     esi,ecx
        ror     ebx,7
        add     ebp,eax
        add     edx,DWORD[8+rsp]
        xor     esi,ebx
        mov     edi,ebp
        rol     ebp,5
        add     edx,esi
        xor     edi,ebx
        ror     eax,7
        add     edx,ebp
        add     ecx,DWORD[12+rsp]
        xor     edi,eax
        mov     esi,edx
        rol     edx,5
        add     ecx,edi
        movups  xmm0,XMMWORD[r15]
DB      102,15,56,220,209
        xor     esi,eax
        ror     ebp,7
        add     ecx,edx
        cmp     r10,r14
        je      NEAR $L$done_ssse3
        movdqa  xmm3,XMMWORD[64+r11]
        movdqa  xmm13,XMMWORD[r11]
        movdqu  xmm4,XMMWORD[r10]
        movdqu  xmm5,XMMWORD[16+r10]
        movdqu  xmm6,XMMWORD[32+r10]
        movdqu  xmm7,XMMWORD[48+r10]
DB      102,15,56,0,227
        add     r10,64
        add     ebx,DWORD[16+rsp]
        xor     esi,ebp
        mov     edi,ecx
DB      102,15,56,0,235
        rol     ecx,5
        add     ebx,esi
        xor     edi,ebp
        ror     edx,7
        paddd   xmm4,xmm13
        add     ebx,ecx
        add     eax,DWORD[20+rsp]
        xor     edi,edx
        mov     esi,ebx
        movdqa  XMMWORD[rsp],xmm4
        rol     ebx,5
        add     eax,edi
        xor     esi,edx
        ror     ecx,7
        psubd   xmm4,xmm13
        add     eax,ebx
        add     ebp,DWORD[24+rsp]
        movups  xmm1,XMMWORD[16+r15]
DB      102,15,56,220,208
        xor     esi,ecx
        mov     edi,eax
        rol     eax,5
        add     ebp,esi
        xor     edi,ecx
        ror     ebx,7
        add     ebp,eax
        add     edx,DWORD[28+rsp]
        xor     edi,ebx
        mov     esi,ebp
        rol     ebp,5
        add     edx,edi
        xor     esi,ebx
        ror     eax,7
        add     edx,ebp
        add     ecx,DWORD[32+rsp]
        xor     esi,eax
        mov     edi,edx
DB      102,15,56,0,243
        rol     edx,5
        add     ecx,esi
        movups  xmm0,XMMWORD[32+r15]
DB      102,15,56,220,209
        xor     edi,eax
        ror     ebp,7
        paddd   xmm5,xmm13
        add     ecx,edx
        add     ebx,DWORD[36+rsp]
        xor     edi,ebp
        mov     esi,ecx
        movdqa  XMMWORD[16+rsp],xmm5
        rol     ecx,5
        add     ebx,edi
        xor     esi,ebp
        ror     edx,7
        psubd   xmm5,xmm13
        add     ebx,ecx
        add     eax,DWORD[40+rsp]
        xor     esi,edx
        mov     edi,ebx
        rol     ebx,5
        add     eax,esi
        xor     edi,edx
        ror     ecx,7
        add     eax,ebx
        add     ebp,DWORD[44+rsp]
        movups  xmm1,XMMWORD[48+r15]
DB      102,15,56,220,208
        xor     edi,ecx
        mov     esi,eax
        rol     eax,5
        add     ebp,edi
        xor     esi,ecx
        ror     ebx,7
        add     ebp,eax
        add     edx,DWORD[48+rsp]
        xor     esi,ebx
        mov     edi,ebp
DB      102,15,56,0,251
        rol     ebp,5
        add     edx,esi
        xor     edi,ebx
        ror     eax,7
        paddd   xmm6,xmm13
        add     edx,ebp
        add     ecx,DWORD[52+rsp]
        xor     edi,eax
        mov     esi,edx
        movdqa  XMMWORD[32+rsp],xmm6
        rol     edx,5
        add     ecx,edi
        cmp     r8d,11
        jb      NEAR $L$aesenclast4
        movups  xmm0,XMMWORD[64+r15]
DB      102,15,56,220,209
        movups  xmm1,XMMWORD[80+r15]
DB      102,15,56,220,208
        je      NEAR $L$aesenclast4
        movups  xmm0,XMMWORD[96+r15]
DB      102,15,56,220,209
        movups  xmm1,XMMWORD[112+r15]
DB      102,15,56,220,208
$L$aesenclast4:
DB      102,15,56,221,209
        movups  xmm0,XMMWORD[((16-112))+r15]
        xor     esi,eax
        ror     ebp,7
        psubd   xmm6,xmm13
        add     ecx,edx
        add     ebx,DWORD[56+rsp]
        xor     esi,ebp
        mov     edi,ecx
        rol     ecx,5
        add     ebx,esi
        xor     edi,ebp
        ror     edx,7
        add     ebx,ecx
        add     eax,DWORD[60+rsp]
        xor     edi,edx
        mov     esi,ebx
        rol     ebx,5
        add     eax,edi
        ror     ecx,7
        add     eax,ebx
        movups  XMMWORD[48+r12*1+r13],xmm2
        lea     r12,[64+r12]

        add     eax,DWORD[r9]
        add     esi,DWORD[4+r9]
        add     ecx,DWORD[8+r9]
        add     edx,DWORD[12+r9]
        mov     DWORD[r9],eax
        add     ebp,DWORD[16+r9]
        mov     DWORD[4+r9],esi
        mov     ebx,esi
        mov     DWORD[8+r9],ecx
        mov     edi,ecx
        mov     DWORD[12+r9],edx
        xor     edi,edx
        mov     DWORD[16+r9],ebp
        and     esi,edi
        jmp     NEAR $L$oop_ssse3

$L$done_ssse3:
        add     ebx,DWORD[16+rsp]
        xor     esi,ebp
        mov     edi,ecx
        rol     ecx,5
        add     ebx,esi
        xor     edi,ebp
        ror     edx,7
        add     ebx,ecx
        add     eax,DWORD[20+rsp]
        xor     edi,edx
        mov     esi,ebx
        rol     ebx,5
        add     eax,edi
        xor     esi,edx
        ror     ecx,7
        add     eax,ebx
        add     ebp,DWORD[24+rsp]
        movups  xmm1,XMMWORD[16+r15]
DB      102,15,56,220,208
        xor     esi,ecx
        mov     edi,eax
        rol     eax,5
        add     ebp,esi
        xor     edi,ecx
        ror     ebx,7
        add     ebp,eax
        add     edx,DWORD[28+rsp]
        xor     edi,ebx
        mov     esi,ebp
        rol     ebp,5
        add     edx,edi
        xor     esi,ebx
        ror     eax,7
        add     edx,ebp
        add     ecx,DWORD[32+rsp]
        xor     esi,eax
        mov     edi,edx
        rol     edx,5
        add     ecx,esi
        movups  xmm0,XMMWORD[32+r15]
DB      102,15,56,220,209
        xor     edi,eax
        ror     ebp,7
        add     ecx,edx
        add     ebx,DWORD[36+rsp]
        xor     edi,ebp
        mov     esi,ecx
        rol     ecx,5
        add     ebx,edi
        xor     esi,ebp
        ror     edx,7
        add     ebx,ecx
        add     eax,DWORD[40+rsp]
        xor     esi,edx
        mov     edi,ebx
        rol     ebx,5
        add     eax,esi
        xor     edi,edx
        ror     ecx,7
        add     eax,ebx
        add     ebp,DWORD[44+rsp]
        movups  xmm1,XMMWORD[48+r15]
DB      102,15,56,220,208
        xor     edi,ecx
        mov     esi,eax
        rol     eax,5
        add     ebp,edi
        xor     esi,ecx
        ror     ebx,7
        add     ebp,eax
        add     edx,DWORD[48+rsp]
        xor     esi,ebx
        mov     edi,ebp
        rol     ebp,5
        add     edx,esi
        xor     edi,ebx
        ror     eax,7
        add     edx,ebp
        add     ecx,DWORD[52+rsp]
        xor     edi,eax
        mov     esi,edx
        rol     edx,5
        add     ecx,edi
        cmp     r8d,11
        jb      NEAR $L$aesenclast5
        movups  xmm0,XMMWORD[64+r15]
DB      102,15,56,220,209
        movups  xmm1,XMMWORD[80+r15]
DB      102,15,56,220,208
        je      NEAR $L$aesenclast5
        movups  xmm0,XMMWORD[96+r15]
DB      102,15,56,220,209
        movups  xmm1,XMMWORD[112+r15]
DB      102,15,56,220,208
$L$aesenclast5:
DB      102,15,56,221,209
        movups  xmm0,XMMWORD[((16-112))+r15]
        xor     esi,eax
        ror     ebp,7
        add     ecx,edx
        add     ebx,DWORD[56+rsp]
        xor     esi,ebp
        mov     edi,ecx
        rol     ecx,5
        add     ebx,esi
        xor     edi,ebp
        ror     edx,7
        add     ebx,ecx
        add     eax,DWORD[60+rsp]
        xor     edi,edx
        mov     esi,ebx
        rol     ebx,5
        add     eax,edi
        ror     ecx,7
        add     eax,ebx
        movups  XMMWORD[48+r12*1+r13],xmm2
        mov     r8,QWORD[88+rsp]

        add     eax,DWORD[r9]
        add     esi,DWORD[4+r9]
        add     ecx,DWORD[8+r9]
        mov     DWORD[r9],eax
        add     edx,DWORD[12+r9]
        mov     DWORD[4+r9],esi
        add     ebp,DWORD[16+r9]
        mov     DWORD[8+r9],ecx
        mov     DWORD[12+r9],edx
        mov     DWORD[16+r9],ebp
        movups  XMMWORD[r8],xmm2
        movaps  xmm6,XMMWORD[((96+0))+rsp]
        movaps  xmm7,XMMWORD[((96+16))+rsp]
        movaps  xmm8,XMMWORD[((96+32))+rsp]
        movaps  xmm9,XMMWORD[((96+48))+rsp]
        movaps  xmm10,XMMWORD[((96+64))+rsp]
        movaps  xmm11,XMMWORD[((96+80))+rsp]
        movaps  xmm12,XMMWORD[((96+96))+rsp]
        movaps  xmm13,XMMWORD[((96+112))+rsp]
        movaps  xmm14,XMMWORD[((96+128))+rsp]
        movaps  xmm15,XMMWORD[((96+144))+rsp]
        lea     rsi,[264+rsp]

        mov     r15,QWORD[rsi]

        mov     r14,QWORD[8+rsi]

        mov     r13,QWORD[16+rsi]

        mov     r12,QWORD[24+rsi]

        mov     rbp,QWORD[32+rsi]

        mov     rbx,QWORD[40+rsi]

        lea     rsp,[48+rsi]

$L$epilogue_ssse3:
        mov     rdi,QWORD[8+rsp]        ;WIN64 epilogue
        mov     rsi,QWORD[16+rsp]
        DB      0F3h,0C3h               ;repret

$L$SEH_end_aesni_cbc_sha1_enc_ssse3:
ALIGN   64
K_XX_XX:
        DD      0x5a827999,0x5a827999,0x5a827999,0x5a827999
        DD      0x6ed9eba1,0x6ed9eba1,0x6ed9eba1,0x6ed9eba1
        DD      0x8f1bbcdc,0x8f1bbcdc,0x8f1bbcdc,0x8f1bbcdc
        DD      0xca62c1d6,0xca62c1d6,0xca62c1d6,0xca62c1d6
        DD      0x00010203,0x04050607,0x08090a0b,0x0c0d0e0f
DB      0xf,0xe,0xd,0xc,0xb,0xa,0x9,0x8,0x7,0x6,0x5,0x4,0x3,0x2,0x1,0x0

DB      65,69,83,78,73,45,67,66,67,43,83,72,65,49,32,115
DB      116,105,116,99,104,32,102,111,114,32,120,56,54,95,54,52
DB      44,32,67,82,89,80,84,79,71,65,77,83,32,98,121,32
DB      60,97,112,112,114,111,64,111,112,101,110,115,115,108,46,111
DB      114,103,62,0
ALIGN   64

ALIGN   32
aesni_cbc_sha1_enc_shaext:
        mov     QWORD[8+rsp],rdi        ;WIN64 prologue
        mov     QWORD[16+rsp],rsi
        mov     rax,rsp
$L$SEH_begin_aesni_cbc_sha1_enc_shaext:
        mov     rdi,rcx
        mov     rsi,rdx
        mov     rdx,r8
        mov     rcx,r9
        mov     r8,QWORD[40+rsp]
        mov     r9,QWORD[48+rsp]



        mov     r10,QWORD[56+rsp]
        lea     rsp,[((-168))+rsp]
        movaps  XMMWORD[(-8-160)+rax],xmm6
        movaps  XMMWORD[(-8-144)+rax],xmm7
        movaps  XMMWORD[(-8-128)+rax],xmm8
        movaps  XMMWORD[(-8-112)+rax],xmm9
        movaps  XMMWORD[(-8-96)+rax],xmm10
        movaps  XMMWORD[(-8-80)+rax],xmm11
        movaps  XMMWORD[(-8-64)+rax],xmm12
        movaps  XMMWORD[(-8-48)+rax],xmm13
        movaps  XMMWORD[(-8-32)+rax],xmm14
        movaps  XMMWORD[(-8-16)+rax],xmm15
$L$prologue_shaext:
        movdqu  xmm8,XMMWORD[r9]
        movd    xmm9,DWORD[16+r9]
        movdqa  xmm7,XMMWORD[((K_XX_XX+80))]

        mov     r11d,DWORD[240+rcx]
        sub     rsi,rdi
        movups  xmm15,XMMWORD[rcx]
        movups  xmm2,XMMWORD[r8]
        movups  xmm0,XMMWORD[16+rcx]
        lea     rcx,[112+rcx]

        pshufd  xmm8,xmm8,27
        pshufd  xmm9,xmm9,27
        jmp     NEAR $L$oop_shaext

ALIGN   16
$L$oop_shaext:
        movups  xmm14,XMMWORD[rdi]
        xorps   xmm14,xmm15
        xorps   xmm2,xmm14
        movups  xmm1,XMMWORD[((-80))+rcx]
DB      102,15,56,220,208
        movdqu  xmm3,XMMWORD[r10]
        movdqa  xmm12,xmm9
DB      102,15,56,0,223
        movdqu  xmm4,XMMWORD[16+r10]
        movdqa  xmm11,xmm8
        movups  xmm0,XMMWORD[((-64))+rcx]
DB      102,15,56,220,209
DB      102,15,56,0,231

        paddd   xmm9,xmm3
        movdqu  xmm5,XMMWORD[32+r10]
        lea     r10,[64+r10]
        pxor    xmm3,xmm12
        movups  xmm1,XMMWORD[((-48))+rcx]
DB      102,15,56,220,208
        pxor    xmm3,xmm12
        movdqa  xmm10,xmm8
DB      102,15,56,0,239
DB      69,15,58,204,193,0
DB      68,15,56,200,212
        movups  xmm0,XMMWORD[((-32))+rcx]
DB      102,15,56,220,209
DB      15,56,201,220
        movdqu  xmm6,XMMWORD[((-16))+r10]
        movdqa  xmm9,xmm8
DB      102,15,56,0,247
        movups  xmm1,XMMWORD[((-16))+rcx]
DB      102,15,56,220,208
DB      69,15,58,204,194,0
DB      68,15,56,200,205
        pxor    xmm3,xmm5
DB      15,56,201,229
        movups  xmm0,XMMWORD[rcx]
DB      102,15,56,220,209
        movdqa  xmm10,xmm8
DB      69,15,58,204,193,0
DB      68,15,56,200,214
        movups  xmm1,XMMWORD[16+rcx]
DB      102,15,56,220,208
DB      15,56,202,222
        pxor    xmm4,xmm6
DB      15,56,201,238
        movups  xmm0,XMMWORD[32+rcx]
DB      102,15,56,220,209
        movdqa  xmm9,xmm8
DB      69,15,58,204,194,0
DB      68,15,56,200,203
        movups  xmm1,XMMWORD[48+rcx]
DB      102,15,56,220,208
DB      15,56,202,227
        pxor    xmm5,xmm3
DB      15,56,201,243
        cmp     r11d,11
        jb      NEAR $L$aesenclast6
        movups  xmm0,XMMWORD[64+rcx]
DB      102,15,56,220,209
        movups  xmm1,XMMWORD[80+rcx]
DB      102,15,56,220,208
        je      NEAR $L$aesenclast6
        movups  xmm0,XMMWORD[96+rcx]
DB      102,15,56,220,209
        movups  xmm1,XMMWORD[112+rcx]
DB      102,15,56,220,208
$L$aesenclast6:
DB      102,15,56,221,209
        movups  xmm0,XMMWORD[((16-112))+rcx]
        movdqa  xmm10,xmm8
DB      69,15,58,204,193,0
DB      68,15,56,200,212
        movups  xmm14,XMMWORD[16+rdi]
        xorps   xmm14,xmm15
        movups  XMMWORD[rdi*1+rsi],xmm2
        xorps   xmm2,xmm14
        movups  xmm1,XMMWORD[((-80))+rcx]
DB      102,15,56,220,208
DB      15,56,202,236
        pxor    xmm6,xmm4
DB      15,56,201,220
        movups  xmm0,XMMWORD[((-64))+rcx]
DB      102,15,56,220,209
        movdqa  xmm9,xmm8
DB      69,15,58,204,194,1
DB      68,15,56,200,205
        movups  xmm1,XMMWORD[((-48))+rcx]
DB      102,15,56,220,208
DB      15,56,202,245
        pxor    xmm3,xmm5
DB      15,56,201,229
        movups  xmm0,XMMWORD[((-32))+rcx]
DB      102,15,56,220,209
        movdqa  xmm10,xmm8
DB      69,15,58,204,193,1
DB      68,15,56,200,214
        movups  xmm1,XMMWORD[((-16))+rcx]
DB      102,15,56,220,208
DB      15,56,202,222
        pxor    xmm4,xmm6
DB      15,56,201,238
        movups  xmm0,XMMWORD[rcx]
DB      102,15,56,220,209
        movdqa  xmm9,xmm8
DB      69,15,58,204,194,1
DB      68,15,56,200,203
        movups  xmm1,XMMWORD[16+rcx]
DB      102,15,56,220,208
DB      15,56,202,227
        pxor    xmm5,xmm3
DB      15,56,201,243
        movups  xmm0,XMMWORD[32+rcx]
DB      102,15,56,220,209
        movdqa  xmm10,xmm8
DB      69,15,58,204,193,1
DB      68,15,56,200,212
        movups  xmm1,XMMWORD[48+rcx]
DB      102,15,56,220,208
DB      15,56,202,236
        pxor    xmm6,xmm4
DB      15,56,201,220
        cmp     r11d,11
        jb      NEAR $L$aesenclast7
        movups  xmm0,XMMWORD[64+rcx]
DB      102,15,56,220,209
        movups  xmm1,XMMWORD[80+rcx]
DB      102,15,56,220,208
        je      NEAR $L$aesenclast7
        movups  xmm0,XMMWORD[96+rcx]
DB      102,15,56,220,209
        movups  xmm1,XMMWORD[112+rcx]
DB      102,15,56,220,208
$L$aesenclast7:
DB      102,15,56,221,209
        movups  xmm0,XMMWORD[((16-112))+rcx]
        movdqa  xmm9,xmm8
DB      69,15,58,204,194,1
DB      68,15,56,200,205
        movups  xmm14,XMMWORD[32+rdi]
        xorps   xmm14,xmm15
        movups  XMMWORD[16+rdi*1+rsi],xmm2
        xorps   xmm2,xmm14
        movups  xmm1,XMMWORD[((-80))+rcx]
DB      102,15,56,220,208
DB      15,56,202,245
        pxor    xmm3,xmm5
DB      15,56,201,229
        movups  xmm0,XMMWORD[((-64))+rcx]
DB      102,15,56,220,209
        movdqa  xmm10,xmm8
DB      69,15,58,204,193,2
DB      68,15,56,200,214
        movups  xmm1,XMMWORD[((-48))+rcx]
DB      102,15,56,220,208
DB      15,56,202,222
        pxor    xmm4,xmm6
DB      15,56,201,238
        movups  xmm0,XMMWORD[((-32))+rcx]
DB      102,15,56,220,209
        movdqa  xmm9,xmm8
DB      69,15,58,204,194,2
DB      68,15,56,200,203
        movups  xmm1,XMMWORD[((-16))+rcx]
DB      102,15,56,220,208
DB      15,56,202,227
        pxor    xmm5,xmm3
DB      15,56,201,243
        movups  xmm0,XMMWORD[rcx]
DB      102,15,56,220,209
        movdqa  xmm10,xmm8
DB      69,15,58,204,193,2
DB      68,15,56,200,212
        movups  xmm1,XMMWORD[16+rcx]
DB      102,15,56,220,208
DB      15,56,202,236
        pxor    xmm6,xmm4
DB      15,56,201,220
        movups  xmm0,XMMWORD[32+rcx]
DB      102,15,56,220,209
        movdqa  xmm9,xmm8
DB      69,15,58,204,194,2
DB      68,15,56,200,205
        movups  xmm1,XMMWORD[48+rcx]
DB      102,15,56,220,208
DB      15,56,202,245
        pxor    xmm3,xmm5
DB      15,56,201,229
        cmp     r11d,11
        jb      NEAR $L$aesenclast8
        movups  xmm0,XMMWORD[64+rcx]
DB      102,15,56,220,209
        movups  xmm1,XMMWORD[80+rcx]
DB      102,15,56,220,208
        je      NEAR $L$aesenclast8
        movups  xmm0,XMMWORD[96+rcx]
DB      102,15,56,220,209
        movups  xmm1,XMMWORD[112+rcx]
DB      102,15,56,220,208
$L$aesenclast8:
DB      102,15,56,221,209
        movups  xmm0,XMMWORD[((16-112))+rcx]
        movdqa  xmm10,xmm8
DB      69,15,58,204,193,2
DB      68,15,56,200,214
        movups  xmm14,XMMWORD[48+rdi]
        xorps   xmm14,xmm15
        movups  XMMWORD[32+rdi*1+rsi],xmm2
        xorps   xmm2,xmm14
        movups  xmm1,XMMWORD[((-80))+rcx]
DB      102,15,56,220,208
DB      15,56,202,222
        pxor    xmm4,xmm6
DB      15,56,201,238
        movups  xmm0,XMMWORD[((-64))+rcx]
DB      102,15,56,220,209
        movdqa  xmm9,xmm8
DB      69,15,58,204,194,3
DB      68,15,56,200,203
        movups  xmm1,XMMWORD[((-48))+rcx]
DB      102,15,56,220,208
DB      15,56,202,227
        pxor    xmm5,xmm3
DB      15,56,201,243
        movups  xmm0,XMMWORD[((-32))+rcx]
DB      102,15,56,220,209
        movdqa  xmm10,xmm8
DB      69,15,58,204,193,3
DB      68,15,56,200,212
DB      15,56,202,236
        pxor    xmm6,xmm4
        movups  xmm1,XMMWORD[((-16))+rcx]
DB      102,15,56,220,208
        movdqa  xmm9,xmm8
DB      69,15,58,204,194,3
DB      68,15,56,200,205
DB      15,56,202,245
        movups  xmm0,XMMWORD[rcx]
DB      102,15,56,220,209
        movdqa  xmm5,xmm12
        movdqa  xmm10,xmm8
DB      69,15,58,204,193,3
DB      68,15,56,200,214
        movups  xmm1,XMMWORD[16+rcx]
DB      102,15,56,220,208
        movdqa  xmm9,xmm8
DB      69,15,58,204,194,3
DB      68,15,56,200,205
        movups  xmm0,XMMWORD[32+rcx]
DB      102,15,56,220,209
        movups  xmm1,XMMWORD[48+rcx]
DB      102,15,56,220,208
        cmp     r11d,11
        jb      NEAR $L$aesenclast9
        movups  xmm0,XMMWORD[64+rcx]
DB      102,15,56,220,209
        movups  xmm1,XMMWORD[80+rcx]
DB      102,15,56,220,208
        je      NEAR $L$aesenclast9
        movups  xmm0,XMMWORD[96+rcx]
DB      102,15,56,220,209
        movups  xmm1,XMMWORD[112+rcx]
DB      102,15,56,220,208
$L$aesenclast9:
DB      102,15,56,221,209
        movups  xmm0,XMMWORD[((16-112))+rcx]
        dec     rdx

        paddd   xmm8,xmm11
        movups  XMMWORD[48+rdi*1+rsi],xmm2
        lea     rdi,[64+rdi]
        jnz     NEAR $L$oop_shaext

        pshufd  xmm8,xmm8,27
        pshufd  xmm9,xmm9,27
        movups  XMMWORD[r8],xmm2
        movdqu  XMMWORD[r9],xmm8
        movd    DWORD[16+r9],xmm9
        movaps  xmm6,XMMWORD[((-8-160))+rax]
        movaps  xmm7,XMMWORD[((-8-144))+rax]
        movaps  xmm8,XMMWORD[((-8-128))+rax]
        movaps  xmm9,XMMWORD[((-8-112))+rax]
        movaps  xmm10,XMMWORD[((-8-96))+rax]
        movaps  xmm11,XMMWORD[((-8-80))+rax]
        movaps  xmm12,XMMWORD[((-8-64))+rax]
        movaps  xmm13,XMMWORD[((-8-48))+rax]
        movaps  xmm14,XMMWORD[((-8-32))+rax]
        movaps  xmm15,XMMWORD[((-8-16))+rax]
        mov     rsp,rax
$L$epilogue_shaext:
        mov     rdi,QWORD[8+rsp]        ;WIN64 epilogue
        mov     rsi,QWORD[16+rsp]
        DB      0F3h,0C3h               ;repret

$L$SEH_end_aesni_cbc_sha1_enc_shaext:
EXTERN  __imp_RtlVirtualUnwind

ALIGN   16
ssse3_handler:
        push    rsi
        push    rdi
        push    rbx
        push    rbp
        push    r12
        push    r13
        push    r14
        push    r15
        pushfq
        sub     rsp,64

        mov     rax,QWORD[120+r8]
        mov     rbx,QWORD[248+r8]

        mov     rsi,QWORD[8+r9]
        mov     r11,QWORD[56+r9]

        mov     r10d,DWORD[r11]
        lea     r10,[r10*1+rsi]
        cmp     rbx,r10
        jb      NEAR $L$common_seh_tail

        mov     rax,QWORD[152+r8]

        mov     r10d,DWORD[4+r11]
        lea     r10,[r10*1+rsi]
        cmp     rbx,r10
        jae     NEAR $L$common_seh_tail
        lea     r10,[aesni_cbc_sha1_enc_shaext]
        cmp     rbx,r10
        jb      NEAR $L$seh_no_shaext

        lea     rsi,[rax]
        lea     rdi,[512+r8]
        mov     ecx,20
        DD      0xa548f3fc
        lea     rax,[168+rax]
        jmp     NEAR $L$common_seh_tail
$L$seh_no_shaext:
        lea     rsi,[96+rax]
        lea     rdi,[512+r8]
        mov     ecx,20
        DD      0xa548f3fc
        lea     rax,[264+rax]

        mov     r15,QWORD[rax]
        mov     r14,QWORD[8+rax]
        mov     r13,QWORD[16+rax]
        mov     r12,QWORD[24+rax]
        mov     rbp,QWORD[32+rax]
        mov     rbx,QWORD[40+rax]
        lea     rax,[48+rax]
        mov     QWORD[144+r8],rbx
        mov     QWORD[160+r8],rbp
        mov     QWORD[216+r8],r12
        mov     QWORD[224+r8],r13
        mov     QWORD[232+r8],r14
        mov     QWORD[240+r8],r15

$L$common_seh_tail:
        mov     rdi,QWORD[8+rax]
        mov     rsi,QWORD[16+rax]
        mov     QWORD[152+r8],rax
        mov     QWORD[168+r8],rsi
        mov     QWORD[176+r8],rdi

        mov     rdi,QWORD[40+r9]
        mov     rsi,r8
        mov     ecx,154
        DD      0xa548f3fc

        mov     rsi,r9
        xor     rcx,rcx
        mov     rdx,QWORD[8+rsi]
        mov     r8,QWORD[rsi]
        mov     r9,QWORD[16+rsi]
        mov     r10,QWORD[40+rsi]
        lea     r11,[56+rsi]
        lea     r12,[24+rsi]
        mov     QWORD[32+rsp],r10
        mov     QWORD[40+rsp],r11
        mov     QWORD[48+rsp],r12
        mov     QWORD[56+rsp],rcx
        call    QWORD[__imp_RtlVirtualUnwind]

        mov     eax,1
        add     rsp,64
        popfq
        pop     r15
        pop     r14
        pop     r13
        pop     r12
        pop     rbp
        pop     rbx
        pop     rdi
        pop     rsi
        DB      0F3h,0C3h               ;repret


section .pdata rdata align=4
ALIGN   4
        DD      $L$SEH_begin_aesni_cbc_sha1_enc_ssse3 wrt ..imagebase
        DD      $L$SEH_end_aesni_cbc_sha1_enc_ssse3 wrt ..imagebase
        DD      $L$SEH_info_aesni_cbc_sha1_enc_ssse3 wrt ..imagebase
        DD      $L$SEH_begin_aesni_cbc_sha1_enc_shaext wrt ..imagebase
        DD      $L$SEH_end_aesni_cbc_sha1_enc_shaext wrt ..imagebase
        DD      $L$SEH_info_aesni_cbc_sha1_enc_shaext wrt ..imagebase
section .xdata rdata align=8
ALIGN   8
$L$SEH_info_aesni_cbc_sha1_enc_ssse3:
DB      9,0,0,0
        DD      ssse3_handler wrt ..imagebase
        DD      $L$prologue_ssse3 wrt ..imagebase,$L$epilogue_ssse3 wrt ..imagebase
$L$SEH_info_aesni_cbc_sha1_enc_shaext:
DB      9,0,0,0
        DD      ssse3_handler wrt ..imagebase
        DD      $L$prologue_shaext wrt ..imagebase,$L$epilogue_shaext wrt ..imagebase
