node/deps/openssl/asm/x64-win32-masm/modes/ghash-x86_64.asm

1203 lines
22 KiB
NASM

OPTION DOTNAME
.text$ SEGMENT ALIGN(64) 'CODE'
PUBLIC gcm_gmult_4bit
ALIGN 16
gcm_gmult_4bit PROC PUBLIC
mov QWORD PTR[8+rsp],rdi ;WIN64 prologue
mov QWORD PTR[16+rsp],rsi
mov rax,rsp
$L$SEH_begin_gcm_gmult_4bit::
mov rdi,rcx
mov rsi,rdx
push rbx
push rbp
push r12
$L$gmult_prologue::
movzx r8,BYTE PTR[15+rdi]
lea r11,QWORD PTR[$L$rem_4bit]
xor rax,rax
xor rbx,rbx
mov al,r8b
mov bl,r8b
shl al,4
mov rcx,14
mov r8,QWORD PTR[8+rax*1+rsi]
mov r9,QWORD PTR[rax*1+rsi]
and bl,0f0h
mov rdx,r8
jmp $L$oop1
ALIGN 16
$L$oop1::
shr r8,4
and rdx,0fh
mov r10,r9
mov al,BYTE PTR[rcx*1+rdi]
shr r9,4
xor r8,QWORD PTR[8+rbx*1+rsi]
shl r10,60
xor r9,QWORD PTR[rbx*1+rsi]
mov bl,al
xor r9,QWORD PTR[rdx*8+r11]
mov rdx,r8
shl al,4
xor r8,r10
dec rcx
js $L$break1
shr r8,4
and rdx,0fh
mov r10,r9
shr r9,4
xor r8,QWORD PTR[8+rax*1+rsi]
shl r10,60
xor r9,QWORD PTR[rax*1+rsi]
and bl,0f0h
xor r9,QWORD PTR[rdx*8+r11]
mov rdx,r8
xor r8,r10
jmp $L$oop1
ALIGN 16
$L$break1::
shr r8,4
and rdx,0fh
mov r10,r9
shr r9,4
xor r8,QWORD PTR[8+rax*1+rsi]
shl r10,60
xor r9,QWORD PTR[rax*1+rsi]
and bl,0f0h
xor r9,QWORD PTR[rdx*8+r11]
mov rdx,r8
xor r8,r10
shr r8,4
and rdx,0fh
mov r10,r9
shr r9,4
xor r8,QWORD PTR[8+rbx*1+rsi]
shl r10,60
xor r9,QWORD PTR[rbx*1+rsi]
xor r8,r10
xor r9,QWORD PTR[rdx*8+r11]
bswap r8
bswap r9
mov QWORD PTR[8+rdi],r8
mov QWORD PTR[rdi],r9
mov rbx,QWORD PTR[16+rsp]
lea rsp,QWORD PTR[24+rsp]
$L$gmult_epilogue::
mov rdi,QWORD PTR[8+rsp] ;WIN64 epilogue
mov rsi,QWORD PTR[16+rsp]
DB 0F3h,0C3h ;repret
$L$SEH_end_gcm_gmult_4bit::
gcm_gmult_4bit ENDP
PUBLIC gcm_ghash_4bit
ALIGN 16
gcm_ghash_4bit PROC PUBLIC
mov QWORD PTR[8+rsp],rdi ;WIN64 prologue
mov QWORD PTR[16+rsp],rsi
mov rax,rsp
$L$SEH_begin_gcm_ghash_4bit::
mov rdi,rcx
mov rsi,rdx
mov rdx,r8
mov rcx,r9
push rbx
push rbp
push r12
push r13
push r14
push r15
sub rsp,280
$L$ghash_prologue::
mov r14,rdx
mov r15,rcx
sub rsi,-128
lea rbp,QWORD PTR[((16+128))+rsp]
xor edx,edx
mov r8,QWORD PTR[((0+0-128))+rsi]
mov rax,QWORD PTR[((0+8-128))+rsi]
mov dl,al
shr rax,4
mov r10,r8
shr r8,4
mov r9,QWORD PTR[((16+0-128))+rsi]
shl dl,4
mov rbx,QWORD PTR[((16+8-128))+rsi]
shl r10,60
mov BYTE PTR[rsp],dl
or rax,r10
mov dl,bl
shr rbx,4
mov r10,r9
shr r9,4
mov QWORD PTR[rbp],r8
mov r8,QWORD PTR[((32+0-128))+rsi]
shl dl,4
mov QWORD PTR[((0-128))+rbp],rax
mov rax,QWORD PTR[((32+8-128))+rsi]
shl r10,60
mov BYTE PTR[1+rsp],dl
or rbx,r10
mov dl,al
shr rax,4
mov r10,r8
shr r8,4
mov QWORD PTR[8+rbp],r9
mov r9,QWORD PTR[((48+0-128))+rsi]
shl dl,4
mov QWORD PTR[((8-128))+rbp],rbx
mov rbx,QWORD PTR[((48+8-128))+rsi]
shl r10,60
mov BYTE PTR[2+rsp],dl
or rax,r10
mov dl,bl
shr rbx,4
mov r10,r9
shr r9,4
mov QWORD PTR[16+rbp],r8
mov r8,QWORD PTR[((64+0-128))+rsi]
shl dl,4
mov QWORD PTR[((16-128))+rbp],rax
mov rax,QWORD PTR[((64+8-128))+rsi]
shl r10,60
mov BYTE PTR[3+rsp],dl
or rbx,r10
mov dl,al
shr rax,4
mov r10,r8
shr r8,4
mov QWORD PTR[24+rbp],r9
mov r9,QWORD PTR[((80+0-128))+rsi]
shl dl,4
mov QWORD PTR[((24-128))+rbp],rbx
mov rbx,QWORD PTR[((80+8-128))+rsi]
shl r10,60
mov BYTE PTR[4+rsp],dl
or rax,r10
mov dl,bl
shr rbx,4
mov r10,r9
shr r9,4
mov QWORD PTR[32+rbp],r8
mov r8,QWORD PTR[((96+0-128))+rsi]
shl dl,4
mov QWORD PTR[((32-128))+rbp],rax
mov rax,QWORD PTR[((96+8-128))+rsi]
shl r10,60
mov BYTE PTR[5+rsp],dl
or rbx,r10
mov dl,al
shr rax,4
mov r10,r8
shr r8,4
mov QWORD PTR[40+rbp],r9
mov r9,QWORD PTR[((112+0-128))+rsi]
shl dl,4
mov QWORD PTR[((40-128))+rbp],rbx
mov rbx,QWORD PTR[((112+8-128))+rsi]
shl r10,60
mov BYTE PTR[6+rsp],dl
or rax,r10
mov dl,bl
shr rbx,4
mov r10,r9
shr r9,4
mov QWORD PTR[48+rbp],r8
mov r8,QWORD PTR[((128+0-128))+rsi]
shl dl,4
mov QWORD PTR[((48-128))+rbp],rax
mov rax,QWORD PTR[((128+8-128))+rsi]
shl r10,60
mov BYTE PTR[7+rsp],dl
or rbx,r10
mov dl,al
shr rax,4
mov r10,r8
shr r8,4
mov QWORD PTR[56+rbp],r9
mov r9,QWORD PTR[((144+0-128))+rsi]
shl dl,4
mov QWORD PTR[((56-128))+rbp],rbx
mov rbx,QWORD PTR[((144+8-128))+rsi]
shl r10,60
mov BYTE PTR[8+rsp],dl
or rax,r10
mov dl,bl
shr rbx,4
mov r10,r9
shr r9,4
mov QWORD PTR[64+rbp],r8
mov r8,QWORD PTR[((160+0-128))+rsi]
shl dl,4
mov QWORD PTR[((64-128))+rbp],rax
mov rax,QWORD PTR[((160+8-128))+rsi]
shl r10,60
mov BYTE PTR[9+rsp],dl
or rbx,r10
mov dl,al
shr rax,4
mov r10,r8
shr r8,4
mov QWORD PTR[72+rbp],r9
mov r9,QWORD PTR[((176+0-128))+rsi]
shl dl,4
mov QWORD PTR[((72-128))+rbp],rbx
mov rbx,QWORD PTR[((176+8-128))+rsi]
shl r10,60
mov BYTE PTR[10+rsp],dl
or rax,r10
mov dl,bl
shr rbx,4
mov r10,r9
shr r9,4
mov QWORD PTR[80+rbp],r8
mov r8,QWORD PTR[((192+0-128))+rsi]
shl dl,4
mov QWORD PTR[((80-128))+rbp],rax
mov rax,QWORD PTR[((192+8-128))+rsi]
shl r10,60
mov BYTE PTR[11+rsp],dl
or rbx,r10
mov dl,al
shr rax,4
mov r10,r8
shr r8,4
mov QWORD PTR[88+rbp],r9
mov r9,QWORD PTR[((208+0-128))+rsi]
shl dl,4
mov QWORD PTR[((88-128))+rbp],rbx
mov rbx,QWORD PTR[((208+8-128))+rsi]
shl r10,60
mov BYTE PTR[12+rsp],dl
or rax,r10
mov dl,bl
shr rbx,4
mov r10,r9
shr r9,4
mov QWORD PTR[96+rbp],r8
mov r8,QWORD PTR[((224+0-128))+rsi]
shl dl,4
mov QWORD PTR[((96-128))+rbp],rax
mov rax,QWORD PTR[((224+8-128))+rsi]
shl r10,60
mov BYTE PTR[13+rsp],dl
or rbx,r10
mov dl,al
shr rax,4
mov r10,r8
shr r8,4
mov QWORD PTR[104+rbp],r9
mov r9,QWORD PTR[((240+0-128))+rsi]
shl dl,4
mov QWORD PTR[((104-128))+rbp],rbx
mov rbx,QWORD PTR[((240+8-128))+rsi]
shl r10,60
mov BYTE PTR[14+rsp],dl
or rax,r10
mov dl,bl
shr rbx,4
mov r10,r9
shr r9,4
mov QWORD PTR[112+rbp],r8
shl dl,4
mov QWORD PTR[((112-128))+rbp],rax
shl r10,60
mov BYTE PTR[15+rsp],dl
or rbx,r10
mov QWORD PTR[120+rbp],r9
mov QWORD PTR[((120-128))+rbp],rbx
add rsi,-128
mov r8,QWORD PTR[8+rdi]
mov r9,QWORD PTR[rdi]
add r15,r14
lea r11,QWORD PTR[$L$rem_8bit]
jmp $L$outer_loop
ALIGN 16
$L$outer_loop::
xor r9,QWORD PTR[r14]
mov rdx,QWORD PTR[8+r14]
lea r14,QWORD PTR[16+r14]
xor rdx,r8
mov QWORD PTR[rdi],r9
mov QWORD PTR[8+rdi],rdx
shr rdx,32
xor rax,rax
rol edx,8
mov al,dl
movzx ebx,dl
shl al,4
shr ebx,4
rol edx,8
mov r8,QWORD PTR[8+rax*1+rsi]
mov r9,QWORD PTR[rax*1+rsi]
mov al,dl
movzx ecx,dl
shl al,4
movzx r12,BYTE PTR[rbx*1+rsp]
shr ecx,4
xor r12,r8
mov r10,r9
shr r8,8
movzx r12,r12b
shr r9,8
xor r8,QWORD PTR[((-128))+rbx*8+rbp]
shl r10,56
xor r9,QWORD PTR[rbx*8+rbp]
rol edx,8
xor r8,QWORD PTR[8+rax*1+rsi]
xor r9,QWORD PTR[rax*1+rsi]
mov al,dl
xor r8,r10
movzx r12,WORD PTR[r12*2+r11]
movzx ebx,dl
shl al,4
movzx r13,BYTE PTR[rcx*1+rsp]
shr ebx,4
shl r12,48
xor r13,r8
mov r10,r9
xor r9,r12
shr r8,8
movzx r13,r13b
shr r9,8
xor r8,QWORD PTR[((-128))+rcx*8+rbp]
shl r10,56
xor r9,QWORD PTR[rcx*8+rbp]
rol edx,8
xor r8,QWORD PTR[8+rax*1+rsi]
xor r9,QWORD PTR[rax*1+rsi]
mov al,dl
xor r8,r10
movzx r13,WORD PTR[r13*2+r11]
movzx ecx,dl
shl al,4
movzx r12,BYTE PTR[rbx*1+rsp]
shr ecx,4
shl r13,48
xor r12,r8
mov r10,r9
xor r9,r13
shr r8,8
movzx r12,r12b
mov edx,DWORD PTR[8+rdi]
shr r9,8
xor r8,QWORD PTR[((-128))+rbx*8+rbp]
shl r10,56
xor r9,QWORD PTR[rbx*8+rbp]
rol edx,8
xor r8,QWORD PTR[8+rax*1+rsi]
xor r9,QWORD PTR[rax*1+rsi]
mov al,dl
xor r8,r10
movzx r12,WORD PTR[r12*2+r11]
movzx ebx,dl
shl al,4
movzx r13,BYTE PTR[rcx*1+rsp]
shr ebx,4
shl r12,48
xor r13,r8
mov r10,r9
xor r9,r12
shr r8,8
movzx r13,r13b
shr r9,8
xor r8,QWORD PTR[((-128))+rcx*8+rbp]
shl r10,56
xor r9,QWORD PTR[rcx*8+rbp]
rol edx,8
xor r8,QWORD PTR[8+rax*1+rsi]
xor r9,QWORD PTR[rax*1+rsi]
mov al,dl
xor r8,r10
movzx r13,WORD PTR[r13*2+r11]
movzx ecx,dl
shl al,4
movzx r12,BYTE PTR[rbx*1+rsp]
shr ecx,4
shl r13,48
xor r12,r8
mov r10,r9
xor r9,r13
shr r8,8
movzx r12,r12b
shr r9,8
xor r8,QWORD PTR[((-128))+rbx*8+rbp]
shl r10,56
xor r9,QWORD PTR[rbx*8+rbp]
rol edx,8
xor r8,QWORD PTR[8+rax*1+rsi]
xor r9,QWORD PTR[rax*1+rsi]
mov al,dl
xor r8,r10
movzx r12,WORD PTR[r12*2+r11]
movzx ebx,dl
shl al,4
movzx r13,BYTE PTR[rcx*1+rsp]
shr ebx,4
shl r12,48
xor r13,r8
mov r10,r9
xor r9,r12
shr r8,8
movzx r13,r13b
shr r9,8
xor r8,QWORD PTR[((-128))+rcx*8+rbp]
shl r10,56
xor r9,QWORD PTR[rcx*8+rbp]
rol edx,8
xor r8,QWORD PTR[8+rax*1+rsi]
xor r9,QWORD PTR[rax*1+rsi]
mov al,dl
xor r8,r10
movzx r13,WORD PTR[r13*2+r11]
movzx ecx,dl
shl al,4
movzx r12,BYTE PTR[rbx*1+rsp]
shr ecx,4
shl r13,48
xor r12,r8
mov r10,r9
xor r9,r13
shr r8,8
movzx r12,r12b
mov edx,DWORD PTR[4+rdi]
shr r9,8
xor r8,QWORD PTR[((-128))+rbx*8+rbp]
shl r10,56
xor r9,QWORD PTR[rbx*8+rbp]
rol edx,8
xor r8,QWORD PTR[8+rax*1+rsi]
xor r9,QWORD PTR[rax*1+rsi]
mov al,dl
xor r8,r10
movzx r12,WORD PTR[r12*2+r11]
movzx ebx,dl
shl al,4
movzx r13,BYTE PTR[rcx*1+rsp]
shr ebx,4
shl r12,48
xor r13,r8
mov r10,r9
xor r9,r12
shr r8,8
movzx r13,r13b
shr r9,8
xor r8,QWORD PTR[((-128))+rcx*8+rbp]
shl r10,56
xor r9,QWORD PTR[rcx*8+rbp]
rol edx,8
xor r8,QWORD PTR[8+rax*1+rsi]
xor r9,QWORD PTR[rax*1+rsi]
mov al,dl
xor r8,r10
movzx r13,WORD PTR[r13*2+r11]
movzx ecx,dl
shl al,4
movzx r12,BYTE PTR[rbx*1+rsp]
shr ecx,4
shl r13,48
xor r12,r8
mov r10,r9
xor r9,r13
shr r8,8
movzx r12,r12b
shr r9,8
xor r8,QWORD PTR[((-128))+rbx*8+rbp]
shl r10,56
xor r9,QWORD PTR[rbx*8+rbp]
rol edx,8
xor r8,QWORD PTR[8+rax*1+rsi]
xor r9,QWORD PTR[rax*1+rsi]
mov al,dl
xor r8,r10
movzx r12,WORD PTR[r12*2+r11]
movzx ebx,dl
shl al,4
movzx r13,BYTE PTR[rcx*1+rsp]
shr ebx,4
shl r12,48
xor r13,r8
mov r10,r9
xor r9,r12
shr r8,8
movzx r13,r13b
shr r9,8
xor r8,QWORD PTR[((-128))+rcx*8+rbp]
shl r10,56
xor r9,QWORD PTR[rcx*8+rbp]
rol edx,8
xor r8,QWORD PTR[8+rax*1+rsi]
xor r9,QWORD PTR[rax*1+rsi]
mov al,dl
xor r8,r10
movzx r13,WORD PTR[r13*2+r11]
movzx ecx,dl
shl al,4
movzx r12,BYTE PTR[rbx*1+rsp]
shr ecx,4
shl r13,48
xor r12,r8
mov r10,r9
xor r9,r13
shr r8,8
movzx r12,r12b
mov edx,DWORD PTR[rdi]
shr r9,8
xor r8,QWORD PTR[((-128))+rbx*8+rbp]
shl r10,56
xor r9,QWORD PTR[rbx*8+rbp]
rol edx,8
xor r8,QWORD PTR[8+rax*1+rsi]
xor r9,QWORD PTR[rax*1+rsi]
mov al,dl
xor r8,r10
movzx r12,WORD PTR[r12*2+r11]
movzx ebx,dl
shl al,4
movzx r13,BYTE PTR[rcx*1+rsp]
shr ebx,4
shl r12,48
xor r13,r8
mov r10,r9
xor r9,r12
shr r8,8
movzx r13,r13b
shr r9,8
xor r8,QWORD PTR[((-128))+rcx*8+rbp]
shl r10,56
xor r9,QWORD PTR[rcx*8+rbp]
rol edx,8
xor r8,QWORD PTR[8+rax*1+rsi]
xor r9,QWORD PTR[rax*1+rsi]
mov al,dl
xor r8,r10
movzx r13,WORD PTR[r13*2+r11]
movzx ecx,dl
shl al,4
movzx r12,BYTE PTR[rbx*1+rsp]
shr ecx,4
shl r13,48
xor r12,r8
mov r10,r9
xor r9,r13
shr r8,8
movzx r12,r12b
shr r9,8
xor r8,QWORD PTR[((-128))+rbx*8+rbp]
shl r10,56
xor r9,QWORD PTR[rbx*8+rbp]
rol edx,8
xor r8,QWORD PTR[8+rax*1+rsi]
xor r9,QWORD PTR[rax*1+rsi]
mov al,dl
xor r8,r10
movzx r12,WORD PTR[r12*2+r11]
movzx ebx,dl
shl al,4
movzx r13,BYTE PTR[rcx*1+rsp]
shr ebx,4
shl r12,48
xor r13,r8
mov r10,r9
xor r9,r12
shr r8,8
movzx r13,r13b
shr r9,8
xor r8,QWORD PTR[((-128))+rcx*8+rbp]
shl r10,56
xor r9,QWORD PTR[rcx*8+rbp]
rol edx,8
xor r8,QWORD PTR[8+rax*1+rsi]
xor r9,QWORD PTR[rax*1+rsi]
mov al,dl
xor r8,r10
movzx r13,WORD PTR[r13*2+r11]
movzx ecx,dl
shl al,4
movzx r12,BYTE PTR[rbx*1+rsp]
and ecx,240
shl r13,48
xor r12,r8
mov r10,r9
xor r9,r13
shr r8,8
movzx r12,r12b
mov edx,DWORD PTR[((-4))+rdi]
shr r9,8
xor r8,QWORD PTR[((-128))+rbx*8+rbp]
shl r10,56
xor r9,QWORD PTR[rbx*8+rbp]
movzx r12,WORD PTR[r12*2+r11]
xor r8,QWORD PTR[8+rax*1+rsi]
xor r9,QWORD PTR[rax*1+rsi]
shl r12,48
xor r8,r10
xor r9,r12
movzx r13,r8b
shr r8,4
mov r10,r9
shl r13b,4
shr r9,4
xor r8,QWORD PTR[8+rcx*1+rsi]
movzx r13,WORD PTR[r13*2+r11]
shl r10,60
xor r9,QWORD PTR[rcx*1+rsi]
xor r8,r10
shl r13,48
bswap r8
xor r9,r13
bswap r9
cmp r14,r15
jb $L$outer_loop
mov QWORD PTR[8+rdi],r8
mov QWORD PTR[rdi],r9
lea rsi,QWORD PTR[280+rsp]
mov r15,QWORD PTR[rsi]
mov r14,QWORD PTR[8+rsi]
mov r13,QWORD PTR[16+rsi]
mov r12,QWORD PTR[24+rsi]
mov rbp,QWORD PTR[32+rsi]
mov rbx,QWORD PTR[40+rsi]
lea rsp,QWORD PTR[48+rsi]
$L$ghash_epilogue::
mov rdi,QWORD PTR[8+rsp] ;WIN64 epilogue
mov rsi,QWORD PTR[16+rsp]
DB 0F3h,0C3h ;repret
$L$SEH_end_gcm_ghash_4bit::
gcm_ghash_4bit ENDP
PUBLIC gcm_init_clmul
ALIGN 16
gcm_init_clmul PROC PUBLIC
movdqu xmm2,XMMWORD PTR[rdx]
pshufd xmm2,xmm2,78
pshufd xmm4,xmm2,255
movdqa xmm3,xmm2
psllq xmm2,1
pxor xmm5,xmm5
psrlq xmm3,63
pcmpgtd xmm5,xmm4
pslldq xmm3,8
por xmm2,xmm3
pand xmm5,XMMWORD PTR[$L$0x1c2_polynomial]
pxor xmm2,xmm5
movdqa xmm0,xmm2
movdqa xmm1,xmm0
pshufd xmm3,xmm0,78
pshufd xmm4,xmm2,78
pxor xmm3,xmm0
pxor xmm4,xmm2
DB 102,15,58,68,194,0
DB 102,15,58,68,202,17
DB 102,15,58,68,220,0
pxor xmm3,xmm0
pxor xmm3,xmm1
movdqa xmm4,xmm3
psrldq xmm3,8
pslldq xmm4,8
pxor xmm1,xmm3
pxor xmm0,xmm4
movdqa xmm3,xmm0
psllq xmm0,1
pxor xmm0,xmm3
psllq xmm0,5
pxor xmm0,xmm3
psllq xmm0,57
movdqa xmm4,xmm0
pslldq xmm0,8
psrldq xmm4,8
pxor xmm0,xmm3
pxor xmm1,xmm4
movdqa xmm4,xmm0
psrlq xmm0,5
pxor xmm0,xmm4
psrlq xmm0,1
pxor xmm0,xmm4
pxor xmm4,xmm1
psrlq xmm0,1
pxor xmm0,xmm4
movdqu XMMWORD PTR[rcx],xmm2
movdqu XMMWORD PTR[16+rcx],xmm0
DB 0F3h,0C3h ;repret
gcm_init_clmul ENDP
PUBLIC gcm_gmult_clmul
ALIGN 16
gcm_gmult_clmul PROC PUBLIC
movdqu xmm0,XMMWORD PTR[rcx]
movdqa xmm5,XMMWORD PTR[$L$bswap_mask]
movdqu xmm2,XMMWORD PTR[rdx]
DB 102,15,56,0,197
movdqa xmm1,xmm0
pshufd xmm3,xmm0,78
pshufd xmm4,xmm2,78
pxor xmm3,xmm0
pxor xmm4,xmm2
DB 102,15,58,68,194,0
DB 102,15,58,68,202,17
DB 102,15,58,68,220,0
pxor xmm3,xmm0
pxor xmm3,xmm1
movdqa xmm4,xmm3
psrldq xmm3,8
pslldq xmm4,8
pxor xmm1,xmm3
pxor xmm0,xmm4
movdqa xmm3,xmm0
psllq xmm0,1
pxor xmm0,xmm3
psllq xmm0,5
pxor xmm0,xmm3
psllq xmm0,57
movdqa xmm4,xmm0
pslldq xmm0,8
psrldq xmm4,8
pxor xmm0,xmm3
pxor xmm1,xmm4
movdqa xmm4,xmm0
psrlq xmm0,5
pxor xmm0,xmm4
psrlq xmm0,1
pxor xmm0,xmm4
pxor xmm4,xmm1
psrlq xmm0,1
pxor xmm0,xmm4
DB 102,15,56,0,197
movdqu XMMWORD PTR[rcx],xmm0
DB 0F3h,0C3h ;repret
gcm_gmult_clmul ENDP
PUBLIC gcm_ghash_clmul
ALIGN 16
gcm_ghash_clmul PROC PUBLIC
$L$SEH_begin_gcm_ghash_clmul::
DB 048h,083h,0ech,058h
DB 00fh,029h,034h,024h
DB 00fh,029h,07ch,024h,010h
DB 044h,00fh,029h,044h,024h,020h
DB 044h,00fh,029h,04ch,024h,030h
DB 044h,00fh,029h,054h,024h,040h
movdqa xmm5,XMMWORD PTR[$L$bswap_mask]
movdqu xmm0,XMMWORD PTR[rcx]
movdqu xmm2,XMMWORD PTR[rdx]
DB 102,15,56,0,197
sub r9,010h
jz $L$odd_tail
movdqu xmm8,XMMWORD PTR[16+rdx]
movdqu xmm3,XMMWORD PTR[r8]
movdqu xmm6,XMMWORD PTR[16+r8]
DB 102,15,56,0,221
DB 102,15,56,0,245
pxor xmm0,xmm3
movdqa xmm7,xmm6
pshufd xmm3,xmm6,78
pshufd xmm4,xmm2,78
pxor xmm3,xmm6
pxor xmm4,xmm2
DB 102,15,58,68,242,0
DB 102,15,58,68,250,17
DB 102,15,58,68,220,0
pxor xmm3,xmm6
pxor xmm3,xmm7
movdqa xmm4,xmm3
psrldq xmm3,8
pslldq xmm4,8
pxor xmm7,xmm3
pxor xmm6,xmm4
movdqa xmm1,xmm0
pshufd xmm3,xmm0,78
pshufd xmm4,xmm8,78
pxor xmm3,xmm0
pxor xmm4,xmm8
lea r8,QWORD PTR[32+r8]
sub r9,020h
jbe $L$even_tail
$L$mod_loop::
DB 102,65,15,58,68,192,0
DB 102,65,15,58,68,200,17
DB 102,15,58,68,220,0
pxor xmm3,xmm0
pxor xmm3,xmm1
movdqa xmm4,xmm3
psrldq xmm3,8
pslldq xmm4,8
pxor xmm1,xmm3
pxor xmm0,xmm4
movdqu xmm3,XMMWORD PTR[r8]
pxor xmm0,xmm6
pxor xmm1,xmm7
movdqu xmm6,XMMWORD PTR[16+r8]
DB 102,15,56,0,221
DB 102,15,56,0,245
movdqa xmm7,xmm6
pshufd xmm9,xmm6,78
pshufd xmm10,xmm2,78
pxor xmm9,xmm6
pxor xmm10,xmm2
pxor xmm1,xmm3
movdqa xmm3,xmm0
psllq xmm0,1
pxor xmm0,xmm3
psllq xmm0,5
pxor xmm0,xmm3
DB 102,15,58,68,242,0
psllq xmm0,57
movdqa xmm4,xmm0
pslldq xmm0,8
psrldq xmm4,8
pxor xmm0,xmm3
pxor xmm1,xmm4
DB 102,15,58,68,250,17
movdqa xmm4,xmm0
psrlq xmm0,5
pxor xmm0,xmm4
psrlq xmm0,1
pxor xmm0,xmm4
pxor xmm4,xmm1
psrlq xmm0,1
pxor xmm0,xmm4
DB 102,69,15,58,68,202,0
movdqa xmm1,xmm0
pshufd xmm3,xmm0,78
pshufd xmm4,xmm8,78
pxor xmm3,xmm0
pxor xmm4,xmm8
pxor xmm9,xmm6
pxor xmm9,xmm7
movdqa xmm10,xmm9
psrldq xmm9,8
pslldq xmm10,8
pxor xmm7,xmm9
pxor xmm6,xmm10
lea r8,QWORD PTR[32+r8]
sub r9,020h
ja $L$mod_loop
$L$even_tail::
DB 102,65,15,58,68,192,0
DB 102,65,15,58,68,200,17
DB 102,15,58,68,220,0
pxor xmm3,xmm0
pxor xmm3,xmm1
movdqa xmm4,xmm3
psrldq xmm3,8
pslldq xmm4,8
pxor xmm1,xmm3
pxor xmm0,xmm4
pxor xmm0,xmm6
pxor xmm1,xmm7
movdqa xmm3,xmm0
psllq xmm0,1
pxor xmm0,xmm3
psllq xmm0,5
pxor xmm0,xmm3
psllq xmm0,57
movdqa xmm4,xmm0
pslldq xmm0,8
psrldq xmm4,8
pxor xmm0,xmm3
pxor xmm1,xmm4
movdqa xmm4,xmm0
psrlq xmm0,5
pxor xmm0,xmm4
psrlq xmm0,1
pxor xmm0,xmm4
pxor xmm4,xmm1
psrlq xmm0,1
pxor xmm0,xmm4
test r9,r9
jnz $L$done
$L$odd_tail::
movdqu xmm3,XMMWORD PTR[r8]
DB 102,15,56,0,221
pxor xmm0,xmm3
movdqa xmm1,xmm0
pshufd xmm3,xmm0,78
pshufd xmm4,xmm2,78
pxor xmm3,xmm0
pxor xmm4,xmm2
DB 102,15,58,68,194,0
DB 102,15,58,68,202,17
DB 102,15,58,68,220,0
pxor xmm3,xmm0
pxor xmm3,xmm1
movdqa xmm4,xmm3
psrldq xmm3,8
pslldq xmm4,8
pxor xmm1,xmm3
pxor xmm0,xmm4
movdqa xmm3,xmm0
psllq xmm0,1
pxor xmm0,xmm3
psllq xmm0,5
pxor xmm0,xmm3
psllq xmm0,57
movdqa xmm4,xmm0
pslldq xmm0,8
psrldq xmm4,8
pxor xmm0,xmm3
pxor xmm1,xmm4
movdqa xmm4,xmm0
psrlq xmm0,5
pxor xmm0,xmm4
psrlq xmm0,1
pxor xmm0,xmm4
pxor xmm4,xmm1
psrlq xmm0,1
pxor xmm0,xmm4
$L$done::
DB 102,15,56,0,197
movdqu XMMWORD PTR[rcx],xmm0
movaps xmm6,XMMWORD PTR[rsp]
movaps xmm7,XMMWORD PTR[16+rsp]
movaps xmm8,XMMWORD PTR[32+rsp]
movaps xmm9,XMMWORD PTR[48+rsp]
movaps xmm10,XMMWORD PTR[64+rsp]
add rsp,058h
DB 0F3h,0C3h ;repret
$L$SEH_end_gcm_ghash_clmul::
gcm_ghash_clmul ENDP
ALIGN 64
$L$bswap_mask::
DB 15,14,13,12,11,10,9,8,7,6,5,4,3,2,1,0
$L$0x1c2_polynomial::
DB 1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0c2h
ALIGN 64
$L$rem_4bit::
DD 0,0,0,471859200,0,943718400,0,610271232
DD 0,1887436800,0,1822425088,0,1220542464,0,1423966208
DD 0,3774873600,0,4246732800,0,3644850176,0,3311403008
DD 0,2441084928,0,2376073216,0,2847932416,0,3051356160
$L$rem_8bit::
DW 00000h,001C2h,00384h,00246h,00708h,006CAh,0048Ch,0054Eh
DW 00E10h,00FD2h,00D94h,00C56h,00918h,008DAh,00A9Ch,00B5Eh
DW 01C20h,01DE2h,01FA4h,01E66h,01B28h,01AEAh,018ACh,0196Eh
DW 01230h,013F2h,011B4h,01076h,01538h,014FAh,016BCh,0177Eh
DW 03840h,03982h,03BC4h,03A06h,03F48h,03E8Ah,03CCCh,03D0Eh
DW 03650h,03792h,035D4h,03416h,03158h,0309Ah,032DCh,0331Eh
DW 02460h,025A2h,027E4h,02626h,02368h,022AAh,020ECh,0212Eh
DW 02A70h,02BB2h,029F4h,02836h,02D78h,02CBAh,02EFCh,02F3Eh
DW 07080h,07142h,07304h,072C6h,07788h,0764Ah,0740Ch,075CEh
DW 07E90h,07F52h,07D14h,07CD6h,07998h,0785Ah,07A1Ch,07BDEh
DW 06CA0h,06D62h,06F24h,06EE6h,06BA8h,06A6Ah,0682Ch,069EEh
DW 062B0h,06372h,06134h,060F6h,065B8h,0647Ah,0663Ch,067FEh
DW 048C0h,04902h,04B44h,04A86h,04FC8h,04E0Ah,04C4Ch,04D8Eh
DW 046D0h,04712h,04554h,04496h,041D8h,0401Ah,0425Ch,0439Eh
DW 054E0h,05522h,05764h,056A6h,053E8h,0522Ah,0506Ch,051AEh
DW 05AF0h,05B32h,05974h,058B6h,05DF8h,05C3Ah,05E7Ch,05FBEh
DW 0E100h,0E0C2h,0E284h,0E346h,0E608h,0E7CAh,0E58Ch,0E44Eh
DW 0EF10h,0EED2h,0EC94h,0ED56h,0E818h,0E9DAh,0EB9Ch,0EA5Eh
DW 0FD20h,0FCE2h,0FEA4h,0FF66h,0FA28h,0FBEAh,0F9ACh,0F86Eh
DW 0F330h,0F2F2h,0F0B4h,0F176h,0F438h,0F5FAh,0F7BCh,0F67Eh
DW 0D940h,0D882h,0DAC4h,0DB06h,0DE48h,0DF8Ah,0DDCCh,0DC0Eh
DW 0D750h,0D692h,0D4D4h,0D516h,0D058h,0D19Ah,0D3DCh,0D21Eh
DW 0C560h,0C4A2h,0C6E4h,0C726h,0C268h,0C3AAh,0C1ECh,0C02Eh
DW 0CB70h,0CAB2h,0C8F4h,0C936h,0CC78h,0CDBAh,0CFFCh,0CE3Eh
DW 09180h,09042h,09204h,093C6h,09688h,0974Ah,0950Ch,094CEh
DW 09F90h,09E52h,09C14h,09DD6h,09898h,0995Ah,09B1Ch,09ADEh
DW 08DA0h,08C62h,08E24h,08FE6h,08AA8h,08B6Ah,0892Ch,088EEh
DW 083B0h,08272h,08034h,081F6h,084B8h,0857Ah,0873Ch,086FEh
DW 0A9C0h,0A802h,0AA44h,0AB86h,0AEC8h,0AF0Ah,0AD4Ch,0AC8Eh
DW 0A7D0h,0A612h,0A454h,0A596h,0A0D8h,0A11Ah,0A35Ch,0A29Eh
DW 0B5E0h,0B422h,0B664h,0B7A6h,0B2E8h,0B32Ah,0B16Ch,0B0AEh
DW 0BBF0h,0BA32h,0B874h,0B9B6h,0BCF8h,0BD3Ah,0BF7Ch,0BEBEh
DB 71,72,65,83,72,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
EXTERN __imp_RtlVirtualUnwind:NEAR
ALIGN 16
se_handler PROC PRIVATE
push rsi
push rdi
push rbx
push rbp
push r12
push r13
push r14
push r15
pushfq
sub rsp,64
mov rax,QWORD PTR[120+r8]
mov rbx,QWORD PTR[248+r8]
mov rsi,QWORD PTR[8+r9]
mov r11,QWORD PTR[56+r9]
mov r10d,DWORD PTR[r11]
lea r10,QWORD PTR[r10*1+rsi]
cmp rbx,r10
jb $L$in_prologue
mov rax,QWORD PTR[152+r8]
mov r10d,DWORD PTR[4+r11]
lea r10,QWORD PTR[r10*1+rsi]
cmp rbx,r10
jae $L$in_prologue
lea rax,QWORD PTR[24+rax]
mov rbx,QWORD PTR[((-8))+rax]
mov rbp,QWORD PTR[((-16))+rax]
mov r12,QWORD PTR[((-24))+rax]
mov QWORD PTR[144+r8],rbx
mov QWORD PTR[160+r8],rbp
mov QWORD PTR[216+r8],r12
$L$in_prologue::
mov rdi,QWORD PTR[8+rax]
mov rsi,QWORD PTR[16+rax]
mov QWORD PTR[152+r8],rax
mov QWORD PTR[168+r8],rsi
mov QWORD PTR[176+r8],rdi
mov rdi,QWORD PTR[40+r9]
mov rsi,r8
mov ecx,154
DD 0a548f3fch
mov rsi,r9
xor rcx,rcx
mov rdx,QWORD PTR[8+rsi]
mov r8,QWORD PTR[rsi]
mov r9,QWORD PTR[16+rsi]
mov r10,QWORD PTR[40+rsi]
lea r11,QWORD PTR[56+rsi]
lea r12,QWORD PTR[24+rsi]
mov QWORD PTR[32+rsp],r10
mov QWORD PTR[40+rsp],r11
mov QWORD PTR[48+rsp],r12
mov QWORD PTR[56+rsp],rcx
call QWORD PTR[__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
se_handler ENDP
.text$ ENDS
.pdata SEGMENT READONLY ALIGN(4)
ALIGN 4
DD imagerel $L$SEH_begin_gcm_gmult_4bit
DD imagerel $L$SEH_end_gcm_gmult_4bit
DD imagerel $L$SEH_info_gcm_gmult_4bit
DD imagerel $L$SEH_begin_gcm_ghash_4bit
DD imagerel $L$SEH_end_gcm_ghash_4bit
DD imagerel $L$SEH_info_gcm_ghash_4bit
DD imagerel $L$SEH_begin_gcm_ghash_clmul
DD imagerel $L$SEH_end_gcm_ghash_clmul
DD imagerel $L$SEH_info_gcm_ghash_clmul
.pdata ENDS
.xdata SEGMENT READONLY ALIGN(8)
ALIGN 8
$L$SEH_info_gcm_gmult_4bit::
DB 9,0,0,0
DD imagerel se_handler
DD imagerel $L$gmult_prologue,imagerel $L$gmult_epilogue
$L$SEH_info_gcm_ghash_4bit::
DB 9,0,0,0
DD imagerel se_handler
DD imagerel $L$ghash_prologue,imagerel $L$ghash_epilogue
$L$SEH_info_gcm_ghash_clmul::
DB 001h,01fh,00bh,000h
DB 01fh,0a8h,004h,000h
DB 019h,098h,003h,000h
DB 013h,088h,002h,000h
DB 00dh,078h,001h,000h
DB 008h,068h,000h,000h
DB 004h,0a2h,000h,000h
.xdata ENDS
END