You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1259 lines
22 KiB
1259 lines
22 KiB
.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
|
|
|