Moxie Marlinspike d83a3d71bc Support for Signal calls.
Merge in RedPhone

// FREEBIE
2015-09-30 14:30:09 -07:00

1260 lines
22 KiB
ArmAsm

.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