deps/openssl/asm/x64-elf-gas/rc4/rc4-md5-x86_64.s

Summary

Maintainability
Test Coverage
.text

.align    16

.globl    rc4_md5_enc
.type    rc4_md5_enc,@function
rc4_md5_enc:
    cmpq    $0,%r9
    je    .Labort
    pushq    %rbx
    pushq    %rbp
    pushq    %r12
    pushq    %r13
    pushq    %r14
    pushq    %r15
    subq    $40,%rsp
.Lbody:
    movq    %rcx,%r11
    movq    %r9,%r12
    movq    %rsi,%r13
    movq    %rdx,%r14
    movq    %r8,%r15
    xorq    %rbp,%rbp
    xorq    %rcx,%rcx

    leaq    8(%rdi),%rdi
    movb    -8(%rdi),%bpl
    movb    -4(%rdi),%cl

    incb    %bpl
    subq    %r13,%r14
    movl    (%rdi,%rbp,4),%eax
    addb    %al,%cl
    leaq    (%rdi,%rbp,4),%rsi
    shlq    $6,%r12
    addq    %r15,%r12
    movq    %r12,16(%rsp)

    movq    %r11,24(%rsp)
    movl    0(%r11),%r8d
    movl    4(%r11),%r9d
    movl    8(%r11),%r10d
    movl    12(%r11),%r11d
    jmp    .Loop

.align    16
.Loop:
    movl    %r8d,0(%rsp)
    movl    %r9d,4(%rsp)
    movl    %r10d,8(%rsp)
    movl    %r11d,%r12d
    movl    %r11d,12(%rsp)
    pxor    %xmm0,%xmm0
    movl    (%rdi,%rcx,4),%edx
    xorl    %r10d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    andl    %r9d,%r12d
    addl    0(%r15),%r8d
    addb    %dl,%al
    movl    4(%rsi),%ebx
    addl    $3614090360,%r8d
    xorl    %r11d,%r12d
    movzbl    %al,%eax
    movl    %edx,0(%rsi)
    addl    %r12d,%r8d
    addb    %bl,%cl
    roll    $7,%r8d
    movl    %r10d,%r12d
    movd    (%rdi,%rax,4),%xmm0

    addl    %r9d,%r8d
    pxor    %xmm1,%xmm1
    movl    (%rdi,%rcx,4),%edx
    xorl    %r9d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    andl    %r8d,%r12d
    addl    4(%r15),%r11d
    addb    %dl,%bl
    movl    8(%rsi),%eax
    addl    $3905402710,%r11d
    xorl    %r10d,%r12d
    movzbl    %bl,%ebx
    movl    %edx,4(%rsi)
    addl    %r12d,%r11d
    addb    %al,%cl
    roll    $12,%r11d
    movl    %r9d,%r12d
    movd    (%rdi,%rbx,4),%xmm1

    addl    %r8d,%r11d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r8d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    andl    %r11d,%r12d
    addl    8(%r15),%r10d
    addb    %dl,%al
    movl    12(%rsi),%ebx
    addl    $606105819,%r10d
    xorl    %r9d,%r12d
    movzbl    %al,%eax
    movl    %edx,8(%rsi)
    addl    %r12d,%r10d
    addb    %bl,%cl
    roll    $17,%r10d
    movl    %r8d,%r12d
    pinsrw    $1,(%rdi,%rax,4),%xmm0

    addl    %r11d,%r10d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r11d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    andl    %r10d,%r12d
    addl    12(%r15),%r9d
    addb    %dl,%bl
    movl    16(%rsi),%eax
    addl    $3250441966,%r9d
    xorl    %r8d,%r12d
    movzbl    %bl,%ebx
    movl    %edx,12(%rsi)
    addl    %r12d,%r9d
    addb    %al,%cl
    roll    $22,%r9d
    movl    %r11d,%r12d
    pinsrw    $1,(%rdi,%rbx,4),%xmm1

    addl    %r10d,%r9d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r10d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    andl    %r9d,%r12d
    addl    16(%r15),%r8d
    addb    %dl,%al
    movl    20(%rsi),%ebx
    addl    $4118548399,%r8d
    xorl    %r11d,%r12d
    movzbl    %al,%eax
    movl    %edx,16(%rsi)
    addl    %r12d,%r8d
    addb    %bl,%cl
    roll    $7,%r8d
    movl    %r10d,%r12d
    pinsrw    $2,(%rdi,%rax,4),%xmm0

    addl    %r9d,%r8d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r9d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    andl    %r8d,%r12d
    addl    20(%r15),%r11d
    addb    %dl,%bl
    movl    24(%rsi),%eax
    addl    $1200080426,%r11d
    xorl    %r10d,%r12d
    movzbl    %bl,%ebx
    movl    %edx,20(%rsi)
    addl    %r12d,%r11d
    addb    %al,%cl
    roll    $12,%r11d
    movl    %r9d,%r12d
    pinsrw    $2,(%rdi,%rbx,4),%xmm1

    addl    %r8d,%r11d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r8d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    andl    %r11d,%r12d
    addl    24(%r15),%r10d
    addb    %dl,%al
    movl    28(%rsi),%ebx
    addl    $2821735955,%r10d
    xorl    %r9d,%r12d
    movzbl    %al,%eax
    movl    %edx,24(%rsi)
    addl    %r12d,%r10d
    addb    %bl,%cl
    roll    $17,%r10d
    movl    %r8d,%r12d
    pinsrw    $3,(%rdi,%rax,4),%xmm0

    addl    %r11d,%r10d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r11d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    andl    %r10d,%r12d
    addl    28(%r15),%r9d
    addb    %dl,%bl
    movl    32(%rsi),%eax
    addl    $4249261313,%r9d
    xorl    %r8d,%r12d
    movzbl    %bl,%ebx
    movl    %edx,28(%rsi)
    addl    %r12d,%r9d
    addb    %al,%cl
    roll    $22,%r9d
    movl    %r11d,%r12d
    pinsrw    $3,(%rdi,%rbx,4),%xmm1

    addl    %r10d,%r9d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r10d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    andl    %r9d,%r12d
    addl    32(%r15),%r8d
    addb    %dl,%al
    movl    36(%rsi),%ebx
    addl    $1770035416,%r8d
    xorl    %r11d,%r12d
    movzbl    %al,%eax
    movl    %edx,32(%rsi)
    addl    %r12d,%r8d
    addb    %bl,%cl
    roll    $7,%r8d
    movl    %r10d,%r12d
    pinsrw    $4,(%rdi,%rax,4),%xmm0

    addl    %r9d,%r8d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r9d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    andl    %r8d,%r12d
    addl    36(%r15),%r11d
    addb    %dl,%bl
    movl    40(%rsi),%eax
    addl    $2336552879,%r11d
    xorl    %r10d,%r12d
    movzbl    %bl,%ebx
    movl    %edx,36(%rsi)
    addl    %r12d,%r11d
    addb    %al,%cl
    roll    $12,%r11d
    movl    %r9d,%r12d
    pinsrw    $4,(%rdi,%rbx,4),%xmm1

    addl    %r8d,%r11d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r8d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    andl    %r11d,%r12d
    addl    40(%r15),%r10d
    addb    %dl,%al
    movl    44(%rsi),%ebx
    addl    $4294925233,%r10d
    xorl    %r9d,%r12d
    movzbl    %al,%eax
    movl    %edx,40(%rsi)
    addl    %r12d,%r10d
    addb    %bl,%cl
    roll    $17,%r10d
    movl    %r8d,%r12d
    pinsrw    $5,(%rdi,%rax,4),%xmm0

    addl    %r11d,%r10d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r11d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    andl    %r10d,%r12d
    addl    44(%r15),%r9d
    addb    %dl,%bl
    movl    48(%rsi),%eax
    addl    $2304563134,%r9d
    xorl    %r8d,%r12d
    movzbl    %bl,%ebx
    movl    %edx,44(%rsi)
    addl    %r12d,%r9d
    addb    %al,%cl
    roll    $22,%r9d
    movl    %r11d,%r12d
    pinsrw    $5,(%rdi,%rbx,4),%xmm1

    addl    %r10d,%r9d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r10d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    andl    %r9d,%r12d
    addl    48(%r15),%r8d
    addb    %dl,%al
    movl    52(%rsi),%ebx
    addl    $1804603682,%r8d
    xorl    %r11d,%r12d
    movzbl    %al,%eax
    movl    %edx,48(%rsi)
    addl    %r12d,%r8d
    addb    %bl,%cl
    roll    $7,%r8d
    movl    %r10d,%r12d
    pinsrw    $6,(%rdi,%rax,4),%xmm0

    addl    %r9d,%r8d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r9d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    andl    %r8d,%r12d
    addl    52(%r15),%r11d
    addb    %dl,%bl
    movl    56(%rsi),%eax
    addl    $4254626195,%r11d
    xorl    %r10d,%r12d
    movzbl    %bl,%ebx
    movl    %edx,52(%rsi)
    addl    %r12d,%r11d
    addb    %al,%cl
    roll    $12,%r11d
    movl    %r9d,%r12d
    pinsrw    $6,(%rdi,%rbx,4),%xmm1

    addl    %r8d,%r11d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r8d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    andl    %r11d,%r12d
    addl    56(%r15),%r10d
    addb    %dl,%al
    movl    60(%rsi),%ebx
    addl    $2792965006,%r10d
    xorl    %r9d,%r12d
    movzbl    %al,%eax
    movl    %edx,56(%rsi)
    addl    %r12d,%r10d
    addb    %bl,%cl
    roll    $17,%r10d
    movl    %r8d,%r12d
    pinsrw    $7,(%rdi,%rax,4),%xmm0

    addl    %r11d,%r10d
    movdqu    (%r13),%xmm2
    movl    (%rdi,%rcx,4),%edx
    xorl    %r11d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    andl    %r10d,%r12d
    addl    60(%r15),%r9d
    addb    %dl,%bl
    movl    64(%rsi),%eax
    addl    $1236535329,%r9d
    xorl    %r8d,%r12d
    movzbl    %bl,%ebx
    movl    %edx,60(%rsi)
    addl    %r12d,%r9d
    addb    %al,%cl
    roll    $22,%r9d
    movl    %r10d,%r12d
    pinsrw    $7,(%rdi,%rbx,4),%xmm1

    addl    %r10d,%r9d
    psllq    $8,%xmm1
    pxor    %xmm0,%xmm2
    pxor    %xmm1,%xmm2
    pxor    %xmm0,%xmm0
    movl    (%rdi,%rcx,4),%edx
    xorl    %r9d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    andl    %r11d,%r12d
    addl    4(%r15),%r8d
    addb    %dl,%al
    movl    68(%rsi),%ebx
    addl    $4129170786,%r8d
    xorl    %r10d,%r12d
    movzbl    %al,%eax
    movl    %edx,64(%rsi)
    addl    %r12d,%r8d
    addb    %bl,%cl
    roll    $5,%r8d
    movl    %r9d,%r12d
    movd    (%rdi,%rax,4),%xmm0

    addl    %r9d,%r8d
    pxor    %xmm1,%xmm1
    movl    (%rdi,%rcx,4),%edx
    xorl    %r8d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    andl    %r10d,%r12d
    addl    24(%r15),%r11d
    addb    %dl,%bl
    movl    72(%rsi),%eax
    addl    $3225465664,%r11d
    xorl    %r9d,%r12d
    movzbl    %bl,%ebx
    movl    %edx,68(%rsi)
    addl    %r12d,%r11d
    addb    %al,%cl
    roll    $9,%r11d
    movl    %r8d,%r12d
    movd    (%rdi,%rbx,4),%xmm1

    addl    %r8d,%r11d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r11d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    andl    %r9d,%r12d
    addl    44(%r15),%r10d
    addb    %dl,%al
    movl    76(%rsi),%ebx
    addl    $643717713,%r10d
    xorl    %r8d,%r12d
    movzbl    %al,%eax
    movl    %edx,72(%rsi)
    addl    %r12d,%r10d
    addb    %bl,%cl
    roll    $14,%r10d
    movl    %r11d,%r12d
    pinsrw    $1,(%rdi,%rax,4),%xmm0

    addl    %r11d,%r10d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r10d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    andl    %r8d,%r12d
    addl    0(%r15),%r9d
    addb    %dl,%bl
    movl    80(%rsi),%eax
    addl    $3921069994,%r9d
    xorl    %r11d,%r12d
    movzbl    %bl,%ebx
    movl    %edx,76(%rsi)
    addl    %r12d,%r9d
    addb    %al,%cl
    roll    $20,%r9d
    movl    %r10d,%r12d
    pinsrw    $1,(%rdi,%rbx,4),%xmm1

    addl    %r10d,%r9d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r9d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    andl    %r11d,%r12d
    addl    20(%r15),%r8d
    addb    %dl,%al
    movl    84(%rsi),%ebx
    addl    $3593408605,%r8d
    xorl    %r10d,%r12d
    movzbl    %al,%eax
    movl    %edx,80(%rsi)
    addl    %r12d,%r8d
    addb    %bl,%cl
    roll    $5,%r8d
    movl    %r9d,%r12d
    pinsrw    $2,(%rdi,%rax,4),%xmm0

    addl    %r9d,%r8d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r8d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    andl    %r10d,%r12d
    addl    40(%r15),%r11d
    addb    %dl,%bl
    movl    88(%rsi),%eax
    addl    $38016083,%r11d
    xorl    %r9d,%r12d
    movzbl    %bl,%ebx
    movl    %edx,84(%rsi)
    addl    %r12d,%r11d
    addb    %al,%cl
    roll    $9,%r11d
    movl    %r8d,%r12d
    pinsrw    $2,(%rdi,%rbx,4),%xmm1

    addl    %r8d,%r11d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r11d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    andl    %r9d,%r12d
    addl    60(%r15),%r10d
    addb    %dl,%al
    movl    92(%rsi),%ebx
    addl    $3634488961,%r10d
    xorl    %r8d,%r12d
    movzbl    %al,%eax
    movl    %edx,88(%rsi)
    addl    %r12d,%r10d
    addb    %bl,%cl
    roll    $14,%r10d
    movl    %r11d,%r12d
    pinsrw    $3,(%rdi,%rax,4),%xmm0

    addl    %r11d,%r10d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r10d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    andl    %r8d,%r12d
    addl    16(%r15),%r9d
    addb    %dl,%bl
    movl    96(%rsi),%eax
    addl    $3889429448,%r9d
    xorl    %r11d,%r12d
    movzbl    %bl,%ebx
    movl    %edx,92(%rsi)
    addl    %r12d,%r9d
    addb    %al,%cl
    roll    $20,%r9d
    movl    %r10d,%r12d
    pinsrw    $3,(%rdi,%rbx,4),%xmm1

    addl    %r10d,%r9d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r9d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    andl    %r11d,%r12d
    addl    36(%r15),%r8d
    addb    %dl,%al
    movl    100(%rsi),%ebx
    addl    $568446438,%r8d
    xorl    %r10d,%r12d
    movzbl    %al,%eax
    movl    %edx,96(%rsi)
    addl    %r12d,%r8d
    addb    %bl,%cl
    roll    $5,%r8d
    movl    %r9d,%r12d
    pinsrw    $4,(%rdi,%rax,4),%xmm0

    addl    %r9d,%r8d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r8d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    andl    %r10d,%r12d
    addl    56(%r15),%r11d
    addb    %dl,%bl
    movl    104(%rsi),%eax
    addl    $3275163606,%r11d
    xorl    %r9d,%r12d
    movzbl    %bl,%ebx
    movl    %edx,100(%rsi)
    addl    %r12d,%r11d
    addb    %al,%cl
    roll    $9,%r11d
    movl    %r8d,%r12d
    pinsrw    $4,(%rdi,%rbx,4),%xmm1

    addl    %r8d,%r11d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r11d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    andl    %r9d,%r12d
    addl    12(%r15),%r10d
    addb    %dl,%al
    movl    108(%rsi),%ebx
    addl    $4107603335,%r10d
    xorl    %r8d,%r12d
    movzbl    %al,%eax
    movl    %edx,104(%rsi)
    addl    %r12d,%r10d
    addb    %bl,%cl
    roll    $14,%r10d
    movl    %r11d,%r12d
    pinsrw    $5,(%rdi,%rax,4),%xmm0

    addl    %r11d,%r10d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r10d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    andl    %r8d,%r12d
    addl    32(%r15),%r9d
    addb    %dl,%bl
    movl    112(%rsi),%eax
    addl    $1163531501,%r9d
    xorl    %r11d,%r12d
    movzbl    %bl,%ebx
    movl    %edx,108(%rsi)
    addl    %r12d,%r9d
    addb    %al,%cl
    roll    $20,%r9d
    movl    %r10d,%r12d
    pinsrw    $5,(%rdi,%rbx,4),%xmm1

    addl    %r10d,%r9d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r9d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    andl    %r11d,%r12d
    addl    52(%r15),%r8d
    addb    %dl,%al
    movl    116(%rsi),%ebx
    addl    $2850285829,%r8d
    xorl    %r10d,%r12d
    movzbl    %al,%eax
    movl    %edx,112(%rsi)
    addl    %r12d,%r8d
    addb    %bl,%cl
    roll    $5,%r8d
    movl    %r9d,%r12d
    pinsrw    $6,(%rdi,%rax,4),%xmm0

    addl    %r9d,%r8d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r8d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    andl    %r10d,%r12d
    addl    8(%r15),%r11d
    addb    %dl,%bl
    movl    120(%rsi),%eax
    addl    $4243563512,%r11d
    xorl    %r9d,%r12d
    movzbl    %bl,%ebx
    movl    %edx,116(%rsi)
    addl    %r12d,%r11d
    addb    %al,%cl
    roll    $9,%r11d
    movl    %r8d,%r12d
    pinsrw    $6,(%rdi,%rbx,4),%xmm1

    addl    %r8d,%r11d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r11d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    andl    %r9d,%r12d
    addl    28(%r15),%r10d
    addb    %dl,%al
    movl    124(%rsi),%ebx
    addl    $1735328473,%r10d
    xorl    %r8d,%r12d
    movzbl    %al,%eax
    movl    %edx,120(%rsi)
    addl    %r12d,%r10d
    addb    %bl,%cl
    roll    $14,%r10d
    movl    %r11d,%r12d
    pinsrw    $7,(%rdi,%rax,4),%xmm0

    addl    %r11d,%r10d
    movdqu    16(%r13),%xmm3
    addb    $32,%bpl
    movl    (%rdi,%rcx,4),%edx
    xorl    %r10d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    andl    %r8d,%r12d
    addl    48(%r15),%r9d
    addb    %dl,%bl
    movl    0(%rdi,%rbp,4),%eax
    addl    $2368359562,%r9d
    xorl    %r11d,%r12d
    movzbl    %bl,%ebx
    movl    %edx,124(%rsi)
    addl    %r12d,%r9d
    addb    %al,%cl
    roll    $20,%r9d
    movl    %r11d,%r12d
    pinsrw    $7,(%rdi,%rbx,4),%xmm1

    addl    %r10d,%r9d
    movq    %rcx,%rsi
    xorq    %rcx,%rcx
    movb    %sil,%cl
    leaq    (%rdi,%rbp,4),%rsi
    psllq    $8,%xmm1
    pxor    %xmm0,%xmm3
    pxor    %xmm1,%xmm3
    pxor    %xmm0,%xmm0
    movl    (%rdi,%rcx,4),%edx
    xorl    %r10d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    xorl    %r9d,%r12d
    addl    20(%r15),%r8d
    addb    %dl,%al
    movl    4(%rsi),%ebx
    addl    $4294588738,%r8d
    movzbl    %al,%eax
    addl    %r12d,%r8d
    movl    %edx,0(%rsi)
    addb    %bl,%cl
    roll    $4,%r8d
    movl    %r10d,%r12d
    movd    (%rdi,%rax,4),%xmm0

    addl    %r9d,%r8d
    pxor    %xmm1,%xmm1
    movl    (%rdi,%rcx,4),%edx
    xorl    %r9d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    xorl    %r8d,%r12d
    addl    32(%r15),%r11d
    addb    %dl,%bl
    movl    8(%rsi),%eax
    addl    $2272392833,%r11d
    movzbl    %bl,%ebx
    addl    %r12d,%r11d
    movl    %edx,4(%rsi)
    addb    %al,%cl
    roll    $11,%r11d
    movl    %r9d,%r12d
    movd    (%rdi,%rbx,4),%xmm1

    addl    %r8d,%r11d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r8d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    xorl    %r11d,%r12d
    addl    44(%r15),%r10d
    addb    %dl,%al
    movl    12(%rsi),%ebx
    addl    $1839030562,%r10d
    movzbl    %al,%eax
    addl    %r12d,%r10d
    movl    %edx,8(%rsi)
    addb    %bl,%cl
    roll    $16,%r10d
    movl    %r8d,%r12d
    pinsrw    $1,(%rdi,%rax,4),%xmm0

    addl    %r11d,%r10d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r11d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    xorl    %r10d,%r12d
    addl    56(%r15),%r9d
    addb    %dl,%bl
    movl    16(%rsi),%eax
    addl    $4259657740,%r9d
    movzbl    %bl,%ebx
    addl    %r12d,%r9d
    movl    %edx,12(%rsi)
    addb    %al,%cl
    roll    $23,%r9d
    movl    %r11d,%r12d
    pinsrw    $1,(%rdi,%rbx,4),%xmm1

    addl    %r10d,%r9d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r10d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    xorl    %r9d,%r12d
    addl    4(%r15),%r8d
    addb    %dl,%al
    movl    20(%rsi),%ebx
    addl    $2763975236,%r8d
    movzbl    %al,%eax
    addl    %r12d,%r8d
    movl    %edx,16(%rsi)
    addb    %bl,%cl
    roll    $4,%r8d
    movl    %r10d,%r12d
    pinsrw    $2,(%rdi,%rax,4),%xmm0

    addl    %r9d,%r8d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r9d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    xorl    %r8d,%r12d
    addl    16(%r15),%r11d
    addb    %dl,%bl
    movl    24(%rsi),%eax
    addl    $1272893353,%r11d
    movzbl    %bl,%ebx
    addl    %r12d,%r11d
    movl    %edx,20(%rsi)
    addb    %al,%cl
    roll    $11,%r11d
    movl    %r9d,%r12d
    pinsrw    $2,(%rdi,%rbx,4),%xmm1

    addl    %r8d,%r11d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r8d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    xorl    %r11d,%r12d
    addl    28(%r15),%r10d
    addb    %dl,%al
    movl    28(%rsi),%ebx
    addl    $4139469664,%r10d
    movzbl    %al,%eax
    addl    %r12d,%r10d
    movl    %edx,24(%rsi)
    addb    %bl,%cl
    roll    $16,%r10d
    movl    %r8d,%r12d
    pinsrw    $3,(%rdi,%rax,4),%xmm0

    addl    %r11d,%r10d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r11d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    xorl    %r10d,%r12d
    addl    40(%r15),%r9d
    addb    %dl,%bl
    movl    32(%rsi),%eax
    addl    $3200236656,%r9d
    movzbl    %bl,%ebx
    addl    %r12d,%r9d
    movl    %edx,28(%rsi)
    addb    %al,%cl
    roll    $23,%r9d
    movl    %r11d,%r12d
    pinsrw    $3,(%rdi,%rbx,4),%xmm1

    addl    %r10d,%r9d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r10d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    xorl    %r9d,%r12d
    addl    52(%r15),%r8d
    addb    %dl,%al
    movl    36(%rsi),%ebx
    addl    $681279174,%r8d
    movzbl    %al,%eax
    addl    %r12d,%r8d
    movl    %edx,32(%rsi)
    addb    %bl,%cl
    roll    $4,%r8d
    movl    %r10d,%r12d
    pinsrw    $4,(%rdi,%rax,4),%xmm0

    addl    %r9d,%r8d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r9d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    xorl    %r8d,%r12d
    addl    0(%r15),%r11d
    addb    %dl,%bl
    movl    40(%rsi),%eax
    addl    $3936430074,%r11d
    movzbl    %bl,%ebx
    addl    %r12d,%r11d
    movl    %edx,36(%rsi)
    addb    %al,%cl
    roll    $11,%r11d
    movl    %r9d,%r12d
    pinsrw    $4,(%rdi,%rbx,4),%xmm1

    addl    %r8d,%r11d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r8d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    xorl    %r11d,%r12d
    addl    12(%r15),%r10d
    addb    %dl,%al
    movl    44(%rsi),%ebx
    addl    $3572445317,%r10d
    movzbl    %al,%eax
    addl    %r12d,%r10d
    movl    %edx,40(%rsi)
    addb    %bl,%cl
    roll    $16,%r10d
    movl    %r8d,%r12d
    pinsrw    $5,(%rdi,%rax,4),%xmm0

    addl    %r11d,%r10d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r11d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    xorl    %r10d,%r12d
    addl    24(%r15),%r9d
    addb    %dl,%bl
    movl    48(%rsi),%eax
    addl    $76029189,%r9d
    movzbl    %bl,%ebx
    addl    %r12d,%r9d
    movl    %edx,44(%rsi)
    addb    %al,%cl
    roll    $23,%r9d
    movl    %r11d,%r12d
    pinsrw    $5,(%rdi,%rbx,4),%xmm1

    addl    %r10d,%r9d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r10d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    xorl    %r9d,%r12d
    addl    36(%r15),%r8d
    addb    %dl,%al
    movl    52(%rsi),%ebx
    addl    $3654602809,%r8d
    movzbl    %al,%eax
    addl    %r12d,%r8d
    movl    %edx,48(%rsi)
    addb    %bl,%cl
    roll    $4,%r8d
    movl    %r10d,%r12d
    pinsrw    $6,(%rdi,%rax,4),%xmm0

    addl    %r9d,%r8d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r9d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    xorl    %r8d,%r12d
    addl    48(%r15),%r11d
    addb    %dl,%bl
    movl    56(%rsi),%eax
    addl    $3873151461,%r11d
    movzbl    %bl,%ebx
    addl    %r12d,%r11d
    movl    %edx,52(%rsi)
    addb    %al,%cl
    roll    $11,%r11d
    movl    %r9d,%r12d
    pinsrw    $6,(%rdi,%rbx,4),%xmm1

    addl    %r8d,%r11d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r8d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    xorl    %r11d,%r12d
    addl    60(%r15),%r10d
    addb    %dl,%al
    movl    60(%rsi),%ebx
    addl    $530742520,%r10d
    movzbl    %al,%eax
    addl    %r12d,%r10d
    movl    %edx,56(%rsi)
    addb    %bl,%cl
    roll    $16,%r10d
    movl    %r8d,%r12d
    pinsrw    $7,(%rdi,%rax,4),%xmm0

    addl    %r11d,%r10d
    movdqu    32(%r13),%xmm4
    movl    (%rdi,%rcx,4),%edx
    xorl    %r11d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    xorl    %r10d,%r12d
    addl    8(%r15),%r9d
    addb    %dl,%bl
    movl    64(%rsi),%eax
    addl    $3299628645,%r9d
    movzbl    %bl,%ebx
    addl    %r12d,%r9d
    movl    %edx,60(%rsi)
    addb    %al,%cl
    roll    $23,%r9d
    movl    $-1,%r12d
    pinsrw    $7,(%rdi,%rbx,4),%xmm1

    addl    %r10d,%r9d
    psllq    $8,%xmm1
    pxor    %xmm0,%xmm4
    pxor    %xmm1,%xmm4
    pxor    %xmm0,%xmm0
    movl    (%rdi,%rcx,4),%edx
    xorl    %r11d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    orl    %r9d,%r12d
    addl    0(%r15),%r8d
    addb    %dl,%al
    movl    68(%rsi),%ebx
    addl    $4096336452,%r8d
    movzbl    %al,%eax
    xorl    %r10d,%r12d
    movl    %edx,64(%rsi)
    addl    %r12d,%r8d
    addb    %bl,%cl
    roll    $6,%r8d
    movl    $-1,%r12d
    movd    (%rdi,%rax,4),%xmm0

    addl    %r9d,%r8d
    pxor    %xmm1,%xmm1
    movl    (%rdi,%rcx,4),%edx
    xorl    %r10d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    orl    %r8d,%r12d
    addl    28(%r15),%r11d
    addb    %dl,%bl
    movl    72(%rsi),%eax
    addl    $1126891415,%r11d
    movzbl    %bl,%ebx
    xorl    %r9d,%r12d
    movl    %edx,68(%rsi)
    addl    %r12d,%r11d
    addb    %al,%cl
    roll    $10,%r11d
    movl    $-1,%r12d
    movd    (%rdi,%rbx,4),%xmm1

    addl    %r8d,%r11d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r9d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    orl    %r11d,%r12d
    addl    56(%r15),%r10d
    addb    %dl,%al
    movl    76(%rsi),%ebx
    addl    $2878612391,%r10d
    movzbl    %al,%eax
    xorl    %r8d,%r12d
    movl    %edx,72(%rsi)
    addl    %r12d,%r10d
    addb    %bl,%cl
    roll    $15,%r10d
    movl    $-1,%r12d
    pinsrw    $1,(%rdi,%rax,4),%xmm0

    addl    %r11d,%r10d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r8d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    orl    %r10d,%r12d
    addl    20(%r15),%r9d
    addb    %dl,%bl
    movl    80(%rsi),%eax
    addl    $4237533241,%r9d
    movzbl    %bl,%ebx
    xorl    %r11d,%r12d
    movl    %edx,76(%rsi)
    addl    %r12d,%r9d
    addb    %al,%cl
    roll    $21,%r9d
    movl    $-1,%r12d
    pinsrw    $1,(%rdi,%rbx,4),%xmm1

    addl    %r10d,%r9d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r11d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    orl    %r9d,%r12d
    addl    48(%r15),%r8d
    addb    %dl,%al
    movl    84(%rsi),%ebx
    addl    $1700485571,%r8d
    movzbl    %al,%eax
    xorl    %r10d,%r12d
    movl    %edx,80(%rsi)
    addl    %r12d,%r8d
    addb    %bl,%cl
    roll    $6,%r8d
    movl    $-1,%r12d
    pinsrw    $2,(%rdi,%rax,4),%xmm0

    addl    %r9d,%r8d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r10d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    orl    %r8d,%r12d
    addl    12(%r15),%r11d
    addb    %dl,%bl
    movl    88(%rsi),%eax
    addl    $2399980690,%r11d
    movzbl    %bl,%ebx
    xorl    %r9d,%r12d
    movl    %edx,84(%rsi)
    addl    %r12d,%r11d
    addb    %al,%cl
    roll    $10,%r11d
    movl    $-1,%r12d
    pinsrw    $2,(%rdi,%rbx,4),%xmm1

    addl    %r8d,%r11d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r9d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    orl    %r11d,%r12d
    addl    40(%r15),%r10d
    addb    %dl,%al
    movl    92(%rsi),%ebx
    addl    $4293915773,%r10d
    movzbl    %al,%eax
    xorl    %r8d,%r12d
    movl    %edx,88(%rsi)
    addl    %r12d,%r10d
    addb    %bl,%cl
    roll    $15,%r10d
    movl    $-1,%r12d
    pinsrw    $3,(%rdi,%rax,4),%xmm0

    addl    %r11d,%r10d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r8d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    orl    %r10d,%r12d
    addl    4(%r15),%r9d
    addb    %dl,%bl
    movl    96(%rsi),%eax
    addl    $2240044497,%r9d
    movzbl    %bl,%ebx
    xorl    %r11d,%r12d
    movl    %edx,92(%rsi)
    addl    %r12d,%r9d
    addb    %al,%cl
    roll    $21,%r9d
    movl    $-1,%r12d
    pinsrw    $3,(%rdi,%rbx,4),%xmm1

    addl    %r10d,%r9d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r11d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    orl    %r9d,%r12d
    addl    32(%r15),%r8d
    addb    %dl,%al
    movl    100(%rsi),%ebx
    addl    $1873313359,%r8d
    movzbl    %al,%eax
    xorl    %r10d,%r12d
    movl    %edx,96(%rsi)
    addl    %r12d,%r8d
    addb    %bl,%cl
    roll    $6,%r8d
    movl    $-1,%r12d
    pinsrw    $4,(%rdi,%rax,4),%xmm0

    addl    %r9d,%r8d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r10d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    orl    %r8d,%r12d
    addl    60(%r15),%r11d
    addb    %dl,%bl
    movl    104(%rsi),%eax
    addl    $4264355552,%r11d
    movzbl    %bl,%ebx
    xorl    %r9d,%r12d
    movl    %edx,100(%rsi)
    addl    %r12d,%r11d
    addb    %al,%cl
    roll    $10,%r11d
    movl    $-1,%r12d
    pinsrw    $4,(%rdi,%rbx,4),%xmm1

    addl    %r8d,%r11d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r9d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    orl    %r11d,%r12d
    addl    24(%r15),%r10d
    addb    %dl,%al
    movl    108(%rsi),%ebx
    addl    $2734768916,%r10d
    movzbl    %al,%eax
    xorl    %r8d,%r12d
    movl    %edx,104(%rsi)
    addl    %r12d,%r10d
    addb    %bl,%cl
    roll    $15,%r10d
    movl    $-1,%r12d
    pinsrw    $5,(%rdi,%rax,4),%xmm0

    addl    %r11d,%r10d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r8d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    orl    %r10d,%r12d
    addl    52(%r15),%r9d
    addb    %dl,%bl
    movl    112(%rsi),%eax
    addl    $1309151649,%r9d
    movzbl    %bl,%ebx
    xorl    %r11d,%r12d
    movl    %edx,108(%rsi)
    addl    %r12d,%r9d
    addb    %al,%cl
    roll    $21,%r9d
    movl    $-1,%r12d
    pinsrw    $5,(%rdi,%rbx,4),%xmm1

    addl    %r10d,%r9d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r11d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    orl    %r9d,%r12d
    addl    16(%r15),%r8d
    addb    %dl,%al
    movl    116(%rsi),%ebx
    addl    $4149444226,%r8d
    movzbl    %al,%eax
    xorl    %r10d,%r12d
    movl    %edx,112(%rsi)
    addl    %r12d,%r8d
    addb    %bl,%cl
    roll    $6,%r8d
    movl    $-1,%r12d
    pinsrw    $6,(%rdi,%rax,4),%xmm0

    addl    %r9d,%r8d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r10d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    orl    %r8d,%r12d
    addl    44(%r15),%r11d
    addb    %dl,%bl
    movl    120(%rsi),%eax
    addl    $3174756917,%r11d
    movzbl    %bl,%ebx
    xorl    %r9d,%r12d
    movl    %edx,116(%rsi)
    addl    %r12d,%r11d
    addb    %al,%cl
    roll    $10,%r11d
    movl    $-1,%r12d
    pinsrw    $6,(%rdi,%rbx,4),%xmm1

    addl    %r8d,%r11d
    movl    (%rdi,%rcx,4),%edx
    xorl    %r9d,%r12d
    movl    %eax,(%rdi,%rcx,4)
    orl    %r11d,%r12d
    addl    8(%r15),%r10d
    addb    %dl,%al
    movl    124(%rsi),%ebx
    addl    $718787259,%r10d
    movzbl    %al,%eax
    xorl    %r8d,%r12d
    movl    %edx,120(%rsi)
    addl    %r12d,%r10d
    addb    %bl,%cl
    roll    $15,%r10d
    movl    $-1,%r12d
    pinsrw    $7,(%rdi,%rax,4),%xmm0

    addl    %r11d,%r10d
    movdqu    48(%r13),%xmm5
    addb    $32,%bpl
    movl    (%rdi,%rcx,4),%edx
    xorl    %r8d,%r12d
    movl    %ebx,(%rdi,%rcx,4)
    orl    %r10d,%r12d
    addl    36(%r15),%r9d
    addb    %dl,%bl
    movl    0(%rdi,%rbp,4),%eax
    addl    $3951481745,%r9d
    movzbl    %bl,%ebx
    xorl    %r11d,%r12d
    movl    %edx,124(%rsi)
    addl    %r12d,%r9d
    addb    %al,%cl
    roll    $21,%r9d
    movl    $-1,%r12d
    pinsrw    $7,(%rdi,%rbx,4),%xmm1

    addl    %r10d,%r9d
    movq    %rbp,%rsi
    xorq    %rbp,%rbp
    movb    %sil,%bpl
    movq    %rcx,%rsi
    xorq    %rcx,%rcx
    movb    %sil,%cl
    leaq    (%rdi,%rbp,4),%rsi
    psllq    $8,%xmm1
    pxor    %xmm0,%xmm5
    pxor    %xmm1,%xmm5
    addl    0(%rsp),%r8d
    addl    4(%rsp),%r9d
    addl    8(%rsp),%r10d
    addl    12(%rsp),%r11d

    movdqu    %xmm2,(%r14,%r13,1)
    movdqu    %xmm3,16(%r14,%r13,1)
    movdqu    %xmm4,32(%r14,%r13,1)
    movdqu    %xmm5,48(%r14,%r13,1)
    leaq    64(%r15),%r15
    leaq    64(%r13),%r13
    cmpq    16(%rsp),%r15
    jb    .Loop

    movq    24(%rsp),%r12
    subb    %al,%cl
    movl    %r8d,0(%r12)
    movl    %r9d,4(%r12)
    movl    %r10d,8(%r12)
    movl    %r11d,12(%r12)
    subb    $1,%bpl
    movl    %ebp,-8(%rdi)
    movl    %ecx,-4(%rdi)

    movq    40(%rsp),%r15
    movq    48(%rsp),%r14
    movq    56(%rsp),%r13
    movq    64(%rsp),%r12
    movq    72(%rsp),%rbp
    movq    80(%rsp),%rbx
    leaq    88(%rsp),%rsp
.Lepilogue:
.Labort:
    .byte    0xf3,0xc3
.size    rc4_md5_enc,.-rc4_md5_enc